@webiny/lexical-editor 6.0.0-alpha.5 → 6.0.0-rc.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.
Files changed (172) hide show
  1. package/README.md +6 -12
  2. package/commands/index.d.ts +5 -5
  3. package/commands/index.js +5 -5
  4. package/commands/index.js.map +1 -1
  5. package/components/Editor/EnsureHeadingTagPlugin.js +1 -1
  6. package/components/Editor/EnsureHeadingTagPlugin.js.map +1 -1
  7. package/components/Editor/RichTextEditor.d.ts +11 -6
  8. package/components/Editor/RichTextEditor.js +22 -16
  9. package/components/Editor/RichTextEditor.js.map +1 -1
  10. package/components/Editor/normalizeInputValue.d.ts +1 -1
  11. package/components/Editor/normalizeInputValue.js.map +1 -1
  12. package/components/LexicalEditorConfig/LexicalEditorConfig.d.ts +14 -16
  13. package/components/LexicalEditorConfig/LexicalEditorConfig.js +20 -58
  14. package/components/LexicalEditorConfig/LexicalEditorConfig.js.map +1 -1
  15. package/components/LexicalHtmlRenderer.d.ts +3 -6
  16. package/components/LexicalHtmlRenderer.js +12 -17
  17. package/components/LexicalHtmlRenderer.js.map +1 -1
  18. package/components/Toolbar/StaticToolbar.css +416 -0
  19. package/components/Toolbar/StaticToolbar.d.ts +1 -1
  20. package/components/Toolbar/StaticToolbar.js +2 -2
  21. package/components/Toolbar/StaticToolbar.js.map +1 -1
  22. package/components/ToolbarActions/BoldAction.js +2 -2
  23. package/components/ToolbarActions/BoldAction.js.map +1 -1
  24. package/components/ToolbarActions/BulletListAction.js +5 -6
  25. package/components/ToolbarActions/BulletListAction.js.map +1 -1
  26. package/components/ToolbarActions/CodeHighlightAction.js +2 -2
  27. package/components/ToolbarActions/CodeHighlightAction.js.map +1 -1
  28. package/components/ToolbarActions/FontColorAction.js +4 -4
  29. package/components/ToolbarActions/FontColorAction.js.map +1 -1
  30. package/components/ToolbarActions/ImageAction.js +3 -3
  31. package/components/ToolbarActions/ImageAction.js.map +1 -1
  32. package/components/ToolbarActions/ItalicAction.js +2 -2
  33. package/components/ToolbarActions/ItalicAction.js.map +1 -1
  34. package/components/ToolbarActions/LinkAction.js +3 -3
  35. package/components/ToolbarActions/LinkAction.js.map +1 -1
  36. package/components/ToolbarActions/NumberedListAction.js +7 -11
  37. package/components/ToolbarActions/NumberedListAction.js.map +1 -1
  38. package/components/ToolbarActions/QuoteAction.js +6 -6
  39. package/components/ToolbarActions/QuoteAction.js.map +1 -1
  40. package/components/ToolbarActions/TextAlignmentAction.js +4 -4
  41. package/components/ToolbarActions/TextAlignmentAction.js.map +1 -1
  42. package/components/ToolbarActions/TypographyAction.js +14 -11
  43. package/components/ToolbarActions/TypographyAction.js.map +1 -1
  44. package/components/ToolbarActions/UnderlineAction.js +1 -1
  45. package/components/ToolbarActions/UnderlineAction.js.map +1 -1
  46. package/context/RichTextEditorContext.d.ts +5 -6
  47. package/context/RichTextEditorContext.js +17 -4
  48. package/context/RichTextEditorContext.js.map +1 -1
  49. package/context/TypographyActionContext.d.ts +1 -1
  50. package/context/TypographyActionContext.js.map +1 -1
  51. package/exports/admin/lexical.d.ts +15 -0
  52. package/exports/admin/lexical.js +23 -0
  53. package/exports/admin/lexical.js.map +1 -0
  54. package/hooks/index.d.ts +7 -8
  55. package/hooks/index.js +7 -8
  56. package/hooks/index.js.map +1 -1
  57. package/hooks/useCurrentElement.js +2 -3
  58. package/hooks/useCurrentElement.js.map +1 -1
  59. package/hooks/useCurrentSelection.js +4 -4
  60. package/hooks/useCurrentSelection.js.map +1 -1
  61. package/hooks/useFontColorPicker.d.ts +1 -1
  62. package/hooks/useFontColorPicker.js +1 -1
  63. package/hooks/useFontColorPicker.js.map +1 -1
  64. package/hooks/useRichTextEditor.d.ts +1 -1
  65. package/hooks/useRichTextEditor.js +1 -1
  66. package/hooks/useRichTextEditor.js.map +1 -1
  67. package/hooks/useTextAlignmentAction.d.ts +1 -1
  68. package/hooks/useTextAlignmentAction.js +1 -1
  69. package/hooks/useTextAlignmentAction.js.map +1 -1
  70. package/hooks/useTypographyAction.d.ts +1 -1
  71. package/hooks/useTypographyAction.js +1 -1
  72. package/hooks/useTypographyAction.js.map +1 -1
  73. package/index.d.ts +33 -37
  74. package/index.js +33 -37
  75. package/index.js.map +1 -1
  76. package/package.json +18 -22
  77. package/plugins/BlurEventPlugin/BlurEventPlugin.d.ts +1 -1
  78. package/plugins/BlurEventPlugin/BlurEventPlugin.js +1 -1
  79. package/plugins/BlurEventPlugin/BlurEventPlugin.js.map +1 -1
  80. package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js +1 -1
  81. package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js.map +1 -1
  82. package/plugins/CodeHighlightPlugin/index.d.ts +1 -1
  83. package/plugins/CodeHighlightPlugin/index.js +1 -1
  84. package/plugins/CodeHighlightPlugin/index.js.map +1 -1
  85. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.d.ts +4 -10
  86. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js +15 -145
  87. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js.map +1 -1
  88. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.d.ts +2 -3
  89. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js +10 -11
  90. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js.map +1 -1
  91. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.css +1 -136
  92. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.d.ts +5 -6
  93. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js +3 -7
  94. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js.map +1 -1
  95. package/plugins/FloatingLinkEditorPlugin/index.d.ts +1 -1
  96. package/plugins/FloatingLinkEditorPlugin/index.js +1 -1
  97. package/plugins/FloatingLinkEditorPlugin/index.js.map +1 -1
  98. package/plugins/FloatingLinkEditorPlugin/types.d.ts +10 -0
  99. package/plugins/FloatingLinkEditorPlugin/types.js +3 -0
  100. package/plugins/FloatingLinkEditorPlugin/types.js.map +1 -0
  101. package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.d.ts +8 -0
  102. package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js +128 -0
  103. package/plugins/FloatingLinkEditorPlugin/useFloatingLinkEditor.js.map +1 -0
  104. package/plugins/FontColorPlugin/FontColorPlugin.js +2 -2
  105. package/plugins/FontColorPlugin/FontColorPlugin.js.map +1 -1
  106. package/plugins/FontColorPlugin/applyColorToSelection.js +1 -1
  107. package/plugins/FontColorPlugin/applyColorToSelection.js.map +1 -1
  108. package/plugins/ImagesPlugin/ImagesPlugin.d.ts +1 -2
  109. package/plugins/ImagesPlugin/ImagesPlugin.js +5 -8
  110. package/plugins/ImagesPlugin/ImagesPlugin.js.map +1 -1
  111. package/plugins/LinkPlugin/LinkPlugin.js +2 -3
  112. package/plugins/LinkPlugin/LinkPlugin.js.map +1 -1
  113. package/plugins/ListPLugin/ListPlugin.js +45 -3
  114. package/plugins/ListPLugin/ListPlugin.js.map +1 -1
  115. package/plugins/QuoteNodePlugin/QuoteNodePlugin.js +12 -4
  116. package/plugins/QuoteNodePlugin/QuoteNodePlugin.js.map +1 -1
  117. package/plugins/StateHandlingPlugin.d.ts +1 -1
  118. package/plugins/StateHandlingPlugin.js +6 -6
  119. package/plugins/StateHandlingPlugin.js.map +1 -1
  120. package/plugins/TypographyPlugin/TypographyPlugin.js +2 -2
  121. package/plugins/TypographyPlugin/TypographyPlugin.js.map +1 -1
  122. package/types.d.ts +3 -3
  123. package/types.js +1 -1
  124. package/types.js.map +1 -1
  125. package/ui/ContentEditable.d.ts +0 -1
  126. package/ui/Divider.d.ts +0 -1
  127. package/ui/DropDown.js +4 -3
  128. package/ui/DropDown.js.map +1 -1
  129. package/ui/ImageResizer.d.ts +0 -1
  130. package/ui/ImageResizer.js.map +1 -1
  131. package/ui/LinkPreview.d.ts +0 -1
  132. package/ui/TextInput.d.ts +0 -1
  133. package/utils/files.d.ts +6 -6
  134. package/utils/files.js +3 -13
  135. package/utils/files.js.map +1 -1
  136. package/utils/insertImage.d.ts +1 -1
  137. package/utils/insertImage.js.map +1 -1
  138. package/utils/isValidLexicalData.d.ts +2 -2
  139. package/utils/isValidLexicalData.js.map +1 -1
  140. package/utils/rect.d.ts +1 -1
  141. package/utils/rect.js +1 -1
  142. package/utils/rect.js.map +1 -1
  143. package/utils/sanitizeUrl.js +1 -1
  144. package/utils/sanitizeUrl.js.map +1 -1
  145. package/utils/setFloatingElemPosition.d.ts +1 -1
  146. package/utils/setFloatingElemPosition.js +23 -21
  147. package/utils/setFloatingElemPosition.js.map +1 -1
  148. package/components/Editor/HeadingEditor.d.ts +0 -7
  149. package/components/Editor/HeadingEditor.js +0 -22
  150. package/components/Editor/HeadingEditor.js.map +0 -1
  151. package/components/Editor/ParagraphEditor.d.ts +0 -7
  152. package/components/Editor/ParagraphEditor.js +0 -22
  153. package/components/Editor/ParagraphEditor.js.map +0 -1
  154. package/components/Toolbar/Toolbar.css +0 -643
  155. package/components/Toolbar/Toolbar.d.ts +0 -6
  156. package/components/Toolbar/Toolbar.js +0 -148
  157. package/components/Toolbar/Toolbar.js.map +0 -1
  158. package/components/ToolbarActions/FontSizeAction.d.ts +0 -14
  159. package/components/ToolbarActions/FontSizeAction.js +0 -91
  160. package/components/ToolbarActions/FontSizeAction.js.map +0 -1
  161. package/hooks/useList.d.ts +0 -2
  162. package/hooks/useList.js +0 -50
  163. package/hooks/useList.js.map +0 -1
  164. package/hooks/useQuote.d.ts +0 -2
  165. package/hooks/useQuote.js +0 -17
  166. package/hooks/useQuote.js.map +0 -1
  167. package/plugins/FloatingLinkEditorPlugin/LinkEditForm.d.ts +0 -8
  168. package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js +0 -104
  169. package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js.map +0 -1
  170. package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.d.ts +0 -9
  171. package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js +0 -34
  172. package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"names":["React","useCallback","useEffect","useRef","useState","getSelectedNode","$isLinkNode","TOGGLE_LINK_COMMAND","setFloatingElemPosition","sanitizeUrl","isChildOfLinkEditor","LinkEditForm","DefaultLinkEditForm","LinkPreviewForm","SELECTION_CHANGE_COMMAND","COMMAND_PRIORITY_LOW","BLUR_COMMAND","$getSelection","$isRangeSelection","mergeRegister","FloatingLinkEditor","editor","isVisible","anchorElem","editorRef","linkData","setLinkData","url","target","alt","isEditMode","setEditMode","lastSelection","setLastSelection","updateLinkEditor","selection","emptyLinkData","node","parent","getParent","getURL","getTarget","getAlt","editorElem","current","nativeSelection","window","getSelection","activeElement","document","rootElement","getRootElement","contains","anchorNode","domRange","getRangeAt","rect","inner","firstElementChild","getBoundingClientRect","className","removeLink","dispatchCommand","applyChanges","confirmedLinkData","scrollerElem","parentElement","update","getEditorState","read","addEventListener","removeEventListener","registerUpdateListener","editorState","registerCommand","payload","relatedTarget","createElement","ref","style","display","onSave","onCancel","onEdit"],"sources":["FloatingLinkEditor.tsx"],"sourcesContent":["import React, { useCallback, useEffect, useRef, useState } from \"react\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode\";\nimport { $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { setFloatingElemPosition } from \"~/utils/setFloatingElemPosition\";\nimport { sanitizeUrl } from \"~/utils/sanitizeUrl\";\nimport { isChildOfLinkEditor } from \"./isChildOfLinkEditor\";\nimport { LinkEditForm as DefaultLinkEditForm } from \"./LinkEditForm\";\nimport { LinkPreviewForm } from \"./LinkPreviewForm\";\nimport {\n SELECTION_CHANGE_COMMAND,\n type BaseSelection,\n type LexicalEditor,\n COMMAND_PRIORITY_LOW,\n BLUR_COMMAND,\n $getSelection,\n $isRangeSelection\n} from \"lexical\";\nimport { mergeRegister } from \"@lexical/utils\";\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 LinkEditForm?: typeof DefaultLinkEditForm;\n}\n\nexport function FloatingLinkEditor({\n editor,\n isVisible,\n anchorElem,\n LinkEditForm = DefaultLinkEditForm\n}: 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 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 }, [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"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["React","useFloatingLinkEditor","FloatingLinkEditor","editor","isVisible","LinkForm","editorRef","linkData","applyChanges","removeLink","createElement","ref","className","style","opacity","pointerEvents","onSave"],"sources":["FloatingLinkEditor.tsx"],"sourcesContent":["import React from \"react\";\nimport type { LexicalEditor } from \"lexical\";\nimport { LinkFormProps } from \"./types.js\";\nimport { useFloatingLinkEditor } from \"./useFloatingLinkEditor.js\";\n\ninterface FloatingLinkEditorProps {\n editor: LexicalEditor;\n isVisible: boolean;\n LinkForm: React.FunctionComponent<LinkFormProps>;\n}\n\nexport function FloatingLinkEditor({ editor, isVisible, LinkForm }: FloatingLinkEditorProps) {\n const { editorRef, linkData, applyChanges, removeLink } = useFloatingLinkEditor(editor);\n\n return (\n <div\n ref={editorRef}\n className=\"z-dialog absolute link-editor\"\n style={{ opacity: isVisible ? 1 : 0, pointerEvents: isVisible ? \"auto\" : \"none\" }}\n >\n {isVisible ? (\n <LinkForm linkData={linkData} onSave={applyChanges} removeLink={removeLink} />\n ) : null}\n </div>\n );\n}\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AAGzB,SAASC,qBAAqB;AAQ9B,OAAO,SAASC,kBAAkBA,CAAC;EAAEC,MAAM;EAAEC,SAAS;EAAEC;AAAkC,CAAC,EAAE;EACzF,MAAM;IAAEC,SAAS;IAAEC,QAAQ;IAAEC,YAAY;IAAEC;EAAW,CAAC,GAAGR,qBAAqB,CAACE,MAAM,CAAC;EAEvF,oBACIH,KAAA,CAAAU,aAAA;IACIC,GAAG,EAAEL,SAAU;IACfM,SAAS,EAAC,+BAA+B;IACzCC,KAAK,EAAE;MAAEC,OAAO,EAAEV,SAAS,GAAG,CAAC,GAAG,CAAC;MAAEW,aAAa,EAAEX,SAAS,GAAG,MAAM,GAAG;IAAO;EAAE,GAEjFA,SAAS,gBACNJ,KAAA,CAAAU,aAAA,CAACL,QAAQ;IAACE,QAAQ,EAAEA,QAAS;IAACS,MAAM,EAAER,YAAa;IAACC,UAAU,EAAEA;EAAW,CAAE,CAAC,GAC9E,IACH,CAAC;AAEd","ignoreList":[]}
@@ -1,8 +1,7 @@
1
1
  import React from "react";
2
- import type { LinkEditForm } from "./LinkEditForm";
2
+ import { LinkFormProps } from "./types.js";
3
3
  interface FloatingLinkEditorProps {
4
- anchorElem: () => HTMLElement;
5
- LinkEditForm?: typeof LinkEditForm;
4
+ LinkForm: React.FunctionComponent<LinkFormProps>;
6
5
  }
7
6
  export declare const FloatingLinkEditorController: (props: FloatingLinkEditorProps) => React.ReactPortal;
8
7
  export {};
@@ -1,16 +1,16 @@
1
1
  import React, { useCallback, useState, useEffect } from "react";
2
2
  import { createPortal } from "react-dom";
3
- import { useRichTextEditor } from "../../hooks";
4
- import { getSelectedNode } from "../../utils/getSelectedNode";
3
+ import { useRichTextEditor } from "../../hooks/index.js";
4
+ import { getSelectedNode } from "../../utils/getSelectedNode.js";
5
5
  import { $isAutoLinkNode, $isLinkNode, TOGGLE_LINK_COMMAND } from "@webiny/lexical-nodes";
6
- import { isChildOfLinkEditor } from "./isChildOfLinkEditor";
7
- import debounce from "lodash/debounce";
8
- import { $getSelection, $isRangeSelection, BLUR_COMMAND, COMMAND_PRIORITY_CRITICAL, COMMAND_PRIORITY_LOW, SELECTION_CHANGE_COMMAND } from "lexical";
9
- import { $findMatchingParent, mergeRegister } from "@lexical/utils";
10
- import { FloatingLinkEditor } from "./FloatingLinkEditor";
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";
11
10
  export const FloatingLinkEditorController = props => {
12
11
  const {
13
- editor
12
+ editor,
13
+ getOverlaysElement
14
14
  } = useRichTextEditor();
15
15
  const [isLink, setIsLink] = useState(false);
16
16
  const debounceSetIsLink = useCallback(debounce(setIsLink, 50), []);
@@ -54,9 +54,8 @@ export const FloatingLinkEditorController = props => {
54
54
  return /*#__PURE__*/createPortal(/*#__PURE__*/React.createElement(FloatingLinkEditor, {
55
55
  isVisible: isLink,
56
56
  editor: editor,
57
- anchorElem: props.anchorElem(),
58
- LinkEditForm: props.LinkEditForm
59
- }), props.anchorElem());
57
+ LinkForm: props.LinkForm
58
+ }), getOverlaysElement());
60
59
  };
