@dxos/react-ui-editor 0.8.3 → 0.8.4-main.1068cf700f

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 (404) hide show
  1. package/dist/lib/browser/index.mjs +1304 -7438
  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 +1304 -7438
  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 +47 -0
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -0
  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/Editor/index.d.ts +2 -0
  12. package/dist/types/src/components/Editor/index.d.ts.map +1 -0
  13. package/dist/types/src/components/EditorContent/EditorContent.d.ts +31 -0
  14. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
  15. package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
  16. package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorContent/index.d.ts +3 -0
  18. package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +36 -0
  20. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
  22. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  23. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  24. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  26. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +46 -0
  28. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  30. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  32. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  33. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  34. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  35. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +28 -2
  36. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  37. package/dist/types/src/components/EditorToolbar/actions.d.ts +24 -0
  38. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  39. package/dist/types/src/components/EditorToolbar/blocks.d.ts +8 -7
  40. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/formatting.d.ts +8 -7
  42. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/headings.d.ts +8 -7
  44. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/image.d.ts +4 -11
  46. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
  48. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  49. package/dist/types/src/components/EditorToolbar/search.d.ts +4 -11
  50. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  51. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
  52. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
  53. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +9 -8
  54. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  55. package/dist/types/src/components/index.d.ts +5 -2
  56. package/dist/types/src/components/index.d.ts.map +1 -1
  57. package/dist/types/src/hooks/useTextEditor.d.ts +6 -10
  58. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  59. package/dist/types/src/index.d.ts +1 -9
  60. package/dist/types/src/index.d.ts.map +1 -1
  61. package/dist/types/src/stories/Automerge.stories.d.ts +43 -0
  62. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  63. package/dist/types/src/stories/CommandDialog.stories.d.ts +14 -0
  64. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  65. package/dist/types/src/stories/Comments.stories.d.ts +22 -10
  66. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  67. package/dist/types/src/stories/EditorToolbar.stories.d.ts +40 -4
  68. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  69. package/dist/types/src/stories/Experimental.stories.d.ts +23 -13
  70. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/Markdown.stories.d.ts +33 -43
  72. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  73. package/dist/types/src/stories/Outliner.stories.d.ts +15 -21
  74. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  75. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  76. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  77. package/dist/types/src/stories/Preview.stories.d.ts +23 -7
  78. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  80. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  81. package/dist/types/src/stories/TextEditor.stories.d.ts +38 -52
  82. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  83. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  84. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  85. package/dist/types/src/stories/components/EditorStory.d.ts +11 -23
  86. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  87. package/dist/types/src/stories/components/util.d.ts +3 -3
  88. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  89. package/dist/types/src/translations.d.ts +29 -30
  90. package/dist/types/src/translations.d.ts.map +1 -1
  91. package/dist/types/src/util/index.d.ts +0 -4
  92. package/dist/types/src/util/index.d.ts.map +1 -1
  93. package/dist/types/src/util/react.d.ts +6 -2
  94. package/dist/types/src/util/react.d.ts.map +1 -1
  95. package/dist/types/tsconfig.tsbuildinfo +1 -1
  96. package/package.json +82 -75
  97. package/src/components/Editor/Editor.stories.tsx +95 -0
  98. package/src/components/Editor/Editor.tsx +185 -0
  99. package/src/components/Editor/index.ts +5 -0
  100. package/src/components/EditorContent/EditorContent.tsx +83 -0
  101. package/src/components/EditorContent/controller.ts +50 -0
  102. package/src/components/EditorContent/index.ts +6 -0
  103. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +227 -0
  104. package/src/components/EditorMenuProvider/index.ts +10 -0
  105. package/src/components/EditorMenuProvider/menu-presets.ts +124 -0
  106. package/src/components/EditorMenuProvider/menu.ts +70 -0
  107. package/src/components/EditorMenuProvider/popover.ts +285 -0
  108. package/src/components/EditorMenuProvider/useEditorMenu.ts +173 -0
  109. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +79 -0
  110. package/src/components/EditorPreviewProvider/index.ts +5 -0
  111. package/src/components/EditorToolbar/EditorToolbar.tsx +119 -96
  112. package/src/components/EditorToolbar/actions.ts +87 -0
  113. package/src/components/EditorToolbar/blocks.ts +23 -26
  114. package/src/components/EditorToolbar/formatting.ts +24 -27
  115. package/src/components/EditorToolbar/headings.ts +20 -12
  116. package/src/components/EditorToolbar/image.ts +17 -6
  117. package/src/components/EditorToolbar/index.ts +3 -7
  118. package/src/components/EditorToolbar/search.ts +17 -6
  119. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  120. package/src/components/EditorToolbar/view-mode.ts +15 -9
  121. package/src/components/index.ts +7 -2
  122. package/src/hooks/useTextEditor.ts +39 -45
  123. package/src/index.ts +1 -11
  124. package/src/stories/Automerge.stories.tsx +175 -0
  125. package/src/stories/CommandDialog.stories.tsx +81 -0
  126. package/src/stories/Comments.stories.tsx +59 -51
  127. package/src/stories/EditorToolbar.stories.tsx +45 -30
  128. package/src/stories/Experimental.stories.tsx +18 -16
  129. package/src/stories/Markdown.stories.tsx +37 -33
  130. package/src/stories/Outliner.stories.tsx +53 -42
  131. package/src/stories/Popover.stories.tsx +158 -0
  132. package/src/stories/Preview.stories.tsx +105 -94
  133. package/src/stories/Tags.stories.tsx +104 -0
  134. package/src/stories/TextEditor.stories.tsx +51 -76
  135. package/src/stories/Theme.stories.tsx +61 -0
  136. package/src/stories/components/EditorStory.tsx +41 -33
  137. package/src/stories/components/util.tsx +43 -11
  138. package/src/translations.ts +9 -7
  139. package/src/util/index.ts +1 -5
  140. package/src/util/react.tsx +7 -3
  141. package/dist/lib/browser/testing/index.mjs +0 -6
  142. package/dist/lib/browser/testing/index.mjs.map +0 -7
  143. package/dist/lib/node/index.cjs +0 -7754
  144. package/dist/lib/node/index.cjs.map +0 -7
  145. package/dist/lib/node/meta.json +0 -1
  146. package/dist/lib/node/testing/index.cjs +0 -29
  147. package/dist/lib/node/testing/index.cjs.map +0 -7
  148. package/dist/lib/node-esm/testing/index.mjs +0 -8
  149. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  150. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  151. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  152. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -50
  153. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  154. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  155. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  156. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  157. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  158. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  159. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  160. package/dist/types/src/components/Popover/index.d.ts +0 -4
  161. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  162. package/dist/types/src/defaults.d.ts +0 -14
  163. package/dist/types/src/defaults.d.ts.map +0 -1
  164. package/dist/types/src/extensions/annotations.d.ts +0 -9
  165. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  166. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  167. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  168. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  169. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  170. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +0 -56
  171. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  172. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  173. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  174. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  175. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  176. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  177. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  178. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  179. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  180. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  181. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  182. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  183. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  184. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  185. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  186. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  187. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  188. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  189. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  190. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  191. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  192. package/dist/types/src/extensions/blast.d.ts +0 -25
  193. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  194. package/dist/types/src/extensions/command/action.d.ts +0 -17
  195. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  196. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  197. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  198. package/dist/types/src/extensions/command/command.d.ts +0 -6
  199. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  200. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  201. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  202. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  203. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  204. package/dist/types/src/extensions/command/index.d.ts +0 -7
  205. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  206. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  207. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  208. package/dist/types/src/extensions/command/state.d.ts +0 -16
  209. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  210. package/dist/types/src/extensions/command/typeahead.d.ts +0 -17
  211. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  212. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  213. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  214. package/dist/types/src/extensions/comments.d.ts +0 -95
  215. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  216. package/dist/types/src/extensions/debug.d.ts +0 -3
  217. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  218. package/dist/types/src/extensions/dnd.d.ts +0 -9
  219. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  220. package/dist/types/src/extensions/factories.d.ts +0 -64
  221. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  222. package/dist/types/src/extensions/focus.d.ts +0 -7
  223. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  224. package/dist/types/src/extensions/folding.d.ts +0 -7
  225. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  226. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  227. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  228. package/dist/types/src/extensions/index.d.ts +0 -23
  229. package/dist/types/src/extensions/index.d.ts.map +0 -1
  230. package/dist/types/src/extensions/json.d.ts +0 -7
  231. package/dist/types/src/extensions/json.d.ts.map +0 -1
  232. package/dist/types/src/extensions/listener.d.ts +0 -11
  233. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  234. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  235. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  236. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -16
  237. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  238. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  239. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  240. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  241. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  242. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  243. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  244. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -17
  245. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  246. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  247. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  248. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  249. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  250. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  251. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  252. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  253. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  254. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  255. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  256. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  257. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  258. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  259. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  260. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  261. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  262. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  263. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  264. package/dist/types/src/extensions/mention.d.ts +0 -7
  265. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  266. package/dist/types/src/extensions/modes.d.ts +0 -17
  267. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  268. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  269. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  270. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  271. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  272. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  273. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  274. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  275. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  276. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  277. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  278. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  279. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  280. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  281. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  282. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  283. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  284. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  285. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  286. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  287. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  288. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  289. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  290. package/dist/types/src/extensions/selection.d.ts +0 -24
  291. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  292. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  293. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  294. package/dist/types/src/stories/Command.stories.d.ts +0 -7
  295. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  296. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  297. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  298. package/dist/types/src/styles/index.d.ts +0 -4
  299. package/dist/types/src/styles/index.d.ts.map +0 -1
  300. package/dist/types/src/styles/markdown.d.ts +0 -8
  301. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  302. package/dist/types/src/styles/theme.d.ts +0 -38
  303. package/dist/types/src/styles/theme.d.ts.map +0 -1
  304. package/dist/types/src/styles/tokens.d.ts +0 -3
  305. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  306. package/dist/types/src/testing/index.d.ts +0 -2
  307. package/dist/types/src/testing/index.d.ts.map +0 -1
  308. package/dist/types/src/testing/util.d.ts +0 -2
  309. package/dist/types/src/testing/util.d.ts.map +0 -1
  310. package/dist/types/src/types.d.ts +0 -14
  311. package/dist/types/src/types.d.ts.map +0 -1
  312. package/dist/types/src/util/cursor.d.ts +0 -31
  313. package/dist/types/src/util/cursor.d.ts.map +0 -1
  314. package/dist/types/src/util/debug.d.ts +0 -17
  315. package/dist/types/src/util/debug.d.ts.map +0 -1
  316. package/dist/types/src/util/dom.d.ts +0 -20
  317. package/dist/types/src/util/dom.d.ts.map +0 -1
  318. package/dist/types/src/util/facet.d.ts +0 -3
  319. package/dist/types/src/util/facet.d.ts.map +0 -1
  320. package/src/components/EditorToolbar/lists.ts +0 -59
  321. package/src/components/EditorToolbar/util.ts +0 -64
  322. package/src/components/Popover/CommandMenu.tsx +0 -279
  323. package/src/components/Popover/RefDropdownMenu.tsx +0 -79
  324. package/src/components/Popover/RefPopover.tsx +0 -99
  325. package/src/components/Popover/index.ts +0 -7
  326. package/src/defaults.ts +0 -49
  327. package/src/extensions/annotations.ts +0 -55
  328. package/src/extensions/autocomplete.ts +0 -69
  329. package/src/extensions/automerge/automerge.stories.tsx +0 -140
  330. package/src/extensions/automerge/automerge.test.tsx +0 -78
  331. package/src/extensions/automerge/automerge.ts +0 -85
  332. package/src/extensions/automerge/cursor.ts +0 -28
  333. package/src/extensions/automerge/defs.ts +0 -31
  334. package/src/extensions/automerge/index.ts +0 -5
  335. package/src/extensions/automerge/sync.ts +0 -75
  336. package/src/extensions/automerge/update-automerge.ts +0 -50
  337. package/src/extensions/automerge/update-codemirror.ts +0 -115
  338. package/src/extensions/awareness/awareness-provider.ts +0 -127
  339. package/src/extensions/awareness/awareness.ts +0 -315
  340. package/src/extensions/awareness/index.ts +0 -6
  341. package/src/extensions/blast.ts +0 -376
  342. package/src/extensions/command/action.ts +0 -56
  343. package/src/extensions/command/command-menu.ts +0 -210
  344. package/src/extensions/command/command.ts +0 -34
  345. package/src/extensions/command/floating-menu.ts +0 -133
  346. package/src/extensions/command/hint.ts +0 -102
  347. package/src/extensions/command/index.ts +0 -10
  348. package/src/extensions/command/placeholder.ts +0 -113
  349. package/src/extensions/command/state.ts +0 -89
  350. package/src/extensions/command/typeahead.ts +0 -116
  351. package/src/extensions/command/useCommandMenu.ts +0 -118
  352. package/src/extensions/comments.ts +0 -592
  353. package/src/extensions/debug.ts +0 -15
  354. package/src/extensions/dnd.ts +0 -37
  355. package/src/extensions/factories.ts +0 -240
  356. package/src/extensions/focus.ts +0 -35
  357. package/src/extensions/folding.tsx +0 -46
  358. package/src/extensions/hashtag.tsx +0 -68
  359. package/src/extensions/index.ts +0 -26
  360. package/src/extensions/json.ts +0 -57
  361. package/src/extensions/listener.ts +0 -38
  362. package/src/extensions/markdown/action.ts +0 -116
  363. package/src/extensions/markdown/bundle.ts +0 -71
  364. package/src/extensions/markdown/changes.test.ts +0 -26
  365. package/src/extensions/markdown/changes.ts +0 -149
  366. package/src/extensions/markdown/debug.ts +0 -44
  367. package/src/extensions/markdown/decorate.ts +0 -591
  368. package/src/extensions/markdown/formatting.test.ts +0 -498
  369. package/src/extensions/markdown/formatting.ts +0 -1265
  370. package/src/extensions/markdown/highlight.ts +0 -183
  371. package/src/extensions/markdown/image.ts +0 -119
  372. package/src/extensions/markdown/index.ts +0 -13
  373. package/src/extensions/markdown/link.ts +0 -47
  374. package/src/extensions/markdown/parser.test.ts +0 -75
  375. package/src/extensions/markdown/styles.ts +0 -135
  376. package/src/extensions/markdown/table.ts +0 -144
  377. package/src/extensions/mention.ts +0 -41
  378. package/src/extensions/modes.ts +0 -50
  379. package/src/extensions/outliner/commands.ts +0 -270
  380. package/src/extensions/outliner/editor.test.ts +0 -33
  381. package/src/extensions/outliner/editor.ts +0 -184
  382. package/src/extensions/outliner/index.ts +0 -7
  383. package/src/extensions/outliner/outliner.test.ts +0 -99
  384. package/src/extensions/outliner/outliner.ts +0 -166
  385. package/src/extensions/outliner/selection.ts +0 -50
  386. package/src/extensions/outliner/tree.test.ts +0 -167
  387. package/src/extensions/outliner/tree.ts +0 -317
  388. package/src/extensions/preview/index.ts +0 -5
  389. package/src/extensions/preview/preview.ts +0 -193
  390. package/src/extensions/selection.ts +0 -100
  391. package/src/extensions/typewriter.ts +0 -68
  392. package/src/stories/Command.stories.tsx +0 -97
  393. package/src/stories/CommandMenu.stories.tsx +0 -159
  394. package/src/styles/index.ts +0 -7
  395. package/src/styles/markdown.ts +0 -26
  396. package/src/styles/theme.ts +0 -266
  397. package/src/styles/tokens.ts +0 -17
  398. package/src/testing/index.ts +0 -5
  399. package/src/testing/util.ts +0 -5
  400. package/src/types.ts +0 -23
  401. package/src/util/cursor.ts +0 -55
  402. package/src/util/debug.ts +0 -64
  403. package/src/util/dom.ts +0 -56
  404. package/src/util/facet.ts +0 -13
