|
import type { LexicalNode, SerializedLexicalNode } from 'lexical' |
|
import { DecoratorNode } from 'lexical' |
|
import QueryBlockComponent from './component' |
|
|
|
export type SerializedNode = SerializedLexicalNode |
|
|
|
export class QueryBlockNode extends DecoratorNode<JSX.Element> { |
|
static getType(): string { |
|
return 'query-block' |
|
} |
|
|
|
static clone(): QueryBlockNode { |
|
return new QueryBlockNode() |
|
} |
|
|
|
isInline(): boolean { |
|
return true |
|
} |
|
|
|
createDOM(): HTMLElement { |
|
const div = document.createElement('div') |
|
div.classList.add('inline-flex', 'items-center', 'align-middle') |
|
return div |
|
} |
|
|
|
updateDOM(): false { |
|
return false |
|
} |
|
|
|
decorate(): JSX.Element { |
|
return <QueryBlockComponent nodeKey={this.getKey()} /> |
|
} |
|
|
|
static importJSON(): QueryBlockNode { |
|
const node = $createQueryBlockNode() |
|
|
|
return node |
|
} |
|
|
|
exportJSON(): SerializedNode { |
|
return { |
|
type: 'query-block', |
|
version: 1, |
|
} |
|
} |
|
|
|
getTextContent(): string { |
|
return '{{#query#}}' |
|
} |
|
} |
|
export function $createQueryBlockNode(): QueryBlockNode { |
|
return new QueryBlockNode() |
|
} |
|
|
|
export function $isQueryBlockNode( |
|
node: QueryBlockNode | LexicalNode | null | undefined, |
|
): node is QueryBlockNode { |
|
return node instanceof QueryBlockNode |
|
} |
|
|