61
60
 
62
61
  //# sourceMappingURL=FloatingLinkEditorController.js.map
@@ -1 +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","$findMatchingParent","mergeRegister","FloatingLinkEditor","FloatingLinkEditorController","props","editor","isLink","setIsLink","debounceSetIsLink","updateToolbar","selection","node","linkParent","autoLinkParent","isLinkOrChildOfLink","Boolean","dirty","registerCommand","payload","relatedTarget","createElement","isVisible","anchorElem","LinkEditForm"],"sources":["FloatingLinkEditorController.tsx"],"sourcesContent":["import React, { useCallback, useState, useEffect } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport { useRichTextEditor } from \"~/hooks\";\nimport { getSelectedNode } from \"~/utils/getSelectedNode\";\nimport { $isAutoLinkNode, $isLinkNode, TOGGLE_LINK_COMMAND } from \"@webiny/lexical-nodes\";\nimport { isChildOfLinkEditor } from \"~/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor\";\nimport debounce from \"lodash/debounce\";\nimport {\n $getSelection,\n $isRangeSelection,\n BLUR_COMMAND,\n COMMAND_PRIORITY_CRITICAL,\n COMMAND_PRIORITY_LOW,\n SELECTION_CHANGE_COMMAND\n} from \"lexical\";\nimport { $findMatchingParent, mergeRegister } from \"@lexical/utils\";\nimport { FloatingLinkEditor } from \"./FloatingLinkEditor\";\nimport type { LinkEditForm } from \"./LinkEditForm\";\n\ninterface FloatingLinkEditorProps {\n anchorElem: () => HTMLElement;\n LinkEditForm?: typeof LinkEditForm;\n}\n\nexport const FloatingLinkEditorController = (props: FloatingLinkEditorProps) => {\n const { editor } = 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\n isVisible={isLink}\n editor={editor}\n anchorElem={props.anchorElem()}\n LinkEditForm={props.LinkEditForm}\n />,\n props.anchorElem()\n );\n};\n"],"mappings":"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","ignoreList":[]}
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,24 +1,14 @@
1
1
  .link-editor {
2
- position: absolute;
3
2
  top: 0;
4
3
  left: 0;
5
- z-index: 51;
6
4
  max-width: 400px;
7
5
  width: 100%;
8
6
  opacity: 0;
9
7
  background-color: #fff;
10
- box-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
8
+ box-shadow: 0 3px 8px rgba(0, 0, 0, 0.3);
11
9
  border-radius: 8px;
12
- transition: opacity 0.5s;
13
- will-change: transform;
14
- padding: 10px 0;
15
10
  pointer-events: all;
16
11
  }
