@dxos/react-ui-editor 0.8.4-main.dedc0f3 → 0.8.4-main.e8ec1fe

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 (317) hide show
  1. package/dist/lib/browser/{chunk-22UMM3QJ.mjs → chunk-HL3YF6WC.mjs} +2 -2
  2. package/dist/lib/browser/chunk-HL3YF6WC.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +5638 -5200
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/types/index.mjs +1 -1
  7. package/dist/lib/node-esm/{chunk-YXYQPV6R.mjs → chunk-YJZGD3LY.mjs} +2 -2
  8. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +7 -0
  9. package/dist/lib/node-esm/index.mjs +5638 -5200
  10. package/dist/lib/node-esm/index.mjs.map +4 -4
  11. package/dist/lib/node-esm/meta.json +1 -1
  12. package/dist/lib/node-esm/types/index.mjs +1 -1
  13. package/dist/types/src/components/Editor/Editor.d.ts +37 -15
  14. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  15. package/dist/types/src/components/Editor/Editor.stories.d.ts +20 -0
  16. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorContent/EditorContent.d.ts +29 -0
  18. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts +26 -0
  20. package/dist/types/src/components/EditorContent/EditorContent.stories.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
  22. package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
  23. package/dist/types/src/components/EditorContent/index.d.ts +3 -0
  24. package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +36 -0
  26. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorMenuProvider/index.d.ts +7 -0
  28. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  30. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  32. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  33. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +47 -0
  34. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  35. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  36. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  37. package/dist/types/src/components/EditorMenuProvider/util.d.ts +8 -0
  38. package/dist/types/src/components/EditorMenuProvider/util.d.ts.map +1 -0
  39. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  40. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  41. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  42. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  43. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +26 -2
  44. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/actions.d.ts +39 -0
  46. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  47. package/dist/types/src/components/EditorToolbar/blocks.d.ts +3 -3
  48. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  49. package/dist/types/src/components/EditorToolbar/formatting.d.ts +3 -3
  50. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  51. package/dist/types/src/components/EditorToolbar/headings.d.ts +3 -3
  52. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  53. package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
  54. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  55. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
  56. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
  57. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +3 -3
  58. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  59. package/dist/types/src/components/index.d.ts +4 -2
  60. package/dist/types/src/components/index.d.ts.map +1 -1
  61. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +17 -0
  62. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +1 -0
  63. package/dist/types/src/extensions/autocomplete/index.d.ts +5 -0
  64. package/dist/types/src/extensions/autocomplete/index.d.ts.map +1 -0
  65. package/dist/types/src/extensions/autocomplete/match.d.ts +13 -0
  66. package/dist/types/src/extensions/autocomplete/match.d.ts.map +1 -0
  67. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +20 -0
  68. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +1 -0
  69. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +10 -0
  70. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +1 -0
  71. package/dist/types/src/extensions/automerge/automerge.d.ts +1 -1
  72. package/dist/types/src/extensions/automerge/automerge.d.ts.map +1 -1
  73. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +1 -1
  74. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +1 -1
  75. package/dist/types/src/extensions/automerge/cursor.d.ts +1 -1
  76. package/dist/types/src/extensions/automerge/cursor.d.ts.map +1 -1
  77. package/dist/types/src/extensions/automerge/sync.d.ts +3 -3
  78. package/dist/types/src/extensions/automerge/sync.d.ts.map +1 -1
  79. package/dist/types/src/extensions/automerge/update-automerge.d.ts +1 -1
  80. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +1 -1
  81. package/dist/types/src/extensions/autoscroll.d.ts +14 -4
  82. package/dist/types/src/extensions/autoscroll.d.ts.map +1 -1
  83. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +1 -1
  84. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +1 -1
  85. package/dist/types/src/extensions/blocks.d.ts +2 -0
  86. package/dist/types/src/extensions/blocks.d.ts.map +1 -0
  87. package/dist/types/src/extensions/bookmarks.d.ts +12 -0
  88. package/dist/types/src/extensions/bookmarks.d.ts.map +1 -0
  89. package/dist/types/src/extensions/comments.d.ts.map +1 -1
  90. package/dist/types/src/extensions/factories.d.ts +10 -5
  91. package/dist/types/src/extensions/factories.d.ts.map +1 -1
  92. package/dist/types/src/extensions/focus.d.ts.map +1 -1
  93. package/dist/types/src/extensions/folding.d.ts.map +1 -1
  94. package/dist/types/src/extensions/index.d.ts +8 -1
  95. package/dist/types/src/extensions/index.d.ts.map +1 -1
  96. package/dist/types/src/extensions/json.d.ts +1 -1
  97. package/dist/types/src/extensions/json.d.ts.map +1 -1
  98. package/dist/types/src/extensions/listener.d.ts +8 -6
  99. package/dist/types/src/extensions/listener.d.ts.map +1 -1
  100. package/dist/types/src/extensions/markdown/bundle.d.ts.map +1 -1
  101. package/dist/types/src/extensions/markdown/decorate.d.ts.map +1 -1
  102. package/dist/types/src/extensions/markdown/formatting.d.ts +1 -3
  103. package/dist/types/src/extensions/markdown/formatting.d.ts.map +1 -1
  104. package/dist/types/src/extensions/markdown/link.d.ts.map +1 -1
  105. package/dist/types/src/extensions/modal.d.ts +7 -0
  106. package/dist/types/src/extensions/modal.d.ts.map +1 -0
  107. package/dist/types/src/extensions/modes.d.ts +1 -1
  108. package/dist/types/src/extensions/modes.d.ts.map +1 -1
  109. package/dist/types/src/extensions/outliner/menu.d.ts +8 -0
  110. package/dist/types/src/extensions/outliner/menu.d.ts.map +1 -0
  111. package/dist/types/src/extensions/preview/preview.d.ts +6 -4
  112. package/dist/types/src/extensions/preview/preview.d.ts.map +1 -1
  113. package/dist/types/src/extensions/replacer.d.ts +21 -0
  114. package/dist/types/src/extensions/replacer.d.ts.map +1 -0
  115. package/dist/types/src/extensions/replacer.test.d.ts +2 -0
  116. package/dist/types/src/extensions/replacer.test.d.ts.map +1 -0
  117. package/dist/types/src/extensions/scrolling.d.ts +78 -0
  118. package/dist/types/src/extensions/scrolling.d.ts.map +1 -0
  119. package/dist/types/src/extensions/state.d.ts +2 -0
  120. package/dist/types/src/extensions/state.d.ts.map +1 -0
  121. package/dist/types/src/extensions/submit.d.ts +10 -0
  122. package/dist/types/src/extensions/submit.d.ts.map +1 -0
  123. package/dist/types/src/extensions/tab.d.ts +4 -0
  124. package/dist/types/src/extensions/tab.d.ts.map +1 -0
  125. package/dist/types/src/extensions/tags/streamer.d.ts.map +1 -1
  126. package/dist/types/src/extensions/tags/xml-tags.d.ts +42 -16
  127. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +1 -1
  128. package/dist/types/src/hooks/useTextEditor.d.ts +5 -9
  129. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  130. package/dist/types/src/stories/{Command.stories.d.ts → CommandDialog.stories.d.ts} +2 -3
  131. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  132. package/dist/types/src/stories/Comments.stories.d.ts +3 -4
  133. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  134. package/dist/types/src/stories/EditorToolbar.stories.d.ts +1 -2
  135. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  136. package/dist/types/src/stories/Experimental.stories.d.ts +3 -4
  137. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  138. package/dist/types/src/stories/Markdown.stories.d.ts +3 -4
  139. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  140. package/dist/types/src/stories/Outliner.stories.d.ts +0 -1
  141. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  142. package/dist/types/src/stories/{CommandMenu.stories.d.ts → Popover.stories.d.ts} +6 -6
  143. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  144. package/dist/types/src/stories/Preview.stories.d.ts +4 -4
  145. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  146. package/dist/types/src/stories/Tags.stories.d.ts +0 -1
  147. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  148. package/dist/types/src/stories/TextEditor.stories.d.ts +3 -5
  149. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  150. package/dist/types/src/stories/components/EditorStory.d.ts +7 -5
  151. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  152. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  153. package/dist/types/src/styles/theme.d.ts.map +1 -1
  154. package/dist/types/src/types/types.d.ts +1 -1
  155. package/dist/types/src/types/types.d.ts.map +1 -1
  156. package/dist/types/src/util/debug.d.ts +4 -0
  157. package/dist/types/src/util/debug.d.ts.map +1 -1
  158. package/dist/types/src/util/index.d.ts +0 -1
  159. package/dist/types/src/util/index.d.ts.map +1 -1
  160. package/dist/types/tsconfig.tsbuildinfo +1 -1
  161. package/package.json +58 -59
  162. package/src/components/Editor/Editor.stories.tsx +89 -0
  163. package/src/components/Editor/Editor.tsx +160 -25
  164. package/src/components/EditorContent/EditorContent.stories.tsx +70 -0
  165. package/src/components/EditorContent/EditorContent.tsx +70 -0
  166. package/src/components/EditorContent/controller.ts +50 -0
  167. package/src/components/EditorContent/index.ts +6 -0
  168. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +233 -0
  169. package/src/components/EditorMenuProvider/index.ts +11 -0
  170. package/src/components/EditorMenuProvider/menu-presets.ts +123 -0
  171. package/src/components/EditorMenuProvider/menu.ts +71 -0
  172. package/src/components/EditorMenuProvider/popover.ts +287 -0
  173. package/src/components/EditorMenuProvider/useEditorMenu.ts +175 -0
  174. package/src/components/EditorMenuProvider/util.ts +31 -0
  175. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +82 -0
  176. package/src/components/EditorPreviewProvider/index.ts +5 -0
  177. package/src/components/EditorToolbar/EditorToolbar.tsx +101 -91
  178. package/src/components/EditorToolbar/{lists.ts → actions.ts} +46 -16
  179. package/src/components/EditorToolbar/blocks.ts +2 -1
  180. package/src/components/EditorToolbar/formatting.ts +2 -1
  181. package/src/components/EditorToolbar/headings.ts +8 -5
  182. package/src/components/EditorToolbar/image.ts +1 -1
  183. package/src/components/EditorToolbar/index.ts +3 -7
  184. package/src/components/EditorToolbar/search.ts +1 -1
  185. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  186. package/src/components/EditorToolbar/view-mode.ts +2 -1
  187. package/src/components/index.ts +8 -2
  188. package/src/extensions/{autocomplete.ts → autocomplete/autocomplete.ts} +8 -76
  189. package/src/extensions/autocomplete/index.ts +8 -0
  190. package/src/extensions/autocomplete/match.ts +46 -0
  191. package/src/extensions/{command → autocomplete}/placeholder.ts +21 -17
  192. package/src/extensions/{command → autocomplete}/typeahead.ts +6 -48
  193. package/src/extensions/automerge/automerge.stories.tsx +9 -9
  194. package/src/extensions/automerge/automerge.ts +28 -9
  195. package/src/extensions/automerge/cursor.ts +1 -1
  196. package/src/extensions/automerge/sync.ts +8 -4
  197. package/src/extensions/automerge/update-automerge.ts +1 -1
  198. package/src/extensions/autoscroll.ts +98 -86
  199. package/src/extensions/awareness/awareness-provider.ts +2 -2
  200. package/src/extensions/blocks.ts +131 -0
  201. package/src/extensions/bookmarks.ts +75 -0
  202. package/src/extensions/comments.ts +2 -1
  203. package/src/extensions/factories.ts +47 -16
  204. package/src/extensions/focus.ts +5 -4
  205. package/src/extensions/folding.tsx +3 -6
  206. package/src/extensions/hashtag.tsx +2 -2
  207. package/src/extensions/index.ts +8 -1
  208. package/src/extensions/json.ts +1 -1
  209. package/src/extensions/listener.ts +14 -20
  210. package/src/extensions/markdown/bundle.ts +16 -4
  211. package/src/extensions/markdown/decorate.ts +9 -8
  212. package/src/extensions/markdown/formatting.ts +8 -10
  213. package/src/extensions/markdown/highlight.ts +1 -1
  214. package/src/extensions/markdown/image.ts +2 -2
  215. package/src/extensions/markdown/link.ts +3 -0
  216. package/src/extensions/markdown/table.ts +6 -6
  217. package/src/extensions/modal.ts +24 -0
  218. package/src/extensions/modes.ts +2 -2
  219. package/src/extensions/{command/floating-menu.ts → outliner/menu.ts} +15 -20
  220. package/src/extensions/outliner/outliner.test.ts +1 -1
  221. package/src/extensions/outliner/outliner.ts +4 -4
  222. package/src/extensions/outliner/tree.test.ts +1 -1
  223. package/src/extensions/preview/index.ts +1 -1
  224. package/src/extensions/preview/preview.ts +14 -14
  225. package/src/extensions/replacer.test.ts +75 -0
  226. package/src/extensions/replacer.ts +93 -0
  227. package/src/extensions/scrolling.ts +189 -0
  228. package/src/extensions/selection.ts +3 -3
  229. package/src/extensions/state.ts +7 -0
  230. package/src/extensions/submit.ts +62 -0
  231. package/src/extensions/tab.ts +29 -0
  232. package/src/extensions/tags/extended-markdown.test.ts +2 -1
  233. package/src/extensions/tags/streamer.ts +4 -5
  234. package/src/extensions/tags/xml-tags.ts +320 -155
  235. package/src/extensions/typewriter.ts +1 -1
  236. package/src/hooks/useTextEditor.ts +31 -43
  237. package/src/stories/{Command.stories.tsx → CommandDialog.stories.tsx} +20 -27
  238. package/src/stories/Comments.stories.tsx +8 -9
  239. package/src/stories/EditorToolbar.stories.tsx +14 -13
  240. package/src/stories/Experimental.stories.tsx +7 -7
  241. package/src/stories/Markdown.stories.tsx +6 -6
  242. package/src/stories/Outliner.stories.tsx +40 -31
  243. package/src/stories/Popover.stories.tsx +162 -0
  244. package/src/stories/Preview.stories.tsx +46 -42
  245. package/src/stories/Tags.stories.tsx +24 -10
  246. package/src/stories/TextEditor.stories.tsx +10 -35
  247. package/src/stories/components/EditorStory.tsx +29 -16
  248. package/src/stories/components/util.tsx +40 -8
  249. package/src/styles/markdown.ts +1 -1
  250. package/src/styles/theme.ts +13 -11
  251. package/src/types/types.ts +1 -1
  252. package/src/util/debug.ts +5 -0
  253. package/src/util/index.ts +0 -1
  254. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  255. package/dist/lib/browser/testing/index.mjs +0 -6
  256. package/dist/lib/browser/testing/index.mjs.map +0 -7
  257. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  258. package/dist/lib/node-esm/testing/index.mjs +0 -8
  259. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  260. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  261. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  262. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  263. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  264. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  265. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  266. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -14
  267. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  268. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -37
  269. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  270. package/dist/types/src/components/Popover/index.d.ts +0 -4
  271. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  272. package/dist/types/src/extensions/autocomplete.d.ts +0 -26
  273. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  274. package/dist/types/src/extensions/command/action.d.ts +0 -17
  275. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  276. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  277. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  278. package/dist/types/src/extensions/command/command.d.ts +0 -6
  279. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  280. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  281. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  282. package/dist/types/src/extensions/command/hint.d.ts +0 -19
  283. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  284. package/dist/types/src/extensions/command/index.d.ts +0 -7
  285. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  286. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  287. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  288. package/dist/types/src/extensions/command/state.d.ts +0 -16
  289. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  290. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  291. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  292. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  293. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  294. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  295. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  296. package/dist/types/src/testing/index.d.ts +0 -2
  297. package/dist/types/src/testing/index.d.ts.map +0 -1
  298. package/dist/types/src/testing/util.d.ts +0 -3
  299. package/dist/types/src/testing/util.d.ts.map +0 -1
  300. package/dist/types/src/util/domino.d.ts +0 -18
  301. package/dist/types/src/util/domino.d.ts.map +0 -1
  302. package/src/components/EditorToolbar/util.ts +0 -76
  303. package/src/components/Popover/CommandMenu.tsx +0 -279
  304. package/src/components/Popover/RefDropdownMenu.tsx +0 -89
  305. package/src/components/Popover/RefPopover.tsx +0 -117
  306. package/src/components/Popover/index.ts +0 -7
  307. package/src/extensions/command/action.ts +0 -56
  308. package/src/extensions/command/command-menu.ts +0 -211
  309. package/src/extensions/command/command.ts +0 -34
  310. package/src/extensions/command/hint.ts +0 -103
  311. package/src/extensions/command/index.ts +0 -10
  312. package/src/extensions/command/state.ts +0 -90
  313. package/src/extensions/command/useCommandMenu.ts +0 -119
  314. package/src/stories/CommandMenu.stories.tsx +0 -160
  315. package/src/testing/index.ts +0 -5
  316. package/src/testing/util.ts +0 -7
  317. package/src/util/domino.ts +0 -51
