@dxos/react-ui-editor 0.8.4-main.84f28bd → 0.8.4-main.ae835ea

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 (321) 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 +4225 -3369
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +71 -1
  7. package/dist/lib/browser/testing/index.mjs.map +4 -4
  8. package/dist/lib/browser/types/index.mjs +1 -1
  9. package/dist/lib/node-esm/{chunk-YXYQPV6R.mjs → chunk-YJZGD3LY.mjs} +2 -2
  10. package/dist/lib/node-esm/chunk-YJZGD3LY.mjs.map +7 -0
  11. package/dist/lib/node-esm/index.mjs +4225 -3369
  12. package/dist/lib/node-esm/index.mjs.map +4 -4
  13. package/dist/lib/node-esm/meta.json +1 -1
  14. package/dist/lib/node-esm/testing/index.mjs +71 -1
  15. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  16. package/dist/lib/node-esm/types/index.mjs +1 -1
  17. package/dist/types/src/components/Editor/Editor.d.ts +24 -9
  18. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  19. package/dist/types/src/components/Editor/Editor.stories.d.ts +27 -0
  20. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +17 -2
  22. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  23. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  24. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  25. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  26. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  27. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +1 -1
  28. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  29. package/dist/types/src/components/EditorToolbar/util.d.ts +6 -20
  30. package/dist/types/src/components/EditorToolbar/util.d.ts.map +1 -1
  31. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +1 -1
  32. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  33. package/dist/types/src/components/index.d.ts +0 -1
  34. package/dist/types/src/components/index.d.ts.map +1 -1
  35. package/dist/types/src/defaults.d.ts.map +1 -1
  36. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +26 -0
  37. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +1 -0
  38. package/dist/types/src/extensions/autocomplete/index.d.ts +5 -0
  39. package/dist/types/src/extensions/autocomplete/index.d.ts.map +1 -0
  40. package/dist/types/src/extensions/autocomplete/match.d.ts +13 -0
  41. package/dist/types/src/extensions/autocomplete/match.d.ts.map +1 -0
  42. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +20 -0
  43. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +1 -0
  44. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +10 -0
  45. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +1 -0
  46. package/dist/types/src/extensions/automerge/automerge.d.ts +1 -1
  47. package/dist/types/src/extensions/automerge/automerge.d.ts.map +1 -1
  48. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +10 -19
  49. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +1 -1
  50. package/dist/types/src/extensions/automerge/cursor.d.ts +1 -1
  51. package/dist/types/src/extensions/automerge/cursor.d.ts.map +1 -1
  52. package/dist/types/src/extensions/automerge/defs.d.ts +1 -1
  53. package/dist/types/src/extensions/automerge/defs.d.ts.map +1 -1
  54. package/dist/types/src/extensions/automerge/sync.d.ts +3 -3
  55. package/dist/types/src/extensions/automerge/sync.d.ts.map +1 -1
  56. package/dist/types/src/extensions/automerge/update-automerge.d.ts +1 -1
  57. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +1 -1
  58. package/dist/types/src/extensions/autoscroll.d.ts +10 -0
  59. package/dist/types/src/extensions/autoscroll.d.ts.map +1 -0
  60. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +1 -1
  61. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +1 -1
  62. package/dist/types/src/extensions/comments.d.ts +1 -1
  63. package/dist/types/src/extensions/comments.d.ts.map +1 -1
  64. package/dist/types/src/extensions/dnd.d.ts.map +1 -1
  65. package/dist/types/src/extensions/factories.d.ts +20 -19
  66. package/dist/types/src/extensions/factories.d.ts.map +1 -1
  67. package/dist/types/src/extensions/focus.d.ts.map +1 -1
  68. package/dist/types/src/extensions/folding.d.ts.map +1 -1
  69. package/dist/types/src/extensions/index.d.ts +4 -1
  70. package/dist/types/src/extensions/index.d.ts.map +1 -1
  71. package/dist/types/src/extensions/json.d.ts +1 -1
  72. package/dist/types/src/extensions/json.d.ts.map +1 -1
  73. package/dist/types/src/extensions/listener.d.ts +8 -6
  74. package/dist/types/src/extensions/listener.d.ts.map +1 -1
  75. package/dist/types/src/extensions/markdown/action.d.ts.map +1 -1
  76. package/dist/types/src/extensions/markdown/bundle.d.ts +8 -2
  77. package/dist/types/src/extensions/markdown/bundle.d.ts.map +1 -1
  78. package/dist/types/src/extensions/markdown/changes.d.ts +1 -1
  79. package/dist/types/src/extensions/markdown/changes.d.ts.map +1 -1
  80. package/dist/types/src/extensions/markdown/decorate.d.ts +9 -1
  81. package/dist/types/src/extensions/markdown/decorate.d.ts.map +1 -1
  82. package/dist/types/src/extensions/markdown/formatting.d.ts +2 -3
  83. package/dist/types/src/extensions/markdown/formatting.d.ts.map +1 -1
  84. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +1 -1
  85. package/dist/types/src/extensions/markdown/highlight.d.ts.map +1 -1
  86. package/dist/types/src/extensions/markdown/image.d.ts.map +1 -1
  87. package/dist/types/src/extensions/markdown/link.d.ts.map +1 -1
  88. package/dist/types/src/extensions/modes.d.ts +1 -1
  89. package/dist/types/src/extensions/modes.d.ts.map +1 -1
  90. package/dist/types/src/extensions/outliner/menu.d.ts +8 -0
  91. package/dist/types/src/extensions/outliner/menu.d.ts.map +1 -0
  92. package/dist/types/src/extensions/outliner/outliner.d.ts +1 -1
  93. package/dist/types/src/extensions/outliner/outliner.d.ts.map +1 -1
  94. package/dist/types/src/extensions/outliner/selection.d.ts.map +1 -1
  95. package/dist/types/src/extensions/outliner/tree.d.ts +2 -2
  96. package/dist/types/src/extensions/outliner/tree.d.ts.map +1 -1
  97. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts +36 -0
  98. package/dist/types/src/extensions/popover/PopoverMenuProvider.d.ts.map +1 -0
  99. package/dist/types/src/extensions/popover/index.d.ts +8 -0
  100. package/dist/types/src/extensions/popover/index.d.ts.map +1 -0
  101. package/dist/types/src/extensions/popover/menu-presets.d.ts +4 -0
  102. package/dist/types/src/extensions/popover/menu-presets.d.ts.map +1 -0
  103. package/dist/types/src/extensions/popover/menu.d.ts +24 -0
  104. package/dist/types/src/extensions/popover/menu.d.ts.map +1 -0
  105. package/dist/types/src/extensions/popover/modal.d.ts +7 -0
  106. package/dist/types/src/extensions/popover/modal.d.ts.map +1 -0
  107. package/dist/types/src/extensions/popover/popover.d.ts +47 -0
  108. package/dist/types/src/extensions/popover/popover.d.ts.map +1 -0
  109. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts +34 -0
  110. package/dist/types/src/extensions/popover/usePopoverMenu.d.ts.map +1 -0
  111. package/dist/types/src/extensions/popover/util.d.ts +8 -0
  112. package/dist/types/src/extensions/popover/util.d.ts.map +1 -0
  113. package/dist/types/src/extensions/preview/preview.d.ts +8 -8
  114. package/dist/types/src/extensions/preview/preview.d.ts.map +1 -1
  115. package/dist/types/src/extensions/state.d.ts +2 -0
  116. package/dist/types/src/extensions/state.d.ts.map +1 -0
  117. package/dist/types/src/extensions/tags/extended-markdown.d.ts +10 -0
  118. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +1 -0
  119. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +2 -0
  120. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +1 -0
  121. package/dist/types/src/extensions/tags/index.d.ts +4 -0
  122. package/dist/types/src/extensions/tags/index.d.ts.map +1 -0
  123. package/dist/types/src/extensions/tags/streamer.d.ts +12 -0
  124. package/dist/types/src/extensions/tags/streamer.d.ts.map +1 -0
  125. package/dist/types/src/extensions/tags/xml-tags.d.ts +72 -0
  126. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +1 -0
  127. package/dist/types/src/extensions/tags/xml-util.d.ts +10 -0
  128. package/dist/types/src/extensions/tags/xml-util.d.ts.map +1 -0
  129. package/dist/types/src/hooks/useTextEditor.d.ts +4 -8
  130. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  131. package/dist/types/src/stories/CommandDialog.stories.d.ts +14 -0
  132. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  133. package/dist/types/src/stories/Comments.stories.d.ts +21 -10
  134. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  135. package/dist/types/src/stories/EditorToolbar.stories.d.ts +39 -3
  136. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  137. package/dist/types/src/stories/Experimental.stories.d.ts +22 -13
  138. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  139. package/dist/types/src/stories/Markdown.stories.d.ts +32 -43
  140. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  141. package/dist/types/src/stories/Outliner.stories.d.ts +15 -21
  142. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  143. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  144. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  145. package/dist/types/src/stories/Preview.stories.d.ts +21 -7
  146. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  147. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  148. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  149. package/dist/types/src/stories/TextEditor.stories.d.ts +37 -52
  150. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  151. package/dist/types/src/stories/components/EditorStory.d.ts +6 -9
  152. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  153. package/dist/types/src/styles/theme.d.ts.map +1 -1
  154. package/dist/types/src/testing/PreviewPopover.d.ts +20 -0
  155. package/dist/types/src/testing/PreviewPopover.d.ts.map +1 -0
  156. package/dist/types/src/testing/index.d.ts +1 -0
  157. package/dist/types/src/testing/index.d.ts.map +1 -1
  158. package/dist/types/src/testing/util.d.ts +1 -0
  159. package/dist/types/src/testing/util.d.ts.map +1 -1
  160. package/dist/types/src/translations.d.ts +1 -1
  161. package/dist/types/src/types/types.d.ts +2 -2
  162. package/dist/types/src/types/types.d.ts.map +1 -1
  163. package/dist/types/src/util/cursor.d.ts.map +1 -1
  164. package/dist/types/src/util/debug.d.ts +1 -1
  165. package/dist/types/src/util/debug.d.ts.map +1 -1
  166. package/dist/types/src/util/decorations.d.ts +4 -0
  167. package/dist/types/src/util/decorations.d.ts.map +1 -0
  168. package/dist/types/src/util/dom.d.ts +2 -12
  169. package/dist/types/src/util/dom.d.ts.map +1 -1
  170. package/dist/types/src/util/index.d.ts +1 -0
  171. package/dist/types/src/util/index.d.ts.map +1 -1
  172. package/dist/types/src/util/react.d.ts +1 -1
  173. package/dist/types/src/util/react.d.ts.map +1 -1
  174. package/dist/types/tsconfig.tsbuildinfo +1 -1
  175. package/package.json +71 -61
  176. package/src/components/Editor/Editor.stories.tsx +69 -0
  177. package/src/components/Editor/Editor.tsx +58 -15
  178. package/src/components/EditorToolbar/EditorToolbar.tsx +104 -93
  179. package/src/components/EditorToolbar/blocks.ts +22 -25
  180. package/src/components/EditorToolbar/formatting.ts +22 -25
  181. package/src/components/EditorToolbar/headings.ts +16 -9
  182. package/src/components/EditorToolbar/image.ts +8 -4
  183. package/src/components/EditorToolbar/lists.ts +16 -19
  184. package/src/components/EditorToolbar/search.ts +8 -4
  185. package/src/components/EditorToolbar/util.ts +18 -23
  186. package/src/components/EditorToolbar/view-mode.ts +11 -6
  187. package/src/components/index.ts +0 -1
  188. package/src/defaults.ts +5 -2
  189. package/src/extensions/autocomplete/autocomplete.ts +220 -0
  190. package/src/extensions/autocomplete/index.ts +8 -0
  191. package/src/extensions/autocomplete/match.ts +46 -0
  192. package/src/extensions/{command → autocomplete}/placeholder.ts +22 -18
  193. package/src/extensions/{command → autocomplete}/typeahead.ts +8 -50
  194. package/src/extensions/automerge/automerge.stories.tsx +31 -24
  195. package/src/extensions/automerge/automerge.ts +31 -11
  196. package/src/extensions/automerge/cursor.ts +1 -1
  197. package/src/extensions/automerge/defs.ts +1 -1
  198. package/src/extensions/automerge/sync.ts +9 -5
  199. package/src/extensions/automerge/update-automerge.ts +2 -2
  200. package/src/extensions/autoscroll.ts +157 -0
  201. package/src/extensions/awareness/awareness-provider.ts +2 -2
  202. package/src/extensions/awareness/awareness.ts +2 -2
  203. package/src/extensions/comments.ts +18 -13
  204. package/src/extensions/dnd.ts +1 -1
  205. package/src/extensions/factories.ts +55 -37
  206. package/src/extensions/focus.ts +5 -4
  207. package/src/extensions/folding.tsx +4 -6
  208. package/src/extensions/hashtag.tsx +2 -2
  209. package/src/extensions/index.ts +4 -1
  210. package/src/extensions/json.ts +1 -1
  211. package/src/extensions/listener.ts +14 -20
  212. package/src/extensions/markdown/action.ts +2 -1
  213. package/src/extensions/markdown/bundle.ts +40 -6
  214. package/src/extensions/markdown/changes.ts +1 -1
  215. package/src/extensions/markdown/decorate.ts +24 -14
  216. package/src/extensions/markdown/formatting.test.ts +6 -6
  217. package/src/extensions/markdown/formatting.ts +11 -11
  218. package/src/extensions/markdown/highlight.ts +1 -1
  219. package/src/extensions/markdown/image.ts +3 -4
  220. package/src/extensions/markdown/link.ts +3 -0
  221. package/src/extensions/markdown/table.ts +7 -1
  222. package/src/extensions/mention.ts +1 -1
  223. package/src/extensions/modes.ts +2 -2
  224. package/src/extensions/{command/floating-menu.ts → outliner/menu.ts} +16 -21
  225. package/src/extensions/outliner/outliner.test.ts +3 -2
  226. package/src/extensions/outliner/outliner.ts +7 -6
  227. package/src/extensions/outliner/selection.ts +1 -1
  228. package/src/extensions/outliner/tree.test.ts +2 -1
  229. package/src/extensions/outliner/tree.ts +2 -2
  230. package/src/extensions/popover/PopoverMenuProvider.tsx +220 -0
  231. package/src/extensions/popover/index.ts +12 -0
  232. package/src/extensions/popover/menu-presets.ts +124 -0
  233. package/src/extensions/popover/menu.ts +67 -0
  234. package/src/extensions/popover/modal.ts +24 -0
  235. package/src/extensions/popover/popover.ts +289 -0
  236. package/src/extensions/popover/usePopoverMenu.ts +173 -0
  237. package/src/extensions/popover/util.ts +29 -0
  238. package/src/extensions/preview/index.ts +1 -1
  239. package/src/extensions/preview/preview.ts +67 -67
  240. package/src/extensions/selection.ts +2 -2
  241. package/src/extensions/state.ts +7 -0
  242. package/src/extensions/tags/extended-markdown.test.ts +261 -0
  243. package/src/extensions/tags/extended-markdown.ts +78 -0
  244. package/src/extensions/tags/index.ts +7 -0
  245. package/src/extensions/tags/streamer.ts +243 -0
  246. package/src/extensions/tags/xml-tags.ts +393 -0
  247. package/src/extensions/tags/xml-util.ts +94 -0
  248. package/src/hooks/useTextEditor.ts +27 -39
  249. package/src/stories/CommandDialog.stories.tsx +78 -0
  250. package/src/stories/Comments.stories.tsx +14 -10
  251. package/src/stories/EditorToolbar.stories.tsx +17 -17
  252. package/src/stories/Experimental.stories.tsx +17 -13
  253. package/src/stories/Markdown.stories.tsx +25 -21
  254. package/src/stories/Outliner.stories.tsx +54 -35
  255. package/src/stories/Popover.stories.tsx +163 -0
  256. package/src/stories/Preview.stories.tsx +49 -41
  257. package/src/stories/Tags.stories.tsx +81 -0
  258. package/src/stories/TextEditor.stories.tsx +41 -60
  259. package/src/stories/components/EditorStory.tsx +17 -16
  260. package/src/styles/theme.ts +18 -15
  261. package/src/testing/PreviewPopover.tsx +80 -0
  262. package/src/testing/index.ts +1 -0
  263. package/src/testing/util.ts +2 -0
  264. package/src/translations.ts +1 -1
  265. package/src/types/types.ts +1 -1
  266. package/src/util/cursor.ts +2 -1
  267. package/src/util/debug.ts +2 -2
  268. package/src/util/decorations.ts +21 -0
  269. package/src/util/dom.ts +5 -27
  270. package/src/util/index.ts +1 -0
  271. package/src/util/react.tsx +1 -1
  272. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  273. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  274. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  275. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  276. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  277. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  278. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  279. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  280. package/dist/types/src/components/Popover/index.d.ts +0 -4
  281. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  282. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  283. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  284. package/dist/types/src/extensions/command/action.d.ts +0 -17
  285. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  286. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  287. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  288. package/dist/types/src/extensions/command/command.d.ts +0 -6
  289. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  290. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  291. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  292. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  293. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  294. package/dist/types/src/extensions/command/index.d.ts +0 -7
  295. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  296. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  297. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  298. package/dist/types/src/extensions/command/state.d.ts +0 -16
  299. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  300. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  301. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  302. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  303. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  304. package/dist/types/src/stories/Command.stories.d.ts +0 -7
  305. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  306. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  307. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  308. package/src/components/Popover/CommandMenu.tsx +0 -279
  309. package/src/components/Popover/RefDropdownMenu.tsx +0 -85
  310. package/src/components/Popover/RefPopover.tsx +0 -99
  311. package/src/components/Popover/index.ts +0 -7
  312. package/src/extensions/autocomplete.ts +0 -69
  313. package/src/extensions/command/action.ts +0 -56
  314. package/src/extensions/command/command-menu.ts +0 -210
  315. package/src/extensions/command/command.ts +0 -34
  316. package/src/extensions/command/hint.ts +0 -102
  317. package/src/extensions/command/index.ts +0 -10
  318. package/src/extensions/command/state.ts +0 -89
  319. package/src/extensions/command/useCommandMenu.ts +0 -118
  320. package/src/stories/Command.stories.tsx +0 -97
  321. package/src/stories/CommandMenu.stories.tsx +0 -159