@@ -2,13 +2,15 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { type NodeArg } from '@dxos/app-graph';
5
+ import { type Node } from '@dxos/app-graph';
6
6
  import { type ToolbarMenuActionGroupProperties } from '@dxos/react-ui-menu';
7
+ import { type EditorViewMode } from '@dxos/ui-editor';
7
8
 
8
- import { createEditorAction, createEditorActionGroup, type EditorToolbarState } from './util';
9
- import { type EditorViewMode } from '../../extensions';
10
9
  import { translationKey } from '../../translations';
11
10
 
11
+ import { createEditorAction, createEditorActionGroup } from './actions';
12
+ import { type EditorToolbarState } from './useEditorToolbar';
13
+
12
14
  const createViewModeGroupAction = (value: string) =>
13
15
  createEditorActionGroup(
14
16
  'viewMode',
@@ -28,11 +30,15 @@ const createViewModeActions = (value: string, onViewModeChange: (mode: EditorVie
28
30
  readonly: 'ph--pencil-slash--regular',
29
31
  }).map(([viewMode, icon]) => {
30
32
  const checked = viewMode === value;
31
- return createEditorAction(`view-mode--${viewMode}`, () => onViewModeChange(viewMode as EditorViewMode), {
32
- label: [`${viewMode} mode label`, { ns: translationKey }],
33
- checked,
34
- icon,
35
- });
33
+ return createEditorAction(
34
+ `view-mode--${viewMode}`,
35
+ {
36
+ label: [`${viewMode} mode label`, { ns: translationKey }],
37
+ checked,
38
+ icon,
39
+ },
40
+ () => onViewModeChange(viewMode as EditorViewMode),
41
+ );
36
42
  });
37
43
 
38
44
  export const createViewMode = (state: EditorToolbarState, onViewModeChange: (mode: EditorViewMode) => void) => {
@@ -40,7 +46,7 @@ export const createViewMode = (state: EditorToolbarState, onViewModeChange: (mod
40
46
  const viewModeGroupAction = createViewModeGroupAction(value);
41
47
  const viewModeActions = createViewModeActions(value, onViewModeChange);
42
48
  return {
43
- nodes: [viewModeGroupAction as NodeArg<any>, ...viewModeActions],
49
+ nodes: [viewModeGroupAction as Node.NodeArg<any>, ...viewModeActions],
44
50
  edges: [
45
51
  { source: 'root', target: 'viewMode' },
46
52
  ...viewModeActions.map(({ id }) => ({ source: viewModeGroupAction.id, target: id })),
@@ -2,5 +2,10 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- export * from './EditorToolbar';
6
- export * from './Popover';
5
+ export * from './Editor';
6
+
7
+ // TODO(burdon): Remove once Editor is fully migrated.
8
+ export { EditorContent, createEditorController } from './EditorContent';
9
+ export * from './EditorMenuProvider';
10
+ export * from './EditorPreviewProvider';
11
+ export { EditorToolbar, type EditorToolbarProps, type EditorToolbarState, useEditorToolbar } from './EditorToolbar';
@@ -4,8 +4,8 @@
4
4
 
5
5
  import { EditorState, type EditorStateConfig, type Text } from '@codemirror/state';
6
6
  import { EditorView } from '@codemirror/view';
7
- import { useFocusableGroup, type TabsterTypes } from '@fluentui/react-tabster';
8
7
  import {
8
+ type ComponentPropsWithoutRef,
9
9
  type DependencyList,
10
10
  type KeyboardEventHandler,
11
11
  type RefObject,
@@ -17,10 +17,14 @@ import {
17
17
  } from 'react';
18
18
 
19
19
  import { log } from '@dxos/log';
20
- import { getProviderValue, isNotFalsy, type MaybeProvider } from '@dxos/util';
21
-
22
- import { type EditorSelection, documentId, createEditorStateTransaction, editorInputMode } from '../extensions';
23
- import { debugDispatcher } from '../util';
20
+ import {
21
+ type EditorSelection,
22
+ createEditorStateTransaction,
23
+ debugDispatcher,
24
+ documentId,
25
+ modalStateField,
26
+ } from '@dxos/ui-editor';
27
+ import { type MaybeProvider, getProviderValue, isTruthy } from '@dxos/util';
24
28
 
25
29
  let instanceCount = 0;
26
30
 
@@ -34,13 +38,9 @@ export type CursorInfo = {
34
38
  };
35
39
 
36
40
  export type UseTextEditor = {
37
- // TODO(burdon): Rename.
38
- parentRef: RefObject<HTMLDivElement>;
39
- view?: EditorView;
40
- focusAttributes?: TabsterTypes.TabsterDOMAttribute & {
41
- tabIndex: 0;
42
- onKeyUp: KeyboardEventHandler<HTMLDivElement>;
43
- };
41
+ parentRef: RefObject<HTMLDivElement | null>;
42
+ view: EditorView | null;
43
+ focusAttributes?: ComponentPropsWithoutRef<'div'>;
44
44
  };
45
45
 
46
46
  export type UseTextEditorProps = Pick<EditorStateConfig, 'extensions'> & {
@@ -50,7 +50,7 @@ export type UseTextEditorProps = Pick<EditorStateConfig, 'extensions'> & {
50
50
  autoFocus?: boolean;
51
51
  scrollTo?: number;
52
52
  selection?: EditorSelection;
53
- moveToEndOfLine?: boolean;
53
+ selectionEnd?: boolean;
54
54
  debug?: boolean;
55
55
  };
56
56
 
@@ -61,16 +61,16 @@ export const useTextEditor = (
61
61
  props: MaybeProvider<UseTextEditorProps> = {},
62
62
  deps: DependencyList = [],
63
63
  ): UseTextEditor => {
64
- const { id, doc, initialValue, extensions, autoFocus, scrollTo, selection, moveToEndOfLine, debug } =
64
+ const { id, doc, initialValue, extensions, autoFocus, scrollTo, selection, selectionEnd, debug } =
65
65
  useMemo<UseTextEditorProps>(() => getProviderValue(props), deps ?? []);
66
66
 
67
67
  // NOTE: Increments by 2 in strict mode.
68
68
  const [instanceId] = useState(() => `text-editor-${++instanceCount}`);
69
- const [view, setView] = useState<EditorView>();
69
+ const [view, setView] = useState<EditorView | null>(null);
70
70
  const parentRef = useRef<HTMLDivElement>(null);
71
71
 
72
72
  useEffect(() => {
73
- let view: EditorView;
73
+ let view: EditorView | null = null;
74
74
  if (parentRef.current) {
75
75
  log('create', { id, instanceId, doc: initialValue?.length ?? 0 });
76
76
 
@@ -79,7 +79,7 @@ export const useTextEditor = (
79
79
  if (selection.anchor <= initialValue.length && (selection?.head ?? 0) <= initialValue.length) {
80
80
  initialSelection = selection;
81
81
  }
82
- } else if (moveToEndOfLine && selection === undefined) {
82
+ } else if (selectionEnd && selection === undefined) {
83
83
  const index = initialValue?.indexOf('\n');
84
84
  const anchor = !index || index === -1 ? 0 : index;
85
85
  initialSelection = { anchor };
@@ -96,19 +96,7 @@ export const useTextEditor = (
96
96
  EditorView.exceptionSink.of((err) => {
97
97
  log.catch(err);
98
98
  }),
99
- // TODO(burdon): Factor out debug inspector.
100
- // ViewPlugin.fromClass(
101
- // class {
102
- // constructor(_view: EditorView) {
103
- // log('construct', { id });
104
- // }
105
- //
106
- // destroy() {
107
- // log('destroy', { id });
108
- // }
109
- // },
110
- // ),
111
- ].filter(isNotFalsy),
99
+ ].filter(isTruthy),
112
100
  });
113
101
 
114
102
  // https://codemirror.net/docs/ref/#view.EditorViewConfig
@@ -120,7 +108,7 @@ export const useTextEditor = (
120
108
  });
121
109
 
122
110
  // Move to end of line after document loaded (unless selection is specified).
123
- if (moveToEndOfLine && !initialSelection) {
111
+ if (selectionEnd && !initialSelection) {
124
112
  const { to } = view.state.doc.lineAt(0);
125
113
  if (to) {
126
114
  view.dispatch({ selection: { anchor: to } });
@@ -155,23 +143,30 @@ export const useTextEditor = (
155
143
  }
156
144
  }, [autoFocus, view]);
157
145
 
158
- const focusableGroupAttrs = useFocusableGroup({
159
- tabBehavior: 'limited',
160
- ignoreDefaultKeydown: {
161
- Escape: view?.state.facet(editorInputMode).noTabster,
162
- },
163
- });
164
-
165
146
  // Focus editor on Enter (e.g., when tabbing to this component).
166
- const handleKeyUp = useCallback<KeyboardEventHandler<HTMLDivElement>>(
147
+ const handleKeyDown = useCallback<KeyboardEventHandler<HTMLDivElement>>(
167
148
  (event) => {
168
149
  const { key, target, currentTarget } = event;
169
- if (target === currentTarget) {
170
- switch (key) {
171
- case 'Enter': {
150
+ switch (key) {
151
+ case 'Escape': {
152
+ // Check if popover is open.
153
+ const modal = view?.state.field(modalStateField, false);
154
+ if (modal) {
155
+ return;
156
+ }
157
+
158
+ // Focus the closest focusable parent.
159
+ const element = view?.contentDOM.closest('[tabindex="0"]') as HTMLDivElement | null;
160
+ element?.focus();
161
+ break;
162
+ }
163
+
164
+ case 'Enter': {
165
+ event.preventDefault();
166
+ if (target === currentTarget) {
172
167
  view?.focus();
173
- break;
174
168
  }
169
+ break;
175
170
  }
176
171
  }
177
172
  },
@@ -183,8 +178,7 @@ export const useTextEditor = (
183
178
  view,
184
179
  focusAttributes: {
185
180
  tabIndex: 0 as const,
186
- ...focusableGroupAttrs,
187
- onKeyUp: handleKeyUp,
181
+ onKeyDown: handleKeyDown,
188
182
  },
189
183
  };
190
184
  };
package/src/index.ts CHANGED
@@ -2,19 +2,9 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- import translations from './translations';
6
-
7
- export { type Extension, EditorState } from '@codemirror/state';
8
- export { EditorView, keymap } from '@codemirror/view';
9
- export { tags } from '@lezer/highlight';
10
-
11
- export { TextKind } from '@dxos/protocols/proto/dxos/echo/model/text';
5
+ import { translations } from './translations';
12
6
 
13
7
  export * from './components';
14
- export * from './defaults';
15
- export * from './extensions';
16
8
  export * from './hooks';
17
- export * from './types';
18
- export * from './util';
19
9
 
20
10
  export { translations };
@@ -0,0 +1,175 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { Repo } from '@automerge/automerge-repo';
6
+ import { BroadcastChannelNetworkAdapter } from '@automerge/automerge-repo-network-broadcastchannel';
7
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
8
+ import React, { useCallback, useEffect, useState } from 'react';
9
+
10
+ import { Obj, Ref } from '@dxos/echo';
11
+ import { TestSchema } from '@dxos/echo/testing';
12
+ import { DocAccessor, createDocAccessor } from '@dxos/echo-db';
13
+ import { log } from '@dxos/log';
14
+ import { type Messenger } from '@dxos/protocols';
15
+ import { Query, useQuery, useSpace } from '@dxos/react-client/echo';
16
+ import { type Identity, useIdentity } from '@dxos/react-client/halo';
17
+ import { useClientStory, withMultiClientProvider } from '@dxos/react-client/testing';
18
+ import { Button, useThemeContext } from '@dxos/react-ui';
19
+ import { withTheme } from '@dxos/react-ui/testing';
20
+ import { render } from '@dxos/storybook-utils';
21
+ import { createBasicExtensions, createDataExtensions, createThemeExtensions } from '@dxos/ui-editor';
22
+
23
+ import { useTextEditor } from '../hooks';
24
+ import { translations } from '../translations';
25
+
26
+ const initialContent = 'Hello world!';
27
+
28
+ type TestObject = {
29
+ text: string;
30
+ };
31
+
32
+ type EditorProps = {
33
+ source: DocAccessor;
34
+ messenger?: Messenger;
35
+ identity?: Identity;
36
+ autoFocus?: boolean;
37
+ };
38
+
39
+ const Editor = ({ source, messenger, identity, autoFocus }: EditorProps) => {
40
+ const { themeMode } = useThemeContext();
41
+ const { parentRef } = useTextEditor(
42
+ () => ({
43
+ autoFocus,
44
+ initialValue: DocAccessor.getValue(source),
45
+ extensions: [
46
+ createBasicExtensions({ placeholder: 'Type here...', search: true }),
47
+ createThemeExtensions({ themeMode, slots: { scroll: { className: 'p-2' } } }),
48
+ createDataExtensions({ id: 'test', text: source, messenger, identity }),
49
+ ],
50
+ }),
51
+ [source, themeMode],
52
+ );
53
+
54
+ return <div ref={parentRef} className='flex is-full' />;
55
+ };
56
+
57
+ const DefaultStory = () => {
58
+ const [object1, setObject1] = useState<DocAccessor<TestObject>>();
59
+ const [object2, setObject2] = useState<DocAccessor<TestObject>>();
60
+
61
+ useEffect(() => {
62
+ queueMicrotask(async () => {
63
+ const repo1 = new Repo({ network: [new BroadcastChannelNetworkAdapter()] });
64
+ const repo2 = new Repo({ network: [new BroadcastChannelNetworkAdapter()] });
65
+
66
+ const object1 = repo1.create<TestObject>();
67
+ object1.change((doc: TestObject) => {
68
+ doc.text = initialContent;
69
+ });
70
+
71
+ const object2 = await repo2.find<TestObject>(object1.url);
72
+ await object2.whenReady();
73
+
74
+ setObject1({ handle: object1, path: ['text'] });
75
+ setObject2({ handle: object2, path: ['text'] });
76
+ });
77
+ }, []);
78
+
79
+ if (!object1 || !object2) {
80
+ return null;
81
+ }
82
+
83
+ return (
84
+ <div className='bs-full is-full grid grid-cols-2 gap-4'>
85
+ <Editor source={object1} autoFocus />
86
+ <Editor source={object2} />
87
+ </div>
88
+ );
89
+ };
90
+
91
+ const EchoStory = () => {
92
+ const { spaceId, index } = useClientStory();
93
+ const identity = useIdentity();
94
+ const space = useSpace(spaceId);
95
+ const objects = useQuery(space?.db, Query.type(TestSchema.Expando, { type: 'test' }));
96
+
97
+ const [source, setSource] = useState<DocAccessor>();
98
+ const init = useCallback(() => {
99
+ const content = objects[0]?.content.target;
100
+ if (!content) {
101
+ if (objects.length) {
102
+ // TODO(burdon): Initially ref isn't ready.
103
+ log.warn('no content', { index, objects: JSON.stringify(objects) });
104
+ }
105
+ return;
106
+ }
107
+
108
+ setSource(createDocAccessor(content, ['content']));
109
+ }, [objects]);
110
+
111
+ useEffect(() => {
112
+ if (source) {
113
+ return;
114
+ }
115
+
116
+ init();
117
+ }, [objects, source]);
118
+
119
+ return (
120
+ <div className='bs-full is-full flex flex-col overflow-hidden'>
121
+ <pre className='p-2 text-xs text-subdued'>
122
+ {JSON.stringify({ index, identity: identity?.identityKey.truncate(), spaceId, objects }, null, 2)}
123
+ </pre>
124
+ {identity && source ? (
125
+ <div className='p-2 flex grow overflow-hidden'>
126
+ <Editor identity={identity} messenger={space} source={source} />
127
+ </div>
128
+ ) : (
129
+ <div className='p-2'>
130
+ <Button onClick={init}>Init</Button>
131
+ </div>
132
+ )}
133
+ </div>
134
+ );
135
+ };
136
+
137
+ const meta = {
138
+ title: 'ui/react-ui-editor/Automerge',
139
+ component: Editor as any,
140
+ parameters: {
141
+ layout: 'fullscreen',
142
+ translations,
143
+ },
144
+ } satisfies Meta<typeof DefaultStory>;
145
+
146
+ export default meta;
147
+
148
+ type Story = StoryObj<typeof meta>;
149
+
150
+ // TODO(burdon): ERROR: factories.ts:126 Error: Non-base58 character
151
+ export const Default: Story = {
152
+ decorators: [withTheme()],
153
+ render: render(DefaultStory),
154
+ };
155
+
156
+ // TODO(burdon): Failing (doesn't sync)
157
+ export const WithEcho: Story = {
158
+ decorators: [
159
+ withTheme(),
160
+ withMultiClientProvider({
161
+ numClients: 2,
162
+ createIdentity: true,
163
+ createSpace: true,
164
+ onCreateSpace: async ({ space }) => {
165
+ space.db.add(
166
+ Obj.make(TestSchema.Expando, {
167
+ type: 'test',
168
+ content: Ref.make(Obj.make(TestSchema.Expando, { content: initialContent })),
169
+ }),
170
+ );
171
+ },
172
+ }),
173
+ ],
174
+ render: render(EchoStory),
175
+ };
@@ -0,0 +1,81 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React, { type KeyboardEvent, useState } from 'react';
7
+
8
+ import { type Button, IconButton, Input } from '@dxos/react-ui';
9
+ import { withTheme } from '@dxos/react-ui/testing';
10
+ import { editorWidth, join } from '@dxos/ui-editor';
11
+ import { mx } from '@dxos/ui-theme';
12
+
13
+ import { EditorStory } from './components';
14
+
15
+ // TODO(burdon): Reimplement with Popover.
16
+ const CommandDialog = ({ onAction }: { onAction: (action?: any) => void }) => {
17
+ const [text, setText] = useState('');
18
+
19
+ const handleInsert = () => {
20
+ // TODO(burdon): Use queue ref.
21
+ const link = `![${text}](dxn:queue:data:123)`;
22
+ onAction(text.length ? { type: 'insert', text: link } : undefined);
23
+ };
24
+
25
+ const handleKeyDown = (event: KeyboardEvent<HTMLInputElement>) => {
26
+ switch (event.key) {
27
+ case 'Enter': {
28
+ handleInsert();
29
+ break;
30
+ }
31
+ case 'Escape': {
32
+ onAction();
33
+ break;
34
+ }
35
+ }
36
+ };
37
+
38
+ return (
39
+ <div className='flex is-full justify-center'>
40
+ <div
41
+ className={mx(
42
+ 'flex is-full p-2 gap-2 items-center bg-modalSurface border border-separator rounded-md',
43
+ editorWidth,
44
+ )}
45
+ >
46
+ <Input.Root>
47
+ <Input.TextInput
48
+ autoFocus={true}
49
+ placeholder='Ask a question...'
50
+ value={text}
51
+ onChange={(ev) => setText(ev.target.value)}
52
+ onKeyDown={handleKeyDown}
53
+ />
54
+ </Input.Root>
55
+ <IconButton
56
+ icon='ph--x--regular'
57
+ label='Cancel'
58
+ iconOnly
59
+ variant='ghost'
60
+ classNames='pli-0'
61
+ onClick={() => onAction({ type: 'cancel' })}
62
+ />
63
+ </div>
64
+ </div>
65
+ );
66
+ };
67
+
68
+ const meta = {
69
+ title: 'ui/react-ui-editor/CommandDialog',
70
+ render: () => <EditorStory text={join('# Command', '', '')} extensions={[]} />,
71
+ decorators: [withTheme()],
72
+ parameters: {
73
+ layout: 'fullscreen',
74
+ },
75
+ } satisfies Meta<typeof Button>;
76
+
77
+ export default meta;
78
+
79
+ type Story = StoryObj<typeof meta>;
80
+
81
+ export const Default: Story = {};
@@ -2,81 +2,89 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import '@dxos-theme';
6
-
7
- import { effect, useSignal } from '@preact/signals-react';
8
- import React, { type FC } from 'react';
5
+ import { Atom, RegistryContext } from '@effect-atom/atom-react';
6
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
7
+ import React, { type FC, useContext, useMemo } from 'react';
9
8
 
10
9
  import { keySymbols, parseShortcut } from '@dxos/keyboard';
11
10
  import { PublicKey } from '@dxos/keys';
12
11
  import { log } from '@dxos/log';
13
- import { withLayout, withTheme, type Meta } from '@dxos/storybook-utils';
12
+ import { withTheme } from '@dxos/react-ui/testing';
13
+ import { withRegistry } from '@dxos/storybook-utils';
14
+ import { type Comment, annotations, comments, createExternalCommentSync } from '@dxos/ui-editor';
15
+
16
+ import { createRenderer, str } from '../util';
14
17
 
15
18
  import { EditorStory, content, longText } from './components';
16
- import { annotations, comments, createExternalCommentSync } from '../extensions';
17
- import { str } from '../testing';
18
- import { type Comment } from '../types';
19
- import { createRenderer } from '../util';
20
19
 
21
- const meta: Meta<typeof EditorStory> = {
20
+ const meta = {
22
21
  title: 'ui/react-ui-editor/Comments',
23
22
  component: EditorStory,
24
- decorators: [withTheme, withLayout({ fullscreen: true })],
25
- parameters: { layout: 'fullscreen' },
26
- };
23
+ decorators: [withRegistry, withTheme()],
24
+ parameters: {
25
+ layout: 'fullscreen',
26
+ },
27
+ } satisfies Meta<typeof EditorStory>;
27
28
 
28
29
  export default meta;
29
30
 
31
+ type Story = StoryObj<typeof meta>;
32
+
30
33
  //
31
34
  // Comments
32
35
  //
33
36
 
34
- export const Comments = {
35
- render: () => {
36
- const _comments = useSignal<Comment[]>([]);
37
- return (
38
- <EditorStory
39
- text={str('# Comments', '', content.paragraphs, content.footer)}
40
- extensions={[
41
- createExternalCommentSync(
42
- 'test',
43
- (sink) => effect(() => sink()),
44
- () => _comments.value,
45
- ),
46
- comments({
47
- id: 'test',
48
- renderTooltip: createRenderer(CommentTooltip),
49
- onCreate: ({ cursor }) => {
50
- const id = PublicKey.random().toHex();
51
- _comments.value = [..._comments.value, { id, cursor }];
52
- return id;
53
- },
54
- onSelect: (state) => {
55
- const debug = false;
56
- if (debug) {
57
- log.info('update', {
58
- comments: state.comments.length,
59
- active: state.selection.current?.slice(0, 8),
60
- closest: state.selection.closest?.slice(0, 8),
61
- });
62
- }
63
- },
64
- }),
65
- ]}
66
- />
67
- );
68
- },
37
+ const CommentsStory = () => {
38
+ const registry = useContext(RegistryContext);
39
+ const commentsAtom = useMemo(() => Atom.make<Comment[]>([]), []);
40
+
41
+ return (
42
+ <EditorStory
43
+ text={str('# Comments', '', content.paragraphs, content.footer)}
44
+ extensions={[
45
+ createExternalCommentSync(
46
+ 'test',
47
+ (sink) => registry.subscribe(commentsAtom, () => sink()),
48
+ () => registry.get(commentsAtom),
49
+ ),
50
+ comments({
51
+ id: 'test',
52
+ renderTooltip: createRenderer(CommentTooltip),
53
+ onCreate: ({ cursor }) => {
54
+ const id = PublicKey.random().toHex();
55
+ const current = registry.get(commentsAtom);
56
+ registry.set(commentsAtom, [...current, { id, cursor }]);
57
+ return id;
58
+ },
59
+ onSelect: (state) => {
60
+ const debug = false;
61
+ if (debug) {
62
+ log.info('update', {
63
+ comments: state.comments.length,
64
+ active: state.selection.current?.slice(0, 8),
65
+ closest: state.selection.closest?.slice(0, 8),
66
+ });
67
+ }
68
+ },
69
+ }),
70
+ ]}
71
+ />
72
+ );
73
+ };
74
+
75
+ export const Comments: Story = {
76
+ render: () => <CommentsStory />,
69
77
  };
70
78
 
71
79
  const Key: FC<{ char: string }> = ({ char }) => (
72
- <span className='flex justify-center items-center w-[24px] h-[24px] rounded text-xs bg-neutral-200 text-black'>
80
+ <span className='flex justify-center items-center is-[24px] bs-[24px] rounded text-xs bg-neutral-200 text-black'>
73
81
  {char}
74
82
  </span>
75
83
  );
76
84
 
77
85
  const CommentTooltip: FC<{ shortcut: string }> = ({ shortcut }) => {
78
86
  return (
79
- <div className='flex items-center gap-2 px-2 py-2 bg-neutral-700 text-white text-xs rounded'>
87
+ <div className='flex items-center gap-2 pli-2 plb-2 bg-neutral-700 text-white text-xs rounded'>
80
88
  <div>Create comment</div>
81
89
  <div className='flex gap-1'>
82
90
  {keySymbols(parseShortcut(shortcut)).map((char) => (
@@ -91,7 +99,7 @@ const CommentTooltip: FC<{ shortcut: string }> = ({ shortcut }) => {
91
99
  // Annotations
92
100
  //
93
101
 
94
- export const Annotations = {
102
+ export const Annotations: Story = {
95
103
  render: () => (
96
104
  <EditorStory text={str('# Annotations', '', longText)} extensions={[annotations({ match: /volup/gi })]} />
97
105
  ),