Commit 73a2a8c2 authored by Thomas Randolph's avatar Thomas Randolph Committed by Phil Hughes

Use an event hub for MR Diffs to coordinate all expandAll requests

Instead of changing a value in state that is then observed in
components, the components just subscribe to the event
they know they need to handle and perform the "normal"
toggle behavior.
parent ebcc4595
<script> <script>
import { mapActions } from 'vuex';
import { GlAlert, GlButton } from '@gitlab/ui'; import { GlAlert, GlButton } from '@gitlab/ui';
import { CENTERED_LIMITED_CONTAINER_CLASSES } from '../constants'; import { CENTERED_LIMITED_CONTAINER_CLASSES } from '../constants';
import eventHub from '../event_hub';
export default { export default {
components: { components: {
...@@ -36,13 +35,12 @@ export default { ...@@ -36,13 +35,12 @@ export default {
}, },
methods: { methods: {
...mapActions('diffs', ['expandAllFiles']),
dismiss() { dismiss() {
this.isDismissed = true; this.isDismissed = true;
this.$emit('dismiss'); this.$emit('dismiss');
}, },
expand() { expand() {
this.expandAllFiles(); eventHub.$emit('mr:diffs:expandAllFiles');
this.dismiss(); this.dismiss();
}, },
}, },
......
...@@ -7,6 +7,7 @@ import CompareDropdownLayout from './compare_dropdown_layout.vue'; ...@@ -7,6 +7,7 @@ import CompareDropdownLayout from './compare_dropdown_layout.vue';
import SettingsDropdown from './settings_dropdown.vue'; import SettingsDropdown from './settings_dropdown.vue';
import DiffStats from './diff_stats.vue'; import DiffStats from './diff_stats.vue';
import { CENTERED_LIMITED_CONTAINER_CLASSES } from '../constants'; import { CENTERED_LIMITED_CONTAINER_CLASSES } from '../constants';
import eventHub from '../event_hub';
export default { export default {
components: { components: {
...@@ -67,9 +68,11 @@ export default { ...@@ -67,9 +68,11 @@ export default {
...mapActions('diffs', [ ...mapActions('diffs', [
'setInlineDiffViewType', 'setInlineDiffViewType',
'setParallelDiffViewType', 'setParallelDiffViewType',
'expandAllFiles',
'toggleShowTreeList', 'toggleShowTreeList',
]), ]),
expandAllFiles() {
eventHub.$emit('mr:diffs:expandAllFiles');
},
}, },
}; };
</script> </script>
......
...@@ -6,13 +6,14 @@ import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin'; ...@@ -6,13 +6,14 @@ import glFeatureFlagsMixin from '~/vue_shared/mixins/gl_feature_flags_mixin';
import { sprintf } from '~/locale'; import { sprintf } from '~/locale';
import { deprecatedCreateFlash as createFlash } from '~/flash'; import { deprecatedCreateFlash as createFlash } from '~/flash';
import { hasDiff } from '~/helpers/diffs_helper'; import { hasDiff } from '~/helpers/diffs_helper';
import eventHub from '../../notes/event_hub'; import notesEventHub from '../../notes/event_hub';
import DiffFileHeader from './diff_file_header.vue'; import DiffFileHeader from './diff_file_header.vue';
import DiffContent from './diff_content.vue'; import DiffContent from './diff_content.vue';
import { diffViewerErrors } from '~/ide/constants'; import { diffViewerErrors } from '~/ide/constants';
import { collapsedType, isCollapsed } from '../diff_file'; import { collapsedType, isCollapsed } from '../diff_file';
import { DIFF_FILE_AUTOMATIC_COLLAPSE, DIFF_FILE_MANUAL_COLLAPSE } from '../constants'; import { DIFF_FILE_AUTOMATIC_COLLAPSE, DIFF_FILE_MANUAL_COLLAPSE } from '../constants';
import { DIFF_FILE, GENERIC_ERROR } from '../i18n'; import { DIFF_FILE, GENERIC_ERROR } from '../i18n';
import eventHub from '../event_hub';
export default { export default {
components: { components: {
...@@ -151,7 +152,11 @@ export default { ...@@ -151,7 +152,11 @@ export default {
}, },
}, },
created() { created() {
eventHub.$on(`loadCollapsedDiff/${this.file.file_hash}`, this.requestDiff); notesEventHub.$on(`loadCollapsedDiff/${this.file.file_hash}`, this.requestDiff);
eventHub.$on('mr:diffs:expandAllFiles', this.expandAllListener);
},
beforeDestroy() {
eventHub.$off('mr:diffs:expandAllFiles', this.expandAllListener);
}, },
methods: { methods: {
...mapActions('diffs', [ ...mapActions('diffs', [
...@@ -160,6 +165,11 @@ export default { ...@@ -160,6 +165,11 @@ export default {
'setRenderIt', 'setRenderIt',
'setFileCollapsedByUser', 'setFileCollapsedByUser',
]), ]),
expandAllListener() {
if (this.isCollapsed) {
this.handleToggle();
}
},
handleToggle() { handleToggle() {
const currentCollapsedFlag = this.isCollapsed; const currentCollapsedFlag = this.isCollapsed;
......
import eventHubFactory from '~/helpers/event_hub_factory';
export default eventHubFactory();
...@@ -364,10 +364,6 @@ export const loadCollapsedDiff = ({ commit, getters, state }, file) => ...@@ -364,10 +364,6 @@ export const loadCollapsedDiff = ({ commit, getters, state }, file) =>
}); });
}); });
export const expandAllFiles = ({ commit }) => {
commit(types.EXPAND_ALL_FILES);
};
/** /**
* Toggles the file discussions after user clicked on the toggle discussions button. * Toggles the file discussions after user clicked on the toggle discussions button.
* *
......
...@@ -13,7 +13,6 @@ export const SET_MERGE_REQUEST_DIFFS = 'SET_MERGE_REQUEST_DIFFS'; ...@@ -13,7 +13,6 @@ export const SET_MERGE_REQUEST_DIFFS = 'SET_MERGE_REQUEST_DIFFS';
export const TOGGLE_LINE_HAS_FORM = 'TOGGLE_LINE_HAS_FORM'; export const TOGGLE_LINE_HAS_FORM = 'TOGGLE_LINE_HAS_FORM';
export const ADD_CONTEXT_LINES = 'ADD_CONTEXT_LINES'; export const ADD_CONTEXT_LINES = 'ADD_CONTEXT_LINES';
export const ADD_COLLAPSED_DIFFS = 'ADD_COLLAPSED_DIFFS'; export const ADD_COLLAPSED_DIFFS = 'ADD_COLLAPSED_DIFFS';
export const EXPAND_ALL_FILES = 'EXPAND_ALL_FILES';
export const RENDER_FILE = 'RENDER_FILE'; export const RENDER_FILE = 'RENDER_FILE';
export const SET_LINE_DISCUSSIONS_FOR_FILE = 'SET_LINE_DISCUSSIONS_FOR_FILE'; export const SET_LINE_DISCUSSIONS_FOR_FILE = 'SET_LINE_DISCUSSIONS_FOR_FILE';
export const REMOVE_LINE_DISCUSSIONS_FOR_FILE = 'REMOVE_LINE_DISCUSSIONS_FOR_FILE'; export const REMOVE_LINE_DISCUSSIONS_FOR_FILE = 'REMOVE_LINE_DISCUSSIONS_FOR_FILE';
......
...@@ -176,17 +176,6 @@ export default { ...@@ -176,17 +176,6 @@ export default {
Object.assign(selectedFile, { ...newFileData }); Object.assign(selectedFile, { ...newFileData });
}, },
[types.EXPAND_ALL_FILES](state) {
state.diffFiles.forEach(file => {
Object.assign(file, {
viewer: Object.assign(file.viewer, {
automaticallyCollapsed: false,
manuallyCollapsed: false,
}),
});
});
},
[types.SET_LINE_DISCUSSIONS_FOR_FILE](state, { discussion, diffPositionByLineCode, hash }) { [types.SET_LINE_DISCUSSIONS_FOR_FILE](state, { discussion, diffPositionByLineCode, hash }) {
const { latestDiff } = state; const { latestDiff } = state;
......
...@@ -3,6 +3,7 @@ import { shallowMount, mount, createLocalVue } from '@vue/test-utils'; ...@@ -3,6 +3,7 @@ import { shallowMount, mount, createLocalVue } from '@vue/test-utils';
import createStore from '~/diffs/store/modules'; import createStore from '~/diffs/store/modules';
import CollapsedFilesWarning from '~/diffs/components/collapsed_files_warning.vue'; import CollapsedFilesWarning from '~/diffs/components/collapsed_files_warning.vue';
import { CENTERED_LIMITED_CONTAINER_CLASSES } from '~/diffs/constants'; import { CENTERED_LIMITED_CONTAINER_CLASSES } from '~/diffs/constants';
import eventHub from '~/diffs/event_hub';
const propsData = { const propsData = {
limited: true, limited: true,
...@@ -76,13 +77,13 @@ describe('CollapsedFilesWarning', () => { ...@@ -76,13 +77,13 @@ describe('CollapsedFilesWarning', () => {
expect(wrapper.find('[data-testid="root"]').exists()).toBe(false); expect(wrapper.find('[data-testid="root"]').exists()).toBe(false);
}); });
it('triggers the expandAllFiles action when the alert action button is clicked', () => { it('emits the `mr:diffs:expandAllFiles` event when the alert action button is clicked', () => {
createComponent({}, { full: true }); createComponent({}, { full: true });
jest.spyOn(wrapper.vm.$store, 'dispatch').mockReturnValue(undefined); jest.spyOn(eventHub, '$emit');
getAlertActionButton().vm.$emit('click'); getAlertActionButton().vm.$emit('click');
expect(wrapper.vm.$store.dispatch).toHaveBeenCalledWith('diffs/expandAllFiles', undefined); expect(eventHub.$emit).toHaveBeenCalledWith('mr:diffs:expandAllFiles');
}); });
}); });
...@@ -9,6 +9,8 @@ import DiffFileComponent from '~/diffs/components/diff_file.vue'; ...@@ -9,6 +9,8 @@ import DiffFileComponent from '~/diffs/components/diff_file.vue';
import DiffFileHeaderComponent from '~/diffs/components/diff_file_header.vue'; import DiffFileHeaderComponent from '~/diffs/components/diff_file_header.vue';
import DiffContentComponent from '~/diffs/components/diff_content.vue'; import DiffContentComponent from '~/diffs/components/diff_content.vue';
import eventHub from '~/diffs/event_hub';
import { diffViewerModes, diffViewerErrors } from '~/ide/constants'; import { diffViewerModes, diffViewerErrors } from '~/ide/constants';
function changeViewer(store, index, { automaticallyCollapsed, manuallyCollapsed, name }) { function changeViewer(store, index, { automaticallyCollapsed, manuallyCollapsed, name }) {
...@@ -138,6 +140,30 @@ describe('DiffFile', () => { ...@@ -138,6 +140,30 @@ describe('DiffFile', () => {
}); });
describe('collapsing', () => { describe('collapsing', () => {
describe('`mr:diffs:expandAllFiles` event', () => {
beforeEach(() => {
jest.spyOn(wrapper.vm, 'handleToggle').mockImplementation(() => {});
});
it('performs the normal file toggle when the file is collapsed', async () => {
makeFileAutomaticallyCollapsed(store);
await wrapper.vm.$nextTick();
eventHub.$emit('mr:diffs:expandAllFiles');
expect(wrapper.vm.handleToggle).toHaveBeenCalledTimes(1);
});
it('does nothing when the file is not collapsed', async () => {
eventHub.$emit('mr:diffs:expandAllFiles');
await wrapper.vm.$nextTick();
expect(wrapper.vm.handleToggle).not.toHaveBeenCalled();
});
});
describe('user collapsed', () => { describe('user collapsed', () => {
beforeEach(() => { beforeEach(() => {
makeFileManuallyCollapsed(store); makeFileManuallyCollapsed(store);
......
...@@ -27,7 +27,6 @@ import { ...@@ -27,7 +27,6 @@ import {
scrollToLineIfNeededInline, scrollToLineIfNeededInline,
scrollToLineIfNeededParallel, scrollToLineIfNeededParallel,
loadCollapsedDiff, loadCollapsedDiff,
expandAllFiles,
toggleFileDiscussions, toggleFileDiscussions,
saveDiffDiscussion, saveDiffDiscussion,
setHighlightedRow, setHighlightedRow,
...@@ -658,23 +657,6 @@ describe('DiffsStoreActions', () => { ...@@ -658,23 +657,6 @@ describe('DiffsStoreActions', () => {
}); });
}); });
describe('expandAllFiles', () => {
it('should change the collapsed prop from the diffFiles', done => {
testAction(
expandAllFiles,
null,
{},
[
{
type: types.EXPAND_ALL_FILES,
},
],
[],
done,
);
});
});
describe('toggleFileDiscussions', () => { describe('toggleFileDiscussions', () => {
it('should dispatch collapseDiscussion when all discussions are expanded', () => { it('should dispatch collapseDiscussion when all discussions are expanded', () => {
const getters = { const getters = {
......
...@@ -126,21 +126,6 @@ describe('DiffsStoreMutations', () => { ...@@ -126,21 +126,6 @@ describe('DiffsStoreMutations', () => {
}); });
}); });
describe('EXPAND_ALL_FILES', () => {
it('should change the collapsed prop from diffFiles', () => {
const diffFile = {
viewer: {
automaticallyCollapsed: true,
},
};
const state = { expandAllFiles: true, diffFiles: [diffFile] };
mutations[types.EXPAND_ALL_FILES](state);
expect(state.diffFiles[0].viewer.automaticallyCollapsed).toEqual(false);
});
});
describe('ADD_CONTEXT_LINES', () => { describe('ADD_CONTEXT_LINES', () => {
it('should call utils.addContextLines with proper params', () => { it('should call utils.addContextLines with proper params', () => {
const options = { const options = {
......
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