-
Notifications
You must be signed in to change notification settings - Fork 1.5k
/
index.tsx
40 lines (33 loc) · 1.14 KB
/
index.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
*/
import {useLexicalComposerContext} from '@lexical/react/LexicalComposerContext';
import {$insertNodeToNearestRoot} from '@lexical/utils';
import {COMMAND_PRIORITY_EDITOR, createCommand, LexicalCommand} from 'lexical';
import {useEffect} from 'react';
import {$createFigmaNode, FigmaNode} from '../../nodes/FigmaNode';
export const INSERT_FIGMA_COMMAND: LexicalCommand<string> = createCommand(
'INSERT_FIGMA_COMMAND',
);
export default function FigmaPlugin(): JSX.Element | null {
const [editor] = useLexicalComposerContext();
useEffect(() => {
if (!editor.hasNodes([FigmaNode])) {
throw new Error('FigmaPlugin: FigmaNode not registered on editor');
}
return editor.registerCommand<string>(
INSERT_FIGMA_COMMAND,
(payload) => {
const figmaNode = $createFigmaNode(payload);
$insertNodeToNearestRoot(figmaNode);
return true;
},
COMMAND_PRIORITY_EDITOR,
);
}, [editor]);
return null;
}