| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152 | import type { EditorConfig, NodeKey, SerializedTextNode } from 'lexical'import { $createTextNode, TextNode } from 'lexical'export class CustomTextNode extends TextNode {  static getType() {    return 'custom-text'  }  static clone(node: CustomTextNode) {    return new CustomTextNode(node.__text, node.__key)  }  constructor(text: string, key?: NodeKey) {    super(text, key)  }  createDOM(config: EditorConfig) {    const dom = super.createDOM(config)    dom.classList.add('align-middle')    return dom  }  static importJSON(serializedNode: SerializedTextNode): TextNode {    const node = $createTextNode(serializedNode.text)    node.setFormat(serializedNode.format)    node.setDetail(serializedNode.detail)    node.setMode(serializedNode.mode)    node.setStyle(serializedNode.style)    return node  }  exportJSON(): SerializedTextNode {    return {      detail: this.getDetail(),      format: this.getFormat(),      mode: this.getMode(),      style: this.getStyle(),      text: this.getTextContent(),      type: 'custom-text',      version: 1,    }  }  isSimpleText() {    return (      (this.__type === 'text' || this.__type === 'custom-text') && this.__mode === 0)  }}export function $createCustomTextNode(text: string): CustomTextNode {  return new CustomTextNode(text)}
 |