2022-03-16 18:33:53 +08:00
|
|
|
import LiveEditor from "./cell_editor/live_editor";
|
2022-03-15 05:19:56 +08:00
|
|
|
import { getAttributeOrThrow } from "../lib/attribute";
|
|
|
|
|
|
|
|
const CellEditor = {
|
|
|
|
mounted() {
|
2022-03-16 18:33:53 +08:00
|
|
|
this.props = this.getProps();
|
2022-03-15 05:19:56 +08:00
|
|
|
|
|
|
|
this.handleEvent(
|
|
|
|
`cell_editor_init:${this.props.cellId}:${this.props.tag}`,
|
|
|
|
({ source_view, language, intellisense, read_only }) => {
|
|
|
|
const editorContainer = this.el.querySelector(
|
2022-04-04 18:19:11 +08:00
|
|
|
`[data-el-editor-container]`
|
2022-03-15 05:19:56 +08:00
|
|
|
);
|
|
|
|
|
|
|
|
const editorEl = document.createElement("div");
|
|
|
|
editorContainer.appendChild(editorEl);
|
|
|
|
|
|
|
|
this.liveEditor = new LiveEditor(
|
|
|
|
this,
|
|
|
|
editorEl,
|
|
|
|
this.props.cellId,
|
|
|
|
this.props.tag,
|
|
|
|
source_view.source,
|
|
|
|
source_view.revision,
|
|
|
|
language,
|
|
|
|
intellisense,
|
|
|
|
read_only
|
|
|
|
);
|
|
|
|
|
2022-04-13 18:45:29 +08:00
|
|
|
this.liveEditor.onMount(() => {
|
|
|
|
// Remove the content placeholder
|
|
|
|
editorContainer.querySelector(`[data-el-skeleton]`).remove();
|
|
|
|
});
|
|
|
|
|
2022-03-15 05:19:56 +08:00
|
|
|
this.el.dispatchEvent(
|
|
|
|
new CustomEvent("lb:cell:editor_created", {
|
|
|
|
detail: { tag: this.props.tag, liveEditor: this.liveEditor },
|
|
|
|
bubbles: true,
|
|
|
|
})
|
|
|
|
);
|
|
|
|
}
|
|
|
|
);
|
|
|
|
},
|
|
|
|
|
|
|
|
destroyed() {
|
|
|
|
if (this.liveEditor) {
|
|
|
|
this.el.dispatchEvent(
|
|
|
|
new CustomEvent("lb:cell:editor_removed", {
|
|
|
|
detail: { tag: this.props.tag },
|
|
|
|
bubbles: true,
|
|
|
|
})
|
|
|
|
);
|
|
|
|
this.liveEditor.dispose();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2022-03-16 18:33:53 +08:00
|
|
|
getProps() {
|
|
|
|
return {
|
|
|
|
cellId: getAttributeOrThrow(this.el, "data-cell-id"),
|
|
|
|
tag: getAttributeOrThrow(this.el, "data-tag"),
|
|
|
|
};
|
|
|
|
},
|
|
|
|
};
|
2022-03-15 05:19:56 +08:00
|
|
|
|
|
|
|
export default CellEditor;
|