@dxos/react-ui-editor 0.8.4-main.c4373fc → 0.8.4-main.d05673bc65

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 (422) hide show
  1. package/dist/lib/browser/index.mjs +1143 -8424
  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 +1143 -8423
  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 -21
  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 +36 -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/actions.d.ts +25 -0
  36. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  37. package/dist/types/src/components/EditorToolbar/blocks.d.ts +9 -7
  38. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/formatting.d.ts +9 -7
  40. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/headings.d.ts +9 -7
  42. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/image.d.ts +5 -11
  44. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
  46. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/search.d.ts +5 -11
  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 +10 -8
  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 +4 -8
  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/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +5 -8
  60. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  61. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -1
  62. package/dist/types/src/stories/Comments.stories.d.ts +4 -3
  63. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  64. package/dist/types/src/stories/EditorToolbar.stories.d.ts +4 -4
  65. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  66. package/dist/types/src/stories/Experimental.stories.d.ts +4 -3
  67. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  68. package/dist/types/src/stories/Markdown.stories.d.ts +4 -3
  69. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  70. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/{CommandMenu.stories.d.ts → Popover.stories.d.ts} +6 -5
  72. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  73. package/dist/types/src/stories/Preview.stories.d.ts +5 -3
  74. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  75. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  76. package/dist/types/src/stories/TextEditor.stories.d.ts +4 -4
  77. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  78. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  79. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  80. package/dist/types/src/stories/components/EditorStory.d.ts +9 -18
  81. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  82. package/dist/types/src/stories/components/util.d.ts +3 -3
  83. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  84. package/dist/types/src/translations.d.ts +5 -5
  85. package/dist/types/src/translations.d.ts.map +1 -1
  86. package/dist/types/src/util/index.d.ts +0 -5
  87. package/dist/types/src/util/index.d.ts.map +1 -1
  88. package/dist/types/src/util/react.d.ts +6 -5
  89. package/dist/types/src/util/react.d.ts.map +1 -1
  90. package/dist/types/tsconfig.tsbuildinfo +1 -1
  91. package/package.json +68 -72
  92. package/src/components/Editor/Editor.stories.tsx +95 -0
  93. package/src/components/Editor/Editor.tsx +167 -56
  94. package/src/components/EditorContent/EditorContent.tsx +83 -0
  95. package/src/components/EditorContent/controller.ts +50 -0
  96. package/src/components/EditorContent/index.ts +6 -0
  97. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +228 -0
  98. package/src/components/EditorMenuProvider/index.ts +10 -0
  99. package/src/components/EditorMenuProvider/menu-presets.ts +124 -0
  100. package/src/components/EditorMenuProvider/menu.ts +70 -0
  101. package/src/components/EditorMenuProvider/popover.ts +285 -0
  102. package/src/components/EditorMenuProvider/useEditorMenu.ts +179 -0
  103. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
  104. package/src/components/EditorPreviewProvider/index.ts +5 -0
  105. package/src/components/EditorToolbar/EditorToolbar.tsx +102 -105
  106. package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
  107. package/src/components/EditorToolbar/blocks.ts +7 -7
  108. package/src/components/EditorToolbar/formatting.ts +7 -7
  109. package/src/components/EditorToolbar/headings.ts +20 -17
  110. package/src/components/EditorToolbar/image.ts +10 -3
  111. package/src/components/EditorToolbar/index.ts +3 -7
  112. package/src/components/EditorToolbar/search.ts +10 -3
  113. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  114. package/src/components/EditorToolbar/view-mode.ts +7 -6
  115. package/src/components/index.ts +6 -2
  116. package/src/hooks/useTextEditor.ts +33 -27
  117. package/src/index.ts +0 -10
  118. package/src/stories/Automerge.stories.tsx +173 -0
  119. package/src/stories/CommandDialog.stories.tsx +18 -26
  120. package/src/stories/Comments.stories.tsx +48 -44
  121. package/src/stories/EditorToolbar.stories.tsx +36 -21
  122. package/src/stories/Experimental.stories.tsx +7 -9
  123. package/src/stories/Markdown.stories.tsx +16 -16
  124. package/src/stories/Outliner.stories.tsx +20 -21
  125. package/src/stories/Popover.stories.tsx +158 -0
  126. package/src/stories/Preview.stories.tsx +100 -81
  127. package/src/stories/Tags.stories.tsx +36 -13
  128. package/src/stories/TextEditor.stories.tsx +16 -48
  129. package/src/stories/Theme.stories.tsx +61 -0
  130. package/src/stories/components/EditorStory.tsx +32 -25
  131. package/src/stories/components/util.tsx +60 -31
  132. package/src/translations.ts +4 -4
  133. package/src/util/index.ts +1 -6
  134. package/src/util/react.tsx +8 -13
  135. package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
  136. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
  137. package/dist/lib/browser/testing/index.mjs +0 -76
  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-YJZGD3LY.mjs +0 -24
  142. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
  143. package/dist/lib/node-esm/testing/index.mjs +0 -78
  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/CommandMenu/CommandMenu.d.ts +0 -38
  148. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts.map +0 -1
  149. package/dist/types/src/components/CommandMenu/index.d.ts +0 -2
  150. package/dist/types/src/components/CommandMenu/index.d.ts.map +0 -1
  151. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  152. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  153. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  154. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  155. package/dist/types/src/defaults.d.ts +0 -14
  156. package/dist/types/src/defaults.d.ts.map +0 -1
  157. package/dist/types/src/extensions/annotations.d.ts +0 -9
  158. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  159. package/dist/types/src/extensions/autocomplete.d.ts +0 -26
  160. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  161. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  162. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  163. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  164. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  165. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  166. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  167. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  168. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  169. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  170. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  171. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  172. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  173. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  174. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  175. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  176. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  177. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  178. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  179. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  180. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  181. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  182. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  183. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  184. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  185. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  186. package/dist/types/src/extensions/blast.d.ts +0 -25
  187. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  188. package/dist/types/src/extensions/command-dialog/action.d.ts +0 -17
  189. package/dist/types/src/extensions/command-dialog/action.d.ts.map +0 -1
  190. package/dist/types/src/extensions/command-dialog/command-dialog.d.ts +0 -6
  191. package/dist/types/src/extensions/command-dialog/command-dialog.d.ts.map +0 -1
  192. package/dist/types/src/extensions/command-dialog/hint.d.ts +0 -19
  193. package/dist/types/src/extensions/command-dialog/hint.d.ts.map +0 -1
  194. package/dist/types/src/extensions/command-dialog/index.d.ts +0 -4
  195. package/dist/types/src/extensions/command-dialog/index.d.ts.map +0 -1
  196. package/dist/types/src/extensions/command-dialog/state.d.ts +0 -16
  197. package/dist/types/src/extensions/command-dialog/state.d.ts.map +0 -1
  198. package/dist/types/src/extensions/command-dialog/typeahead.d.ts +0 -22
  199. package/dist/types/src/extensions/command-dialog/typeahead.d.ts.map +0 -1
  200. package/dist/types/src/extensions/command-menu/command-menu.d.ts +0 -20
  201. package/dist/types/src/extensions/command-menu/command-menu.d.ts.map +0 -1
  202. package/dist/types/src/extensions/command-menu/index.d.ts +0 -3
  203. package/dist/types/src/extensions/command-menu/index.d.ts.map +0 -1
  204. package/dist/types/src/extensions/command-menu/placeholder.d.ts +0 -10
  205. package/dist/types/src/extensions/command-menu/placeholder.d.ts.map +0 -1
  206. package/dist/types/src/extensions/command-menu/useCommandMenu.d.ts +0 -24
  207. package/dist/types/src/extensions/command-menu/useCommandMenu.d.ts.map +0 -1
  208. package/dist/types/src/extensions/comments.d.ts +0 -95
  209. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  210. package/dist/types/src/extensions/debug.d.ts +0 -3
  211. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  212. package/dist/types/src/extensions/dnd.d.ts +0 -9
  213. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  214. package/dist/types/src/extensions/factories.d.ts +0 -83
  215. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  216. package/dist/types/src/extensions/floating-menu.d.ts +0 -7
  217. package/dist/types/src/extensions/floating-menu.d.ts.map +0 -1
  218. package/dist/types/src/extensions/focus.d.ts +0 -7
  219. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  220. package/dist/types/src/extensions/folding.d.ts +0 -7
  221. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  222. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  223. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  224. package/dist/types/src/extensions/index.d.ts +0 -27
  225. package/dist/types/src/extensions/index.d.ts.map +0 -1
  226. package/dist/types/src/extensions/json.d.ts +0 -7
  227. package/dist/types/src/extensions/json.d.ts.map +0 -1
  228. package/dist/types/src/extensions/listener.d.ts +0 -11
  229. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  230. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  231. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  232. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  233. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  234. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  235. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  236. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  237. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  238. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  239. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  240. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  241. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  242. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  243. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  244. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  245. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  246. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  247. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  248. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  249. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  250. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  251. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  252. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  253. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  254. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  255. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  256. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  257. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  258. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  259. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  260. package/dist/types/src/extensions/mention.d.ts +0 -7
  261. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  262. package/dist/types/src/extensions/modes.d.ts +0 -10
  263. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  264. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  265. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  266. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  267. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  268. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  269. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  270. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  271. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  272. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  273. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  274. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  275. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  276. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  277. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  278. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  279. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  280. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  281. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  282. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  283. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  284. package/dist/types/src/extensions/preview/preview.d.ts +0 -29
  285. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  286. package/dist/types/src/extensions/selection.d.ts +0 -24
  287. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  288. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  289. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  290. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  291. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  292. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  293. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  294. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  295. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  296. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -72
  297. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  298. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  299. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  300. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  301. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  302. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  303. package/dist/types/src/styles/index.d.ts +0 -4
  304. package/dist/types/src/styles/index.d.ts.map +0 -1
  305. package/dist/types/src/styles/markdown.d.ts +0 -8
  306. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  307. package/dist/types/src/styles/theme.d.ts +0 -38
  308. package/dist/types/src/styles/theme.d.ts.map +0 -1
  309. package/dist/types/src/styles/tokens.d.ts +0 -3
  310. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  311. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  312. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  313. package/dist/types/src/testing/index.d.ts +0 -3
  314. package/dist/types/src/testing/index.d.ts.map +0 -1
  315. package/dist/types/src/testing/util.d.ts +0 -3
  316. package/dist/types/src/testing/util.d.ts.map +0 -1
  317. package/dist/types/src/types/index.d.ts +0 -2
  318. package/dist/types/src/types/index.d.ts.map +0 -1
  319. package/dist/types/src/types/types.d.ts +0 -21
  320. package/dist/types/src/types/types.d.ts.map +0 -1
  321. package/dist/types/src/util/cursor.d.ts +0 -31
  322. package/dist/types/src/util/cursor.d.ts.map +0 -1
  323. package/dist/types/src/util/debug.d.ts +0 -17
  324. package/dist/types/src/util/debug.d.ts.map +0 -1
  325. package/dist/types/src/util/decorations.d.ts +0 -4
  326. package/dist/types/src/util/decorations.d.ts.map +0 -1
  327. package/dist/types/src/util/dom.d.ts +0 -10
  328. package/dist/types/src/util/dom.d.ts.map +0 -1
  329. package/dist/types/src/util/facet.d.ts +0 -3
  330. package/dist/types/src/util/facet.d.ts.map +0 -1
  331. package/src/components/CommandMenu/CommandMenu.tsx +0 -348
  332. package/src/components/CommandMenu/index.ts +0 -5
  333. package/src/components/EditorToolbar/util.ts +0 -76
  334. package/src/defaults.ts +0 -52
  335. package/src/extensions/annotations.ts +0 -55
  336. package/src/extensions/autocomplete.ts +0 -219
  337. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  338. package/src/extensions/automerge/automerge.test.tsx +0 -78
  339. package/src/extensions/automerge/automerge.ts +0 -86
  340. package/src/extensions/automerge/cursor.ts +0 -28
  341. package/src/extensions/automerge/defs.ts +0 -31
  342. package/src/extensions/automerge/index.ts +0 -5
  343. package/src/extensions/automerge/sync.ts +0 -75
  344. package/src/extensions/automerge/update-automerge.ts +0 -50
  345. package/src/extensions/automerge/update-codemirror.ts +0 -115
  346. package/src/extensions/autoscroll.ts +0 -157
  347. package/src/extensions/awareness/awareness-provider.ts +0 -127
  348. package/src/extensions/awareness/awareness.ts +0 -315
  349. package/src/extensions/awareness/index.ts +0 -6
  350. package/src/extensions/blast.ts +0 -363
  351. package/src/extensions/command-dialog/action.ts +0 -55
  352. package/src/extensions/command-dialog/command-dialog.ts +0 -34
  353. package/src/extensions/command-dialog/hint.ts +0 -103
  354. package/src/extensions/command-dialog/index.ts +0 -7
  355. package/src/extensions/command-dialog/state.ts +0 -90
  356. package/src/extensions/command-dialog/typeahead.ts +0 -129
  357. package/src/extensions/command-menu/command-menu.ts +0 -210
  358. package/src/extensions/command-menu/index.ts +0 -6
  359. package/src/extensions/command-menu/placeholder.ts +0 -113
  360. package/src/extensions/command-menu/useCommandMenu.ts +0 -134
  361. package/src/extensions/comments.ts +0 -597
  362. package/src/extensions/debug.ts +0 -15
  363. package/src/extensions/dnd.ts +0 -37
  364. package/src/extensions/factories.ts +0 -284
  365. package/src/extensions/floating-menu.ts +0 -126
  366. package/src/extensions/focus.ts +0 -36
  367. package/src/extensions/folding.tsx +0 -44
  368. package/src/extensions/hashtag.tsx +0 -68
  369. package/src/extensions/index.ts +0 -30
  370. package/src/extensions/json.ts +0 -57
  371. package/src/extensions/listener.ts +0 -38
  372. package/src/extensions/markdown/action.ts +0 -117
  373. package/src/extensions/markdown/bundle.ts +0 -93
  374. package/src/extensions/markdown/changes.test.ts +0 -26
  375. package/src/extensions/markdown/changes.ts +0 -149
  376. package/src/extensions/markdown/debug.ts +0 -44
  377. package/src/extensions/markdown/decorate.ts +0 -601
  378. package/src/extensions/markdown/formatting.test.ts +0 -498
  379. package/src/extensions/markdown/formatting.ts +0 -1267
  380. package/src/extensions/markdown/highlight.ts +0 -183
  381. package/src/extensions/markdown/image.ts +0 -118
  382. package/src/extensions/markdown/index.ts +0 -13
  383. package/src/extensions/markdown/link.ts +0 -50
  384. package/src/extensions/markdown/parser.test.ts +0 -75
  385. package/src/extensions/markdown/styles.ts +0 -135
  386. package/src/extensions/markdown/table.ts +0 -150
  387. package/src/extensions/mention.ts +0 -41
  388. package/src/extensions/modes.ts +0 -41
  389. package/src/extensions/outliner/commands.ts +0 -270
  390. package/src/extensions/outliner/editor.test.ts +0 -33
  391. package/src/extensions/outliner/editor.ts +0 -184
  392. package/src/extensions/outliner/index.ts +0 -7
  393. package/src/extensions/outliner/outliner.test.ts +0 -100
  394. package/src/extensions/outliner/outliner.ts +0 -167
  395. package/src/extensions/outliner/selection.ts +0 -50
  396. package/src/extensions/outliner/tree.test.ts +0 -168
  397. package/src/extensions/outliner/tree.ts +0 -317
  398. package/src/extensions/preview/index.ts +0 -5
  399. package/src/extensions/preview/preview.ts +0 -190
  400. package/src/extensions/selection.ts +0 -100
  401. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  402. package/src/extensions/tags/extended-markdown.ts +0 -78
  403. package/src/extensions/tags/index.ts +0 -7
  404. package/src/extensions/tags/streamer.ts +0 -243
  405. package/src/extensions/tags/xml-tags.ts +0 -393
  406. package/src/extensions/tags/xml-util.ts +0 -94
  407. package/src/extensions/typewriter.ts +0 -68
  408. package/src/stories/CommandMenu.stories.tsx +0 -158
  409. package/src/styles/index.ts +0 -7
  410. package/src/styles/markdown.ts +0 -26
  411. package/src/styles/theme.ts +0 -268
  412. package/src/styles/tokens.ts +0 -17
  413. package/src/testing/PreviewPopover.tsx +0 -78
  414. package/src/testing/index.ts +0 -6
  415. package/src/testing/util.ts +0 -7
  416. package/src/types/index.ts +0 -5
  417. package/src/types/types.ts +0 -32
  418. package/src/util/cursor.ts +0 -56
  419. package/src/util/debug.ts +0 -64
  420. package/src/util/decorations.ts +0 -21
  421. package/src/util/dom.ts +0 -34
  422. package/src/util/facet.ts +0 -13
