Skip to content

Commit

Permalink
feat: check how many users update country on registration form after …
Browse files Browse the repository at this point in the history
…we auto populate it with IP (#1127)

Description: Check how many users update country on registration form after we auto populate it with IP.
VAN-1793
  • Loading branch information
ahtesham-quraish authored Jan 16, 2024
1 parent d74b5c4 commit b9b4492
Show file tree
Hide file tree
Showing 4 changed files with 49 additions and 1 deletion.
13 changes: 12 additions & 1 deletion src/register/RegistrationPage.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -70,6 +70,7 @@ const RegistrationPage = (props) => {
userPipelineDataLoaded,
submitState,
validations,
IPBasedCountryCode,
} = useSelector(state => state.register);

const {
Expand Down Expand Up @@ -177,8 +178,18 @@ const RegistrationPage = (props) => {

// This is used by the "User Retention Rate Event" on GTM
setCookie(getConfig().USER_RETENTION_COOKIE_NAME, true);

// This event will be used to track the number of users who have
// changed country field and selected the country other than
// IP based country.
if (configurableFormFields.country?.countryCode !== IPBasedCountryCode) {
sendTrackEvent('edx.bi.user.auto-populatedcountry.changed', {
originalCountry: IPBasedCountryCode,
selectedCountry: configurableFormFields.country.countryCode,
});
}
}
}, [registrationResult]);
}, [registrationResult, IPBasedCountryCode, configurableFormFields.country]);

const handleOnChange = (event) => {
const { name } = event.target;
Expand Down
32 changes: 32 additions & 0 deletions src/register/RegistrationPage.test.jsx
Original file line number Diff line number Diff line change
Expand Up @@ -519,6 +519,38 @@ describe('RegistrationPage', () => {
expect(sendTrackEvent).toHaveBeenCalledWith('edx.bi.user.account.registered.client', {});
});

it('should send track event when user changed the country field', () => {
store = mockStore({
...initialState,
register: {
...initialState.register,
IPBasedCountryCode: 'AL',
registrationFormData: {
...registrationFormData,
configurableFormFields: {
marketingEmailsOptIn: true,
country: {
countryCode: 'PK',
displayValue: 'Pakistan',
},
},
},
registrationResult: {
success: true,
redirectUrl: 'https://test.com/testing-dashboard/',
},
},
});

delete window.location;
window.location = { href: getConfig().BASE_URL };
render(routerWrapper(reduxWrapper(<IntlRegistrationPage {...props} />)));
expect(sendTrackEvent).toHaveBeenCalledWith('edx.bi.user.auto-populatedcountry.changed', {
originalCountry: 'AL',
selectedCountry: 'PK',
});
});

it('should populate form with pipeline user details', () => {
store = mockStore({
...initialState,
Expand Down
3 changes: 3 additions & 0 deletions src/register/data/reducers.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ export const storeName = 'register';

export const defaultState = {
backendCountryCode: '',
IPBasedCountryCode: '',
registrationError: {},
registrationResult: {},
registrationFormData: {
Expand Down Expand Up @@ -49,6 +50,7 @@ const reducer = (state = defaultState, action = {}) => {
case BACKUP_REGISTRATION_DATA.BEGIN:
return {
...defaultState,
IPBasedCountryCode: state.IPBasedCountryCode,
usernameSuggestions: state.usernameSuggestions,
registrationFormData: { ...action.payload },
userPipelineDataLoaded: state.userPipelineDataLoaded,
Expand Down Expand Up @@ -108,6 +110,7 @@ const reducer = (state = defaultState, action = {}) => {
return {
...state,
backendCountryCode: countryCode,
IPBasedCountryCode: countryCode,
};
}
return state;
Expand Down
2 changes: 2 additions & 0 deletions src/register/data/tests/reducers.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import reducer from '../reducers';
describe('Registration Reducer Tests', () => {
const defaultState = {
backendCountryCode: '',
IPBasedCountryCode: '',
registrationError: {},
registrationResult: {},
registrationFormData: {
Expand Down Expand Up @@ -246,6 +247,7 @@ describe('Registration Reducer Tests', () => {
{
...defaultState,
backendCountryCode: countryCode,
IPBasedCountryCode: countryCode,
},
);
});
Expand Down

0 comments on commit b9b4492

Please sign in to comment.