Commit 26df1614 authored by Angelo Gulina's avatar Angelo Gulina Committed by Vitaly Slobodin

Update condition for submit button on 'just me' cases

parent 8ab9f4b3
...@@ -72,16 +72,31 @@ export default { ...@@ -72,16 +72,31 @@ export default {
selectedPlanTextLine() { selectedPlanTextLine() {
return sprintf(this.$options.i18n.selectedPlan, { selectedPlanText: this.selectedPlanText }); return sprintf(this.$options.i18n.selectedPlan, { selectedPlanText: this.selectedPlanText });
}, },
isValid() { hasAtLeastOneUser() {
return this.numberOfUsers > 0;
},
hasSelectedPlan() {
return !isEmpty(this.selectedPlan);
},
hasOrganizationName() {
return !isEmpty(this.organizationName);
},
hasRequisitesForCompany() {
if (this.isSetupForCompany) { if (this.isSetupForCompany) {
return this.hasOrganizationName || this.isGroupSelected;
}
return true;
},
isSelectedUsersEqualOrGreaterThanGroupUsers() {
return this.numberOfUsers >= this.selectedGroupUsers;
},
isValid() {
return ( return (
!isEmpty(this.selectedPlan) && this.hasSelectedPlan &&
(!isEmpty(this.organizationName) || this.isGroupSelected) && this.hasAtLeastOneUser &&
this.numberOfUsers > 0 && this.isSelectedUsersEqualOrGreaterThanGroupUsers &&
this.numberOfUsers >= this.selectedGroupUsers this.hasRequisitesForCompany
); );
}
return !isEmpty(this.selectedPlan) && this.numberOfUsers === 1;
}, },
isShowingGroupSelector() { isShowingGroupSelector() {
return !this.isNewUser && this.groupData.length; return !this.isNewUser && this.groupData.length;
......
...@@ -345,18 +345,19 @@ describe('Subscription Details', () => { ...@@ -345,18 +345,19 @@ describe('Subscription Details', () => {
const isStepValid = () => wrapper.findComponent(Step).props('isValid'); const isStepValid = () => wrapper.findComponent(Step).props('isValid');
let store; let store;
describe('when setting up for a company', () => {
beforeEach(() => { beforeEach(() => {
const mockApollo = createMockApolloProvider(STEPS); const mockApollo = createMockApolloProvider(STEPS);
store = createStore(createDefaultInitialStoreData()); store = createStore(
createDefaultInitialStoreData({
namespaceId: 483,
newUser: 'true',
setupForCompany: 'true',
}),
);
wrapper = createComponent({ apolloProvider: mockApollo, store }); wrapper = createComponent({ apolloProvider: mockApollo, store });
});
describe('when setting up for a company', () => {
beforeEach(() => {
store.commit(types.UPDATE_IS_SETUP_FOR_COMPANY, true);
store.commit(types.UPDATE_SELECTED_PLAN, 'firstPlanId'); store.commit(types.UPDATE_SELECTED_PLAN, 'firstPlanId');
store.commit(types.UPDATE_ORGANIZATION_NAME, 'Organization name'); store.commit(types.UPDATE_ORGANIZATION_NAME, 'Organization name');
store.commit(types.UPDATE_SELECTED_GROUP, 483);
store.commit(types.UPDATE_NUMBER_OF_USERS, 14); store.commit(types.UPDATE_NUMBER_OF_USERS, 14);
}); });
...@@ -398,10 +399,41 @@ describe('Subscription Details', () => { ...@@ -398,10 +399,41 @@ describe('Subscription Details', () => {
}); });
}); });
describe('when not setting up for a company', () => { describe('when not setting up for a company and a new user', () => {
beforeEach(() => {
const mockApollo = createMockApolloProvider(STEPS);
store = createStore(
createDefaultInitialStoreData({
namespaceId: 111,
newUser: 'true',
setupForCompany: 'false',
groupData: JSON.stringify([{ id: 111, name: 'Just me group', users: 1 }]),
}),
);
wrapper = createComponent({ apolloProvider: mockApollo, store });
});
it('should disable the number of users input field', () => {
expect(numberOfUsersInput().attributes('disabled')).toBeDefined();
});
it('should be valid', () => {
expect(isStepValid()).toBe(true);
});
});
describe('when not setting up for a company and not a new user', () => {
beforeEach(() => { beforeEach(() => {
store.commit(types.UPDATE_IS_SETUP_FOR_COMPANY, false); const mockApollo = createMockApolloProvider(STEPS);
store.commit(types.UPDATE_NUMBER_OF_USERS, 1); store = createStore(
createDefaultInitialStoreData({
namespaceId: 132,
newUser: 'false',
setupForCompany: 'false',
}),
);
wrapper = createComponent({ apolloProvider: mockApollo, store });
store.commit(types.UPDATE_NUMBER_OF_USERS, 3);
}); });
it('should be valid', () => { it('should be valid', () => {
...@@ -416,7 +448,7 @@ describe('Subscription Details', () => { ...@@ -416,7 +448,7 @@ describe('Subscription Details', () => {
}); });
}); });
it('should be invalid when no number of users is 0', () => { it('should be invalid when number users is 0', () => {
store.commit(types.UPDATE_NUMBER_OF_USERS, 0); store.commit(types.UPDATE_NUMBER_OF_USERS, 0);
return localVue.nextTick().then(() => { return localVue.nextTick().then(() => {
...@@ -424,7 +456,15 @@ describe('Subscription Details', () => { ...@@ -424,7 +456,15 @@ describe('Subscription Details', () => {
}); });
}); });
it('should be invalid when no number of users is greater than 1', () => { it('should be valid when number of users is greater than group users', () => {
store.commit(types.UPDATE_NUMBER_OF_USERS, 4);
return localVue.nextTick().then(() => {
expect(isStepValid()).toBe(true);
});
});
it('should not be valid when number of users is less than group users', () => {
store.commit(types.UPDATE_NUMBER_OF_USERS, 2); store.commit(types.UPDATE_NUMBER_OF_USERS, 2);
return localVue.nextTick().then(() => { return localVue.nextTick().then(() => {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment