@dxos/react-ui-editor 0.8.4-main.1da679c → 0.8.4-main.21d9917

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 (426) hide show
  1. package/dist/lib/browser/index.mjs +1171 -8426
  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 +1171 -8425
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/types/src/components/Editor/Editor.d.ts +43 -15
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +23 -0
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +31 -0
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
  13. package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
  14. package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
  15. package/dist/types/src/components/EditorContent/index.d.ts +3 -0
  16. package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +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 +24 -0
  36. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  37. package/dist/types/src/components/EditorToolbar/blocks.d.ts +8 -7
  38. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/formatting.d.ts +8 -7
  40. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/headings.d.ts +8 -7
  42. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/image.d.ts +4 -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 +4 -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 +9 -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 +6 -10
  56. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  57. package/dist/types/src/index.d.ts +0 -8
  58. package/dist/types/src/index.d.ts.map +1 -1
  59. package/dist/types/src/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +6 -10
  60. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  61. package/dist/types/src/stories/{Command.stories.d.ts → CommandDialog.stories.d.ts} +2 -3
  62. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  63. package/dist/types/src/stories/Comments.stories.d.ts +4 -4
  64. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/EditorToolbar.stories.d.ts +5 -6
  66. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  67. package/dist/types/src/stories/Experimental.stories.d.ts +4 -4
  68. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  69. package/dist/types/src/stories/Markdown.stories.d.ts +4 -4
  70. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/Outliner.stories.d.ts +0 -1
  72. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  73. package/dist/types/src/stories/{CommandMenu.stories.d.ts → Popover.stories.d.ts} +6 -6
  74. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  75. package/dist/types/src/stories/Preview.stories.d.ts +5 -4
  76. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  77. package/dist/types/src/stories/Tags.stories.d.ts +0 -1
  78. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/TextEditor.stories.d.ts +4 -5
  80. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  81. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  82. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  83. package/dist/types/src/stories/components/EditorStory.d.ts +10 -19
  84. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  85. package/dist/types/src/stories/components/util.d.ts +3 -3
  86. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  87. package/dist/types/src/translations.d.ts +5 -5
  88. package/dist/types/src/translations.d.ts.map +1 -1
  89. package/dist/types/src/util/index.d.ts +0 -6
  90. package/dist/types/src/util/index.d.ts.map +1 -1
  91. package/dist/types/src/util/react.d.ts +5 -1
  92. package/dist/types/src/util/react.d.ts.map +1 -1
  93. package/dist/types/tsconfig.tsbuildinfo +1 -1
  94. package/package.json +70 -73
  95. package/src/components/Editor/Editor.stories.tsx +95 -0
  96. package/src/components/Editor/Editor.tsx +164 -24
  97. package/src/components/EditorContent/EditorContent.tsx +83 -0
  98. package/src/components/EditorContent/controller.ts +50 -0
  99. package/src/components/EditorContent/index.ts +6 -0
  100. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +233 -0
  101. package/src/components/EditorMenuProvider/index.ts +10 -0
  102. package/src/components/EditorMenuProvider/menu-presets.ts +124 -0
  103. package/src/components/EditorMenuProvider/menu.ts +70 -0
  104. package/src/components/EditorMenuProvider/popover.ts +285 -0
  105. package/src/components/EditorMenuProvider/useEditorMenu.ts +173 -0
  106. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +81 -0
  107. package/src/components/EditorPreviewProvider/index.ts +5 -0
  108. package/src/components/EditorToolbar/EditorToolbar.tsx +105 -91
  109. package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
  110. package/src/components/EditorToolbar/blocks.ts +5 -5
  111. package/src/components/EditorToolbar/formatting.ts +5 -5
  112. package/src/components/EditorToolbar/headings.ts +11 -8
  113. package/src/components/EditorToolbar/image.ts +9 -2
  114. package/src/components/EditorToolbar/index.ts +3 -7
  115. package/src/components/EditorToolbar/search.ts +9 -2
  116. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  117. package/src/components/EditorToolbar/view-mode.ts +5 -4
  118. package/src/components/index.ts +6 -2
  119. package/src/hooks/useTextEditor.ts +39 -33
  120. package/src/index.ts +0 -10
  121. package/src/stories/Automerge.stories.tsx +175 -0
  122. package/src/stories/{Command.stories.tsx → CommandDialog.stories.tsx} +21 -30
  123. package/src/stories/Comments.stories.tsx +51 -47
  124. package/src/stories/EditorToolbar.stories.tsx +39 -23
  125. package/src/stories/Experimental.stories.tsx +10 -12
  126. package/src/stories/Markdown.stories.tsx +19 -19
  127. package/src/stories/Outliner.stories.tsx +23 -24
  128. package/src/stories/Popover.stories.tsx +158 -0
  129. package/src/stories/Preview.stories.tsx +94 -85
  130. package/src/stories/Tags.stories.tsx +37 -14
  131. package/src/stories/TextEditor.stories.tsx +20 -51
  132. package/src/stories/Theme.stories.tsx +61 -0
  133. package/src/stories/components/EditorStory.tsx +36 -27
  134. package/src/stories/components/util.tsx +43 -11
  135. package/src/translations.ts +4 -4
  136. package/src/util/index.ts +1 -7
  137. package/src/util/react.tsx +6 -2
  138. package/dist/lib/browser/chunk-22UMM3QJ.mjs +0 -22
  139. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  140. package/dist/lib/browser/testing/index.mjs +0 -76
  141. package/dist/lib/browser/testing/index.mjs.map +0 -7
  142. package/dist/lib/browser/types/index.mjs +0 -13
  143. package/dist/lib/browser/types/index.mjs.map +0 -7
  144. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs +0 -24
  145. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  146. package/dist/lib/node-esm/testing/index.mjs +0 -78
  147. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  148. package/dist/lib/node-esm/types/index.mjs +0 -14
  149. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  150. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts +0 -38
  151. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts.map +0 -1
  152. package/dist/types/src/components/CommandMenu/index.d.ts +0 -2
  153. package/dist/types/src/components/CommandMenu/index.d.ts.map +0 -1
  154. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  155. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  156. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  157. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  158. package/dist/types/src/defaults.d.ts +0 -14
  159. package/dist/types/src/defaults.d.ts.map +0 -1
  160. package/dist/types/src/extensions/annotations.d.ts +0 -9
  161. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  162. package/dist/types/src/extensions/autocomplete.d.ts +0 -26
  163. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  164. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  165. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  166. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  167. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  168. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  169. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  170. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  171. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  172. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  173. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  174. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  175. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  176. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  177. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  178. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  179. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  180. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  181. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  182. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  183. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  184. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  185. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  186. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  187. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  188. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  189. package/dist/types/src/extensions/blast.d.ts +0 -25
  190. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  191. package/dist/types/src/extensions/command/action.d.ts +0 -17
  192. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  193. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  194. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  195. package/dist/types/src/extensions/command/command.d.ts +0 -6
  196. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  197. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  198. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  199. package/dist/types/src/extensions/command/hint.d.ts +0 -19
  200. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  201. package/dist/types/src/extensions/command/index.d.ts +0 -7
  202. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  203. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  204. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  205. package/dist/types/src/extensions/command/state.d.ts +0 -16
  206. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  207. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  208. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  209. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -25
  210. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  211. package/dist/types/src/extensions/comments.d.ts +0 -95
  212. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  213. package/dist/types/src/extensions/debug.d.ts +0 -3
  214. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  215. package/dist/types/src/extensions/dnd.d.ts +0 -9
  216. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  217. package/dist/types/src/extensions/factories.d.ts +0 -78
  218. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  219. package/dist/types/src/extensions/focus.d.ts +0 -7
  220. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  221. package/dist/types/src/extensions/folding.d.ts +0 -7
  222. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  223. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  224. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  225. package/dist/types/src/extensions/index.d.ts +0 -25
  226. package/dist/types/src/extensions/index.d.ts.map +0 -1
  227. package/dist/types/src/extensions/json.d.ts +0 -7
  228. package/dist/types/src/extensions/json.d.ts.map +0 -1
  229. package/dist/types/src/extensions/listener.d.ts +0 -11
  230. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  231. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  232. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  233. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  234. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  235. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  236. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  237. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  238. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  239. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  240. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  241. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  242. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  243. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  244. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  245. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  246. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  247. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  248. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  249. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  250. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  251. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  252. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  253. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  254. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  255. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  256. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  257. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  258. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  259. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  260. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  261. package/dist/types/src/extensions/mention.d.ts +0 -7
  262. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  263. package/dist/types/src/extensions/modes.d.ts +0 -10
  264. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  265. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  266. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  267. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  268. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  269. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  270. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  271. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  272. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  273. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  274. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  275. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  276. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  277. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  278. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  279. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  280. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  281. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  282. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  283. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  284. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  285. package/dist/types/src/extensions/preview/preview.d.ts +0 -29
  286. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  287. package/dist/types/src/extensions/selection.d.ts +0 -24
  288. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  289. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  290. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  291. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  292. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  293. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  294. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  295. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  296. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  297. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -71
  298. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  299. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  300. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  301. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  302. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  303. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  304. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  305. package/dist/types/src/styles/index.d.ts +0 -4
  306. package/dist/types/src/styles/index.d.ts.map +0 -1
  307. package/dist/types/src/styles/markdown.d.ts +0 -8
  308. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  309. package/dist/types/src/styles/theme.d.ts +0 -38
  310. package/dist/types/src/styles/theme.d.ts.map +0 -1
  311. package/dist/types/src/styles/tokens.d.ts +0 -3
  312. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  313. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  314. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  315. package/dist/types/src/testing/index.d.ts +0 -3
  316. package/dist/types/src/testing/index.d.ts.map +0 -1
  317. package/dist/types/src/testing/util.d.ts +0 -3
  318. package/dist/types/src/testing/util.d.ts.map +0 -1
  319. package/dist/types/src/types/index.d.ts +0 -2
  320. package/dist/types/src/types/index.d.ts.map +0 -1
  321. package/dist/types/src/types/types.d.ts +0 -21
  322. package/dist/types/src/types/types.d.ts.map +0 -1
  323. package/dist/types/src/util/cursor.d.ts +0 -31
  324. package/dist/types/src/util/cursor.d.ts.map +0 -1
  325. package/dist/types/src/util/debug.d.ts +0 -17
  326. package/dist/types/src/util/debug.d.ts.map +0 -1
  327. package/dist/types/src/util/decorations.d.ts +0 -4
  328. package/dist/types/src/util/decorations.d.ts.map +0 -1
  329. package/dist/types/src/util/dom.d.ts +0 -10
  330. package/dist/types/src/util/dom.d.ts.map +0 -1
  331. package/dist/types/src/util/domino.d.ts +0 -18
  332. package/dist/types/src/util/domino.d.ts.map +0 -1
  333. package/dist/types/src/util/facet.d.ts +0 -3
  334. package/dist/types/src/util/facet.d.ts.map +0 -1
  335. package/src/components/CommandMenu/CommandMenu.tsx +0 -346
  336. package/src/components/CommandMenu/index.ts +0 -5
  337. package/src/components/EditorToolbar/util.ts +0 -76
  338. package/src/defaults.ts +0 -52
  339. package/src/extensions/annotations.ts +0 -55
  340. package/src/extensions/autocomplete.ts +0 -219
  341. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  342. package/src/extensions/automerge/automerge.test.tsx +0 -78
  343. package/src/extensions/automerge/automerge.ts +0 -86
  344. package/src/extensions/automerge/cursor.ts +0 -28
  345. package/src/extensions/automerge/defs.ts +0 -31
  346. package/src/extensions/automerge/index.ts +0 -5
  347. package/src/extensions/automerge/sync.ts +0 -75
  348. package/src/extensions/automerge/update-automerge.ts +0 -50
  349. package/src/extensions/automerge/update-codemirror.ts +0 -115
  350. package/src/extensions/autoscroll.ts +0 -157
  351. package/src/extensions/awareness/awareness-provider.ts +0 -127
  352. package/src/extensions/awareness/awareness.ts +0 -315
  353. package/src/extensions/awareness/index.ts +0 -6
  354. package/src/extensions/blast.ts +0 -363
  355. package/src/extensions/command/action.ts +0 -55
  356. package/src/extensions/command/command-menu.ts +0 -211
  357. package/src/extensions/command/command.ts +0 -34
  358. package/src/extensions/command/floating-menu.ts +0 -128
  359. package/src/extensions/command/hint.ts +0 -103
  360. package/src/extensions/command/index.ts +0 -10
  361. package/src/extensions/command/placeholder.ts +0 -113
  362. package/src/extensions/command/state.ts +0 -90
  363. package/src/extensions/command/typeahead.ts +0 -129
  364. package/src/extensions/command/useCommandMenu.ts +0 -115
  365. package/src/extensions/comments.ts +0 -597
  366. package/src/extensions/debug.ts +0 -15
  367. package/src/extensions/dnd.ts +0 -37
  368. package/src/extensions/factories.ts +0 -247
  369. package/src/extensions/focus.ts +0 -35
  370. package/src/extensions/folding.tsx +0 -46
  371. package/src/extensions/hashtag.tsx +0 -68
  372. package/src/extensions/index.ts +0 -28
  373. package/src/extensions/json.ts +0 -57
  374. package/src/extensions/listener.ts +0 -38
  375. package/src/extensions/markdown/action.ts +0 -117
  376. package/src/extensions/markdown/bundle.ts +0 -93
  377. package/src/extensions/markdown/changes.test.ts +0 -26
  378. package/src/extensions/markdown/changes.ts +0 -149
  379. package/src/extensions/markdown/debug.ts +0 -44
  380. package/src/extensions/markdown/decorate.ts +0 -600
  381. package/src/extensions/markdown/formatting.test.ts +0 -498
  382. package/src/extensions/markdown/formatting.ts +0 -1267
  383. package/src/extensions/markdown/highlight.ts +0 -183
  384. package/src/extensions/markdown/image.ts +0 -118
  385. package/src/extensions/markdown/index.ts +0 -13
  386. package/src/extensions/markdown/link.ts +0 -50
  387. package/src/extensions/markdown/parser.test.ts +0 -75
  388. package/src/extensions/markdown/styles.ts +0 -135
  389. package/src/extensions/markdown/table.ts +0 -150
  390. package/src/extensions/mention.ts +0 -41
  391. package/src/extensions/modes.ts +0 -41
  392. package/src/extensions/outliner/commands.ts +0 -270
  393. package/src/extensions/outliner/editor.test.ts +0 -33
  394. package/src/extensions/outliner/editor.ts +0 -184
  395. package/src/extensions/outliner/index.ts +0 -7
  396. package/src/extensions/outliner/outliner.test.ts +0 -100
  397. package/src/extensions/outliner/outliner.ts +0 -167
  398. package/src/extensions/outliner/selection.ts +0 -50
  399. package/src/extensions/outliner/tree.test.ts +0 -168
  400. package/src/extensions/outliner/tree.ts +0 -317
  401. package/src/extensions/preview/index.ts +0 -5
  402. package/src/extensions/preview/preview.ts +0 -190
  403. package/src/extensions/selection.ts +0 -100
  404. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  405. package/src/extensions/tags/extended-markdown.ts +0 -78
  406. package/src/extensions/tags/index.ts +0 -7
  407. package/src/extensions/tags/streamer.ts +0 -244
  408. package/src/extensions/tags/xml-tags.ts +0 -335
  409. package/src/extensions/tags/xml-util.ts +0 -94
  410. package/src/extensions/typewriter.ts +0 -68
  411. package/src/stories/CommandMenu.stories.tsx +0 -158
  412. package/src/styles/index.ts +0 -7
  413. package/src/styles/markdown.ts +0 -26
  414. package/src/styles/theme.ts +0 -267
  415. package/src/styles/tokens.ts +0 -17
  416. package/src/testing/PreviewPopover.tsx +0 -78
  417. package/src/testing/index.ts +0 -6
  418. package/src/testing/util.ts +0 -7
  419. package/src/types/index.ts +0 -5
  420. package/src/types/types.ts +0 -32
  421. package/src/util/cursor.ts +0 -56
  422. package/src/util/debug.ts +0 -64
  423. package/src/util/decorations.ts +0 -21
  424. package/src/util/dom.ts +0 -34
  425. package/src/util/domino.ts +0 -51
  426. package/src/util/facet.ts +0 -13
@@ -2,8 +2,6 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
5
  import { syntaxTree } from '@codemirror/language';
8
6
  import { type EditorView } from '@codemirror/view';
9
7
  import { type Meta, type StoryObj } from '@storybook/react-vite';
@@ -13,13 +11,20 @@ import { createPortal } from 'react-dom';
13
11
  import { invariant } from '@dxos/invariant';
14
12
  import { faker } from '@dxos/random';
15
13
  import { Popover } from '@dxos/react-ui';
16
- import { Card } from '@dxos/react-ui-stack';
17
- import { hoverableControlItem, hoverableControlItemTransition, hoverableControls } from '@dxos/react-ui-theme';
18
- import { withLayout, withTheme } from '@dxos/storybook-utils';
19
- import { trim } from '@dxos/util';
20
-
21
- import { type PreviewLinkRef, type PreviewLinkTarget, getLinkRef, image, preview } from '../extensions';
22
- import { PreviewPopoverProvider, usePreviewPopover } from '../testing';
14
+ import { withTheme } from '@dxos/react-ui/testing';
15
+ import { Card } from '@dxos/react-ui-mosaic';
16
+ import {
17
+ type PreviewBlock,
18
+ type PreviewLinkRef,
19
+ type PreviewLinkTarget,
20
+ getLinkRef,
21
+ image,
22
+ preview,
23
+ } from '@dxos/ui-editor';
24
+ import { hoverableControls } from '@dxos/ui-theme';
25
+ import { isTruthy, trim } from '@dxos/util';
26
+
27
+ import { type EditorController, EditorPreviewProvider, useEditorPreview } from '../components';
23
28
 
