@webiny/lexical-editor 0.0.0-unstable.06b2ede40f

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 (308) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +17 -0
  3. package/commands/image.d.ts +6 -0
  4. package/commands/image.js +4 -0
  5. package/commands/image.js.map +1 -0
  6. package/commands/index.d.ts +5 -0
  7. package/commands/index.js +7 -0
  8. package/commands/index.js.map +1 -0
  9. package/commands/list.d.ts +7 -0
  10. package/commands/list.js +6 -0
  11. package/commands/list.js.map +1 -0
  12. package/commands/quote.d.ts +5 -0
  13. package/commands/quote.js +4 -0
  14. package/commands/quote.js.map +1 -0
  15. package/commands/toolbar.d.ts +1 -0
  16. package/commands/toolbar.js +4 -0
  17. package/commands/toolbar.js.map +1 -0
  18. package/commands/typography.d.ts +8 -0
  19. package/commands/typography.js +4 -0
  20. package/commands/typography.js.map +1 -0
  21. package/components/Editor/EnsureHeadingTagPlugin.d.ts +6 -0
  22. package/components/Editor/EnsureHeadingTagPlugin.js +20 -0
  23. package/components/Editor/EnsureHeadingTagPlugin.js.map +1 -0
  24. package/components/Editor/HeadingEditor.d.ts +7 -0
  25. package/components/Editor/HeadingEditor.js +22 -0
  26. package/components/Editor/HeadingEditor.js.map +1 -0
  27. package/components/Editor/ParagraphEditor.d.ts +7 -0
  28. package/components/Editor/ParagraphEditor.js +22 -0
  29. package/components/Editor/ParagraphEditor.js.map +1 -0
  30. package/components/Editor/RichTextEditor.d.ts +49 -0
  31. package/components/Editor/RichTextEditor.js +133 -0
  32. package/components/Editor/RichTextEditor.js.map +1 -0
  33. package/components/Editor/normalizeInputValue.d.ts +6 -0
  34. package/components/Editor/normalizeInputValue.js +16 -0
  35. package/components/Editor/normalizeInputValue.js.map +1 -0
  36. package/components/LexicalEditorConfig/LexicalEditorConfig.d.ts +20 -0
  37. package/components/LexicalEditorConfig/LexicalEditorConfig.js +63 -0
  38. package/components/LexicalEditorConfig/LexicalEditorConfig.js.map +1 -0
  39. package/components/LexicalEditorConfig/components/Node.d.ts +14 -0
  40. package/components/LexicalEditorConfig/components/Node.js +30 -0
  41. package/components/LexicalEditorConfig/components/Node.js.map +1 -0
  42. package/components/LexicalEditorConfig/components/Plugin.d.ts +13 -0
  43. package/components/LexicalEditorConfig/components/Plugin.js +30 -0
  44. package/components/LexicalEditorConfig/components/Plugin.js.map +1 -0
  45. package/components/LexicalEditorConfig/components/ToolbarElement.d.ts +13 -0
  46. package/components/LexicalEditorConfig/components/ToolbarElement.js +30 -0
  47. package/components/LexicalEditorConfig/components/ToolbarElement.js.map +1 -0
  48. package/components/LexicalHtmlRenderer.d.ts +14 -0
  49. package/components/LexicalHtmlRenderer.js +55 -0
  50. package/components/LexicalHtmlRenderer.js.map +1 -0
  51. package/components/Toolbar/StaticToolbar.css +260 -0
  52. package/components/Toolbar/StaticToolbar.d.ts +5 -0
  53. package/components/Toolbar/StaticToolbar.js +22 -0
  54. package/components/Toolbar/StaticToolbar.js.map +1 -0
  55. package/components/Toolbar/Toolbar.css +643 -0
  56. package/components/Toolbar/Toolbar.d.ts +6 -0
  57. package/components/Toolbar/Toolbar.js +148 -0
  58. package/components/Toolbar/Toolbar.js.map +1 -0
  59. package/components/ToolbarActions/BoldAction.d.ts +2 -0
  60. package/components/ToolbarActions/BoldAction.js +25 -0
  61. package/components/ToolbarActions/BoldAction.js.map +1 -0
  62. package/components/ToolbarActions/BulletListAction.d.ts +2 -0
  63. package/components/ToolbarActions/BulletListAction.js +40 -0
  64. package/components/ToolbarActions/BulletListAction.js.map +1 -0
  65. package/components/ToolbarActions/CodeHighlightAction.d.ts +2 -0
  66. package/components/ToolbarActions/CodeHighlightAction.js +25 -0
  67. package/components/ToolbarActions/CodeHighlightAction.js.map +1 -0
  68. package/components/ToolbarActions/FontColorAction.d.ts +29 -0
  69. package/components/ToolbarActions/FontColorAction.js +50 -0
  70. package/components/ToolbarActions/FontColorAction.js.map +1 -0
  71. package/components/ToolbarActions/FontSizeAction.d.ts +14 -0
  72. package/components/ToolbarActions/FontSizeAction.js +91 -0
  73. package/components/ToolbarActions/FontSizeAction.js.map +1 -0
  74. package/components/ToolbarActions/ImageAction.d.ts +2 -0
  75. package/components/ToolbarActions/ImageAction.js +37 -0
  76. package/components/ToolbarActions/ImageAction.js.map +1 -0
  77. package/components/ToolbarActions/ItalicAction.d.ts +2 -0
  78. package/components/ToolbarActions/ItalicAction.js +25 -0
  79. package/components/ToolbarActions/ItalicAction.js.map +1 -0
  80. package/components/ToolbarActions/LinkAction.d.ts +2 -0
  81. package/components/ToolbarActions/LinkAction.js +37 -0
  82. package/components/ToolbarActions/LinkAction.js.map +1 -0
  83. package/components/ToolbarActions/NumberedListAction.d.ts +2 -0
  84. package/components/ToolbarActions/NumberedListAction.js +48 -0
  85. package/components/ToolbarActions/NumberedListAction.js.map +1 -0
  86. package/components/ToolbarActions/QuoteAction.d.ts +2 -0
  87. package/components/ToolbarActions/QuoteAction.js +33 -0
  88. package/components/ToolbarActions/QuoteAction.js.map +1 -0
  89. package/components/ToolbarActions/TextAlignmentAction.d.ts +29 -0
  90. package/components/ToolbarActions/TextAlignmentAction.js +61 -0
  91. package/components/ToolbarActions/TextAlignmentAction.js.map +1 -0
  92. package/components/ToolbarActions/TypographyAction.d.ts +29 -0
  93. package/components/ToolbarActions/TypographyAction.js +108 -0
  94. package/components/ToolbarActions/TypographyAction.js.map +1 -0
  95. package/components/ToolbarActions/UnderlineAction.d.ts +2 -0
  96. package/components/ToolbarActions/UnderlineAction.js +24 -0
  97. package/components/ToolbarActions/UnderlineAction.js.map +1 -0
  98. package/context/FontColorActionContext.d.ts +6 -0
  99. package/context/FontColorActionContext.js +4 -0
  100. package/context/FontColorActionContext.js.map +1 -0
  101. package/context/RichTextEditorContext.d.ts +19 -0
  102. package/context/RichTextEditorContext.js +21 -0
  103. package/context/RichTextEditorContext.js.map +1 -0
  104. package/context/SharedHistoryContext.d.ts +10 -0
  105. package/context/SharedHistoryContext.js +19 -0
  106. package/context/SharedHistoryContext.js.map +1 -0
  107. package/context/TextAlignmentActionContextProps.d.ts +9 -0
  108. package/context/TextAlignmentActionContextProps.js +4 -0
  109. package/context/TextAlignmentActionContextProps.js.map +1 -0
  110. package/context/TypographyActionContext.d.ts +8 -0
  111. package/context/TypographyActionContext.js +4 -0
  112. package/context/TypographyActionContext.js.map +1 -0
  113. package/hooks/index.d.ts +8 -0
  114. package/hooks/index.js +10 -0
  115. package/hooks/index.js.map +1 -0
  116. package/hooks/useCurrentElement.d.ts +7 -0
  117. package/hooks/useCurrentElement.js +27 -0
  118. package/hooks/useCurrentElement.js.map +1 -0
  119. package/hooks/useCurrentSelection.d.ts +13 -0
  120. package/hooks/useCurrentSelection.js +57 -0
  121. package/hooks/useCurrentSelection.js.map +1 -0
  122. package/hooks/useFontColorPicker.d.ts +2 -0
  123. package/hooks/useFontColorPicker.js +11 -0
  124. package/hooks/useFontColorPicker.js.map +1 -0
  125. package/hooks/useIsMounted.d.ts +1 -0
  126. package/hooks/useIsMounted.js +12 -0
  127. package/hooks/useIsMounted.js.map +1 -0
  128. package/hooks/useList.d.ts +2 -0
  129. package/hooks/useList.js +50 -0
  130. package/hooks/useList.js.map +1 -0
  131. package/hooks/useQuote.d.ts +2 -0
  132. package/hooks/useQuote.js +17 -0
  133. package/hooks/useQuote.js.map +1 -0
  134. package/hooks/useRichTextEditor.d.ts +2 -0
  135. package/hooks/useRichTextEditor.js +11 -0
  136. package/hooks/useRichTextEditor.js.map +1 -0
  137. package/hooks/useTextAlignmentAction.d.ts +1 -0
  138. package/hooks/useTextAlignmentAction.js +11 -0
  139. package/hooks/useTextAlignmentAction.js.map +1 -0
  140. package/hooks/useTypographyAction.d.ts +1 -0
  141. package/hooks/useTypographyAction.js +11 -0
  142. package/hooks/useTypographyAction.js.map +1 -0
  143. package/images/icons/LICENSE.md +5 -0
  144. package/images/icons/chat-square-quote.svg +1 -0
  145. package/images/icons/chevron-down.svg +1 -0
  146. package/images/icons/code.svg +1 -0
  147. package/images/icons/font-color.svg +1 -0
  148. package/images/icons/indent.svg +3 -0
  149. package/images/icons/insert-image.svg +4 -0
  150. package/images/icons/justify.svg +3 -0
  151. package/images/icons/link.svg +1 -0
  152. package/images/icons/list-ol.svg +1 -0
  153. package/images/icons/list-ul.svg +1 -0
  154. package/images/icons/outdent.svg +3 -0
  155. package/images/icons/pencil-fill.svg +1 -0
  156. package/images/icons/text-center.svg +1 -0
  157. package/images/icons/text-left.svg +1 -0
  158. package/images/icons/text-paragraph.svg +1 -0
  159. package/images/icons/text-right.svg +1 -0
  160. package/images/icons/type-bold.svg +1 -0
  161. package/images/icons/type-h1.svg +1 -0
  162. package/images/icons/type-h2.svg +1 -0
  163. package/images/icons/type-h3.svg +1 -0
  164. package/images/icons/type-h4.svg +1 -0
  165. package/images/icons/type-h5.svg +1 -0
  166. package/images/icons/type-h6.svg +1 -0
  167. package/images/icons/type-italic.svg +1 -0
  168. package/images/icons/type-strikethrough.svg +1 -0
  169. package/images/icons/type-underline.svg +1 -0
  170. package/images/icons/unlink_icon.svg +1 -0
  171. package/index.d.ts +37 -0
  172. package/index.js +50 -0
  173. package/index.js.map +1 -0
  174. package/package.json +40 -0
  175. package/plugins/BlurEventPlugin/BlurEventPlugin.d.ts +7 -0
  176. package/plugins/BlurEventPlugin/BlurEventPlugin.js +20 -0
  177. package/plugins/BlurEventPlugin/BlurEventPlugin.js.map +1 -0
  178. package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.d.ts +1 -0
  179. package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js +14 -0
  180. package/plugins/CodeHighlightPlugin/CodeHighlightPlugin.js.map +1 -0
  181. package/plugins/CodeHighlightPlugin/index.d.ts +1 -0
  182. package/plugins/CodeHighlightPlugin/index.js +3 -0
  183. package/plugins/CodeHighlightPlugin/index.js.map +1 -0
  184. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.d.ts +16 -0
  185. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js +158 -0
  186. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditor.js.map +1 -0
  187. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.d.ts +8 -0
  188. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js +62 -0
  189. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorController.js.map +1 -0
  190. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.css +176 -0
  191. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.d.ts +7 -0
  192. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js +14 -0
  193. package/plugins/FloatingLinkEditorPlugin/FloatingLinkEditorPlugin.js.map +1 -0
  194. package/plugins/FloatingLinkEditorPlugin/LinkEditForm.d.ts +8 -0
  195. package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js +104 -0
  196. package/plugins/FloatingLinkEditorPlugin/LinkEditForm.js.map +1 -0
  197. package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.d.ts +9 -0
  198. package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js +34 -0
  199. package/plugins/FloatingLinkEditorPlugin/LinkPreviewForm.js.map +1 -0
  200. package/plugins/FloatingLinkEditorPlugin/index.d.ts +1 -0
  201. package/plugins/FloatingLinkEditorPlugin/index.js +3 -0
  202. package/plugins/FloatingLinkEditorPlugin/index.js.map +1 -0
  203. package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.d.ts +1 -0
  204. package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js +12 -0
  205. package/plugins/FloatingLinkEditorPlugin/isChildOfLinkEditor.js.map +1 -0
  206. package/plugins/FontColorPlugin/FontColorPlugin.d.ts +1 -0
  207. package/plugins/FontColorPlugin/FontColorPlugin.js +27 -0
  208. package/plugins/FontColorPlugin/FontColorPlugin.js.map +1 -0
  209. package/plugins/FontColorPlugin/applyColorToNode.d.ts +3 -0
  210. package/plugins/FontColorPlugin/applyColorToNode.js +8 -0
  211. package/plugins/FontColorPlugin/applyColorToNode.js.map +1 -0
  212. package/plugins/FontColorPlugin/applyColorToSelection.d.ts +3 -0
  213. package/plugins/FontColorPlugin/applyColorToSelection.js +66 -0
  214. package/plugins/FontColorPlugin/applyColorToSelection.js.map +1 -0
  215. package/plugins/ImagesPlugin/ImagesPlugin.d.ts +12 -0
  216. package/plugins/ImagesPlugin/ImagesPlugin.js +151 -0
  217. package/plugins/ImagesPlugin/ImagesPlugin.js.map +1 -0
  218. package/plugins/LinkPlugin/LinkPlugin.d.ts +5 -0
  219. package/plugins/LinkPlugin/LinkPlugin.js +59 -0
  220. package/plugins/LinkPlugin/LinkPlugin.js.map +1 -0
  221. package/plugins/ListPLugin/ListPlugin.d.ts +1 -0
  222. package/plugins/ListPLugin/ListPlugin.js +17 -0
  223. package/plugins/ListPLugin/ListPlugin.js.map +1 -0
  224. package/plugins/QuoteNodePlugin/QuoteNodePlugin.d.ts +1 -0
  225. package/plugins/QuoteNodePlugin/QuoteNodePlugin.js +18 -0
  226. package/plugins/QuoteNodePlugin/QuoteNodePlugin.js.map +1 -0
  227. package/plugins/StateHandlingPlugin.d.ts +8 -0
  228. package/plugins/StateHandlingPlugin.js +75 -0
  229. package/plugins/StateHandlingPlugin.js.map +1 -0
  230. package/plugins/TypographyPlugin/TypographyPlugin.d.ts +1 -0
  231. package/plugins/TypographyPlugin/TypographyPlugin.js +27 -0
  232. package/plugins/TypographyPlugin/TypographyPlugin.js.map +1 -0
  233. package/types.d.ts +12 -0
  234. package/types.js +9 -0
  235. package/types.js.map +1 -0
  236. package/ui/ContentEditable.css +22 -0
  237. package/ui/ContentEditable.d.ts +12 -0
  238. package/ui/ContentEditable.js +19 -0
  239. package/ui/ContentEditable.js.map +1 -0
  240. package/ui/Divider.d.ts +2 -0
  241. package/ui/Divider.js +8 -0
  242. package/ui/Divider.js.map +1 -0
  243. package/ui/DropDown.d.ts +25 -0
  244. package/ui/DropDown.js +182 -0
  245. package/ui/DropDown.js.map +1 -0
  246. package/ui/ImageResizer.d.ts +24 -0
  247. package/ui/ImageResizer.js +211 -0
  248. package/ui/ImageResizer.js.map +1 -0
  249. package/ui/Input.css +32 -0
  250. package/ui/LinkPreview.css +69 -0
  251. package/ui/LinkPreview.d.ts +12 -0
  252. package/ui/LinkPreview.js +97 -0
  253. package/ui/LinkPreview.js.map +1 -0
  254. package/ui/Placeholder.css +20 -0
  255. package/ui/Placeholder.d.ts +15 -0
  256. package/ui/Placeholder.js +24 -0
  257. package/ui/Placeholder.js.map +1 -0
  258. package/ui/TextInput.d.ts +18 -0
  259. package/ui/TextInput.js +34 -0
  260. package/ui/TextInput.js.map +1 -0
  261. package/ui/ToolbarActionDialog.d.ts +11 -0
  262. package/ui/ToolbarActionDialog.js +77 -0
  263. package/ui/ToolbarActionDialog.js.map +1 -0
  264. package/utils/canUseDOM.d.ts +1 -0
  265. package/utils/canUseDOM.js +3 -0
  266. package/utils/canUseDOM.js.map +1 -0
  267. package/utils/files.d.ts +11 -0
  268. package/utils/files.js +21 -0
  269. package/utils/files.js.map +1 -0
  270. package/utils/getDOMRangeRect.d.ts +8 -0
  271. package/utils/getDOMRangeRect.js +23 -0
  272. package/utils/getDOMRangeRect.js.map +1 -0
  273. package/utils/getSelectedNode.d.ts +2 -0
  274. package/utils/getSelectedNode.js +25 -0
  275. package/utils/getSelectedNode.js.map +1 -0
  276. package/utils/getTransparentImage.d.ts +1 -0
  277. package/utils/getTransparentImage.js +5 -0
  278. package/utils/getTransparentImage.js.map +1 -0
  279. package/utils/insertImage.d.ts +2 -0
  280. package/utils/insertImage.js +16 -0
  281. package/utils/insertImage.js.map +1 -0
  282. package/utils/isAnchorLink.d.ts +1 -0
  283. package/utils/isAnchorLink.js +5 -0
  284. package/utils/isAnchorLink.js.map +1 -0
  285. package/utils/isChildOfFloatingToolbar.d.ts +1 -0
  286. package/utils/isChildOfFloatingToolbar.js +12 -0
  287. package/utils/isChildOfFloatingToolbar.js.map +1 -0
  288. package/utils/isHTMLElement.d.ts +8 -0
  289. package/utils/isHTMLElement.js +12 -0
  290. package/utils/isHTMLElement.js.map +1 -0
  291. package/utils/isValidJSON.d.ts +1 -0
  292. package/utils/isValidJSON.js +13 -0
  293. package/utils/isValidJSON.js.map +1 -0
  294. package/utils/isValidLexicalData.d.ts +4 -0
  295. package/utils/isValidLexicalData.js +24 -0
  296. package/utils/isValidLexicalData.js.map +1 -0
  297. package/utils/point.d.ts +21 -0
  298. package/utils/point.js +49 -0
  299. package/utils/point.js.map +1 -0
  300. package/utils/rect.d.ts +45 -0
  301. package/utils/rect.js +130 -0
  302. package/utils/rect.js.map +1 -0
  303. package/utils/sanitizeUrl.d.ts +1 -0
  304. package/utils/sanitizeUrl.js +25 -0
  305. package/utils/sanitizeUrl.js.map +1 -0
  306. package/utils/setFloatingElemPosition.d.ts +1 -0
  307. package/utils/setFloatingElemPosition.js +30 -0
  308. package/utils/setFloatingElemPosition.js.map +1 -0
