debian-mirror-gitlab/app/assets/javascripts/diffs/store/mutations.js

230 lines
6.6 KiB
JavaScript
Raw Normal View History

2019-01-03 12:48:30 +05:30
import Vue from 'vue';
2018-11-08 19:23:39 +05:30
import { convertObjectPropsToCamelCase } from '~/lib/utils/common_utils';
2018-12-05 23:21:45 +05:30
import { sortTree } from '~/ide/stores/utils';
2018-11-20 20:47:30 +05:30
import {
findDiffFile,
addLineReferences,
removeMatchLine,
addContextLines,
prepareDiffData,
isDiscussionApplicableToLine,
2018-12-05 23:21:45 +05:30
generateTreeList,
2018-11-20 20:47:30 +05:30
} from './utils';
2018-11-08 19:23:39 +05:30
import * as types from './mutation_types';
export default {
[types.SET_BASE_CONFIG](state, options) {
const { endpoint, projectPath } = options;
Object.assign(state, { endpoint, projectPath });
},
[types.SET_LOADING](state, isLoading) {
Object.assign(state, { isLoading });
},
[types.SET_DIFF_DATA](state, data) {
2019-01-03 12:48:30 +05:30
const diffData = convertObjectPropsToCamelCase(data, { deep: true });
prepareDiffData(diffData);
const { tree, treeEntries } = generateTreeList(diffData.diffFiles);
2018-11-20 20:47:30 +05:30
2018-11-08 19:23:39 +05:30
Object.assign(state, {
2019-01-03 12:48:30 +05:30
...diffData,
2018-12-05 23:21:45 +05:30
tree: sortTree(tree),
treeEntries,
2018-11-20 20:47:30 +05:30
});
},
[types.RENDER_FILE](state, file) {
Object.assign(file, {
renderIt: true,
2018-11-08 19:23:39 +05:30
});
},
[types.SET_MERGE_REQUEST_DIFFS](state, mergeRequestDiffs) {
Object.assign(state, {
2019-01-03 12:48:30 +05:30
mergeRequestDiffs: convertObjectPropsToCamelCase(mergeRequestDiffs, { deep: true }),
2018-11-08 19:23:39 +05:30
});
},
[types.SET_DIFF_VIEW_TYPE](state, diffViewType) {
Object.assign(state, { diffViewType });
},
2019-01-03 12:48:30 +05:30
[types.ADD_COMMENT_FORM_LINE](state, { lineCode }) {
Vue.set(state.diffLineCommentForms, lineCode, true);
},
2018-12-23 12:14:25 +05:30
2019-01-03 12:48:30 +05:30
[types.REMOVE_COMMENT_FORM_LINE](state, { lineCode }) {
Vue.delete(state.diffLineCommentForms, lineCode);
2018-11-08 19:23:39 +05:30
},
[types.ADD_CONTEXT_LINES](state, options) {
const { lineNumbers, contextLines, fileHash } = options;
const { bottom } = options.params;
const diffFile = findDiffFile(state.diffFiles, fileHash);
2019-01-03 12:48:30 +05:30
const { highlightedDiffLines, parallelDiffLines } = diffFile;
2018-11-08 19:23:39 +05:30
removeMatchLine(diffFile, lineNumbers, bottom);
2018-12-13 13:39:08 +05:30
const lines = addLineReferences(contextLines, lineNumbers, bottom).map(line => ({
...line,
2019-01-03 12:48:30 +05:30
lineCode: line.lineCode || `${fileHash}_${line.oldLine}_${line.newLine}`,
2018-12-13 13:39:08 +05:30
discussions: line.discussions || [],
}));
2018-11-08 19:23:39 +05:30
addContextLines({
2019-01-03 12:48:30 +05:30
inlineLines: highlightedDiffLines,
parallelLines: parallelDiffLines,
2018-11-08 19:23:39 +05:30
contextLines: lines,
bottom,
lineNumbers,
});
},
[types.ADD_COLLAPSED_DIFFS](state, { file, data }) {
2019-01-03 12:48:30 +05:30
const normalizedData = convertObjectPropsToCamelCase(data, { deep: true });
prepareDiffData(normalizedData);
const [newFileData] = normalizedData.diffFiles.filter(f => f.fileHash === file.fileHash);
const selectedFile = state.diffFiles.find(f => f.fileHash === file.fileHash);
2018-11-20 20:47:30 +05:30
Object.assign(selectedFile, { ...newFileData });
2018-11-08 19:23:39 +05:30
},
[types.EXPAND_ALL_FILES](state) {
state.diffFiles = state.diffFiles.map(file => ({
...file,
collapsed: false,
}));
},
2018-11-20 20:47:30 +05:30
2018-12-13 13:39:08 +05:30
[types.SET_LINE_DISCUSSIONS_FOR_FILE](state, { discussion, diffPositionByLineCode }) {
const { latestDiff } = state;
const discussionLineCode = discussion.line_code;
const fileHash = discussion.diff_file.file_hash;
2019-01-03 12:48:30 +05:30
const lineCheck = ({ lineCode }) =>
lineCode === discussionLineCode &&
2018-12-05 23:21:45 +05:30
isDiscussionApplicableToLine({
2018-12-13 13:39:08 +05:30
discussion,
2019-01-03 12:48:30 +05:30
diffPosition: diffPositionByLineCode[lineCode],
2018-12-13 13:39:08 +05:30
latestDiff,
});
state.diffFiles = state.diffFiles.map(diffFile => {
2019-01-03 12:48:30 +05:30
if (diffFile.fileHash === fileHash) {
2018-12-13 13:39:08 +05:30
const file = { ...diffFile };
2019-01-03 12:48:30 +05:30
if (file.highlightedDiffLines) {
file.highlightedDiffLines = file.highlightedDiffLines.map(line => {
if (lineCheck(line)) {
return {
...line,
discussions: line.discussions.concat(discussion),
};
}
return line;
});
2018-11-20 20:47:30 +05:30
}
2019-01-03 12:48:30 +05:30
if (file.parallelDiffLines) {
file.parallelDiffLines = file.parallelDiffLines.map(line => {
2018-12-13 13:39:08 +05:30
const left = line.left && lineCheck(line.left);
const right = line.right && lineCheck(line.right);
if (left || right) {
return {
2019-01-03 12:48:30 +05:30
left: {
...line.left,
discussions: left ? line.left.discussions.concat(discussion) : [],
},
right: {
...line.right,
discussions: right && !left ? line.right.discussions.concat(discussion) : [],
},
2018-12-13 13:39:08 +05:30
};
}
return line;
2018-11-20 20:47:30 +05:30
});
}
2018-12-13 13:39:08 +05:30
2019-01-03 12:48:30 +05:30
if (!file.parallelDiffLines || !file.highlightedDiffLines) {
file.discussions = file.discussions.concat(discussion);
2018-12-13 13:39:08 +05:30
}
return file;
2018-11-20 20:47:30 +05:30
}
2018-12-13 13:39:08 +05:30
return diffFile;
});
2018-11-20 20:47:30 +05:30
},
2019-01-03 12:48:30 +05:30
[types.REMOVE_LINE_DISCUSSIONS_FOR_FILE](state, { fileHash, lineCode, id }) {
const selectedFile = state.diffFiles.find(f => f.fileHash === fileHash);
2018-11-20 20:47:30 +05:30
if (selectedFile) {
2019-01-03 12:48:30 +05:30
if (selectedFile.parallelDiffLines) {
const targetLine = selectedFile.parallelDiffLines.find(
2018-12-13 13:39:08 +05:30
line =>
2019-01-03 12:48:30 +05:30
(line.left && line.left.lineCode === lineCode) ||
(line.right && line.right.lineCode === lineCode),
2018-12-13 13:39:08 +05:30
);
if (targetLine) {
2019-01-03 12:48:30 +05:30
const side = targetLine.left && targetLine.left.lineCode === lineCode ? 'left' : 'right';
2018-12-13 13:39:08 +05:30
Object.assign(targetLine[side], {
2019-01-03 12:48:30 +05:30
discussions: [],
2018-12-13 13:39:08 +05:30
});
}
2018-11-20 20:47:30 +05:30
}
2019-01-03 12:48:30 +05:30
if (selectedFile.highlightedDiffLines) {
const targetInlineLine = selectedFile.highlightedDiffLines.find(
line => line.lineCode === lineCode,
2018-11-20 20:47:30 +05:30
);
if (targetInlineLine) {
Object.assign(targetInlineLine, {
2019-01-03 12:48:30 +05:30
discussions: [],
2018-11-20 20:47:30 +05:30
});
}
}
2018-12-13 13:39:08 +05:30
if (selectedFile.discussions && selectedFile.discussions.length) {
selectedFile.discussions = selectedFile.discussions.filter(
2019-01-03 12:48:30 +05:30
discussion => discussion.id !== id,
2018-12-13 13:39:08 +05:30
);
}
2018-11-20 20:47:30 +05:30
}
},
2018-12-05 23:21:45 +05:30
[types.TOGGLE_FOLDER_OPEN](state, path) {
state.treeEntries[path].opened = !state.treeEntries[path].opened;
},
[types.TOGGLE_SHOW_TREE_LIST](state) {
state.showTreeList = !state.showTreeList;
},
[types.UPDATE_CURRENT_DIFF_FILE_ID](state, fileId) {
state.currentDiffFileId = fileId;
},
2018-12-13 13:39:08 +05:30
[types.OPEN_DIFF_FILE_COMMENT_FORM](state, formData) {
state.commentForms.push({
...formData,
});
},
[types.UPDATE_DIFF_FILE_COMMENT_FORM](state, formData) {
const { fileHash } = formData;
state.commentForms = state.commentForms.map(form => {
if (form.fileHash === fileHash) {
return {
...formData,
};
}
return form;
});
},
[types.CLOSE_DIFF_FILE_COMMENT_FORM](state, fileHash) {
state.commentForms = state.commentForms.filter(form => form.fileHash !== fileHash);
},
2018-11-08 19:23:39 +05:30
};