17
-
18
- .link-editor .link-editor-target-checkbox {
19
- padding: 10px 10px 5px 10px;
20
- }
21
-
22
12
  .link-editor .button {
23
13
  width: 20px;
24
14
  height: 20px;
@@ -41,131 +31,6 @@
41
31
  background-color: rgb(223, 232, 250);
42
32
  }
43
33
 
44
- .link-editor .link-editor-section {
45
- margin: 0 15px;
46
- padding: 10px 0;
47
- width: calc(100% - 24px);
48
- }
49
-
50
- .link-editor .link-editor-popup-title {
51
- margin: 0 15px 10px;
52
- color: var(--mdc-theme-primary);
53
- }
54
-
55
- .link-editor .link-editor-section .header {
56
- width: auto;
57
- margin-bottom: 10px;
58
- }
59
-
60
- .link-editor .link-editor-section .header_icon {
61
- font-size: 16px;
62
- width: 16px;
63
- height: 16px;
64
- }
65
-
66
- .link-editor .link-editor-section .header_title {
67
- font-size: 16px;
68
- font-width: bold;
69
- color: var(--mdc-theme-primary);
70
- }
71
-
72
- .link-editor .link-editor-section .section-desc {
73
- color: #0a0a0a;
74
- }
75
-
76
- .link-editor .link-editor-section.edit-form-bottom-menu {
77
- display: flex;
78
- justify-content: right;
79
- margin-top: 5px;
80
- column-gap: 10px;
81
- }
82
-
83
- .link-editor .link-editor-section ul {
84
- list-style: initial;
85
- padding: 0 20px;
86
- }
87
-
88
- .link-editor .link-editor-section ul li {
89
- padding: 3px 0;
90
- }
91
-
92
- .link-editor .link-input {
93
- display: block;
94
- width: calc(100% - 24px);
95
- height: 42px;
96
- box-sizing: border-box;
97
- margin: 12px;
98
- padding: 12px;
99
- border-radius: 10px;
100
- background-color: #eee;
101
- font-size: 16px;
102
- color: rgb(5, 5, 5);
103
- border: 0;
104
- outline: 0;
105
- position: relative;
106
- font-family: inherit;
107
- }
108
-
109
- .link-editor .link-input.full-with {
110
- width: 100%;
111
- margin: 0;
112
- }
113
-
114
- .link-editor .link-input .link-unlink {
115
- background-image: url(../../images/icons/unlink_icon.svg);
116
- background-size: 18px;
117
- background-position: center;
118
- background-repeat: no-repeat;
119
- width: 35px;
120
- vertical-align: -0.25em;
121
- position: absolute;
122
- right: 5px;
123
- top: 0;
124
- bottom: 0;
125
- cursor: pointer;
126
- }
127
-
128
- .link-editor .link-input .link-edit {
129
- background-image: url(../../images/icons/pencil-fill.svg);
130
- background-size: 16px;
131
- background-position: center;
132
- background-repeat: no-repeat;
133
- width: 35px;
134
- vertical-align: -0.25em;
135
- position: absolute;
136
- right: 35px;
137
- top: 0;
138
- bottom: 0;
139
- cursor: pointer;
140
- }
141
-
142
- .link-editor .link-input a {
143
- color: rgb(33, 111, 219);
144
- text-decoration: none;
145
- display: block;
146
- white-space: nowrap;
147
- overflow: hidden;
148
- margin-right: 30px;
149
- text-overflow: ellipsis;
150
- }
151
-
152
- .link-editor .link-input a:hover {
153
- text-decoration: underline;
154
- }
155
-
156
- .link-editor .font-size-wrapper,
157
- .link-editor .font-family-wrapper {
158
- display: flex;
159
- margin: 0 4px;
160
- }
161
-
162
- .link-editor select {
163
- padding: 6px;
164
- border: none;
165
- background-color: rgba(0, 0, 0, 0.075);
166
- border-radius: 4px;
167
- }
168
-
169
34
  .link-editor .button i,
