78 lines
3.3 KiB
JavaScript
78 lines
3.3 KiB
JavaScript
import { parseBoolean, getCookie } from '~/lib/utils/common_utils';
|
|
import mrNotes from '~/mr_notes/stores';
|
|
import { getLocationHash, getParameterValues } from '~/lib/utils/url_utility';
|
|
import eventHub from '~/notes/event_hub';
|
|
import { initReviewBar } from '~/batch_comments';
|
|
import { initDiscussionCounter } from '~/mr_notes/discussion_counter';
|
|
import { initOverviewTabCounter } from '~/mr_notes/init_count';
|
|
import { getDerivedMergeRequestInformation } from '~/diffs/utils/merge_request';
|
|
import { getReviewsForMergeRequest } from '~/diffs/utils/file_reviews';
|
|
import { DIFF_VIEW_COOKIE_NAME, INLINE_DIFF_VIEW_TYPE } from '~/diffs/constants';
|
|
|
|
function setupMrNotesState(store, notesDataset, diffsDataset) {
|
|
const noteableData = JSON.parse(notesDataset.noteableData);
|
|
noteableData.noteableType = notesDataset.noteableType;
|
|
noteableData.targetType = notesDataset.targetType;
|
|
noteableData.discussion_locked = parseBoolean(notesDataset.isLocked);
|
|
const notesData = JSON.parse(notesDataset.notesData);
|
|
const currentUserData = JSON.parse(notesDataset.currentUserData);
|
|
const endpoints = { metadata: notesDataset.endpointMetadata };
|
|
|
|
const { mrPath } = getDerivedMergeRequestInformation({ endpoint: diffsDataset.endpoint });
|
|
|
|
store.dispatch('setNotesData', notesData);
|
|
store.dispatch('setNoteableData', noteableData);
|
|
store.dispatch('setUserData', currentUserData);
|
|
store.dispatch('setTargetNoteHash', getLocationHash());
|
|
store.dispatch('setEndpoints', endpoints);
|
|
store.dispatch('diffs/setBaseConfig', {
|
|
endpoint: diffsDataset.endpoint,
|
|
endpointMetadata: diffsDataset.endpointMetadata,
|
|
endpointBatch: diffsDataset.endpointBatch,
|
|
endpointDiffForPath: diffsDataset.endpointDiffForPath,
|
|
endpointCoverage: diffsDataset.endpointCoverage,
|
|
endpointUpdateUser: diffsDataset.updateCurrentUserPath,
|
|
projectPath: diffsDataset.projectPath,
|
|
dismissEndpoint: diffsDataset.dismissEndpoint,
|
|
showSuggestPopover: parseBoolean(diffsDataset.showSuggestPopover),
|
|
viewDiffsFileByFile: parseBoolean(diffsDataset.fileByFileDefault),
|
|
defaultSuggestionCommitMessage: diffsDataset.defaultSuggestionCommitMessage,
|
|
mrReviews: getReviewsForMergeRequest(mrPath),
|
|
diffViewType:
|
|
getParameterValues('view')[0] || getCookie(DIFF_VIEW_COOKIE_NAME) || INLINE_DIFF_VIEW_TYPE,
|
|
perPage: Number(diffsDataset.perPage),
|
|
});
|
|
}
|
|
|
|
export function initMrStateLazyLoad(store = mrNotes) {
|
|
store.dispatch('setActiveTab', window.mrTabs.getCurrentAction());
|
|
window.mrTabs.eventHub.$on('MergeRequestTabChange', (value) =>
|
|
store.dispatch('setActiveTab', value),
|
|
);
|
|
|
|
const discussionsEl = document.getElementById('js-vue-mr-discussions');
|
|
const diffsEl = document.getElementById('js-diffs-app');
|
|
|
|
let stop = () => {};
|
|
stop = store.watch(
|
|
(state) => state.page.activeTab,
|
|
(activeTab) => {
|
|
setupMrNotesState(store, discussionsEl.dataset, diffsEl.dataset);
|
|
|
|
// prevent loading MR state on commits and pipelines pages
|
|
// this is due to them having a shared controller with the Overview page
|
|
if (['diffs', 'show'].includes(activeTab)) {
|
|
eventHub.$once('fetchNotesData', () => store.dispatch('fetchNotes'));
|
|
|
|
requestIdleCallback(() => {
|
|
initReviewBar();
|
|
initOverviewTabCounter();
|
|
initDiscussionCounter();
|
|
});
|
|
stop();
|
|
}
|
|
},
|
|
{ immediate: true },
|
|
);
|
|
}
|