package/src/defaults.ts DELETED
@@ -1,52 +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
- // NOTE: Color required to cover content if scrolling horizontally.
32
- // TODO(burdon): Non-transparent background clips the focus ring.
33
- background: 'var(--dx-baseSurface) !important',
34
- paddingRight: '1rem',
35
- },
36
- });
37
-
38
- export const editorMonospace = EditorView.theme({
39
- '.cm-content': {
40
- fontFamily: fontMono,
41
- },
42
- });
43
-
44
- export const editorWithToolbarLayout =
45
- 'grid grid-cols-1 grid-rows-[min-content_1fr] data-[toolbar=disabled]:grid-rows-[1fr] justify-center content-start overflow-hidden';
46
-
47
- // NOTE: Padding is added to the editor to account for the focus ring (since otherwise the CM gutter will clip it)
48
- export const stackItemContentEditorClassNames = (role?: string) =>
49
- mx(
50
- 'p-0.5 dx-focus-ring-inset attention-surface data-[toolbar=disabled]:pbs-2',
51
- role === 'section' ? '[&_.cm-scroller]:overflow-hidden [&_.cm-scroller]:min-bs-24' : 'min-bs-0',
52
- );
@@ -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,219 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { type Extension, Prec } from '@codemirror/state';
6
- import {
7
- Decoration,
8
- type DecorationSet,
9
- EditorView,
10
- ViewPlugin,
11
- type ViewUpdate,
12
- WidgetType,
13
- keymap,
14
- } from '@codemirror/view';
15
-
16
- export type AutocompleteOptions = {
17
- fireIfEmpty?: boolean;
18
-
19
- /**
20
- * Callback triggered when Enter is pressed.
21
- * @param text The current text in the editor
22
- * @returns true if the editor should reset the document.
23
- */
24
- onSubmit?: (text: string) => boolean | void;
25
-
26
- /**
27
- * Function that returns a list of suggestions based on the current text.
28
- * @param text The current text before the cursor
29
- * @returns Array of suggestion strings
30
- */
31
- onSuggest?: (text: string) => string[];
32
-
33
- /**
34
- * ESC pressed.
35
- */
36
- onCancel?: () => void;
37
- };
38
-
39
- /**
40
- * Creates an autocomplete extension that shows inline suggestions.
41
- * Pressing Tab will complete the suggestion.
42
- */
43
- export const autocomplete = ({ fireIfEmpty, onSubmit, onSuggest, onCancel }: AutocompleteOptions = {}): Extension => {
44
- const suggest = ViewPlugin.fromClass(
45
- class {
46
- _decorations: DecorationSet;
47
- _currentSuggestion: string | null = null;
48
-
49
- constructor(view: EditorView) {
50
- this._decorations = this.computeDecorations(view);
51
- }
52
-
53
- update(update: ViewUpdate) {
54
- if (update.docChanged || update.selectionSet) {
55
- this._decorations = this.computeDecorations(update.view);
56
- }
57
- }
58
-
59
- private computeDecorations(view: EditorView): DecorationSet {
60
- const text = view.state.doc.toString();
61
- const suggestions = onSuggest?.(text) ?? [];
62
- if (!suggestions.length) {
63
- this._currentSuggestion = null;
64
- return Decoration.none;
65
- }
66
-
67
- // Get the first suggestion.
68
- this._currentSuggestion = suggestions[0];
69
- const suffix = this._currentSuggestion.slice(text.length);
70
- if (!suffix) {
71
- return Decoration.none;
72
- }
73
-
74
- // Always show ghost text at the end of the document.
75
- return Decoration.set([
76
- Decoration.widget({
77
- widget: new InlineSuggestionWidget(suffix),
78
- side: 1,
79
- }).range(view.state.doc.length),
80
- ]);
81
- }
82
-
83
- completeSuggestion(view: EditorView): boolean {
84
- if (!this._currentSuggestion) {
85
- return false;
86
- }
87
-
88
- const text = view.state.doc.toString();
89
- const suffix = this._currentSuggestion.slice(text.length);
90
- if (!suffix) {
91
- return false;
92
- }
93
-
94
- view.dispatch({
95
- changes: {
96
- from: view.state.doc.length,
97
- insert: suffix,
98
- },
99
- selection: {
100
- anchor: view.state.doc.length + suffix.length,
101
- },
102
- });
103
-
104
- return true;
105
- }
106
- },
107
- {
108
- decorations: (v) => v._decorations,
109
- },
110
- );
111
-
112
- return [
113
- suggest,
114
- EditorView.theme({
115
- '.cm-inline-suggestion': {
116
- opacity: 0.4,
117
- },
118
- }),
119
-
120
- Prec.highest(
121
- keymap.of([
122
- {
123
- key: 'Tab',
124
- preventDefault: true,
125
- run: (view) => {
126
- const plugin = view.plugin(suggest);
127
- return plugin?.completeSuggestion(view) ?? false;
128
- },
129
- },
130
- {
131
- key: 'ArrowRight',
132
- preventDefault: true,
133
- run: (view) => {
134
- // Only complete if cursor is at the end
135
- if (view.state.selection.main.head !== view.state.doc.length) {
136
- return false;
137
- }
138
-
139
- const plugin = view.plugin(suggest);
140
- return plugin?.completeSuggestion(view) ?? false;
141
- },
142
- },
143
- {
144
- key: 'Enter',
145
- preventDefault: true,
146
- run: (view) => {
147
- const text = view.state.doc.toString().trim();
148
- if (onSubmit && (fireIfEmpty || text.length > 0)) {
149
- const reset = onSubmit(text);
150
-
151
- // Clear the document after calling onEnter.
152
- if (reset) {
153
- view.dispatch({
154
- changes: {
155
- from: 0,
156
- to: view.state.doc.length,
157
- insert: '',
158
- },
159
- });
160
- }
161
- }
162
-
163
- return true;
164
- },
165
- },
166
- {
167
- key: 'Shift-Enter',
168
- preventDefault: true,
169
- run: (view) => {
170
- view.dispatch({
171
- changes: {
172
- from: view.state.selection.main.head,
173
- insert: '\n',
174
- },
175
- selection: {
176
- anchor: view.state.selection.main.head + 1,
177
- head: view.state.selection.main.head + 1,
178
- },
179
- });
180
- return true;
181
- },
182
- },
183
- {
184
- key: 'Escape',
185
- preventDefault: true,
186
- run: (view) => {
187
- // Clear the entire document.
188
- view.dispatch({
189
- changes: {
190
- from: 0,
191
- to: view.state.doc.length,
192
- insert: '',
193
- },
194
- });
195
- onCancel?.();
196
- return true;
197
- },
198
- },
199
- ]),
200
- ),
201
- ];
202
- };
203
-
204
- class InlineSuggestionWidget extends WidgetType {
205
- constructor(private suffix: string) {
206
- super();
207
- }
208
-
209
- override toDOM(): HTMLSpanElement {
210
- const span = document.createElement('span');
211
- span.textContent = this.suffix;
212
- span.className = 'cm-inline-suggestion';
213
- return span;
214
- }
215
-
216
- override eq(other: InlineSuggestionWidget): boolean {
217
- return other.suffix === this.suffix;
218
- }
219
- }
@@ -1,149 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import '@preact/signals-react';
6
-
7
- import { Repo } from '@automerge/automerge-repo';
8
- import { BroadcastChannelNetworkAdapter } from '@automerge/automerge-repo-network-broadcastchannel';
9
- import { type Meta, type StoryObj } from '@storybook/react-vite';
10
- import React, { useEffect, useState } from 'react';
11
-
12
- import { Obj, Ref, Type } from '@dxos/echo';
13
- import { DocAccessor, Query, type Space, createDocAccessor, useQuery, useSpace } from '@dxos/react-client/echo';
14
- import { type Identity, useIdentity } from '@dxos/react-client/halo';
15
- import { type ClientRepeatedComponentProps, ClientRepeater } from '@dxos/react-client/testing';
16
- import { useThemeContext } from '@dxos/react-ui';
17
- import { withTheme } from '@dxos/react-ui/testing';
18
- import { render } 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...', search: true }),
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 DefaultStory = () => {
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
- const EchoStory = ({ spaceKey }: ClientRepeatedComponentProps) => {
92
- const identity = useIdentity();
93
- const space = useSpace(spaceKey);
94
- const [source, setSource] = useState<DocAccessor>();
95
- const objects = useQuery(space, Query.type(Type.Expando, { type: 'test' }));
96
-
97
- useEffect(() => {
98
- const content = objects[0]?.content.target;
99
- if (!source && content) {
100
- const source = createDocAccessor(content, ['content']);
101
- setSource(source);
102
- }
103
- }, [objects, source]);
104
-
105
- if (!source) {
106
- return null;
107
- }
108
-
109
- return <Editor source={source} space={space} identity={identity ?? undefined} />;
110
- };
111
-
112
- const meta = {
113
- title: 'ui/react-ui-editor/Automerge',
114
- component: Editor as any,
115
- render: render(DefaultStory),
116
- decorators: [withTheme],
117
- parameters: {
118
- layout: 'fullscreen',
119
- translations,
120
- },
121
- } satisfies Meta<typeof DefaultStory>;
122
-
123
- export default meta;
124
-
125
- type Story = StoryObj<typeof meta>;
126
-
127
- export const Default: Story = {
128
- args: {},
129
- };
130
-
131
- export const WithEcho: Story = {
132
- render: () => {
133
- return (
134
- <ClientRepeater
135
- count={2}
136
- component={EchoStory}
137
- createSpace
138
- onCreateSpace={async ({ space }) => {
139
- space.db.add(
140
- Obj.make(Type.Expando, {
141
- type: 'test',
142
- content: Ref.make(Obj.make(Type.Expando, { content: initialContent })),
143
- }),
144
- );
145
- }}
146
- />
147
- );
148
- },
149
- };
@@ -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,86 +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 { type Extension, StateField } from '@codemirror/state';
9
- import { EditorView, ViewPlugin } from '@codemirror/view';
10
-
11
- import { type DocAccessor } from '@dxos/react-client/echo';
12
-
13
- import { Cursor } from '../../util';
14
-
15
- import { cursorConverter } from './cursor';
16
- import { type State, isReconcile, updateHeadsEffect } from './defs';
17
- import { Syncer } from './sync';
18
-
19
- export const automerge = (accessor: DocAccessor): Extension => {
20
- const syncState = StateField.define<State>({
21
- create: () => ({
22
- path: accessor.path.slice(),
23
- lastHeads: A.getHeads(accessor.handle.doc()!),
24
- unreconciledTransactions: [],
25
- }),
26
-
27
- update: (value, tr) => {
28
- const result: State = {
29
- path: accessor.path.slice(),
30
- lastHeads: value.lastHeads,
31
- unreconciledTransactions: value.unreconciledTransactions.slice(),
32
- };
33
-
34
- let clearUnreconciled = false;
35
- for (const effect of tr.effects) {
36
- if (effect.is(updateHeadsEffect)) {
37
- result.lastHeads = effect.value.newHeads;
38
- clearUnreconciled = true;
39
- }
40
- }
41
-
42
- if (clearUnreconciled) {
43
- result.unreconciledTransactions = [];
44
- } else {
45
- if (!isReconcile(tr)) {
46
- result.unreconciledTransactions.push(tr);
47
- }
48
- }
49
-
50
- return result;
51
- },
52
- });
53
-
54
- const syncer = new Syncer(accessor.handle, syncState);
55
-
56
- return [
57
- Cursor.converter.of(cursorConverter(accessor)),
58
-
59
- // Track heads.
60
- syncState,
61
-
62
- // Reconcile external updates.
63
- ViewPlugin.fromClass(
64
- class {
65
- constructor(private readonly _view: EditorView) {
66
- accessor.handle.addListener('change', this._handleChange);
67
- }
68
-
69
- destroy() {
70
- accessor.handle.removeListener('change', this._handleChange);
71
- }
72
-
73
- readonly _handleChange = () => {
74
- syncer.reconcile(this._view, false);
75
- };
76
- },
77
- ),
78
-
79
- // Reconcile local updates.
80
- EditorView.updateListener.of(({ view, changes }) => {
81
- if (!changes.empty) {
82
- syncer.reconcile(view, true);
83
- }
84
- }),
85
- ];
86
- };
@@ -1,28 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { log } from '@dxos/log';
6
- import { type DocAccessor, fromCursor, toCursor } from '@dxos/react-client/echo';
7
-
8
- import { type CursorConverter } from '../../util';
9
-
10
- export const cursorConverter = (accessor: DocAccessor): CursorConverter => ({
11
- toCursor: (pos, assoc) => {
12
- try {
13
- return toCursor(accessor, pos, assoc);
14
- } catch (err) {
15
- log.catch(err);
16
- return ''; // In case of invalid request (e.g., wrong document).
17
- }
18
- },
19
-
20
- fromCursor: (cursor) => {
21
- try {
22
- return fromCursor(accessor, cursor);
23
- } catch (err) {
24
- log.catch(err);
25
- return 0; // In case of invalid request (e.g., wrong document).
26
- }
27
- },
28
- });
@@ -1,31 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- // Copyright 2024 Automerge
4
- // Ref: https://github.com/automerge/automerge-codemirror
5
- //
6
-
7
- import { type Heads, type Prop } from '@automerge/automerge';
8
- import { Annotation, type EditorState, StateEffect, type StateField, type Transaction } from '@codemirror/state';
9
-
10
- export type State = {
11
- path: Prop[];
12
- lastHeads: Heads;
13
- unreconciledTransactions: Transaction[];
14
- };
15
-
16
- export const getPath = (state: EditorState, field: StateField<State>): Prop[] => state.field(field).path;
17
- export const getLastHeads = (state: EditorState, field: StateField<State>): Heads => state.field(field).lastHeads;
18
-
19
- export type UpdateHeads = {
20
- newHeads: Heads;
21
- };
22
-
23
- export const updateHeadsEffect = StateEffect.define<UpdateHeads>({});
24
-
25
- export const updateHeads = (newHeads: Heads): StateEffect<UpdateHeads> => updateHeadsEffect.of({ newHeads });
26
-
27
- export const reconcileAnnotation = Annotation.define<boolean>();
28
-
29
- export const isReconcile = (tr: Transaction): boolean => {
30
- return !!tr.annotation(reconcileAnnotation);
31
- };
@@ -1,5 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- export { automerge } from './automerge';