170
35
  .actions i {
171
36
  background-size: contain;
@@ -1,7 +1,6 @@
1
- /// <reference types="react" />
2
- import type { LinkEditForm } from "./LinkEditForm";
1
+ import React from "react";
3
2
  import "./FloatingLinkEditorPlugin.css";
4
- export declare function FloatingLinkEditorPlugin({ anchorElem, ...props }: {
5
- anchorElem?: () => HTMLElement;
6
- LinkEditForm?: typeof LinkEditForm;
7
- }): JSX.Element | null;
3
+ import { LinkFormProps } from "./types.js";
4
+ export declare function FloatingLinkEditorPlugin(props: {
5
+ LinkForm: React.FunctionComponent<LinkFormProps>;
6
+ }): React.JSX.Element;
@@ -1,13 +1,9 @@
1
1
  import React from "react";
2
- import { FloatingLinkEditorController } from "./FloatingLinkEditorController";
2
+ import { FloatingLinkEditorController } from "./FloatingLinkEditorController.js";
3
3
  import "./FloatingLinkEditorPlugin.css";
4
- export function FloatingLinkEditorPlugin({
5
- anchorElem = () => document.body,
6
- ...props
7
- }) {
4
+ export function FloatingLinkEditorPlugin(props) {
8
5
  return /*#__PURE__*/React.createElement(FloatingLinkEditorController, {
9
- anchorElem: anchorElem,
10
- LinkEditForm: props.LinkEditForm
6
+ LinkForm: props.LinkForm
11
7
  });
12
8
  }
13
9
 
@@ -1 +1 @@
1
- {"version":3,"names":["React","FloatingLinkEditorController","FloatingLinkEditorPlugin","anchorElem","document","body","props","createElement","LinkEditForm"],"sources":["FloatingLinkEditorPlugin.tsx"],"sourcesContent":["import React from \"react\";\nimport { FloatingLinkEditorController } from \"./FloatingLinkEditorController\";\nimport type { LinkEditForm } from \"./LinkEditForm\";\nimport \"./FloatingLinkEditorPlugin.css\";\n\nexport function FloatingLinkEditorPlugin({\n anchorElem = () => document.body,\n ...props\n}: {\n anchorElem?: () => HTMLElement;\n LinkEditForm?: typeof LinkEditForm;\n}): JSX.Element | null {\n return (\n <FloatingLinkEditorController anchorElem={anchorElem} LinkEditForm={props.LinkEditForm} />\n );\n}\n"],"mappings":"AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,SAASC,4BAA4B;AAErC;AAEA,OAAO,SAASC,wBAAwBA,CAAC;EACrCC,UAAU,GAAGA,CAAA,KAAMC,QAAQ,CAACC,IAAI;EAChC,GAAGC;AAIP,CAAC,EAAsB;EACnB,oBACIN,KAAA,CAAAO,aAAA,CAACN,4BAA4B;IAACE,UAAU,EAAEA,UAAW;IAACK,YAAY,EAAEF,KAAK,CAACE;EAAa,CAAE,CAAC;AAElG","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,3 +1,3 @@
1
- export * from "./FloatingLinkEditorPlugin";
1
+ export * from "./FloatingLinkEditorPlugin.js";
2
2
 
3
3
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./FloatingLinkEditorPlugin\";\n"],"mappings":"AAAA","ignoreList":[]}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./FloatingLinkEditorPlugin.js\";\n"],"mappings":"AAAA","ignoreList":[]}
@@ -0,0 +1,10 @@
1
+ export interface LinkFormProps {
2
+ linkData: LinkData;
3
+ onSave: (linkData: LinkData) => void;
4
+ removeLink: () => void;
5
+ }
6
+ export interface LinkData {
7
+ url: string;
8
+ target: string | null;
9
+ alt: string | null;
10
+ }
@@ -0,0 +1,3 @@
1
+ export {};
2
+
3
+ //# sourceMappingURL=types.js.map
@@ -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":[]}
@@ -0,0 +1,8 @@
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
+ };
@@ -0,0 +1,128 @@
1
+ import { useCallback, useEffect, useRef, useState } from "react";
2
+ import { SELECTION_CHANGE_COMMAND, COMMAND_PRIORITY_LOW, $getSelection, $isRangeSelection, mergeRegister } from "lexical";
3
+ import { $isLinkNode, TOGGLE_LINK_COMMAND } from "@webiny/lexical-nodes";
4
+ import { getSelectedNode } from "../../utils/getSelectedNode.js";
5
+ import { setFloatingElemPosition } from "../../utils/setFloatingElemPosition.js";
6
+ import { sanitizeUrl } from "../../utils/sanitizeUrl.js";
7
+ const emptyLinkData = {
8
+ url: "",
9
+ target: null,
10
+ alt: null
11
+ };
12
+ function getSelectionKey(selection) {
13
+ if ($isRangeSelection(selection)) {
14
+ return `${selection.anchor.key}:${selection.anchor.offset}-${selection.focus.key}:${selection.focus.offset}`;
15
+ }
16
+ return null;
17
+ }
18
+ function getLinkDataFromSelection() {
19
+ const selection = $getSelection();
20
+ if (!$isRangeSelection(selection)) {
21
+ return emptyLinkData;
22
+ }
23
+ const node = getSelectedNode(selection);
24
+ const parent = node.getParent();
25
+ if ($isLinkNode(parent)) {
26
+ return {
27
+ url: parent.getURL(),
28
+ target: parent.getTarget(),
29
+ alt: parent.getAlt()
30
+ };
31
+ }
32
+ if ($isLinkNode(node)) {
33
+ return {
34
+ url: node.getURL(),
35
+ target: node.getTarget(),
36
+ alt: node.getAlt()
37
+ };
38
+ }
39
+ return emptyLinkData;
40
+ }
41
+ export function useFloatingLinkEditor(editor) {
42
+ const editorRef = useRef(null);
43
+ const [linkData, setLinkData] = useState(emptyLinkData);
44
+ const [lastSelection, setLastSelection] = useState(null);
45
+ const suppressedSelectionKeyRef = useRef(null);
46
+ const updateLinkEditor = useCallback(() => {
47
+ const selection = $getSelection();
48
+ const selectionKey = getSelectionKey(selection);
49
+
50
+ // If we're still on the same selection that was suppressed, hide the popover.
51
+ if (suppressedSelectionKeyRef.current !== null) {
52
+ if (selectionKey === suppressedSelectionKeyRef.current) {
53
+ const editorElem = editorRef.current;
54
+ if (editorElem) {
55
+ setFloatingElemPosition(null, editorElem);
56
+ }
57
+ setLastSelection(null);
58
+ setLinkData(emptyLinkData);
59
+ return true;
60
+ }
61
+ // New selection — clear suppression.
62
+ suppressedSelectionKeyRef.current = null;
63
+ }
64
+ setLinkData(getLinkDataFromSelection());
65
+ const editorElem = editorRef.current;
66
+ const nativeSelection = window.getSelection();
67
+ const activeElement = document.activeElement;
68
+ if (editorElem === null) {
69
+ return;
70
+ }
71
+ const rootElement = editor.getRootElement();
72
+ if (selection !== null && nativeSelection !== null && rootElement !== null && rootElement.contains(nativeSelection.anchorNode)) {
73
+ const range = nativeSelection.getRangeAt(0);
74
+ setFloatingElemPosition(range, editorElem);
75
+ setLastSelection(selection);
76
+ } else if (!activeElement || activeElement.className !== "link-input") {
77
+ if (rootElement !== null) {
78
+ setFloatingElemPosition(null, editorElem);
79
+ }
80
+ setLastSelection(null);
81
+ setLinkData(emptyLinkData);
82
+ }
83
+ return true;
84
+ }, [editor]);
85
+ const removeLink = useCallback(() => {
86
+ editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);
87
+ }, [editor]);
88
+ const applyChanges = useCallback(linkData => {
89
+ const confirmedLinkData = {
90
+ url: sanitizeUrl(linkData.url),
91
+ target: linkData.target,
92
+ alt: linkData.alt
93
+ };
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
+ }
127
+
128
+ //# sourceMappingURL=useFloatingLinkEditor.js.map
@@ -0,0 +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,8 +1,8 @@
1
1
  import { useEffect } from "react";
2
2
  import { $getSelection, $isRangeSelection, COMMAND_PRIORITY_EDITOR } from "lexical";
3
3
  import { ADD_FONT_COLOR_COMMAND } from "@webiny/lexical-nodes";
4
- import { useRichTextEditor } from "../../hooks";
5
- import { applyColorToSelection } from "./applyColorToSelection";
4
+ import { useRichTextEditor } from "../../hooks/index.js";
5
+ import { applyColorToSelection } from "./applyColorToSelection.js";
6
6
  export const FontColorPlugin = () => {
7
7
  const {
8
8
  editor
@@ -1 +1 @@
1
- {"version":3,"names":["useEffect","$getSelection","$isRangeSelection","COMMAND_PRIORITY_EDITOR","ADD_FONT_COLOR_COMMAND","useRichTextEditor","applyColorToSelection","FontColorPlugin","editor","registerCommand","payload","update","color","selection"],"sources":["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\";\nimport { applyColorToSelection } from \"./applyColorToSelection\";\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"],"mappings":"AAAA,SAASA,SAAS,QAAQ,OAAO;AACjC,SAASC,aAAa,EAAEC,iBAAiB,EAAEC,uBAAuB,QAAQ,SAAS;AAEnF,SAASC,sBAAsB,QAAQ,uBAAuB;AAC9D,SAASC,iBAAiB;AAC1B,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,eAAe,GAAGA,CAAA,KAAM;EACjC,MAAM;IAAEC;EAAO,CAAC,GAAGH,iBAAiB,CAAC,CAAC;EAEtCL,SAAS,CAAC,MAAM;IACZ,OAAOQ,MAAM,CAACC,eAAe,CACzBL,sBAAsB,EACtBM,OAAO,IAAI;MACPF,MAAM,CAACG,MAAM,CAAC,MAAM;QAChB,MAAM;UAAEC;QAAM,CAAC,GAAGF,OAAO;QACzB,MAAMG,SAAS,GAAGZ,aAAa,CAAC,CAAC;QAEjC,IAAIC,iBAAiB,CAACW,SAAS,CAAC,EAAE;UAC9BP,qBAAqB,CAACO,SAAS,EAAED,KAAK,CAAC;QAC3C;MACJ,CAAC,CAAC;MACF,OAAO,IAAI;IACf,CAAC,EACDT,uBACJ,CAAC;EACL,CAAC,EAAE,CAACK,MAAM,CAAC,CAAC;EAEZ,OAAO,IAAI;AACf,CAAC","ignoreList":[]}
1
+ {"version":3,"names":["useEffect","$getSelection","$isRangeSelection","COMMAND_PRIORITY_EDITOR","ADD_FONT_COLOR_COMMAND","useRichTextEditor","applyColorToSelection","FontColorPlugin","editor","registerCommand","payload","update","color","selection"],"sources":["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"],"mappings":"AAAA,SAASA,SAAS,QAAQ,OAAO;AACjC,SAASC,aAAa,EAAEC,iBAAiB,EAAEC,uBAAuB,QAAQ,SAAS;AAEnF,SAASC,sBAAsB,QAAQ,uBAAuB;AAC9D,SAASC,iBAAiB;AAC1B,SAASC,qBAAqB;AAE9B,OAAO,MAAMC,eAAe,GAAGA,CAAA,KAAM;EACjC,MAAM;IAAEC;EAAO,CAAC,GAAGH,iBAAiB,CAAC,CAAC;EAEtCL,SAAS,CAAC,MAAM;IACZ,OAAOQ,MAAM,CAACC,eAAe,CACzBL,sBAAsB,EACtBM,OAAO,IAAI;MACPF,MAAM,CAACG,MAAM,CAAC,MAAM;QAChB,MAAM;UAAEC;QAAM,CAAC,GAAGF,OAAO;QACzB,MAAMG,SAAS,GAAGZ,aAAa,CAAC,CAAC;QAEjC,IAAIC,iBAAiB,CAACW,SAAS,CAAC,EAAE;UAC9BP,qBAAqB,CAACO,SAAS,EAAED,KAAK,CAAC;QAC3C;MACJ,CAAC,CAAC;MACF,OAAO,IAAI;IACf,CAAC,EACDT,uBACJ,CAAC;EACL,CAAC,EAAE,CAACK,MAAM,CAAC,CAAC;EAEZ,OAAO,IAAI;AACf,CAAC","ignoreList":[]}
@@ -1,5 +1,5 @@
1
1
  import { TextNode } from "lexical";
2
- import { applyColorToNode } from "./applyColorToNode";
2
+ import { applyColorToNode } from "./applyColorToNode.js";
3
3
  export function applyColorToSelection(selection, color) {
4
4
  // Basic variables
5
5
  const textNodes = selection.getNodes().filter(node => node instanceof TextNode);
@@ -1 +1 @@
1
- {"version":3,"names":["TextNode","applyColorToNode","applyColorToSelection","selection","color","textNodes","getNodes","filter","node","selectedTextNodesLength","length","startEndPoints","getStartEndPoints","anchor","focus","lastIndex","firstNode","lastNode","firstNodeText","getTextContent","firstNodeTextLength","focusOffset","offset","anchorOffset","isBefore","startOffset","endOffset","fontColorNode","select","splitNodes","splitText","replacement","forEach","textNode","toColor"],"sources":["applyColorToSelection.ts"],"sourcesContent":["import type { RangeSelection } from \"lexical\";\nimport { TextNode } from \"lexical\";\nimport type { ThemeColorValue } from \"@webiny/lexical-nodes\";\nimport { applyColorToNode } from \"~/plugins/FontColorPlugin/applyColorToNode\";\n\nexport function applyColorToSelection(selection: RangeSelection, color: ThemeColorValue) {\n // Basic variables\n const textNodes = selection.getNodes().filter(node => node instanceof TextNode) as TextNode[];\n\n const selectedTextNodesLength = textNodes.length;\n const startEndPoints = selection.getStartEndPoints();\n\n if (startEndPoints === null) {\n return;\n }\n\n const [anchor, focus] = startEndPoints;\n\n const lastIndex = selectedTextNodesLength - 1;\n const firstNode = textNodes[0];\n const lastNode = textNodes[lastIndex];\n const firstNodeText = firstNode.getTextContent();\n const firstNodeTextLength = firstNodeText.length;\n const focusOffset = focus.offset;\n const anchorOffset = anchor.offset;\n const isBefore = anchor.isBefore(focus);\n const startOffset = isBefore ? anchorOffset : focusOffset;\n const endOffset = isBefore ? focusOffset : anchorOffset;\n\n // No actual text is selected, so do nothing.\n if (startOffset === endOffset) {\n return;\n }\n\n // Only one node is selected.\n if (selectedTextNodesLength === 1) {\n // The entire node is selected.\n if (startOffset === 0 && endOffset === firstNodeTextLength) {\n const fontColorNode = applyColorToNode(firstNode, color);\n fontColorNode.select(startOffset, endOffset);\n return;\n }\n\n // The node is partially selected, so split it into two nodes and style the selected part.\n const splitNodes = firstNode.splitText(startOffset, endOffset);\n const replacement = startOffset === 0 ? splitNodes[0] : splitNodes[1];\n const fontColorNode = applyColorToNode(replacement, color);\n fontColorNode.select(0, endOffset - startOffset);\n\n return;\n }\n\n // Several nodes are selected.\n textNodes.forEach(textNode => {\n // First node is partially selected.\n if (textNode === firstNode && startOffset > 0) {\n const [, toColor] = textNode.splitText(startOffset);\n applyColorToNode(toColor, color);\n\n return;\n }\n\n // Last node is partially selected.\n if (textNode === lastNode && lastNode.getTextContent().length !== endOffset) {\n const [toColor] = textNode.splitText(endOffset);\n applyColorToNode(toColor, color);\n return;\n }\n\n // Colorize the whole node.\n applyColorToNode(textNode, color);\n });\n}\n"],"mappings":"AACA,SAASA,QAAQ,QAAQ,SAAS;AAElC,SAASC,gBAAgB;AAEzB,OAAO,SAASC,qBAAqBA,CAACC,SAAyB,EAAEC,KAAsB,EAAE;EACrF;EACA,MAAMC,SAAS,GAAGF,SAAS,CAACG,QAAQ,CAAC,CAAC,CAACC,MAAM,CAACC,IAAI,IAAIA,IAAI,YAAYR,QAAQ,CAAe;EAE7F,MAAMS,uBAAuB,GAAGJ,SAAS,CAACK,MAAM;EAChD,MAAMC,cAAc,GAAGR,SAAS,CAACS,iBAAiB,CAAC,CAAC;EAEpD,IAAID,cAAc,KAAK,IAAI,EAAE;IACzB;EACJ;EAEA,MAAM,CAACE,MAAM,EAAEC,KAAK,CAAC,GAAGH,cAAc;EAEtC,MAAMI,SAAS,GAAGN,uBAAuB,GAAG,CAAC;EAC7C,MAAMO,SAAS,GAAGX,SAAS,CAAC,CAAC,CAAC;EAC9B,MAAMY,QAAQ,GAAGZ,SAAS,CAACU,SAAS,CAAC;EACrC,MAAMG,aAAa,GAAGF,SAAS,CAACG,cAAc,CAAC,CAAC;EAChD,MAAMC,mBAAmB,GAAGF,aAAa,CAACR,MAAM;EAChD,MAAMW,WAAW,GAAGP,KAAK,CAACQ,MAAM;EAChC,MAAMC,YAAY,GAAGV,MAAM,CAACS,MAAM;EAClC,MAAME,QAAQ,GAAGX,MAAM,CAACW,QAAQ,CAACV,KAAK,CAAC;EACvC,MAAMW,WAAW,GAAGD,QAAQ,GAAGD,YAAY,GAAGF,WAAW;EACzD,MAAMK,SAAS,GAAGF,QAAQ,GAAGH,WAAW,GAAGE,YAAY;;EAEvD;EACA,IAAIE,WAAW,KAAKC,SAAS,EAAE;IAC3B;EACJ;;EAEA;EACA,IAAIjB,uBAAuB,KAAK,CAAC,EAAE;IAC/B;IACA,IAAIgB,WAAW,KAAK,CAAC,IAAIC,SAAS,KAAKN,mBAAmB,EAAE;MACxD,MAAMO,aAAa,GAAG1B,gBAAgB,CAACe,SAAS,EAAEZ,KAAK,CAAC;MACxDuB,aAAa,CAACC,MAAM,CAACH,WAAW,EAAEC,SAAS,CAAC;MAC5C;IACJ;;IAEA;IACA,MAAMG,UAAU,GAAGb,SAAS,CAACc,SAAS,CAACL,WAAW,EAAEC,SAAS,CAAC;IAC9D,MAAMK,WAAW,GAAGN,WAAW,KAAK,CAAC,GAAGI,UAAU,CAAC,CAAC,CAAC,GAAGA,UAAU,CAAC,CAAC,CAAC;IACrE,MAAMF,aAAa,GAAG1B,gBAAgB,CAAC8B,WAAW,EAAE3B,KAAK,CAAC;IAC1DuB,aAAa,CAACC,MAAM,CAAC,CAAC,EAAEF,SAAS,GAAGD,WAAW,CAAC;IAEhD;EACJ;;EAEA;EACApB,SAAS,CAAC2B,OAAO,CAACC,QAAQ,IAAI;IAC1B;IACA,IAAIA,QAAQ,KAAKjB,SAAS,IAAIS,WAAW,GAAG,CAAC,EAAE;MAC3C,MAAM,GAAGS,OAAO,CAAC,GAAGD,QAAQ,CAACH,SAAS,CAACL,WAAW,CAAC;MACnDxB,gBAAgB,CAACiC,OAAO,EAAE9B,KAAK,CAAC;MAEhC;IACJ;;IAEA;IACA,IAAI6B,QAAQ,KAAKhB,QAAQ,IAAIA,QAAQ,CAACE,cAAc,CAAC,CAAC,CAACT,MAAM,KAAKgB,SAAS,EAAE;MACzE,MAAM,CAACQ,OAAO,CAAC,GAAGD,QAAQ,CAACH,SAAS,CAACJ,SAAS,CAAC;MAC/CzB,gBAAgB,CAACiC,OAAO,EAAE9B,KAAK,CAAC;MAChC;IACJ;;IAEA;IACAH,gBAAgB,CAACgC,QAAQ,EAAE7B,KAAK,CAAC;EACrC,CAAC,CAAC;AACN","ignoreList":[]}
1
+ {"version":3,"names":["TextNode","applyColorToNode","applyColorToSelection","selection","color","textNodes","getNodes","filter","node","selectedTextNodesLength","length","startEndPoints","getStartEndPoints","anchor","focus","lastIndex","firstNode","lastNode","firstNodeText","getTextContent","firstNodeTextLength","focusOffset","offset","anchorOffset","isBefore","startOffset","endOffset","fontColorNode","select","splitNodes","splitText","replacement","forEach","textNode","toColor"],"sources":["applyColorToSelection.ts"],"sourcesContent":["import type { RangeSelection } from \"lexical\";\nimport { TextNode } from \"lexical\";\nimport type { ThemeColorValue } from \"@webiny/lexical-nodes\";\nimport { applyColorToNode } from \"~/plugins/FontColorPlugin/applyColorToNode.js\";\n\nexport function applyColorToSelection(selection: RangeSelection, color: ThemeColorValue) {\n // Basic variables\n const textNodes = selection.getNodes().filter(node => node instanceof TextNode) as TextNode[];\n\n const selectedTextNodesLength = textNodes.length;\n const startEndPoints = selection.getStartEndPoints();\n\n if (startEndPoints === null) {\n return;\n }\n\n const [anchor, focus] = startEndPoints;\n\n const lastIndex = selectedTextNodesLength - 1;\n const firstNode = textNodes[0];\n const lastNode = textNodes[lastIndex];\n const firstNodeText = firstNode.getTextContent();\n const firstNodeTextLength = firstNodeText.length;\n const focusOffset = focus.offset;\n const anchorOffset = anchor.offset;\n const isBefore = anchor.isBefore(focus);\n const startOffset = isBefore ? anchorOffset : focusOffset;\n const endOffset = isBefore ? focusOffset : anchorOffset;\n\n // No actual text is selected, so do nothing.\n if (startOffset === endOffset) {\n return;\n }\n\n // Only one node is selected.\n if (selectedTextNodesLength === 1) {\n // The entire node is selected.\n if (startOffset === 0 && endOffset === firstNodeTextLength) {\n const fontColorNode = applyColorToNode(firstNode, color);\n fontColorNode.select(startOffset, endOffset);\n return;\n }\n\n // The node is partially selected, so split it into two nodes and style the selected part.\n const splitNodes = firstNode.splitText(startOffset, endOffset);\n const replacement = startOffset === 0 ? splitNodes[0] : splitNodes[1];\n const fontColorNode = applyColorToNode(replacement, color);\n fontColorNode.select(0, endOffset - startOffset);\n\n return;\n }\n\n // Several nodes are selected.\n textNodes.forEach(textNode => {\n // First node is partially selected.\n if (textNode === firstNode && startOffset > 0) {\n const [, toColor] = textNode.splitText(startOffset);\n applyColorToNode(toColor, color);\n\n return;\n }\n\n // Last node is partially selected.\n if (textNode === lastNode && lastNode.getTextContent().length !== endOffset) {\n const [toColor] = textNode.splitText(endOffset);\n applyColorToNode(toColor, color);\n return;\n }\n\n // Colorize the whole node.\n applyColorToNode(textNode, color);\n });\n}\n"],"mappings":"AACA,SAASA,QAAQ,QAAQ,SAAS;AAElC,SAASC,gBAAgB;AAEzB,OAAO,SAASC,qBAAqBA,CAACC,SAAyB,EAAEC,KAAsB,EAAE;EACrF;EACA,MAAMC,SAAS,GAAGF,SAAS,CAACG,QAAQ,CAAC,CAAC,CAACC,MAAM,CAACC,IAAI,IAAIA,IAAI,YAAYR,QAAQ,CAAe;EAE7F,MAAMS,uBAAuB,GAAGJ,SAAS,CAACK,MAAM;EAChD,MAAMC,cAAc,GAAGR,SAAS,CAACS,iBAAiB,CAAC,CAAC;EAEpD,IAAID,cAAc,KAAK,IAAI,EAAE;IACzB;EACJ;EAEA,MAAM,CAACE,MAAM,EAAEC,KAAK,CAAC,GAAGH,cAAc;EAEtC,MAAMI,SAAS,GAAGN,uBAAuB,GAAG,CAAC;EAC7C,MAAMO,SAAS,GAAGX,SAAS,CAAC,CAAC,CAAC;EAC9B,MAAMY,QAAQ,GAAGZ,SAAS,CAACU,SAAS,CAAC;EACrC,MAAMG,aAAa,GAAGF,SAAS,CAACG,cAAc,CAAC,CAAC;EAChD,MAAMC,mBAAmB,GAAGF,aAAa,CAACR,MAAM;EAChD,MAAMW,WAAW,GAAGP,KAAK,CAACQ,MAAM;EAChC,MAAMC,YAAY,GAAGV,MAAM,CAACS,MAAM;EAClC,MAAME,QAAQ,GAAGX,MAAM,CAACW,QAAQ,CAACV,KAAK,CAAC;EACvC,MAAMW,WAAW,GAAGD,QAAQ,GAAGD,YAAY,GAAGF,WAAW;EACzD,MAAMK,SAAS,GAAGF,QAAQ,GAAGH,WAAW,GAAGE,YAAY;;EAEvD;EACA,IAAIE,WAAW,KAAKC,SAAS,EAAE;IAC3B;EACJ;;EAEA;EACA,IAAIjB,uBAAuB,KAAK,CAAC,EAAE;IAC/B;IACA,IAAIgB,WAAW,KAAK,CAAC,IAAIC,SAAS,KAAKN,mBAAmB,EAAE;MACxD,MAAMO,aAAa,GAAG1B,gBAAgB,CAACe,SAAS,EAAEZ,KAAK,CAAC;MACxDuB,aAAa,CAACC,MAAM,CAACH,WAAW,EAAEC,SAAS,CAAC;MAC5C;IACJ;;IAEA;IACA,MAAMG,UAAU,GAAGb,SAAS,CAACc,SAAS,CAACL,WAAW,EAAEC,SAAS,CAAC;IAC9D,MAAMK,WAAW,GAAGN,WAAW,KAAK,CAAC,GAAGI,UAAU,CAAC,CAAC,CAAC,GAAGA,UAAU,CAAC,CAAC,CAAC;IACrE,MAAMF,aAAa,GAAG1B,gBAAgB,CAAC8B,WAAW,EAAE3B,KAAK,CAAC;IAC1DuB,aAAa,CAACC,MAAM,CAAC,CAAC,EAAEF,SAAS,GAAGD,WAAW,CAAC;IAEhD;EACJ;;EAEA;EACApB,SAAS,CAAC2B,OAAO,CAACC,QAAQ,IAAI;IAC1B;IACA,IAAIA,QAAQ,KAAKjB,SAAS,IAAIS,WAAW,GAAG,CAAC,EAAE;MAC3C,MAAM,GAAGS,OAAO,CAAC,GAAGD,QAAQ,CAACH,SAAS,CAACL,WAAW,CAAC;MACnDxB,gBAAgB,CAACiC,OAAO,EAAE9B,KAAK,CAAC;MAEhC;IACJ;;IAEA;IACA,IAAI6B,QAAQ,KAAKhB,QAAQ,IAAIA,QAAQ,CAACE,cAAc,CAAC,CAAC,CAACT,MAAM,KAAKgB,SAAS,EAAE;MACzE,MAAM,CAACQ,OAAO,CAAC,GAAGD,QAAQ,CAACH,SAAS,CAACJ,SAAS,CAAC;MAC/CzB,gBAAgB,CAACiC,OAAO,EAAE9B,KAAK,CAAC;MAChC;IACJ;;IAEA;IACAH,gBAAgB,CAACgC,QAAQ,EAAE7B,KAAK,CAAC;EACrC,CAAC,CAAC;AACN","ignoreList":[]}
@@ -1,5 +1,4 @@
1
- /// <reference types="react" />
2
- import type { ImagePayload } from "../../commands";
1
+ import type { ImagePayload } from "../../commands/index.js";
3
2
  export type InsertImagePayload = Readonly<ImagePayload>;
4
3
  export declare function ImagesPlugin({ captionsEnabled }: {
5
4
  captionsEnabled?: boolean;
@@ -8,13 +8,12 @@
8
8
  *
9
9
  */
10
10
  import { useEffect } from "react";
11
- import { mergeRegister } from "@lexical/utils";
12
- import { $createRangeSelection, $getSelection, $isNodeSelection, $setSelection, COMMAND_PRIORITY_EDITOR, COMMAND_PRIORITY_HIGH, COMMAND_PRIORITY_LOW, DRAGOVER_COMMAND, DRAGSTART_COMMAND, DROP_COMMAND } from "lexical";
11
+ import { $createRangeSelection, $getSelection, $isNodeSelection, $setSelection, mergeRegister, COMMAND_PRIORITY_EDITOR, COMMAND_PRIORITY_HIGH, COMMAND_PRIORITY_LOW, DRAGOVER_COMMAND, DRAGSTART_COMMAND, DROP_COMMAND } from "lexical";
13
12
  import { $isImageNode, ImageNode } from "@webiny/lexical-nodes";
14
- import { INSERT_IMAGE_COMMAND } from "../../commands";
15
- import { CAN_USE_DOM } from "../../utils/canUseDOM";
16
- import { insertImage } from "../../utils/insertImage";
17
- import { useRichTextEditor } from "../../hooks";
13
+ import { INSERT_IMAGE_COMMAND } from "../../commands/index.js";
14
+ import { CAN_USE_DOM } from "../../utils/canUseDOM.js";
15
+ import { insertImage } from "../../utils/insertImage.js";
16
+ import { useRichTextEditor } from "../../hooks/index.js";
18
17
  const getDOMSelection = targetWindow => CAN_USE_DOM ? (targetWindow || window).getSelection() : null;
19
18
  export function ImagesPlugin({
20
19
  captionsEnabled
@@ -61,11 +60,9 @@ function onDragStart(event) {
61
60
  data: {
62
61
  id: node.__id,
63
62
  altText: node.__altText,
64
- caption: node.__caption,
65
63
  height: node.__height,
66
64
  key: node.getKey(),
67
65
  maxWidth: node.__maxWidth,
68
- showCaption: node.__showCaption,
69
66
  src: node.__src,
70
67
  width: node.__width
71
68
  },