@dxos/react-ui-editor 0.8.4-main.72ec0f3 → 0.8.4-main.7996785055

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (400) hide show
  1. package/dist/lib/browser/index.mjs +520 -8302
  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 +518 -8299
  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 +8 -2
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +4 -1
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -1
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +4 -2
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -1
  13. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +2 -4
  14. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -1
  15. package/dist/types/src/components/EditorMenuProvider/index.d.ts +0 -1
  16. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -1
  17. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -1
  18. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -1
  19. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +1 -2
  20. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -1
  21. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -1
  22. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +1 -1
  23. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -1
  24. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +7 -5
  25. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  26. package/dist/types/src/components/EditorToolbar/actions.d.ts +9 -23
  27. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -1
  28. package/dist/types/src/components/EditorToolbar/blocks.d.ts +7 -5
  29. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  30. package/dist/types/src/components/EditorToolbar/formatting.d.ts +7 -5
  31. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  32. package/dist/types/src/components/EditorToolbar/headings.d.ts +7 -5
  33. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  34. package/dist/types/src/components/EditorToolbar/image.d.ts +5 -11
  35. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  36. package/dist/types/src/components/EditorToolbar/index.d.ts +1 -1
  37. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  38. package/dist/types/src/components/EditorToolbar/search.d.ts +5 -11
  39. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  40. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +4 -4
  41. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -1
  42. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +8 -6
  43. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  44. package/dist/types/src/components/index.d.ts.map +1 -1
  45. package/dist/types/src/hooks/useTextEditor.d.ts +1 -1
  46. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  47. package/dist/types/src/index.d.ts +0 -8
  48. package/dist/types/src/index.d.ts.map +1 -1
  49. package/dist/types/src/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +5 -8
  50. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  51. package/dist/types/src/stories/Comments.stories.d.ts +3 -2
  52. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  53. package/dist/types/src/stories/EditorToolbar.stories.d.ts +6 -6
  54. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  55. package/dist/types/src/stories/Experimental.stories.d.ts +3 -2
  56. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  57. package/dist/types/src/stories/Markdown.stories.d.ts +3 -2
  58. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  59. package/dist/types/src/stories/Outliner.stories.d.ts +2 -2
  60. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  61. package/dist/types/src/stories/Popover.stories.d.ts +2 -2
  62. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -1
  63. package/dist/types/src/stories/Preview.stories.d.ts +3 -2
  64. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  66. package/dist/types/src/stories/TextEditor.stories.d.ts +3 -2
  67. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  68. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  69. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  70. package/dist/types/src/stories/components/EditorStory.d.ts +9 -20
  71. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  72. package/dist/types/src/stories/components/util.d.ts +3 -3
  73. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  74. package/dist/types/src/translations.d.ts +5 -5
  75. package/dist/types/src/translations.d.ts.map +1 -1
  76. package/dist/types/src/util/index.d.ts +0 -5
  77. package/dist/types/src/util/index.d.ts.map +1 -1
  78. package/dist/types/src/util/react.d.ts +6 -5
  79. package/dist/types/src/util/react.d.ts.map +1 -1
  80. package/dist/types/tsconfig.tsbuildinfo +1 -1
  81. package/package.json +65 -66
  82. package/src/components/Editor/Editor.stories.tsx +14 -8
  83. package/src/components/Editor/Editor.tsx +21 -10
  84. package/src/components/EditorContent/EditorContent.tsx +19 -6
  85. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +23 -30
  86. package/src/components/EditorMenuProvider/index.ts +0 -1
  87. package/src/components/EditorMenuProvider/menu-presets.ts +3 -1
  88. package/src/components/EditorMenuProvider/menu.ts +1 -2
  89. package/src/components/EditorMenuProvider/popover.ts +1 -3
  90. package/src/components/EditorMenuProvider/useEditorMenu.ts +9 -4
  91. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +6 -9
  92. package/src/components/EditorToolbar/EditorToolbar.tsx +25 -37
  93. package/src/components/EditorToolbar/actions.ts +10 -9
  94. package/src/components/EditorToolbar/blocks.ts +5 -6
  95. package/src/components/EditorToolbar/formatting.ts +5 -6
  96. package/src/components/EditorToolbar/headings.ts +12 -12
  97. package/src/components/EditorToolbar/image.ts +9 -2
  98. package/src/components/EditorToolbar/index.ts +1 -1
  99. package/src/components/EditorToolbar/search.ts +9 -2
  100. package/src/components/EditorToolbar/useEditorToolbar.ts +6 -6
  101. package/src/components/EditorToolbar/view-mode.ts +5 -5
  102. package/src/components/index.ts +0 -2
  103. package/src/hooks/useTextEditor.ts +9 -3
  104. package/src/index.ts +0 -10
  105. package/src/stories/Automerge.stories.tsx +173 -0
  106. package/src/stories/Comments.stories.tsx +47 -42
  107. package/src/stories/EditorToolbar.stories.tsx +57 -27
  108. package/src/stories/Experimental.stories.tsx +7 -9
  109. package/src/stories/Markdown.stories.tsx +16 -16
  110. package/src/stories/Outliner.stories.tsx +8 -9
  111. package/src/stories/Popover.stories.tsx +25 -29
  112. package/src/stories/Preview.stories.tsx +66 -51
  113. package/src/stories/Tags.stories.tsx +24 -15
  114. package/src/stories/TextEditor.stories.tsx +13 -19
  115. package/src/stories/Theme.stories.tsx +61 -0
  116. package/src/stories/components/EditorStory.tsx +22 -28
  117. package/src/stories/components/util.tsx +21 -24
  118. package/src/translations.ts +4 -4
  119. package/src/util/index.ts +1 -6
  120. package/src/util/react.tsx +8 -13
  121. package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
  122. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
  123. package/dist/lib/browser/types/index.mjs +0 -13
  124. package/dist/lib/browser/types/index.mjs.map +0 -7
  125. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs +0 -24
  126. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
  127. package/dist/lib/node-esm/types/index.mjs +0 -14
  128. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  129. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts +0 -26
  130. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts.map +0 -1
  131. package/dist/types/src/components/EditorMenuProvider/util.d.ts +0 -8
  132. package/dist/types/src/components/EditorMenuProvider/util.d.ts.map +0 -1
  133. package/dist/types/src/defaults.d.ts +0 -14
  134. package/dist/types/src/defaults.d.ts.map +0 -1
  135. package/dist/types/src/extensions/annotations.d.ts +0 -9
  136. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  137. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +0 -17
  138. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +0 -1
  139. package/dist/types/src/extensions/autocomplete/index.d.ts +0 -5
  140. package/dist/types/src/extensions/autocomplete/index.d.ts.map +0 -1
  141. package/dist/types/src/extensions/autocomplete/match.d.ts +0 -13
  142. package/dist/types/src/extensions/autocomplete/match.d.ts.map +0 -1
  143. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +0 -20
  144. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +0 -1
  145. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +0 -10
  146. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +0 -1
  147. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  148. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  149. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  150. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  151. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  152. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  153. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  154. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  155. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  156. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  157. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  158. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  159. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  160. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  161. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  162. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  163. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  164. package/dist/types/src/extensions/autoscroll.d.ts +0 -20
  165. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  166. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  167. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  168. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  169. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  170. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  171. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  172. package/dist/types/src/extensions/blast.d.ts +0 -25
  173. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  174. package/dist/types/src/extensions/blocks.d.ts +0 -2
  175. package/dist/types/src/extensions/blocks.d.ts.map +0 -1
  176. package/dist/types/src/extensions/bookmarks.d.ts +0 -12
  177. package/dist/types/src/extensions/bookmarks.d.ts.map +0 -1
  178. package/dist/types/src/extensions/comments.d.ts +0 -95
  179. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  180. package/dist/types/src/extensions/debug.d.ts +0 -3
  181. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  182. package/dist/types/src/extensions/dnd.d.ts +0 -9
  183. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  184. package/dist/types/src/extensions/factories.d.ts +0 -83
  185. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  186. package/dist/types/src/extensions/focus.d.ts +0 -7
  187. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  188. package/dist/types/src/extensions/folding.d.ts +0 -7
  189. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  190. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  191. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  192. package/dist/types/src/extensions/index.d.ts +0 -32
  193. package/dist/types/src/extensions/index.d.ts.map +0 -1
  194. package/dist/types/src/extensions/json.d.ts +0 -7
  195. package/dist/types/src/extensions/json.d.ts.map +0 -1
  196. package/dist/types/src/extensions/listener.d.ts +0 -13
  197. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  198. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  199. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  200. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  201. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  202. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  203. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  204. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  205. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  206. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  207. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  208. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  209. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  210. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -61
  211. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  212. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  213. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  214. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  215. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  216. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  217. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  218. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  219. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  220. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  221. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  222. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  223. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  224. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  225. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  226. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  227. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  228. package/dist/types/src/extensions/mention.d.ts +0 -7
  229. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  230. package/dist/types/src/extensions/modal.d.ts +0 -7
  231. package/dist/types/src/extensions/modal.d.ts.map +0 -1
  232. package/dist/types/src/extensions/modes.d.ts +0 -10
  233. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  234. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  235. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  236. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  237. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  238. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  239. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  240. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  241. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  242. package/dist/types/src/extensions/outliner/menu.d.ts +0 -8
  243. package/dist/types/src/extensions/outliner/menu.d.ts.map +0 -1
  244. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  245. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  246. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  247. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  248. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  249. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  250. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  251. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  252. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  253. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  254. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  255. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  256. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  257. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  258. package/dist/types/src/extensions/replacer.d.ts +0 -21
  259. package/dist/types/src/extensions/replacer.d.ts.map +0 -1
  260. package/dist/types/src/extensions/replacer.test.d.ts +0 -2
  261. package/dist/types/src/extensions/replacer.test.d.ts.map +0 -1
  262. package/dist/types/src/extensions/scrolling.d.ts +0 -78
  263. package/dist/types/src/extensions/scrolling.d.ts.map +0 -1
  264. package/dist/types/src/extensions/selection.d.ts +0 -24
  265. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  266. package/dist/types/src/extensions/state.d.ts +0 -2
  267. package/dist/types/src/extensions/state.d.ts.map +0 -1
  268. package/dist/types/src/extensions/submit.d.ts +0 -10
  269. package/dist/types/src/extensions/submit.d.ts.map +0 -1
  270. package/dist/types/src/extensions/tab.d.ts +0 -4
  271. package/dist/types/src/extensions/tab.d.ts.map +0 -1
  272. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  273. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  274. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  275. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  276. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  277. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  278. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  279. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  280. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -97
  281. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  282. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  283. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  284. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  285. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  286. package/dist/types/src/stories/CommandDialog.stories.d.ts +0 -14
  287. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +0 -1
  288. package/dist/types/src/styles/index.d.ts +0 -4
  289. package/dist/types/src/styles/index.d.ts.map +0 -1
  290. package/dist/types/src/styles/markdown.d.ts +0 -8
  291. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  292. package/dist/types/src/styles/theme.d.ts +0 -38
  293. package/dist/types/src/styles/theme.d.ts.map +0 -1
  294. package/dist/types/src/styles/tokens.d.ts +0 -3
  295. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  296. package/dist/types/src/types/index.d.ts +0 -2
  297. package/dist/types/src/types/index.d.ts.map +0 -1
  298. package/dist/types/src/types/types.d.ts +0 -21
  299. package/dist/types/src/types/types.d.ts.map +0 -1
  300. package/dist/types/src/util/cursor.d.ts +0 -31
  301. package/dist/types/src/util/cursor.d.ts.map +0 -1
  302. package/dist/types/src/util/debug.d.ts +0 -21
  303. package/dist/types/src/util/debug.d.ts.map +0 -1
  304. package/dist/types/src/util/decorations.d.ts +0 -4
  305. package/dist/types/src/util/decorations.d.ts.map +0 -1
  306. package/dist/types/src/util/dom.d.ts +0 -10
  307. package/dist/types/src/util/dom.d.ts.map +0 -1
  308. package/dist/types/src/util/facet.d.ts +0 -3
  309. package/dist/types/src/util/facet.d.ts.map +0 -1
  310. package/src/components/EditorContent/EditorContent.stories.tsx +0 -70
  311. package/src/components/EditorMenuProvider/util.ts +0 -31
  312. package/src/defaults.ts +0 -52
  313. package/src/extensions/annotations.ts +0 -55
  314. package/src/extensions/autocomplete/autocomplete.ts +0 -151
  315. package/src/extensions/autocomplete/index.ts +0 -8
  316. package/src/extensions/autocomplete/match.ts +0 -46
  317. package/src/extensions/autocomplete/placeholder.ts +0 -117
  318. package/src/extensions/autocomplete/typeahead.ts +0 -87
  319. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  320. package/src/extensions/automerge/automerge.test.tsx +0 -78
  321. package/src/extensions/automerge/automerge.ts +0 -105
  322. package/src/extensions/automerge/cursor.ts +0 -28
  323. package/src/extensions/automerge/defs.ts +0 -31
  324. package/src/extensions/automerge/index.ts +0 -5
  325. package/src/extensions/automerge/sync.ts +0 -79
  326. package/src/extensions/automerge/update-automerge.ts +0 -50
  327. package/src/extensions/automerge/update-codemirror.ts +0 -115
  328. package/src/extensions/autoscroll.ts +0 -163
  329. package/src/extensions/awareness/awareness-provider.ts +0 -127
  330. package/src/extensions/awareness/awareness.ts +0 -315
  331. package/src/extensions/awareness/index.ts +0 -6
  332. package/src/extensions/blast.ts +0 -363
  333. package/src/extensions/blocks.ts +0 -131
  334. package/src/extensions/bookmarks.ts +0 -75
  335. package/src/extensions/comments.ts +0 -598
  336. package/src/extensions/debug.ts +0 -15
  337. package/src/extensions/dnd.ts +0 -37
  338. package/src/extensions/factories.ts +0 -278
  339. package/src/extensions/focus.ts +0 -36
  340. package/src/extensions/folding.tsx +0 -43
  341. package/src/extensions/hashtag.tsx +0 -68
  342. package/src/extensions/index.ts +0 -35
  343. package/src/extensions/json.ts +0 -57
  344. package/src/extensions/listener.ts +0 -32
  345. package/src/extensions/markdown/action.ts +0 -117
  346. package/src/extensions/markdown/bundle.ts +0 -105
  347. package/src/extensions/markdown/changes.test.ts +0 -26
  348. package/src/extensions/markdown/changes.ts +0 -149
  349. package/src/extensions/markdown/debug.ts +0 -44
  350. package/src/extensions/markdown/decorate.ts +0 -601
  351. package/src/extensions/markdown/formatting.test.ts +0 -498
  352. package/src/extensions/markdown/formatting.ts +0 -1265
  353. package/src/extensions/markdown/highlight.ts +0 -183
  354. package/src/extensions/markdown/image.ts +0 -118
  355. package/src/extensions/markdown/index.ts +0 -13
  356. package/src/extensions/markdown/link.ts +0 -50
  357. package/src/extensions/markdown/parser.test.ts +0 -75
  358. package/src/extensions/markdown/styles.ts +0 -135
  359. package/src/extensions/markdown/table.ts +0 -150
  360. package/src/extensions/mention.ts +0 -41
  361. package/src/extensions/modal.ts +0 -24
  362. package/src/extensions/modes.ts +0 -41
  363. package/src/extensions/outliner/commands.ts +0 -270
  364. package/src/extensions/outliner/editor.test.ts +0 -33
  365. package/src/extensions/outliner/editor.ts +0 -184
  366. package/src/extensions/outliner/index.ts +0 -7
  367. package/src/extensions/outliner/menu.ts +0 -128
  368. package/src/extensions/outliner/outliner.test.ts +0 -100
  369. package/src/extensions/outliner/outliner.ts +0 -167
  370. package/src/extensions/outliner/selection.ts +0 -50
  371. package/src/extensions/outliner/tree.test.ts +0 -168
  372. package/src/extensions/outliner/tree.ts +0 -317
  373. package/src/extensions/preview/index.ts +0 -5
  374. package/src/extensions/preview/preview.ts +0 -193
  375. package/src/extensions/replacer.test.ts +0 -75
  376. package/src/extensions/replacer.ts +0 -93
  377. package/src/extensions/scrolling.ts +0 -189
  378. package/src/extensions/selection.ts +0 -100
  379. package/src/extensions/state.ts +0 -7
  380. package/src/extensions/submit.ts +0 -62
  381. package/src/extensions/tab.ts +0 -29
  382. package/src/extensions/tags/extended-markdown.test.ts +0 -262
  383. package/src/extensions/tags/extended-markdown.ts +0 -78
  384. package/src/extensions/tags/index.ts +0 -7
  385. package/src/extensions/tags/streamer.ts +0 -243
  386. package/src/extensions/tags/xml-tags.ts +0 -500
  387. package/src/extensions/tags/xml-util.ts +0 -94
  388. package/src/extensions/typewriter.ts +0 -68
  389. package/src/stories/CommandDialog.stories.tsx +0 -83
  390. package/src/styles/index.ts +0 -7
  391. package/src/styles/markdown.ts +0 -26
  392. package/src/styles/theme.ts +0 -269
  393. package/src/styles/tokens.ts +0 -17
  394. package/src/types/index.ts +0 -5
  395. package/src/types/types.ts +0 -32
  396. package/src/util/cursor.ts +0 -56
  397. package/src/util/debug.ts +0 -69
  398. package/src/util/decorations.ts +0 -21
  399. package/src/util/dom.ts +0 -34
  400. package/src/util/facet.ts +0 -13
