90 lines
3.2 KiB
JavaScript
90 lines
3.2 KiB
JavaScript
|
//= require vue
|
||
|
//= require ./merge_conflict_store
|
||
|
//= require ./merge_conflict_service
|
||
|
//= require ./mixins/line_conflict_utils
|
||
|
//= require ./mixins/line_conflict_actions
|
||
|
//= require ./components/diff_file_editor
|
||
|
//= require ./components/inline_conflict_lines
|
||
|
//= require ./components/parallel_conflict_line
|
||
|
//= require ./components/parallel_conflict_lines
|
||
|
|
||
|
$(() => {
|
||
|
const INTERACTIVE_RESOLVE_MODE = 'interactive';
|
||
|
const conflictsEl = document.querySelector('#conflicts');
|
||
|
const mergeConflictsStore = gl.mergeConflicts.mergeConflictsStore;
|
||
|
const mergeConflictsService = new gl.mergeConflicts.mergeConflictsService({
|
||
|
conflictsPath: conflictsEl.dataset.conflictsPath,
|
||
|
resolveConflictsPath: conflictsEl.dataset.resolveConflictsPath
|
||
|
});
|
||
|
|
||
|
gl.MergeConflictsResolverApp = new Vue({
|
||
|
el: '#conflicts',
|
||
|
data: mergeConflictsStore.state,
|
||
|
components: {
|
||
|
'diff-file-editor': gl.mergeConflicts.diffFileEditor,
|
||
|
'inline-conflict-lines': gl.mergeConflicts.inlineConflictLines,
|
||
|
'parallel-conflict-lines': gl.mergeConflicts.parallelConflictLines
|
||
|
},
|
||
|
computed: {
|
||
|
conflictsCountText() { return mergeConflictsStore.getConflictsCountText() },
|
||
|
readyToCommit() { return mergeConflictsStore.isReadyToCommit() },
|
||
|
commitButtonText() { return mergeConflictsStore.getCommitButtonText() },
|
||
|
showDiffViewTypeSwitcher() { return mergeConflictsStore.fileTextTypePresent() }
|
||
|
},
|
||
|
created() {
|
||
|
mergeConflictsService
|
||
|
.fetchConflictsData()
|
||
|
.done((data) => {
|
||
|
if (data.type === 'error') {
|
||
|
mergeConflictsStore.setFailedRequest(data.message);
|
||
|
} else {
|
||
|
mergeConflictsStore.setConflictsData(data);
|
||
|
}
|
||
|
})
|
||
|
.error(() => {
|
||
|
mergeConflictsStore.setFailedRequest();
|
||
|
})
|
||
|
.always(() => {
|
||
|
mergeConflictsStore.setLoadingState(false);
|
||
|
|
||
|
this.$nextTick(() => {
|
||
|
$(conflictsEl.querySelectorAll('.js-syntax-highlight')).syntaxHighlight();
|
||
|
});
|
||
|
});
|
||
|
},
|
||
|
methods: {
|
||
|
handleViewTypeChange(viewType) {
|
||
|
mergeConflictsStore.setViewType(viewType);
|
||
|
},
|
||
|
onClickResolveModeButton(file, mode) {
|
||
|
if (mode === INTERACTIVE_RESOLVE_MODE && file.resolveEditChanged) {
|
||
|
mergeConflictsStore.setPromptConfirmationState(file, true);
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
mergeConflictsStore.setFileResolveMode(file, mode);
|
||
|
},
|
||
|
acceptDiscardConfirmation(file) {
|
||
|
mergeConflictsStore.setPromptConfirmationState(file, false);
|
||
|
mergeConflictsStore.setFileResolveMode(file, INTERACTIVE_RESOLVE_MODE);
|
||
|
},
|
||
|
cancelDiscardConfirmation(file) {
|
||
|
mergeConflictsStore.setPromptConfirmationState(file, false);
|
||
|
},
|
||
|
commit() {
|
||
|
mergeConflictsStore.setSubmitState(true);
|
||
|
|
||
|
mergeConflictsService
|
||
|
.submitResolveConflicts(mergeConflictsStore.getCommitData())
|
||
|
.done((data) => {
|
||
|
window.location.href = data.redirect_to;
|
||
|
})
|
||
|
.error(() => {
|
||
|
mergeConflictsStore.setSubmitState(false);
|
||
|
new Flash('Failed to save merge conflicts resolutions. Please try again!');
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
})
|
||
|
});
|