@dxos/react-ui-editor 0.8.4-main.b97322e → 0.8.4-main.bcb3aa67d6

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 (401) hide show
  1. package/dist/lib/browser/index.mjs +1337 -7593
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/node-esm/index.mjs +1337 -7592
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/types/src/components/Editor/Editor.d.ts +43 -15
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +23 -0
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +31 -0
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
  13. package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
  14. package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
  15. package/dist/types/src/components/EditorContent/index.d.ts +3 -0
  16. package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +34 -0
  18. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
  20. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  22. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  23. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  24. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +46 -0
  26. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  28. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  30. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  32. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  33. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +28 -2
  34. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  35. package/dist/types/src/components/EditorToolbar/blocks.d.ts +4 -17
  36. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  37. package/dist/types/src/components/EditorToolbar/formatting.d.ts +4 -17
  38. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/headings.d.ts +4 -17
  40. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/image.d.ts +3 -15
  42. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/index.d.ts +1 -1
  44. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/lists.d.ts +4 -17
  46. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/search.d.ts +3 -15
  48. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  49. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
  50. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
  51. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +5 -18
  52. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  53. package/dist/types/src/components/index.d.ts +4 -2
  54. package/dist/types/src/components/index.d.ts.map +1 -1
  55. package/dist/types/src/hooks/useTextEditor.d.ts +6 -10
  56. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  57. package/dist/types/src/index.d.ts +0 -8
  58. package/dist/types/src/index.d.ts.map +1 -1
  59. package/dist/types/src/stories/Automerge.stories.d.ts +44 -0
  60. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  61. package/dist/types/src/stories/Comments.stories.d.ts +22 -10
  62. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  63. package/dist/types/src/stories/EditorToolbar.stories.d.ts +40 -4
  64. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/Experimental.stories.d.ts +23 -13
  66. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  67. package/dist/types/src/stories/Markdown.stories.d.ts +33 -43
  68. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  69. package/dist/types/src/stories/Outliner.stories.d.ts +16 -22
  70. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  72. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  73. package/dist/types/src/stories/Preview.stories.d.ts +23 -7
  74. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  75. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  76. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  77. package/dist/types/src/stories/TextEditor.stories.d.ts +38 -52
  78. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  80. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  81. package/dist/types/src/stories/components/EditorStory.d.ts +11 -23
  82. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  83. package/dist/types/src/stories/components/util.d.ts +3 -3
  84. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  85. package/dist/types/src/translations.d.ts +26 -26
  86. package/dist/types/src/translations.d.ts.map +1 -1
  87. package/dist/types/src/util/index.d.ts +0 -4
  88. package/dist/types/src/util/index.d.ts.map +1 -1
  89. package/dist/types/src/util/react.d.ts +7 -6
  90. package/dist/types/src/util/react.d.ts.map +1 -1
  91. package/dist/types/tsconfig.tsbuildinfo +1 -1
  92. package/package.json +84 -80
  93. package/src/components/Editor/Editor.stories.tsx +95 -0
  94. package/src/components/Editor/Editor.tsx +170 -24
  95. package/src/components/EditorContent/EditorContent.tsx +83 -0
  96. package/src/components/EditorContent/controller.ts +50 -0
  97. package/src/components/EditorContent/index.ts +6 -0
  98. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +226 -0
  99. package/src/components/EditorMenuProvider/index.ts +10 -0
  100. package/src/components/EditorMenuProvider/menu-presets.ts +125 -0
  101. package/src/components/EditorMenuProvider/menu.ts +70 -0
  102. package/src/components/EditorMenuProvider/popover.ts +285 -0
  103. package/src/components/EditorMenuProvider/useEditorMenu.ts +180 -0
  104. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
  105. package/src/components/EditorPreviewProvider/index.ts +5 -0
  106. package/src/components/EditorToolbar/EditorToolbar.tsx +90 -103
  107. package/src/components/EditorToolbar/blocks.ts +53 -48
  108. package/src/components/EditorToolbar/formatting.ts +42 -46
  109. package/src/components/EditorToolbar/headings.ts +46 -44
  110. package/src/components/EditorToolbar/image.ts +16 -10
  111. package/src/components/EditorToolbar/index.ts +2 -7
  112. package/src/components/EditorToolbar/lists.ts +39 -41
  113. package/src/components/EditorToolbar/search.ts +16 -10
  114. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  115. package/src/components/EditorToolbar/view-mode.ts +39 -39
  116. package/src/components/index.ts +6 -2
  117. package/src/hooks/useTextEditor.ts +39 -45
  118. package/src/index.ts +0 -10
  119. package/src/stories/Automerge.stories.tsx +173 -0
  120. package/src/stories/Comments.stories.tsx +59 -51
  121. package/src/stories/EditorToolbar.stories.tsx +72 -41
  122. package/src/stories/Experimental.stories.tsx +18 -16
  123. package/src/stories/Markdown.stories.tsx +37 -33
  124. package/src/stories/Outliner.stories.tsx +55 -44
  125. package/src/stories/Popover.stories.tsx +158 -0
  126. package/src/stories/Preview.stories.tsx +112 -92
  127. package/src/stories/Tags.stories.tsx +104 -0
  128. package/src/stories/TextEditor.stories.tsx +50 -75
  129. package/src/stories/Theme.stories.tsx +61 -0
  130. package/src/stories/components/EditorStory.tsx +48 -35
  131. package/src/stories/components/util.tsx +60 -31
  132. package/src/translations.ts +30 -25
  133. package/src/util/index.ts +1 -5
  134. package/src/util/react.tsx +9 -14
  135. package/dist/lib/browser/chunk-22UMM3QJ.mjs +0 -22
  136. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  137. package/dist/lib/browser/testing/index.mjs +0 -6
  138. package/dist/lib/browser/testing/index.mjs.map +0 -7
  139. package/dist/lib/browser/types/index.mjs +0 -13
  140. package/dist/lib/browser/types/index.mjs.map +0 -7
  141. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs +0 -24
  142. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  143. package/dist/lib/node-esm/testing/index.mjs +0 -8
  144. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  145. package/dist/lib/node-esm/types/index.mjs +0 -14
  146. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  147. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  148. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  149. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  150. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  151. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  152. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  153. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  154. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  155. package/dist/types/src/components/Popover/index.d.ts +0 -4
  156. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  157. package/dist/types/src/defaults.d.ts +0 -14
  158. package/dist/types/src/defaults.d.ts.map +0 -1
  159. package/dist/types/src/extensions/annotations.d.ts +0 -9
  160. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  161. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  162. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  163. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  164. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  165. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +0 -56
  166. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  167. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  168. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  169. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  170. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  171. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  172. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  173. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  174. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  175. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  176. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  177. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  178. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  179. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  180. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  181. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  182. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  183. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  184. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  185. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  186. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  187. package/dist/types/src/extensions/blast.d.ts +0 -25
  188. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  189. package/dist/types/src/extensions/command/action.d.ts +0 -17
  190. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  191. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  192. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  193. package/dist/types/src/extensions/command/command.d.ts +0 -6
  194. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  195. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  196. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  197. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  198. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  199. package/dist/types/src/extensions/command/index.d.ts +0 -7
  200. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  201. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  202. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  203. package/dist/types/src/extensions/command/state.d.ts +0 -16
  204. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  205. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  206. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  207. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  208. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  209. package/dist/types/src/extensions/comments.d.ts +0 -95
  210. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  211. package/dist/types/src/extensions/debug.d.ts +0 -3
  212. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  213. package/dist/types/src/extensions/dnd.d.ts +0 -9
  214. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  215. package/dist/types/src/extensions/factories.d.ts +0 -83
  216. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  217. package/dist/types/src/extensions/focus.d.ts +0 -7
  218. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  219. package/dist/types/src/extensions/folding.d.ts +0 -7
  220. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  221. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  222. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  223. package/dist/types/src/extensions/index.d.ts +0 -23
  224. package/dist/types/src/extensions/index.d.ts.map +0 -1
  225. package/dist/types/src/extensions/json.d.ts +0 -7
  226. package/dist/types/src/extensions/json.d.ts.map +0 -1
  227. package/dist/types/src/extensions/listener.d.ts +0 -11
  228. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  229. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  230. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  231. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -16
  232. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  233. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  234. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  235. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  236. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  237. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  238. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  239. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -17
  240. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  241. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  242. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  243. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  244. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  245. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  246. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  247. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  248. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  249. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  250. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  251. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  252. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  253. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  254. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  255. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  256. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  257. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  258. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  259. package/dist/types/src/extensions/mention.d.ts +0 -7
  260. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  261. package/dist/types/src/extensions/modes.d.ts +0 -10
  262. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  263. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  264. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  265. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  266. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  267. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  268. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  269. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  270. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  271. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  272. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  273. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  274. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  275. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  276. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  277. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  278. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  279. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  280. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  281. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  282. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  283. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  284. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  285. package/dist/types/src/extensions/selection.d.ts +0 -24
  286. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  287. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  288. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  289. package/dist/types/src/stories/Command.stories.d.ts +0 -7
  290. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  291. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  292. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  293. package/dist/types/src/styles/index.d.ts +0 -4
  294. package/dist/types/src/styles/index.d.ts.map +0 -1
  295. package/dist/types/src/styles/markdown.d.ts +0 -8
  296. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  297. package/dist/types/src/styles/theme.d.ts +0 -38
  298. package/dist/types/src/styles/theme.d.ts.map +0 -1
  299. package/dist/types/src/styles/tokens.d.ts +0 -3
  300. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  301. package/dist/types/src/testing/index.d.ts +0 -2
  302. package/dist/types/src/testing/index.d.ts.map +0 -1
  303. package/dist/types/src/testing/util.d.ts +0 -2
  304. package/dist/types/src/testing/util.d.ts.map +0 -1
  305. package/dist/types/src/types/index.d.ts +0 -2
  306. package/dist/types/src/types/index.d.ts.map +0 -1
  307. package/dist/types/src/types/types.d.ts +0 -21
  308. package/dist/types/src/types/types.d.ts.map +0 -1
  309. package/dist/types/src/util/cursor.d.ts +0 -31
  310. package/dist/types/src/util/cursor.d.ts.map +0 -1
  311. package/dist/types/src/util/debug.d.ts +0 -17
  312. package/dist/types/src/util/debug.d.ts.map +0 -1
  313. package/dist/types/src/util/dom.d.ts +0 -20
  314. package/dist/types/src/util/dom.d.ts.map +0 -1
  315. package/dist/types/src/util/facet.d.ts +0 -3
  316. package/dist/types/src/util/facet.d.ts.map +0 -1
  317. package/src/components/EditorToolbar/util.ts +0 -65
  318. package/src/components/Popover/CommandMenu.tsx +0 -279
  319. package/src/components/Popover/RefDropdownMenu.tsx +0 -85
  320. package/src/components/Popover/RefPopover.tsx +0 -99
  321. package/src/components/Popover/index.ts +0 -7
  322. package/src/defaults.ts +0 -49
  323. package/src/extensions/annotations.ts +0 -55
  324. package/src/extensions/autocomplete.ts +0 -69
  325. package/src/extensions/automerge/automerge.stories.tsx +0 -142
  326. package/src/extensions/automerge/automerge.test.tsx +0 -78
  327. package/src/extensions/automerge/automerge.ts +0 -85
  328. package/src/extensions/automerge/cursor.ts +0 -28
  329. package/src/extensions/automerge/defs.ts +0 -31
  330. package/src/extensions/automerge/index.ts +0 -5
  331. package/src/extensions/automerge/sync.ts +0 -75
  332. package/src/extensions/automerge/update-automerge.ts +0 -50
  333. package/src/extensions/automerge/update-codemirror.ts +0 -115
  334. package/src/extensions/awareness/awareness-provider.ts +0 -127
  335. package/src/extensions/awareness/awareness.ts +0 -315
  336. package/src/extensions/awareness/index.ts +0 -6
  337. package/src/extensions/blast.ts +0 -363
  338. package/src/extensions/command/action.ts +0 -56
  339. package/src/extensions/command/command-menu.ts +0 -210
  340. package/src/extensions/command/command.ts +0 -34
  341. package/src/extensions/command/floating-menu.ts +0 -133
  342. package/src/extensions/command/hint.ts +0 -102
  343. package/src/extensions/command/index.ts +0 -10
  344. package/src/extensions/command/placeholder.ts +0 -113
  345. package/src/extensions/command/state.ts +0 -89
  346. package/src/extensions/command/typeahead.ts +0 -129
  347. package/src/extensions/command/useCommandMenu.ts +0 -118
  348. package/src/extensions/comments.ts +0 -592
  349. package/src/extensions/debug.ts +0 -15
  350. package/src/extensions/dnd.ts +0 -37
  351. package/src/extensions/factories.ts +0 -259
  352. package/src/extensions/focus.ts +0 -35
  353. package/src/extensions/folding.tsx +0 -46
  354. package/src/extensions/hashtag.tsx +0 -68
  355. package/src/extensions/index.ts +0 -26
  356. package/src/extensions/json.ts +0 -57
  357. package/src/extensions/listener.ts +0 -38
  358. package/src/extensions/markdown/action.ts +0 -116
  359. package/src/extensions/markdown/bundle.ts +0 -71
  360. package/src/extensions/markdown/changes.test.ts +0 -26
  361. package/src/extensions/markdown/changes.ts +0 -149
  362. package/src/extensions/markdown/debug.ts +0 -44
  363. package/src/extensions/markdown/decorate.ts +0 -591
  364. package/src/extensions/markdown/formatting.test.ts +0 -498
  365. package/src/extensions/markdown/formatting.ts +0 -1267
  366. package/src/extensions/markdown/highlight.ts +0 -183
  367. package/src/extensions/markdown/image.ts +0 -119
  368. package/src/extensions/markdown/index.ts +0 -13
  369. package/src/extensions/markdown/link.ts +0 -47
  370. package/src/extensions/markdown/parser.test.ts +0 -75
  371. package/src/extensions/markdown/styles.ts +0 -135
  372. package/src/extensions/markdown/table.ts +0 -144
  373. package/src/extensions/mention.ts +0 -41
  374. package/src/extensions/modes.ts +0 -41
  375. package/src/extensions/outliner/commands.ts +0 -270
  376. package/src/extensions/outliner/editor.test.ts +0 -33
  377. package/src/extensions/outliner/editor.ts +0 -184
  378. package/src/extensions/outliner/index.ts +0 -7
  379. package/src/extensions/outliner/outliner.test.ts +0 -99
  380. package/src/extensions/outliner/outliner.ts +0 -166
  381. package/src/extensions/outliner/selection.ts +0 -50
  382. package/src/extensions/outliner/tree.test.ts +0 -167
  383. package/src/extensions/outliner/tree.ts +0 -317
  384. package/src/extensions/preview/index.ts +0 -5
  385. package/src/extensions/preview/preview.ts +0 -193
  386. package/src/extensions/selection.ts +0 -100
  387. package/src/extensions/typewriter.ts +0 -68
  388. package/src/stories/Command.stories.tsx +0 -97
  389. package/src/stories/CommandMenu.stories.tsx +0 -159
  390. package/src/styles/index.ts +0 -7
  391. package/src/styles/markdown.ts +0 -26
  392. package/src/styles/theme.ts +0 -265
  393. package/src/styles/tokens.ts +0 -17
  394. package/src/testing/index.ts +0 -5
  395. package/src/testing/util.ts +0 -5
  396. package/src/types/index.ts +0 -5
  397. package/src/types/types.ts +0 -32
  398. package/src/util/cursor.ts +0 -55
  399. package/src/util/debug.ts +0 -64
  400. package/src/util/dom.ts +0 -56
  401. package/src/util/facet.ts +0 -13