@@ -1,159 +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 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 { createObjectFactory, Testing, type ValueGenerator } from '@dxos/schema/testing';
15
- import { withLayout, withTheme, type Meta } from '@dxos/storybook-utils';
16
-
17
- import { EditorStory, names } from './components';
18
- import {
19
- CommandMenu,
20
- type CommandMenuGroup,
21
- type CommandMenuItem,
22
- RefPopover,
23
- coreSlashCommands,
24
- filterItems,
25
- insertAtCursor,
26
- insertAtLineStart,
27
- linkSlashCommands,
28
- } from '../components';
29
- import { useCommandMenu, type UseCommandMenuOptions } from '../extensions';
30
- import { str } from '../testing';
31
- import { createElement } from '../util';
32
-
33
- const generator: ValueGenerator = faker as any;
34
-
35
- type StoryProps = Omit<UseCommandMenuOptions, 'viewRef'> & { text: string };
36
-
37
- const DefaultStory = ({ text, ...options }: StoryProps) => {
38
- const viewRef = useRef<EditorView>();
39
- const { commandMenu, groupsRef, currentItem, onSelect, ...props } = useCommandMenu({ viewRef, ...options });
40
-
41
- return (
42
- <RefPopover modal={false} {...props}>
43
- <EditorStory ref={viewRef} text={text} placeholder={''} extensions={commandMenu} />
44
- <CommandMenu groups={groupsRef.current} currentItem={currentItem} onSelect={onSelect} />
45
- </RefPopover>
46
- );
47
- };
48
-
49
- const groups: CommandMenuGroup[] = [
50
- coreSlashCommands,
51
- linkSlashCommands,
52
- {
53
- id: 'custom',
54
- label: 'Custom',
55
- items: [
56
- {
57
- id: 'custom-1',
58
- label: 'Log',
59
- icon: 'ph--log--regular',
60
- onSelect: console.log,
61
- },
62
- ],
63
- },
64
- ];
65
-
66
- const meta: Meta<StoryProps> = {
67
- title: 'ui/react-ui-editor/CommandMenu',
68
- decorators: [withTheme, withLayout({ fullscreen: true })],
69
- render: (args) => <DefaultStory {...args} />,
70
- parameters: {
71
- layout: 'fullscreen',
72
- },
73
- };
74
-
75
- export default meta;
76
-
77
- type Story = StoryObj<StoryProps>;
78
-
79
- // TODO(burdon): Not working.
80
- export const Slash: Story = {
81
- args: {
82
- text: str('# Slash', '', names.join(' '), ''),
83
- trigger: '/',
84
- placeholder: {
85
- content: () => {
86
- return createElement('div', undefined, [
87
- createElement('span', { text: 'Press' }),
88
- createElement('span', { className: 'border border-separator rounded-sm mx-1 px-1', text: '/' }),
89
- createElement('span', { text: 'for commands' }),
90
- ]);
91
- },
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) => {
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
- args: {
143
- text: str('# Link', '', names.join(' '), ''),
144
- trigger: ['/', '@'],
145
- },
146
- decorators: [
147
- withClientProvider({
148
- createSpace: true,
149
- onInitialized: async (client) => {
150
- client.addTypes([Testing.Contact]);
151
- },
152
- onSpaceCreated: async ({ space }) => {
153
- const createObjects = createObjectFactory(space.db, generator);
154
- await createObjects([{ type: Testing.Contact, count: 10 }]);
155
- await space.db.flush({ indexes: true });
156
- },
157
- }),
158
- ],
159
- };