@@ -1,119 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type EditorView } from '@codemirror/view';
6
- import { type RefObject, useCallback, useMemo, useRef, useState } from 'react';
7
-
8
- import { type DxAnchor, type DxAnchorActivate } from '@dxos/lit-ui';
9
- import { type MaybePromise } from '@dxos/util';
10
-
11
- import { type CommandMenuGroup, type CommandMenuItem, getItem, getNextItem, getPreviousItem } from '../../components';
12
-
13
- import { commandMenu, commandRangeEffect } from './command-menu';
14
- import { type PlaceholderOptions } from './placeholder';
15
-
16
- export type UseCommandMenuOptions = {
17
- viewRef: RefObject<EditorView | undefined>;
18
- trigger: string | string[];
19
- placeholder?: Partial<PlaceholderOptions>;
20
- getMenu: (trigger: string, query?: string) => MaybePromise<CommandMenuGroup[]>;
21
- };
22
-
23
- export const useCommandMenu = ({ viewRef, trigger, placeholder, getMenu }: UseCommandMenuOptions) => {
24
- const triggerRef = useRef<DxAnchor | null>(null);
25
- const currentRef = useRef<CommandMenuItem | null>(null);
26
- const groupsRef = useRef<CommandMenuGroup[]>([]);
27
- const [currentItem, setCurrentItem] = useState<string>();
28
- const [open, setOpen] = useState(false);
29
- const [_, refresh] = useState({});
30
-
31
- const handleOpenChange = useCallback(
32
- async (open: boolean, trigger?: string) => {
33
- if (open && trigger) {
34
- groupsRef.current = await getMenu(trigger);
35
- }
36
- setOpen(open);
37
- if (!open) {
38
- triggerRef.current = null;
39
- setCurrentItem(undefined);
40
- viewRef.current?.dispatch({ effects: [commandRangeEffect.of(null)] });
41
- }
42
- },
43
- [getMenu],
44
- );
45
-
46
- const handleActivate = useCallback(
47
- async (event: DxAnchorActivate) => {
48
- const item = getItem(groupsRef.current, currentItem);
49
- if (item) {
50
- currentRef.current = item;
51
- }
52
-
53
- triggerRef.current = event.trigger;
54
- const triggerKey = event.trigger.getAttribute('data-trigger');
55
- if (!open && triggerKey) {
56
- await handleOpenChange(true, triggerKey);
57
- }
58
- },
59
- [open, handleOpenChange],
60
- );
61
-
62
- const handleSelect = useCallback((item: CommandMenuItem) => {
63
- const view = viewRef.current;
64
- if (!view) {
65
- return;
66
- }
67
-
68
- const selection = view.state.selection.main;
69
- void item.onSelect?.(view, selection.head);
70
- }, []);
71
-
72
- const serializedTrigger = Array.isArray(trigger) ? trigger.join(',') : trigger;
73
- const _commandMenu = useMemo(() => {
74
- return commandMenu({
75
- trigger,
76
- placeholder,
77
- onClose: () => handleOpenChange(false),
78
- onArrowDown: () => {
79
- setCurrentItem((currentItem) => {
80
- const next = getNextItem(groupsRef.current, currentItem);
81
- currentRef.current = next;
82
- return next.id;
83
- });
84
- },
85
- onArrowUp: () => {
86
- setCurrentItem((currentItem) => {
87
- const previous = getPreviousItem(groupsRef.current, currentItem);
88
- currentRef.current = previous;
89
- return previous.id;
90
- });
91
- },
92
- onEnter: () => {
93
- if (currentRef.current) {
94
- handleSelect(currentRef.current);
95
- }
96
- },
97
- onTextChange: async (trigger, text) => {
98
- groupsRef.current = await getMenu(trigger, text);
99
- const firstItem = groupsRef.current.filter((group) => group.items.length > 0)[0]?.items[0];
100
- if (firstItem) {
101
- setCurrentItem(firstItem.id);
102
- currentRef.current = firstItem;
103
- }
104
- refresh({});
105
- },
106
- });
107
- }, [handleOpenChange, getMenu, serializedTrigger, placeholder]);
108
-
109
- return {
110
- commandMenu: _commandMenu,
111
- currentItem,
112
- groupsRef,
113
- ref: triggerRef,
114
- open,
115
- onActivate: handleActivate,
116
- onOpenChange: setOpen,
117
- onSelect: handleSelect,
118
- };
119
- };
@@ -1,160 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- import '@dxos-theme';
6
-
7
- import { type EditorView } from '@codemirror/view';
8
- import { type Meta, type StoryObj } from '@storybook/react-vite';
9
- import React, { useCallback, useRef } from 'react';
10
-
11
- import { Obj, Query } from '@dxos/echo';
12
- import { faker } from '@dxos/random';
13
- import { useClientProvider, withClientProvider } from '@dxos/react-client/testing';
14
- import { Testing, type ValueGenerator, createObjectFactory } from '@dxos/schema/testing';
15
- import { withLayout, withTheme } from '@dxos/storybook-utils';
16
-
17
- import {
18
- CommandMenu,
19
- type CommandMenuGroup,
20
- type CommandMenuItem,
21
- RefPopover,
22
- coreSlashCommands,
23
- filterItems,
24
- insertAtCursor,
25
- insertAtLineStart,
26
- linkSlashCommands,
27
- } from '../components';
28
- import { type UseCommandMenuOptions, useCommandMenu } from '../extensions';
29
- import { str } from '../testing';
30
- import { Domino } from '../util';
31
-
32
- import { EditorStory, names } from './components';
33
-
34
- const generator: ValueGenerator = faker as any;
35
-
36
- type StoryProps = Omit<UseCommandMenuOptions, 'viewRef'> & { text: string };
37
-
38
- const DefaultStory = ({ text, ...options }: StoryProps) => {
39
- const viewRef = useRef<EditorView>();
40
- const { commandMenu, groupsRef, currentItem, onSelect, ...props } = useCommandMenu({ viewRef, ...options });
41
-
42
- return (
43
- <RefPopover modal={false} {...props}>
44
- <EditorStory ref={viewRef} text={text} placeholder={''} extensions={commandMenu} />
45
- <CommandMenu groups={groupsRef.current} currentItem={currentItem} onSelect={onSelect} />
46
- </RefPopover>
47
- );
48
- };
49
-
50
- const groups: CommandMenuGroup[] = [
51
- coreSlashCommands,
52
- linkSlashCommands,
53
- {
54
- id: 'custom',
55
- label: 'Custom',
56
- items: [
57
- {
58
- id: 'custom-1',
59
- label: 'Log',
60
- icon: 'ph--log--regular',
61
- onSelect: console.log,
62
- },
63
- ],
64
- },
65
- ];
66
-
67
- const meta = {
68
- title: 'ui/react-ui-editor/CommandMenu',
69
- render: DefaultStory,
70
- decorators: [withTheme, withLayout({ fullscreen: true })],
71
- parameters: {
72
- layout: 'fullscreen',
73
- },
74
- } satisfies Meta<typeof DefaultStory>;
75
-
76
- export default meta;
77
-
78
- type Story = StoryObj<typeof meta>;
79
-
80
- // TODO(burdon): Not working.
81
- export const Slash: Story = {
82
- args: {
83
- text: str('# Slash', '', names.join(' '), ''),
84
- trigger: '/',
85
- placeholder: {
86
- content: () =>
87
- Domino.of('div')
88
- .child(Domino.of('span').text('Press'))
89
- .child(Domino.of('span').text('/').classNames('border border-separator rounded-sm mx-1 px-1'))
90
- .child(Domino.of('span').text('for commands'))
91
- .build(),
92
- },
93
- getMenu: (text) => {
94
- return filterItems(groups, (item) =>
95
- text ? (item.label as string).toLowerCase().includes(text.toLowerCase()) : true,
96
- );
97
- },
98
- },
99
- };
100
-
101
- export const Link: Story = {
102
- render: (args: StoryProps) => {
103
- const { space } = useClientProvider();
104
- const getMenu = useCallback(
105
- async (trigger: string, query?: string): Promise<CommandMenuGroup[]> => {
106
- if (trigger === '/') {
107
- return filterItems(groups, (item) =>
108
- query ? (item.label as string).toLowerCase().includes(query.toLowerCase()) : true,
109
- );
110
- }
111
-
112
- if (!space) {
113
- return [];
114
- }
115
-
116
- const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');
117
- const result = await space?.db.query(Query.type(Testing.Contact)).run();
118
- const items = result.objects
119
- .filter((object) => object.name.toLowerCase().includes(name))
120
- .map(
121
- (object): CommandMenuItem => ({
122
- id: object.id,
123
- label: object.name,
124
- icon: 'ph--user--regular',
125
- onSelect: (view, head) => {
126
- const link = `[${object.name}][${Obj.getDXN(object)}]`;
127
- if (query?.startsWith('@')) {
128
- insertAtLineStart(view, head, `!${link}\n`);
129
- } else {
130
- insertAtCursor(view, head, `${link} `);
131
- }
132
- },
133
- }),
134
- );
135
- return [{ id: 'echo', items }];
136
- },
137
- [space],
138
- );
139
-
140
- return <DefaultStory {...args} getMenu={getMenu} />;
141
- },
142
- decorators: [
143
- withClientProvider({
144
- createSpace: true,
145
- onInitialized: async (client) => {
146
- client.addTypes([Testing.Contact]);
147
- },
148
- onSpaceCreated: async ({ space }) => {
149
- const createObjects = createObjectFactory(space.db, generator);
150
- await createObjects([{ type: Testing.Contact, count: 10 }]);
151
- await space.db.flush({ indexes: true });
152
- },
153
- }),
154
- ],
155
- args: {
156
- text: str('# Link', '', names.join(' '), ''),
157
- trigger: ['/', '@'],
158
- getMenu: () => [],
159
- },
160
- };
@@ -1,5 +0,0 @@
1
- //
2
- // Copyright 2022 DXOS.org
3
- //
4
-
5
- export * from './util';
@@ -1,7 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- /** deprecated Replace with @dxos/util trim */
6
- // TODO(burdon): Remove
7
- export const str = (...lines: string[]) => lines.join('\n');
@@ -1,51 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { mx } from '@dxos/react-ui-theme';
6
- import { type ClassNameValue } from '@dxos/react-ui-types';
7
-
8
- /**
9
- * Super lightweight chainable DOM builder.
10
- */
11
- export class Domino<T extends HTMLElement> {
12
- static of<K extends keyof HTMLElementTagNameMap>(tag: K): Domino<HTMLElementTagNameMap[K]> {
13
- return new Domino<HTMLElementTagNameMap[K]>(tag);
14
- }
15
-
16
- private readonly _el: T;
17
- constructor(tag: keyof HTMLElementTagNameMap) {
18
- this._el = document.createElement(tag) as T;
19
- }
20
- classNames(...classNames: ClassNameValue[]): this {
21
- this._el.className = mx(classNames);
22
- return this;
23
- }
24
- text(value: string): this {
25
- this._el.textContent = value;
26
- return this;
27
- }
28
- data(key: string, value: string): this {
29
- this._el.dataset[key] = value;
30
- return this;
31
- }
32
- style(styles: Partial<CSSStyleDeclaration>): this {
33
- Object.assign(this._el.style, styles);
34
- return this;
35
- }
36
- attr<K extends keyof T>(key: K, value: T[K]): this {
37
- (this._el as any)[key] = value;
38
- return this;
39
- }
40
- child<C extends HTMLElement>(...children: Domino<C>[]): this {
41
- children.forEach((child) => this._el.appendChild(child.build()));
42
- return this;
43
- }
44
- on(event: string, handler: (e: Event) => void): this {
45
- this._el.addEventListener(event, handler);
46
- return this;
47
- }
48
- build(): T {
49
- return this._el;
50
- }
51
- }