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

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 +718 -8598
  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 +711 -8590
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/types/src/components/Editor/Editor.d.ts +8 -2
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +4 -1
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -1
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +4 -2
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -1
  13. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +2 -4
  14. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -1
  15. package/dist/types/src/components/EditorMenuProvider/index.d.ts +0 -1
  16. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -1
  17. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -1
  18. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -1
  19. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +1 -2
  20. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -1
  21. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -1
  22. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +1 -1
  23. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -1
  24. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +7 -5
  25. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  26. package/dist/types/src/components/EditorToolbar/blocks.d.ts +3 -16
  27. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  28. package/dist/types/src/components/EditorToolbar/formatting.d.ts +3 -16
  29. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  30. package/dist/types/src/components/EditorToolbar/headings.d.ts +3 -16
  31. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  32. package/dist/types/src/components/EditorToolbar/image.d.ts +3 -15
  33. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  34. package/dist/types/src/components/EditorToolbar/index.d.ts +0 -1
  35. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  36. package/dist/types/src/components/EditorToolbar/lists.d.ts +6 -0
  37. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -0
  38. package/dist/types/src/components/EditorToolbar/search.d.ts +3 -15
  39. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  40. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +4 -4
  41. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -1
  42. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +4 -17
  43. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  44. package/dist/types/src/components/index.d.ts.map +1 -1
  45. package/dist/types/src/hooks/useTextEditor.d.ts +1 -1
  46. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  47. package/dist/types/src/index.d.ts +0 -8
  48. package/dist/types/src/index.d.ts.map +1 -1
  49. package/dist/types/src/stories/Automerge.stories.d.ts +44 -0
  50. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  51. package/dist/types/src/stories/Comments.stories.d.ts +3 -2
  52. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  53. package/dist/types/src/stories/EditorToolbar.stories.d.ts +27 -27
  54. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  55. package/dist/types/src/stories/Experimental.stories.d.ts +3 -2
  56. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  57. package/dist/types/src/stories/Markdown.stories.d.ts +3 -2
  58. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  59. package/dist/types/src/stories/Outliner.stories.d.ts +2 -2
  60. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  61. package/dist/types/src/stories/Popover.stories.d.ts +2 -2
  62. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -1
  63. package/dist/types/src/stories/Preview.stories.d.ts +3 -2
  64. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  66. package/dist/types/src/stories/TextEditor.stories.d.ts +3 -2
  67. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  68. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  69. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  70. package/dist/types/src/stories/components/EditorStory.d.ts +9 -20
  71. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  72. package/dist/types/src/stories/components/util.d.ts +3 -3
  73. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  74. package/dist/types/src/translations.d.ts +26 -26
  75. package/dist/types/src/translations.d.ts.map +1 -1
  76. package/dist/types/src/util/index.d.ts +0 -5
  77. package/dist/types/src/util/index.d.ts.map +1 -1
  78. package/dist/types/src/util/react.d.ts +6 -5
  79. package/dist/types/src/util/react.d.ts.map +1 -1
  80. package/dist/types/tsconfig.tsbuildinfo +1 -1
  81. package/package.json +65 -66
  82. package/src/components/Editor/Editor.stories.tsx +17 -12
  83. package/src/components/Editor/Editor.tsx +21 -10
  84. package/src/components/EditorContent/EditorContent.tsx +19 -7
  85. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +23 -30
  86. package/src/components/EditorMenuProvider/index.ts +0 -1
  87. package/src/components/EditorMenuProvider/menu-presets.ts +3 -1
  88. package/src/components/EditorMenuProvider/menu.ts +1 -2
  89. package/src/components/EditorMenuProvider/popover.ts +1 -3
  90. package/src/components/EditorMenuProvider/useEditorMenu.ts +9 -4
  91. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +6 -9
  92. package/src/components/EditorToolbar/EditorToolbar.tsx +33 -66
  93. package/src/components/EditorToolbar/blocks.ts +54 -48
  94. package/src/components/EditorToolbar/formatting.ts +45 -48
  95. package/src/components/EditorToolbar/headings.ts +43 -50
  96. package/src/components/EditorToolbar/image.ts +16 -14
  97. package/src/components/EditorToolbar/index.ts +0 -1
  98. package/src/components/EditorToolbar/lists.ts +57 -0
  99. package/src/components/EditorToolbar/search.ts +16 -14
  100. package/src/components/EditorToolbar/useEditorToolbar.ts +6 -6
  101. package/src/components/EditorToolbar/view-mode.ts +35 -42
  102. package/src/components/index.ts +0 -2
  103. package/src/hooks/useTextEditor.ts +9 -3
  104. package/src/index.ts +0 -10
  105. package/src/stories/Automerge.stories.tsx +173 -0
  106. package/src/stories/Comments.stories.tsx +47 -43
  107. package/src/stories/EditorToolbar.stories.tsx +57 -27
  108. package/src/stories/Experimental.stories.tsx +10 -12
  109. package/src/stories/Markdown.stories.tsx +16 -16
  110. package/src/stories/Outliner.stories.tsx +8 -10
  111. package/src/stories/Popover.stories.tsx +27 -32
  112. package/src/stories/Preview.stories.tsx +67 -53
  113. package/src/stories/Tags.stories.tsx +24 -15
  114. package/src/stories/TextEditor.stories.tsx +13 -19
  115. package/src/stories/Theme.stories.tsx +61 -0
  116. package/src/stories/components/EditorStory.tsx +31 -30
  117. package/src/stories/components/util.tsx +51 -52
  118. package/src/translations.ts +30 -25
  119. package/src/util/index.ts +1 -6
  120. package/src/util/react.tsx +8 -13
  121. package/dist/lib/browser/chunk-HL3YF6WC.mjs +0 -22
  122. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +0 -7
  123. package/dist/lib/browser/types/index.mjs +0 -13
  124. package/dist/lib/browser/types/index.mjs.map +0 -7
  125. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs +0 -24
  126. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +0 -7
  127. package/dist/lib/node-esm/types/index.mjs +0 -14
  128. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  129. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts +0 -26
  130. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts.map +0 -1
  131. package/dist/types/src/components/EditorMenuProvider/util.d.ts +0 -8
  132. package/dist/types/src/components/EditorMenuProvider/util.d.ts.map +0 -1
  133. package/dist/types/src/components/EditorToolbar/actions.d.ts +0 -39
  134. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +0 -1
  135. package/dist/types/src/defaults.d.ts +0 -14
  136. package/dist/types/src/defaults.d.ts.map +0 -1
  137. package/dist/types/src/extensions/annotations.d.ts +0 -9
  138. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  139. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +0 -17
  140. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +0 -1
  141. package/dist/types/src/extensions/autocomplete/index.d.ts +0 -5
  142. package/dist/types/src/extensions/autocomplete/index.d.ts.map +0 -1
  143. package/dist/types/src/extensions/autocomplete/match.d.ts +0 -13
  144. package/dist/types/src/extensions/autocomplete/match.d.ts.map +0 -1
  145. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +0 -20
  146. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +0 -1
  147. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +0 -10
  148. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +0 -1
  149. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  150. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  151. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +0 -47
  152. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  153. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  154. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  155. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  156. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  157. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  158. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  159. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  160. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  161. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  162. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  163. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  164. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  165. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  166. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  167. package/dist/types/src/extensions/autoscroll.d.ts +0 -20
  168. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  169. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  170. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  171. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  172. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  173. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  174. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  175. package/dist/types/src/extensions/blast.d.ts +0 -25
  176. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  177. package/dist/types/src/extensions/blocks.d.ts +0 -2
  178. package/dist/types/src/extensions/blocks.d.ts.map +0 -1
  179. package/dist/types/src/extensions/bookmarks.d.ts +0 -12
  180. package/dist/types/src/extensions/bookmarks.d.ts.map +0 -1
  181. package/dist/types/src/extensions/comments.d.ts +0 -95
  182. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  183. package/dist/types/src/extensions/debug.d.ts +0 -3
  184. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  185. package/dist/types/src/extensions/dnd.d.ts +0 -9
  186. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  187. package/dist/types/src/extensions/factories.d.ts +0 -83
  188. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  189. package/dist/types/src/extensions/focus.d.ts +0 -7
  190. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  191. package/dist/types/src/extensions/folding.d.ts +0 -7
  192. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  193. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  194. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  195. package/dist/types/src/extensions/index.d.ts +0 -32
  196. package/dist/types/src/extensions/index.d.ts.map +0 -1
  197. package/dist/types/src/extensions/json.d.ts +0 -7
  198. package/dist/types/src/extensions/json.d.ts.map +0 -1
  199. package/dist/types/src/extensions/listener.d.ts +0 -13
  200. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  201. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  202. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  203. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  204. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  205. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  206. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  207. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  208. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  209. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  210. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  211. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  212. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  213. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -61
  214. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  215. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  216. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  217. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  218. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  219. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  220. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  221. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  222. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  223. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  224. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  225. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  226. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  227. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  228. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  229. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  230. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  231. package/dist/types/src/extensions/mention.d.ts +0 -7
  232. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  233. package/dist/types/src/extensions/modal.d.ts +0 -7
  234. package/dist/types/src/extensions/modal.d.ts.map +0 -1
  235. package/dist/types/src/extensions/modes.d.ts +0 -10
  236. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  237. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  238. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  239. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  240. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  241. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  242. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  243. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  244. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  245. package/dist/types/src/extensions/outliner/menu.d.ts +0 -8
  246. package/dist/types/src/extensions/outliner/menu.d.ts.map +0 -1
  247. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  248. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  249. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  250. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  251. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  252. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  253. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  254. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  255. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  256. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  257. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  258. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  259. package/dist/types/src/extensions/preview/preview.d.ts +0 -32
  260. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  261. package/dist/types/src/extensions/replacer.d.ts +0 -21
  262. package/dist/types/src/extensions/replacer.d.ts.map +0 -1
  263. package/dist/types/src/extensions/replacer.test.d.ts +0 -2
  264. package/dist/types/src/extensions/replacer.test.d.ts.map +0 -1
  265. package/dist/types/src/extensions/scrolling.d.ts +0 -78
  266. package/dist/types/src/extensions/scrolling.d.ts.map +0 -1
  267. package/dist/types/src/extensions/selection.d.ts +0 -24
  268. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  269. package/dist/types/src/extensions/state.d.ts +0 -2
  270. package/dist/types/src/extensions/state.d.ts.map +0 -1
  271. package/dist/types/src/extensions/submit.d.ts +0 -10
  272. package/dist/types/src/extensions/submit.d.ts.map +0 -1
  273. package/dist/types/src/extensions/tab.d.ts +0 -4
  274. package/dist/types/src/extensions/tab.d.ts.map +0 -1
  275. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  276. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  277. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  278. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  279. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  280. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  281. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  282. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  283. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -97
  284. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  285. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  286. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  287. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  288. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  289. package/dist/types/src/stories/CommandDialog.stories.d.ts +0 -14
  290. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +0 -1
  291. package/dist/types/src/styles/index.d.ts +0 -4
  292. package/dist/types/src/styles/index.d.ts.map +0 -1
  293. package/dist/types/src/styles/markdown.d.ts +0 -8
  294. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  295. package/dist/types/src/styles/theme.d.ts +0 -38
  296. package/dist/types/src/styles/theme.d.ts.map +0 -1
  297. package/dist/types/src/styles/tokens.d.ts +0 -3
  298. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  299. package/dist/types/src/types/index.d.ts +0 -2
  300. package/dist/types/src/types/index.d.ts.map +0 -1
  301. package/dist/types/src/types/types.d.ts +0 -21
  302. package/dist/types/src/types/types.d.ts.map +0 -1
  303. package/dist/types/src/util/cursor.d.ts +0 -31
  304. package/dist/types/src/util/cursor.d.ts.map +0 -1
  305. package/dist/types/src/util/debug.d.ts +0 -21
  306. package/dist/types/src/util/debug.d.ts.map +0 -1
  307. package/dist/types/src/util/decorations.d.ts +0 -4
  308. package/dist/types/src/util/decorations.d.ts.map +0 -1
  309. package/dist/types/src/util/dom.d.ts +0 -10
  310. package/dist/types/src/util/dom.d.ts.map +0 -1
  311. package/dist/types/src/util/facet.d.ts +0 -3
  312. package/dist/types/src/util/facet.d.ts.map +0 -1
  313. package/src/components/EditorContent/EditorContent.stories.tsx +0 -70
  314. package/src/components/EditorMenuProvider/util.ts +0 -31
  315. package/src/components/EditorToolbar/actions.ts +0 -86
  316. package/src/defaults.ts +0 -52
  317. package/src/extensions/annotations.ts +0 -55
  318. package/src/extensions/autocomplete/autocomplete.ts +0 -151
  319. package/src/extensions/autocomplete/index.ts +0 -8
  320. package/src/extensions/autocomplete/match.ts +0 -46
  321. package/src/extensions/autocomplete/placeholder.ts +0 -117
  322. package/src/extensions/autocomplete/typeahead.ts +0 -87
  323. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  324. package/src/extensions/automerge/automerge.test.tsx +0 -78
  325. package/src/extensions/automerge/automerge.ts +0 -105
  326. package/src/extensions/automerge/cursor.ts +0 -28
  327. package/src/extensions/automerge/defs.ts +0 -31
  328. package/src/extensions/automerge/index.ts +0 -5
  329. package/src/extensions/automerge/sync.ts +0 -79
  330. package/src/extensions/automerge/update-automerge.ts +0 -50
  331. package/src/extensions/automerge/update-codemirror.ts +0 -115
  332. package/src/extensions/autoscroll.ts +0 -163
  333. package/src/extensions/awareness/awareness-provider.ts +0 -127
  334. package/src/extensions/awareness/awareness.ts +0 -315
  335. package/src/extensions/awareness/index.ts +0 -6
  336. package/src/extensions/blast.ts +0 -363
  337. package/src/extensions/blocks.ts +0 -131
  338. package/src/extensions/bookmarks.ts +0 -75
  339. package/src/extensions/comments.ts +0 -598
  340. package/src/extensions/debug.ts +0 -15
  341. package/src/extensions/dnd.ts +0 -37
  342. package/src/extensions/factories.ts +0 -278
  343. package/src/extensions/focus.ts +0 -36
  344. package/src/extensions/folding.tsx +0 -43
  345. package/src/extensions/hashtag.tsx +0 -68
  346. package/src/extensions/index.ts +0 -35
  347. package/src/extensions/json.ts +0 -57
  348. package/src/extensions/listener.ts +0 -32
  349. package/src/extensions/markdown/action.ts +0 -117
  350. package/src/extensions/markdown/bundle.ts +0 -105
  351. package/src/extensions/markdown/changes.test.ts +0 -26
  352. package/src/extensions/markdown/changes.ts +0 -149
  353. package/src/extensions/markdown/debug.ts +0 -44
  354. package/src/extensions/markdown/decorate.ts +0 -601
  355. package/src/extensions/markdown/formatting.test.ts +0 -498
  356. package/src/extensions/markdown/formatting.ts +0 -1265
  357. package/src/extensions/markdown/highlight.ts +0 -183
  358. package/src/extensions/markdown/image.ts +0 -118
  359. package/src/extensions/markdown/index.ts +0 -13
  360. package/src/extensions/markdown/link.ts +0 -50
  361. package/src/extensions/markdown/parser.test.ts +0 -75
  362. package/src/extensions/markdown/styles.ts +0 -135
  363. package/src/extensions/markdown/table.ts +0 -150
  364. package/src/extensions/mention.ts +0 -41
  365. package/src/extensions/modal.ts +0 -24
  366. package/src/extensions/modes.ts +0 -41
  367. package/src/extensions/outliner/commands.ts +0 -270
  368. package/src/extensions/outliner/editor.test.ts +0 -33
  369. package/src/extensions/outliner/editor.ts +0 -184
  370. package/src/extensions/outliner/index.ts +0 -7
  371. package/src/extensions/outliner/menu.ts +0 -128
  372. package/src/extensions/outliner/outliner.test.ts +0 -100
  373. package/src/extensions/outliner/outliner.ts +0 -167
  374. package/src/extensions/outliner/selection.ts +0 -50
  375. package/src/extensions/outliner/tree.test.ts +0 -168
  376. package/src/extensions/outliner/tree.ts +0 -317
  377. package/src/extensions/preview/index.ts +0 -5
  378. package/src/extensions/preview/preview.ts +0 -193
  379. package/src/extensions/replacer.test.ts +0 -75
  380. package/src/extensions/replacer.ts +0 -93
  381. package/src/extensions/scrolling.ts +0 -189
  382. package/src/extensions/selection.ts +0 -100
  383. package/src/extensions/state.ts +0 -7
  384. package/src/extensions/submit.ts +0 -62
  385. package/src/extensions/tab.ts +0 -29
  386. package/src/extensions/tags/extended-markdown.test.ts +0 -262
  387. package/src/extensions/tags/extended-markdown.ts +0 -78
  388. package/src/extensions/tags/index.ts +0 -7
  389. package/src/extensions/tags/streamer.ts +0 -243
  390. package/src/extensions/tags/xml-tags.ts +0 -500
  391. package/src/extensions/tags/xml-util.ts +0 -94
  392. package/src/extensions/typewriter.ts +0 -68
  393. package/src/stories/CommandDialog.stories.tsx +0 -83
  394. package/src/styles/index.ts +0 -7
  395. package/src/styles/markdown.ts +0 -26
  396. package/src/styles/theme.ts +0 -269
  397. package/src/styles/tokens.ts +0 -17
  398. package/src/types/index.ts +0 -5
  399. package/src/types/types.ts +0 -32
  400. package/src/util/cursor.ts +0 -56
  401. package/src/util/debug.ts +0 -69
  402. package/src/util/decorations.ts +0 -21
  403. package/src/util/dom.ts +0 -34
  404. package/src/util/facet.ts +0 -13
