import { customElement, LitElement, property } from "lit-element"; // @ts-ignore import CodeMirror from "codemirror"; import "codemirror/addon/display/autorefresh"; import "codemirror/mode/xml/xml.js"; import "codemirror/mode/yaml/yaml.js"; import "codemirror/mode/javascript/javascript.js"; import "codemirror/mode/python/python.js"; @customElement("ak-codemirror") export class CodeMirrorTextarea extends LitElement { @property({type: Boolean}) readOnly = false; @property() mode = "yaml"; editor?: CodeMirror.EditorFromTextArea; createRenderRoot() : ShadowRoot | Element { return this; } firstUpdated(): void { const textarea = this.querySelector("textarea"); if (!textarea) { return; } this.editor = CodeMirror.fromTextArea(textarea, { mode: this.mode, theme: "monokai", lineNumbers: false, readOnly: this.readOnly, autoRefresh: true, }); this.editor.on("blur", () => { this.editor?.save(); }); } }