@@ -1,31 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { type EditorView } from '@codemirror/view';
6
-
7
- // TODO(burdon): Factor out.
8
-
9
- export const insertAtCursor = (view: EditorView, from: number, insert: string) => {
10
- view.dispatch({
11
- changes: { from, to: from, insert },
12
- selection: { anchor: from + insert.length, head: from + insert.length },
13
- });
14
- };
15
-
16
- /**
17
- * If the cursor is at the start of a line, insert the text at the cursor.
18
- * Otherwise, insert the text on a new line.
19
- */
20
- export const insertAtLineStart = (view: EditorView, from: number, insert: string) => {
21
- const line = view.state.doc.lineAt(from);
22
- if (line.from === from) {
23
- insertAtCursor(view, from, insert);
24
- } else {
25
- insert = '\n' + insert;
26
- view.dispatch({
27
- changes: { from: line.to, to: line.to, insert },
28
- selection: { anchor: line.to + insert.length, head: line.to + insert.length },
29
- });
30
- }
31
- };
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,151 +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
- /**
18
- * Function that returns a list of suggestions based on the current text.
19
- * @param text The current text before the cursor
20
- * @returns Array of suggestion strings
21
- */
22
- onSuggest?: (text: string) => string[];
23
- };
24
-
25
- /**
26
- * Creates an autocomplete extension that shows inline suggestions.
27
- * Pressing Tab will complete the suggestion.
28
- *
29
- * @deprecated Use typeahead.
30
- */
31
- export const autocomplete = ({ onSuggest }: AutocompleteOptions = {}): Extension => {
32
- const suggest = ViewPlugin.fromClass(
33
- class {
34
- _decorations: DecorationSet;
35
- _currentSuggestion: string | null = null;
36
-
37
- constructor(view: EditorView) {
38
- this._decorations = this.computeDecorations(view);
39
- }
40
-
41
- update(update: ViewUpdate) {
42
- if (update.docChanged || update.selectionSet) {
43
- this._decorations = this.computeDecorations(update.view);
44
- }
45
- }
46
-
47
- private computeDecorations(view: EditorView): DecorationSet {
48
- const text = view.state.doc.toString();
49
- const suggestions = onSuggest?.(text) ?? [];
50
- if (!suggestions.length) {
51
- this._currentSuggestion = null;
52
- return Decoration.none;
53
- }
54
-
55
- // Get the first suggestion.
56
- this._currentSuggestion = suggestions[0];
57
- const suffix = this._currentSuggestion.slice(text.length);
58
- if (!suffix) {
59
- return Decoration.none;
60
- }
61
-
62
- // Always show ghost text at the end of the document.
63
- return Decoration.set([
64
- Decoration.widget({
65
- widget: new InlineSuggestionWidget(suffix),
66
- side: 1,
67
- }).range(view.state.doc.length),
68
- ]);
69
- }
70
-
71
- completeSuggestion(view: EditorView): boolean {
72
- if (!this._currentSuggestion) {
73
- return false;
74
- }
75
-
76
- const text = view.state.doc.toString();
77
- const suffix = this._currentSuggestion.slice(text.length);
78
- if (!suffix) {
79
- return false;
80
- }
81
-
82
- view.dispatch({
83
- changes: {
84
- from: view.state.doc.length,
85
- insert: suffix,
86
- },
87
- selection: {
88
- anchor: view.state.doc.length + suffix.length,
89
- },
90
- });
91
-
92
- return true;
93
- }
94
- },
95
- {
96
- decorations: (v) => v._decorations,
97
- },
98
- );
99
-
100
- return [
101
- suggest,
102
- EditorView.theme({
103
- '.cm-inline-suggestion': {
104
- opacity: 0.4,
105
- },
106
- }),
107
-
108
- Prec.highest(
109
- keymap.of([
110
- {
111
- key: 'Tab',
112
- preventDefault: true,
113
- run: (view) => {
114
- const plugin = view.plugin(suggest);
115
- return plugin?.completeSuggestion(view) ?? false;
116
- },
117
- },
118
- {
119
- key: 'ArrowRight',
120
- preventDefault: true,
121
- run: (view) => {
122
- // Only complete if cursor is at the end
123
- if (view.state.selection.main.head !== view.state.doc.length) {
124
- return false;
125
- }
126
-
127
- const plugin = view.plugin(suggest);
128
- return plugin?.completeSuggestion(view) ?? false;
129
- },
130
- },
131
- ]),
132
- ),
133
- ];
134
- };
135
-
136
- class InlineSuggestionWidget extends WidgetType {
137
- constructor(private suffix: string) {
138
- super();
139
- }
140
-
141
- override eq(other: this) {
142
- return this.suffix === other.suffix;
143
- }
144
-
145
- override toDOM() {
146
- const span = document.createElement('span');
147
- span.textContent = this.suffix;
148
- span.className = 'cm-inline-suggestion';
149
- return span;
150
- }
151
- }
@@ -1,8 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- export * from './autocomplete';
6
- export * from './match';
7
- export * from './placeholder';
8
- export * from './typeahead';
@@ -1,46 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- export type CompoetionContext = { line: string };
6
-
7
- export type CompletionOptions = {
8
- default?: string;
9
- minLength?: number;
10
- };
11
-
12
- /**
13
- * Util to match current line to a static list of completions.
14
- */
15
- export const staticCompletion =
16
- (completions: string[], options: CompletionOptions = {}) =>
17
- ({ line }: CompoetionContext) => {
18
- if (line.length === 0 && options.default) {
19
- return options.default;
20
- }
21
-
22
- const parts = line.split(/\s+/).filter(Boolean);
23
- if (parts.length) {
24
- const str = parts.at(-1)!;
25
- if (str.length >= (options.minLength ?? 0)) {
26
- for (const completion of completions) {
27
- const match = matchCompletion(completion, str);
28
- if (match) {
29
- return match;
30
- }
31
- }
32
- }
33
- }
34
- };
35
-
36
- export const matchCompletion = (completion: string, str: string, minLength = 0): string | undefined => {
37
- if (
38
- str.length >= minLength &&
39
- completion.length > str.length &&
40
- completion.startsWith(str)
41
- // TODO(burdon): If case insensitive, need to replace existing chars.
42
- // completion.toLowerCase().startsWith(str.toLowerCase())
43
- ) {
44
- return completion.slice(str.length);
45
- }
46
- };
@@ -1,117 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- // Based on https://github.com/codemirror/view/blob/main/src/placeholder.ts
4
- //
5
-
6
- import { type Extension } from '@codemirror/state';
7
- import { Decoration, EditorView, ViewPlugin, type ViewUpdate, WidgetType } from '@codemirror/view';
8
-
9
- import { clientRectsFor, flattenRect } from '../../util';
10
-
11
- type Content = string | HTMLElement | ((view: EditorView) => HTMLElement);
12
-
13
- export type PlaceholderOptions = {
14
- content: Content;
15
- delay?: number;
16
- };
17
-
18
- /**
19
- * Shows a transient placeholder at the current cursor position.
20
- */
21
- export const placeholder = ({ content, delay = 3_000 }: PlaceholderOptions): Extension => {
22
- const plugin = ViewPlugin.fromClass(
23
- class {
24
- _timeout: ReturnType<typeof setTimeout> | undefined;
25
- _decorations = Decoration.none;
26
-
27
- update(update: ViewUpdate) {
28
- if (this._timeout) {
29
- window.clearTimeout(this._timeout);
30
- this._timeout = undefined;
31
- }
32
-
33
- // Check if the active line (where cursor is) is empty.
34
- const activeLine = update.view.state.doc.lineAt(update.view.state.selection.main.head);
35
- const isEmpty = activeLine.text.trim() === '';
36
- if (isEmpty) {
37
- // Create widget decoration at the start of the current line.
38
- const lineStart = activeLine.from;
39
- this._timeout = setTimeout(() => {
40
- this._decorations = Decoration.set([
41
- Decoration.widget({
42
- widget: new PlaceholderWidget(content),
43
- side: 1,
44
- }).range(lineStart),
45
- ]);
46
-
47
- update.view.update([]);
48
- }, delay);
49
- }
50
-
51
- this._decorations = Decoration.none;
52
- }
53
-
54
- destroy() {
55
- if (this._timeout) {
56
- clearTimeout(this._timeout);
57
- }
58
- }
59
- },
60
- {
61
- provide: (plugin) => {
62
- return [EditorView.decorations.of((view) => view.plugin(plugin)?._decorations ?? Decoration.none)];
63
- },
64
- },
65
- );
66
-
67
- return typeof content === 'string'
68
- ? [plugin, EditorView.contentAttributes.of({ 'aria-placeholder': content })]
69
- : plugin;
70
- };
71
-
72
- export class PlaceholderWidget extends WidgetType {
73
- constructor(readonly content: Content) {
74
- super();
75
- }
76
-
77
- toDOM(view: EditorView) {
78
- const wrap = document.createElement('span');
79
- wrap.className = 'cm-placeholder';
80
- wrap.style.pointerEvents = 'none';
81
- wrap.setAttribute('aria-hidden', 'true');
82
- wrap.appendChild(
83
- typeof this.content === 'string'
84
- ? document.createTextNode(this.content)
85
- : typeof this.content === 'function'
86
- ? this.content(view)
87
- : this.content.cloneNode(true),
88
- );
89
-
90
- return wrap;
91
- }
92
-
93
- override coordsAt(dom: HTMLElement) {
94
- const rects = dom.firstChild ? clientRectsFor(dom.firstChild) : [];
95
- if (!rects.length) {
96
- return null;
97
- }
98
-
99
- const style = getComputedStyle(dom.parentNode as HTMLElement);
100
- const rect = flattenRect(rects[0], style.direction !== 'rtl');
101
- const lineHeight = parseInt(style.lineHeight);
102
- if (rect.bottom - rect.top > lineHeight * 1.5) {
103
- return {
104
- left: rect.left,
105
- right: rect.right,
106
- top: rect.top,
107
- bottom: rect.top + lineHeight,
108
- };
109
- }
110
-
111
- return rect;
112
- }
113
-
114
- override ignoreEvent() {
115
- return false;
116
- }
117
- }
@@ -1,87 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { EditorSelection, type Extension, Prec, RangeSetBuilder } from '@codemirror/state';
6
- import {
7
- type Command,
8
- Decoration,
9
- type DecorationSet,
10
- type EditorView,
11
- ViewPlugin,
12
- type ViewUpdate,
13
- keymap,
14
- } from '@codemirror/view';
15
-
16
- import { type CompoetionContext } from './match';
17
- import { PlaceholderWidget } from './placeholder';
18
-
19
- // TODO(burdon): Option to complete only at end of line.
20
- export type TypeaheadOptions = {
21
- onComplete?: (context: CompoetionContext) => string | undefined;
22
- };
23
-
24
- /**
25
- * Shows a completion placeholder.
26
- */
27
- export const typeahead = ({ onComplete }: TypeaheadOptions = {}): Extension => {
28
- let hint: string | undefined;
29
-
30
- const complete: Command = (view: EditorView) => {
31
- if (!hint) {
32
- return false;
33
- }
34
-
35
- const selection = view.state.selection.main;
36
- view.dispatch({
37
- changes: [{ from: selection.from, to: selection.to, insert: hint }],
38
- selection: EditorSelection.cursor(selection.from + hint.length),
39
- });
40
-
41
- return true;
42
- };
43
-
44
- return [
45
- ViewPlugin.fromClass(
46
- class {
47
- decorations: DecorationSet = Decoration.none;
48
- update(update: ViewUpdate) {
49
- const builder = new RangeSetBuilder<Decoration>();
50
- const selection = update.view.state.selection.main;
51
- const line = update.view.state.doc.lineAt(selection.from);
52
-
53
- // TODO(burdon): Check at end of line and matches start of previous word.
54
- // TODO(burdon): Context grammar.
55
- if (selection.from === selection.to && selection.from === line.to) {
56
- const str = update.state.sliceDoc(line.from, selection.from);
57
- hint = onComplete?.({ line: str });
58
- if (hint) {
59
- builder.add(selection.from, selection.to, Decoration.widget({ widget: new PlaceholderWidget(hint) }));
60
- }
61
- }
62
-
63
- this.decorations = builder.finish();
64
- }
65
- },
66
- {
67
- decorations: (v) => v.decorations,
68
- },
69
- ),
70
-
71
- // Keys.
72
- Prec.highest(
73
- keymap.of([
74
- {
75
- key: 'Tab',
76
- preventDefault: true,
77
- run: complete,
78
- },
79
- {
80
- key: 'ArrowRight',
81
- preventDefault: true,
82
- run: complete,
83
- },
84
- ]),
85
- ),
86
- ];
87
- };
@@ -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 is-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
- };