summaryrefslogtreecommitdiff
path: root/app/assets/javascripts/merge_conflicts
diff options
context:
space:
mode:
authorAlfredo Sumaran <alfredo@gitlab.com>2016-09-16 19:41:15 -0500
committerAlfredo Sumaran <alfredo@gitlab.com>2016-10-13 14:16:34 -0500
commita3eb39a1068df93d732585272c5eaff380801430 (patch)
tree7ec0263041316dbf37e8638ecd9fd79ec2dbe1c7 /app/assets/javascripts/merge_conflicts
parent26f658decd3943bbc66c567ea91e7b859b32e0e6 (diff)
downloadgitlab-ce-a3eb39a1068df93d732585272c5eaff380801430.tar.gz
Replace textarea with Ace editor
Diffstat (limited to 'app/assets/javascripts/merge_conflicts')
-rw-r--r--app/assets/javascripts/merge_conflicts/components/diff_file_editor.js.es627
1 files changed, 20 insertions, 7 deletions
diff --git a/app/assets/javascripts/merge_conflicts/components/diff_file_editor.js.es6 b/app/assets/javascripts/merge_conflicts/components/diff_file_editor.js.es6
index 570d9ff877c..abdf73febb4 100644
--- a/app/assets/javascripts/merge_conflicts/components/diff_file_editor.js.es6
+++ b/app/assets/javascripts/merge_conflicts/components/diff_file_editor.js.es6
@@ -4,7 +4,7 @@
template: '#diff-file-editor',
data() {
return {
- originalState: '',
+ originalContent: '',
saved: false,
loading: false,
fileLoaded: false
@@ -23,6 +23,8 @@
loadFile(val) {
const self = this;
+ this.resetEditorContent();
+
if (!val || this.fileLoaded || this.loading) {
return
}
@@ -31,10 +33,19 @@
$.get(this.file.content_path)
.done((file) => {
- $(self.$el).find('textarea').val(file.content);
- self.originalState = file.content;
+ let content = self.$el.querySelector('pre');
+ let fileContent = document.createTextNode(file.content);
+
+ content.textContent = fileContent.textContent;
+
+ self.originalContent = file.content;
self.fileLoaded = true;
+ self.editor = ace.edit(content);
+ self.editor.$blockScrolling = Infinity; // Turn off annoying warning
+ self.editor.on('change', () => {
+ self.saveDiffResolution();
+ });
self.saveDiffResolution();
})
.fail(() => {
@@ -50,12 +61,14 @@
this.saved = true;
// This probably be better placed in the data provider
- this.file.content = this.$el.querySelector('textarea').value;
- this.file.resolveEditChanged = this.file.content !== this.originalState;
+ this.file.content = this.editor.getValue();
+ this.file.resolveEditChanged = this.file.content !== this.originalContent;
this.file.promptDiscardConfirmation = false;
},
- onInput() {
- this.saveDiffResolution();
+ resetEditorContent() {
+ if (this.fileLoaded) {
+ this.editor.setValue(this.originalContent, -1);
+ }
}
}
});