@datalayer/lexical-loro 0.1.0 → 0.2.1

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 (400) hide show
  1. package/README.md +1 -1
  2. package/package.json +7 -7
  3. package/lib/App.d.ts +0 -2
  4. package/lib/App.js +0 -141
  5. package/lib/Editor.d.ts +0 -2
  6. package/lib/Editor.js +0 -111
  7. package/lib/Settings.d.ts +0 -2
  8. package/lib/Settings.js +0 -57
  9. package/lib/appSettings.d.ts +0 -36
  10. package/lib/appSettings.js +0 -44
  11. package/lib/collab/loro/Bindings.d.ts +0 -41
  12. package/lib/collab/loro/Bindings.js +0 -95
  13. package/lib/collab/loro/Debug.d.ts +0 -33
  14. package/lib/collab/loro/Debug.js +0 -448
  15. package/lib/collab/loro/LexicalCollaborationContext.d.ts +0 -19
  16. package/lib/collab/loro/LexicalCollaborationContext.js +0 -48
  17. package/lib/collab/loro/LexicalCollaborationPlugin.d.ts +0 -24
  18. package/lib/collab/loro/LexicalCollaborationPlugin.js +0 -83
  19. package/lib/collab/loro/State.d.ts +0 -53
  20. package/lib/collab/loro/State.js +0 -90
  21. package/lib/collab/loro/components/LoroCollaborationUI.d.ts +0 -13
  22. package/lib/collab/loro/components/LoroCollaborationUI.js +0 -9
  23. package/lib/collab/loro/components/LoroCollaborators.d.ts +0 -8
  24. package/lib/collab/loro/components/LoroCollaborators.js +0 -97
  25. package/lib/collab/loro/components/index.d.ts +0 -2
  26. package/lib/collab/loro/components/index.js +0 -2
  27. package/lib/collab/loro/index.d.ts +0 -6
  28. package/lib/collab/loro/index.js +0 -6
  29. package/lib/collab/loro/integrators/BaseIntegrator.d.ts +0 -14
  30. package/lib/collab/loro/integrators/BaseIntegrator.js +0 -1
  31. package/lib/collab/loro/integrators/CounterIntegrator.d.ts +0 -23
  32. package/lib/collab/loro/integrators/CounterIntegrator.js +0 -40
  33. package/lib/collab/loro/integrators/ListIntegrator.d.ts +0 -23
  34. package/lib/collab/loro/integrators/ListIntegrator.js +0 -49
  35. package/lib/collab/loro/integrators/MapIntegrator.d.ts +0 -24
  36. package/lib/collab/loro/integrators/MapIntegrator.js +0 -177
  37. package/lib/collab/loro/integrators/TextIntegrator.d.ts +0 -25
  38. package/lib/collab/loro/integrators/TextIntegrator.js +0 -51
  39. package/lib/collab/loro/integrators/TreeIntegrator.d.ts +0 -25
  40. package/lib/collab/loro/integrators/TreeIntegrator.js +0 -201
  41. package/lib/collab/loro/nodes/NodeFactory.d.ts +0 -8
  42. package/lib/collab/loro/nodes/NodeFactory.js +0 -105
  43. package/lib/collab/loro/nodes/NodesMapper.d.ts +0 -111
  44. package/lib/collab/loro/nodes/NodesMapper.js +0 -258
  45. package/lib/collab/loro/propagators/DecoratorNodePropagator.d.ts +0 -60
  46. package/lib/collab/loro/propagators/DecoratorNodePropagator.js +0 -302
  47. package/lib/collab/loro/propagators/ElementNodePropagator.d.ts +0 -62
  48. package/lib/collab/loro/propagators/ElementNodePropagator.js +0 -335
  49. package/lib/collab/loro/propagators/LineBreakNodePropagator.d.ts +0 -57
  50. package/lib/collab/loro/propagators/LineBreakNodePropagator.js +0 -196
  51. package/lib/collab/loro/propagators/RootNodePropagator.d.ts +0 -55
  52. package/lib/collab/loro/propagators/RootNodePropagator.js +0 -168
  53. package/lib/collab/loro/propagators/TextNodePropagator.d.ts +0 -60
  54. package/lib/collab/loro/propagators/TextNodePropagator.js +0 -434
  55. package/lib/collab/loro/propagators/index.d.ts +0 -49
  56. package/lib/collab/loro/propagators/index.js +0 -32
  57. package/lib/collab/loro/provider/websocket.d.ts +0 -116
  58. package/lib/collab/loro/provider/websocket.js +0 -907
  59. package/lib/collab/loro/servers/index.d.ts +0 -0
  60. package/lib/collab/loro/servers/index.js +0 -0
  61. package/lib/collab/loro/servers/ws/callback.d.ts +0 -5
  62. package/lib/collab/loro/servers/ws/callback.js +0 -85
  63. package/lib/collab/loro/servers/ws/server.d.ts +0 -2
  64. package/lib/collab/loro/servers/ws/server.js +0 -25
  65. package/lib/collab/loro/servers/ws/utils.d.ts +0 -40
  66. package/lib/collab/loro/servers/ws/utils.js +0 -513
  67. package/lib/collab/loro/sync/SyncCursors.d.ts +0 -32
  68. package/lib/collab/loro/sync/SyncCursors.js +0 -435
  69. package/lib/collab/loro/sync/SyncLexicalToLoro.d.ts +0 -4
  70. package/lib/collab/loro/sync/SyncLexicalToLoro.js +0 -80
  71. package/lib/collab/loro/sync/SyncLoroToLexical.d.ts +0 -5
  72. package/lib/collab/loro/sync/SyncLoroToLexical.js +0 -96
  73. package/lib/collab/loro/types/LexicalNodeData.d.ts +0 -32
  74. package/lib/collab/loro/types/LexicalNodeData.js +0 -71
  75. package/lib/collab/loro/useCollaboration.d.ts +0 -12
  76. package/lib/collab/loro/useCollaboration.js +0 -248
  77. package/lib/collab/loro/utils/InitialContent.d.ts +0 -64
  78. package/lib/collab/loro/utils/InitialContent.js +0 -109
  79. package/lib/collab/loro/utils/LexicalToLoro.d.ts +0 -18
  80. package/lib/collab/loro/utils/LexicalToLoro.js +0 -96
  81. package/lib/collab/loro/utils/Utils.d.ts +0 -44
  82. package/lib/collab/loro/utils/Utils.js +0 -153
  83. package/lib/collab/loro/wsProvider.d.ts +0 -8
  84. package/lib/collab/loro/wsProvider.js +0 -31
  85. package/lib/collab/utils/invariant.d.ts +0 -1
  86. package/lib/collab/utils/invariant.js +0 -11
  87. package/lib/collab/utils/simpleDiffWithCursor.d.ts +0 -5
  88. package/lib/collab/utils/simpleDiffWithCursor.js +0 -31
  89. package/lib/collab/yjs/Bindings.d.ts +0 -23
  90. package/lib/collab/yjs/Bindings.js +0 -26
  91. package/lib/collab/yjs/Debug.d.ts +0 -23
  92. package/lib/collab/yjs/Debug.js +0 -213
  93. package/lib/collab/yjs/LexicalCollaborationContext.d.ts +0 -10
  94. package/lib/collab/yjs/LexicalCollaborationContext.js +0 -37
  95. package/lib/collab/yjs/LexicalCollaborationPlugin.d.ts +0 -21
  96. package/lib/collab/yjs/LexicalCollaborationPlugin.js +0 -63
  97. package/lib/collab/yjs/State.d.ts +0 -51
  98. package/lib/collab/yjs/State.js +0 -35
  99. package/lib/collab/yjs/nodes/AnyCollabNode.d.ts +0 -5
  100. package/lib/collab/yjs/nodes/AnyCollabNode.js +0 -1
  101. package/lib/collab/yjs/nodes/CollabDecoratorNode.d.ts +0 -22
  102. package/lib/collab/yjs/nodes/CollabDecoratorNode.js +0 -64
  103. package/lib/collab/yjs/nodes/CollabElementNode.d.ts +0 -40
  104. package/lib/collab/yjs/nodes/CollabElementNode.js +0 -462
  105. package/lib/collab/yjs/nodes/CollabLineBreakNode.d.ts +0 -19
  106. package/lib/collab/yjs/nodes/CollabLineBreakNode.js +0 -44
  107. package/lib/collab/yjs/nodes/CollabTextNode.d.ts +0 -25
  108. package/lib/collab/yjs/nodes/CollabTextNode.js +0 -103
  109. package/lib/collab/yjs/provider/websocket.d.ts +0 -88
  110. package/lib/collab/yjs/provider/websocket.js +0 -415
  111. package/lib/collab/yjs/servers/index.d.ts +0 -0
  112. package/lib/collab/yjs/servers/index.js +0 -0
  113. package/lib/collab/yjs/servers/ws/callback.d.ts +0 -5
  114. package/lib/collab/yjs/servers/ws/callback.js +0 -72
  115. package/lib/collab/yjs/servers/ws/server.d.ts +0 -2
  116. package/lib/collab/yjs/servers/ws/server.js +0 -25
  117. package/lib/collab/yjs/servers/ws/utils.d.ts +0 -49
  118. package/lib/collab/yjs/servers/ws/utils.js +0 -284
  119. package/lib/collab/yjs/sync/SyncCursors.d.ts +0 -39
  120. package/lib/collab/yjs/sync/SyncCursors.js +0 -351
  121. package/lib/collab/yjs/sync/SyncEditorStates.d.ts +0 -10
  122. package/lib/collab/yjs/sync/SyncEditorStates.js +0 -200
  123. package/lib/collab/yjs/useCollaboration.d.ts +0 -12
  124. package/lib/collab/yjs/useCollaboration.js +0 -255
  125. package/lib/collab/yjs/utils/Utils.d.ts +0 -25
  126. package/lib/collab/yjs/utils/Utils.js +0 -402
  127. package/lib/collab/yjs/wsProvider.d.ts +0 -3
  128. package/lib/collab/yjs/wsProvider.js +0 -21
  129. package/lib/commenting/index.d.ts +0 -41
  130. package/lib/commenting/index.js +0 -324
  131. package/lib/context/FlashMessageContext.d.ts +0 -7
  132. package/lib/context/FlashMessageContext.js +0 -24
  133. package/lib/context/SettingsContext.d.ts +0 -12
  134. package/lib/context/SettingsContext.js +0 -38
  135. package/lib/context/SharedHistoryContext.d.ts +0 -11
  136. package/lib/context/SharedHistoryContext.js +0 -11
  137. package/lib/context/ToolbarContext.d.ts +0 -65
  138. package/lib/context/ToolbarContext.js +0 -84
  139. package/lib/demo.d.ts +0 -12
  140. package/lib/demo.js +0 -41
  141. package/lib/hooks/useFlashMessage.d.ts +0 -2
  142. package/lib/hooks/useFlashMessage.js +0 -4
  143. package/lib/hooks/useModal.d.ts +0 -5
  144. package/lib/hooks/useModal.js +0 -26
  145. package/lib/hooks/useReport.d.ts +0 -1
  146. package/lib/hooks/useReport.js +0 -46
  147. package/lib/index.d.ts +0 -1
  148. package/lib/index.js +0 -1
  149. package/lib/nodes/AutocompleteNode.d.ts +0 -27
  150. package/lib/nodes/AutocompleteNode.js +0 -56
  151. package/lib/nodes/CounterComponent.d.ts +0 -6
  152. package/lib/nodes/CounterComponent.js +0 -137
  153. package/lib/nodes/CounterNode.d.ts +0 -23
  154. package/lib/nodes/CounterNode.js +0 -47
  155. package/lib/nodes/DateTimeNode/DateTimeComponent.d.ts +0 -8
  156. package/lib/nodes/DateTimeNode/DateTimeComponent.js +0 -119
  157. package/lib/nodes/DateTimeNode/DateTimeNode.d.ts +0 -27
  158. package/lib/nodes/DateTimeNode/DateTimeNode.js +0 -82
  159. package/lib/nodes/EmojiNode.d.ts +0 -18
  160. package/lib/nodes/EmojiNode.js +0 -50
  161. package/lib/nodes/EquationComponent.d.ts +0 -9
  162. package/lib/nodes/EquationComponent.js +0 -75
  163. package/lib/nodes/EquationNode.d.ts +0 -26
  164. package/lib/nodes/EquationNode.js +0 -109
  165. package/lib/nodes/ExcalidrawNode/ExcalidrawComponent.d.ts +0 -8
  166. package/lib/nodes/ExcalidrawNode/ExcalidrawComponent.js +0 -110
  167. package/lib/nodes/ExcalidrawNode/ExcalidrawImage.d.ts +0 -50
  168. package/lib/nodes/ExcalidrawNode/ExcalidrawImage.js +0 -55
  169. package/lib/nodes/ExcalidrawNode/index.d.ts +0 -32
  170. package/lib/nodes/ExcalidrawNode/index.js +0 -117
  171. package/lib/nodes/FigmaNode.d.ts +0 -20
  172. package/lib/nodes/FigmaNode.js +0 -52
  173. package/lib/nodes/ImageComponent.d.ts +0 -16
  174. package/lib/nodes/ImageComponent.js +0 -272
  175. package/lib/nodes/ImageNode.d.ts +0 -50
  176. package/lib/nodes/ImageNode.js +0 -151
  177. package/lib/nodes/InlineImageNode/InlineImageComponent.d.ts +0 -26
  178. package/lib/nodes/InlineImageNode/InlineImageComponent.js +0 -161
  179. package/lib/nodes/InlineImageNode/InlineImageNode.d.ts +0 -59
  180. package/lib/nodes/InlineImageNode/InlineImageNode.js +0 -162
  181. package/lib/nodes/KeywordNode.d.ts +0 -14
  182. package/lib/nodes/KeywordNode.js +0 -33
  183. package/lib/nodes/LayoutContainerNode.d.ts +0 -24
  184. package/lib/nodes/LayoutContainerNode.js +0 -91
  185. package/lib/nodes/LayoutItemNode.d.ts +0 -16
  186. package/lib/nodes/LayoutItemNode.js +0 -65
  187. package/lib/nodes/MentionNode.d.ts +0 -20
  188. package/lib/nodes/MentionNode.js +0 -81
  189. package/lib/nodes/PageBreakNode/index.d.ts +0 -17
  190. package/lib/nodes/PageBreakNode/index.js +0 -83
  191. package/lib/nodes/PlaygroundNodes.d.ts +0 -3
  192. package/lib/nodes/PlaygroundNodes.js +0 -71
  193. package/lib/nodes/PollComponent.d.ts +0 -9
  194. package/lib/nodes/PollComponent.js +0 -85
  195. package/lib/nodes/PollNode.d.ts +0 -43
  196. package/lib/nodes/PollNode.js +0 -153
  197. package/lib/nodes/SpecialTextNode.d.ts +0 -24
  198. package/lib/nodes/SpecialTextNode.js +0 -50
  199. package/lib/nodes/StickyComponent.d.ts +0 -10
  200. package/lib/nodes/StickyComponent.js +0 -162
  201. package/lib/nodes/StickyNode.d.ts +0 -31
  202. package/lib/nodes/StickyNode.js +0 -76
  203. package/lib/nodes/TweetNode.d.ts +0 -21
  204. package/lib/nodes/TweetNode.js +0 -119
  205. package/lib/nodes/YouTubeNode.d.ts +0 -22
  206. package/lib/nodes/YouTubeNode.js +0 -84
  207. package/lib/plugins/ActionsPlugin/index.d.ts +0 -5
  208. package/lib/plugins/ActionsPlugin/index.js +0 -168
  209. package/lib/plugins/AutoEmbedPlugin/index.d.ts +0 -19
  210. package/lib/plugins/AutoEmbedPlugin/index.js +0 -158
  211. package/lib/plugins/AutoLinkPlugin/index.d.ts +0 -2
  212. package/lib/plugins/AutoLinkPlugin/index.js +0 -15
  213. package/lib/plugins/AutocompletePlugin/index.d.ts +0 -10
  214. package/lib/plugins/AutocompletePlugin/index.js +0 -2473
  215. package/lib/plugins/CodeActionMenuPlugin/components/CopyButton/index.d.ts +0 -7
  216. package/lib/plugins/CodeActionMenuPlugin/components/CopyButton/index.js +0 -42
  217. package/lib/plugins/CodeActionMenuPlugin/components/PrettierButton/index.d.ts +0 -17
  218. package/lib/plugins/CodeActionMenuPlugin/components/PrettierButton/index.js +0 -111
  219. package/lib/plugins/CodeActionMenuPlugin/index.d.ts +0 -5
  220. package/lib/plugins/CodeActionMenuPlugin/index.js +0 -104
  221. package/lib/plugins/CodeActionMenuPlugin/utils.d.ts +0 -1
  222. package/lib/plugins/CodeActionMenuPlugin/utils.js +0 -18
  223. package/lib/plugins/CodeHighlightPrismPlugin/index.d.ts +0 -2
  224. package/lib/plugins/CodeHighlightPrismPlugin/index.js +0 -10
  225. package/lib/plugins/CodeHighlightShikiPlugin/index.d.ts +0 -2
  226. package/lib/plugins/CodeHighlightShikiPlugin/index.js +0 -10
  227. package/lib/plugins/CollapsiblePlugin/CollapsibleContainerNode.d.ts +0 -25
  228. package/lib/plugins/CollapsiblePlugin/CollapsibleContainerNode.js +0 -131
  229. package/lib/plugins/CollapsiblePlugin/CollapsibleContentNode.d.ts +0 -16
  230. package/lib/plugins/CollapsiblePlugin/CollapsibleContentNode.js +0 -79
  231. package/lib/plugins/CollapsiblePlugin/CollapsibleTitleNode.d.ts +0 -16
  232. package/lib/plugins/CollapsiblePlugin/CollapsibleTitleNode.js +0 -81
  233. package/lib/plugins/CollapsiblePlugin/CollapsibleUtils.d.ts +0 -2
  234. package/lib/plugins/CollapsiblePlugin/CollapsibleUtils.js +0 -8
  235. package/lib/plugins/CollapsiblePlugin/index.d.ts +0 -3
  236. package/lib/plugins/CollapsiblePlugin/index.js +0 -128
  237. package/lib/plugins/CommentPlugin/index.d.ts +0 -9
  238. package/lib/plugins/CommentPlugin/index.js +0 -460
  239. package/lib/plugins/ComponentPickerPlugin/index.d.ts +0 -2
  240. package/lib/plugins/ComponentPickerPlugin/index.js +0 -276
  241. package/lib/plugins/ContextMenuPlugin/index.d.ts +0 -2
  242. package/lib/plugins/ContextMenuPlugin/index.js +0 -112
  243. package/lib/plugins/CounterPlugin/index.d.ts +0 -3
  244. package/lib/plugins/CounterPlugin/index.js +0 -20
  245. package/lib/plugins/DatalayerPlugin/index.d.ts +0 -2
  246. package/lib/plugins/DatalayerPlugin/index.js +0 -218
  247. package/lib/plugins/DateTimePlugin/index.d.ts +0 -8
  248. package/lib/plugins/DateTimePlugin/index.js +0 -24
  249. package/lib/plugins/DocsPlugin/index.d.ts +0 -2
  250. package/lib/plugins/DocsPlugin/index.js +0 -4
  251. package/lib/plugins/DragDropPastePlugin/index.d.ts +0 -1
  252. package/lib/plugins/DragDropPastePlugin/index.js +0 -33
  253. package/lib/plugins/DraggableBlockPlugin/index.d.ts +0 -12
  254. package/lib/plugins/DraggableBlockPlugin/index.js +0 -36
  255. package/lib/plugins/EmojiPickerPlugin/index.d.ts +0 -1
  256. package/lib/plugins/EmojiPickerPlugin/index.js +0 -80
  257. package/lib/plugins/EmojisPlugin/index.d.ts +0 -2
  258. package/lib/plugins/EmojisPlugin/index.js +0 -52
  259. package/lib/plugins/EquationsPlugin/index.d.ts +0 -14
  260. package/lib/plugins/EquationsPlugin/index.js +0 -34
  261. package/lib/plugins/ExcalidrawPlugin/index.d.ts +0 -5
  262. package/lib/plugins/ExcalidrawPlugin/index.js +0 -44
  263. package/lib/plugins/FigmaPlugin/index.d.ts +0 -4
  264. package/lib/plugins/FigmaPlugin/index.js +0 -20
  265. package/lib/plugins/FloatingLinkEditorPlugin/index.d.ts +0 -15
  266. package/lib/plugins/FloatingLinkEditorPlugin/index.js +0 -280
  267. package/lib/plugins/FloatingTextFormatToolbarPlugin/index.d.ts +0 -7
  268. package/lib/plugins/FloatingTextFormatToolbarPlugin/index.js +0 -219
  269. package/lib/plugins/ImagesPlugin/index.d.ts +0 -24
  270. package/lib/plugins/ImagesPlugin/index.js +0 -195
  271. package/lib/plugins/InlineImagePlugin/index.d.ts +0 -17
  272. package/lib/plugins/InlineImagePlugin/index.js +0 -180
  273. package/lib/plugins/KeywordsPlugin/index.d.ts +0 -2
  274. package/lib/plugins/KeywordsPlugin/index.js +0 -31
  275. package/lib/plugins/LayoutPlugin/InsertLayoutDialog.d.ts +0 -6
  276. package/lib/plugins/LayoutPlugin/InsertLayoutDialog.js +0 -21
  277. package/lib/plugins/LayoutPlugin/LayoutPlugin.d.ts +0 -7
  278. package/lib/plugins/LayoutPlugin/LayoutPlugin.js +0 -131
  279. package/lib/plugins/LinkPlugin/index.d.ts +0 -6
  280. package/lib/plugins/LinkPlugin/index.js +0 -11
  281. package/lib/plugins/MarkdownShortcutPlugin/index.d.ts +0 -2
  282. package/lib/plugins/MarkdownShortcutPlugin/index.js +0 -6
  283. package/lib/plugins/MarkdownTransformers/index.d.ts +0 -8
  284. package/lib/plugins/MarkdownTransformers/index.js +0 -234
  285. package/lib/plugins/MaxLengthPlugin/index.d.ts +0 -3
  286. package/lib/plugins/MaxLengthPlugin/index.js +0 -37
  287. package/lib/plugins/MentionsPlugin/index.d.ts +0 -2
  288. package/lib/plugins/MentionsPlugin/index.js +0 -564
  289. package/lib/plugins/PageBreakPlugin/index.d.ts +0 -4
  290. package/lib/plugins/PageBreakPlugin/index.js +0 -27
  291. package/lib/plugins/PasteLogPlugin/index.d.ts +0 -2
  292. package/lib/plugins/PasteLogPlugin/index.js +0 -27
  293. package/lib/plugins/PollPlugin/index.d.ts +0 -8
  294. package/lib/plugins/PollPlugin/index.js +0 -38
  295. package/lib/plugins/ShortcutsPlugin/index.d.ts +0 -6
  296. package/lib/plugins/ShortcutsPlugin/index.js +0 -112
  297. package/lib/plugins/ShortcutsPlugin/shortcuts.d.ts +0 -59
  298. package/lib/plugins/ShortcutsPlugin/shortcuts.js +0 -169
  299. package/lib/plugins/SpecialTextPlugin/index.d.ts +0 -2
  300. package/lib/plugins/SpecialTextPlugin/index.js +0 -46
  301. package/lib/plugins/SpeechToTextPlugin/index.d.ts +0 -5
  302. package/lib/plugins/SpeechToTextPlugin/index.js +0 -82
  303. package/lib/plugins/StickyPlugin/index.d.ts +0 -2
  304. package/lib/plugins/StickyPlugin/index.js +0 -12
  305. package/lib/plugins/TabFocusPlugin/index.d.ts +0 -1
  306. package/lib/plugins/TabFocusPlugin/index.js +0 -34
  307. package/lib/plugins/TableActionMenuPlugin/index.d.ts +0 -5
  308. package/lib/plugins/TableActionMenuPlugin/index.js +0 -492
  309. package/lib/plugins/TableCellResizer/index.d.ts +0 -3
  310. package/lib/plugins/TableCellResizer/index.js +0 -297
  311. package/lib/plugins/TableHoverActionsPlugin/index.d.ts +0 -4
  312. package/lib/plugins/TableHoverActionsPlugin/index.js +0 -188
  313. package/lib/plugins/TableOfContentsPlugin/index.d.ts +0 -2
  314. package/lib/plugins/TableOfContentsPlugin/index.js +0 -116
  315. package/lib/plugins/TablePlugin.d.ts +0 -31
  316. package/lib/plugins/TablePlugin.js +0 -63
  317. package/lib/plugins/TestRecorderPlugin/index.d.ts +0 -3
  318. package/lib/plugins/TestRecorderPlugin/index.js +0 -346
  319. package/lib/plugins/ToolbarPlugin/fontSize.d.ts +0 -9
  320. package/lib/plugins/ToolbarPlugin/fontSize.js +0 -80
  321. package/lib/plugins/ToolbarPlugin/index.d.ts +0 -9
  322. package/lib/plugins/ToolbarPlugin/index.js +0 -500
  323. package/lib/plugins/ToolbarPlugin/utils.d.ts +0 -26
  324. package/lib/plugins/ToolbarPlugin/utils.js +0 -243
  325. package/lib/plugins/TreeViewPlugin/index.d.ts +0 -2
  326. package/lib/plugins/TreeViewPlugin/index.js +0 -7
  327. package/lib/plugins/TwitterPlugin/index.d.ts +0 -4
  328. package/lib/plugins/TwitterPlugin/index.js +0 -20
  329. package/lib/plugins/TypingPerfPlugin/index.d.ts +0 -2
  330. package/lib/plugins/TypingPerfPlugin/index.js +0 -93
  331. package/lib/plugins/YouTubePlugin/index.d.ts +0 -4
  332. package/lib/plugins/YouTubePlugin/index.js +0 -20
  333. package/lib/server/validation.d.ts +0 -1
  334. package/lib/server/validation.js +0 -111
  335. package/lib/setupEnv.d.ts +0 -2
  336. package/lib/setupEnv.js +0 -25
  337. package/lib/themes/CommentEditorTheme.d.ts +0 -4
  338. package/lib/themes/CommentEditorTheme.js +0 -7
  339. package/lib/themes/PlaygroundEditorTheme.d.ts +0 -4
  340. package/lib/themes/PlaygroundEditorTheme.js +0 -120
  341. package/lib/themes/StickyEditorTheme.d.ts +0 -4
  342. package/lib/themes/StickyEditorTheme.js +0 -7
  343. package/lib/tyes.dt.d.ts +0 -12
  344. package/lib/tyes.dt.js +0 -0
  345. package/lib/ui/Button.d.ts +0 -12
  346. package/lib/ui/Button.js +0 -6
  347. package/lib/ui/ColorPicker.d.ts +0 -14
  348. package/lib/ui/ColorPicker.js +0 -219
  349. package/lib/ui/ContentEditable.d.ts +0 -9
  350. package/lib/ui/ContentEditable.js +0 -6
  351. package/lib/ui/Dialog.d.ts +0 -10
  352. package/lib/ui/Dialog.js +0 -8
  353. package/lib/ui/DropDown.d.ts +0 -18
  354. package/lib/ui/DropDown.js +0 -133
  355. package/lib/ui/DropdownColorPicker.d.ts +0 -13
  356. package/lib/ui/DropdownColorPicker.js +0 -6
  357. package/lib/ui/EquationEditor.d.ts +0 -8
  358. package/lib/ui/EquationEditor.js +0 -11
  359. package/lib/ui/ExcalidrawModal.d.ts +0 -42
  360. package/lib/ui/ExcalidrawModal.js +0 -103
  361. package/lib/ui/FileInput.d.ts +0 -10
  362. package/lib/ui/FileInput.js +0 -5
  363. package/lib/ui/FlashMessage.d.ts +0 -7
  364. package/lib/ui/FlashMessage.js +0 -6
  365. package/lib/ui/ImageResizer.d.ts +0 -17
  366. package/lib/ui/ImageResizer.js +0 -171
  367. package/lib/ui/KatexEquationAlterer.d.ts +0 -8
  368. package/lib/ui/KatexEquationAlterer.js +0 -23
  369. package/lib/ui/KatexRenderer.d.ts +0 -6
  370. package/lib/ui/KatexRenderer.js +0 -24
  371. package/lib/ui/Modal.d.ts +0 -9
  372. package/lib/ui/Modal.js +0 -48
  373. package/lib/ui/Select.d.ts +0 -8
  374. package/lib/ui/Select.js +0 -5
  375. package/lib/ui/Switch.d.ts +0 -8
  376. package/lib/ui/Switch.js +0 -6
  377. package/lib/ui/TextInput.d.ts +0 -13
  378. package/lib/ui/TextInput.js +0 -7
  379. package/lib/utils/docSerialization.d.ts +0 -3
  380. package/lib/utils/docSerialization.js +0 -56
  381. package/lib/utils/emoji-list.d.ts +0 -20
  382. package/lib/utils/emoji-list.js +0 -16605
  383. package/lib/utils/getDOMRangeRect.d.ts +0 -8
  384. package/lib/utils/getDOMRangeRect.js +0 -22
  385. package/lib/utils/getSelectedNode.d.ts +0 -2
  386. package/lib/utils/getSelectedNode.js +0 -24
  387. package/lib/utils/getThemeSelector.d.ts +0 -2
  388. package/lib/utils/getThemeSelector.js +0 -10
  389. package/lib/utils/isMobileWidth.d.ts +0 -7
  390. package/lib/utils/isMobileWidth.js +0 -7
  391. package/lib/utils/joinClasses.d.ts +0 -1
  392. package/lib/utils/joinClasses.js +0 -3
  393. package/lib/utils/setFloatingElemPosition.d.ts +0 -1
  394. package/lib/utils/setFloatingElemPosition.js +0 -55
  395. package/lib/utils/setFloatingElemPositionForLinkEditor.d.ts +0 -1
  396. package/lib/utils/setFloatingElemPositionForLinkEditor.js +0 -32
  397. package/lib/utils/swipe.d.ts +0 -4
  398. package/lib/utils/swipe.js +0 -90
  399. package/lib/utils/url.d.ts +0 -2
  400. package/lib/utils/url.js +0 -27
