Spaces:
Running
Running
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) | |
} | |