@webiny/lexical-editor 5.44.1-beta.0 → 5.45.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/README.md +6 -12
- package/commands/image.d.ts +2 -2
- package/commands/image.js +2 -8
- package/commands/image.js.map +1 -1
- package/commands/index.d.ts +5 -4
- package/commands/index.js +5 -49
- package/commands/index.js.map +1 -1
- package/commands/list.d.ts +1 -1
- package/commands/list.js +4 -10
- package/commands/list.js.map +1 -1
- package/commands/quote.d.ts +1 -1
- package/commands/quote.js +2 -8
- package/commands/quote.js.map +1 -1
- package/commands/toolbar.js +2 -8
- package/commands/toolbar.js.map +1 -1
- package/commands/typography.d.ts +8 -0
- package/commands/typography.js +4 -0
- package/commands/typography.js.map +1 -0
- package/components/Editor/EnsureHeadingTagPlugin.js +10 -16
- package/components/Editor/EnsureHeadingTagPlugin.js.map +1 -1
- package/components/Editor/RichTextEditor.d.ts +12 -8
- package/components/Editor/RichTextEditor.js +89 -102
- package/components/Editor/RichTextEditor.js.map +1 -1
- package/components/Editor/normalizeInputValue.d.ts +1 -1
- package/components/Editor/normalizeInputValue.js +2 -8
- package/components/Editor/normalizeInputValue.js.map +1 -1
- package/components/LexicalEditorConfig/LexicalEditorConfig.d.ts +14 -16
- package/components/LexicalEditorConfig/LexicalEditorConfig.js +21 -69
- package/components/LexicalEditorConfig/LexicalEditorConfig.js.map +1 -1
- package/components/LexicalEditorConfig/components/Node.d.ts +1 -1
- package/components/LexicalEditorConfig/components/Node.js +17 -26
- package/components/LexicalEditorConfig/components/Node.js.map +1 -1
- package/components/LexicalEditorConfig/components/Plugin.js +17 -26
- package/components/LexicalEditorConfig/components/Plugin.js.map +1 -1
- package/components/LexicalEditorConfig/components/ToolbarElement.js +17 -26
- package/components/LexicalEditorConfig/components/ToolbarElement.js.map +1 -1
- package/components/LexicalHtmlRenderer.d.ts +4 -7
- package/components/LexicalHtmlRenderer.js +35 -53
- package/components/LexicalHtmlRenderer.js.map +1 -1
- package/components/Toolbar/StaticToolbar.css +416 -0
- package/components/Toolbar/StaticToolbar.d.ts +3 -1
- package/components/Toolbar/StaticToolbar.js +19 -23
- package/components/Toolbar/StaticToolbar.js.map +1 -1
- package/components/ToolbarActions/BoldAction.js +16 -21
- package/components/ToolbarActions/BoldAction.js.map +1 -1
- package/components/ToolbarActions/BulletListAction.js +25 -31
- package/components/ToolbarActions/BulletListAction.js.map +1 -1
- package/components/ToolbarActions/CodeHighlightAction.js +16 -21
- package/components/ToolbarActions/CodeHighlightAction.js.map +1 -1
- package/components/ToolbarActions/FontColorAction.js +32 -42
- package/components/ToolbarActions/FontColorAction.js.map +1 -1
- package/components/ToolbarActions/ImageAction.js +19 -34
- package/components/ToolbarActions/ImageAction.js.map +1 -1
- package/components/ToolbarActions/ItalicAction.js +16 -21
- package/components/ToolbarActions/ItalicAction.js.map +1 -1
- package/components/ToolbarActions/LinkAction.js +19 -24
- package/components/ToolbarActions/LinkAction.js.map +1 -1
- package/components/ToolbarActions/NumberedListAction.js +25 -36
- package/components/ToolbarActions/NumberedListAction.js.map +1 -1
- package/components/ToolbarActions/QuoteAction.js +20 -25
- package/components/ToolbarActions/QuoteAction.js.map +1 -1
- package/components/ToolbarActions/TextAlignmentAction.js +36 -45
- package/components/ToolbarActions/TextAlignmentAction.js.map +1 -1
- package/components/ToolbarActions/TypographyAction.js +57 -79
- package/components/ToolbarActions/TypographyAction.js.map +1 -1
- package/components/ToolbarActions/UnderlineAction.js +16 -21
- package/components/ToolbarActions/UnderlineAction.js.map +1 -1
- package/context/FontColorActionContext.js +2 -9
- package/context/FontColorActionContext.js.map +1 -1
- package/context/RichTextEditorContext.d.ts +6 -7
- package/context/RichTextEditorContext.js +28 -26
- package/context/RichTextEditorContext.js.map +1 -1
- package/context/SharedHistoryContext.d.ts +2 -2
- package/context/SharedHistoryContext.js +12 -20
- package/context/SharedHistoryContext.js.map +1 -1
- package/context/TextAlignmentActionContextProps.d.ts +1 -1
- package/context/TextAlignmentActionContextProps.js +2 -9
- package/context/TextAlignmentActionContextProps.js.map +1 -1
- package/context/TypographyActionContext.d.ts +3 -2
- package/context/TypographyActionContext.js +2 -9
- package/context/TypographyActionContext.js.map +1 -1
- package/exports/admin/lexical.d.ts +15 -0
- package/exports/admin/lexical.js +23 -0
- package/exports/admin/lexical.js.map +1 -0
- package/hooks/index.d.ts +7 -8
- package/hooks/index.js +7 -93
- package/hooks/index.js.map +1 -1
- package/hooks/useCurrentElement.d.ts +3 -3
- package/hooks/useCurrentElement.js +11 -18
- package/hooks/useCurrentElement.js.map +1 -1
- package/hooks/useCurrentSelection.d.ts +2 -1
- package/hooks/useCurrentSelection.js +27 -40
- package/hooks/useCurrentSelection.js.map +1 -1
- package/hooks/useFontColorPicker.d.ts +1 -1
- package/hooks/useFontColorPicker.js +5 -11
- package/hooks/useFontColorPicker.js.map +1 -1
- package/hooks/useIsMounted.js +6 -14
- package/hooks/useIsMounted.js.map +1 -1
- package/hooks/useRichTextEditor.d.ts +1 -1
- package/hooks/useRichTextEditor.js +5 -11
- package/hooks/useRichTextEditor.js.map +1 -1
- package/hooks/useTextAlignmentAction.d.ts +1 -1
- package/hooks/useTextAlignmentAction.js +5 -11
- package/hooks/useTextAlignmentAction.js.map +1 -1
- package/hooks/useTypographyAction.d.ts +1 -1
- package/hooks/useTypographyAction.js +5 -11
- package/hooks/useTypographyAction.js.map +1 -1
- package/index.d.ts +33 -38
- package/index.js +44 -322
- package/index.js.map +1 -1
- package/package.json +18 -22
- package/plugins/BlurEventPlugin/BlurEventPlugin.d.ts +2 -2
- package/plugins/BlurEventPlugin/BlurEventPlugin.js +16 -22
- package/plugins/BlurEventPlugin/BlurEventPlugin.js.map +1 -1
- package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js +9 -14
- package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js.map +1 -1
- package/plugins/CodeHighlightPlugin/index.d.ts +1 -1
- package/plugins/CodeHighlightPlugin/index.js +1 -16
- package/plugins/CodeHighlightPlugin/index.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.d.ts +10 -0
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js +28 -0
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js.map +1 -0
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.d.ts +7 -0
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js +61 -0
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js.map +1 -0
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.css +2 -136
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.d.ts +4 -16
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js +7 -180
- package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/index.d.ts +1 -1
- package/plugins/FloatingLinkEditorPlugin/index.js +1 -16
- package/plugins/FloatingLinkEditorPlugin/index.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js +3 -9
- package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js.map +1 -1
- package/plugins/FloatingLinkEditorPlugin/types.d.ts +10 -0
- package/plugins/FloatingLinkEditorPlugin/types.js +3 -0
- package/plugins/FloatingLinkEditorPlugin/types.js.map +1 -0
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.d.ts +8 -2
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js +120 -88
- package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js.map +1 -1
- package/plugins/FontColorPlugin/FontColorPlugin.js +19 -22
- package/plugins/FontColorPlugin/FontColorPlugin.js.map +1 -1
- package/plugins/FontColorPlugin/applyColorToNode.d.ts +2 -2
- package/plugins/FontColorPlugin/applyColorToNode.js +4 -10
- package/plugins/FontColorPlugin/applyColorToNode.js.map +1 -1
- package/plugins/FontColorPlugin/applyColorToSelection.d.ts +2 -2
- package/plugins/FontColorPlugin/applyColorToSelection.js +28 -44
- package/plugins/FontColorPlugin/applyColorToSelection.js.map +1 -1
- package/plugins/ImagesPlugin/ImagesPlugin.d.ts +1 -2
- package/plugins/ImagesPlugin/ImagesPlugin.js +58 -60
- package/plugins/ImagesPlugin/ImagesPlugin.js.map +1 -1
- package/plugins/LinkPlugin/LinkPlugin.js +29 -37
- package/plugins/LinkPlugin/LinkPlugin.js.map +1 -1
- package/plugins/ListPLugin/ListPlugin.js +52 -15
- package/plugins/ListPLugin/ListPlugin.js.map +1 -1
- package/plugins/QuoteNodePlugin/QuoteNodePlugin.js +19 -16
- package/plugins/QuoteNodePlugin/QuoteNodePlugin.js.map +1 -1
- package/plugins/StateHandlingPlugin.d.ts +1 -1
- package/plugins/StateHandlingPlugin.js +32 -39
- package/plugins/StateHandlingPlugin.js.map +1 -1
- package/plugins/TypographyPlugin/TypographyPlugin.js +17 -21
- package/plugins/TypographyPlugin/TypographyPlugin.js.map +1 -1
- package/types.d.ts +4 -4
- package/types.js +6 -38
- package/types.js.map +1 -1
- package/ui/ContentEditable.d.ts +0 -1
- package/ui/ContentEditable.js +7 -14
- package/ui/ContentEditable.js.map +1 -1
- package/ui/Divider.d.ts +0 -1
- package/ui/Divider.js +3 -10
- package/ui/Divider.js.map +1 -1
- package/ui/DropDown.d.ts +1 -1
- package/ui/DropDown.js +64 -90
- package/ui/DropDown.js.map +1 -1
- package/ui/ImageResizer.d.ts +0 -1
- package/ui/ImageResizer.js +78 -83
- package/ui/ImageResizer.js.map +1 -1
- package/ui/LinkPreview.d.ts +0 -1
- package/ui/LinkPreview.js +22 -29
- package/ui/LinkPreview.js.map +1 -1
- package/ui/Placeholder.d.ts +1 -1
- package/ui/Placeholder.js +10 -16
- package/ui/Placeholder.js.map +1 -1
- package/ui/TextInput.d.ts +0 -1
- package/ui/TextInput.js +11 -18
- package/ui/TextInput.js.map +1 -1
- package/ui/ToolbarActionDialog.js +30 -42
- package/ui/ToolbarActionDialog.js.map +1 -1
- package/utils/canUseDOM.js +1 -7
- package/utils/canUseDOM.js.map +1 -1
- package/utils/files.d.ts +6 -6
- package/utils/files.js +5 -32
- package/utils/files.js.map +1 -1
- package/utils/getDOMRangeRect.js +4 -10
- package/utils/getDOMRangeRect.js.map +1 -1
- package/utils/getSelectedNode.d.ts +1 -1
- package/utils/getSelectedNode.js +9 -16
- package/utils/getSelectedNode.js.map +1 -1
- package/utils/getTransparentImage.js +1 -7
- package/utils/getTransparentImage.js.map +1 -1
- package/utils/insertImage.d.ts +1 -1
- package/utils/insertImage.js +8 -14
- package/utils/insertImage.js.map +1 -1
- package/utils/isAnchorLink.js +1 -7
- package/utils/isAnchorLink.js.map +1 -1
- package/utils/isChildOfFloatingToolbar.js +3 -12
- package/utils/isChildOfFloatingToolbar.js.map +1 -1
- package/utils/isHTMLElement.js +1 -7
- package/utils/isHTMLElement.js.map +1 -1
- package/utils/isValidJSON.js +3 -9
- package/utils/isValidJSON.js.map +1 -1
- package/utils/isValidLexicalData.d.ts +3 -3
- package/utils/isValidLexicalData.js +6 -12
- package/utils/isValidLexicalData.js.map +1 -1
- package/utils/point.js +35 -60
- package/utils/point.js.map +1 -1
- package/utils/rect.d.ts +1 -1
- package/utils/rect.js +115 -149
- package/utils/rect.js.map +1 -1
- package/utils/sanitizeUrl.js +6 -13
- package/utils/sanitizeUrl.js.map +1 -1
- package/utils/setFloatingElemPosition.d.ts +1 -1
- package/utils/setFloatingElemPosition.js +24 -30
- package/utils/setFloatingElemPosition.js.map +1 -1
- package/components/Editor/HeadingEditor.d.ts +0 -7
- package/components/Editor/HeadingEditor.js +0 -30
- package/components/Editor/HeadingEditor.js.map +0 -1
- package/components/Editor/ParagraphEditor.d.ts +0 -7
- package/components/Editor/ParagraphEditor.js +0 -29
- package/components/Editor/ParagraphEditor.js.map +0 -1
- package/components/Toolbar/Toolbar.css +0 -643
- package/components/Toolbar/Toolbar.d.ts +0 -11
- package/components/Toolbar/Toolbar.js +0 -165
- package/components/Toolbar/Toolbar.js.map +0 -1
- package/components/ToolbarActions/FontSizeAction.d.ts +0 -14
- package/components/ToolbarActions/FontSizeAction.js +0 -109
- package/components/ToolbarActions/FontSizeAction.js.map +0 -1
- package/hooks/useList.d.ts +0 -2
- package/hooks/useList.js +0 -54
- package/hooks/useList.js.map +0 -1
- package/hooks/useQuote.d.ts +0 -2
- package/hooks/useQuote.js +0 -22
- package/hooks/useQuote.js.map +0 -1
- package/plugins/FloatingLinkEditorPlugin/LinkEditForm.d.ts +0 -9
- package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js +0 -118
- package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js.map +0 -1
- package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.d.ts +0 -9
- package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js +0 -44
- package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js.map +0 -1
- package/utils/generateInitialLexicalValue.d.ts +0 -4
- package/utils/generateInitialLexicalValue.js +0 -33
- package/utils/generateInitialLexicalValue.js.map +0 -1
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { LinkFormProps } from "./types.js";
|
|
3
|
+
interface FloatingLinkEditorProps {
|
|
4
|
+
LinkForm: React.FunctionComponent<LinkFormProps>;
|
|
5
|
+
}
|
|
6
|
+
export declare const FloatingLinkEditorController: (props: FloatingLinkEditorProps) => React.ReactPortal;
|
|
7
|
+
export {};
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import React, { useCallback, useState, useEffect } from "react";
|
|
2
|
+
import { createPortal } from "react-dom";
|
|
3
|
+
import { useRichTextEditor } from "../../hooks/index.js";
|
|
4
|
+
import { getSelectedNode } from "../../utils/getSelectedNode.js";
|
|
5
|
+
import { $isAutoLinkNode, $isLinkNode, TOGGLE_LINK_COMMAND } from "@webiny/lexical-nodes";
|
|
6
|
+
import { isChildOfLinkEditor } from "./isChildOfLinkEditor.js";
|
|
7
|
+
import debounce from "lodash/debounce.js";
|
|
8
|
+
import { $getSelection, $isRangeSelection, BLUR_COMMAND, COMMAND_PRIORITY_CRITICAL, COMMAND_PRIORITY_LOW, SELECTION_CHANGE_COMMAND, mergeRegister, $findMatchingParent } from "lexical";
|
|
9
|
+
import { FloatingLinkEditor } from "./FloatingLinkEditor.js";
|
|
10
|
+
export const FloatingLinkEditorController = props => {
|
|
11
|
+
const {
|
|
12
|
+
editor,
|
|
13
|
+
getOverlaysElement
|
|
14
|
+
} = useRichTextEditor();
|
|
15
|
+
const [isLink, setIsLink] = useState(false);
|
|
16
|
+
const debounceSetIsLink = useCallback(debounce(setIsLink, 50), []);
|
|
17
|
+
const updateToolbar = useCallback(() => {
|
|
18
|
+
const selection = $getSelection();
|
|
19
|
+
if (!$isRangeSelection(selection)) {
|
|
20
|
+
return;
|
|
21
|
+
}
|
|
22
|
+
const node = getSelectedNode(selection);
|
|
23
|
+
const linkParent = $findMatchingParent(node, $isLinkNode);
|
|
24
|
+
const autoLinkParent = $findMatchingParent(node, $isAutoLinkNode);
|
|
25
|
+
const isLinkOrChildOfLink = Boolean($isLinkNode(node) || linkParent);
|
|
26
|
+
if (!isLinkOrChildOfLink) {
|
|
27
|
+
// When hiding the toolbar, we want to hide immediately.
|
|
28
|
+
setIsLink(false);
|
|
29
|
+
}
|
|
30
|
+
if (selection.dirty) {
|
|
31
|
+
// We don't want this menu to open for auto links.
|
|
32
|
+
if (linkParent != null && autoLinkParent == null) {
|
|
33
|
+
// When showing the toolbar, we want to debounce it, because sometimes selection gets updated
|
|
34
|
+
// multiple times, and the `selection.dirty` flag goes from true to false multiple times,
|
|
35
|
+
// eventually settling on `false`, which we want to set once it has settled.
|
|
36
|
+
debounceSetIsLink(true);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}, []);
|
|
40
|
+
useEffect(() => {
|
|
41
|
+
return mergeRegister(editor.registerCommand(SELECTION_CHANGE_COMMAND, () => {
|
|
42
|
+
updateToolbar();
|
|
43
|
+
return false;
|
|
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());
|
|
59
|
+
};
|
|
60
|
+
|
|
61
|
+
//# sourceMappingURL=FloatingLinkEditorController.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","useCallback","useState","useEffect","createPortal","useRichTextEditor","getSelectedNode","$isAutoLinkNode","$isLinkNode","TOGGLE_LINK_COMMAND","isChildOfLinkEditor","debounce","$getSelection","$isRangeSelection","BLUR_COMMAND","COMMAND_PRIORITY_CRITICAL","COMMAND_PRIORITY_LOW","SELECTION_CHANGE_COMMAND","mergeRegister","$findMatchingParent","FloatingLinkEditor","FloatingLinkEditorController","props","editor","getOverlaysElement","isLink","setIsLink","debounceSetIsLink","updateToolbar","selection","node","linkParent","autoLinkParent","isLinkOrChildOfLink","Boolean","dirty","registerCommand","payload","relatedTarget","createElement","isVisible","LinkForm"],"sources":["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"],"mappings":"AAAA,OAAOA,KAAK,IAAIC,WAAW,EAAEC,QAAQ,EAAEC,SAAS,QAAQ,OAAO;AAC/D,SAASC,YAAY,QAAQ,WAAW;AACxC,SAASC,iBAAiB;AAC1B,SAASC,eAAe;AACxB,SAASC,eAAe,EAAEC,WAAW,EAAEC,mBAAmB,QAAQ,uBAAuB;AACzF,SAASC,mBAAmB;AAC5B,OAAOC,QAAQ,MAAM,oBAAoB;AACzC,SACIC,aAAa,EACbC,iBAAiB,EACjBC,YAAY,EACZC,yBAAyB,EACzBC,oBAAoB,EACpBC,wBAAwB,EACxBC,aAAa,EACbC,mBAAmB,QAChB,SAAS;AAChB,SAASC,kBAAkB;AAO3B,OAAO,MAAMC,4BAA4B,GAAIC,KAA8B,IAAK;EAC5E,MAAM;IAAEC,MAAM;IAAEC;EAAmB,CAAC,GAAGnB,iBAAiB,CAAC,CAAC;EAC1D,MAAM,CAACoB,MAAM,EAAEC,SAAS,CAAC,GAAGxB,QAAQ,CAAC,KAAK,CAAC;EAE3C,MAAMyB,iBAAiB,GAAG1B,WAAW,CAACU,QAAQ,CAACe,SAAS,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC;EAElE,MAAME,aAAa,GAAG3B,WAAW,CAAC,MAAM;IACpC,MAAM4B,SAAS,GAAGjB,aAAa,CAAC,CAAC;IACjC,IAAI,CAACC,iBAAiB,CAACgB,SAAS,CAAC,EAAE;MAC/B;IACJ;IAEA,MAAMC,IAAI,GAAGxB,eAAe,CAACuB,SAAS,CAAC;IACvC,MAAME,UAAU,GAAGZ,mBAAmB,CAACW,IAAI,EAAEtB,WAAW,CAAC;IACzD,MAAMwB,cAAc,GAAGb,mBAAmB,CAACW,IAAI,EAAEvB,eAAe,CAAC;IACjE,MAAM0B,mBAAmB,GAAGC,OAAO,CAAC1B,WAAW,CAACsB,IAAI,CAAC,IAAIC,UAAU,CAAC;IAEpE,IAAI,CAACE,mBAAmB,EAAE;MACtB;MACAP,SAAS,CAAC,KAAK,CAAC;IACpB;IAEA,IAAIG,SAAS,CAACM,KAAK,EAAE;MACjB;MACA,IAAIJ,UAAU,IAAI,IAAI,IAAIC,cAAc,IAAI,IAAI,EAAE;QAC9C;QACA;QACA;QACAL,iBAAiB,CAAC,IAAI,CAAC;MAC3B;IACJ;EACJ,CAAC,EAAE,EAAE,CAAC;EAENxB,SAAS,CAAC,MAAM;IACZ,OAAOe,aAAa,CAChBK,MAAM,CAACa,eAAe,CAClBnB,wBAAwB,EACxB,MAAM;MACFW,aAAa,CAAC,CAAC;MACf,OAAO,KAAK;IAChB,CAAC,EACDb,yBACJ,CAAC,EACDQ,MAAM,CAACa,eAAe,CAClBtB,YAAY,EACZuB,OAAO,IAAI;MACP,IAAI,CAAC3B,mBAAmB,CAAC2B,OAAO,CAACC,aAA4B,CAAC,EAAE;QAC5DZ,SAAS,CAAC,KAAK,CAAC;MACpB;MAEA,OAAO,KAAK;IAChB,CAAC,EACDV,oBACJ,CAAC,EACDO,MAAM,CAACa,eAAe,CAClB3B,mBAAmB,EACnB4B,OAAO,IAAI;MACPX,SAAS,CAAC,CAAC,CAACW,OAAO,CAAC;MACpB,OAAO,KAAK;IAChB,CAAC,EACDtB,yBACJ,CACJ,CAAC;EACL,CAAC,EAAE,CAACQ,MAAM,EAAEK,aAAa,CAAC,CAAC;EAE3B,oBAAOxB,YAAY,cACfJ,KAAA,CAAAuC,aAAA,CAACnB,kBAAkB;IAACoB,SAAS,EAAEf,MAAO;IAACF,MAAM,EAAEA,MAAO;IAACkB,QAAQ,EAAEnB,KAAK,CAACmB;EAAS,CAAE,CAAC,EACnFjB,kBAAkB,CAAC,CACvB,CAAC;AACL,CAAC","ignoreList":[]}
|
|
@@ -1,23 +1,14 @@
|
|
|
1
1
|
.link-editor {
|
|
2
|
-
position: absolute;
|
|
3
2
|
top: 0;
|
|
4
3
|
left: 0;
|
|
5
|
-
z-index: 31;
|
|
6
4
|
max-width: 400px;
|
|
7
5
|
width: 100%;
|
|
8
6
|
opacity: 0;
|
|
9
7
|
background-color: #fff;
|
|
10
|
-
box-shadow: 0
|
|
8
|
+
box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
|
|
11
9
|
border-radius: 8px;
|
|
12
|
-
|
|
13
|
-
will-change: transform;
|
|
14
|
-
padding: 10px 0;
|
|
10
|
+
pointer-events: all;
|
|
15
11
|
}
|
|
16
|
-
|
|
17
|
-
.link-editor .link-editor-target-checkbox {
|
|
18
|
-
padding: 10px 10px 5px 10px;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
12
|
.link-editor .button {
|
|
22
13
|
width: 20px;
|
|
23
14
|
height: 20px;
|
|
@@ -40,131 +31,6 @@
|
|
|
40
31
|
background-color: rgb(223, 232, 250);
|
|
41
32
|
}
|
|
42
33
|
|
|
43
|
-
.link-editor .link-editor-section {
|
|
44
|
-
margin: 0 15px;
|
|
45
|
-
padding: 10px 0;
|
|
46
|
-
width: calc(100% - 24px);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
.link-editor .link-editor-popup-title {
|
|
50
|
-
margin: 0 15px 10px;
|
|
51
|
-
color: var(--mdc-theme-primary);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
.link-editor .link-editor-section .header {
|
|
55
|
-
width: auto;
|
|
56
|
-
margin-bottom: 10px;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
.link-editor .link-editor-section .header_icon {
|
|
60
|
-
font-size: 16px;
|
|
61
|
-
width: 16px;
|
|
62
|
-
height: 16px;
|
|
63
|
-
}
|
|
64
|
-
|
|
65
|
-
.link-editor .link-editor-section .header_title {
|
|
66
|
-
font-size: 16px;
|
|
67
|
-
font-width: bold;
|
|
68
|
-
color: var(--mdc-theme-primary);
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
.link-editor .link-editor-section .section-desc {
|
|
72
|
-
color: #0a0a0a;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
.link-editor .link-editor-section.edit-form-bottom-menu {
|
|
76
|
-
display: flex;
|
|
77
|
-
justify-content: right;
|
|
78
|
-
margin-top: 5px;
|
|
79
|
-
column-gap: 10px;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
.link-editor .link-editor-section ul {
|
|
83
|
-
list-style: initial;
|
|
84
|
-
padding: 0 20px;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
.link-editor .link-editor-section ul li {
|
|
88
|
-
padding: 3px 0;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
.link-editor .link-input {
|
|
92
|
-
display: block;
|
|
93
|
-
width: calc(100% - 24px);
|
|
94
|
-
height: 42px;
|
|
95
|
-
box-sizing: border-box;
|
|
96
|
-
margin: 12px;
|
|
97
|
-
padding: 12px;
|
|
98
|
-
border-radius: 10px;
|
|
99
|
-
background-color: #eee;
|
|
100
|
-
font-size: 16px;
|
|
101
|
-
color: rgb(5, 5, 5);
|
|
102
|
-
border: 0;
|
|
103
|
-
outline: 0;
|
|
104
|
-
position: relative;
|
|
105
|
-
font-family: inherit;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
.link-editor .link-input.full-with {
|
|
109
|
-
width: 100%;
|
|
110
|
-
margin: 0;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
.link-editor .link-input .link-unlink {
|
|
114
|
-
background-image: url(../../images/icons/unlink_icon.svg);
|
|
115
|
-
background-size: 18px;
|
|
116
|
-
background-position: center;
|
|
117
|
-
background-repeat: no-repeat;
|
|
118
|
-
width: 35px;
|
|
119
|
-
vertical-align: -0.25em;
|
|
120
|
-
position: absolute;
|
|
121
|
-
right: 5px;
|
|
122
|
-
top: 0;
|
|
123
|
-
bottom: 0;
|
|
124
|
-
cursor: pointer;
|
|
125
|
-
}
|
|
126
|
-
|
|
127
|
-
.link-editor .link-input .link-edit {
|
|
128
|
-
background-image: url(../../images/icons/pencil-fill.svg);
|
|
129
|
-
background-size: 16px;
|
|
130
|
-
background-position: center;
|
|
131
|
-
background-repeat: no-repeat;
|
|
132
|
-
width: 35px;
|
|
133
|
-
vertical-align: -0.25em;
|
|
134
|
-
position: absolute;
|
|
135
|
-
right: 35px;
|
|
136
|
-
top: 0;
|
|
137
|
-
bottom: 0;
|
|
138
|
-
cursor: pointer;
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
.link-editor .link-input a {
|
|
142
|
-
color: rgb(33, 111, 219);
|
|
143
|
-
text-decoration: none;
|
|
144
|
-
display: block;
|
|
145
|
-
white-space: nowrap;
|
|
146
|
-
overflow: hidden;
|
|
147
|
-
margin-right: 30px;
|
|
148
|
-
text-overflow: ellipsis;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
.link-editor .link-input a:hover {
|
|
152
|
-
text-decoration: underline;
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
.link-editor .font-size-wrapper,
|
|
156
|
-
.link-editor .font-family-wrapper {
|
|
157
|
-
display: flex;
|
|
158
|
-
margin: 0 4px;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
.link-editor select {
|
|
162
|
-
padding: 6px;
|
|
163
|
-
border: none;
|
|
164
|
-
background-color: rgba(0, 0, 0, 0.075);
|
|
165
|
-
border-radius: 4px;
|
|
166
|
-
}
|
|
167
|
-
|
|
168
34
|
.link-editor .button i,
|
|
169
35
|
.actions i {
|
|
170
36
|
background-size: contain;
|
|
@@ -1,18 +1,6 @@
|
|
|
1
1
|
import React from "react";
|
|
2
|
-
import { LexicalEditor } from "lexical";
|
|
3
2
|
import "./FloatingLinkEditorPlugin.css";
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
9
|
-
interface FloatingLinkEditorProps {
|
|
10
|
-
editor: LexicalEditor;
|
|
11
|
-
isVisible: boolean;
|
|
12
|
-
anchorElem: HTMLElement;
|
|
13
|
-
}
|
|
14
|
-
export declare function FloatingLinkEditor({ editor, isVisible, anchorElem }: FloatingLinkEditorProps): React.JSX.Element;
|
|
15
|
-
export declare function FloatingLinkEditorPlugin({ anchorElem }: {
|
|
16
|
-
anchorElem?: HTMLElement;
|
|
17
|
-
}): JSX.Element | null;
|
|
18
|
-
export {};
|
|
3
|
+
import { LinkFormProps } from "./types.js";
|
|
4
|
+
export declare function FloatingLinkEditorPlugin(props: {
|
|
5
|
+
LinkForm: React.FunctionComponent<LinkFormProps>;
|
|
6
|
+
}): React.JSX.Element;
|
|
@@ -1,183 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
});
|
|
8
|
-
exports.FloatingLinkEditor = FloatingLinkEditor;
|
|
9
|
-
exports.FloatingLinkEditorPlugin = FloatingLinkEditorPlugin;
|
|
10
|
-
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
11
|
-
var _react = _interopRequireWildcard(require("react"));
|
|
12
|
-
var _utils = require("@lexical/utils");
|
|
13
|
-
var _lexical = require("lexical");
|
|
14
|
-
var _lexicalNodes = require("@webiny/lexical-nodes");
|
|
15
|
-
var _getSelectedNode = require("../../utils/getSelectedNode");
|
|
16
|
-
var _setFloatingElemPosition = require("../../utils/setFloatingElemPosition");
|
|
17
|
-
var _useFloatingLinkEditor = require("./useFloatingLinkEditor");
|
|
18
|
-
var _LinkEditForm = require("./LinkEditForm");
|
|
19
|
-
var _LinkPreviewForm = require("./LinkPreviewForm");
|
|
20
|
-
require("./FloatingLinkEditorPlugin.css");
|
|
21
|
-
var _sanitizeUrl = require("../../utils/sanitizeUrl");
|
|
22
|
-
var _isChildOfLinkEditor = require("./isChildOfLinkEditor");
|
|
23
|
-
function FloatingLinkEditor(_ref) {
|
|
24
|
-
var editor = _ref.editor,
|
|
25
|
-
isVisible = _ref.isVisible,
|
|
26
|
-
anchorElem = _ref.anchorElem;
|
|
27
|
-
var editorRef = (0, _react.useRef)(null);
|
|
28
|
-
var _useState = (0, _react.useState)({
|
|
29
|
-
url: "",
|
|
30
|
-
target: null,
|
|
31
|
-
alt: null
|
|
32
|
-
}),
|
|
33
|
-
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
34
|
-
linkData = _useState2[0],
|
|
35
|
-
setLinkData = _useState2[1];
|
|
36
|
-
var _useState3 = (0, _react.useState)(false),
|
|
37
|
-
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
38
|
-
isEditMode = _useState4[0],
|
|
39
|
-
setEditMode = _useState4[1];
|
|
40
|
-
var _useState5 = (0, _react.useState)(null),
|
|
41
|
-
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
42
|
-
lastSelection = _useState6[0],
|
|
43
|
-
setLastSelection = _useState6[1];
|
|
44
|
-
var updateLinkEditor = (0, _react.useCallback)(function () {
|
|
45
|
-
var selection = (0, _lexical.$getSelection)();
|
|
46
|
-
var emptyLinkData = {
|
|
47
|
-
url: "",
|
|
48
|
-
target: null,
|
|
49
|
-
alt: null
|
|
50
|
-
};
|
|
51
|
-
if ((0, _lexical.$isRangeSelection)(selection)) {
|
|
52
|
-
var node = (0, _getSelectedNode.getSelectedNode)(selection);
|
|
53
|
-
var parent = node.getParent();
|
|
54
|
-
if ((0, _lexicalNodes.$isLinkNode)(parent)) {
|
|
55
|
-
var _linkData = {
|
|
56
|
-
url: parent.getURL(),
|
|
57
|
-
target: parent.getTarget(),
|
|
58
|
-
alt: (0, _lexicalNodes.$isLinkNode)(parent) ? parent.getAlt() : null
|
|
59
|
-
};
|
|
60
|
-
setLinkData(_linkData);
|
|
61
|
-
} else if ((0, _lexicalNodes.$isLinkNode)(node)) {
|
|
62
|
-
var _linkData2 = {
|
|
63
|
-
url: node.getURL(),
|
|
64
|
-
target: node.getTarget(),
|
|
65
|
-
alt: (0, _lexicalNodes.$isLinkNode)(node) ? node.getAlt() : null
|
|
66
|
-
};
|
|
67
|
-
setLinkData(_linkData2);
|
|
68
|
-
} else {
|
|
69
|
-
setLinkData(emptyLinkData);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
var editorElem = editorRef.current;
|
|
73
|
-
var nativeSelection = window.getSelection();
|
|
74
|
-
var activeElement = document.activeElement;
|
|
75
|
-
if (editorElem === null) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
var rootElement = editor.getRootElement();
|
|
79
|
-
if (isVisible && selection !== null && nativeSelection !== null && rootElement !== null && rootElement.contains(nativeSelection.anchorNode)) {
|
|
80
|
-
var domRange = nativeSelection.getRangeAt(0);
|
|
81
|
-
var rect;
|
|
82
|
-
if (nativeSelection.anchorNode === rootElement) {
|
|
83
|
-
var inner = rootElement;
|
|
84
|
-
while (inner.firstElementChild != null) {
|
|
85
|
-
inner = inner.firstElementChild;
|
|
86
|
-
}
|
|
87
|
-
rect = inner.getBoundingClientRect();
|
|
88
|
-
} else {
|
|
89
|
-
rect = domRange.getBoundingClientRect();
|
|
90
|
-
}
|
|
91
|
-
(0, _setFloatingElemPosition.setFloatingElemPosition)(rect, editorElem, anchorElem);
|
|
92
|
-
setLastSelection(selection);
|
|
93
|
-
} else if (!activeElement || activeElement.className !== "link-input") {
|
|
94
|
-
if (rootElement !== null) {
|
|
95
|
-
(0, _setFloatingElemPosition.setFloatingElemPosition)(null, editorElem, anchorElem);
|
|
96
|
-
}
|
|
97
|
-
setLastSelection(null);
|
|
98
|
-
setEditMode(false);
|
|
99
|
-
setLinkData(emptyLinkData);
|
|
100
|
-
}
|
|
101
|
-
return true;
|
|
102
|
-
}, [isVisible, anchorElem, editor]);
|
|
103
|
-
var removeLink = function removeLink() {
|
|
104
|
-
editor.dispatchCommand(_lexicalNodes.TOGGLE_LINK_COMMAND, null);
|
|
105
|
-
setEditMode(false);
|
|
106
|
-
};
|
|
107
|
-
var applyChanges = function applyChanges(linkData) {
|
|
108
|
-
var confirmedLinkData = {
|
|
109
|
-
url: (0, _sanitizeUrl.sanitizeUrl)(linkData.url),
|
|
110
|
-
target: linkData.target,
|
|
111
|
-
alt: linkData.alt
|
|
112
|
-
};
|
|
113
|
-
if (lastSelection !== null) {
|
|
114
|
-
editor.dispatchCommand(_lexicalNodes.TOGGLE_LINK_COMMAND, confirmedLinkData);
|
|
115
|
-
setEditMode(false);
|
|
116
|
-
}
|
|
117
|
-
};
|
|
118
|
-
(0, _react.useEffect)(function () {
|
|
119
|
-
var scrollerElem = anchorElem.parentElement;
|
|
120
|
-
var update = function update() {
|
|
121
|
-
editor.getEditorState().read(function () {
|
|
122
|
-
updateLinkEditor();
|
|
123
|
-
});
|
|
124
|
-
};
|
|
125
|
-
window.addEventListener("resize", update);
|
|
126
|
-
if (scrollerElem) {
|
|
127
|
-
scrollerElem.addEventListener("scroll", update);
|
|
128
|
-
}
|
|
129
|
-
return function () {
|
|
130
|
-
window.removeEventListener("resize", update);
|
|
131
|
-
if (scrollerElem) {
|
|
132
|
-
scrollerElem.removeEventListener("scroll", update);
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
|
-
}, [anchorElem.parentElement, editor, updateLinkEditor]);
|
|
136
|
-
(0, _react.useEffect)(function () {
|
|
137
|
-
return (0, _utils.mergeRegister)(editor.registerUpdateListener(function (_ref2) {
|
|
138
|
-
var editorState = _ref2.editorState;
|
|
139
|
-
editorState.read(function () {
|
|
140
|
-
updateLinkEditor();
|
|
141
|
-
});
|
|
142
|
-
}), editor.registerCommand(_lexical.SELECTION_CHANGE_COMMAND, function () {
|
|
143
|
-
updateLinkEditor();
|
|
144
|
-
return false;
|
|
145
|
-
}, _lexical.COMMAND_PRIORITY_LOW), editor.registerCommand(_lexical.BLUR_COMMAND, function (payload) {
|
|
146
|
-
if (!(0, _isChildOfLinkEditor.isChildOfLinkEditor)(payload.relatedTarget)) {
|
|
147
|
-
setEditMode(false);
|
|
148
|
-
}
|
|
149
|
-
return false;
|
|
150
|
-
}, _lexical.COMMAND_PRIORITY_LOW));
|
|
151
|
-
}, [editor, updateLinkEditor]);
|
|
152
|
-
(0, _react.useEffect)(function () {
|
|
153
|
-
editor.getEditorState().read(function () {
|
|
154
|
-
updateLinkEditor();
|
|
155
|
-
});
|
|
156
|
-
}, [editor, updateLinkEditor]);
|
|
157
|
-
return /*#__PURE__*/_react.default.createElement("div", {
|
|
158
|
-
ref: editorRef,
|
|
159
|
-
className: "link-editor",
|
|
160
|
-
style: {
|
|
161
|
-
display: isVisible ? "block" : "none"
|
|
162
|
-
}
|
|
163
|
-
}, isEditMode ? /*#__PURE__*/_react.default.createElement(_LinkEditForm.LinkEditForm, {
|
|
164
|
-
linkData: linkData,
|
|
165
|
-
onSave: applyChanges,
|
|
166
|
-
onCancel: function onCancel() {
|
|
167
|
-
return setEditMode(false);
|
|
168
|
-
}
|
|
169
|
-
}) : /*#__PURE__*/_react.default.createElement(_LinkPreviewForm.LinkPreviewForm, {
|
|
170
|
-
linkData: linkData,
|
|
171
|
-
removeLink: removeLink,
|
|
172
|
-
onEdit: function onEdit() {
|
|
173
|
-
setEditMode(true);
|
|
174
|
-
}
|
|
175
|
-
}));
|
|
176
|
-
}
|
|
177
|
-
function FloatingLinkEditorPlugin(_ref3) {
|
|
178
|
-
var _ref3$anchorElem = _ref3.anchorElem,
|
|
179
|
-
anchorElem = _ref3$anchorElem === void 0 ? document.body : _ref3$anchorElem;
|
|
180
|
-
return (0, _useFloatingLinkEditor.useFloatingLinkEditor)(anchorElem);
|
|
1
|
+
import React from "react";
|
|
2
|
+
import { FloatingLinkEditorController } from "./FloatingLinkEditorController.js";
|
|
3
|
+
import "./FloatingLinkEditorPlugin.css";
|
|
4
|
+
export function FloatingLinkEditorPlugin(props) {
|
|
5
|
+
return /*#__PURE__*/React.createElement(FloatingLinkEditorController, {
|
|
6
|
+
LinkForm: props.LinkForm
|
|
7
|
+
});
|
|
181
8
|
}
|
|
182
9
|
|
|
183
10
|
//# sourceMappingURL=FloatingLinkEditorPlugin.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_utils","_lexical","_lexicalNodes","_getSelectedNode","_setFloatingElemPosition","_useFloatingLinkEditor","_LinkEditForm","_LinkPreviewForm","_sanitizeUrl","_isChildOfLinkEditor","FloatingLinkEditor","_ref","editor","isVisible","anchorElem","editorRef","useRef","_useState","useState","url","target","alt","_useState2","_slicedToArray2","default","linkData","setLinkData","_useState3","_useState4","isEditMode","setEditMode","_useState5","_useState6","lastSelection","setLastSelection","updateLinkEditor","useCallback","selection","$getSelection","emptyLinkData","$isRangeSelection","node","getSelectedNode","parent","getParent","$isLinkNode","getURL","getTarget","getAlt","editorElem","current","nativeSelection","window","getSelection","activeElement","document","rootElement","getRootElement","contains","anchorNode","domRange","getRangeAt","rect","inner","firstElementChild","getBoundingClientRect","setFloatingElemPosition","className","removeLink","dispatchCommand","TOGGLE_LINK_COMMAND","applyChanges","confirmedLinkData","sanitizeUrl","useEffect","scrollerElem","parentElement","update","getEditorState","read","addEventListener","removeEventListener","mergeRegister","registerUpdateListener","_ref2","editorState","registerCommand","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_LOW","BLUR_COMMAND","payload","isChildOfLinkEditor","relatedTarget","createElement","ref","style","display","LinkEditForm","onSave","onCancel","LinkPreviewForm","onEdit","FloatingLinkEditorPlugin","_ref3","_ref3$anchorElem","body","useFloatingLinkEditor"],"sources":["FloatingLinkEditorPlugin.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { mergeRegister } from \"@lexical/utils\";\nimport {\n $getSelection,\n $isRangeSelection,\n BaseSelection,\n BLUR_COMMAND,\n COMMAND_PRIORITY_LOW,\n LexicalEditor,\n SELECTION_CHANGE_COMMAND\n} from \"lexical\";\nimport { $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode\";\nimport { setFloatingElemPosition } from \"~/utils/setFloatingElemPosition\";\nimport { useFloatingLinkEditor } from \"./useFloatingLinkEditor\";\nimport { LinkEditForm } from \"./LinkEditForm\";\nimport { LinkPreviewForm } from \"./LinkPreviewForm\";\nimport \"./FloatingLinkEditorPlugin.css\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl\";\nimport { isChildOfLinkEditor } from \"~/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor\";\n\nexport interface LinkData {\n url: string;\n target: string | null;\n alt: string | null;\n}\n\ninterface FloatingLinkEditorProps {\n editor: LexicalEditor;\n isVisible: boolean;\n anchorElem: HTMLElement;\n}\n\nexport function FloatingLinkEditor({ editor, isVisible, anchorElem }: FloatingLinkEditorProps) {\n const editorRef = useRef<HTMLDivElement | null>(null);\n const [linkData, setLinkData] = useState<LinkData>({\n url: \"\",\n target: null,\n alt: null\n });\n\n const [isEditMode, setEditMode] = useState(false);\n const [lastSelection, setLastSelection] = useState<BaseSelection | null>(null);\n\n const updateLinkEditor = useCallback(() => {\n const selection = $getSelection();\n const emptyLinkData = { url: \"\", target: null, alt: null };\n if ($isRangeSelection(selection)) {\n const node = getSelectedNode(selection);\n const parent = node.getParent();\n\n if ($isLinkNode(parent)) {\n const linkData = {\n url: parent.getURL(),\n target: parent.getTarget(),\n alt: $isLinkNode(parent) ? parent.getAlt() : null\n };\n setLinkData(linkData);\n } else if ($isLinkNode(node)) {\n const linkData = {\n url: node.getURL(),\n target: node.getTarget(),\n alt: $isLinkNode(node) ? node.getAlt() : null\n };\n setLinkData(linkData);\n } else {\n setLinkData(emptyLinkData);\n }\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 isVisible &&\n selection !== null &&\n nativeSelection !== null &&\n rootElement !== null &&\n rootElement.contains(nativeSelection.anchorNode)\n ) {\n const domRange = nativeSelection.getRangeAt(0);\n let rect;\n if (nativeSelection.anchorNode === rootElement) {\n let inner = rootElement;\n while (inner.firstElementChild != null) {\n inner = inner.firstElementChild as HTMLElement;\n }\n rect = inner.getBoundingClientRect();\n } else {\n rect = domRange.getBoundingClientRect();\n }\n\n setFloatingElemPosition(rect, editorElem, anchorElem);\n setLastSelection(selection);\n } else if (!activeElement || activeElement.className !== \"link-input\") {\n if (rootElement !== null) {\n setFloatingElemPosition(null, editorElem, anchorElem);\n }\n setLastSelection(null);\n setEditMode(false);\n setLinkData(emptyLinkData);\n }\n\n return true;\n }, [isVisible, anchorElem, editor]);\n\n const removeLink = () => {\n editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);\n setEditMode(false);\n };\n\n const applyChanges = (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.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);\n setEditMode(false);\n }\n };\n\n useEffect(() => {\n const scrollerElem = anchorElem.parentElement;\n\n const update = () => {\n editor.getEditorState().read(() => {\n updateLinkEditor();\n });\n };\n\n window.addEventListener(\"resize\", update);\n\n if (scrollerElem) {\n scrollerElem.addEventListener(\"scroll\", update);\n }\n\n return () => {\n window.removeEventListener(\"resize\", update);\n\n if (scrollerElem) {\n scrollerElem.removeEventListener(\"scroll\", update);\n }\n };\n }, [anchorElem.parentElement, editor, updateLinkEditor]);\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.registerCommand(\n BLUR_COMMAND,\n payload => {\n if (!isChildOfLinkEditor(payload.relatedTarget as HTMLElement)) {\n setEditMode(false);\n }\n return false;\n },\n COMMAND_PRIORITY_LOW\n )\n );\n }, [editor, updateLinkEditor]);\n\n useEffect(() => {\n editor.getEditorState().read(() => {\n updateLinkEditor();\n });\n }, [editor, updateLinkEditor]);\n\n return (\n <div\n ref={editorRef}\n className=\"link-editor\"\n style={{ display: isVisible ? \"block\" : \"none\" }}\n >\n {isEditMode ? (\n <LinkEditForm\n linkData={linkData}\n onSave={applyChanges}\n onCancel={() => setEditMode(false)}\n />\n ) : (\n <LinkPreviewForm\n linkData={linkData}\n removeLink={removeLink}\n onEdit={() => {\n setEditMode(true);\n }}\n />\n )}\n </div>\n );\n}\n\nexport function FloatingLinkEditorPlugin({\n anchorElem = document.body\n}: {\n anchorElem?: HTMLElement;\n}): JSX.Element | null {\n return useFloatingLinkEditor(anchorElem);\n}\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["React","FloatingLinkEditorController","FloatingLinkEditorPlugin","props","createElement","LinkForm"],"sources":["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"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,4BAA4B;AACrC;AAGA,OAAO,SAASC,wBAAwBA,CAACC,KAExC,EAAE;EACC,oBAAOH,KAAA,CAAAI,aAAA,CAACH,4BAA4B;IAACI,QAAQ,EAAEF,KAAK,CAACE;EAAS,CAAE,CAAC;AACrE","ignoreList":[]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export * from "./FloatingLinkEditorPlugin";
|
|
1
|
+
export * from "./FloatingLinkEditorPlugin.js";
|
|
@@ -1,18 +1,3 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
var _FloatingLinkEditorPlugin = require("./FloatingLinkEditorPlugin");
|
|
7
|
-
Object.keys(_FloatingLinkEditorPlugin).forEach(function (key) {
|
|
8
|
-
if (key === "default" || key === "__esModule") return;
|
|
9
|
-
if (key in exports && exports[key] === _FloatingLinkEditorPlugin[key]) return;
|
|
10
|
-
Object.defineProperty(exports, key, {
|
|
11
|
-
enumerable: true,
|
|
12
|
-
get: function get() {
|
|
13
|
-
return _FloatingLinkEditorPlugin[key];
|
|
14
|
-
}
|
|
15
|
-
});
|
|
16
|
-
});
|
|
1
|
+
export * from "./FloatingLinkEditorPlugin.js";
|
|
17
2
|
|
|
18
3
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":[
|
|
1
|
+
{"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./FloatingLinkEditorPlugin.js\";\n"],"mappings":"AAAA","ignoreList":[]}
|
|
@@ -1,18 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
Object.defineProperty(exports, "__esModule", {
|
|
4
|
-
value: true
|
|
5
|
-
});
|
|
6
|
-
exports.isChildOfLinkEditor = void 0;
|
|
7
|
-
var _isChildOfLinkEditor = exports.isChildOfLinkEditor = function isChildOfLinkEditor(element) {
|
|
8
|
-
var parent = element ? element.parentElement : null;
|
|
1
|
+
export const isChildOfLinkEditor = element => {
|
|
2
|
+
const parent = element ? element.parentElement : null;
|
|
9
3
|
if (!parent) {
|
|
10
4
|
return false;
|
|
11
5
|
}
|
|
12
6
|
if (parent.classList.contains("link-editor")) {
|
|
13
7
|
return true;
|
|
14
8
|
}
|
|
15
|
-
return
|
|
9
|
+
return isChildOfLinkEditor(parent);
|
|
16
10
|
};
|
|
17
11
|
|
|
18
12
|
//# sourceMappingURL=isChildOfLinkEditor.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["isChildOfLinkEditor","
|
|
1
|
+
{"version":3,"names":["isChildOfLinkEditor","element","parent","parentElement","classList","contains"],"sources":["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"],"mappings":"AAAA,OAAO,MAAMA,mBAAmB,GAAIC,OAA2B,IAAc;EACzE,MAAMC,MAAM,GAAGD,OAAO,GAAGA,OAAO,CAACE,aAAa,GAAG,IAAI;EAErD,IAAI,CAACD,MAAM,EAAE;IACT,OAAO,KAAK;EAChB;EAEA,IAAIA,MAAM,CAACE,SAAS,CAACC,QAAQ,CAAC,aAAa,CAAC,EAAE;IAC1C,OAAO,IAAI;EACf;EAEA,OAAOL,mBAAmB,CAACE,MAAM,CAAC;AACtC,CAAC","ignoreList":[]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["export interface LinkFormProps {\n linkData: LinkData;\n onSave: (linkData: LinkData) => void;\n removeLink: () => void;\n}\n\nexport interface LinkData {\n url: string;\n target: string | null;\n alt: string | null;\n}\n"],"mappings":"","ignoreList":[]}
|
|
@@ -1,2 +1,8 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
import { type LexicalEditor } from "lexical";
|
|
2
|
+
import { LinkData } from "./types.js";
|
|
3
|
+
export declare function useFloatingLinkEditor(editor: LexicalEditor): {
|
|
4
|
+
editorRef: import("react").MutableRefObject<HTMLDivElement | null>;
|
|
5
|
+
linkData: LinkData;
|
|
6
|
+
applyChanges: (linkData: LinkData) => void;
|
|
7
|
+
removeLink: () => void;
|
|
8
|
+
};
|