@webiny/lexical-editor 6.3.0-beta.4 → 6.4.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/commands/image.js +2 -1
- package/commands/image.js.map +1 -1
- package/commands/index.js +0 -2
- package/commands/list.js +4 -3
- package/commands/list.js.map +1 -1
- package/commands/quote.js +2 -1
- package/commands/quote.js.map +1 -1
- package/commands/toolbar.js +2 -1
- package/commands/toolbar.js.map +1 -1
- package/commands/typography.js +2 -1
- package/commands/typography.js.map +1 -1
- package/components/Editor/EnsureHeadingTagPlugin.js +8 -15
- package/components/Editor/EnsureHeadingTagPlugin.js.map +1 -1
- package/components/Editor/RichTextEditor.js +82 -121
- package/components/Editor/RichTextEditor.js.map +1 -1
- package/components/Editor/normalizeInputValue.js +11 -13
- package/components/Editor/normalizeInputValue.js.map +1 -1
- package/components/LexicalEditorConfig/LexicalEditorConfig.js +24 -15
- package/components/LexicalEditorConfig/LexicalEditorConfig.js.map +1 -1
- package/components/LexicalEditorConfig/components/Node.js +21 -26
- package/components/LexicalEditorConfig/components/Node.js.map +1 -1
- package/components/LexicalEditorConfig/components/Plugin.js +21 -26
- package/components/LexicalEditorConfig/components/Plugin.js.map +1 -1
- package/components/LexicalEditorConfig/components/ToolbarElement.js +21 -26
- package/components/LexicalEditorConfig/components/ToolbarElement.js.map +1 -1
- package/components/LexicalHtmlRenderer.js +35 -40
- package/components/LexicalHtmlRenderer.js.map +1 -1
- package/components/Toolbar/StaticToolbar.js +11 -16
- package/components/Toolbar/StaticToolbar.js.map +1 -1
- package/components/ToolbarActions/BoldAction.js +16 -19
- package/components/ToolbarActions/BoldAction.js.map +1 -1
- package/components/ToolbarActions/BulletListAction.js +24 -32
- package/components/ToolbarActions/BulletListAction.js.map +1 -1
- package/components/ToolbarActions/CodeHighlightAction.js +16 -19
- package/components/ToolbarActions/CodeHighlightAction.js.map +1 -1
- package/components/ToolbarActions/FontColorAction.js +32 -38
- package/components/ToolbarActions/FontColorAction.js.map +1 -1
- package/components/ToolbarActions/ImageAction.js +28 -30
- package/components/ToolbarActions/ImageAction.js.map +1 -1
- package/components/ToolbarActions/ItalicAction.js +16 -19
- package/components/ToolbarActions/ItalicAction.js.map +1 -1
- package/components/ToolbarActions/LinkAction.js +25 -30
- package/components/ToolbarActions/LinkAction.js.map +1 -1
- package/components/ToolbarActions/NumberedListAction.js +28 -37
- package/components/ToolbarActions/NumberedListAction.js.map +1 -1
- package/components/ToolbarActions/QuoteAction.js +22 -27
- package/components/ToolbarActions/QuoteAction.js.map +1 -1
- package/components/ToolbarActions/TextAlignmentAction.js +38 -50
- package/components/ToolbarActions/TextAlignmentAction.js.map +1 -1
- package/components/ToolbarActions/TypographyAction.js +69 -99
- package/components/ToolbarActions/TypographyAction.js.map +1 -1
- package/components/ToolbarActions/UnderlineAction.js +16 -19
- package/components/ToolbarActions/UnderlineAction.js.map +1 -1
- package/context/FontColorActionContext.js +3 -2
- package/context/FontColorActionContext.js.map +1 -1
- package/context/RichTextEditorContext.js +26 -29
- package/context/RichTextEditorContext.js.map +1 -1
- package/context/SharedHistoryContext.js +11 -15
- package/context/SharedHistoryContext.js.map +1 -1
- package/context/TextAlignmentActionContextProps.js +3 -2
- package/context/TextAlignmentActionContextProps.js.map +1 -1
- package/context/TypographyActionContext.js +3 -2
- package/context/TypographyActionContext.js.map +1 -1
- package/exports/admin/lexical.js +2 -20
- package/hooks/index.js +0 -2
- package/hooks/useCurrentElement.js +18 -21
- package/hooks/useCurrentElement.js.map +1 -1
- package/hooks/useCurrentSelection.js +39 -48
- package/hooks/useCurrentSelection.js.map +1 -1
- package/hooks/useFontColorPicker.js +5 -6
- package/hooks/useFontColorPicker.js.map +1 -1
- package/hooks/useIsMounted.js +7 -8
- package/hooks/useIsMounted.js.map +1 -1
- package/hooks/useRichTextEditor.js +5 -6
- package/hooks/useRichTextEditor.js.map +1 -1
- package/hooks/useTextAlignmentAction.js +5 -6
- package/hooks/useTextAlignmentAction.js.map +1 -1
- package/hooks/useTypographyAction.js +5 -6
- package/hooks/useTypographyAction.js.map +1 -1
- package/images/icons/chat-square-quote.js +19 -0
- package/images/icons/chat-square-quote.js.map +1 -0
- package/images/icons/chevron-down.js +18 -0
- package/images/icons/chevron-down.js.map +1 -0
- package/images/icons/code.js +17 -0
- package/images/icons/code.js.map +1 -0
- package/images/icons/font-color.js +17 -0
- package/images/icons/font-color.js.map +1 -0
- package/images/icons/indent.js +18 -0
- package/images/icons/indent.js.map +1 -0
- package/images/icons/insert-image.js +20 -0
- package/images/icons/insert-image.js.map +1 -0
- package/images/icons/justify.js +19 -0
- package/images/icons/justify.js.map +1 -0
- package/images/icons/link.js +19 -0
- package/images/icons/link.js.map +1 -0
- package/images/icons/list-ol.js +20 -0
- package/images/icons/list-ol.js.map +1 -0
- package/images/icons/list-ul.js +18 -0
- package/images/icons/list-ul.js.map +1 -0
- package/images/icons/outdent.js +18 -0
- package/images/icons/outdent.js.map +1 -0
- package/images/icons/pencil-fill.js +17 -0
- package/images/icons/pencil-fill.js.map +1 -0
- package/images/icons/text-center.js +18 -0
- package/images/icons/text-center.js.map +1 -0
- package/images/icons/text-left.js +18 -0
- package/images/icons/text-left.js.map +1 -0
- package/images/icons/text-paragraph.js +18 -0
- package/images/icons/text-paragraph.js.map +1 -0
- package/images/icons/text-right.js +18 -0
- package/images/icons/text-right.js.map +1 -0
- package/images/icons/type-bold.js +17 -0
- package/images/icons/type-bold.js.map +1 -0
- package/images/icons/type-h1.js +17 -0
- package/images/icons/type-h1.js.map +1 -0
- package/images/icons/type-h2.js +17 -0
- package/images/icons/type-h2.js.map +1 -0
- package/images/icons/type-h3.js +17 -0
- package/images/icons/type-h3.js.map +1 -0
- package/images/icons/type-h4.js +17 -0
- package/images/icons/type-h4.js.map +1 -0
- package/images/icons/type-h5.js +17 -0
- package/images/icons/type-h5.js.map +1 -0
- package/images/icons/type-h6.js +17 -0
- package/images/icons/type-h6.js.map +1 -0
- package/images/icons/type-italic.js +17 -0
- package/images/icons/type-italic.js.map +1 -0
- package/images/icons/type-strikethrough.js +17 -0
- package/images/icons/type-strikethrough.js.map +1 -0
- package/images/icons/type-underline.js +17 -0
- package/images/icons/type-underline.js.map +1 -0
- package/images/icons/unlink_icon.js +27 -0
- package/images/icons/unlink_icon.js.map +1 -0
- package/index.js +5 -18
- package/package.json +7 -7
- package/plugins/BlurEventPlugin/BlurEventPlugin.js +11 -14
- package/plugins/BlurEventPlugin/BlurEventPlugin.js.map +1 -1
- package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js +7 -8
- package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js.map +1 -1
- package/plugins/CodeHighlightPlugin/index.js +0 -2
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js +16 -24
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js +37 -51
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js +6 -5
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/index.js +0 -2
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js +6 -9
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/types.js +0 -3
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js +101 -108
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js.map +1 -1
- package/plugins/FontColorPlugin/FontColorPlugin.js +14 -19
- package/plugins/FontColorPlugin/FontColorPlugin.js.map +1 -1
- package/plugins/FontColorPlugin/applyColorToNode.js +5 -4
- package/plugins/FontColorPlugin/applyColorToNode.js.map +1 -1
- package/plugins/FontColorPlugin/applyColorToSelection.js +42 -60
- package/plugins/FontColorPlugin/applyColorToSelection.js.map +1 -1
- package/plugins/ImagesPlugin/ImagesPlugin.js +79 -121
- package/plugins/ImagesPlugin/ImagesPlugin.js.map +1 -1
- package/plugins/LinkPlugin/LinkPlugin.js +46 -52
- package/plugins/LinkPlugin/LinkPlugin.js.map +1 -1
- package/plugins/ListPLugin/ListPlugin.js +44 -52
- package/plugins/ListPLugin/ListPlugin.js.map +1 -1
- package/plugins/QuoteNodePlugin/QuoteNodePlugin.js +18 -19
- package/plugins/QuoteNodePlugin/QuoteNodePlugin.js.map +1 -1
- package/plugins/StateHandlingPlugin.js +55 -64
- package/plugins/StateHandlingPlugin.js.map +1 -1
- package/plugins/TypographyPlugin/TypographyPlugin.js +13 -20
- package/plugins/TypographyPlugin/TypographyPlugin.js.map +1 -1
- package/static/svg/chat-square-quote.123cfa24.svg +1 -0
- package/static/svg/chevron-down.d9636921.svg +1 -0
- package/static/svg/code.912b1f4d.svg +1 -0
- package/static/svg/font-color.4f0c0de5.svg +1 -0
- package/static/svg/indent.4d78e483.svg +3 -0
- package/static/svg/insert-image.354465f1.svg +4 -0
- package/static/svg/justify.dab42aec.svg +3 -0
- package/static/svg/link.b774de25.svg +1 -0
- package/static/svg/list-ol.d64946f3.svg +1 -0
- package/static/svg/list-ul.1d54da3f.svg +1 -0
- package/static/svg/outdent.5c13ff16.svg +3 -0
- package/static/svg/pencil-fill.94cb216b.svg +1 -0
- package/static/svg/text-center.a411e780.svg +1 -0
- package/static/svg/text-left.54f41f4e.svg +1 -0
- package/static/svg/text-paragraph.61674422.svg +1 -0
- package/static/svg/text-right.9288b7a2.svg +1 -0
- package/static/svg/type-bold.7e3e270b.svg +1 -0
- package/static/svg/type-h1.f292ffe1.svg +1 -0
- package/static/svg/type-h2.a9d1aa48.svg +1 -0
- package/static/svg/type-h3.4a29ff88.svg +1 -0
- package/static/svg/type-h4.7f48750c.svg +1 -0
- package/static/svg/type-h5.14b4ac56.svg +1 -0
- package/static/svg/type-h6.4e9dfe2d.svg +1 -0
- package/static/svg/type-italic.d8e45748.svg +1 -0
- package/static/svg/type-strikethrough.2694a816.svg +1 -0
- package/static/svg/type-underline.104a0ed5.svg +1 -0
- package/static/svg/unlink_icon.074ceed3.svg +1 -0
- package/types.js +0 -8
- package/ui/ContentEditable.js +6 -14
- package/ui/ContentEditable.js.map +1 -1
- package/ui/Divider.js +6 -5
- package/ui/Divider.js.map +1 -1
- package/ui/DropDown.js +146 -176
- package/ui/DropDown.js.map +1 -1
- package/ui/ImageResizer.js +173 -204
- package/ui/ImageResizer.js.map +1 -1
- package/ui/LinkPreview.js +61 -84
- package/ui/LinkPreview.js.map +1 -1
- package/ui/Placeholder.js +9 -20
- package/ui/Placeholder.js.map +1 -1
- package/ui/TextInput.js +17 -30
- package/ui/TextInput.js.map +1 -1
- package/ui/ToolbarActionDialog.js +64 -73
- package/ui/ToolbarActionDialog.js.map +1 -1
- package/utils/canUseDOM.js +2 -1
- package/utils/canUseDOM.js.map +1 -1
- package/utils/files.js +9 -8
- package/utils/files.js.map +1 -1
- package/utils/getDOMRangeRect.js +10 -20
- package/utils/getDOMRangeRect.js.map +1 -1
- package/utils/getSelectedNode.js +9 -20
- package/utils/getSelectedNode.js.map +1 -1
- package/utils/getTransparentImage.js +2 -3
- package/utils/getTransparentImage.js.map +1 -1
- package/utils/insertImage.js +9 -11
- package/utils/insertImage.js.map +1 -1
- package/utils/isAnchorLink.js +2 -3
- package/utils/isAnchorLink.js.map +1 -1
- package/utils/isChildOfFloatingToolbar.js +6 -9
- package/utils/isChildOfFloatingToolbar.js.map +1 -1
- package/utils/isHTMLElement.js +3 -9
- package/utils/isHTMLElement.js.map +1 -1
- package/utils/isValidJSON.js +9 -10
- package/utils/isValidJSON.js.map +1 -1
- package/utils/isValidLexicalData.js +17 -20
- package/utils/isValidLexicalData.js.map +1 -1
- package/utils/point.js +32 -45
- package/utils/point.js.map +1 -1
- package/utils/rect.js +92 -125
- package/utils/rect.js.map +1 -1
- package/utils/sanitizeUrl.js +8 -21
- package/utils/sanitizeUrl.js.map +1 -1
- package/utils/setFloatingElemPosition.js +23 -27
- package/utils/setFloatingElemPosition.js.map +1 -1
- package/commands/index.js.map +0 -1
- package/exports/admin/lexical.js.map +0 -1
- package/hooks/index.js.map +0 -1
- package/index.js.map +0 -1
- package/plugins/CodeHighlightPlugin/index.js.map +0 -1
- package/plugins/FloatingLinkEditorPlugin/index.js.map +0 -1
- package/plugins/FloatingLinkEditorPlugin/types.js.map +0 -1
- package/types.js.map +0 -1
|
@@ -1,61 +1,47 @@
|
|
|
1
|
-
import
|
|
1
|
+
import react, { useCallback, useEffect, useState } from "react";
|
|
2
2
|
import { createPortal } from "react-dom";
|
|
3
3
|
import { useRichTextEditor } from "../../hooks/index.js";
|
|
4
4
|
import { getSelectedNode } from "../../utils/getSelectedNode.js";
|
|
5
5
|
import { $isAutoLinkNode, $isLinkNode, TOGGLE_LINK_COMMAND } from "@webiny/lexical-nodes";
|
|
6
6
|
import { isChildOfLinkEditor } from "./isChildOfLinkEditor.js";
|
|
7
7
|
import debounce from "lodash/debounce.js";
|
|
8
|
-
import { $getSelection, $isRangeSelection, BLUR_COMMAND, COMMAND_PRIORITY_CRITICAL, COMMAND_PRIORITY_LOW, SELECTION_CHANGE_COMMAND, mergeRegister
|
|
8
|
+
import { $findMatchingParent, $getSelection, $isRangeSelection, BLUR_COMMAND, COMMAND_PRIORITY_CRITICAL, COMMAND_PRIORITY_LOW, SELECTION_CHANGE_COMMAND, mergeRegister } from "lexical";
|
|
9
9
|
import { FloatingLinkEditor } from "./FloatingLinkEditor.js";
|
|
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
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
}, COMMAND_PRIORITY_CRITICAL), editor.registerCommand(BLUR_COMMAND, payload => {
|
|
45
|
-
if (!isChildOfLinkEditor(payload.relatedTarget)) {
|
|
46
|
-
setIsLink(false);
|
|
47
|
-
}
|
|
48
|
-
return false;
|
|
49
|
-
}, COMMAND_PRIORITY_LOW), editor.registerCommand(TOGGLE_LINK_COMMAND, payload => {
|
|
50
|
-
setIsLink(!!payload);
|
|
51
|
-
return false;
|
|
52
|
-
}, COMMAND_PRIORITY_CRITICAL));
|
|
53
|
-
}, [editor, updateToolbar]);
|
|
54
|
-
return /*#__PURE__*/createPortal(/*#__PURE__*/React.createElement(FloatingLinkEditor, {
|
|
55
|
-
isVisible: isLink,
|
|
56
|
-
editor: editor,
|
|
57
|
-
LinkForm: props.LinkForm
|
|
58
|
-
}), getOverlaysElement());
|
|
10
|
+
const FloatingLinkEditorController = (props)=>{
|
|
11
|
+
const { editor, getOverlaysElement } = useRichTextEditor();
|
|
12
|
+
const [isLink, setIsLink] = useState(false);
|
|
13
|
+
const debounceSetIsLink = useCallback(debounce(setIsLink, 50), []);
|
|
14
|
+
const updateToolbar = useCallback(()=>{
|
|
15
|
+
const selection = $getSelection();
|
|
16
|
+
if (!$isRangeSelection(selection)) return;
|
|
17
|
+
const node = getSelectedNode(selection);
|
|
18
|
+
const linkParent = $findMatchingParent(node, $isLinkNode);
|
|
19
|
+
const autoLinkParent = $findMatchingParent(node, $isAutoLinkNode);
|
|
20
|
+
const isLinkOrChildOfLink = Boolean($isLinkNode(node) || linkParent);
|
|
21
|
+
if (!isLinkOrChildOfLink) setIsLink(false);
|
|
22
|
+
if (selection.dirty) {
|
|
23
|
+
if (null != linkParent && null == autoLinkParent) debounceSetIsLink(true);
|
|
24
|
+
}
|
|
25
|
+
}, []);
|
|
26
|
+
useEffect(()=>mergeRegister(editor.registerCommand(SELECTION_CHANGE_COMMAND, ()=>{
|
|
27
|
+
updateToolbar();
|
|
28
|
+
return false;
|
|
29
|
+
}, COMMAND_PRIORITY_CRITICAL), editor.registerCommand(BLUR_COMMAND, (payload)=>{
|
|
30
|
+
if (!isChildOfLinkEditor(payload.relatedTarget)) setIsLink(false);
|
|
31
|
+
return false;
|
|
32
|
+
}, COMMAND_PRIORITY_LOW), editor.registerCommand(TOGGLE_LINK_COMMAND, (payload)=>{
|
|
33
|
+
setIsLink(!!payload);
|
|
34
|
+
return false;
|
|
35
|
+
}, COMMAND_PRIORITY_CRITICAL)), [
|
|
36
|
+
editor,
|
|
37
|
+
updateToolbar
|
|
38
|
+
]);
|
|
39
|
+
return /*#__PURE__*/ createPortal(/*#__PURE__*/ react.createElement(FloatingLinkEditor, {
|
|
40
|
+
isVisible: isLink,
|
|
41
|
+
editor: editor,
|
|
42
|
+
LinkForm: props.LinkForm
|
|
43
|
+
}), getOverlaysElement());
|
|
59
44
|
};
|
|
45
|
+
export { FloatingLinkEditorController };
|
|
60
46
|
|
|
61
47
|
//# sourceMappingURL=FloatingLinkEditorController.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js","sources":["../../../src/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.tsx"],"sourcesContent":["import React, { useCallback, useState, useEffect } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport { useRichTextEditor } from \"~/hooks/index.js\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode.js\";\nimport { $isAutoLinkNode, $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { isChildOfLinkEditor } from \"~/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js\";\nimport debounce from \"lodash/debounce.js\";\nimport {\n $getSelection,\n $isRangeSelection,\n BLUR_COMMAND,\n COMMAND_PRIORITY_CRITICAL,\n COMMAND_PRIORITY_LOW,\n SELECTION_CHANGE_COMMAND,\n mergeRegister,\n $findMatchingParent\n} from \"lexical\";\nimport { FloatingLinkEditor } from \"./FloatingLinkEditor.js\";\nimport { LinkFormProps } from \"./types.js\";\n\ninterface FloatingLinkEditorProps {\n LinkForm: React.FunctionComponent<LinkFormProps>;\n}\n\nexport const FloatingLinkEditorController = (props: FloatingLinkEditorProps) => {\n const { editor, getOverlaysElement } = useRichTextEditor();\n const [isLink, setIsLink] = useState(false);\n\n const debounceSetIsLink = useCallback(debounce(setIsLink, 50), []);\n\n const updateToolbar = useCallback(() => {\n const selection = $getSelection();\n if (!$isRangeSelection(selection)) {\n return;\n }\n\n const node = getSelectedNode(selection);\n const linkParent = $findMatchingParent(node, $isLinkNode);\n const autoLinkParent = $findMatchingParent(node, $isAutoLinkNode);\n const isLinkOrChildOfLink = Boolean($isLinkNode(node) || linkParent);\n\n if (!isLinkOrChildOfLink) {\n // When hiding the toolbar, we want to hide immediately.\n setIsLink(false);\n }\n\n if (selection.dirty) {\n // We don't want this menu to open for auto links.\n if (linkParent != null && autoLinkParent == null) {\n // When showing the toolbar, we want to debounce it, because sometimes selection gets updated\n // multiple times, and the `selection.dirty` flag goes from true to false multiple times,\n // eventually settling on `false`, which we want to set once it has settled.\n debounceSetIsLink(true);\n }\n }\n }, []);\n\n useEffect(() => {\n return mergeRegister(\n editor.registerCommand(\n SELECTION_CHANGE_COMMAND,\n () => {\n updateToolbar();\n return false;\n },\n COMMAND_PRIORITY_CRITICAL\n ),\n editor.registerCommand(\n BLUR_COMMAND,\n payload => {\n if (!isChildOfLinkEditor(payload.relatedTarget as HTMLElement)) {\n setIsLink(false);\n }\n\n return false;\n },\n COMMAND_PRIORITY_LOW\n ),\n editor.registerCommand(\n TOGGLE_LINK_COMMAND,\n payload => {\n setIsLink(!!payload);\n return false;\n },\n COMMAND_PRIORITY_CRITICAL\n )\n );\n }, [editor, updateToolbar]);\n\n return createPortal(\n <FloatingLinkEditor isVisible={isLink} editor={editor} LinkForm={props.LinkForm} />,\n getOverlaysElement()\n );\n};\n"],"names":["FloatingLinkEditorController","props","editor","getOverlaysElement","useRichTextEditor","isLink","setIsLink","useState","debounceSetIsLink","useCallback","debounce","updateToolbar","selection","$getSelection","$isRangeSelection","node","getSelectedNode","linkParent","$findMatchingParent","$isLinkNode","autoLinkParent","$isAutoLinkNode","isLinkOrChildOfLink","Boolean","useEffect","mergeRegister","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_CRITICAL","BLUR_COMMAND","payload","isChildOfLinkEditor","COMMAND_PRIORITY_LOW","TOGGLE_LINK_COMMAND","createPortal","FloatingLinkEditor"],"mappings":";;;;;;;;;AAwBO,MAAMA,+BAA+B,CAACC;IACzC,MAAM,EAAEC,MAAM,EAAEC,kBAAkB,EAAE,GAAGC;IACvC,MAAM,CAACC,QAAQC,UAAU,GAAGC,SAAS;IAErC,MAAMC,oBAAoBC,YAAYC,SAASJ,WAAW,KAAK,EAAE;IAEjE,MAAMK,gBAAgBF,YAAY;QAC9B,MAAMG,YAAYC;QAClB,IAAI,CAACC,kBAAkBF,YACnB;QAGJ,MAAMG,OAAOC,gBAAgBJ;QAC7B,MAAMK,aAAaC,oBAAoBH,MAAMI;QAC7C,MAAMC,iBAAiBF,oBAAoBH,MAAMM;QACjD,MAAMC,sBAAsBC,QAAQJ,YAAYJ,SAASE;QAEzD,IAAI,CAACK,qBAEDhB,UAAU;QAGd,IAAIM,UAAU,KAAK,EAEf;YAAA,IAAIK,AAAc,QAAdA,cAAsBG,AAAkB,QAAlBA,gBAItBZ,kBAAkB;QACtB;IAER,GAAG,EAAE;IAELgB,UAAU,IACCC,cACHvB,OAAO,eAAe,CAClBwB,0BACA;YACIf;YACA,OAAO;QACX,GACAgB,4BAEJzB,OAAO,eAAe,CAClB0B,cACAC,CAAAA;YACI,IAAI,CAACC,oBAAoBD,QAAQ,aAAa,GAC1CvB,UAAU;YAGd,OAAO;QACX,GACAyB,uBAEJ7B,OAAO,eAAe,CAClB8B,qBACAH,CAAAA;YACIvB,UAAU,CAAC,CAACuB;YACZ,OAAO;QACX,GACAF,6BAGT;QAACzB;QAAQS;KAAc;IAE1B,OAAO,WAAP,GAAOsB,aAAa,WAADA,GACf,oBAACC,oBAAkBA;QAAC,WAAW7B;QAAQ,QAAQH;QAAQ,UAAUD,MAAM,QAAQ;QAC/EE;AAER"}
|
|
@@ -1,10 +1,11 @@
|
|
|
1
|
-
import
|
|
1
|
+
import react from "react";
|
|
2
2
|
import { FloatingLinkEditorController } from "./FloatingLinkEditorController.js";
|
|
3
3
|
import "./FloatingLinkEditorPlugin.css";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
4
|
+
function FloatingLinkEditorPlugin(props) {
|
|
5
|
+
return /*#__PURE__*/ react.createElement(FloatingLinkEditorController, {
|
|
6
|
+
LinkForm: props.LinkForm
|
|
7
|
+
});
|
|
8
8
|
}
|
|
9
|
+
export { FloatingLinkEditorPlugin };
|
|
9
10
|
|
|
10
11
|
//# sourceMappingURL=FloatingLinkEditorPlugin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js","sources":["../../../src/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.tsx"],"sourcesContent":["import React from \"react\";\nimport { FloatingLinkEditorController } from \"./FloatingLinkEditorController.js\";\nimport \"./FloatingLinkEditorPlugin.css\";\nimport { LinkFormProps } from \"./types.js\";\n\nexport function FloatingLinkEditorPlugin(props: {\n LinkForm: React.FunctionComponent<LinkFormProps>;\n}) {\n return <FloatingLinkEditorController LinkForm={props.LinkForm} />;\n}\n"],"names":["FloatingLinkEditorPlugin","props","FloatingLinkEditorController"],"mappings":";;;AAKO,SAASA,yBAAyBC,KAExC;IACG,OAAO,WAAP,GAAO,oBAACC,8BAA4BA;QAAC,UAAUD,MAAM,QAAQ;;AACjE"}
|
|
@@ -1,12 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
return
|
|
5
|
-
|
|
6
|
-
if (parent.classList.contains("link-editor")) {
|
|
7
|
-
return true;
|
|
8
|
-
}
|
|
9
|
-
return isChildOfLinkEditor(parent);
|
|
1
|
+
const isChildOfLinkEditor = (element)=>{
|
|
2
|
+
const parent = element ? element.parentElement : null;
|
|
3
|
+
if (!parent) return false;
|
|
4
|
+
if (parent.classList.contains("link-editor")) return true;
|
|
5
|
+
return isChildOfLinkEditor(parent);
|
|
10
6
|
};
|
|
7
|
+
export { isChildOfLinkEditor };
|
|
11
8
|
|
|
12
9
|
//# sourceMappingURL=isChildOfLinkEditor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js","sources":["../../../src/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.ts"],"sourcesContent":["export const isChildOfLinkEditor = (element: HTMLElement | null): boolean => {\n const parent = element ? element.parentElement : null;\n\n if (!parent) {\n return false;\n }\n\n if (parent.classList.contains(\"link-editor\")) {\n return true;\n }\n\n return isChildOfLinkEditor(parent);\n};\n"],"names":["isChildOfLinkEditor","element","parent"],"mappings":"AAAO,MAAMA,sBAAsB,CAACC;IAChC,MAAMC,SAASD,UAAUA,QAAQ,aAAa,GAAG;IAEjD,IAAI,CAACC,QACD,OAAO;IAGX,IAAIA,OAAO,SAAS,CAAC,QAAQ,CAAC,gBAC1B,OAAO;IAGX,OAAOF,oBAAoBE;AAC/B"}
|
|
@@ -1,128 +1,121 @@
|
|
|
1
1
|
import { useCallback, useEffect, useRef, useState } from "react";
|
|
2
|
-
import {
|
|
2
|
+
import { $getSelection, $isRangeSelection, COMMAND_PRIORITY_LOW, SELECTION_CHANGE_COMMAND, mergeRegister } from "lexical";
|
|
3
3
|
import { $isLinkNode, TOGGLE_LINK_COMMAND } from "@webiny/lexical-nodes";
|
|
4
4
|
import { getSelectedNode } from "../../utils/getSelectedNode.js";
|
|
5
5
|
import { setFloatingElemPosition } from "../../utils/setFloatingElemPosition.js";
|
|
6
6
|
import { sanitizeUrl } from "../../utils/sanitizeUrl.js";
|
|
7
7
|
const emptyLinkData = {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
url: "",
|
|
9
|
+
target: null,
|
|
10
|
+
alt: null
|
|
11
11
|
};
|
|
12
12
|
function getSelectionKey(selection) {
|
|
13
|
-
|
|
14
|
-
return
|
|
15
|
-
}
|
|
16
|
-
return null;
|
|
13
|
+
if ($isRangeSelection(selection)) return `${selection.anchor.key}:${selection.anchor.offset}-${selection.focus.key}:${selection.focus.offset}`;
|
|
14
|
+
return null;
|
|
17
15
|
}
|
|
18
16
|
function getLinkDataFromSelection() {
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
url: parent.getURL(),
|
|
28
|
-
target: parent.getTarget(),
|
|
29
|
-
alt: parent.getAlt()
|
|
17
|
+
const selection = $getSelection();
|
|
18
|
+
if (!$isRangeSelection(selection)) return emptyLinkData;
|
|
19
|
+
const node = getSelectedNode(selection);
|
|
20
|
+
const parent = node.getParent();
|
|
21
|
+
if ($isLinkNode(parent)) return {
|
|
22
|
+
url: parent.getURL(),
|
|
23
|
+
target: parent.getTarget(),
|
|
24
|
+
alt: parent.getAlt()
|
|
30
25
|
};
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
target: node.getTarget(),
|
|
36
|
-
alt: node.getAlt()
|
|
26
|
+
if ($isLinkNode(node)) return {
|
|
27
|
+
url: node.getURL(),
|
|
28
|
+
target: node.getTarget(),
|
|
29
|
+
alt: node.getAlt()
|
|
37
30
|
};
|
|
38
|
-
|
|
39
|
-
return emptyLinkData;
|
|
31
|
+
return emptyLinkData;
|
|
40
32
|
}
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
33
|
+
function useFloatingLinkEditor(editor) {
|
|
34
|
+
const editorRef = useRef(null);
|
|
35
|
+
const [linkData, setLinkData] = useState(emptyLinkData);
|
|
36
|
+
const [lastSelection, setLastSelection] = useState(null);
|
|
37
|
+
const suppressedSelectionKeyRef = useRef(null);
|
|
38
|
+
const updateLinkEditor = useCallback(()=>{
|
|
39
|
+
const selection = $getSelection();
|
|
40
|
+
const selectionKey = getSelectionKey(selection);
|
|
41
|
+
if (null !== suppressedSelectionKeyRef.current) {
|
|
42
|
+
if (selectionKey === suppressedSelectionKeyRef.current) {
|
|
43
|
+
const editorElem = editorRef.current;
|
|
44
|
+
if (editorElem) setFloatingElemPosition(null, editorElem);
|
|
45
|
+
setLastSelection(null);
|
|
46
|
+
setLinkData(emptyLinkData);
|
|
47
|
+
return true;
|
|
48
|
+
}
|
|
49
|
+
suppressedSelectionKeyRef.current = null;
|
|
50
|
+
}
|
|
51
|
+
setLinkData(getLinkDataFromSelection());
|
|
53
52
|
const editorElem = editorRef.current;
|
|
54
|
-
|
|
55
|
-
|
|
53
|
+
const nativeSelection = window.getSelection();
|
|
54
|
+
const activeElement = document.activeElement;
|
|
55
|
+
if (null === editorElem) return;
|
|
56
|
+
const rootElement = editor.getRootElement();
|
|
57
|
+
if (null !== selection && null !== nativeSelection && null !== rootElement && rootElement.contains(nativeSelection.anchorNode)) {
|
|
58
|
+
const range = nativeSelection.getRangeAt(0);
|
|
59
|
+
setFloatingElemPosition(range, editorElem);
|
|
60
|
+
setLastSelection(selection);
|
|
61
|
+
} else if (!activeElement || "link-input" !== activeElement.className) {
|
|
62
|
+
if (null !== rootElement) setFloatingElemPosition(null, editorElem);
|
|
63
|
+
setLastSelection(null);
|
|
64
|
+
setLinkData(emptyLinkData);
|
|
56
65
|
}
|
|
57
|
-
setLastSelection(null);
|
|
58
|
-
setLinkData(emptyLinkData);
|
|
59
66
|
return true;
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
editor.
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
67
|
+
}, [
|
|
68
|
+
editor
|
|
69
|
+
]);
|
|
70
|
+
const removeLink = useCallback(()=>{
|
|
71
|
+
editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);
|
|
72
|
+
}, [
|
|
73
|
+
editor
|
|
74
|
+
]);
|
|
75
|
+
const applyChanges = useCallback((linkData)=>{
|
|
76
|
+
const confirmedLinkData = {
|
|
77
|
+
url: sanitizeUrl(linkData.url),
|
|
78
|
+
target: linkData.target,
|
|
79
|
+
alt: linkData.alt
|
|
80
|
+
};
|
|
81
|
+
if (null !== lastSelection) {
|
|
82
|
+
editor.read(()=>{
|
|
83
|
+
const selection = $getSelection();
|
|
84
|
+
suppressedSelectionKeyRef.current = getSelectionKey(selection);
|
|
85
|
+
});
|
|
86
|
+
editor.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);
|
|
87
|
+
}
|
|
88
|
+
setLastSelection(null);
|
|
89
|
+
}, [
|
|
90
|
+
editor,
|
|
91
|
+
lastSelection
|
|
92
|
+
]);
|
|
93
|
+
useEffect(()=>mergeRegister(editor.registerUpdateListener(({ editorState })=>{
|
|
94
|
+
editorState.read(()=>{
|
|
95
|
+
updateLinkEditor();
|
|
96
|
+
});
|
|
97
|
+
}), editor.registerCommand(SELECTION_CHANGE_COMMAND, ()=>{
|
|
98
|
+
updateLinkEditor();
|
|
99
|
+
return false;
|
|
100
|
+
}, COMMAND_PRIORITY_LOW)), [
|
|
101
|
+
editor,
|
|
102
|
+
updateLinkEditor
|
|
103
|
+
]);
|
|
104
|
+
useEffect(()=>{
|
|
105
|
+
editor.read(()=>{
|
|
106
|
+
updateLinkEditor();
|
|
107
|
+
});
|
|
108
|
+
}, [
|
|
109
|
+
editor,
|
|
110
|
+
updateLinkEditor
|
|
111
|
+
]);
|
|
112
|
+
return {
|
|
113
|
+
editorRef,
|
|
114
|
+
linkData,
|
|
115
|
+
applyChanges,
|
|
116
|
+
removeLink
|
|
93
117
|
};
|
|
94
|
-
if (lastSelection !== null) {
|
|
95
|
-
editor.read(() => {
|
|
96
|
-
const selection = $getSelection();
|
|
97
|
-
suppressedSelectionKeyRef.current = getSelectionKey(selection);
|
|
98
|
-
});
|
|
99
|
-
editor.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);
|
|
100
|
-
}
|
|
101
|
-
setLastSelection(null);
|
|
102
|
-
}, [editor, lastSelection]);
|
|
103
|
-
useEffect(() => {
|
|
104
|
-
return mergeRegister(editor.registerUpdateListener(({
|
|
105
|
-
editorState
|
|
106
|
-
}) => {
|
|
107
|
-
editorState.read(() => {
|
|
108
|
-
updateLinkEditor();
|
|
109
|
-
});
|
|
110
|
-
}), editor.registerCommand(SELECTION_CHANGE_COMMAND, () => {
|
|
111
|
-
updateLinkEditor();
|
|
112
|
-
return false;
|
|
113
|
-
}, COMMAND_PRIORITY_LOW));
|
|
114
|
-
}, [editor, updateLinkEditor]);
|
|
115
|
-
useEffect(() => {
|
|
116
|
-
editor.read(() => {
|
|
117
|
-
updateLinkEditor();
|
|
118
|
-
});
|
|
119
|
-
}, [editor, updateLinkEditor]);
|
|
120
|
-
return {
|
|
121
|
-
editorRef,
|
|
122
|
-
linkData,
|
|
123
|
-
applyChanges,
|
|
124
|
-
removeLink
|
|
125
|
-
};
|
|
126
118
|
}
|
|
119
|
+
export { useFloatingLinkEditor };
|
|
127
120
|
|
|
128
121
|
//# sourceMappingURL=useFloatingLinkEditor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useCallback","useEffect","useRef","useState","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_LOW","$getSelection","$isRangeSelection","mergeRegister","$isLinkNode","TOGGLE_LINK_COMMAND","getSelectedNode","setFloatingElemPosition","sanitizeUrl","emptyLinkData","url","target","alt","getSelectionKey","selection","anchor","key","offset","focus","getLinkDataFromSelection","node","parent","getParent","getURL","getTarget","getAlt","useFloatingLinkEditor","editor","editorRef","linkData","setLinkData","lastSelection","setLastSelection","suppressedSelectionKeyRef","updateLinkEditor","selectionKey","current","editorElem","nativeSelection","window","getSelection","activeElement","document","rootElement","getRootElement","contains","anchorNode","range","getRangeAt","className","removeLink","dispatchCommand","applyChanges","confirmedLinkData","read","registerUpdateListener","editorState","registerCommand"],"sources":["useFloatingLinkEditor.ts"],"sourcesContent":["import { useCallback, useEffect, useRef, useState } from \"react\";\nimport {\n SELECTION_CHANGE_COMMAND,\n type BaseSelection,\n type LexicalEditor,\n COMMAND_PRIORITY_LOW,\n $getSelection,\n $isRangeSelection,\n mergeRegister\n} from \"lexical\";\nimport { $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode.js\";\nimport { setFloatingElemPosition } from \"~/utils/setFloatingElemPosition.js\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl.js\";\nimport { LinkData } from \"./types.js\";\n\nconst emptyLinkData: LinkData = { url: \"\", target: null, alt: null };\n\nfunction getSelectionKey(selection: BaseSelection | null): string | null {\n if ($isRangeSelection(selection)) {\n return `${selection.anchor.key}:${selection.anchor.offset}-${selection.focus.key}:${selection.focus.offset}`;\n }\n return null;\n}\n\nfunction getLinkDataFromSelection(): LinkData {\n const selection = $getSelection();\n if (!$isRangeSelection(selection)) {\n return emptyLinkData;\n }\n\n const node = getSelectedNode(selection);\n const parent = node.getParent();\n\n if ($isLinkNode(parent)) {\n return {\n url: parent.getURL(),\n target: parent.getTarget(),\n alt: parent.getAlt()\n };\n }\n\n if ($isLinkNode(node)) {\n return {\n url: node.getURL(),\n target: node.getTarget(),\n alt: node.getAlt()\n };\n }\n\n return emptyLinkData;\n}\n\nexport function useFloatingLinkEditor(editor: LexicalEditor) {\n const editorRef = useRef<HTMLDivElement | null>(null);\n const [linkData, setLinkData] = useState<LinkData>(emptyLinkData);\n const [lastSelection, setLastSelection] = useState<BaseSelection | null>(null);\n const suppressedSelectionKeyRef = useRef<string | null>(null);\n\n const updateLinkEditor = useCallback(() => {\n const selection = $getSelection();\n const selectionKey = getSelectionKey(selection);\n\n // If we're still on the same selection that was suppressed, hide the popover.\n if (suppressedSelectionKeyRef.current !== null) {\n if (selectionKey === suppressedSelectionKeyRef.current) {\n const editorElem = editorRef.current;\n if (editorElem) {\n setFloatingElemPosition(null, editorElem);\n }\n setLastSelection(null);\n setLinkData(emptyLinkData);\n return true;\n }\n // New selection — clear suppression.\n suppressedSelectionKeyRef.current = null;\n }\n\n setLinkData(getLinkDataFromSelection());\n\n const editorElem = editorRef.current;\n const nativeSelection = window.getSelection();\n const activeElement = document.activeElement;\n\n if (editorElem === null) {\n return;\n }\n\n const rootElement = editor.getRootElement();\n\n if (\n selection !== null &&\n nativeSelection !== null &&\n rootElement !== null &&\n rootElement.contains(nativeSelection.anchorNode)\n ) {\n const range = nativeSelection.getRangeAt(0);\n setFloatingElemPosition(range, editorElem);\n setLastSelection(selection);\n } else if (!activeElement || activeElement.className !== \"link-input\") {\n if (rootElement !== null) {\n setFloatingElemPosition(null, editorElem);\n }\n setLastSelection(null);\n setLinkData(emptyLinkData);\n }\n\n return true;\n }, [editor]);\n\n const removeLink = useCallback(() => {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);\n }, [editor]);\n\n const applyChanges = useCallback(\n (linkData: LinkData) => {\n const confirmedLinkData = {\n url: sanitizeUrl(linkData.url),\n target: linkData.target,\n alt: linkData.alt\n };\n\n if (lastSelection !== null) {\n editor.read(() => {\n const selection = $getSelection();\n suppressedSelectionKeyRef.current = getSelectionKey(selection);\n });\n\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);\n }\n\n setLastSelection(null);\n },\n [editor, lastSelection]\n );\n\n useEffect(() => {\n return mergeRegister(\n editor.registerUpdateListener(({ editorState }) => {\n editorState.read(() => {\n updateLinkEditor();\n });\n }),\n\n editor.registerCommand(\n SELECTION_CHANGE_COMMAND,\n () => {\n updateLinkEditor();\n return false;\n },\n COMMAND_PRIORITY_LOW\n )\n );\n }, [editor, updateLinkEditor]);\n\n useEffect(() => {\n editor.read(() => {\n updateLinkEditor();\n });\n }, [editor, updateLinkEditor]);\n\n return { editorRef, linkData, applyChanges, removeLink };\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"file":"plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js","sources":["../../../src/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.ts"],"sourcesContent":["import { useCallback, useEffect, useRef, useState } from \"react\";\nimport {\n SELECTION_CHANGE_COMMAND,\n type BaseSelection,\n type LexicalEditor,\n COMMAND_PRIORITY_LOW,\n $getSelection,\n $isRangeSelection,\n mergeRegister\n} from \"lexical\";\nimport { $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode.js\";\nimport { setFloatingElemPosition } from \"~/utils/setFloatingElemPosition.js\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl.js\";\nimport { LinkData } from \"./types.js\";\n\nconst emptyLinkData: LinkData = { url: \"\", target: null, alt: null };\n\nfunction getSelectionKey(selection: BaseSelection | null): string | null {\n if ($isRangeSelection(selection)) {\n return `${selection.anchor.key}:${selection.anchor.offset}-${selection.focus.key}:${selection.focus.offset}`;\n }\n return null;\n}\n\nfunction getLinkDataFromSelection(): LinkData {\n const selection = $getSelection();\n if (!$isRangeSelection(selection)) {\n return emptyLinkData;\n }\n\n const node = getSelectedNode(selection);\n const parent = node.getParent();\n\n if ($isLinkNode(parent)) {\n return {\n url: parent.getURL(),\n target: parent.getTarget(),\n alt: parent.getAlt()\n };\n }\n\n if ($isLinkNode(node)) {\n return {\n url: node.getURL(),\n target: node.getTarget(),\n alt: node.getAlt()\n };\n }\n\n return emptyLinkData;\n}\n\nexport function useFloatingLinkEditor(editor: LexicalEditor) {\n const editorRef = useRef<HTMLDivElement | null>(null);\n const [linkData, setLinkData] = useState<LinkData>(emptyLinkData);\n const [lastSelection, setLastSelection] = useState<BaseSelection | null>(null);\n const suppressedSelectionKeyRef = useRef<string | null>(null);\n\n const updateLinkEditor = useCallback(() => {\n const selection = $getSelection();\n const selectionKey = getSelectionKey(selection);\n\n // If we're still on the same selection that was suppressed, hide the popover.\n if (suppressedSelectionKeyRef.current !== null) {\n if (selectionKey === suppressedSelectionKeyRef.current) {\n const editorElem = editorRef.current;\n if (editorElem) {\n setFloatingElemPosition(null, editorElem);\n }\n setLastSelection(null);\n setLinkData(emptyLinkData);\n return true;\n }\n // New selection — clear suppression.\n suppressedSelectionKeyRef.current = null;\n }\n\n setLinkData(getLinkDataFromSelection());\n\n const editorElem = editorRef.current;\n const nativeSelection = window.getSelection();\n const activeElement = document.activeElement;\n\n if (editorElem === null) {\n return;\n }\n\n const rootElement = editor.getRootElement();\n\n if (\n selection !== null &&\n nativeSelection !== null &&\n rootElement !== null &&\n rootElement.contains(nativeSelection.anchorNode)\n ) {\n const range = nativeSelection.getRangeAt(0);\n setFloatingElemPosition(range, editorElem);\n setLastSelection(selection);\n } else if (!activeElement || activeElement.className !== \"link-input\") {\n if (rootElement !== null) {\n setFloatingElemPosition(null, editorElem);\n }\n setLastSelection(null);\n setLinkData(emptyLinkData);\n }\n\n return true;\n }, [editor]);\n\n const removeLink = useCallback(() => {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);\n }, [editor]);\n\n const applyChanges = useCallback(\n (linkData: LinkData) => {\n const confirmedLinkData = {\n url: sanitizeUrl(linkData.url),\n target: linkData.target,\n alt: linkData.alt\n };\n\n if (lastSelection !== null) {\n editor.read(() => {\n const selection = $getSelection();\n suppressedSelectionKeyRef.current = getSelectionKey(selection);\n });\n\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);\n }\n\n setLastSelection(null);\n },\n [editor, lastSelection]\n );\n\n useEffect(() => {\n return mergeRegister(\n editor.registerUpdateListener(({ editorState }) => {\n editorState.read(() => {\n updateLinkEditor();\n });\n }),\n\n editor.registerCommand(\n SELECTION_CHANGE_COMMAND,\n () => {\n updateLinkEditor();\n return false;\n },\n COMMAND_PRIORITY_LOW\n )\n );\n }, [editor, updateLinkEditor]);\n\n useEffect(() => {\n editor.read(() => {\n updateLinkEditor();\n });\n }, [editor, updateLinkEditor]);\n\n return { editorRef, linkData, applyChanges, removeLink };\n}\n"],"names":["emptyLinkData","getSelectionKey","selection","$isRangeSelection","getLinkDataFromSelection","$getSelection","node","getSelectedNode","parent","$isLinkNode","useFloatingLinkEditor","editor","editorRef","useRef","linkData","setLinkData","useState","lastSelection","setLastSelection","suppressedSelectionKeyRef","updateLinkEditor","useCallback","selectionKey","editorElem","setFloatingElemPosition","nativeSelection","window","activeElement","document","rootElement","range","removeLink","TOGGLE_LINK_COMMAND","applyChanges","confirmedLinkData","sanitizeUrl","useEffect","mergeRegister","editorState","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_LOW"],"mappings":"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"}
|
|
@@ -3,25 +3,20 @@ import { $getSelection, $isRangeSelection, COMMAND_PRIORITY_EDITOR } from "lexic
|
|
|
3
3
|
import { ADD_FONT_COLOR_COMMAND } from "@webiny/lexical-nodes";
|
|
4
4
|
import { useRichTextEditor } from "../../hooks/index.js";
|
|
5
5
|
import { applyColorToSelection } from "./applyColorToSelection.js";
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
editor
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}
|
|
20
|
-
});
|
|
21
|
-
return true;
|
|
22
|
-
}, COMMAND_PRIORITY_EDITOR);
|
|
23
|
-
}, [editor]);
|
|
24
|
-
return null;
|
|
6
|
+
const FontColorPlugin = ()=>{
|
|
7
|
+
const { editor } = useRichTextEditor();
|
|
8
|
+
useEffect(()=>editor.registerCommand(ADD_FONT_COLOR_COMMAND, (payload)=>{
|
|
9
|
+
editor.update(()=>{
|
|
10
|
+
const { color } = payload;
|
|
11
|
+
const selection = $getSelection();
|
|
12
|
+
if ($isRangeSelection(selection)) applyColorToSelection(selection, color);
|
|
13
|
+
});
|
|
14
|
+
return true;
|
|
15
|
+
}, COMMAND_PRIORITY_EDITOR), [
|
|
16
|
+
editor
|
|
17
|
+
]);
|
|
18
|
+
return null;
|
|
25
19
|
};
|
|
20
|
+
export { FontColorPlugin };
|
|
26
21
|
|
|
27
22
|
//# sourceMappingURL=FontColorPlugin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"plugins/FontColorPlugin/FontColorPlugin.js","sources":["../../../src/plugins/FontColorPlugin/FontColorPlugin.tsx"],"sourcesContent":["import { useEffect } from \"react\";\nimport { $getSelection, $isRangeSelection, COMMAND_PRIORITY_EDITOR } from \"lexical\";\nimport type { FontColorPayload } from \"@webiny/lexical-nodes\";\nimport { ADD_FONT_COLOR_COMMAND } from \"@webiny/lexical-nodes\";\nimport { useRichTextEditor } from \"~/hooks/index.js\";\nimport { applyColorToSelection } from \"./applyColorToSelection.js\";\n\nexport const FontColorPlugin = () => {\n const { editor } = useRichTextEditor();\n\n useEffect(() => {\n return editor.registerCommand<FontColorPayload>(\n ADD_FONT_COLOR_COMMAND,\n payload => {\n editor.update(() => {\n const { color } = payload;\n const selection = $getSelection();\n\n if ($isRangeSelection(selection)) {\n applyColorToSelection(selection, color);\n }\n });\n return true;\n },\n COMMAND_PRIORITY_EDITOR\n );\n }, [editor]);\n\n return null;\n};\n"],"names":["FontColorPlugin","editor","useRichTextEditor","useEffect","ADD_FONT_COLOR_COMMAND","payload","color","selection","$getSelection","$isRangeSelection","applyColorToSelection","COMMAND_PRIORITY_EDITOR"],"mappings":";;;;;AAOO,MAAMA,kBAAkB;IAC3B,MAAM,EAAEC,MAAM,EAAE,GAAGC;IAEnBC,UAAU,IACCF,OAAO,eAAe,CACzBG,wBACAC,CAAAA;YACIJ,OAAO,MAAM,CAAC;gBACV,MAAM,EAAEK,KAAK,EAAE,GAAGD;gBAClB,MAAME,YAAYC;gBAElB,IAAIC,kBAAkBF,YAClBG,sBAAsBH,WAAWD;YAEzC;YACA,OAAO;QACX,GACAK,0BAEL;QAACV;KAAO;IAEX,OAAO;AACX"}
|
|
@@ -1,8 +1,9 @@
|
|
|
1
1
|
import { $applyStylesToNode, $createFontColorNode } from "@webiny/lexical-nodes";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
2
|
+
function applyColorToNode(textNode, color) {
|
|
3
|
+
const fontColorNode = $createFontColorNode(textNode.getTextContent(), color);
|
|
4
|
+
$applyStylesToNode(fontColorNode, textNode);
|
|
5
|
+
return textNode.replace(fontColorNode);
|
|
6
6
|
}
|
|
7
|
+
export { applyColorToNode };
|
|
7
8
|
|
|
8
9
|
//# sourceMappingURL=applyColorToNode.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"
|
|
1
|
+
{"version":3,"file":"plugins/FontColorPlugin/applyColorToNode.js","sources":["../../../src/plugins/FontColorPlugin/applyColorToNode.ts"],"sourcesContent":["import type { TextNode } from \"lexical\";\nimport type { ThemeColorValue } from \"@webiny/lexical-nodes\";\nimport { $applyStylesToNode, $createFontColorNode } from \"@webiny/lexical-nodes\";\n\nexport function applyColorToNode(textNode: TextNode, color: ThemeColorValue) {\n const fontColorNode = $createFontColorNode(textNode.getTextContent(), color);\n $applyStylesToNode(fontColorNode, textNode);\n\n return textNode.replace(fontColorNode);\n}\n"],"names":["applyColorToNode","textNode","color","fontColorNode","$createFontColorNode","$applyStylesToNode"],"mappings":";AAIO,SAASA,iBAAiBC,QAAkB,EAAEC,KAAsB;IACvE,MAAMC,gBAAgBC,qBAAqBH,SAAS,cAAc,IAAIC;IACtEG,mBAAmBF,eAAeF;IAElC,OAAOA,SAAS,OAAO,CAACE;AAC5B"}
|