@datalayer/lexical-loro 0.0.7 → 0.1.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 (406) hide show
  1. package/README.md +24 -137
  2. package/lib/App.d.ts +2 -0
  3. package/lib/App.js +141 -0
  4. package/lib/Editor.d.ts +2 -0
  5. package/lib/Editor.js +111 -0
  6. package/lib/Settings.d.ts +2 -0
  7. package/lib/Settings.js +57 -0
  8. package/lib/appSettings.d.ts +36 -0
  9. package/lib/appSettings.js +44 -0
  10. package/lib/collab/loro/Bindings.d.ts +41 -0
  11. package/lib/collab/loro/Bindings.js +95 -0
  12. package/lib/collab/loro/Debug.d.ts +33 -0
  13. package/lib/collab/loro/Debug.js +448 -0
  14. package/lib/collab/loro/LexicalCollaborationContext.d.ts +19 -0
  15. package/lib/collab/loro/LexicalCollaborationContext.js +48 -0
  16. package/lib/collab/loro/LexicalCollaborationPlugin.d.ts +24 -0
  17. package/lib/collab/loro/LexicalCollaborationPlugin.js +83 -0
  18. package/lib/collab/loro/State.d.ts +53 -0
  19. package/lib/collab/loro/State.js +90 -0
  20. package/lib/collab/loro/components/LoroCollaborationUI.d.ts +13 -0
  21. package/lib/collab/loro/components/LoroCollaborationUI.js +9 -0
  22. package/lib/collab/loro/components/LoroCollaborators.d.ts +8 -0
  23. package/lib/collab/loro/components/LoroCollaborators.js +97 -0
  24. package/lib/collab/loro/components/index.d.ts +2 -0
  25. package/lib/collab/loro/components/index.js +2 -0
  26. package/lib/collab/loro/index.d.ts +6 -0
  27. package/lib/collab/loro/index.js +6 -0
  28. package/lib/collab/loro/integrators/BaseIntegrator.d.ts +14 -0
  29. package/lib/collab/loro/integrators/BaseIntegrator.js +1 -0
  30. package/lib/collab/loro/integrators/CounterIntegrator.d.ts +23 -0
  31. package/lib/collab/loro/integrators/CounterIntegrator.js +40 -0
  32. package/lib/collab/loro/integrators/ListIntegrator.d.ts +23 -0
  33. package/lib/collab/loro/integrators/ListIntegrator.js +49 -0
  34. package/lib/collab/loro/integrators/MapIntegrator.d.ts +24 -0
  35. package/lib/collab/loro/integrators/MapIntegrator.js +177 -0
  36. package/lib/collab/loro/integrators/TextIntegrator.d.ts +25 -0
  37. package/lib/collab/loro/integrators/TextIntegrator.js +51 -0
  38. package/lib/collab/loro/integrators/TreeIntegrator.d.ts +25 -0
  39. package/lib/collab/loro/integrators/TreeIntegrator.js +201 -0
  40. package/lib/collab/loro/nodes/NodeFactory.d.ts +8 -0
  41. package/lib/collab/loro/nodes/NodeFactory.js +105 -0
  42. package/lib/collab/loro/nodes/NodesMapper.d.ts +111 -0
  43. package/lib/collab/loro/nodes/NodesMapper.js +258 -0
  44. package/lib/collab/loro/propagators/DecoratorNodePropagator.d.ts +60 -0
  45. package/lib/collab/loro/propagators/DecoratorNodePropagator.js +302 -0
  46. package/lib/collab/loro/propagators/ElementNodePropagator.d.ts +62 -0
  47. package/lib/collab/loro/propagators/ElementNodePropagator.js +335 -0
  48. package/lib/collab/loro/propagators/LineBreakNodePropagator.d.ts +57 -0
  49. package/lib/collab/loro/propagators/LineBreakNodePropagator.js +196 -0
  50. package/lib/collab/loro/propagators/RootNodePropagator.d.ts +55 -0
  51. package/lib/collab/loro/propagators/RootNodePropagator.js +168 -0
  52. package/lib/collab/loro/propagators/TextNodePropagator.d.ts +60 -0
  53. package/lib/collab/loro/propagators/TextNodePropagator.js +434 -0
  54. package/lib/collab/loro/propagators/index.d.ts +49 -0
  55. package/lib/collab/loro/propagators/index.js +32 -0
  56. package/lib/collab/loro/provider/websocket.d.ts +116 -0
  57. package/lib/collab/loro/provider/websocket.js +907 -0
  58. package/lib/collab/loro/servers/index.d.ts +0 -0
  59. package/lib/collab/loro/servers/index.js +0 -0
  60. package/lib/collab/loro/servers/ws/callback.d.ts +5 -0
  61. package/lib/collab/loro/servers/ws/callback.js +85 -0
  62. package/lib/collab/loro/servers/ws/server.d.ts +2 -0
  63. package/lib/collab/loro/servers/ws/server.js +25 -0
  64. package/lib/collab/loro/servers/ws/utils.d.ts +40 -0
  65. package/lib/collab/loro/servers/ws/utils.js +513 -0
  66. package/lib/collab/loro/sync/SyncCursors.d.ts +32 -0
  67. package/lib/collab/loro/sync/SyncCursors.js +435 -0
  68. package/lib/collab/loro/sync/SyncLexicalToLoro.d.ts +4 -0
  69. package/lib/collab/loro/sync/SyncLexicalToLoro.js +80 -0
  70. package/lib/collab/loro/sync/SyncLoroToLexical.d.ts +5 -0
  71. package/lib/collab/loro/sync/SyncLoroToLexical.js +96 -0
  72. package/lib/collab/loro/types/LexicalNodeData.d.ts +32 -0
  73. package/lib/collab/loro/types/LexicalNodeData.js +71 -0
  74. package/lib/collab/loro/useCollaboration.d.ts +12 -0
  75. package/lib/collab/loro/useCollaboration.js +248 -0
  76. package/lib/collab/loro/utils/InitialContent.d.ts +64 -0
  77. package/lib/collab/loro/utils/InitialContent.js +109 -0
  78. package/lib/collab/loro/utils/LexicalToLoro.d.ts +18 -0
  79. package/lib/collab/loro/utils/LexicalToLoro.js +96 -0
  80. package/lib/collab/loro/utils/Utils.d.ts +44 -0
  81. package/lib/collab/loro/utils/Utils.js +153 -0
  82. package/lib/collab/loro/wsProvider.d.ts +8 -0
  83. package/lib/collab/loro/wsProvider.js +31 -0
  84. package/lib/collab/utils/invariant.d.ts +1 -0
  85. package/lib/collab/utils/invariant.js +11 -0
  86. package/lib/collab/utils/simpleDiffWithCursor.d.ts +5 -0
  87. package/lib/collab/utils/simpleDiffWithCursor.js +31 -0
  88. package/lib/collab/yjs/Bindings.d.ts +23 -0
  89. package/lib/collab/yjs/Bindings.js +26 -0
  90. package/lib/collab/yjs/Debug.d.ts +23 -0
  91. package/lib/collab/yjs/Debug.js +213 -0
  92. package/lib/collab/yjs/LexicalCollaborationContext.d.ts +10 -0
  93. package/lib/collab/yjs/LexicalCollaborationContext.js +37 -0
  94. package/lib/collab/yjs/LexicalCollaborationPlugin.d.ts +21 -0
  95. package/lib/collab/yjs/LexicalCollaborationPlugin.js +63 -0
  96. package/lib/collab/yjs/State.d.ts +51 -0
  97. package/lib/collab/yjs/State.js +35 -0
  98. package/lib/collab/yjs/nodes/AnyCollabNode.d.ts +5 -0
  99. package/lib/collab/yjs/nodes/AnyCollabNode.js +1 -0
  100. package/lib/collab/yjs/nodes/CollabDecoratorNode.d.ts +22 -0
  101. package/lib/collab/yjs/nodes/CollabDecoratorNode.js +64 -0
  102. package/lib/collab/yjs/nodes/CollabElementNode.d.ts +40 -0
  103. package/lib/collab/yjs/nodes/CollabElementNode.js +462 -0
  104. package/lib/collab/yjs/nodes/CollabLineBreakNode.d.ts +19 -0
  105. package/lib/collab/yjs/nodes/CollabLineBreakNode.js +44 -0
  106. package/lib/collab/yjs/nodes/CollabTextNode.d.ts +25 -0
  107. package/lib/collab/yjs/nodes/CollabTextNode.js +103 -0
  108. package/lib/collab/yjs/provider/websocket.d.ts +88 -0
  109. package/lib/collab/yjs/provider/websocket.js +415 -0
  110. package/lib/collab/yjs/servers/index.d.ts +0 -0
  111. package/lib/collab/yjs/servers/index.js +0 -0
  112. package/lib/collab/yjs/servers/ws/callback.d.ts +5 -0
  113. package/lib/collab/yjs/servers/ws/callback.js +72 -0
  114. package/lib/collab/yjs/servers/ws/server.d.ts +2 -0
  115. package/lib/collab/yjs/servers/ws/server.js +25 -0
  116. package/lib/collab/yjs/servers/ws/utils.d.ts +49 -0
  117. package/lib/collab/yjs/servers/ws/utils.js +284 -0
  118. package/lib/collab/yjs/sync/SyncCursors.d.ts +39 -0
  119. package/lib/collab/yjs/sync/SyncCursors.js +351 -0
  120. package/lib/collab/yjs/sync/SyncEditorStates.d.ts +10 -0
  121. package/lib/collab/yjs/sync/SyncEditorStates.js +200 -0
  122. package/lib/collab/yjs/useCollaboration.d.ts +12 -0
  123. package/lib/collab/yjs/useCollaboration.js +255 -0
  124. package/lib/collab/yjs/utils/Utils.d.ts +25 -0
  125. package/lib/collab/yjs/utils/Utils.js +402 -0
  126. package/lib/collab/yjs/wsProvider.d.ts +3 -0
  127. package/lib/collab/yjs/wsProvider.js +21 -0
  128. package/lib/commenting/index.d.ts +41 -0
  129. package/lib/commenting/index.js +324 -0
  130. package/lib/context/FlashMessageContext.d.ts +7 -0
  131. package/lib/context/FlashMessageContext.js +24 -0
  132. package/lib/context/SettingsContext.d.ts +12 -0
  133. package/lib/context/SettingsContext.js +38 -0
  134. package/lib/context/SharedHistoryContext.d.ts +11 -0
  135. package/lib/context/SharedHistoryContext.js +11 -0
  136. package/lib/context/ToolbarContext.d.ts +65 -0
  137. package/lib/context/ToolbarContext.js +84 -0
  138. package/lib/demo.d.ts +12 -0
  139. package/lib/demo.js +41 -0
  140. package/lib/hooks/useFlashMessage.d.ts +2 -0
  141. package/lib/hooks/useFlashMessage.js +4 -0
  142. package/lib/hooks/useModal.d.ts +5 -0
  143. package/lib/hooks/useModal.js +26 -0
  144. package/lib/hooks/useReport.d.ts +1 -0
  145. package/lib/hooks/useReport.js +46 -0
  146. package/lib/index.d.ts +1 -1
  147. package/lib/index.js +1 -5
  148. package/lib/nodes/AutocompleteNode.d.ts +27 -0
  149. package/lib/nodes/AutocompleteNode.js +56 -0
  150. package/lib/nodes/CounterComponent.d.ts +6 -0
  151. package/lib/nodes/CounterComponent.js +137 -0
  152. package/lib/nodes/CounterNode.d.ts +23 -0
  153. package/lib/nodes/CounterNode.js +47 -0
  154. package/lib/nodes/DateTimeNode/DateTimeComponent.d.ts +8 -0
  155. package/lib/nodes/DateTimeNode/DateTimeComponent.js +119 -0
  156. package/lib/nodes/DateTimeNode/DateTimeNode.d.ts +27 -0
  157. package/lib/nodes/DateTimeNode/DateTimeNode.js +82 -0
  158. package/lib/nodes/EmojiNode.d.ts +18 -0
  159. package/lib/nodes/EmojiNode.js +50 -0
  160. package/lib/nodes/EquationComponent.d.ts +9 -0
  161. package/lib/nodes/EquationComponent.js +75 -0
  162. package/lib/nodes/EquationNode.d.ts +26 -0
  163. package/lib/nodes/EquationNode.js +109 -0
  164. package/lib/nodes/ExcalidrawNode/ExcalidrawComponent.d.ts +8 -0
  165. package/lib/nodes/ExcalidrawNode/ExcalidrawComponent.js +110 -0
  166. package/lib/nodes/ExcalidrawNode/ExcalidrawImage.d.ts +50 -0
  167. package/lib/nodes/ExcalidrawNode/ExcalidrawImage.js +55 -0
  168. package/lib/nodes/ExcalidrawNode/index.d.ts +32 -0
  169. package/lib/nodes/ExcalidrawNode/index.js +117 -0
  170. package/lib/nodes/FigmaNode.d.ts +20 -0
  171. package/lib/nodes/FigmaNode.js +52 -0
  172. package/lib/nodes/ImageComponent.d.ts +16 -0
  173. package/lib/nodes/ImageComponent.js +272 -0
  174. package/lib/nodes/ImageNode.d.ts +50 -0
  175. package/lib/nodes/ImageNode.js +151 -0
  176. package/lib/nodes/InlineImageNode/InlineImageComponent.d.ts +26 -0
  177. package/lib/nodes/InlineImageNode/InlineImageComponent.js +161 -0
  178. package/lib/nodes/InlineImageNode/InlineImageNode.d.ts +59 -0
  179. package/lib/nodes/InlineImageNode/InlineImageNode.js +162 -0
  180. package/lib/nodes/KeywordNode.d.ts +14 -0
  181. package/lib/nodes/KeywordNode.js +33 -0
  182. package/lib/nodes/LayoutContainerNode.d.ts +24 -0
  183. package/lib/nodes/LayoutContainerNode.js +91 -0
  184. package/lib/nodes/LayoutItemNode.d.ts +16 -0
  185. package/lib/nodes/LayoutItemNode.js +65 -0
  186. package/lib/nodes/MentionNode.d.ts +20 -0
  187. package/lib/nodes/MentionNode.js +81 -0
  188. package/lib/nodes/PageBreakNode/index.d.ts +17 -0
  189. package/lib/nodes/PageBreakNode/index.js +83 -0
  190. package/lib/nodes/PlaygroundNodes.d.ts +3 -0
  191. package/lib/nodes/PlaygroundNodes.js +71 -0
  192. package/lib/nodes/PollComponent.d.ts +9 -0
  193. package/lib/nodes/PollComponent.js +85 -0
  194. package/lib/nodes/PollNode.d.ts +43 -0
  195. package/lib/nodes/PollNode.js +153 -0
  196. package/lib/nodes/SpecialTextNode.d.ts +24 -0
  197. package/lib/nodes/SpecialTextNode.js +50 -0
  198. package/lib/nodes/StickyComponent.d.ts +10 -0
  199. package/lib/nodes/StickyComponent.js +162 -0
  200. package/lib/nodes/StickyNode.d.ts +31 -0
  201. package/lib/nodes/StickyNode.js +76 -0
  202. package/lib/nodes/TweetNode.d.ts +21 -0
  203. package/lib/nodes/TweetNode.js +119 -0
  204. package/lib/nodes/YouTubeNode.d.ts +22 -0
  205. package/lib/nodes/YouTubeNode.js +84 -0
  206. package/lib/plugins/ActionsPlugin/index.d.ts +5 -0
  207. package/lib/plugins/ActionsPlugin/index.js +168 -0
  208. package/lib/plugins/AutoEmbedPlugin/index.d.ts +19 -0
  209. package/lib/plugins/AutoEmbedPlugin/index.js +158 -0
  210. package/lib/plugins/AutoLinkPlugin/index.d.ts +2 -0
  211. package/lib/plugins/AutoLinkPlugin/index.js +15 -0
  212. package/lib/plugins/AutocompletePlugin/index.d.ts +10 -0
  213. package/lib/plugins/AutocompletePlugin/index.js +2473 -0
  214. package/lib/plugins/CodeActionMenuPlugin/components/CopyButton/index.d.ts +7 -0
  215. package/lib/plugins/CodeActionMenuPlugin/components/CopyButton/index.js +42 -0
  216. package/lib/plugins/CodeActionMenuPlugin/components/PrettierButton/index.d.ts +17 -0
  217. package/lib/plugins/CodeActionMenuPlugin/components/PrettierButton/index.js +111 -0
  218. package/lib/plugins/CodeActionMenuPlugin/index.d.ts +5 -0
  219. package/lib/plugins/CodeActionMenuPlugin/index.js +104 -0
  220. package/lib/plugins/CodeActionMenuPlugin/utils.d.ts +1 -0
  221. package/lib/plugins/CodeActionMenuPlugin/utils.js +18 -0
  222. package/lib/plugins/CodeHighlightPrismPlugin/index.d.ts +2 -0
  223. package/lib/plugins/CodeHighlightPrismPlugin/index.js +10 -0
  224. package/lib/plugins/CodeHighlightShikiPlugin/index.d.ts +2 -0
  225. package/lib/plugins/CodeHighlightShikiPlugin/index.js +10 -0
  226. package/lib/plugins/CollapsiblePlugin/CollapsibleContainerNode.d.ts +25 -0
  227. package/lib/plugins/CollapsiblePlugin/CollapsibleContainerNode.js +131 -0
  228. package/lib/plugins/CollapsiblePlugin/CollapsibleContentNode.d.ts +16 -0
  229. package/lib/plugins/CollapsiblePlugin/CollapsibleContentNode.js +79 -0
  230. package/lib/plugins/CollapsiblePlugin/CollapsibleTitleNode.d.ts +16 -0
  231. package/lib/plugins/CollapsiblePlugin/CollapsibleTitleNode.js +81 -0
  232. package/lib/plugins/CollapsiblePlugin/CollapsibleUtils.d.ts +2 -0
  233. package/lib/plugins/CollapsiblePlugin/CollapsibleUtils.js +8 -0
  234. package/lib/plugins/CollapsiblePlugin/index.d.ts +3 -0
  235. package/lib/plugins/CollapsiblePlugin/index.js +128 -0
  236. package/lib/plugins/CommentPlugin/index.d.ts +9 -0
  237. package/lib/plugins/CommentPlugin/index.js +460 -0
  238. package/lib/plugins/ComponentPickerPlugin/index.d.ts +2 -0
  239. package/lib/plugins/ComponentPickerPlugin/index.js +276 -0
  240. package/lib/plugins/ContextMenuPlugin/index.d.ts +2 -0
  241. package/lib/plugins/ContextMenuPlugin/index.js +112 -0
  242. package/lib/plugins/CounterPlugin/index.d.ts +3 -0
  243. package/lib/plugins/CounterPlugin/index.js +20 -0
  244. package/lib/plugins/DatalayerPlugin/index.d.ts +2 -0
  245. package/lib/plugins/DatalayerPlugin/index.js +218 -0
  246. package/lib/plugins/DateTimePlugin/index.d.ts +8 -0
  247. package/lib/plugins/DateTimePlugin/index.js +24 -0
  248. package/lib/plugins/DocsPlugin/index.d.ts +2 -0
  249. package/lib/plugins/DocsPlugin/index.js +4 -0
  250. package/lib/plugins/DragDropPastePlugin/index.d.ts +1 -0
  251. package/lib/plugins/DragDropPastePlugin/index.js +33 -0
  252. package/lib/plugins/DraggableBlockPlugin/index.d.ts +12 -0
  253. package/lib/plugins/DraggableBlockPlugin/index.js +36 -0
  254. package/lib/plugins/EmojiPickerPlugin/index.d.ts +1 -0
  255. package/lib/plugins/EmojiPickerPlugin/index.js +80 -0
  256. package/lib/plugins/EmojisPlugin/index.d.ts +2 -0
  257. package/lib/plugins/EmojisPlugin/index.js +52 -0
  258. package/lib/plugins/EquationsPlugin/index.d.ts +14 -0
  259. package/lib/plugins/EquationsPlugin/index.js +34 -0
  260. package/lib/plugins/ExcalidrawPlugin/index.d.ts +5 -0
  261. package/lib/plugins/ExcalidrawPlugin/index.js +44 -0
  262. package/lib/plugins/FigmaPlugin/index.d.ts +4 -0
  263. package/lib/plugins/FigmaPlugin/index.js +20 -0
  264. package/lib/plugins/FloatingLinkEditorPlugin/index.d.ts +15 -0
  265. package/lib/plugins/FloatingLinkEditorPlugin/index.js +280 -0
  266. package/lib/plugins/FloatingTextFormatToolbarPlugin/index.d.ts +7 -0
  267. package/lib/plugins/FloatingTextFormatToolbarPlugin/index.js +219 -0
  268. package/lib/plugins/ImagesPlugin/index.d.ts +24 -0
  269. package/lib/plugins/ImagesPlugin/index.js +195 -0
  270. package/lib/plugins/InlineImagePlugin/index.d.ts +17 -0
  271. package/lib/plugins/InlineImagePlugin/index.js +180 -0
  272. package/lib/plugins/KeywordsPlugin/index.d.ts +2 -0
  273. package/lib/plugins/KeywordsPlugin/index.js +31 -0
  274. package/lib/plugins/LayoutPlugin/InsertLayoutDialog.d.ts +6 -0
  275. package/lib/plugins/LayoutPlugin/InsertLayoutDialog.js +21 -0
  276. package/lib/plugins/LayoutPlugin/LayoutPlugin.d.ts +7 -0
  277. package/lib/plugins/LayoutPlugin/LayoutPlugin.js +131 -0
  278. package/lib/plugins/LinkPlugin/index.d.ts +6 -0
  279. package/lib/plugins/LinkPlugin/index.js +11 -0
  280. package/lib/plugins/MarkdownShortcutPlugin/index.d.ts +2 -0
  281. package/lib/plugins/MarkdownShortcutPlugin/index.js +6 -0
  282. package/lib/plugins/MarkdownTransformers/index.d.ts +8 -0
  283. package/lib/plugins/MarkdownTransformers/index.js +234 -0
  284. package/lib/plugins/MaxLengthPlugin/index.d.ts +3 -0
  285. package/lib/plugins/MaxLengthPlugin/index.js +37 -0
  286. package/lib/plugins/MentionsPlugin/index.d.ts +2 -0
  287. package/lib/plugins/MentionsPlugin/index.js +564 -0
  288. package/lib/plugins/PageBreakPlugin/index.d.ts +4 -0
  289. package/lib/plugins/PageBreakPlugin/index.js +27 -0
  290. package/lib/plugins/PasteLogPlugin/index.d.ts +2 -0
  291. package/lib/plugins/PasteLogPlugin/index.js +27 -0
  292. package/lib/plugins/PollPlugin/index.d.ts +8 -0
  293. package/lib/plugins/PollPlugin/index.js +38 -0
  294. package/lib/plugins/ShortcutsPlugin/index.d.ts +6 -0
  295. package/lib/plugins/ShortcutsPlugin/index.js +112 -0
  296. package/lib/plugins/ShortcutsPlugin/shortcuts.d.ts +59 -0
  297. package/lib/plugins/ShortcutsPlugin/shortcuts.js +169 -0
  298. package/lib/plugins/SpecialTextPlugin/index.d.ts +2 -0
  299. package/lib/plugins/SpecialTextPlugin/index.js +46 -0
  300. package/lib/plugins/SpeechToTextPlugin/index.d.ts +5 -0
  301. package/lib/plugins/SpeechToTextPlugin/index.js +82 -0
  302. package/lib/plugins/StickyPlugin/index.d.ts +2 -0
  303. package/lib/plugins/StickyPlugin/index.js +12 -0
  304. package/lib/plugins/TabFocusPlugin/index.d.ts +1 -0
  305. package/lib/plugins/TabFocusPlugin/index.js +34 -0
  306. package/lib/plugins/TableActionMenuPlugin/index.d.ts +5 -0
  307. package/lib/plugins/TableActionMenuPlugin/index.js +492 -0
  308. package/lib/plugins/TableCellResizer/index.d.ts +3 -0
  309. package/lib/plugins/TableCellResizer/index.js +297 -0
  310. package/lib/plugins/TableHoverActionsPlugin/index.d.ts +4 -0
  311. package/lib/plugins/TableHoverActionsPlugin/index.js +188 -0
  312. package/lib/plugins/TableOfContentsPlugin/index.d.ts +2 -0
  313. package/lib/plugins/TableOfContentsPlugin/index.js +116 -0
  314. package/lib/plugins/TablePlugin.d.ts +31 -0
  315. package/lib/plugins/TablePlugin.js +63 -0
  316. package/lib/plugins/TestRecorderPlugin/index.d.ts +3 -0
  317. package/lib/plugins/TestRecorderPlugin/index.js +346 -0
  318. package/lib/plugins/ToolbarPlugin/fontSize.d.ts +9 -0
  319. package/lib/plugins/ToolbarPlugin/fontSize.js +80 -0
  320. package/lib/plugins/ToolbarPlugin/index.d.ts +9 -0
  321. package/lib/plugins/ToolbarPlugin/index.js +500 -0
  322. package/lib/plugins/ToolbarPlugin/utils.d.ts +26 -0
  323. package/lib/plugins/ToolbarPlugin/utils.js +243 -0
  324. package/lib/plugins/TreeViewPlugin/index.d.ts +2 -0
  325. package/lib/plugins/TreeViewPlugin/index.js +7 -0
  326. package/lib/plugins/TwitterPlugin/index.d.ts +4 -0
  327. package/lib/plugins/TwitterPlugin/index.js +20 -0
  328. package/lib/plugins/TypingPerfPlugin/index.d.ts +2 -0
  329. package/lib/plugins/TypingPerfPlugin/index.js +93 -0
  330. package/lib/plugins/YouTubePlugin/index.d.ts +4 -0
  331. package/lib/plugins/YouTubePlugin/index.js +20 -0
  332. package/lib/server/validation.d.ts +1 -0
  333. package/lib/server/validation.js +111 -0
  334. package/lib/setupEnv.d.ts +2 -0
  335. package/lib/setupEnv.js +25 -0
  336. package/lib/themes/CommentEditorTheme.d.ts +4 -0
  337. package/lib/themes/CommentEditorTheme.js +7 -0
  338. package/lib/themes/PlaygroundEditorTheme.d.ts +4 -0
  339. package/lib/themes/PlaygroundEditorTheme.js +120 -0
  340. package/lib/themes/StickyEditorTheme.d.ts +4 -0
  341. package/lib/themes/StickyEditorTheme.js +7 -0
  342. package/lib/tyes.dt.d.ts +12 -0
  343. package/lib/tyes.dt.js +0 -0
  344. package/lib/ui/Button.d.ts +12 -0
  345. package/lib/ui/Button.js +6 -0
  346. package/lib/ui/ColorPicker.d.ts +14 -0
  347. package/lib/ui/ColorPicker.js +219 -0
  348. package/lib/ui/ContentEditable.d.ts +9 -0
  349. package/lib/ui/ContentEditable.js +6 -0
  350. package/lib/ui/Dialog.d.ts +10 -0
  351. package/lib/ui/Dialog.js +8 -0
  352. package/lib/ui/DropDown.d.ts +18 -0
  353. package/lib/ui/DropDown.js +133 -0
  354. package/lib/ui/DropdownColorPicker.d.ts +13 -0
  355. package/lib/ui/DropdownColorPicker.js +6 -0
  356. package/lib/ui/EquationEditor.d.ts +8 -0
  357. package/lib/ui/EquationEditor.js +11 -0
  358. package/lib/ui/ExcalidrawModal.d.ts +42 -0
  359. package/lib/ui/ExcalidrawModal.js +103 -0
  360. package/lib/ui/FileInput.d.ts +10 -0
  361. package/lib/ui/FileInput.js +5 -0
  362. package/lib/ui/FlashMessage.d.ts +7 -0
  363. package/lib/ui/FlashMessage.js +6 -0
  364. package/lib/ui/ImageResizer.d.ts +17 -0
  365. package/lib/ui/ImageResizer.js +171 -0
  366. package/lib/ui/KatexEquationAlterer.d.ts +8 -0
  367. package/lib/ui/KatexEquationAlterer.js +23 -0
  368. package/lib/ui/KatexRenderer.d.ts +6 -0
  369. package/lib/ui/KatexRenderer.js +24 -0
  370. package/lib/ui/Modal.d.ts +9 -0
  371. package/lib/ui/Modal.js +48 -0
  372. package/lib/ui/Select.d.ts +8 -0
  373. package/lib/ui/Select.js +5 -0
  374. package/lib/ui/Switch.d.ts +8 -0
  375. package/lib/ui/Switch.js +6 -0
  376. package/lib/ui/TextInput.d.ts +13 -0
  377. package/lib/ui/TextInput.js +7 -0
  378. package/lib/utils/docSerialization.d.ts +3 -0
  379. package/lib/utils/docSerialization.js +56 -0
  380. package/lib/utils/emoji-list.d.ts +20 -0
  381. package/lib/utils/emoji-list.js +16605 -0
  382. package/lib/utils/getDOMRangeRect.d.ts +8 -0
  383. package/lib/utils/getDOMRangeRect.js +22 -0
  384. package/lib/utils/getSelectedNode.d.ts +2 -0
  385. package/lib/utils/getSelectedNode.js +24 -0
  386. package/lib/utils/getThemeSelector.d.ts +2 -0
  387. package/lib/utils/getThemeSelector.js +10 -0
  388. package/lib/utils/isMobileWidth.d.ts +7 -0
  389. package/lib/utils/isMobileWidth.js +7 -0
  390. package/lib/utils/joinClasses.d.ts +1 -0
  391. package/lib/utils/joinClasses.js +3 -0
  392. package/lib/utils/setFloatingElemPosition.d.ts +1 -0
  393. package/lib/utils/setFloatingElemPosition.js +55 -0
  394. package/lib/utils/setFloatingElemPositionForLinkEditor.d.ts +1 -0
  395. package/lib/utils/setFloatingElemPositionForLinkEditor.js +32 -0
  396. package/lib/utils/swipe.d.ts +4 -0
  397. package/lib/utils/swipe.js +90 -0
  398. package/lib/utils/url.d.ts +2 -0
  399. package/lib/utils/url.js +27 -0
  400. package/package.json +82 -51
  401. package/lib/DiffMerge.d.ts +0 -39
  402. package/lib/DiffMerge.js +0 -437
  403. package/lib/LoroCollaborativePlugin.d.ts +0 -62
  404. package/lib/LoroCollaborativePlugin.js +0 -2826
  405. package/lib/stableNodeState.d.ts +0 -8
  406. package/lib/stableNodeState.js +0 -15
