From 42d714e4e8aefe503057db18a3a8face8273a94f Mon Sep 17 00:00:00 2001 From: Awais Ansari <79941147+awais-ansari@users.noreply.github.com> Date: Tue, 17 Sep 2024 17:35:00 +0500 Subject: [PATCH] feat: added country disabling feature (#1116) * feat: added country disabling feature * refactor: removed isDisabledCountry additional call --- src/account-settings/AccountSettingsPage.jsx | 39 +++++++++++++++++++- src/account-settings/EditableSelectField.jsx | 3 +- src/account-settings/data/reducers.js | 1 + src/account-settings/data/selectors.js | 8 ++++ 4 files changed, 48 insertions(+), 3 deletions(-) diff --git a/src/account-settings/AccountSettingsPage.jsx b/src/account-settings/AccountSettingsPage.jsx index 6c2e336d8..f67e71762 100644 --- a/src/account-settings/AccountSettingsPage.jsx +++ b/src/account-settings/AccountSettingsPage.jsx @@ -120,7 +120,15 @@ class AccountSettingsPage extends React.Component { countryOptions: [{ value: '', label: this.props.intl.formatMessage(messages['account.settings.field.country.options.empty']), - }].concat(getCountryList(locale).map(({ code, name }) => ({ value: code, label: name }))), + }].concat( + this.removeDisabledCountries( + getCountryList(locale).map(({ code, name }) => ({ + value: code, + label: name, + disabled: this.isDisabledCountry(code), + })), + ), + ), stateOptions: [{ value: '', label: this.props.intl.formatMessage(messages['account.settings.field.state.options.empty']), @@ -147,11 +155,28 @@ class AccountSettingsPage extends React.Component { })), })); + removeDisabledCountries = (countryList) => { + const { disabledCountries, committedValues } = this.props; + + if (!disabledCountries.length) { + return countryList; + } + + return countryList.filter(({ value, disabled }) => { + const isUserCountry = value === committedValues.country; + return !disabled || isUserCountry; + }); + }; + handleEditableFieldChange = (name, value) => { this.props.updateDraft(name, value); }; handleSubmit = (formId, values) => { + if (formId === 'country' && this.isDisabledCountry(values)) { + return; + } + const { formValues } = this.props; let extendedProfileObject = {}; @@ -193,6 +218,11 @@ class AccountSettingsPage extends React.Component { } }; + isDisabledCountry = (country) => { + const { disabledCountries } = this.props; + return disabledCountries.includes(country); + }; + isEditable(fieldName) { return !this.props.staticFields.includes(fieldName); } @@ -476,7 +506,8 @@ class AccountSettingsPage extends React.Component { } = this.getLocalizedOptions(this.context.locale, this.props.formValues.country); // Show State field only if the country is US (could include Canada later) - const showState = this.props.formValues.country === COUNTRY_WITH_STATES; + const { country } = this.props.formValues; + const showState = country === COUNTRY_WITH_STATES && !this.isDisabledCountry(country); const { verifiedName } = this.props; const hasWorkExperience = !!this.props.formValues?.extended_profile?.find(field => field.field_name === 'work_experience'); @@ -880,6 +911,7 @@ AccountSettingsPage.propTypes = { name: PropTypes.string, useVerifiedNameForCerts: PropTypes.bool, verified_name: PropTypes.string, + country: PropTypes.string, }), drafts: PropTypes.shape({}), formErrors: PropTypes.shape({ @@ -938,6 +970,7 @@ AccountSettingsPage.propTypes = { ), navigate: PropTypes.func.isRequired, location: PropTypes.string.isRequired, + disabledCountries: PropTypes.arrayOf(PropTypes.string), }; AccountSettingsPage.defaultProps = { @@ -947,6 +980,7 @@ AccountSettingsPage.defaultProps = { committedValues: { useVerifiedNameForCerts: false, verified_name: null, + country: '', }, drafts: {}, formErrors: {}, @@ -963,6 +997,7 @@ AccountSettingsPage.defaultProps = { verifiedName: null, mostRecentVerifiedName: {}, verifiedNameHistory: [], + disabledCountries: [], }; export default withLocation(withNavigate(connect(accountSettingsPageSelector, { diff --git a/src/account-settings/EditableSelectField.jsx b/src/account-settings/EditableSelectField.jsx index 63a1f7d1c..bc1757e07 100644 --- a/src/account-settings/EditableSelectField.jsx +++ b/src/account-settings/EditableSelectField.jsx @@ -107,6 +107,7 @@ const EditableSelectField = (props) => { @@ -115,7 +116,7 @@ const EditableSelectField = (props) => { ); } return ( - ); diff --git a/src/account-settings/data/reducers.js b/src/account-settings/data/reducers.js index 7edb53a4e..35de9effc 100644 --- a/src/account-settings/data/reducers.js +++ b/src/account-settings/data/reducers.js @@ -39,6 +39,7 @@ export const defaultState = { verifiedName: null, mostRecentVerifiedName: {}, verifiedNameHistory: {}, + disabledCountries: ['RU'], }; const reducer = (state = defaultState, action = {}) => { diff --git a/src/account-settings/data/selectors.js b/src/account-settings/data/selectors.js index 1e6eb2497..99480a7f9 100644 --- a/src/account-settings/data/selectors.js +++ b/src/account-settings/data/selectors.js @@ -206,6 +206,11 @@ const activeAccountSelector = createSelector( accountSettings => accountSettings.values.is_active, ); +const disabledCountriesSelector = createSelector( + accountSettingsSelector, + accountSettings => accountSettings.disabledCountries, +); + export const siteLanguageSelector = createSelector( previousSiteLanguageSelector, draftsSelector, @@ -237,6 +242,7 @@ export const accountSettingsPageSelector = createSelector( mostRecentApprovedVerifiedNameValueSelector, mostRecentVerifiedNameSelector, sortedVerifiedNameHistorySelector, + disabledCountriesSelector, ( accountSettings, siteLanguageOptions, @@ -254,6 +260,7 @@ export const accountSettingsPageSelector = createSelector( verifiedName, mostRecentVerifiedName, verifiedNameHistory, + disabledCountries, ) => ({ siteLanguageOptions, siteLanguage, @@ -274,6 +281,7 @@ export const accountSettingsPageSelector = createSelector( verifiedName, mostRecentVerifiedName, verifiedNameHistory, + disabledCountries, }), );