Commit 9e9b5e69 authored by Alex Buijs's avatar Alex Buijs

Only show Progress Bar for new users

When existing users are buying a plan,
do not show the progress bar.
parent fcc2bdb4
<script> <script>
import { s__ } from '~/locale'; import { s__ } from '~/locale';
import { PROGRESS_STEPS } from '../constants'; import { PROGRESS_STEPS } from '../constants';
import { mapState } from 'vuex';
import ProgressBar from './checkout/progress_bar.vue'; import ProgressBar from './checkout/progress_bar.vue';
import SubscriptionDetails from './checkout/subscription_details.vue'; import SubscriptionDetails from './checkout/subscription_details.vue';
import BillingAddress from './checkout/billing_address.vue'; import BillingAddress from './checkout/billing_address.vue';
...@@ -14,6 +15,9 @@ export default { ...@@ -14,6 +15,9 @@ export default {
step: PROGRESS_STEPS.checkout, step: PROGRESS_STEPS.checkout,
}; };
}, },
computed: {
...mapState(['newUser']),
},
i18n: { i18n: {
checkout: s__('Checkout|Checkout'), checkout: s__('Checkout|Checkout'),
}, },
...@@ -22,7 +26,7 @@ export default { ...@@ -22,7 +26,7 @@ export default {
<template> <template>
<div class="checkout d-flex flex-column justify-content-between w-100"> <div class="checkout d-flex flex-column justify-content-between w-100">
<div class="full-width"> <div class="full-width">
<progress-bar :step="step" /> <progress-bar v-if="newUser" :step="step" />
<div class="flash-container"></div> <div class="flash-container"></div>
<h2 class="mt-4 mb-3 mb-lg-5">{{ $options.i18n.checkout }}</h2> <h2 class="mt-4 mb-3 mb-lg-5">{{ $options.i18n.checkout }}</h2>
<subscription-details /> <subscription-details />
......
...@@ -16,14 +16,15 @@ const determineSelectedPlan = (planId, plans) => { ...@@ -16,14 +16,15 @@ const determineSelectedPlan = (planId, plans) => {
return plans[0] && plans[0].value; return plans[0] && plans[0].value;
}; };
export default ({ planData = '[]', planId, setupForCompany, fullName }) => { export default ({ planData = '[]', planId, setupForCompany, fullName, newUser }) => {
const plans = parsePlanData(planData); const availablePlans = parsePlanData(planData);
return { return {
currentStep: STEPS[0], currentStep: STEPS[0],
availablePlans: plans,
selectedPlan: determineSelectedPlan(planId, plans),
isSetupForCompany: parseBoolean(setupForCompany), isSetupForCompany: parseBoolean(setupForCompany),
availablePlans,
selectedPlan: determineSelectedPlan(planId, availablePlans),
newUser: parseBoolean(newUser),
fullName, fullName,
organizationName: null, organizationName: null,
numberOfUsers: parseBoolean(setupForCompany) ? 0 : 1, numberOfUsers: parseBoolean(setupForCompany) ? 0 : 1,
......
import Vuex from 'vuex';
import { shallowMount, createLocalVue } from '@vue/test-utils';
import createStore from 'ee/subscriptions/new/store';
import Component from 'ee/subscriptions/new/components/checkout.vue';
import ProgressBar from 'ee/subscriptions/new/components/checkout/progress_bar.vue';
describe('Checkout', () => {
const localVue = createLocalVue();
localVue.use(Vuex);
let store;
let wrapper;
const createComponent = () => {
wrapper = shallowMount(Component, {
store,
});
};
const findProgressBar = () => wrapper.find(ProgressBar);
beforeEach(() => {
store = createStore();
createComponent();
});
afterEach(() => {
wrapper.destroy();
});
describe.each([[true, true], [false, false]])('when newUser=%s', (newUser, visible) => {
beforeEach(() => {
store.state.newUser = newUser;
});
it(`progress bar visibility is ${visible}`, () => {
expect(findProgressBar().exists()).toBe(visible);
});
});
});
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