package/package.json ADDED
@@ -0,0 +1,40 @@
1
+ {
2
+ "name": "@webiny/lexical-editor",
3
+ "version": "0.0.0-unstable.06b2ede40f",
4
+ "repository": {
5
+ "type": "git",
6
+ "url": "https://github.com/webiny/webiny-js.git"
7
+ },
8
+ "license": "MIT",
9
+ "dependencies": {
10
+ "@emotion/react": "11.10.8",
11
+ "@lexical/code": "0.23.1",
12
+ "@lexical/history": "0.23.1",
13
+ "@lexical/react": "0.23.1",
14
+ "@lexical/rich-text": "0.23.1",
15
+ "@lexical/selection": "0.23.1",
16
+ "@lexical/text": "0.23.1",
17
+ "@lexical/utils": "0.23.1",
18
+ "@webiny/lexical-nodes": "0.0.0-unstable.06b2ede40f",
19
+ "@webiny/lexical-theme": "0.0.0-unstable.06b2ede40f",
20
+ "@webiny/react-composition": "0.0.0-unstable.06b2ede40f",
21
+ "@webiny/react-properties": "0.0.0-unstable.06b2ede40f",
22
+ "emotion": "10.0.27",
23
+ "lexical": "0.23.1",
24
+ "lodash": "4.17.21",
25
+ "react": "18.2.0",
26
+ "react-dom": "18.2.0"
27
+ },
28
+ "devDependencies": {
29
+ "@webiny/project-utils": "0.0.0-unstable.06b2ede40f"
30
+ },
31
+ "publishConfig": {
32
+ "access": "public",
33
+ "directory": "dist"
34
+ },
35
+ "scripts": {
36
+ "build": "node ../cli/bin.js run build",
37
+ "watch": "node ../cli/bin.js run watch"
38
+ },
39
+ "gitHead": "06b2ede40fc2212a70eeafd74afd50b56fb0ce82"
40
+ }
@@ -0,0 +1,7 @@
1
+ import type { FC } from "react";
2
+ import type { LexicalValue } from "../../types";
3
+ interface BlurEventPlugin {
4
+ onBlur?: (editorState: LexicalValue) => void;
5
+ }
6
+ export declare const BlurEventPlugin: FC<BlurEventPlugin>;
7
+ export {};
@@ -0,0 +1,20 @@
1
+ import { useEffect } from "react";
2
+ import { BLUR_COMMAND, COMMAND_PRIORITY_LOW } from "lexical";
3
+ import { useRichTextEditor } from "../../hooks";
4
+ export const BlurEventPlugin = ({
5
+ onBlur
6
+ }) => {
7
+ const {
8
+ editor
9
+ } = useRichTextEditor();
10
+ useEffect(() => editor.registerCommand(BLUR_COMMAND, () => {
11
+ if (typeof onBlur === "function") {
12
+ const editorState = editor.getEditorState();
13
+ onBlur(JSON.stringify(editorState.toJSON()));
14
+ }
15
+ return false;
16
+ }, COMMAND_PRIORITY_LOW), []);
17
+ return null;
18
+ };
19
+
20
+ //# sourceMappingURL=BlurEventPlugin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useEffect","BLUR_COMMAND","COMMAND_PRIORITY_LOW","useRichTextEditor","BlurEventPlugin","onBlur","editor","registerCommand","editorState","getEditorState","JSON","stringify","toJSON"],"sources":["BlurEventPlugin.tsx"],"sourcesContent":["import type { FC } from \"react\";\nimport { useEffect } from \"react\";\nimport { BLUR_COMMAND, COMMAND_PRIORITY_LOW } from \"lexical\";\nimport type { LexicalValue } from \"~/types\";\nimport { useRichTextEditor } from \"~/hooks\";\n\ninterface BlurEventPlugin {\n onBlur?: (editorState: LexicalValue) => void;\n}\n\nexport const BlurEventPlugin: FC<BlurEventPlugin> = ({ onBlur }) => {\n const { editor } = useRichTextEditor();\n\n useEffect(\n () =>\n editor.registerCommand(\n BLUR_COMMAND,\n () => {\n if (typeof onBlur === \"function\") {\n const editorState = editor.getEditorState();\n onBlur(JSON.stringify(editorState.toJSON()));\n }\n return false;\n },\n COMMAND_PRIORITY_LOW\n ),\n []\n );\n return null;\n};\n"],"mappings":"AACA,SAASA,SAAS,QAAQ,OAAO;AACjC,SAASC,YAAY,EAAEC,oBAAoB,QAAQ,SAAS;AAE5D,SAASC,iBAAiB;AAM1B,OAAO,MAAMC,eAAoC,GAAGA,CAAC;EAAEC;AAAO,CAAC,KAAK;EAChE,MAAM;IAAEC;EAAO,CAAC,GAAGH,iBAAiB,CAAC,CAAC;EAEtCH,SAAS,CACL,MACIM,MAAM,CAACC,eAAe,CAClBN,YAAY,EACZ,MAAM;IACF,IAAI,OAAOI,MAAM,KAAK,UAAU,EAAE;MAC9B,MAAMG,WAAW,GAAGF,MAAM,CAACG,cAAc,CAAC,CAAC;MAC3CJ,MAAM,CAACK,IAAI,CAACC,SAAS,CAACH,WAAW,CAACI,MAAM,CAAC,CAAC,CAAC,CAAC;IAChD;IACA,OAAO,KAAK;EAChB,CAAC,EACDV,oBACJ,CAAC,EACL,EACJ,CAAC;EACD,OAAO,IAAI;AACf,CAAC","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export declare function CodeHighlightPlugin(): null;
@@ -0,0 +1,14 @@
1
+ import { useEffect } from "react";
2
+ import { registerCodeHighlighting } from "@lexical/code";
3
+ import { useRichTextEditor } from "../../hooks";
4
+ export function CodeHighlightPlugin() {
5
+ const {
6
+ editor
7
+ } = useRichTextEditor();
8
+ useEffect(() => {
9
+ return registerCodeHighlighting(editor);
10
+ }, [editor]);
11
+ return null;
12
+ }
13
+
14
+ //# sourceMappingURL=CodeHighlightPlugin.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["useEffect","registerCodeHighlighting","useRichTextEditor","CodeHighlightPlugin","editor"],"sources":["CodeHighlightPlugin.tsx"],"sourcesContent":["import { useEffect } from \"react\";\nimport { registerCodeHighlighting } from \"@lexical/code\";\nimport { useRichTextEditor } from \"~/hooks\";\n\nexport function CodeHighlightPlugin() {\n const { editor } = useRichTextEditor();\n useEffect(() => {\n return registerCodeHighlighting(editor);\n }, [editor]);\n return null;\n}\n"],"mappings":"AAAA,SAASA,SAAS,QAAQ,OAAO;AACjC,SAASC,wBAAwB,QAAQ,eAAe;AACxD,SAASC,iBAAiB;AAE1B,OAAO,SAASC,mBAAmBA,CAAA,EAAG;EAClC,MAAM;IAAEC;EAAO,CAAC,GAAGF,iBAAiB,CAAC,CAAC;EACtCF,SAAS,CAAC,MAAM;IACZ,OAAOC,wBAAwB,CAACG,MAAM,CAAC;EAC3C,CAAC,EAAE,CAACA,MAAM,CAAC,CAAC;EACZ,OAAO,IAAI;AACf","ignoreList":[]}
@@ -0,0 +1 @@
1
+ export * from "./CodeHighlightPlugin";
@@ -0,0 +1,3 @@
1
+ export * from "./CodeHighlightPlugin";
2
+
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./CodeHighlightPlugin\";\n"],"mappings":"AAAA","ignoreList":[]}
@@ -0,0 +1,16 @@
1
+ import React from "react";
2
+ import { LinkEditForm as DefaultLinkEditForm } from "./LinkEditForm";
3
+ import { type LexicalEditor } from "lexical";
4
+ export interface LinkData {
5
+ url: string;
6
+ target: string | null;
7
+ alt: string | null;
8
+ }
9
+ interface FloatingLinkEditorProps {
10
+ editor: LexicalEditor;
11
+ isVisible: boolean;
12
+ anchorElem: HTMLElement;
13
+ LinkEditForm?: typeof DefaultLinkEditForm;
14
+ }
15
+ export declare function FloatingLinkEditor({ editor, isVisible, anchorElem, LinkEditForm }: FloatingLinkEditorProps): React.JSX.Element;
16
+ export {};
@@ -0,0 +1,158 @@
1
+ import React, { useCallback, useEffect, useRef, useState } from "react";
2
+ import { getSelectedNode } from "../../utils/getSelectedNode";
3
+ import { $isLinkNode, TOGGLE_LINK_COMMAND } from "@webiny/lexical-nodes";
4
+ import { setFloatingElemPosition } from "../../utils/setFloatingElemPosition";
5
+ import { sanitizeUrl } from "../../utils/sanitizeUrl";
6
+ import { isChildOfLinkEditor } from "./isChildOfLinkEditor";
7
+ import { LinkEditForm as DefaultLinkEditForm } from "./LinkEditForm";
8
+ import { LinkPreviewForm } from "./LinkPreviewForm";
9
+ import { SELECTION_CHANGE_COMMAND, COMMAND_PRIORITY_LOW, BLUR_COMMAND, $getSelection, $isRangeSelection } from "lexical";
10
+ import { mergeRegister } from "@lexical/utils";
11
+ export function FloatingLinkEditor({
12
+ editor,
13
+ isVisible,
14
+ anchorElem,
15
+ LinkEditForm = DefaultLinkEditForm
16
+ }) {
17
+ const editorRef = useRef(null);
18
+ const [linkData, setLinkData] = useState({
19
+ url: "",
20
+ target: null,
21
+ alt: null
22
+ });
23
+ const [isEditMode, setEditMode] = useState(false);
24
+ const [lastSelection, setLastSelection] = useState(null);
25
+ const updateLinkEditor = useCallback(() => {
26
+ const selection = $getSelection();
27
+ const emptyLinkData = {
28
+ url: "",
29
+ target: null,
30
+ alt: null
31
+ };
32
+ if ($isRangeSelection(selection)) {
33
+ const node = getSelectedNode(selection);
34
+ const parent = node.getParent();
35
+ if ($isLinkNode(parent)) {
36
+ const linkData = {
37
+ url: parent.getURL(),
38
+ target: parent.getTarget(),
39
+ alt: $isLinkNode(parent) ? parent.getAlt() : null
40
+ };
41
+ setLinkData(linkData);
42
+ } else if ($isLinkNode(node)) {
43
+ const linkData = {
44
+ url: node.getURL(),
45
+ target: node.getTarget(),
46
+ alt: $isLinkNode(node) ? node.getAlt() : null
47
+ };
48
+ setLinkData(linkData);
49
+ } else {
50
+ setLinkData(emptyLinkData);
51
+ }
52
+ }
53
+ const editorElem = editorRef.current;
54
+ const nativeSelection = window.getSelection();
55
+ const activeElement = document.activeElement;
56
+ if (editorElem === null) {
57
+ return;
58
+ }
59
+ const rootElement = editor.getRootElement();
60
+ if (selection !== null && nativeSelection !== null && rootElement !== null && rootElement.contains(nativeSelection.anchorNode)) {
61
+ const domRange = nativeSelection.getRangeAt(0);
62
+ let rect;
63
+ if (nativeSelection.anchorNode === rootElement) {
64
+ let inner = rootElement;
65
+ while (inner.firstElementChild != null) {
66
+ inner = inner.firstElementChild;
67
+ }
68
+ rect = inner.getBoundingClientRect();
69
+ } else {
70
+ rect = domRange.getBoundingClientRect();
71
+ }
72
+ setFloatingElemPosition(rect, editorElem, anchorElem);
73
+ setLastSelection(selection);
74
+ } else if (!activeElement || activeElement.className !== "link-input") {
75
+ if (rootElement !== null) {
76
+ setFloatingElemPosition(null, editorElem, anchorElem);
77
+ }
78
+ setLastSelection(null);
79
+ setEditMode(false);
80
+ setLinkData(emptyLinkData);
81
+ }
82
+ return true;
83
+ }, [anchorElem, editor]);
84
+ const removeLink = () => {
85
+ editor.dispatchCommand(TOGGLE_LINK_COMMAND, null);
86
+ setEditMode(false);
87
+ };
88
+ const applyChanges = linkData => {
89
+ const confirmedLinkData = {
90
+ url: sanitizeUrl(linkData.url),
91
+ target: linkData.target,
92
+ alt: linkData.alt
93
+ };
94
+ if (lastSelection !== null) {
95
+ editor.dispatchCommand(TOGGLE_LINK_COMMAND, confirmedLinkData);
96
+ setEditMode(false);
97
+ }
98
+ };
99
+ useEffect(() => {
100
+ const scrollerElem = anchorElem.parentElement;
101
+ const update = () => {
102
+ editor.getEditorState().read(() => {
103
+ updateLinkEditor();
104
+ });
105
+ };
106
+ window.addEventListener("resize", update);
107
+ if (scrollerElem) {
108
+ scrollerElem.addEventListener("scroll", update);
109
+ }
110
+ return () => {
111
+ window.removeEventListener("resize", update);
112
+ if (scrollerElem) {
113
+ scrollerElem.removeEventListener("scroll", update);
114
+ }
115
+ };
116
+ }, [anchorElem.parentElement, editor, updateLinkEditor]);
117
+ useEffect(() => {
118
+ return mergeRegister(editor.registerUpdateListener(({
119
+ editorState
120
+ }) => {
121
+ editorState.read(() => {
122
+ updateLinkEditor();
123
+ });
124
+ }), editor.registerCommand(SELECTION_CHANGE_COMMAND, () => {
125
+ updateLinkEditor();
126
+ return false;
127
+ }, COMMAND_PRIORITY_LOW), editor.registerCommand(BLUR_COMMAND, payload => {
128
+ if (!isChildOfLinkEditor(payload.relatedTarget)) {
129
+ // setEditMode(false);
130
+ }
131
+ return false;
132
+ }, COMMAND_PRIORITY_LOW));
133
+ }, [editor, updateLinkEditor]);
134
+ useEffect(() => {
135
+ editor.getEditorState().read(() => {
136
+ updateLinkEditor();
137
+ });
138
+ }, [editor, updateLinkEditor]);
139
+ return /*#__PURE__*/React.createElement("div", {
140
+ ref: editorRef,
141
+ className: "link-editor",
142
+ style: {
143
+ display: isVisible ? "block" : "none"
144
+ }
145
+ }, isEditMode ? /*#__PURE__*/React.createElement(LinkEditForm, {
146
+ linkData: linkData,
147
+ onSave: applyChanges,
148
+ onCancel: () => setEditMode(false)
149
+ }) : /*#__PURE__*/React.createElement(LinkPreviewForm, {
150
+ linkData: linkData,
151
+ removeLink: removeLink,
152
+ onEdit: () => {
153
+ setEditMode(true);
154
+ }
155
+ }));
156
+ }
157
+
158
+ //# sourceMappingURL=FloatingLinkEditor.js.map
@@ -0,0 +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":[]}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import type { LinkEditForm } from "./LinkEditForm";
3
+ interface FloatingLinkEditorProps {
4
+ anchorElem: () => HTMLElement;
5
+ LinkEditForm?: typeof LinkEditForm;
6
+ }
7
+ export declare const FloatingLinkEditorController: (props: FloatingLinkEditorProps) => React.ReactPortal;
8
+ export {};
@@ -0,0 +1,62 @@
1
+ import React, { useCallback, useState, useEffect } from "react";
2
+ import { createPortal } from "react-dom";
3
+ import { useRichTextEditor } from "../../hooks";
4
+ import { getSelectedNode } from "../../utils/getSelectedNode";
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";
11
+ export const FloatingLinkEditorController = props => {
12
+ const {
13
+ editor
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
+ anchorElem: props.anchorElem(),
58
+ LinkEditForm: props.LinkEditForm
59
+ }), props.anchorElem());
60
+ };
61
+
62
+ //# 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","$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":[]}
@@ -0,0 +1,176 @@
1
+ .link-editor {
2
+ position: absolute;
3
+ top: 0;
4
+ left: 0;
5
+ z-index: 51;
6
+ max-width: 400px;
7
+ width: 100%;
8
+ opacity: 0;
9
+ background-color: #fff;
10
+ box-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
11
+ border-radius: 8px;
12
+ transition: opacity 0.5s;
13
+ will-change: transform;
14
+ padding: 10px 0;
15
+ pointer-events: all;
16
+ }
17
+
18
+ .link-editor .link-editor-target-checkbox {
19
+ padding: 10px 10px 5px 10px;
20
+ }
21
+
22
+ .link-editor .button {
23
+ width: 20px;
24
+ height: 20px;
25
+ display: inline-block;
26
+ padding: 6px;
27
+ border-radius: 8px;
28
+ cursor: pointer;
29
+ margin: 0 2px;
30
+ }
31
+
32
+ .link-editor .button.hovered {
33
+ width: 20px;
34
+ height: 20px;
35
+ display: inline-block;
36
+ background-color: #eee;
37
+ }
38
+
39
+ .link-editor .button.active,
40
+ .toolbar .button.active {
41
+ background-color: rgb(223, 232, 250);
42
+ }
43
+
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
+ .link-editor .button i,
170
+ .actions i {
171
+ background-size: contain;
172
+ display: inline-block;
173
+ height: 20px;
174
+ width: 20px;
175
+ vertical-align: -0.25em;
176
+ }
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import type { LinkEditForm } from "./LinkEditForm";
3
+ import "./FloatingLinkEditorPlugin.css";
4
+ export declare function FloatingLinkEditorPlugin({ anchorElem, ...props }: {
5
+ anchorElem?: () => HTMLElement;
6
+ LinkEditForm?: typeof LinkEditForm;
7
+ }): JSX.Element | null;
@@ -0,0 +1,14 @@
1
+ import React from "react";
2
+ import { FloatingLinkEditorController } from "./FloatingLinkEditorController";
3
+ import "./FloatingLinkEditorPlugin.css";
4
+ export function FloatingLinkEditorPlugin({
5
+ anchorElem = () => document.body,
6
+ ...props
7
+ }) {
8
+ return /*#__PURE__*/React.createElement(FloatingLinkEditorController, {
9
+ anchorElem: anchorElem,
10
+ LinkEditForm: props.LinkEditForm
11
+ });
12
+ }
13
+
14
+ //# sourceMappingURL=FloatingLinkEditorPlugin.js.map
@@ -0,0 +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":[]}
@@ -0,0 +1,8 @@
1
+ import React from "react";
2
+ import type { LinkData } from "./FloatingLinkEditor";
3
+ export interface LinkFormProps {
4
+ linkData: LinkData;
5
+ onSave: (linkData: LinkData) => void;
6
+ onCancel: () => void;
7
+ }
8
+ export declare const LinkEditForm: ({ linkData, onSave, onCancel }: LinkFormProps) => React.JSX.Element;