@@ -7,18 +7,16 @@ import defaultsDeep from 'lodash.defaultsdeep';
7
7
  import React from 'react';
8
8
 
9
9
  import { log } from '@dxos/log';
10
- import { faker } from '@dxos/random';
11
- import { withTheme } from '@dxos/react-ui/testing';
12
-
13
- import { blast, defaultOptions, dropFile, typewriter } from '../extensions';
14
- import { str } from '../util';
10
+ import { random } from '@dxos/random';
11
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
12
+ import { blast, defaultOptions, dropFile, join, typewriter } from '@dxos/ui-editor';
15
13
 
16
14
  import { EditorStory, content } from './components';
17
15
 
18
16
  const meta = {
19
17
  title: 'ui/react-ui-editor/Experimental',
20
18
  component: EditorStory,
21
- decorators: [withTheme],
19
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
22
20
  parameters: {
23
21
  layout: 'fullscreen',
24
22
  },
@@ -32,12 +30,12 @@ type Story = StoryObj<typeof meta>;
32
30
  // Typewriter
33
31
  //
34
32
 
35
- const typewriterItems = localStorage.getItem('dxos.org/testing/typewriter')?.split(',');
33
+ const typewriterItems = localStorage.getItem('org.dxos.testing.typewriter')?.split(',');
36
34
 
37
35
  export const Typewriter: Story = {
38
36
  render: () => (
39
37
  <EditorStory
40
- text={str('# Typewriter', '', content.paragraphs, content.footer)}
38
+ text={join('# Typewriter', '', content.paragraphs, content.footer)}
41
39
  extensions={[typewriter({ items: typewriterItems })]}
42
40
  />
43
41
  ),
@@ -50,7 +48,7 @@ export const Typewriter: Story = {
50
48
  export const Blast: Story = {
51
49
  render: () => (
52
50
  <EditorStory
53
- text={str('# Blast', '', content.paragraphs, content.codeblocks, content.paragraphs)}
51
+ text={join('# Blast', '', content.paragraphs, content.codeblocks, content.paragraphs)}
54
52
  extensions={[
55
53
  typewriter({ items: typewriterItems }),
56
54
  blast(
@@ -59,8 +57,8 @@ export const Blast: Story = {
59
57
  effect: 2,
60
58
  particleGravity: 0.2,
61
59
  particleShrinkRate: 0.995,
62
- color: () => [faker.number.int({ min: 100, max: 200 }), 0, 0],
63
- // color: () => [faker.number.int(256), faker.number.int(256), faker.number.int(256)],
60
+ color: () => [random.number.int({ min: 100, max: 200 }), 0, 0],
61
+ // color: () => [random.number.int(256), random.number.int(256), random.number.int(256)],
64
62
  },
65
63
  defaultOptions,
66
64
  ),
@@ -77,7 +75,7 @@ export const Blast: Story = {
77
75
  export const DND: Story = {
78
76
  render: () => (
79
77
  <EditorStory
80
- text={str('# DND', '')}
78
+ text={join('# DND', '')}
81
79
  extensions={[
82
80
  dropFile({
83
81
  onDrop: (view, event) => {
@@ -6,17 +6,15 @@ import { markdown } from '@codemirror/lang-markdown';
6
6
  import { type Meta, type StoryObj } from '@storybook/react-vite';
7
7
  import React from 'react';
8
8
 
9
- import { withTheme } from '@dxos/react-ui/testing';
10
-
11
- import { decorateMarkdown, image, linkTooltip, table } from '../extensions';
12
- import { str } from '../util';
9
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
10
+ import { decorateMarkdown, image, join, linkTooltip, table } from '@dxos/ui-editor';
13
11
 
14
12
  import { EditorStory, content, defaultExtensions, headings, renderLinkTooltip, text } from './components';
15
13
 
16
14
  const meta = {
17
15
  title: 'ui/react-ui-editor/Markdown',
18
16
  component: EditorStory,
19
- decorators: [withTheme],
17
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
20
18
  parameters: {
21
19
  layout: 'fullscreen',
22
20
  },
@@ -37,7 +35,7 @@ export const Default: Story = {
37
35
  export const Blockquote: Story = {
38
36
  render: () => (
39
37
  <EditorStory
40
- text={str('> Blockquote', 'continuation', content.footer)}
38
+ text={join('> Blockquote', 'continuation', content.footer)}
41
39
  extensions={decorateMarkdown()}
42
40
  debug='raw'
43
41
  />
@@ -49,21 +47,23 @@ export const Headings: Story = {
49
47
  };
50
48
 
51
49
  export const Links: Story = {
52
- render: () => <EditorStory text={str(content.links, content.footer)} extensions={[linkTooltip(renderLinkTooltip)]} />,
50
+ render: () => (
51
+ <EditorStory text={join(content.links, content.footer)} extensions={[linkTooltip(renderLinkTooltip)]} />
52
+ ),
53
53
  };
54
54
 
55
55
  export const Image: Story = {
56
- render: () => <EditorStory text={str(content.image, content.footer)} extensions={[image()]} />,
56
+ render: () => <EditorStory text={join(content.image, content.footer)} extensions={[image()]} />,
57
57
  };
58
58
 
59
59
  export const Code: Story = {
60
- render: () => <EditorStory text={str(content.codeblocks, content.footer)} extensions={[decorateMarkdown()]} />,
60
+ render: () => <EditorStory text={join(content.codeblocks, content.footer)} extensions={[decorateMarkdown()]} />,
61
61
  };
62
62
 
63
63
  export const Lists: Story = {
64
64
  render: () => (
65
65
  <EditorStory
66
- text={str(content.tasks, '', content.bullets, '', content.numbered, content.footer)}
66
+ text={join(content.tasks, '', content.bullets, '', content.numbered, content.footer)}
67
67
  extensions={[decorateMarkdown()]}
68
68
  />
69
69
  ),
@@ -74,7 +74,7 @@ export const Lists: Story = {
74
74
  //
75
75
 
76
76
  export const BulletList: Story = {
77
- render: () => <EditorStory text={str(content.bullets, content.footer)} extensions={[decorateMarkdown()]} />,
77
+ render: () => <EditorStory text={join(content.bullets, content.footer)} extensions={[decorateMarkdown()]} />,
78
78
  };
79
79
 
80
80
  //
@@ -82,7 +82,7 @@ export const BulletList: Story = {
82
82
  //
83
83
 
84
84
  export const OrderedList: Story = {
85
- render: () => <EditorStory text={str(content.numbered, content.footer)} extensions={[decorateMarkdown()]} />,
85
+ render: () => <EditorStory text={join(content.numbered, content.footer)} extensions={[decorateMarkdown()]} />,
86
86
  };
87
87
 
88
88
  //
@@ -91,12 +91,12 @@ export const OrderedList: Story = {
91
91
 
92
92
  export const TaskList: Story = {
93
93
  render: () => (
94
- <EditorStory text={str(content.tasks, content.footer)} extensions={[decorateMarkdown()]} debug='raw+tree' />
94
+ <EditorStory text={join(content.tasks, content.footer)} extensions={[decorateMarkdown()]} debug='raw+tree' />
95
95
  ),
96
96
  };
97
97
 
98
98
  export const TaskListEmpty: Story = {
99
- render: () => <EditorStory text={str('- [ ] ')} extensions={[decorateMarkdown()]} debug='raw+tree' />,
99
+ render: () => <EditorStory text={join('- [ ] ')} extensions={[decorateMarkdown()]} debug='raw+tree' />,
100
100
  };
101
101
 
102
102
  //
@@ -104,7 +104,7 @@ export const TaskListEmpty: Story = {
104
104
  //
105
105
 
106
106
  export const Table: Story = {
107
- render: () => <EditorStory text={str(content.table, content.footer)} extensions={[decorateMarkdown(), table()]} />,
107
+ render: () => <EditorStory text={join(content.table, content.footer)} extensions={[decorateMarkdown(), table()]} />,
108
108
  };
109
109
 
110
110
  //
@@ -114,7 +114,7 @@ export const Table: Story = {
114
114
  export const CommentedOut: Story = {
115
115
  render: () => (
116
116
  <EditorStory
117
- text={str('# Commented out', '', content.comment, content.footer)}
117
+ text={join('# Commented out', '', content.comment, content.footer)}
118
118
  extensions={[
119
119
  decorateMarkdown(),
120
120
  markdown(),
@@ -5,20 +5,18 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { useMemo, useState } from 'react';
7
7
 
8
- import { withTheme } from '@dxos/react-ui/testing';
9
8
  import { withAttention } from '@dxos/react-ui-attention/testing';
9
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
10
+ import { deleteItem, hashtag, join, listItemToString, outliner, treeFacet } from '@dxos/ui-editor';
10
11
 
11
12
  import { type EditorController, type EditorMenuGroup, EditorMenuProvider } from '../components';
12
- import { deleteItem, hashtag, listItemToString, outliner, treeFacet } from '../extensions';
13
- import { str } from '../util';
14
-
15
13
  import { EditorStory } from './components';
16
14
 
17
- type StoryProps = {
15
+ type DefaultStoryProps = {
18
16
  text?: string;
19
17
  };
20
18
 
21
- const DefaultStory = ({ text }: StoryProps) => {
19
+ const DefaultStory = ({ text }: DefaultStoryProps) => {
22
20
  const [controller, setController] = useState<EditorController | null>(null);
23
21
 
24
22
  const extensions = useMemo(() => [outliner(), hashtag()], []);
@@ -69,7 +67,7 @@ const DefaultStory = ({ text }: StoryProps) => {
69
67
  const meta = {
70
68
  title: 'ui/react-ui-editor/Outliner',
71
69
  render: DefaultStory,
72
- decorators: [withTheme, withAttention],
70
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' }), withAttention()],
73
71
  parameters: {
74
72
  layout: 'fullscreen',
75
73
  },
@@ -85,7 +83,7 @@ export const Empty: Story = {
85
83
 
86
84
  export const Basic: Story = {
87
85
  args: {
88
- text: str(
86
+ text: join(
89
87
  //
90
88
  '- [ ] A',
91
89
  '- [ ] B',
@@ -100,7 +98,7 @@ export const Basic: Story = {
100
98
 
101
99
  export const Nested: Story = {
102
100
  args: {
103
- text: str(
101
+ text: join(
104
102
  //
105
103
  '- [ ] A',
106
104
  ' - [ ] B',
@@ -115,7 +113,7 @@ export const Nested: Story = {
115
113
 
116
114
  export const Continuation: Story = {
117
115
  args: {
118
- text: str(
116
+ text: join(
119
117
  //
120
118
  '- [ ] A',
121
119
  '- [ ] B',
@@ -6,11 +6,12 @@ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React, { useCallback, useState } from 'react';
7
7
 
8
8
  import { Obj, Query } from '@dxos/echo';
9
- import { faker } from '@dxos/random';
10
- import { useClientProvider, withClientProvider } from '@dxos/react-client/testing';
11
- import { Domino } from '@dxos/react-ui';
12
- import { withTheme } from '@dxos/react-ui/testing';
13
- import { Testing, type ValueGenerator, createObjectFactory } from '@dxos/schema/testing';
9
+ import { random } from '@dxos/random';
10
+ import { useClientStory, withClientProvider } from '@dxos/react-client/testing';
11
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
12
+ import { TestSchema, type ValueGenerator, createObjectFactory } from '@dxos/schema/testing';
13
+ import { Domino, mx } from '@dxos/ui';
14
+ import { insertAtCursor, insertAtLineStart, join } from '@dxos/ui-editor';
14
15
 
15
16
  import {
16
17
  type EditorController,
@@ -21,36 +22,30 @@ import {
21
22
  createMenuGroup,
22
23
  filterMenuGroups,
23
24
  formattingCommands,
24
- insertAtCursor,
25
- insertAtLineStart,
26
25
  linkSlashCommands,
27
26
  useEditorMenu,
28
27
  } from '../components';
29
- import { str } from '../util';
30
-
31
28
  import { EditorStory } from './components';
32
29
 
33
- const generator: ValueGenerator = faker as any;
30
+ const generator: ValueGenerator = random as any;
34
31
 
35
32
  const customCompletions: EditorMenuGroup = createMenuGroup({
36
33
  id: 'test',
37
34
  items: ['Hello world!', 'Hello DXOS', 'Hello Composer', 'https://dxos.org'],
38
35
  });
39
36
 
40
- const placeholder = (trigger: string[]) =>
41
- Domino.of('div')
42
- .children(
43
- Domino.of('span').text('Press'),
44
- ...trigger.map((trigger) =>
45
- Domino.of('span').text(trigger).classNames('border border-separator rounded-sm mx-1 pli-1 pbs-[2px] pbe-[3px]'),
46
- ),
47
- Domino.of('span').text('for commands'),
48
- )
49
- .build();
37
+ const placeholder = (trigger: string[]) => {
38
+ const pressEl = Domino.of('span').text('Press');
39
+ const triggerEls = trigger.map((trigger) =>
40
+ Domino.of('span').classNames(mx('border border-separator rounded-xs mx-1 px-1 py-[2px] pb-[3px]')).text(trigger),
41
+ );
42
+ const forCommandsEl = Domino.of('span').text('for commands');
43
+ return Domino.of('div').append(pressEl, ...triggerEls, forCommandsEl).root;
44
+ };
50
45
 
51
- type StoryProps = Omit<UseEditorMenuProps, 'viewRef'> & { text: string };
46
+ type DefaultStoryProps = Omit<UseEditorMenuProps, 'viewRef'> & { text: string };
52
47
 
53
- const DefaultStory = ({ text, ...props }: StoryProps) => {
48
+ const DefaultStory = ({ text, ...props }: DefaultStoryProps) => {
54
49
  const [controller, setController] = useState<EditorController | null>(null);
55
50
  const { groupsRef, extension, ...menuProps } = useEditorMenu(props);
56
51
 
@@ -61,8 +56,8 @@ const DefaultStory = ({ text, ...props }: StoryProps) => {
61
56
  );
62
57
  };
63
58
 
64
- const LinkStory = (args: StoryProps) => {
65
- const { space } = useClientProvider();
59
+ const LinkStory = (args: DefaultStoryProps) => {
60
+ const { space } = useClientStory();
66
61
 
67
62
  const getMenu = useCallback<NonNullable<UseEditorMenuProps['getMenu']>>(
68
63
  async ({ text, trigger }): Promise<EditorMenuGroup[]> => {
@@ -77,8 +72,8 @@ const LinkStory = (args: StoryProps) => {
77
72
  }
78
73
 
79
74
  const name = text?.startsWith('@') ? text.slice(1).toLowerCase() : (text?.toLowerCase() ?? '');
80
- const result = await space?.db.query(Query.type(Testing.Person)).run();
81
- const items = result.objects
75
+ const result = await space?.db.query(Query.type(TestSchema.Person)).run();
76
+ const items = result
82
77
  .filter((object) => object.name.toLowerCase().includes(name))
83
78
  .map(
84
79
  (object): EditorMenuItem => ({
@@ -107,7 +102,7 @@ const LinkStory = (args: StoryProps) => {
107
102
  const meta = {
108
103
  title: 'ui/react-ui-editor/Popover',
109
104
  render: DefaultStory,
110
- decorators: [withTheme],
105
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
111
106
  parameters: {
112
107
  layout: 'fullscreen',
113
108
  },
@@ -119,7 +114,7 @@ type Story = StoryObj<typeof meta>;
119
114
 
120
115
  export const Default: Story = {
121
116
  args: {
122
- text: str('# Autocomplete', '', ''),
117
+ text: join('# Autocomplete', '', ''),
123
118
  triggerKey: 'Ctrl-Space',
124
119
  filter: true,
125
120
  getMenu: () => [customCompletions],
@@ -128,7 +123,7 @@ export const Default: Story = {
128
123
 
129
124
  export const Formatting: Story = {
130
125
  args: {
131
- text: str('# Slash command', '', ''),
126
+ text: join('# Slash command', '', ''),
132
127
  trigger: '/',
133
128
  placeholder: {
134
129
  content: () => placeholder(['/']),
@@ -143,17 +138,17 @@ export const Link: Story = {
143
138
  withClientProvider({
144
139
  createSpace: true,
145
140
  onInitialized: async (client) => {
146
- client.addTypes([Testing.Person]);
141
+ await client.addTypes([TestSchema.Person]);
147
142
  },
148
143
  onCreateSpace: async ({ space }) => {
149
144
  const createObjects = createObjectFactory(space.db, generator);
150
- await createObjects([{ type: Testing.Person, count: 10 }]);
145
+ await createObjects([{ type: TestSchema.Person, count: 10 }]);
151
146
  await space.db.flush({ indexes: true });
152
147
  },
153
148
  }),
154
149
  ],
155
150
  args: {
156
- text: str('# Links', '', ''),
151
+ text: join('# Links', '', ''),
157
152
  trigger: ['/', '@'],
158
153
  placeholder: {
159
154
  content: () => placeholder(['/', '@']),
@@ -9,14 +9,10 @@ import React, { useCallback, useEffect, useMemo, useState } from 'react';
9
9
  import { createPortal } from 'react-dom';
10
10
 
11
11
  import { invariant } from '@dxos/invariant';
12
- import { faker } from '@dxos/random';
13
- import { Popover } from '@dxos/react-ui';
14
- import { withTheme } from '@dxos/react-ui/testing';
15
- import { Card } from '@dxos/react-ui-stack';
16
- import { hoverableControlItem, hoverableControlItemTransition, hoverableControls } from '@dxos/react-ui-theme';
17
- import { trim } from '@dxos/util';
18
-
19
- import { type EditorController, EditorPreviewProvider, useEditorPreview } from '../components';
12
+ import { random } from '@dxos/random';
13
+ import { Card, Popover, Toolbar } from '@dxos/react-ui';
14
+ import { Menu, createMenuAction } from '@dxos/react-ui-menu';
15
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
20
16
  import {
21
17
  type PreviewBlock,
22
18
  type PreviewLinkRef,
@@ -24,14 +20,17 @@ import {
24
20
  getLinkRef,
25
21
  image,
26
22
  preview,
27
- } from '../extensions';
23
+ } from '@dxos/ui-editor';
24
+ import { hoverableControls } from '@dxos/ui-theme';
25
+ import { trim } from '@dxos/util';
28
26
 
27
+ import { type EditorController, EditorPreviewProvider, useEditorPreview } from '../components';
29
28
  import { EditorStory } from './components';
30
29
 
31
- const handlePreviewLookup = async ({ label, ref }: PreviewLinkRef): Promise<PreviewLinkTarget> => {
30
+ const handlePreviewLookup = async ({ dxn, label }: PreviewLinkRef): Promise<PreviewLinkTarget> => {
32
31
  // Random text.
33
- faker.seed(ref.split('').reduce((acc: number, char: string) => acc + char.charCodeAt(0), 1));
34
- const text = Array.from({ length: 2 }, () => faker.lorem.paragraphs()).join('\n\n');
32
+ random.seed(dxn.split('').reduce((acc: number, char: string) => acc + char.charCodeAt(0), 1));
33
+ const text = Array.from({ length: 2 }, () => random.lorem.paragraphs()).join('\n\n');
35
34
  return {
36
35
  label,
37
36
  text,
@@ -51,14 +50,26 @@ const useRefTarget = (link: PreviewLinkRef): PreviewLinkTarget | undefined => {
51
50
 
52
51
  const PreviewCard = () => {
53
52
  const { target } = useEditorPreview('PreviewCard');
53
+ if (!target) {
54
+ return null;
55
+ }
56
+
54
57
  return (
55
58
  <Popover.Portal>
56
59
  <Popover.Content onOpenAutoFocus={(event) => event.preventDefault()}>
57
- <Popover.Viewport>
58
- <Card.SurfaceRoot role='card--popover'>
59
- <Card.Heading>{target?.label}</Card.Heading>
60
- {target && <Card.Text classNames='line-clamp-3'>{target.text}</Card.Text>}
61
- </Card.SurfaceRoot>
60
+ <Popover.Viewport classNames='dx-card-popover-width'>
61
+ <Card.Root border={false}>
62
+ <Card.Toolbar>
63
+ <Card.Icon icon='ph--file-text--regular' />
64
+ <Card.Title>{target.label}</Card.Title>
65
+ <Popover.Close asChild>
66
+ <Card.CloseIconButton />
67
+ </Popover.Close>
68
+ </Card.Toolbar>
69
+ <Card.Row>
70
+ <Card.Text variant='description'>{target.text}</Card.Text>
71
+ </Card.Row>
72
+ </Card.Root>
62
73
  </Popover.Viewport>
63
74
  <Popover.Arrow />
64
75
  </Popover.Content>
@@ -90,7 +101,7 @@ const PreviewBlockComponent = ({ link, el, view }: { link: PreviewLinkRef; el: H
90
101
  }
91
102
 
92
103
  const link = getLinkRef(view.state, node);
93
- if (link?.ref !== action.link.ref) {
104
+ if (link?.dxn !== action.link.dxn) {
94
105
  return;
95
106
  }
96
107
 
@@ -132,41 +143,45 @@ const PreviewBlockComponent = ({ link, el, view }: { link: PreviewLinkRef; el: H
132
143
  }
133
144
  }, [handleAction, link, target]);
134
145
 
146
+ const menuItems = useMemo(
147
+ () => [
148
+ createMenuAction('delete', handleDelete, {
149
+ label: link.suggest ? 'Discard' : 'Delete',
150
+ icon: 'ph--x--regular',
151
+ }),
152
+ ...(target
153
+ ? [
154
+ createMenuAction('apply', handleInsert, {
155
+ label: 'Apply',
156
+ icon: 'ph--check--regular',
157
+ }),
158
+ ]
159
+ : []),
160
+ ],
161
+ [handleDelete, handleInsert, link.suggest, target],
162
+ );
163
+
135
164
  return createPortal(
136
- <Card.StaticRoot classNames={hoverableControls}>
137
- <div className='flex items-start'>
165
+ <Menu.Root>
166
+ <Card.Root classNames={hoverableControls}>
138
167
  {!view?.state.readOnly && (
139
- <Card.Toolbar classNames='is-min p-[--dx-cardSpacingInline]'>
140
- {(link.suggest && (
141
- <>
142
- <Card.ToolbarIconButton label='Discard' icon='ph--x--regular' onClick={handleDelete} />
143
- {target && (
144
- <Card.ToolbarIconButton
145
- classNames='bg-successSurface text-successSurfaceText'
146
- label='Apply'
147
- icon='ph--check--regular'
148
- onClick={handleInsert}
149
- />
150
- )}
151
- </>
152
- )) || (
153
- <Card.ToolbarIconButton
154
- iconOnly
155
- label='Delete'
156
- icon='ph--x--regular'
157
- classNames={[hoverableControlItem, hoverableControlItemTransition]}
158
- onClick={handleDelete}
159
- />
160
- )}
168
+ <Card.Toolbar>
169
+ <Card.Icon icon='ph--bookmark--regular' />
170
+ <Card.Title>{link.label}</Card.Title>
171
+ {/* TODO(wittjosiah): Reconcile with Card.Menu. */}
172
+ <Menu.Trigger asChild disabled={!menuItems?.length}>
173
+ <Toolbar.IconButton iconOnly variant='ghost' icon='ph--dots-three-vertical--regular' label='Menu' />
174
+ </Menu.Trigger>
175
+ <Menu.Content items={menuItems} />
161
176
  </Card.Toolbar>
162
177
  )}
163
- <Card.Heading classNames='grow order-first mie-0'>
164
- {/* <span className='text-xs text-subdued mie-2'>Prompt</span> */}
165
- {link.label}
166
- </Card.Heading>
167
- </div>
168
- {target && <Card.Text classNames='line-clamp-3 mbs-0'>{target.text}</Card.Text>}
169
- </Card.StaticRoot>,
178
+ {target && (
179
+ <Card.Row>
180
+ <Card.Text className='text-description'>{target.text}</Card.Text>
181
+ </Card.Row>
182
+ )}
183
+ </Card.Root>
184
+ </Menu.Root>,
170
185
  el,
171
186
  );
172
187
  };
@@ -174,7 +189,7 @@ const PreviewBlockComponent = ({ link, el, view }: { link: PreviewLinkRef; el: H
174
189
  const meta = {
175
190
  title: 'ui/react-ui-editor/Preview',
176
191
  component: EditorStory,
177
- decorators: [withTheme],
192
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
178
193
  parameters: {
179
194
  layout: 'fullscreen',
180
195
  },
@@ -211,21 +226,20 @@ export const Default: Story = {
211
226
  setPreviewBlocks((prev) => [...prev, block]);
212
227
  },
213
228
  removeBlockContainer: (block) => {
214
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== block.link.ref));
229
+ setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.dxn !== block.link.dxn));
215
230
  },
216
231
  }),
217
232
  ];
218
233
  }, []);
219
234
 
220
235
  // TODO(burdon): Migrate to Editor.Root.
221
- // TODO(burdon): Ranges must be sorted error (decorate.enter).
222
236
  return (
223
237
  <EditorPreviewProvider onLookup={handlePreviewLookup}>
224
238
  <EditorStory ref={setController} text={text} extensions={extensions} />
225
239
  <PreviewCard />
226
240
  {controller?.view &&
227
241
  previewBlocks.map(({ link, el }) => (
228
- <PreviewBlockComponent key={link.ref} link={link} el={el} view={controller.view!} />
242
+ <PreviewBlockComponent key={link.dxn} link={link} el={el} view={controller.view!} />
229
243
  ))}
230
244
  </EditorPreviewProvider>
231
245
  );
@@ -7,9 +7,7 @@ import React, { useEffect, useState } from 'react';
7
7
  import { createPortal } from 'react-dom';
8
8
 
9
9
  import { useThemeContext } from '@dxos/react-ui';
10
- import { withTheme } from '@dxos/react-ui/testing';
11
- import { trim } from '@dxos/util';
12
-
10
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
13
11
  import {
14
12
  type XmlWidgetRegistry,
15
13
  type XmlWidgetState,
@@ -18,25 +16,34 @@ import {
18
16
  decorateMarkdown,
19
17
  extendedMarkdown,
20
18
  xmlTags,
21
- } from '../extensions';
19
+ } from '@dxos/ui-editor';
20
+ import { safeParseInt, trim } from '@dxos/util';
21
+
22
22
  import { useTextEditor } from '../hooks';
23
23
 
24
24
  const registry = {
25
25
  /**
26
26
  * Custom tag: <test/>
27
27
  */
28
- ['test' as const]: {
28
+ test: {
29
29
  block: true,
30
- Component: () => {
31
- const [count, setCount] = useState(0);
30
+ Component: ({ start = '0' }) => {
31
+ const [count, setCount] = useState<number>(safeParseInt(start, 0));
32
32
  useEffect(() => {
33
33
  const interval = setInterval(() => {
34
- setCount((prev) => prev + 1);
35
- }, 1_000);
34
+ setCount((prev) => {
35
+ if (prev >= 200) {
36
+ clearInterval(interval);
37
+ return prev;
38
+ }
39
+
40
+ return prev + 1;
41
+ });
42
+ }, 100);
36
43
  return () => clearInterval(interval);
37
44
  }, []);
38
45
 
39
- return <div className='p-2 border border-separator rounded'>Test {count}</div>;
46
+ return <div className='p-2 border border-separator rounded-sm'>Test {count}</div>;
40
47
  },
41
48
  },
42
49
  } satisfies XmlWidgetRegistry;
@@ -57,8 +64,8 @@ const DefaultStory = ({ text }: { text?: string }) => {
57
64
 
58
65
  return (
59
66
  <>
60
- <div ref={parentRef} className='is-full p-4' />
61
- {widgets.map(({ Component, root, id, ...props }) => (
67
+ <div ref={parentRef} className='w-full p-4' />
68
+ {widgets.map(({ id, root, Component, props }) => (
62
69
  <div key={id}>{createPortal(<Component {...props} />, root)}</div>
63
70
  ))}
64
71
  </>
@@ -70,15 +77,17 @@ const text = trim`
70
77
 
71
78
  React widget below.
72
79
 
73
- <test id="123" />
80
+ <test id="t-1" />
81
+
82
+ <test id="t-2" start="100" />
74
83
 
75
84
  React widget above.
76
85
  `;
77
86
 
78
87
  const meta = {
79
- title: 'ui/react-ui-editor/XmlTags',
88
+ title: 'ui/react-ui-editor/Tags',
80
89
  render: DefaultStory,
81
- decorators: [withTheme],
90
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
82
91
  parameters: {
83
92
  layout: 'fullscreen',
84
93
  },