Commit 8cf55a26 authored by Jiaan Louw's avatar Jiaan Louw

Update approvals createStore

Update the approval rules createStore function to allow for
multiple modules, this will by the project approval app
to mount with both the approval and approvalSettings stores.
parent cb05bad5
......@@ -23,10 +23,10 @@ export default {
},
computed: {
...mapState({
isLoading: (state) => state.approvals.isLoading,
isUpdated: (state) => state.approvals.isUpdated,
settings: (state) => state.approvals.settings,
errorMessage: (state) => state.approvals.errorMessage,
isLoading: (state) => state.approvalSettings.isLoading,
isUpdated: (state) => state.approvalSettings.isUpdated,
settings: (state) => state.approvalSettings.settings,
errorMessage: (state) => state.approvalSettings.errorMessage,
}),
...mapComputed(
[
......@@ -37,7 +37,7 @@ export default {
{ key: 'requireUserPassword', updateFn: 'setRequireUserPassword' },
],
undefined,
(state) => state.approvals.settings,
(state) => state.approvalSettings.settings,
),
hasSettings() {
return !isEmpty(this.settings);
......
......@@ -11,7 +11,9 @@ const mountGroupApprovalSettings = (el) => {
}
const { defaultExpanded, approvalSettingsPath } = el.dataset;
const store = createStore(approvalSettingsModule(groupApprovalsMappers));
const store = createStore({
approvalSettings: approvalSettingsModule(groupApprovalsMappers),
});
return new Vue({
el,
......
......@@ -13,7 +13,9 @@ export default function mountApprovalInput(el) {
document.querySelector('#js-target-branch-title')?.textContent ||
document.querySelector('#merge_request_target_branch')?.value;
const store = createStore(mrEditModule(), {
const store = createStore(
{ approvals: mrEditModule() },
{
...el.dataset,
prefix: 'mr-edit',
canEdit: parseBoolean(el.dataset.canEdit),
......@@ -21,7 +23,8 @@ export default function mountApprovalInput(el) {
showCodeOwnerTip: parseBoolean(el.dataset.showCodeOwnerTip),
allowMultiRule: parseBoolean(el.dataset.allowMultiRule),
canOverride: parseBoolean(el.dataset.canOverride),
});
},
);
store.dispatch('setTargetBranch', targetBranch);
......
......@@ -15,12 +15,15 @@ export default function mountProjectSettingsApprovals(el) {
coverageCheckHelpPagePath,
} = el.dataset;
const store = createStore(projectSettingsModule(), {
const store = createStore(
{ approvals: projectSettingsModule() },
{
...el.dataset,
prefix: 'project-settings',
allowMultiRule: parseBoolean(el.dataset.allowMultiRule),
canEdit: parseBoolean(el.dataset.canEdit),
});
},
);
return new Vue({
el,
......
......@@ -3,10 +3,10 @@ import securityConfigurationModule from 'ee/security_configuration/modules/confi
import modalModule from '~/vuex_shared/modules/modal';
import state from './state';
export const createStoreOptions = (approvalsModule, settings) => ({
export const createStoreOptions = (approvalsModules, settings) => ({
state: state(settings),
modules: {
...(approvalsModule ? { approvals: approvalsModule } : {}),
...approvalsModules,
createModal: modalModule(),
deleteModal: modalModule(),
securityConfiguration: securityConfigurationModule({
......@@ -15,5 +15,5 @@ export const createStoreOptions = (approvalsModule, settings) => ({
},
});
export default (approvalsModule, settings = {}) =>
new Vuex.Store(createStoreOptions(approvalsModule, settings));
export default (approvalModules, settings = {}) =>
new Vuex.Store(createStoreOptions(approvalModules, settings));
......@@ -38,10 +38,13 @@ describe('EE Approvals App', () => {
rules: `<div class="${TEST_RULES_CLASS}">These are the rules!</div>`,
};
store = createStoreOptions(settingsModule(), {
store = createStoreOptions(
{ approvals: settingsModule() },
{
canEdit: true,
prefix: APP_PREFIX,
});
},
);
store.modules.approvals.actions = {
fetchRules: jest.fn().mockResolvedValue(),
......
......@@ -30,7 +30,7 @@ describe('ApprovalSettings', () => {
jest.spyOn(actions, 'dismissErrorMessage').mockImplementation();
jest.spyOn(actions, 'dismissSuccessMessage').mockImplementation();
store = createStore(module);
store = createStore({ approvalSettings: module });
};
const createWrapper = () => {
......
......@@ -43,7 +43,7 @@ describe('EE Approvals Group Settings App', () => {
axiosMock = new MockAdapter(axios);
axiosMock.onGet('*');
store = createStoreOptions(approvalSettingsModule(groupApprovalsMappers));
store = createStoreOptions({ approvalSettings: approvalSettingsModule(groupApprovalsMappers) });
});
afterEach(() => {
......
......@@ -32,7 +32,7 @@ describe('EE Approvals MREditApp', () => {
axiosMock = new MockAdapter(axios);
axiosMock.onGet('*');
store = createStoreOptions(MREditModule());
store = createStoreOptions({ approvals: MREditModule() });
store.modules.approvals.state.hasLoaded = true;
});
......
......@@ -34,7 +34,7 @@ describe('EE Approvlas MRRulesHiddenInputs', () => {
};
beforeEach(() => {
store = createStoreOptions(MREditModule());
store = createStoreOptions({ approvals: MREditModule() });
store.modules.approvals.state = {
rules: [],
rulesToDelete: [],
......
......@@ -46,7 +46,7 @@ describe('EE Approvals MRRules', () => {
.fn()
.mockImplementation((args) => new OriginalMutationObserver(args));
store = createStoreOptions(MREditModule());
store = createStoreOptions({ approvals: MREditModule() });
store.modules.approvals.state = {
hasLoaded: true,
rules: [],
......
......@@ -26,7 +26,7 @@ describe('Rule Input', () => {
};
beforeEach(() => {
store = createStoreOptions(MREditModule());
store = createStoreOptions({ approvals: MREditModule() });
store.state.settings.canEdit = true;
store.modules.approvals.actions = {
......
......@@ -41,7 +41,7 @@ describe('Approvals ProjectRules', () => {
};
beforeEach(() => {
store = createStoreOptions(projectSettingsModule());
store = createStoreOptions({ approvals: projectSettingsModule() });
store.modules.approvals.state.rules = TEST_RULES;
});
......
......@@ -33,7 +33,7 @@ describe('EE Approvals RuleControls', () => {
const findRemoveButton = () => findButton('Remove');
beforeEach(() => {
store = createStoreOptions(MREditModule());
store = createStoreOptions({ approvals: MREditModule() });
({ actions } = store.modules.approvals);
['requestEditRule', 'requestDeleteRule'].forEach((actionName) =>
jest.spyOn(actions, actionName),
......
......@@ -104,7 +104,10 @@ describe('EE Approvals RuleForm', () => {
];
beforeEach(() => {
store = createStoreOptions(projectSettingsModule(), { projectId: TEST_PROJECT_ID });
store = createStoreOptions(
{ approvals: projectSettingsModule() },
{ projectId: TEST_PROJECT_ID },
);
['postRule', 'putRule', 'deleteRule', 'putFallbackRule'].forEach((actionName) => {
jest.spyOn(store.modules.approvals.actions, actionName).mockImplementation(() => {});
......
......@@ -31,7 +31,7 @@ describe('UnconfiguredSecurityRules component', () => {
beforeEach(() => {
store = new Vuex.Store(
createStoreOptions(projectSettingsModule(), { projectId: TEST_PROJECT_ID }),
createStoreOptions({ approvals: projectSettingsModule() }, { projectId: TEST_PROJECT_ID }),
);
jest.spyOn(store, 'dispatch');
});
......
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