diff --git a/src/components/Footer.test.jsx b/src/components/Footer.test.jsx
index 55f399f3a..12c416889 100644
--- a/src/components/Footer.test.jsx
+++ b/src/components/Footer.test.jsx
@@ -1,10 +1,13 @@
/* eslint-disable react/prop-types */
import React, { useMemo } from 'react';
import renderer from 'react-test-renderer';
-import { render, fireEvent, screen } from '@testing-library/react';
+import {
+ render, waitFor,
+} from '@testing-library/react';
import { initializeMockApp } from '@edx/frontend-platform';
import { IntlProvider } from '@edx/frontend-platform/i18n';
import { AppContext } from '@edx/frontend-platform/react';
+import '@testing-library/jest-dom';
import Footer from './Footer';
@@ -89,17 +92,21 @@ describe('', () => {
initializeMockApp();
render();
- await fireEvent.submit(screen.getByTestId('site-footer-submit-btn'), {
- target: {
- elements: {
- 'site-footer-language-select': {
- value: 'pt-pt',
- },
- },
- },
+ await waitFor(() => {
+ document.querySelector('.language-selector');
+ });
+ expect(document.querySelectorAll('.language-selector').length).toBe(1);
+
+ document.querySelector('.language-selector>button').click();
+
+ Array.from(document.querySelectorAll('.dropdown-menu.show a')).filter((e) => e.innerHTML === 'Português')[0].click();
+
+ await waitFor(() => {
+ expect(patchPreferences).toHaveBeenCalledWith('user123', { prefLang: 'pt-pt' });
+ });
+ await waitFor(() => {
+ expect(postSetLang).toHaveBeenCalledWith('pt-pt');
});
- expect(patchPreferences).toHaveBeenCalledWith('user123', { prefLang: 'pt-pt' });
- expect(postSetLang).toHaveBeenCalledWith('pt-pt');
});
});
});
diff --git a/src/components/LanguageSelector.jsx b/src/components/LanguageSelector.jsx
index 5c000c60d..f2a55a813 100644
--- a/src/components/LanguageSelector.jsx
+++ b/src/components/LanguageSelector.jsx
@@ -25,58 +25,57 @@ const onLanguageSelected = async (username, selectedLanguageCode) => {
};
const LanguageSelector = ({
- intl, options, authenticatedUser, compact, ...props
+ intl, options, authenticatedUser, compact,
}) => {
-
const languageLabel = (languageCode) => {
- const option = options.find( ({ value, label }) => value === languageCode )
- return option ? option.label : null
- }
+ const option = options.find(({ value }) => value === languageCode);
+ return option ? option.label : null;
+ };
const handleChange = (languageCode, event) => {
const previousSiteLanguage = getLocale();
+ /* eslint-disable no-console */
console.debug(previousSiteLanguage, languageCode, authenticatedUser);
if (previousSiteLanguage !== languageCode) {
onLanguageSelected(authenticatedUser?.username, languageCode);
}
- event.target.parentElement.parentElement.querySelector(".languageLabel").innerHTML = languageLabel(languageCode);
+ const languageLabelElement = event.target.parentElement.parentElement.querySelector('.languageLabel');
+ languageLabelElement.innerHTML = languageLabel(languageCode);
};
- const currentLangLabel = languageLabel(intl.locale)
- const showLabel = !Boolean(compact || false);
+ const currentLangLabel = languageLabel(intl.locale);
+ const showLabel = !(compact || false);
return (
- <>
-
-
-
- {showLabel && (
- currentLangLabel ? (
-
- {currentLangLabel}
-
- ) : (
-
-
-
- )
- )}
-
-
+
+
+
+ {showLabel && (
+ currentLangLabel ? (
+
+ {currentLangLabel}
+
+ ) : (
+
+
+
+ )
+ )}
+
+
{options.map(({ value, label }) => (
{label}
))}
-
-
- >
+
+
);
};
@@ -92,4 +91,8 @@ LanguageSelector.propTypes = {
})).isRequired,
};
+LanguageSelector.defaultProps = {
+ compact: false,
+};
+
export default injectIntl(LanguageSelector);
diff --git a/src/components/__snapshots__/Footer.test.jsx.snap b/src/components/__snapshots__/Footer.test.jsx.snap
index 650c518e3..99d7a2fb8 100644
--- a/src/components/__snapshots__/Footer.test.jsx.snap
+++ b/src/components/__snapshots__/Footer.test.jsx.snap
@@ -36,46 +36,47 @@ exports[` renders correctly renders with a language selector 1`] = `
- FCT|FCCN
All rights reserved
-
-
+