24
29
  import { EditorStory } from './components';
25
30
 
@@ -45,15 +50,26 @@ const useRefTarget = (link: PreviewLinkRef): PreviewLinkTarget | undefined => {
45
50
  };
46
51
 
47
52
  const PreviewCard = () => {
48
- const { target } = usePreviewPopover('PreviewCard');
53
+ const { target } = useEditorPreview('PreviewCard');
54
+
49
55
  return (
50
56
  <Popover.Portal>
51
57
  <Popover.Content onOpenAutoFocus={(event) => event.preventDefault()}>
52
- <Popover.Viewport>
53
- <Card.SurfaceRoot role='card--popover'>
54
- <Card.Heading>{target?.label}</Card.Heading>
55
- {target && <Card.Text classNames='line-clamp-3'>{target.text}</Card.Text>}
56
- </Card.SurfaceRoot>
58
+ <Popover.Viewport classNames='popover-card-width'>
59
+ <Card.Root border={false}>
60
+ <Card.Toolbar>
61
+ <Card.Icon toolbar icon='ph--file-text--regular' />
62
+ <Card.Title>{target?.label}</Card.Title>
63
+ <Popover.Close asChild>
64
+ <Card.Close />
65
+ </Popover.Close>
66
+ </Card.Toolbar>
67
+ {target && (
68
+ <Card.Row>
69
+ <Card.Text variant='description'>{target.text}</Card.Text>
70
+ </Card.Row>
71
+ )}
72
+ </Card.Root>
57
73
  </Popover.Viewport>
58
74
  <Popover.Arrow />
59
75
  </Popover.Content>
@@ -72,7 +88,7 @@ type PreviewAction =
72
88
  link: PreviewLinkRef;
73
89
  };
74
90
 
75
- const PreviewBlock = ({ link, el, view }: { link: PreviewLinkRef; el: HTMLElement; view?: EditorView }) => {
91
+ const PreviewBlockComponent = ({ link, el, view }: { link: PreviewLinkRef; el: HTMLElement; view?: EditorView }) => {
76
92
  const target = useRefTarget(link);
77
93
 
78
94
  const handleAction = useCallback(
@@ -128,40 +144,35 @@ const PreviewBlock = ({ link, el, view }: { link: PreviewLinkRef; el: HTMLElemen
128
144
  }, [handleAction, link, target]);
129
145
 
130
146
  return createPortal(
131
- <Card.StaticRoot classNames={hoverableControls}>
132
- <div className='flex items-start'>
133
- {!view?.state.readOnly && (
134
- <Card.Toolbar classNames='is-min p-[--dx-cardSpacingInline]'>
135
- {(link.suggest && (
136
- <>
137
- <Card.ToolbarIconButton label='Discard' icon='ph--x--regular' onClick={handleDelete} />
138
- {target && (
139
- <Card.ToolbarIconButton
140
- classNames='bg-successSurface text-successSurfaceText'
141
- label='Apply'
142
- icon='ph--check--regular'
143
- onClick={handleInsert}
144
- />
145
- )}
146
- </>
147
- )) || (
148
- <Card.ToolbarIconButton
149
- iconOnly
150
- label='Delete'
151
- icon='ph--x--regular'
152
- classNames={[hoverableControlItem, hoverableControlItemTransition]}
153
- onClick={handleDelete}
154
- />
155
- )}
156
- </Card.Toolbar>
157
- )}
158
- <Card.Heading classNames='grow order-first mie-0'>
159
- {/* <span className='text-xs text-subdued mie-2'>Prompt</span> */}
160
- {link.label}
161
- </Card.Heading>
162
- </div>
163
- {target && <Card.Text classNames='line-clamp-3 mbs-0'>{target.text}</Card.Text>}
164
- </Card.StaticRoot>,
147
+ <Card.Root classNames={hoverableControls}>
148
+ {!view?.state.readOnly && (
149
+ <Card.Toolbar>
150
+ <Card.Icon toolbar icon='ph--bookmark--regular' />
151
+ <Card.Title>{link.label}</Card.Title>
152
+ <Card.Menu
153
+ items={[
154
+ {
155
+ id: 'delete',
156
+ label: link.suggest ? 'Discard' : 'Delete',
157
+ icon: 'ph--x--regular',
158
+ onClick: handleDelete,
159
+ },
160
+ target && {
161
+ id: 'apply',
162
+ label: 'Apply',
163
+ icon: 'ph--check--regular',
164
+ onClick: handleInsert,
165
+ },
166
+ ].filter(isTruthy)}
167
+ />
168
+ </Card.Toolbar>
169
+ )}
170
+ {target && (
171
+ <Card.Row>
172
+ <Card.Text className='text-description'>{target.text}</Card.Text>
173
+ </Card.Row>
174
+ )}
175
+ </Card.Root>,
165
176
  el,
166
177
  );
167
178
  };
@@ -169,61 +180,59 @@ const PreviewBlock = ({ link, el, view }: { link: PreviewLinkRef; el: HTMLElemen
169
180
  const meta = {
170
181
  title: 'ui/react-ui-editor/Preview',
171
182
  component: EditorStory,
172
- decorators: [withTheme, withLayout({ fullscreen: true })],
173
- parameters: { layout: 'fullscreen' },
183
+ decorators: [withTheme],
184
+ parameters: {
185
+ layout: 'fullscreen',
186
+ },
174
187
  } satisfies Meta<typeof EditorStory>;
175
188
 
176
189
  export default meta;
177
190
 
178
191
  type Story = StoryObj<typeof meta>;
179
192
 
193
+ const text = trim`
194
+ # Preview
195
+
196
+ This project is part of the [DXOS](dxn:queue:data:123) SDK.
197
+
198
+ ![DXOS](dxn:queue:data:123)
199
+
200
+ It consists of [ECHO](dxn:queue:data:echo), [HALO](dxn:queue:data:halo), and [MESH](dxn:queue:data:mesh).
201
+
202
+ ## Deep dive
203
+
204
+ ![ECHO](dxn:queue:data:echo)
205
+
206
+ `;
207
+
180
208
  export const Default: Story = {
181
209
  render: () => {
182
- const [view, setView] = useState<EditorView>();
183
- const [previewBlocks, setPreviewBlocks] = useState<{ link: PreviewLinkRef; el: HTMLElement }[]>([]);
210
+ const [controller, setController] = useState<EditorController | null>(null);
211
+ const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);
184
212
  const extensions = useMemo(() => {
185
213
  return [
186
214
  image(),
187
215
  preview({
188
- addBlockContainer: (link, el) => {
189
- setPreviewBlocks((prev) => [...prev, { link, el }]);
216
+ addBlockContainer: (block) => {
217
+ setPreviewBlocks((prev) => [...prev, block]);
190
218
  },
191
- removeBlockContainer: (link) => {
192
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
219
+ removeBlockContainer: (block) => {
220
+ setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== block.link.ref));
193
221
  },
194
222
  }),
195
223
  ];
196
224
  }, []);
197
225
 
198
- const handleViewRef = useCallback((instance?: EditorView | null) => {
199
- setView(instance ?? undefined);
200
- }, []);
201
-
226
+ // TODO(burdon): Migrate to Editor.Root.
202
227
  return (
203
- <PreviewPopoverProvider onLookup={handlePreviewLookup}>
204
- <EditorStory
205
- ref={handleViewRef}
206
- text={trim`
207
- # Preview
208
-
209
- This project is part of the [DXOS](dxn:queue:data:123) SDK.
210
-
211
- ![DXOS](dxn:queue:data:123)
212
-
213
- It consists of [ECHO](dxn:queue:data:echo), [HALO](dxn:queue:data:halo), and [MESH](dxn:queue:data:mesh).
214
-
215
- ## Deep dive
216
-
217
- ![ECHO](dxn:queue:data:echo)
218
-
219
- `}
220
- extensions={extensions}
221
- />
228
+ <EditorPreviewProvider onLookup={handlePreviewLookup}>
229
+ <EditorStory ref={setController} text={text} extensions={extensions} />
222
230
  <PreviewCard />
223
- {previewBlocks.map(({ link, el }) => (
224
- <PreviewBlock key={link.ref} link={link} el={el} view={view} />
225
- ))}
226
- </PreviewPopoverProvider>
231
+ {controller?.view &&
232
+ previewBlocks.map(({ link, el }) => (
233
+ <PreviewBlockComponent key={link.ref} link={link} el={el} view={controller.view!} />
234
+ ))}
235
+ </EditorPreviewProvider>
227
236
  );
228
237
  },
229
238
  };
@@ -2,16 +2,12 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
8
- import React, { useState } from 'react';
6
+ import React, { useEffect, useState } from 'react';
9
7
  import { createPortal } from 'react-dom';
10
8
 
11
9
  import { useThemeContext } from '@dxos/react-ui';
12
- import { withLayout, withTheme } from '@dxos/storybook-utils';
13
- import { trim } from '@dxos/util';
14
-
10
+ import { withTheme } from '@dxos/react-ui/testing';
15
11
  import {
16
12
  type XmlWidgetRegistry,
17
13
  type XmlWidgetState,
@@ -20,14 +16,35 @@ import {
20
16
  decorateMarkdown,
21
17
  extendedMarkdown,
22
18
  xmlTags,
23
- } from '../extensions';
19
+ } from '@dxos/ui-editor';
20
+ import { safeParseInt, trim } from '@dxos/util';
21
+
24
22
  import { useTextEditor } from '../hooks';
25
23
 
26
24
  const registry = {
27
- // <test/>
25
+ /**
26
+ * Custom tag: <test/>
27
+ */
28
28
  ['test' as const]: {
29
29
  block: true,
30
- Component: () => <div className='p-2 border border-separator rounded'>Test</div>,
30
+ Component: ({ start = '0' }) => {
31
+ const [count, setCount] = useState<number>(safeParseInt(start, 0));
32
+ useEffect(() => {
33
+ const interval = setInterval(() => {
34
+ setCount((prev) => {
35
+ if (prev >= 200) {
36
+ clearInterval(interval);
37
+ return prev;
38
+ }
39
+
40
+ return prev + 1;
41
+ });
42
+ }, 100);
43
+ return () => clearInterval(interval);
44
+ }, []);
45
+
46
+ return <div className='p-2 border border-separator rounded'>Test {count}</div>;
47
+ },
31
48
  },
32
49
  } satisfies XmlWidgetRegistry;
33
50
 
@@ -38,7 +55,7 @@ const DefaultStory = ({ text }: { text?: string }) => {
38
55
  initialValue: text,
39
56
  extensions: [
40
57
  createThemeExtensions({ themeMode }),
41
- createBasicExtensions({ lineWrapping: true, readOnly: true }),
58
+ createBasicExtensions({ lineWrapping: true }),
42
59
  decorateMarkdown(),
43
60
  extendedMarkdown({ registry }),
44
61
  xmlTags({ registry, setWidgets }),
@@ -48,7 +65,7 @@ const DefaultStory = ({ text }: { text?: string }) => {
48
65
  return (
49
66
  <>
50
67
  <div ref={parentRef} className='is-full p-4' />
51
- {widgets.map(({ Component, root, id, ...props }) => (
68
+ {widgets.map(({ id, root, Component, props }) => (
52
69
  <div key={id}>{createPortal(<Component {...props} />, root)}</div>
53
70
  ))}
54
71
  </>
@@ -58,7 +75,11 @@ const DefaultStory = ({ text }: { text?: string }) => {
58
75
  const text = trim`
59
76
  # Tags
60
77
 
61
- <test id="123" />
78
+ React widget below.
79
+
80
+ <test id="t-1" />
81
+
82
+ <test id="t-2" start="100" />
62
83
 
63
84
  React widget above.
64
85
  `;
@@ -66,8 +87,10 @@ const text = trim`
66
87
  const meta = {
67
88
  title: 'ui/react-ui-editor/Tags',
68
89
  render: DefaultStory,
69
- decorators: [withTheme, withLayout({ fullscreen: true })],
70
- parameters: { layout: 'fullscreen' },
90
+ decorators: [withTheme],
91
+ parameters: {
92
+ layout: 'fullscreen',
93
+ },
71
94
  } satisfies Meta<typeof DefaultStory>;
72
95
 
73
96
  export default meta;
@@ -2,30 +2,25 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
5
  import { javascript } from '@codemirror/lang-javascript';
8
6
  import { openSearchPanel } from '@codemirror/search';
9
7
  import { type Meta, type StoryObj } from '@storybook/react-vite';
10
8
  import React from 'react';
11
9
 
12
10
  import { log } from '@dxos/log';
13
- import { withLayout, withTheme } from '@dxos/storybook-utils';
14
-
15
- import { editorMonospace } from '../defaults';
11
+ import { withTheme } from '@dxos/react-ui/testing';
16
12
  import {
17
13
  InputModeExtensions,
18
- autocomplete,
19
14
  decorateMarkdown,
20
15
  folding,
21
16
  image,
17
+ join,
22
18
  listener,
23
19
  mention,
24
20
  selectionState,
25
21
  staticCompletion,
26
22
  typeahead,
27
- } from '../extensions';
28
- import { str } from '../testing';
23
+ } from '@dxos/ui-editor';
29
24
 
30
25
  import {
31
26
  EditorStory,
@@ -34,18 +29,19 @@ import {
34
29
  defaultExtensions,
35
30
  global,
36
31
  largeWithImages,
37
- links,
38
32
  longText,
39
33
  names,
40
- renderLinkButton,
41
34
  text,
42
35
  } from './components';
43
36
 
44
37
  const meta = {
45
38
  title: 'ui/react-ui-editor/TextEditor',
46
39
  component: EditorStory,
47
- decorators: [withTheme, withLayout({ fullscreen: true })],
48
- parameters: { layout: 'fullscreen', controls: { disable: true } },
40
+ decorators: [withTheme],
41
+ parameters: {
42
+ layout: 'fullscreen',
43
+ controls: { disable: true },
44
+ },
49
45
  } satisfies Meta<typeof EditorStory>;
50
46
 
51
47
  export default meta;
@@ -99,7 +95,7 @@ export const NoExtensions: Story = {
99
95
  export const Vim: Story = {
100
96
  render: () => (
101
97
  <EditorStory
102
- text={str('# Vim Mode', '', 'The distant future. The year 2000.', '', content.paragraphs)}
98
+ text={join('# Vim Mode', '', 'The distant future. The year 2000.', '', content.paragraphs)}
103
99
  extensions={[defaultExtensions, InputModeExtensions.vim]}
104
100
  />
105
101
  ),
@@ -112,13 +108,13 @@ export const Vim: Story = {
112
108
  export const Listener: Story = {
113
109
  render: () => (
114
110
  <EditorStory
115
- text={str('# Listener', '', content.footer)}
111
+ text={join('# Listener', '', content.footer)}
116
112
  extensions={[
117
113
  listener({
118
- onFocus: (focusing) => {
114
+ onFocus: ({ focusing }) => {
119
115
  log.info('listener', { focusing });
120
116
  },
121
- onChange: (text) => {
117
+ onChange: ({ text }) => {
122
118
  log.info('listener', { text });
123
119
  },
124
120
  }),
@@ -142,7 +138,7 @@ export const Folding: Story = {
142
138
  export const Scrolling: Story = {
143
139
  render: () => (
144
140
  <EditorStory
145
- text={str('# Large Document', '', longText)}
141
+ text={join('# Large Document', '', longText)}
146
142
  extensions={selectionState({
147
143
  setState: (id, state) => global.set(id, state),
148
144
  getState: (id) => global.get(id),
@@ -153,7 +149,7 @@ export const Scrolling: Story = {
153
149
 
154
150
  export const ScrollingWithImages: Story = {
155
151
  render: () => (
156
- <EditorStory text={str('# Large Document', '', largeWithImages)} extensions={[decorateMarkdown(), image()]} />
152
+ <EditorStory text={join('# Large Document', '', largeWithImages)} extensions={[decorateMarkdown(), image()]} />
157
153
  ),
158
154
  };
159
155
 
@@ -161,7 +157,7 @@ export const ScrollTo: Story = {
161
157
  render: () => {
162
158
  // NOTE: Selection won't appear if text is reformatted.
163
159
  const word = 'Scroll to here...';
164
- const text = str('# Scroll To', longText, '', word, '', longText);
160
+ const text = join('# Scroll To', longText, '', word, '', longText);
165
161
  const idx = text.indexOf(word);
166
162
  return (
167
163
  <EditorStory
@@ -180,33 +176,7 @@ export const ScrollTo: Story = {
180
176
 
181
177
  export const Typescript: Story = {
182
178
  render: () => (
183
- <EditorStory
184
- text={content.typescript}
185
- lineNumbers
186
- extensions={[editorMonospace, javascript({ typescript: true })]}
187
- />
188
- ),
189
- };
190
-
191
- //
192
- // Autocomplete
193
- //
194
-
195
- export const Autocomplete: Story = {
196
- render: () => (
197
- <EditorStory
198
- text={str('# Autocomplete', '', 'Press Ctrl-Space...', content.footer)}
199
- extensions={[
200
- decorateMarkdown({ renderLinkButton }),
201
- autocomplete({
202
- onSuggest: (text) => {
203
- return links
204
- .filter(({ label }) => label.toLowerCase().includes(text.toLowerCase()))
205
- .map(({ label }) => label);
206
- },
207
- }),
208
- ]}
209
- />
179
+ <EditorStory text={content.typescript} lineNumbers monospace extensions={javascript({ typescript: true })} />
210
180
  ),
211
181
  };
212
182
 
@@ -214,14 +184,13 @@ export const Autocomplete: Story = {
214
184
  // Typeahead
215
185
  //
216
186
 
217
- const completions = ['type', 'AND', 'OR', 'NOT', 'dxos.org'];
187
+ const completions = ['hello world!', 'dxos.org'];
218
188
 
219
189
  export const Typeahead: Story = {
220
190
  render: () => (
221
191
  <EditorStory
222
- text={str('# Typeahead', '')}
192
+ text={join('# Typeahead', '')}
223
193
  extensions={[
224
- decorateMarkdown({ renderLinkButton }),
225
194
  typeahead({
226
195
  onComplete: staticCompletion(completions, { minLength: 2 }),
227
196
  }),
@@ -237,7 +206,7 @@ export const Typeahead: Story = {
237
206
  export const Mention: Story = {
238
207
  render: () => (
239
208
  <EditorStory
240
- text={str('# Mention', '', 'Type @...', content.footer)}
209
+ text={join('# Mention', '', 'Type @...', content.footer)}
241
210
  extensions={[
242
211
  mention({
243
212
  onSearch: (text) => names.filter((name) => name.toLowerCase().startsWith(text.toLowerCase())),
@@ -254,7 +223,7 @@ export const Mention: Story = {
254
223
  export const Search: Story = {
255
224
  render: () => (
256
225
  <EditorStory
257
- text={str('# Search', text)}
226
+ text={join('# Search', text)}
258
227
  extensions={defaultExtensions}
259
228
  onReady={(view) => openSearchPanel(view)}
260
229
  />
@@ -0,0 +1,61 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React, { useMemo } from 'react';
7
+
8
+ import { useThemeContext } from '@dxos/react-ui';
9
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
10
+ import { createBasicExtensions, createThemeExtensions } from '@dxos/ui-editor';
11
+
12
+ import { Editor } from '../components';
13
+
14
+ const createText = (monospace?: boolean) =>
15
+ [`${monospace ? 'monospace' : 'body'}`, 'Hello world', '0123456789'].join('\n');
16
+
17
+ const DefaultStory = () => {
18
+ const { themeMode } = useThemeContext();
19
+ const [ext1, ext2] = useMemo(
20
+ () => [
21
+ //
22
+ [
23
+ createBasicExtensions({ placeholder: 'Enter text', search: true }),
24
+ createThemeExtensions({ themeMode, monospace: false }),
25
+ ],
26
+ [
27
+ createBasicExtensions({ placeholder: 'Enter text', search: true }),
28
+ createThemeExtensions({ themeMode, monospace: true }),
29
+ ],
30
+ ],
31
+ [],
32
+ );
33
+
34
+ return (
35
+ <div className='is-full grid grid-cols-2 gap-2'>
36
+ <Editor.Root>
37
+ <Editor.Content classNames='p-2' extensions={ext1} initialValue={createText(false)} />
38
+ </Editor.Root>
39
+ <Editor.Root>
40
+ <Editor.Content classNames='p-2' extensions={ext2} initialValue={createText(true)} />
41
+ </Editor.Root>
42
+ </div>
43
+ );
44
+ };
45
+
46
+ const meta: Meta<typeof DefaultStory> = {
47
+ title: 'ui/react-ui-editor/Theme',
48
+ component: DefaultStory,
49
+ decorators: [withTheme, withLayout()],
50
+ parameters: {
51
+ layout: 'fullscreen',
52
+ },
53
+ };
54
+
55
+ export default meta;
56
+
57
+ type Story = StoryObj<typeof meta>;
58
+
59
+ export const Default: Story = {
60
+ args: {},
61
+ };