@@ -1,33 +0,0 @@
1
- import type { Binding } from './Bindings';
2
- /**
3
- * Debugging utilities for Loro collaboration
4
- * This module provides comprehensive debugging tools for inspecting tree structure,
5
- * node mappings, and collaboration state in the Loro-Lexical integration.
6
- */
7
- export interface LoroDebugger {
8
- binding: Binding | null;
9
- logStructure: () => void;
10
- verifyStructure: () => void;
11
- inspectNode: (treeId: string) => void;
12
- generateTreeHTML: (nodes: any[], rootNode?: any, prefix?: string, isLast?: boolean, depth?: number) => string;
13
- addDebugToPage: () => void;
14
- cleanupEphemeralStore: (provider?: any) => void;
15
- resetGlobalEphemeralStore: () => void;
16
- }
17
- /**
18
- * Sets up global debugging utilities for Loro collaboration.
19
- * Attaches comprehensive debugging tools to window.debugLoro for development use.
20
- */
21
- export declare function setupLoroDebugging(binding: Binding): void;
22
- /**
23
- * Quick access function to add debug panel to page
24
- */
25
- export declare function addDebugPanel(): void;
26
- /**
27
- * Quick access function to log tree structure
28
- */
29
- export declare function logTreeStructure(): void;
30
- /**
31
- * Quick access function to verify tree structure
32
- */
33
- export declare function verifyTreeStructure(): void;
@@ -1,448 +0,0 @@
1
- /**
2
- * Sets up global debugging utilities for Loro collaboration.
3
- * Attaches comprehensive debugging tools to window.debugLoro for development use.
4
- */
5
- export function setupLoroDebugging(binding) {
6
- // Setup global debugging for Loro
7
- window.debugLoro = {
8
- binding: null, // Will be set after binding is created
9
- logStructure: () => {
10
- const binding = window.debugLoro.binding;
11
- if (binding) {
12
- console.log('=== LORO TREE STRUCTURE DEBUG ===');
13
- const tree = binding.tree;
14
- const nodes = tree.nodes();
15
- console.log(`Total nodes in tree: ${nodes.length}`);
16
- // Helper function to recursively log tree structure
17
- const logTreeStructure = (node, prefix = '', isLast = true, depth = 0) => {
18
- const data = Object.fromEntries(node.data.entries());
19
- const treeId = node.id;
20
- // Get lexical key from mapper instead of node data
21
- const lexicalKey = binding.nodeMapper?.getLexicalKeyByLoroId(treeId) || 'no-key';
22
- const elementType = data.elementType || 'no-type';
23
- const connector = depth === 0 ? '' : (isLast ? '└── ' : '├── ');
24
- const nodeInfo = `TreeID(${treeId.slice(0, 8)}...) → ${lexicalKey} [${elementType}]`;
25
- console.log(`${prefix}${connector}${nodeInfo}`);
26
- const children = node.children();
27
- if (children && children.length > 0) {
28
- children.forEach((child, index) => {
29
- const isLastChild = index === children.length - 1;
30
- const childPrefix = prefix + (depth === 0 ? '' : (isLast ? ' ' : '│ '));
31
- logTreeStructure(child, childPrefix, isLastChild, depth + 1);
32
- });
33
- }
34
- };
35
- // Find and display all root nodes
36
- const rootNodes = nodes.filter((node) => {
37
- const parent = node.parent();
38
- const data = Object.fromEntries(node.data.entries());
39
- return !parent || data.isRoot;
40
- });
41
- console.log(`Root nodes: ${rootNodes.length}`);
42
- console.log('');
43
- if (rootNodes.length === 0) {
44
- console.log('⚠️ No root nodes found!');
45
- }
46
- else {
47
- rootNodes.forEach((root, index) => {
48
- const isLastRoot = index === rootNodes.length - 1;
49
- logTreeStructure(root, '', isLastRoot, 0);
50
- });
51
- }
52
- console.log('=== END LORO DEBUG ===');
53
- }
54
- else {
55
- console.log('Loro binding not available yet');
56
- }
57
- },
58
- verifyStructure: () => {
59
- const binding = window.debugLoro.binding;
60
- if (!binding)
61
- return console.log('❌ Loro Binding not available');
62
- console.log('🔍 LORO TREE VERIFICATION:');
63
- const tree = binding.tree;
64
- const nodes = tree.nodes();
65
- console.log('Total nodes:', nodes.length);
66
- console.log('Peer ID:', binding.doc.peerIdStr);
67
- console.log('Client ID:', binding.clientID);
68
- // Check mapping consistency
69
- const mapper = binding.nodeMapper;
70
- console.log('\n📍 Node Mappings:');
71
- nodes.forEach((node, index) => {
72
- const data = Object.fromEntries(node.data.entries());
73
- const treeId = node.id;
74
- // Get lexical key from mapper instead of node data
75
- const lexicalKey = binding.nodeMapper?.getLexicalKeyByLoroId(treeId) || 'no-key';
76
- console.log(`\n📍 Node ${index}:`);
77
- console.log(' TreeID:', treeId);
78
- console.log(' Lexical Key:', lexicalKey);
79
- console.log(' Element Type:', data.elementType || 'N/A');
80
- console.log(' Created At:', data.createdAt && typeof data.createdAt === 'number' ? new Date(data.createdAt).toLocaleTimeString() : 'N/A');
81
- console.log(' Has Lexical Data:', data.lexical ? 'Yes' : 'No');
82
- const parent = node.parent();
83
- console.log(' Parent:', parent ? parent.id : 'None (Root)');
84
- const children = node.children();
85
- console.log(' Children Count:', children ? children.length : 0);
86
- if (data.lexical && typeof data.lexical === 'string') {
87
- try {
88
- const parsed = JSON.parse(data.lexical);
89
- console.log(' Lexical Type:', parsed.lexicalNode?.type || 'Unknown');
90
- }
91
- catch (e) {
92
- console.log(' Lexical Data: Invalid JSON');
93
- }
94
- }
95
- });
96
- // Check for orphaned nodes
97
- const orphanedNodes = nodes.filter(node => {
98
- const parent = node.parent();
99
- const data = Object.fromEntries(node.data.entries());
100
- return !parent && !data.isRoot;
101
- });
102
- if (orphanedNodes.length > 0) {
103
- console.log('\n⚠️ WARNING: Found orphaned nodes (no parent, not root):');
104
- orphanedNodes.forEach(node => {
105
- const data = Object.fromEntries(node.data.entries());
106
- const lexicalKey = binding.nodeMapper?.getLexicalKeyByLoroId(node.id) || 'no-key';
107
- console.log(` - ${node.id} (${lexicalKey}, ${data.elementType})`);
108
- });
109
- }
110
- // Show parent-child relationships
111
- console.log('\n🌳 Parent-Child Relationships:');
112
- nodes.forEach(node => {
113
- const data = Object.fromEntries(node.data.entries());
114
- const parent = node.parent();
115
- const children = node.children();
116
- const lexicalKey = binding.nodeMapper?.getLexicalKeyByLoroId(node.id) || 'no-key';
117
- console.log(`${node.id} (${lexicalKey}, ${data.elementType || 'no-type'})`);
118
- console.log(` Parent: ${parent ? parent.id : 'None'}`);
119
- console.log(` Children: ${children ? children.map(child => child.id).join(', ') : 'None'}`);
120
- });
121
- },
122
- inspectNode: (treeId) => {
123
- const binding = window.debugLoro.binding;
124
- if (!binding)
125
- return console.log('Loro binding not available');
126
- const tree = binding.tree;
127
- // Cast treeId to TreeID type - in practice this should work if it's a valid ID
128
- const node = tree.getNodeByID(treeId);
129
- if (node) {
130
- const data = Object.fromEntries(node.data.entries());
131
- const parent = node.parent();
132
- const children = node.children();
133
- // Collect lexical properties (new individual property format)
134
- const lexicalProps = {};
135
- Object.entries(data).forEach(([key, value]) => {
136
- if (key.startsWith('lexical_')) {
137
- lexicalProps[key.substring(8)] = value; // Remove 'lexical_' prefix
138
- }
139
- });
140
- // Get lexical key from mapper instead of node data
141
- const lexicalKey = binding.nodeMapper?.getLexicalKeyByLoroId(node.id) || 'no-key';
142
- console.log('🔍 Loro Node Details:', {
143
- treeId: node.id,
144
- lexicalKey: lexicalKey,
145
- elementType: data.elementType,
146
- createdAt: data.createdAt && typeof data.createdAt === 'number' ? new Date(data.createdAt).toLocaleString() : 'N/A',
147
- hasLexicalData: Object.keys(lexicalProps).length > 0 || !!data.lexical,
148
- parent: parent ? parent.id : 'None (Root)',
149
- childrenCount: children ? children.length : 0,
150
- isRoot: data.isRoot || false
151
- });
152
- // Handle different lexical data formats
153
- if (Object.keys(lexicalProps).length > 0) {
154
- console.log('📄 Lexical Data (Individual Properties):', lexicalProps);
155
- }
156
- else if (data.lexical) {
157
- if (typeof data.lexical === 'object') {
158
- console.log('📄 Lexical Data (Current JSON Object):', data.lexical);
159
- }
160
- else if (typeof data.lexical === 'string') {
161
- try {
162
- const lexicalData = JSON.parse(data.lexical);
163
- console.log('📄 Lexical Data (Legacy JSON String):', lexicalData);
164
- }
165
- catch (e) {
166
- console.log('❌ Failed to parse lexical data:', e);
167
- }
168
- }
169
- }
170
- else {
171
- console.log('⚠️ No lexical data found for this node');
172
- }
173
- // Fetch and log the corresponding lexical node
174
- if (lexicalKey && lexicalKey !== 'no-key' && typeof lexicalKey === 'string') {
175
- try {
176
- const editorState = binding.editor.getEditorState();
177
- const nodeInfo = editorState.read(() => {
178
- const lexicalNode = editorState._nodeMap.get(lexicalKey);
179
- if (!lexicalNode) {
180
- return null;
181
- }
182
- const info = {
183
- key: lexicalNode.getKey(),
184
- type: lexicalNode.getType(),
185
- parent: lexicalNode.getParent()?.getKey() || 'None (Root)',
186
- textContent: lexicalNode.getTextContent ? lexicalNode.getTextContent() : 'N/A',
187
- serialized: lexicalNode.exportJSON()
188
- };
189
- // Add children info if it's an ElementNode
190
- if ('getChildren' in lexicalNode && typeof lexicalNode.getChildren === 'function') {
191
- info.children = lexicalNode.getChildren().map((child) => child.getKey());
192
- }
193
- else {
194
- info.children = 'N/A (Not an ElementNode)';
195
- }
196
- return info;
197
- });
198
- if (nodeInfo) {
199
- console.log('🔗 Linked Lexical Node:', nodeInfo);
200
- }
201
- else {
202
- console.log('⚠️ No lexical node found in editor state for key:', lexicalKey, '(node may have been deleted or not yet created)');
203
- }
204
- }
205
- catch (e) {
206
- console.log('❌ Failed to fetch lexical node:', e);
207
- }
208
- }
209
- else {
210
- console.log('⚠️ No valid lexical key found for this Loro node (key:', lexicalKey, ')');
211
- }
212
- }
213
- else {
214
- console.warn(`Node with TreeID "${treeId}" not found`);
215
- }
216
- },
217
- generateTreeHTML: (nodes, rootNode, prefix = '', isLast = true, depth = 0) => {
218
- if (!rootNode) {
219
- // Find root nodes
220
- const rootNodes = nodes.filter(node => {
221
- const parent = node.parent();
222
- const data = Object.fromEntries(node.data.entries());
223
- return !parent || data.isRoot;
224
- });
225
- if (rootNodes.length === 0)
226
- return '<div style="color: #ffaa00;">No root nodes found</div>';
227
- // Display all root nodes
228
- let result = '';
229
- rootNodes.forEach((root, index) => {
230
- const isLastRoot = index === rootNodes.length - 1;
231
- result += window.debugLoro.generateTreeHTML(nodes, root, '', isLastRoot, 0);
232
- });
233
- return result;
234
- }
235
- const data = Object.fromEntries(rootNode.data.entries());
236
- const treeId = rootNode.id;
237
- // Get lexical key from mapper instead of node data
238
- const binding = window.debugLoro.binding;
239
- const lexicalKey = binding?.nodeMapper?.getLexicalKeyByLoroId(treeId) || 'no-key';
240
- const elementType = data.elementType || 'no-type';
241
- const nodeInfo = `TreeID(${treeId.slice(0, 8)}...) → ${lexicalKey} [${elementType}]`;
242
- const clickIntegrator = `onclick="window.debugLoro.inspectNode('${treeId}')"`;
243
- const nodeColor = data.isRoot ? '#00ff88' : '#00ffaa';
244
- const cursor = 'cursor: pointer; text-decoration: underline;';
245
- // Create proper tree structure with indentation
246
- const connector = depth === 0 ? '' : (isLast ? '└── ' : '├── ');
247
- let result = `<div style="color: ${nodeColor}; ${cursor}" ${clickIntegrator}>${prefix}${connector}${nodeInfo}</div>`;
248
- const children = rootNode.children();
249
- if (children && children.length > 0) {
250
- children.forEach((child, index) => {
251
- const isLastChild = index === children.length - 1;
252
- // Calculate prefix for children - if current node is last, use spaces, otherwise use vertical line
253
- // Use &nbsp; for HTML spaces to ensure proper rendering
254
- const childPrefix = prefix + (depth === 0 ? '' : (isLast ? '&nbsp;&nbsp;&nbsp;&nbsp;' : '│&nbsp;&nbsp;&nbsp;'));
255
- result += window.debugLoro.generateTreeHTML(nodes, child, childPrefix, isLastChild, depth + 1);
256
- });
257
- }
258
- return result;
259
- },
260
- addDebugToPage: () => {
261
- const binding = window.debugLoro.binding;
262
- if (!binding)
263
- return;
264
- const tree = binding.tree;
265
- const nodes = tree.nodes();
266
- // Debug: log the actual structure to console as a tree
267
- console.log('🟢 LORO Tree structure:');
268
- console.log(` Total nodes: ${nodes.length}`);
269
- console.log(` Peer ID: ${binding.doc.peerIdStr}`);
270
- console.log(` Client ID: ${binding.clientID}`);
271
- console.log('');
272
- // Helper function to recursively log tree structure
273
- const logTreeStructure = (node, prefix = '', isLast = true, depth = 0) => {
274
- const data = Object.fromEntries(node.data.entries());
275
- const treeId = node.id;
276
- // Get lexical key from mapper instead of node data
277
- const lexicalKey = binding.nodeMapper?.getLexicalKeyByLoroId(treeId) || 'no-key';
278
- const elementType = data.elementType || 'no-type';
279
- const connector = depth === 0 ? '' : (isLast ? '└── ' : '├── ');
280
- const nodeInfo = `TreeID(${treeId.slice(0, 8)}...) → ${lexicalKey} [${elementType}]`;
281
- console.log(`${prefix}${connector}${nodeInfo}`);
282
- const children = node.children();
283
- if (children && children.length > 0) {
284
- children.forEach((child, index) => {
285
- const isLastChild = index === children.length - 1;
286
- const childPrefix = prefix + (depth === 0 ? '' : (isLast ? ' ' : '│ '));
287
- logTreeStructure(child, childPrefix, isLastChild, depth + 1);
288
- });
289
- }
290
- };
291
- // Find and display all root nodes
292
- const rootNodes = nodes.filter((node) => {
293
- const parent = node.parent();
294
- const data = Object.fromEntries(node.data.entries());
295
- return !parent || data.isRoot;
296
- });
297
- if (rootNodes.length === 0) {
298
- console.log(' ⚠️ No root nodes found!');
299
- }
300
- else {
301
- rootNodes.forEach((root, index) => {
302
- const isLastRoot = index === rootNodes.length - 1;
303
- logTreeStructure(root, '', isLastRoot, 0);
304
- });
305
- }
306
- console.log('🟢 Loro Tree:', tree.toJSON());
307
- console.log('🟢 Lexical State:', binding.editor.getEditorState().toJSON());
308
- const treeHTML = window.debugLoro.generateTreeHTML(nodes);
309
- const debugDiv = document.getElementById('debug-loro') || document.createElement('div');
310
- const existingDiv = document.getElementById('debug-loro');
311
- // Preserve current position if panel already exists
312
- let currentLeft = '10px';
313
- let currentTop = '700px';
314
- if (existingDiv) {
315
- currentLeft = existingDiv.style.left || '10px';
316
- currentTop = existingDiv.style.top || '10px';
317
- }
318
- debugDiv.id = 'debug-loro';
319
- debugDiv.style.cssText = `position: fixed; top: ${currentTop}; left: ${currentLeft}; background: rgba(0,0,0,0.95); color: #00ff00; padding: 0; border-radius: 8px; font-family: "Courier New", monospace; font-size: 11px; z-index: 9999; max-width: 500px; max-height: 80vh; box-shadow: 0 4px 8px rgba(0,0,0,0.5); border: 1px solid #00ff00; user-select: none;`;
320
- // Add drag functionality if not already added
321
- if (!debugDiv.classList.contains('draggable-initialized')) {
322
- debugDiv.classList.add('draggable-initialized');
323
- let isDragging = false;
324
- let startX = 0;
325
- let startY = 0;
326
- let startLeft = 0;
327
- let startTop = 0;
328
- debugDiv.addEventListener('mousedown', (e) => {
329
- // Only start drag if clicking on the header area
330
- const target = e.target;
331
- const dragHandle = debugDiv.querySelector('.debug-drag-integrate');
332
- if (!dragHandle || !dragHandle.contains(target))
333
- return;
334
- isDragging = true;
335
- startX = e.clientX;
336
- startY = e.clientY;
337
- const rect = debugDiv.getBoundingClientRect();
338
- startLeft = rect.left;
339
- startTop = rect.top;
340
- document.addEventListener('mousemove', onMouseMove);
341
- document.addEventListener('mouseup', onMouseUp);
342
- e.preventDefault();
343
- });
344
- function onMouseMove(e) {
345
- if (!isDragging)
346
- return;
347
- const deltaX = e.clientX - startX;
348
- const deltaY = e.clientY - startY;
349
- const newLeft = Math.max(0, Math.min(window.innerWidth - debugDiv.offsetWidth, startLeft + deltaX));
350
- const newTop = Math.max(0, Math.min(window.innerHeight - debugDiv.offsetHeight, startTop + deltaY));
351
- debugDiv.style.left = newLeft + 'px';
352
- debugDiv.style.top = newTop + 'px';
353
- }
354
- function onMouseUp() {
355
- isDragging = false;
356
- document.removeEventListener('mousemove', onMouseMove);
357
- document.removeEventListener('mouseup', onMouseUp);
358
- }
359
- }
360
- debugDiv.innerHTML = `
361
- <div class="debug-drag-integrate" style="color: #00ff88; font-weight: bold; margin-bottom: 10px; border-bottom: 1px solid #00ff00; padding: 15px 15px 5px 15px; cursor: move; background: linear-gradient(90deg, rgba(0,255,136,0.1), transparent);">
362
- 🟢 LORO TREE <span style="float: right; font-size: 9px; color: #666;">⋮⋮ drag</span>
363
- </div>
364
- <div style="padding: 0 15px 15px 15px; overflow-y: auto; max-height: calc(80vh - 50px);">
365
- <div style="color: #00ffaa; margin-bottom: 8px;">Total nodes: ${nodes.length}</div>
366
- <div style="color: #00ff66; margin-bottom: 8px;">Peer ID: ${binding.doc.peerIdStr.slice(0, 8)}...</div>
367
- <div style="color: #00ffdd; margin-bottom: 10px;">Time: ${new Date().toLocaleTimeString()}</div>
368
- <div style="border-top: 1px solid #444; padding-top: 8px; line-height: 1.4; font-family: 'Courier New', monospace;">
369
- ${treeHTML}
370
- </div>
371
- <div style="margin-top: 10px; font-size: 10px; color: #666;">
372
- <span onclick="window.debugLoro.addDebugToPage()" style="color: #00ffaa; cursor: pointer; text-decoration: underline;">🔄 Refresh</span> |
373
- <span onclick="window.debugLoro.verifyStructure()" style="color: #00ff66; cursor: pointer; text-decoration: underline;">✅ Verify</span> |
374
- <span onclick="window.debugLoro.logStructure()" style="color: #00ffdd; cursor: pointer; text-decoration: underline;">📝 Log</span> |
375
- <span onclick="window.debugLoro.cleanupEphemeralStore()" style="color: #ffaa00; cursor: pointer; text-decoration: underline;">🧹 Cleanup</span> |
376
- <span onclick="window.debugLoro.resetGlobalEphemeralStore()" style="color: #ff6600; cursor: pointer; text-decoration: underline;">🔄 Reset</span> |
377
- <span onclick="document.getElementById('debug-loro').remove()" style="color: #ff0066; cursor: pointer; text-decoration: underline;">❌ Close</span>
378
- </div>
379
- </div>
380
- `;
381
- document.body.appendChild(debugDiv);
382
- },
383
- cleanupEphemeralStore: (provider) => {
384
- if (!provider) {
385
- console.log('⚠️ No provider passed. Usage: window.debugLoro.cleanupEphemeralStore(provider)');
386
- console.log('You can get the provider from your useCollaboration hook');
387
- return;
388
- }
389
- if (typeof provider.cleanupStaleStates !== 'function') {
390
- console.log('❌ Provider does not have cleanupStaleStates method');
391
- return;
392
- }
393
- console.log('🧹 Cleaning up stale ephemeral states...');
394
- provider.cleanupStaleStates();
395
- },
396
- resetGlobalEphemeralStore: () => {
397
- try {
398
- // We need to access the WebsocketProvider class which may not be globally available
399
- console.log('🔄 Attempting to reset global EphemeralStore...');
400
- console.log('💡 You can also refresh the browser to clear the global store');
401
- // For now, instruct user to refresh
402
- alert('To reset the global ephemeral store and clear all collaborators, please refresh the browser page.');
403
- }
404
- catch (error) {
405
- console.warn('❌ Reset failed:', error.message);
406
- }
407
- }
408
- };
409
- // Expose binding for debugging
410
- window.debugLoro.binding = binding;
411
- // Auto-initialize debug window after a short delay
412
- setTimeout(() => {
413
- window.debugLoro.addDebugToPage();
414
- }, 2000); // Slightly later than Y.js to avoid overlap
415
- }
416
- /**
417
- * Quick access function to add debug panel to page
418
- */
419
- export function addDebugPanel() {
420
- if (window.debugLoro?.addDebugToPage) {
421
- window.debugLoro.addDebugToPage();
422
- }
423
- else {
424
- console.warn('Debug utilities not initialized. Call setupLoroDebugging first.');
425
- }
426
- }
427
- /**
428
- * Quick access function to log tree structure
429
- */
430
- export function logTreeStructure() {
431
- if (window.debugLoro?.logStructure) {
432
- window.debugLoro.logStructure();
433
- }
434
- else {
435
- console.warn('Debug utilities not initialized. Call setupLoroDebugging first.');
436
- }
437
- }
438
- /**
439
- * Quick access function to verify tree structure
440
- */
441
- export function verifyTreeStructure() {
442
- if (window.debugLoro?.verifyStructure) {
443
- window.debugLoro.verifyStructure();
444
- }
445
- else {
446
- console.warn('Debug utilities not initialized. Call setupLoroDebugging first.');
447
- }
448
- }
@@ -1,19 +0,0 @@
1
- import type { LoroDoc } from 'loro-crdt';
2
- export type CollaborationContextType = {
3
- clientID: number;
4
- color: string;
5
- isCollabActive: boolean;
6
- name: string;
7
- docMap: Map<string, LoroDoc>;
8
- };
9
- /**
10
- * Generate a deterministic name and color based on a client ID
11
- * This ensures the same client ID always gets the same name across browser sessions
12
- */
13
- declare function generateDeterministicUserData(clientId: number): {
14
- name: string;
15
- color: string;
16
- };
17
- export declare const CollaborationContext: import("react").Context<CollaborationContextType>;
18
- export { generateDeterministicUserData };
19
- export declare function useCollaborationContext(username?: string, color?: string): CollaborationContextType;
@@ -1,48 +0,0 @@
1
- import { createContext, useContext } from 'react';
2
- const ANIMAL_NAMES = [
3
- 'Cat', 'Dog', 'Rabbit', 'Frog', 'Fox', 'Hedgehog', 'Pigeon', 'Squirrel',
4
- 'Bear', 'Tiger', 'Leopard', 'Zebra', 'Wolf', 'Owl', 'Gull', 'Squid',
5
- 'Panda', 'Lion', 'Eagle', 'Shark', 'Dolphin', 'Penguin', 'Koala', 'Kangaroo'
6
- ];
7
- const COLORS = [
8
- 'rgb(125, 50, 0)', 'rgb(100, 0, 0)', 'rgb(150, 0, 0)', 'rgb(200, 0, 0)',
9
- 'rgb(200, 75, 0)', 'rgb(0, 75, 0)', 'rgb(0, 125, 0)', 'rgb(75, 100, 0)',
10
- 'rgb(125, 100, 0)', 'rgb(0, 0, 150)', 'rgb(0, 0, 200)', 'rgb(0, 0, 250)',
11
- 'rgb(0, 100, 150)', 'rgb(0, 100, 100)', 'rgb(100, 0, 100)', 'rgb(150, 0, 150)',
12
- 'rgb(255, 99, 71)', 'rgb(60, 179, 113)', 'rgb(30, 144, 255)', 'rgb(255, 165, 0)',
13
- 'rgb(138, 43, 226)', 'rgb(255, 20, 147)', 'rgb(0, 191, 255)', 'rgb(50, 205, 50)'
14
- ];
15
- /**
16
- * Generate a deterministic name and color based on a client ID
17
- * This ensures the same client ID always gets the same name across browser sessions
18
- */
19
- function generateDeterministicUserData(clientId) {
20
- // Use clientId as seed for deterministic selection
21
- const nameIndex = Math.abs(clientId) % ANIMAL_NAMES.length;
22
- const colorIndex = Math.abs(clientId) % COLORS.length;
23
- // Add a short ID suffix for uniqueness in case of collisions
24
- const shortId = Math.abs(clientId).toString().slice(-4);
25
- const name = `${ANIMAL_NAMES[nameIndex]}-${shortId}`;
26
- const color = COLORS[colorIndex];
27
- return { name, color };
28
- }
29
- // Use a temporary fallback for initial context (will be updated when client connects)
30
- const fallbackUserData = generateDeterministicUserData(Math.floor(Math.random() * 100000));
31
- export const CollaborationContext = createContext({
32
- clientID: 0,
33
- color: fallbackUserData.color,
34
- isCollabActive: false,
35
- name: fallbackUserData.name,
36
- docMap: new Map(),
37
- });
38
- export { generateDeterministicUserData };
39
- export function useCollaborationContext(username, color) {
40
- const collabContext = useContext(CollaborationContext);
41
- if (username != null) {
42
- collabContext.name = username;
43
- }
44
- if (color != null) {
45
- collabContext.color = color;
46
- }
47
- return collabContext;
48
- }
@@ -1,24 +0,0 @@
1
- import type { JSX } from 'react';
2
- import { InitialEditorStateType } from '@lexical/react/LexicalComposer';
3
- import type { LoroDoc } from 'loro-crdt';
4
- import { Provider } from './State';
5
- import { CursorsContainerRef } from './useCollaboration';
6
- import { SyncCursorPositionsFn } from './sync/SyncCursors';
7
- import { ExcludedProperties } from './Bindings';
8
- type Props = {
9
- id: string;
10
- providerFactory: (id: string, docMap: Map<string, LoroDoc>, websocketUrl?: string) => Provider;
11
- shouldBootstrap: boolean;
12
- username?: string;
13
- cursorColor?: string;
14
- cursorsContainerRef?: CursorsContainerRef;
15
- initialEditorState?: InitialEditorStateType;
16
- excludedProperties?: ExcludedProperties;
17
- awarenessData?: object;
18
- syncCursorPositionsFn?: SyncCursorPositionsFn;
19
- showCollaborators?: boolean;
20
- websocketUrl?: string;
21
- onInitialization?: (isInitialized: boolean) => void;
22
- };
23
- export declare function LoroCollaborationPlugin({ id, providerFactory, shouldBootstrap, username, cursorColor, cursorsContainerRef, initialEditorState, excludedProperties, awarenessData, syncCursorPositionsFn, showCollaborators, websocketUrl, onInitialization, }: Props): JSX.Element;
24
- export {};
@@ -1,83 +0,0 @@
1
- import { Fragment as _Fragment, jsx as _jsx } from "react/jsx-runtime";
2
- import { useEffect, useRef, useState } from 'react';
3
- import { useLexicalComposerContext } from '@lexical/react/LexicalComposerContext';
4
- import { useCollaborationContext, generateDeterministicUserData, } from './LexicalCollaborationContext';
5
- import { updateLocalStateName } from './State';
6
- import { useCollaboration, useFocusTracking, useHistory, } from './useCollaboration';
7
- import { createBinding, LoroCollaborationUI } from './Bindings';
8
- export function LoroCollaborationPlugin({ id, providerFactory, shouldBootstrap, username, cursorColor, cursorsContainerRef, initialEditorState, excludedProperties, awarenessData, syncCursorPositionsFn, showCollaborators = true, websocketUrl = 'ws://localhost:3002', onInitialization, }) {
9
- const isBindingInitialized = useRef(false);
10
- const isProviderInitialized = useRef(false);
11
- const collabContext = useCollaborationContext(username, cursorColor);
12
- const { docMap, name, color } = collabContext;
13
- const [editor] = useLexicalComposerContext();
14
- useEffect(() => {
15
- collabContext.isCollabActive = true;
16
- return () => {
17
- // Resetting flag only when unmount top level editor collab plugin. Nested
18
- // editors (e.g. image caption) should unmount without affecting it
19
- if (editor._parentEditor == null) {
20
- collabContext.isCollabActive = false;
21
- }
22
- };
23
- }, [collabContext, editor]);
24
- const [provider, setProvider] = useState();
25
- const [doc, setDoc] = useState();
26
- useEffect(() => {
27
- if (isProviderInitialized.current) {
28
- return;
29
- }
30
- isProviderInitialized.current = true;
31
- const provider = providerFactory(id, docMap, websocketUrl);
32
- setProvider(provider);
33
- setDoc(docMap.get(id));
34
- return () => {
35
- provider.disconnect();
36
- };
37
- }, [id, providerFactory, docMap, websocketUrl]);
38
- const [binding, setBinding] = useState();
39
- useEffect(() => {
40
- if (!provider) {
41
- return;
42
- }
43
- if (isBindingInitialized.current) {
44
- return;
45
- }
46
- isBindingInitialized.current = true;
47
- const binding = createBinding(editor, provider, id, doc || docMap.get(id), docMap, excludedProperties);
48
- // Update collaboration context with deterministic name based on client ID
49
- // This ensures consistent names across browser sessions
50
- const deterministicUserData = generateDeterministicUserData(binding.clientID);
51
- console.log('Setting deterministic user data based on client ID:', {
52
- clientId: binding.clientID,
53
- name: deterministicUserData.name,
54
- color: deterministicUserData.color
55
- });
56
- // Update the collaboration context with stable name and color
57
- const finalName = username || deterministicUserData.name;
58
- const finalColor = cursorColor || deterministicUserData.color;
59
- collabContext.name = finalName;
60
- collabContext.color = finalColor;
61
- collabContext.clientID = binding.clientID;
62
- // Update the awareness state immediately with the deterministic name
63
- updateLocalStateName(provider, finalName, finalColor);
64
- setBinding(binding);
65
- return () => {
66
- // Clean up binding resources if needed
67
- };
68
- }, [editor, provider, id, docMap, doc, excludedProperties, collabContext, username, cursorColor]);
69
- if (!provider || !binding) {
70
- return _jsx(_Fragment, {});
71
- }
72
- return (_jsx(LoroCollaborationCursors, { awarenessData: awarenessData, binding: binding, collabContext: collabContext, color: color, cursorsContainerRef: cursorsContainerRef, editor: editor, id: id, initialEditorState: initialEditorState, name: name, provider: provider, setDoc: setDoc, shouldBootstrap: shouldBootstrap, docMap: docMap, syncCursorPositionsFn: syncCursorPositionsFn, showCollaborators: showCollaborators, onInitialization: onInitialization }));
73
- }
74
- function LoroCollaborationCursors({ editor, id, provider, docMap, name, color, shouldBootstrap, cursorsContainerRef, initialEditorState, awarenessData, collabContext, binding, setDoc, syncCursorPositionsFn, showCollaborators = false, onInitialization, }) {
75
- const cursorsElement = useCollaboration(editor, id, provider, docMap, name, color, shouldBootstrap, binding, setDoc, cursorsContainerRef, initialEditorState, awarenessData, syncCursorPositionsFn, onInitialization);
76
- collabContext.clientID = binding.clientID;
77
- useHistory(editor, binding);
78
- useFocusTracking(editor, provider, name, color, awarenessData);
79
- if (showCollaborators) {
80
- return (_jsx(LoroCollaborationUI, { binding: binding, cursorsContainer: cursorsElement, currentUserName: name, currentUserColor: color, showCollaborators: true }));
81
- }
82
- return cursorsElement;
83
- }