@@ -0,0 +1,71 @@
1
+ import { CodeHighlightNode, CodeNode } from '@lexical/code';
2
+ import { HashtagNode } from '@lexical/hashtag';
3
+ import { AutoLinkNode, LinkNode } from '@lexical/link';
4
+ import { ListItemNode, ListNode } from '@lexical/list';
5
+ import { MarkNode } from '@lexical/mark';
6
+ import { OverflowNode } from '@lexical/overflow';
7
+ import { HorizontalRuleNode } from '@lexical/react/LexicalHorizontalRuleNode';
8
+ import { HeadingNode, QuoteNode } from '@lexical/rich-text';
9
+ import { TableCellNode, TableNode, TableRowNode } from '@lexical/table';
10
+ import { CollapsibleContainerNode } from '../plugins/CollapsiblePlugin/CollapsibleContainerNode';
11
+ import { CollapsibleContentNode } from '../plugins/CollapsiblePlugin/CollapsibleContentNode';
12
+ import { CollapsibleTitleNode } from '../plugins/CollapsiblePlugin/CollapsibleTitleNode';
13
+ import { AutocompleteNode } from './AutocompleteNode';
14
+ import { CounterNode } from './CounterNode';
15
+ import { DateTimeNode } from './DateTimeNode/DateTimeNode';
16
+ import { EmojiNode } from './EmojiNode';
17
+ import { EquationNode } from './EquationNode';
18
+ import { ExcalidrawNode } from './ExcalidrawNode';
19
+ import { FigmaNode } from './FigmaNode';
20
+ import { ImageNode } from './ImageNode';
21
+ import { InlineImageNode } from './InlineImageNode/InlineImageNode';
22
+ import { KeywordNode } from './KeywordNode';
23
+ import { LayoutContainerNode } from './LayoutContainerNode';
24
+ import { LayoutItemNode } from './LayoutItemNode';
25
+ import { MentionNode } from './MentionNode';
26
+ import { PageBreakNode } from './PageBreakNode';
27
+ import { PollNode } from './PollNode';
28
+ import { SpecialTextNode } from './SpecialTextNode';
29
+ import { StickyNode } from './StickyNode';
30
+ import { TweetNode } from './TweetNode';
31
+ import { YouTubeNode } from './YouTubeNode';
32
+ const PlaygroundNodes = [
33
+ HeadingNode,
34
+ ListNode,
35
+ ListItemNode,
36
+ QuoteNode,
37
+ CodeNode,
38
+ TableNode,
39
+ TableCellNode,
40
+ TableRowNode,
41
+ HashtagNode,
42
+ CodeHighlightNode,
43
+ AutoLinkNode,
44
+ LinkNode,
45
+ OverflowNode,
46
+ PollNode,
47
+ StickyNode,
48
+ ImageNode,
49
+ InlineImageNode,
50
+ MentionNode,
51
+ EmojiNode,
52
+ ExcalidrawNode,
53
+ EquationNode,
54
+ AutocompleteNode,
55
+ CounterNode,
56
+ KeywordNode,
57
+ HorizontalRuleNode,
58
+ TweetNode,
59
+ YouTubeNode,
60
+ FigmaNode,
61
+ MarkNode,
62
+ CollapsibleContainerNode,
63
+ CollapsibleContentNode,
64
+ CollapsibleTitleNode,
65
+ PageBreakNode,
66
+ LayoutContainerNode,
67
+ LayoutItemNode,
68
+ SpecialTextNode,
69
+ DateTimeNode,
70
+ ];
71
+ export default PlaygroundNodes;
@@ -0,0 +1,9 @@
1
+ import type { Options } from './PollNode';
2
+ import type { JSX } from 'react';
3
+ import './PollNode.css';
4
+ import { NodeKey } from 'lexical';
5
+ export default function PollComponent({ question, options, nodeKey, }: {
6
+ nodeKey: NodeKey;
7
+ options: Options;
8
+ question: string;
9
+ }): JSX.Element;
@@ -0,0 +1,85 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import './PollNode.css';
3
+ import { useCollaborationContext } from '@lexical/react/LexicalCollaborationContext';
4
+ import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext';
5
+ import { useLexicalNodeSelection } from '@lexical/react/useLexicalNodeSelection';
6
+ import { mergeRegister } from '@lexical/utils';
7
+ import { $getNodeByKey, $getSelection, $isNodeSelection, CLICK_COMMAND, COMMAND_PRIORITY_LOW, } from 'lexical';
8
+ import { useEffect, useMemo, useRef, useState } from 'react';
9
+ import Button from '../ui/Button';
10
+ import joinClasses from '../utils/joinClasses';
11
+ import { $isPollNode, createPollOption } from './PollNode';
12
+ function getTotalVotes(options) {
13
+ return options.reduce((totalVotes, next) => {
14
+ return totalVotes + next.votes.length;
15
+ }, 0);
16
+ }
17
+ function PollOptionComponent({ option, index, options, totalVotes, withPollNode, }) {
18
+ const { clientID } = useCollaborationContext();
19
+ const checkboxRef = useRef(null);
20
+ const votesArray = option.votes;
21
+ const checkedIndex = votesArray.indexOf(clientID);
22
+ const checked = checkedIndex !== -1;
23
+ const votes = votesArray.length;
24
+ const text = option.text;
25
+ return (_jsxs("div", { className: "PollNode__optionContainer", children: [_jsx("div", { className: joinClasses('PollNode__optionCheckboxWrapper', checked && 'PollNode__optionCheckboxChecked'), children: _jsx("input", { ref: checkboxRef, className: "PollNode__optionCheckbox", type: "checkbox", onChange: (e) => {
26
+ withPollNode((node) => {
27
+ node.toggleVote(option, clientID);
28
+ });
29
+ }, checked: checked }) }), _jsxs("div", { className: "PollNode__optionInputWrapper", children: [_jsx("div", { className: "PollNode__optionInputVotes", style: { width: `${votes === 0 ? 0 : (votes / totalVotes) * 100}%` } }), _jsx("span", { className: "PollNode__optionInputVotesCount", children: votes > 0 && (votes === 1 ? '1 vote' : `${votes} votes`) }), _jsx("input", { className: "PollNode__optionInput", type: "text", value: text, onChange: (e) => {
30
+ const target = e.target;
31
+ const value = target.value;
32
+ const selectionStart = target.selectionStart;
33
+ const selectionEnd = target.selectionEnd;
34
+ withPollNode((node) => {
35
+ node.setOptionText(option, value);
36
+ }, () => {
37
+ target.selectionStart = selectionStart;
38
+ target.selectionEnd = selectionEnd;
39
+ });
40
+ }, placeholder: `Option ${index + 1}` })] }), _jsx("button", { disabled: options.length < 3, className: joinClasses('PollNode__optionDelete', options.length < 3 && 'PollNode__optionDeleteDisabled'), "aria-label": "Remove", onClick: () => {
41
+ withPollNode((node) => {
42
+ node.deleteOption(option);
43
+ });
44
+ } })] }));
45
+ }
46
+ export default function PollComponent({ question, options, nodeKey, }) {
47
+ const [editor] = useLexicalComposerContext();
48
+ const totalVotes = useMemo(() => getTotalVotes(options), [options]);
49
+ const [isSelected, setSelected, clearSelection] = useLexicalNodeSelection(nodeKey);
50
+ const [selection, setSelection] = useState(null);
51
+ const ref = useRef(null);
52
+ useEffect(() => {
53
+ return mergeRegister(editor.registerUpdateListener(({ editorState }) => {
54
+ setSelection(editorState.read(() => $getSelection()));
55
+ }), editor.registerCommand(CLICK_COMMAND, (payload) => {
56
+ const event = payload;
57
+ if (event.target === ref.current) {
58
+ if (!event.shiftKey) {
59
+ clearSelection();
60
+ }
61
+ setSelected(!isSelected);
62
+ return true;
63
+ }
64
+ return false;
65
+ }, COMMAND_PRIORITY_LOW));
66
+ }, [clearSelection, editor, isSelected, nodeKey, setSelected]);
67
+ const withPollNode = (cb, onUpdate) => {
68
+ editor.update(() => {
69
+ const node = $getNodeByKey(nodeKey);
70
+ if ($isPollNode(node)) {
71
+ cb(node);
72
+ }
73
+ }, { onUpdate });
74
+ };
75
+ const addOption = () => {
76
+ withPollNode((node) => {
77
+ node.addOption(createPollOption());
78
+ });
79
+ };
80
+ const isFocused = $isNodeSelection(selection) && isSelected;
81
+ return (_jsx("div", { className: `PollNode__container ${isFocused ? 'focused' : ''}`, ref: ref, children: _jsxs("div", { className: "PollNode__inner", children: [_jsx("h2", { className: "PollNode__heading", children: question }), options.map((option, index) => {
82
+ const key = option.uid;
83
+ return (_jsx(PollOptionComponent, { withPollNode: withPollNode, option: option, index: index, options: options, totalVotes: totalVotes }, key));
84
+ }), _jsx("div", { className: "PollNode__footer", children: _jsx(Button, { onClick: addOption, small: true, children: "Add Option" }) })] }) }));
85
+ }
@@ -0,0 +1,43 @@
1
+ import type { JSX } from 'react';
2
+ import { DecoratorNode, DOMExportOutput, LexicalNode, SerializedLexicalNode, Spread, StateConfigValue, type StateValueOrUpdater } from 'lexical';
3
+ export type Options = ReadonlyArray<Option>;
4
+ export type Option = Readonly<{
5
+ text: string;
6
+ uid: string;
7
+ votes: Array<number>;
8
+ }>;
9
+ export declare function createPollOption(text?: string): Option;
10
+ export type SerializedPollNode = Spread<{
11
+ question: string;
12
+ options: Options;
13
+ }, SerializedLexicalNode>;
14
+ declare const questionState: import("lexical").StateConfig<"question", string>;
15
+ declare const optionsState: import("lexical").StateConfig<"options", Options>;
16
+ export declare class PollNode extends DecoratorNode<JSX.Element> {
17
+ $config(): import("lexical").StaticNodeConfigRecord<"poll", {
18
+ extends: typeof DecoratorNode;
19
+ importDOM: import("lexical").DOMConversionMap<HTMLElement>;
20
+ stateConfigs: ({
21
+ flat: true;
22
+ stateConfig: import("lexical").StateConfig<"question", string>;
23
+ } | {
24
+ flat: true;
25
+ stateConfig: import("lexical").StateConfig<"options", Options>;
26
+ })[];
27
+ }>;
28
+ getQuestion(): StateConfigValue<typeof questionState>;
29
+ setQuestion(valueOrUpdater: StateValueOrUpdater<typeof questionState>): this;
30
+ getOptions(): StateConfigValue<typeof optionsState>;
31
+ setOptions(valueOrUpdater: StateValueOrUpdater<typeof optionsState>): this;
32
+ addOption(option: Option): this;
33
+ deleteOption(option: Option): this;
34
+ setOptionText(option: Option, text: string): this;
35
+ toggleVote(option: Option, clientID: number): this;
36
+ exportDOM(): DOMExportOutput;
37
+ createDOM(): HTMLElement;
38
+ updateDOM(): false;
39
+ decorate(): JSX.Element;
40
+ }
41
+ export declare function $createPollNode(question: string, options: Options): PollNode;
42
+ export declare function $isPollNode(node: LexicalNode | null | undefined): node is PollNode;
43
+ export {};
@@ -0,0 +1,153 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { $getState, $setState, buildImportMap, createState, DecoratorNode, } from 'lexical';
3
+ import * as React from 'react';
4
+ const PollComponent = React.lazy(() => import('./PollComponent'));
5
+ function createUID() {
6
+ return Math.random()
7
+ .toString(36)
8
+ .replace(/[^a-z]+/g, '')
9
+ .substring(0, 5);
10
+ }
11
+ export function createPollOption(text = '') {
12
+ return {
13
+ text,
14
+ uid: createUID(),
15
+ votes: [],
16
+ };
17
+ }
18
+ function cloneOption(option, text, votes) {
19
+ return {
20
+ text,
21
+ uid: option.uid,
22
+ votes: votes || Array.from(option.votes),
23
+ };
24
+ }
25
+ function $convertPollElement(domNode) {
26
+ const question = domNode.getAttribute('data-lexical-poll-question');
27
+ const options = domNode.getAttribute('data-lexical-poll-options');
28
+ if (question !== null && options !== null) {
29
+ const node = $createPollNode(question, JSON.parse(options));
30
+ return { node };
31
+ }
32
+ return null;
33
+ }
34
+ function parseOptions(json) {
35
+ const options = [];
36
+ if (Array.isArray(json)) {
37
+ for (const row of json) {
38
+ if (row &&
39
+ typeof row.text === 'string' &&
40
+ typeof row.uid === 'string' &&
41
+ Array.isArray(row.votes) &&
42
+ row.votes.every((v) => typeof v === 'number')) {
43
+ options.push(row);
44
+ }
45
+ }
46
+ }
47
+ return options;
48
+ }
49
+ const questionState = createState('question', {
50
+ parse: (v) => (typeof v === 'string' ? v : ''),
51
+ });
52
+ const optionsState = createState('options', {
53
+ isEqual: (a, b) => a.length === b.length && JSON.stringify(a) === JSON.stringify(b),
54
+ parse: parseOptions,
55
+ });
56
+ export class PollNode extends DecoratorNode {
57
+ $config() {
58
+ return this.config('poll', {
59
+ extends: DecoratorNode,
60
+ importDOM: buildImportMap({
61
+ span: (domNode) => domNode.getAttribute('data-lexical-poll-question') !== null
62
+ ? {
63
+ conversion: $convertPollElement,
64
+ priority: 2,
65
+ }
66
+ : null,
67
+ }),
68
+ stateConfigs: [
69
+ { flat: true, stateConfig: questionState },
70
+ { flat: true, stateConfig: optionsState },
71
+ ],
72
+ });
73
+ }
74
+ getQuestion() {
75
+ return $getState(this, questionState);
76
+ }
77
+ setQuestion(valueOrUpdater) {
78
+ return $setState(this, questionState, valueOrUpdater);
79
+ }
80
+ getOptions() {
81
+ return $getState(this, optionsState);
82
+ }
83
+ setOptions(valueOrUpdater) {
84
+ return $setState(this, optionsState, valueOrUpdater);
85
+ }
86
+ addOption(option) {
87
+ return this.setOptions((options) => [...options, option]);
88
+ }
89
+ deleteOption(option) {
90
+ return this.setOptions((prevOptions) => {
91
+ const index = prevOptions.indexOf(option);
92
+ if (index === -1) {
93
+ return prevOptions;
94
+ }
95
+ const options = Array.from(prevOptions);
96
+ options.splice(index, 1);
97
+ return options;
98
+ });
99
+ }
100
+ setOptionText(option, text) {
101
+ return this.setOptions((prevOptions) => {
102
+ const clonedOption = cloneOption(option, text);
103
+ const options = Array.from(prevOptions);
104
+ const index = options.indexOf(option);
105
+ options[index] = clonedOption;
106
+ return options;
107
+ });
108
+ }
109
+ toggleVote(option, clientID) {
110
+ return this.setOptions((prevOptions) => {
111
+ const index = prevOptions.indexOf(option);
112
+ if (index === -1) {
113
+ return prevOptions;
114
+ }
115
+ const votes = option.votes;
116
+ const votesClone = Array.from(votes);
117
+ const voteIndex = votes.indexOf(clientID);
118
+ if (voteIndex === -1) {
119
+ votesClone.push(clientID);
120
+ }
121
+ else {
122
+ votesClone.splice(voteIndex, 1);
123
+ }
124
+ const clonedOption = cloneOption(option, option.text, votesClone);
125
+ const options = Array.from(prevOptions);
126
+ options[index] = clonedOption;
127
+ return options;
128
+ });
129
+ }
130
+ exportDOM() {
131
+ const element = document.createElement('span');
132
+ element.setAttribute('data-lexical-poll-question', this.getQuestion());
133
+ element.setAttribute('data-lexical-poll-options', JSON.stringify(this.getOptions()));
134
+ return { element };
135
+ }
136
+ createDOM() {
137
+ const elem = document.createElement('span');
138
+ elem.style.display = 'inline-block';
139
+ return elem;
140
+ }
141
+ updateDOM() {
142
+ return false;
143
+ }
144
+ decorate() {
145
+ return (_jsx(PollComponent, { question: this.getQuestion(), options: this.getOptions(), nodeKey: this.__key }));
146
+ }
147
+ }
148
+ export function $createPollNode(question, options) {
149
+ return new PollNode().setQuestion(question).setOptions(options);
150
+ }
151
+ export function $isPollNode(node) {
152
+ return node instanceof PollNode;
153
+ }
@@ -0,0 +1,24 @@
1
+ import type { EditorConfig, LexicalNode, SerializedTextNode } from 'lexical';
2
+ import { TextNode } from 'lexical';
3
+ /** @noInheritDoc */
4
+ export declare class SpecialTextNode extends TextNode {
5
+ static getType(): string;
6
+ static clone(node: SpecialTextNode): SpecialTextNode;
7
+ createDOM(config: EditorConfig): HTMLElement;
8
+ updateDOM(prevNode: this, dom: HTMLElement, config: EditorConfig): boolean;
9
+ static importJSON(serializedNode: SerializedTextNode): SpecialTextNode;
10
+ isTextEntity(): true;
11
+ canInsertTextAfter(): boolean;
12
+ }
13
+ /**
14
+ * Creates a SpecialTextNode with the given text.
15
+ * @param text - Text content for the SpecialTextNode.
16
+ * @returns A new SpecialTextNode instance.
17
+ */
18
+ export declare function $createSpecialTextNode(text?: string): SpecialTextNode;
19
+ /**
20
+ * Checks if a node is a SpecialTextNode.
21
+ * @param node - Node to check.
22
+ * @returns True if the node is a SpecialTextNode.
23
+ */
24
+ export declare function $isSpecialTextNode(node: LexicalNode | null | undefined): node is SpecialTextNode;
@@ -0,0 +1,50 @@
1
+ import { addClassNamesToElement } from '@lexical/utils';
2
+ import { $applyNodeReplacement, TextNode } from 'lexical';
3
+ /** @noInheritDoc */
4
+ export class SpecialTextNode extends TextNode {
5
+ static getType() {
6
+ return 'specialText';
7
+ }
8
+ static clone(node) {
9
+ return new SpecialTextNode(node.__text, node.__key);
10
+ }
11
+ createDOM(config) {
12
+ const dom = document.createElement('span');
13
+ addClassNamesToElement(dom, config.theme.specialText);
14
+ dom.textContent = this.getTextContent();
15
+ return dom;
16
+ }
17
+ updateDOM(prevNode, dom, config) {
18
+ if (prevNode.__text.startsWith('[') && prevNode.__text.endsWith(']')) {
19
+ const strippedText = this.__text.substring(1, this.__text.length - 1); // Strip brackets again
20
+ dom.textContent = strippedText; // Update the text content
21
+ }
22
+ addClassNamesToElement(dom, config.theme.specialText);
23
+ return false;
24
+ }
25
+ static importJSON(serializedNode) {
26
+ return $createSpecialTextNode().updateFromJSON(serializedNode);
27
+ }
28
+ isTextEntity() {
29
+ return true;
30
+ }
31
+ canInsertTextAfter() {
32
+ return false; // Prevents appending text to this node
33
+ }
34
+ }
35
+ /**
36
+ * Creates a SpecialTextNode with the given text.
37
+ * @param text - Text content for the SpecialTextNode.
38
+ * @returns A new SpecialTextNode instance.
39
+ */
40
+ export function $createSpecialTextNode(text = '') {
41
+ return $applyNodeReplacement(new SpecialTextNode(text));
42
+ }
43
+ /**
44
+ * Checks if a node is a SpecialTextNode.
45
+ * @param node - Node to check.
46
+ * @returns True if the node is a SpecialTextNode.
47
+ */
48
+ export function $isSpecialTextNode(node) {
49
+ return node instanceof SpecialTextNode;
50
+ }
@@ -0,0 +1,10 @@
1
+ import type { LexicalEditor, NodeKey } from 'lexical';
2
+ import type { JSX } from 'react';
3
+ import './StickyNode.css';
4
+ export default function StickyComponent({ x, y, nodeKey, color, caption, }: {
5
+ caption: LexicalEditor;
6
+ color: 'pink' | 'yellow';
7
+ nodeKey: NodeKey;
8
+ x: number;
9
+ y: number;
10
+ }): JSX.Element;
@@ -0,0 +1,162 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import './StickyNode.css';
3
+ import { useCollaborationContext } from '@lexical/react/LexicalCollaborationContext';
4
+ import { CollaborationPlugin } from '@lexical/react/LexicalCollaborationPlugin';
5
+ import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext';
6
+ import { LexicalErrorBoundary } from '@lexical/react/LexicalErrorBoundary';
7
+ import { HistoryPlugin } from '@lexical/react/LexicalHistoryPlugin';
8
+ import { LexicalNestedComposer } from '@lexical/react/LexicalNestedComposer';
9
+ import { PlainTextPlugin } from '@lexical/react/LexicalPlainTextPlugin';
10
+ import { calculateZoomLevel } from '@lexical/utils';
11
+ import { $getNodeByKey } from 'lexical';
12
+ import { useEffect, useLayoutEffect, useRef } from 'react';
13
+ import { createWebsocketProvider } from '../collab/yjs/wsProvider';
14
+ import { useSharedHistoryContext } from '../context/SharedHistoryContext';
15
+ import StickyEditorTheme from '../themes/StickyEditorTheme';
16
+ import ContentEditable from '../ui/ContentEditable';
17
+ import { $isStickyNode } from './StickyNode';
18
+ function positionSticky(stickyElem, positioning) {
19
+ const style = stickyElem.style;
20
+ const rootElementRect = positioning.rootElementRect;
21
+ const rectLeft = rootElementRect !== null ? rootElementRect.left : 0;
22
+ const rectTop = rootElementRect !== null ? rootElementRect.top : 0;
23
+ style.top = rectTop + positioning.y + 'px';
24
+ style.left = rectLeft + positioning.x + 'px';
25
+ }
26
+ export default function StickyComponent({ x, y, nodeKey, color, caption, }) {
27
+ const [editor] = useLexicalComposerContext();
28
+ const stickyContainerRef = useRef(null);
29
+ const positioningRef = useRef({
30
+ isDragging: false,
31
+ offsetX: 0,
32
+ offsetY: 0,
33
+ rootElementRect: null,
34
+ x: 0,
35
+ y: 0,
36
+ });
37
+ const { isCollabActive } = useCollaborationContext();
38
+ useEffect(() => {
39
+ const position = positioningRef.current;
40
+ position.x = x;
41
+ position.y = y;
42
+ const stickyContainer = stickyContainerRef.current;
43
+ if (stickyContainer !== null) {
44
+ positionSticky(stickyContainer, position);
45
+ }
46
+ }, [x, y]);
47
+ useLayoutEffect(() => {
48
+ const position = positioningRef.current;
49
+ const resizeObserver = new ResizeObserver((entries) => {
50
+ for (let i = 0; i < entries.length; i++) {
51
+ const entry = entries[i];
52
+ const { target } = entry;
53
+ position.rootElementRect = target.getBoundingClientRect();
54
+ const stickyContainer = stickyContainerRef.current;
55
+ if (stickyContainer !== null) {
56
+ positionSticky(stickyContainer, position);
57
+ }
58
+ }
59
+ });
60
+ const removeRootListener = editor.registerRootListener((nextRootElem, prevRootElem) => {
61
+ if (prevRootElem !== null) {
62
+ resizeObserver.unobserve(prevRootElem);
63
+ }
64
+ if (nextRootElem !== null) {
65
+ resizeObserver.observe(nextRootElem);
66
+ }
67
+ });
68
+ const handleWindowResize = () => {
69
+ const rootElement = editor.getRootElement();
70
+ const stickyContainer = stickyContainerRef.current;
71
+ if (rootElement !== null && stickyContainer !== null) {
72
+ position.rootElementRect = rootElement.getBoundingClientRect();
73
+ positionSticky(stickyContainer, position);
74
+ }
75
+ };
76
+ window.addEventListener('resize', handleWindowResize);
77
+ return () => {
78
+ window.removeEventListener('resize', handleWindowResize);
79
+ removeRootListener();
80
+ };
81
+ }, [editor]);
82
+ useEffect(() => {
83
+ const stickyContainer = stickyContainerRef.current;
84
+ if (stickyContainer !== null) {
85
+ // Delay adding transition so we don't trigger the
86
+ // transition on load of the sticky.
87
+ setTimeout(() => {
88
+ stickyContainer.style.setProperty('transition', 'top 0.3s ease 0s, left 0.3s ease 0s');
89
+ }, 500);
90
+ }
91
+ }, []);
92
+ const handlePointerMove = (event) => {
93
+ const stickyContainer = stickyContainerRef.current;
94
+ const positioning = positioningRef.current;
95
+ const rootElementRect = positioning.rootElementRect;
96
+ const zoom = calculateZoomLevel(stickyContainer);
97
+ if (stickyContainer !== null &&
98
+ positioning.isDragging &&
99
+ rootElementRect !== null) {
100
+ positioning.x =
101
+ event.pageX / zoom - positioning.offsetX - rootElementRect.left;
102
+ positioning.y =
103
+ event.pageY / zoom - positioning.offsetY - rootElementRect.top;
104
+ positionSticky(stickyContainer, positioning);
105
+ }
106
+ };
107
+ const handlePointerUp = (event) => {
108
+ const stickyContainer = stickyContainerRef.current;
109
+ const positioning = positioningRef.current;
110
+ if (stickyContainer !== null) {
111
+ positioning.isDragging = false;
112
+ stickyContainer.classList.remove('dragging');
113
+ editor.update(() => {
114
+ const node = $getNodeByKey(nodeKey);
115
+ if ($isStickyNode(node)) {
116
+ node.setPosition(positioning.x, positioning.y);
117
+ }
118
+ });
119
+ }
120
+ document.removeEventListener('pointermove', handlePointerMove);
121
+ document.removeEventListener('pointerup', handlePointerUp);
122
+ };
123
+ const handleDelete = () => {
124
+ editor.update(() => {
125
+ const node = $getNodeByKey(nodeKey);
126
+ if ($isStickyNode(node)) {
127
+ node.remove();
128
+ }
129
+ });
130
+ };
131
+ const handleColorChange = () => {
132
+ editor.update(() => {
133
+ const node = $getNodeByKey(nodeKey);
134
+ if ($isStickyNode(node)) {
135
+ node.toggleColor();
136
+ }
137
+ });
138
+ };
139
+ const { historyState } = useSharedHistoryContext();
140
+ return (_jsx("div", { ref: stickyContainerRef, className: "sticky-note-container", children: _jsxs("div", { className: `sticky-note ${color}`, onPointerDown: (event) => {
141
+ const stickyContainer = stickyContainerRef.current;
142
+ if (stickyContainer == null ||
143
+ event.button === 2 ||
144
+ event.target !== stickyContainer.firstChild) {
145
+ // Right click or click on editor should not work
146
+ return;
147
+ }
148
+ const stickContainer = stickyContainer;
149
+ const positioning = positioningRef.current;
150
+ if (stickContainer !== null) {
151
+ const { top, left } = stickContainer.getBoundingClientRect();
152
+ const zoom = calculateZoomLevel(stickContainer);
153
+ positioning.offsetX = event.clientX / zoom - left;
154
+ positioning.offsetY = event.clientY / zoom - top;
155
+ positioning.isDragging = true;
156
+ stickContainer.classList.add('dragging');
157
+ document.addEventListener('pointermove', handlePointerMove);
158
+ document.addEventListener('pointerup', handlePointerUp);
159
+ event.preventDefault();
160
+ }
161
+ }, children: [_jsx("button", { onClick: handleDelete, className: "delete", "aria-label": "Delete sticky note", title: "Delete", children: "X" }), _jsx("button", { onClick: handleColorChange, className: "color", "aria-label": "Change sticky note color", title: "Color", children: _jsx("i", { className: "bucket" }) }), _jsxs(LexicalNestedComposer, { initialEditor: caption, initialTheme: StickyEditorTheme, children: [isCollabActive ? (_jsx(CollaborationPlugin, { id: caption.getKey(), providerFactory: createWebsocketProvider, shouldBootstrap: true })) : (_jsx(HistoryPlugin, { externalHistoryState: historyState })), _jsx(PlainTextPlugin, { contentEditable: _jsx(ContentEditable, { placeholder: "What's up?", placeholderClassName: "StickyNode__placeholder", className: "StickyNode__contentEditable" }), ErrorBoundary: LexicalErrorBoundary })] })] }) }));
162
+ }
@@ -0,0 +1,31 @@
1
+ import type { EditorConfig, LexicalEditor, LexicalNode, LexicalUpdateJSON, NodeKey, SerializedEditor, SerializedLexicalNode, Spread } from 'lexical';
2
+ import type { JSX } from 'react';
3
+ import { DecoratorNode } from 'lexical';
4
+ type StickyNoteColor = 'pink' | 'yellow';
5
+ export type SerializedStickyNode = Spread<{
6
+ xOffset: number;
7
+ yOffset: number;
8
+ color: StickyNoteColor;
9
+ caption: SerializedEditor;
10
+ }, SerializedLexicalNode>;
11
+ export declare class StickyNode extends DecoratorNode<JSX.Element> {
12
+ __x: number;
13
+ __y: number;
14
+ __color: StickyNoteColor;
15
+ __caption: LexicalEditor;
16
+ static getType(): string;
17
+ static clone(node: StickyNode): StickyNode;
18
+ static importJSON(serializedNode: SerializedStickyNode): StickyNode;
19
+ updateFromJSON(serializedNode: LexicalUpdateJSON<SerializedStickyNode>): this;
20
+ constructor(x: number, y: number, color: 'pink' | 'yellow', caption?: LexicalEditor, key?: NodeKey);
21
+ exportJSON(): SerializedStickyNode;
22
+ createDOM(config: EditorConfig): HTMLElement;
23
+ updateDOM(): false;
24
+ setPosition(x: number, y: number): void;
25
+ toggleColor(): void;
26
+ decorate(editor: LexicalEditor, config: EditorConfig): JSX.Element;
27
+ isIsolated(): true;
28
+ }
29
+ export declare function $isStickyNode(node: LexicalNode | null | undefined): node is StickyNode;
30
+ export declare function $createStickyNode(xOffset: number, yOffset: number): StickyNode;
31
+ export {};