Commit ce94b55f authored by Jose Ivan Vargas's avatar Jose Ivan Vargas

Merge branch 'dmishunov-editor-lite-reusability' into 'master'

Improve re-usability of Editor Lite

See merge request gitlab-org/gitlab!45083
parents 8f02467b e16a692a
......@@ -123,7 +123,7 @@ export default {
};
</script>
<template>
<div class="form-group file-editor">
<div class="form-group">
<label :for="firstInputId">{{ s__('Snippets|Files') }}</label>
<snippet-blob-edit
v-for="(blobId, index) in blobIds"
......
......@@ -57,6 +57,9 @@ export default {
fileName(newVal) {
this.editor.updateModelLanguage(newVal);
},
value(newVal) {
this.editor.setValue(newVal);
},
},
mounted() {
this.editor = initEditorLite({
......@@ -83,9 +86,12 @@ export default {
};
</script>
<template>
<div class="file-content code">
<div id="editor" ref="editor" data-editor-loading @editor-ready="$emit('editor-ready')">
<div
:id="`editor-lite-${fileGlobalId}`"
ref="editor"
data-editor-loading
@editor-ready="$emit('editor-ready')"
>
<pre class="editor-loading-content">{{ value }}</pre>
</div>
</div>
</template>
.monaco-editor.gl-editor-lite {
.line-numbers {
@include gl-pt-0;
}
[id^='editor-lite-'] {
height: 500px;
}
......@@ -79,7 +79,7 @@ module QA
private
def text_area
find('#editor textarea', visible: false)
find('.monaco-editor textarea', visible: false)
end
end
end
......
......@@ -26,7 +26,7 @@ module QA
private
def text_area
find('#editor textarea', visible: false)
find('.monaco-editor textarea', visible: false)
end
end
end
......
......@@ -2,17 +2,13 @@
exports[`Editor Lite component rendering matches the snapshot 1`] = `
<div
class="file-content code"
>
<div
data-editor-loading=""
id="editor"
>
id="editor-lite-snippet_777"
>
<pre
class="editor-loading-content"
>
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
</pre>
</div>
</div>
`;
......@@ -10,6 +10,7 @@ describe('Editor Lite component', () => {
const onDidChangeModelContent = jest.fn();
const updateModelLanguage = jest.fn();
const getValue = jest.fn();
const setValue = jest.fn();
const value = 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.';
const fileName = 'lorem.txt';
const fileGlobalId = 'snippet_777';
......@@ -17,6 +18,7 @@ describe('Editor Lite component', () => {
onDidChangeModelContent,
updateModelLanguage,
getValue,
setValue,
dispose: jest.fn(),
}));
Editor.mockImplementation(() => {
......@@ -68,7 +70,7 @@ describe('Editor Lite component', () => {
createComponent({ value: undefined });
expect(spy).not.toHaveBeenCalled();
expect(wrapper.find('#editor').exists()).toBe(true);
expect(wrapper.find('[id^="editor-lite-"]').exists()).toBe(true);
});
it('initialises Editor Lite instance', () => {
......@@ -94,6 +96,17 @@ describe('Editor Lite component', () => {
});
});
it('reacts to the changes in the pased value', async () => {
const newValue = 'New Value';
wrapper.setProps({
value: newValue,
});
await nextTick();
expect(setValue).toHaveBeenCalledWith(newValue);
});
it('registers callback with editor onChangeContent', () => {
expect(onDidChangeModelContent).toHaveBeenCalledWith(expect.any(Function));
});
......
......@@ -31,7 +31,7 @@ module Spec
end
def snippet_get_first_blob_value
page.find('.file-content', match: :first)
page.find('.gl-editor-lite', match: :first)
end
def snippet_description_value
......@@ -53,7 +53,7 @@ module Spec
end
def snippet_fill_in_content(value)
page.within('.file-editor') do
page.within('.gl-editor-lite') do
el = find('.inputarea')
el.send_keys value
end
......
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