@@ -1,85 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { createContext } from '@radix-ui/react-context';
6
- import React, { type PropsWithChildren, useRef, useState, useEffect, useCallback, type RefObject } from 'react';
7
-
8
- import { addEventListener } from '@dxos/async';
9
- import { type DxRefTag, type DxRefTagActivate } from '@dxos/lit-ui';
10
- import { DropdownMenu } from '@dxos/react-ui';
11
-
12
- import { type PreviewLinkRef, type PreviewLinkTarget, type PreviewLookup } from '../../extensions';
13
-
14
- // TODO(burdon): Reconcile this file with RefPopover?
15
-
16
- const customEventOptions = { capture: true, passive: false };
17
-
18
- // Create a context for the dxn value.
19
- type RefDropdownMenuValue = Partial<{
20
- link: PreviewLinkRef;
21
- target: PreviewLinkTarget;
22
- pending: boolean;
23
- }>;
24
-
25
- const REF_DROPDOWN_MENU = 'RefDropdownMenu';
26
- const [RefDropdownMenuContextProvider, useRefDropdownMenu] = createContext<RefDropdownMenuValue>(REF_DROPDOWN_MENU, {});
27
-
28
- type RefDropdownMenuProviderProps = PropsWithChildren<{
29
- onLookup?: PreviewLookup;
30
- }>;
31
-
32
- const RefDropdownMenuProvider = ({ children, onLookup }: RefDropdownMenuProviderProps) => {
33
- const trigger = useRef<DxRefTag | null>(null);
34
- const [value, setValue] = useState<RefDropdownMenuValue>({});
35
- const [rootRef, setRootRef] = useState<HTMLDivElement | null>(null);
36
- const [open, setOpen] = useState(false);
37
-
38
- const handleDxRefTagActivate = useCallback(
39
- (event: DxRefTagActivate) => {
40
- const { refId, label, trigger: dxTrigger } = event;
41
- setValue((value) => ({
42
- ...value,
43
- link: { label, ref: refId },
44
- pending: true,
45
- }));
46
- trigger.current = dxTrigger;
47
- queueMicrotask(() => setOpen(true));
48
- void onLookup?.({ label, ref: refId }).then((target) =>
49
- setValue((value) => ({
50
- ...value,
51
- target: target ?? undefined,
52
- pending: false,
53
- })),
54
- );
55
- },
56
- [onLookup],
57
- );
58
-
59
- useEffect(() => {
60
- if (!rootRef) {
61
- return;
62
- }
63
-
64
- return addEventListener(rootRef, 'dx-ref-tag-activate' as any, handleDxRefTagActivate, customEventOptions);
65
- }, [rootRef]);
66
-
67
- return (
68
- <RefDropdownMenuContextProvider pending={value.pending} link={value.link} target={value.target}>
69
- <DropdownMenu.Root open={open} onOpenChange={setOpen}>
70
- <DropdownMenu.VirtualTrigger virtualRef={trigger as unknown as RefObject<HTMLButtonElement>} />
71
- <div role='none' className='contents' ref={setRootRef}>
72
- {children}
73
- </div>
74
- </DropdownMenu.Root>
75
- </RefDropdownMenuContextProvider>
76
- );
77
- };
78
-
79
- export const RefDropdownMenu = {
80
- Provider: RefDropdownMenuProvider,
81
- };
82
-
83
- export { useRefDropdownMenu };
84
-
85
- export type { RefDropdownMenuProviderProps, RefDropdownMenuValue };
@@ -1,99 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { createContext } from '@radix-ui/react-context';
6
- import React, {
7
- type PropsWithChildren,
8
- useRef,
9
- useState,
10
- useEffect,
11
- useCallback,
12
- type RefObject,
13
- forwardRef,
14
- } from 'react';
15
-
16
- import { addEventListener } from '@dxos/async';
17
- import { type DxRefTag, type DxRefTagActivate } from '@dxos/lit-ui';
18
- import { Popover } from '@dxos/react-ui';
19
-
20
- import { type PreviewLinkRef, type PreviewLinkTarget, type PreviewLookup } from '../../extensions';
21
-
22
- const customEventOptions = { capture: true, passive: false };
23
-
24
- export type RefPopoverProps = PropsWithChildren<{
25
- modal?: boolean;
26
- open?: boolean;
27
- onOpenChange?: (open: boolean) => void;
28
- onActivate?: (event: DxRefTagActivate) => void;
29
- }>;
30
-
31
- export const RefPopover = forwardRef<DxRefTag | null, RefPopoverProps>(
32
- ({ children, open, onOpenChange, modal, onActivate }, ref) => {
33
- const [rootRef, setRootRef] = useState<HTMLDivElement | null>(null);
34
-
35
- useEffect(() => {
36
- if (!rootRef || !onActivate) {
37
- return;
38
- }
39
-
40
- return addEventListener(rootRef, 'dx-ref-tag-activate' as any, onActivate, customEventOptions);
41
- }, [rootRef, onActivate]);
42
-
43
- return (
44
- <Popover.Root open={open} onOpenChange={onOpenChange} modal={modal}>
45
- <Popover.VirtualTrigger virtualRef={ref as unknown as RefObject<HTMLButtonElement>} />
46
- <div role='none' className='contents' ref={setRootRef}>
47
- {children}
48
- </div>
49
- </Popover.Root>
50
- );
51
- },
52
- );
53
-
54
- // Create a context for the dxn value.
55
- type RefPopoverValue = Partial<{ link: PreviewLinkRef; target: PreviewLinkTarget; pending: boolean }>;
56
-
57
- const REF_POPOVER = 'RefPopover';
58
- const [RefPopoverContextProvider, useRefPopover] = createContext<RefPopoverValue>(REF_POPOVER, {});
59
-
60
- type PreviewProviderProps = PropsWithChildren<{ onLookup?: PreviewLookup }>;
61
-
62
- const PreviewProvider = ({ children, onLookup }: PreviewProviderProps) => {
63
- const trigger = useRef<DxRefTag | null>(null);
64
- const [value, setValue] = useState<RefPopoverValue>({});
65
- const [open, setOpen] = useState(false);
66
-
67
- const handleDxRefTagActivate = useCallback(
68
- (event: DxRefTagActivate) => {
69
- const { refId, label, trigger: dxTrigger } = event;
70
- setValue((value) => ({
71
- ...value,
72
- link: { label, ref: refId },
73
- pending: true,
74
- }));
75
- trigger.current = dxTrigger;
76
- queueMicrotask(() => setOpen(true));
77
- void onLookup?.({ label, ref: refId }).then((target) =>
78
- setValue((value) => ({
79
- ...value,
80
- target: target ?? undefined,
81
- pending: false,
82
- })),
83
- );
84
- },
85
- [onLookup],
86
- );
87
-
88
- return (
89
- <RefPopoverContextProvider pending={value.pending} link={value.link} target={value.target}>
90
- <RefPopover ref={trigger} open={open} onOpenChange={setOpen} onActivate={handleDxRefTagActivate}>
91
- {children}
92
- </RefPopover>
93
- </RefPopoverContextProvider>
94
- );
95
- };
96
-
97
- export { PreviewProvider, useRefPopover };
98
-
99
- export type { PreviewProviderProps, RefPopoverValue };
@@ -1,7 +0,0 @@
1
- //
2
- // Copyright 2022 DXOS.org
3
- //
4
-
5
- export * from './CommandMenu';
6
- export * from './RefPopover';
7
- export * from './RefDropdownMenu';
package/src/defaults.ts DELETED
@@ -1,49 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { EditorView } from '@codemirror/view';
6
-
7
- import { mx } from '@dxos/react-ui-theme';
8
-
9
- import { type ThemeExtensionsOptions } from './extensions';
10
- import { fontMono } from './styles';
11
-
12
- /**
13
- * CodeMirror content width.
14
- * 40rem = 640px. Corresponds to initial plank width (Google docs, Stashpad, etc.)
15
- * 50rem = 800px. Maximum content width for solo mode.
16
- * NOTE: Max width - 4rem = 2rem left/right margin (or 2rem gutter plus 1rem left/right margin).
17
- */
18
- export const editorWidth = '!mli-auto is-full max-is-[min(50rem,100%-4rem)]';
19
-
20
- export const editorSlots: ThemeExtensionsOptions['slots'] = {
21
- scroll: {
22
- className: 'pbs-2',
23
- },
24
- content: {
25
- className: editorWidth,
26
- },
27
- };
28
-
29
- export const editorGutter = EditorView.theme({
30
- '.cm-gutters': {
31
- background: 'var(--dx-baseSurface)',
32
- paddingRight: '1rem',
33
- },
34
- });
35
-
36
- export const editorMonospace = EditorView.theme({
37
- '.cm-content': {
38
- fontFamily: fontMono,
39
- },
40
- });
41
-
42
- export const editorWithToolbarLayout =
43
- 'grid grid-cols-1 grid-rows-[min-content_1fr] data-[toolbar=disabled]:grid-rows-[1fr] justify-center content-start overflow-hidden';
44
-
45
- export const stackItemContentEditorClassNames = (role?: string) =>
46
- mx(
47
- 'attention-surface dx-focus-ring-inset data-[toolbar=disabled]:pbs-2',
48
- role === 'section' ? '[&_.cm-scroller]:overflow-hidden [&_.cm-scroller]:min-bs-24' : 'min-bs-0',
49
- );
@@ -1,55 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type Extension, RangeSetBuilder } from '@codemirror/state';
6
- import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate } from '@codemirror/view';
7
-
8
- const annotationMark = Decoration.mark({ class: 'cm-annotation' });
9
-
10
- export type AnnotationOptions = {
11
- match?: RegExp; // TODO(burdon): Update via hook (e.g., for search).
12
- };
13
-
14
- /**
15
- *
16
- */
17
- export const annotations = ({ match }: AnnotationOptions = {}): Extension => {
18
- return [
19
- ViewPlugin.fromClass(
20
- class {
21
- decorations: DecorationSet = Decoration.none;
22
- update(update: ViewUpdate) {
23
- const builder = new RangeSetBuilder<Decoration>();
24
- if (match) {
25
- // Only process visible lines.
26
- const { from, to } = update.view.viewport;
27
- const text = update.state.doc.sliceString(from, to);
28
- const matches = text.matchAll(match);
29
- for (const m of matches) {
30
- if (m.index !== undefined) {
31
- // Adjust match position relative to viewport.
32
- const start = from + m.index;
33
- const end = start + m[0].length;
34
- builder.add(start, end, annotationMark);
35
- }
36
- }
37
- }
38
-
39
- this.decorations = builder.finish();
40
- }
41
- },
42
- {
43
- decorations: (v) => v.decorations,
44
- },
45
- ),
46
-
47
- EditorView.theme({
48
- '.cm-annotation': {
49
- textDecoration: 'underline',
50
- textDecorationStyle: 'wavy',
51
- textDecorationColor: 'var(--dx-errorText)',
52
- },
53
- }),
54
- ];
55
- };
@@ -1,69 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import {
6
- autocompletion,
7
- completionKeymap,
8
- type CompletionSource,
9
- type Completion,
10
- type CompletionContext,
11
- type CompletionResult,
12
- } from '@codemirror/autocomplete';
13
- import { markdownLanguage } from '@codemirror/lang-markdown';
14
- import { type Extension } from '@codemirror/state';
15
- import { keymap } from '@codemirror/view';
16
-
17
- export type AutocompleteResult = Completion;
18
-
19
- export type AutocompleteOptions = {
20
- activateOnTyping?: boolean;
21
- override?: CompletionSource[];
22
- onSearch?: (text: string) => Completion[];
23
- };
24
-
25
- // https://codemirror.net/examples/autocompletion
26
- // https://codemirror.net/docs/ref/#autocomplete.autocompletion
27
- // https://codemirror.net/docs/ref/#autocomplete.Completion
28
-
29
- /**
30
- * Autocomplete extension.
31
- */
32
- export const autocomplete = ({ activateOnTyping, override, onSearch }: AutocompleteOptions = {}): Extension => {
33
- const extensions: Extension[] = [
34
- // https://codemirror.net/docs/ref/#view.keymap
35
- // https://discuss.codemirror.net/t/how-can-i-replace-the-default-autocompletion-keymap-v6/3322
36
- // TODO(burdon): Set custom keymap.
37
- keymap.of(completionKeymap),
38
-
39
- // https://codemirror.net/examples/autocompletion
40
- // https://codemirror.net/docs/ref/#autocomplete.autocompletion
41
- autocompletion({
42
- override,
43
- activateOnTyping,
44
- // closeOnBlur: false,
45
- // tooltipClass: () => 'rounded-be pbe-1 border-separator',
46
- }),
47
- ];
48
-
49
- if (onSearch) {
50
- extensions.push(
51
- // TODO(burdon): Optional decoration via addToOptions.
52
- markdownLanguage.data.of({
53
- autocomplete: (context: CompletionContext): CompletionResult | null => {
54
- const match = context.matchBefore(/\w*/);
55
- if (!match || (match.from === match.to && !context.explicit)) {
56
- return null;
57
- }
58
-
59
- return {
60
- from: match.from,
61
- options: onSearch(match.text.toLowerCase()),
62
- };
63
- },
64
- }),
65
- );
66
- }
67
-
68
- return extensions;
69
- };
@@ -1,142 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import '@preact/signals-react';
8
-
9
- import { Repo } from '@automerge/automerge-repo';
10
- import { BroadcastChannelNetworkAdapter } from '@automerge/automerge-repo-network-broadcastchannel';
11
- import React, { useEffect, useState } from 'react';
12
-
13
- import { Obj, Ref, Type } from '@dxos/echo';
14
- import { DocAccessor, createDocAccessor, useQuery, useSpace, type Space, Query } from '@dxos/react-client/echo';
15
- import { useIdentity, type Identity } from '@dxos/react-client/halo';
16
- import { ClientRepeater, type ClientRepeatedComponentProps } from '@dxos/react-client/testing';
17
- import { useThemeContext } from '@dxos/react-ui';
18
- import { withLayout, withTheme } from '@dxos/storybook-utils';
19
-
20
- import { editorSlots } from '../../defaults';
21
- import { useTextEditor } from '../../hooks';
22
- import { translations } from '../../translations';
23
- import { createBasicExtensions, createDataExtensions, createThemeExtensions } from '../factories';
24
-
25
- const initialContent = 'Hello world!';
26
-
27
- type TestObject = {
28
- text: string;
29
- };
30
-
31
- type EditorProps = {
32
- source: DocAccessor;
33
- autoFocus?: boolean;
34
- space?: Space;
35
- identity?: Identity;
36
- };
37
-
38
- const Editor = ({ source, autoFocus, space, identity }: EditorProps) => {
39
- const { themeMode } = useThemeContext();
40
- const { parentRef } = useTextEditor(
41
- () => ({
42
- initialValue: DocAccessor.getValue(source),
43
- extensions: [
44
- createBasicExtensions({ placeholder: 'Type here...' }),
45
- createThemeExtensions({ themeMode, slots: editorSlots }),
46
- createDataExtensions({ id: 'test', text: source, space, identity }),
47
- ],
48
- autoFocus,
49
- }),
50
- [source, themeMode],
51
- );
52
-
53
- return <div ref={parentRef} className='flex w-full' />;
54
- };
55
-
56
- const Story = () => {
57
- const [object1, setObject1] = useState<DocAccessor<TestObject>>();
58
- const [object2, setObject2] = useState<DocAccessor<TestObject>>();
59
-
60
- useEffect(() => {
61
- queueMicrotask(async () => {
62
- const repo1 = new Repo({ network: [new BroadcastChannelNetworkAdapter()] });
63
- const repo2 = new Repo({ network: [new BroadcastChannelNetworkAdapter()] });
64
-
65
- const object1 = repo1.create<TestObject>();
66
- object1.change((doc: TestObject) => {
67
- doc.text = initialContent;
68
- });
69
-
70
- const object2 = await repo2.find<TestObject>(object1.url);
71
- await object2.whenReady();
72
-
73
- // TODO(mykola): Fix types.
74
- setObject1({ handle: object1 as any, path: ['text'] });
75
- setObject2({ handle: object2 as any, path: ['text'] });
76
- });
77
- }, []);
78
-
79
- if (!object1 || !object2) {
80
- return null;
81
- }
82
-
83
- return (
84
- <div role='none' className='grid grid-cols-2 bs-full is-full divide-x divide-neutral-500'>
85
- <Editor source={object1} autoFocus />
86
- <Editor source={object2} />
87
- </div>
88
- );
89
- };
90
-
91
- export default {
92
- title: 'ui/react-ui-editor/Automerge',
93
- component: Editor,
94
- decorators: [withTheme, withLayout({ fullscreen: true })],
95
- render: () => <Story />,
96
- parameters: {
97
- translations,
98
- },
99
- };
100
-
101
- const EchoStory = ({ spaceKey }: ClientRepeatedComponentProps) => {
102
- const identity = useIdentity();
103
- const space = useSpace(spaceKey);
104
- const [source, setSource] = useState<DocAccessor>();
105
- const objects = useQuery(space, Query.type(Type.Expando, { type: 'test' }));
106
-
107
- useEffect(() => {
108
- if (!source && objects.length) {
109
- const source = createDocAccessor(objects[0].content, ['content']);
110
- setSource(source);
111
- }
112
- }, [objects, source]);
113
-
114
- if (!source) {
115
- return null;
116
- }
117
-
118
- return <Editor source={source} space={space} identity={identity ?? undefined} />;
119
- };
120
-
121
- export const Default = {};
122
-
123
- export const WithEcho = {
124
- decorators: [withTheme],
125
- render: () => {
126
- return (
127
- <ClientRepeater
128
- count={2}
129
- component={EchoStory}
130
- createSpace
131
- onSpaceCreated={async ({ space }) => {
132
- space.db.add(
133
- Obj.make(Type.Expando, {
134
- type: 'test',
135
- content: Ref.make(Obj.make(Type.Expando, { content: initialContent })),
136
- }),
137
- );
138
- }}
139
- />
140
- );
141
- },
142
- };
@@ -1,78 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type DocHandle, Repo } from '@automerge/automerge-repo';
6
- import { EditorState } from '@codemirror/state';
7
- import { EditorView } from '@codemirror/view';
8
- import { render, screen } from '@testing-library/react';
9
- // TODO(wittjosiah): Move to vitest expect (and remove from package.json).
10
- import chai, { expect } from 'chai';
11
- import chaiDom from 'chai-dom';
12
- import React, { type FC, useEffect, useRef, useState } from 'react';
13
- import { describe, test } from 'vitest';
14
-
15
- import { get } from '@dxos/util';
16
-
17
- import { automerge } from './automerge';
18
-
19
- type TestObject = {
20
- text: string;
21
- };
22
-
23
- const path = ['text'];
24
-
25
- class Generator {
26
- constructor(private readonly _handle: DocHandle<TestObject>) {}
27
- update(text: string): void {
28
- this._handle.change((doc: TestObject) => {
29
- doc.text = text;
30
- });
31
- }
32
- }
33
-
34
- const Test: FC<{ handle: DocHandle<TestObject>; generator: Generator }> = ({ handle, generator }) => {
35
- const ref = useRef<HTMLDivElement>(null);
36
- const [view, setView] = useState<EditorView>();
37
- useEffect(() => {
38
- const extensions = [
39
- // TODO(mykola): Fix types.
40
- automerge({ handle: handle as any, path }),
41
- EditorView.updateListener.of((update) => {
42
- if (view.state.doc.toString() === 'hello!') {
43
- // Update editor.
44
- update.view.dispatch({ changes: { from: view.state.doc.length - 1, insert: ' world' } });
45
- }
46
- }),
47
- ];
48
-
49
- const view = new EditorView({
50
- state: EditorState.create({ doc: get(handle.doc()!, path), extensions }),
51
- parent: ref.current!,
52
- });
53
-
54
- setView(view);
55
- }, []);
56
-
57
- useEffect(() => {}, [view]);
58
-
59
- return <div ref={ref} />;
60
- };
61
-
62
- chai.use(chaiDom);
63
-
64
- describe('Automerge', () => {
65
- test('basic sync', () => {
66
- const repo = new Repo({ network: [] });
67
- const handle = repo.create<TestObject>();
68
- const generator = new Generator(handle);
69
- render(<Test handle={handle} generator={generator} />);
70
- expect(screen.getByRole('textbox')).to.have.text('');
71
-
72
- generator.update('hello!');
73
- expect(screen.getByRole('textbox')).to.have.text('hello world!');
74
- });
75
-
76
- // TODO(burdon): Test history/undo.
77
- // TODO(burdon): https://testing-library.com/docs/react-testing-library/example-intro/
78
- });
@@ -1,85 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- // Copyright 2024 Automerge
4
- // Ref: https://github.com/automerge/automerge-codemirror
5
- //
6
-
7
- import { next as A } from '@automerge/automerge';
8
- import { StateField, type Extension } from '@codemirror/state';
9
- import { EditorView, ViewPlugin } from '@codemirror/view';
10
-
11
- import { type DocAccessor } from '@dxos/react-client/echo';
12
-
13
- import { cursorConverter } from './cursor';
14
- import { updateHeadsEffect, isReconcile, type State } from './defs';
15
- import { Syncer } from './sync';
16
- import { Cursor } from '../../util';
17
-
18
- export const automerge = (accessor: DocAccessor): Extension => {
19
- const syncState = StateField.define<State>({
20
- create: () => ({
21
- path: accessor.path.slice(),
22
- lastHeads: A.getHeads(accessor.handle.doc()!),
23
- unreconciledTransactions: [],
24
- }),
25
-
26
- update: (value, tr) => {
27
- const result: State = {
28
- path: accessor.path.slice(),
29
- lastHeads: value.lastHeads,
30
- unreconciledTransactions: value.unreconciledTransactions.slice(),
31
- };
32
-
33
- let clearUnreconciled = false;
34
- for (const effect of tr.effects) {
35
- if (effect.is(updateHeadsEffect)) {
36
- result.lastHeads = effect.value.newHeads;
37
- clearUnreconciled = true;
38
- }
39
- }
40
-
41
- if (clearUnreconciled) {
42
- result.unreconciledTransactions = [];
43
- } else {
44
- if (!isReconcile(tr)) {
45
- result.unreconciledTransactions.push(tr);
46
- }
47
- }
48
-
49
- return result;
50
- },
51
- });
52
-
53
- const syncer = new Syncer(accessor.handle, syncState);
54
-
55
- return [
56
- Cursor.converter.of(cursorConverter(accessor)),
57
-
58
- // Track heads.
59
- syncState,
60
-
61
- // Reconcile external updates.
62
- ViewPlugin.fromClass(
63
- class {
64
- constructor(private readonly _view: EditorView) {
65
- accessor.handle.addListener('change', this._handleChange);
66
- }
67
-
68
- destroy() {
69
- accessor.handle.removeListener('change', this._handleChange);
70
- }
71
-
72
- readonly _handleChange = () => {
73
- syncer.reconcile(this._view, false);
74
- };
75
- },
76
- ),
77
-
78
- // Reconcile local updates.
79
- EditorView.updateListener.of(({ view, changes }) => {
80
- if (!changes.empty) {
81
- syncer.reconcile(view, true);
82
- }
83
- }),
84
- ];
85
- };