@dxos/react-ui-editor 0.8.4-main.3a94e84 → 0.8.4-main.3c1ae3b

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 (378) 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 +4541 -2844
  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 +4541 -2844
  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/image.d.ts.map +1 -1
  54. package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
  55. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  56. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  57. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
  58. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
  59. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +3 -3
  60. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  61. package/dist/types/src/components/index.d.ts +4 -2
  62. package/dist/types/src/components/index.d.ts.map +1 -1
  63. package/dist/types/src/defaults.d.ts +0 -2
  64. package/dist/types/src/defaults.d.ts.map +1 -1
  65. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts +17 -0
  66. package/dist/types/src/extensions/autocomplete/autocomplete.d.ts.map +1 -0
  67. package/dist/types/src/extensions/autocomplete/index.d.ts +5 -0
  68. package/dist/types/src/extensions/autocomplete/index.d.ts.map +1 -0
  69. package/dist/types/src/extensions/autocomplete/match.d.ts +13 -0
  70. package/dist/types/src/extensions/autocomplete/match.d.ts.map +1 -0
  71. package/dist/types/src/extensions/autocomplete/placeholder.d.ts +20 -0
  72. package/dist/types/src/extensions/autocomplete/placeholder.d.ts.map +1 -0
  73. package/dist/types/src/extensions/autocomplete/typeahead.d.ts +10 -0
  74. package/dist/types/src/extensions/autocomplete/typeahead.d.ts.map +1 -0
  75. package/dist/types/src/extensions/automerge/automerge.d.ts +1 -1
  76. package/dist/types/src/extensions/automerge/automerge.d.ts.map +1 -1
  77. package/dist/types/src/extensions/automerge/automerge.stories.d.ts +10 -19
  78. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +1 -1
  79. package/dist/types/src/extensions/automerge/cursor.d.ts +1 -1
  80. package/dist/types/src/extensions/automerge/cursor.d.ts.map +1 -1
  81. package/dist/types/src/extensions/automerge/defs.d.ts +1 -1
  82. package/dist/types/src/extensions/automerge/defs.d.ts.map +1 -1
  83. package/dist/types/src/extensions/automerge/sync.d.ts +3 -3
  84. package/dist/types/src/extensions/automerge/sync.d.ts.map +1 -1
  85. package/dist/types/src/extensions/automerge/update-automerge.d.ts +1 -1
  86. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +1 -1
  87. package/dist/types/src/extensions/autoscroll.d.ts +20 -0
  88. package/dist/types/src/extensions/autoscroll.d.ts.map +1 -0
  89. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +4 -4
  90. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +1 -1
  91. package/dist/types/src/extensions/blocks.d.ts +2 -0
  92. package/dist/types/src/extensions/blocks.d.ts.map +1 -0
  93. package/dist/types/src/extensions/bookmarks.d.ts +12 -0
  94. package/dist/types/src/extensions/bookmarks.d.ts.map +1 -0
  95. package/dist/types/src/extensions/comments.d.ts +1 -1
  96. package/dist/types/src/extensions/comments.d.ts.map +1 -1
  97. package/dist/types/src/extensions/dnd.d.ts.map +1 -1
  98. package/dist/types/src/extensions/factories.d.ts +15 -16
  99. package/dist/types/src/extensions/factories.d.ts.map +1 -1
  100. package/dist/types/src/extensions/focus.d.ts.map +1 -1
  101. package/dist/types/src/extensions/folding.d.ts.map +1 -1
  102. package/dist/types/src/extensions/index.d.ts +10 -1
  103. package/dist/types/src/extensions/index.d.ts.map +1 -1
  104. package/dist/types/src/extensions/json.d.ts +1 -1
  105. package/dist/types/src/extensions/json.d.ts.map +1 -1
  106. package/dist/types/src/extensions/listener.d.ts +8 -6
  107. package/dist/types/src/extensions/listener.d.ts.map +1 -1
  108. package/dist/types/src/extensions/markdown/action.d.ts.map +1 -1
  109. package/dist/types/src/extensions/markdown/bundle.d.ts +8 -2
  110. package/dist/types/src/extensions/markdown/bundle.d.ts.map +1 -1
  111. package/dist/types/src/extensions/markdown/changes.d.ts +1 -1
  112. package/dist/types/src/extensions/markdown/changes.d.ts.map +1 -1
  113. package/dist/types/src/extensions/markdown/decorate.d.ts +9 -1
  114. package/dist/types/src/extensions/markdown/decorate.d.ts.map +1 -1
  115. package/dist/types/src/extensions/markdown/formatting.d.ts +2 -4
  116. package/dist/types/src/extensions/markdown/formatting.d.ts.map +1 -1
  117. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +1 -1
  118. package/dist/types/src/extensions/markdown/highlight.d.ts.map +1 -1
  119. package/dist/types/src/extensions/markdown/image.d.ts.map +1 -1
  120. package/dist/types/src/extensions/markdown/link.d.ts.map +1 -1
  121. package/dist/types/src/extensions/modal.d.ts +7 -0
  122. package/dist/types/src/extensions/modal.d.ts.map +1 -0
  123. package/dist/types/src/extensions/modes.d.ts +1 -1
  124. package/dist/types/src/extensions/modes.d.ts.map +1 -1
  125. package/dist/types/src/extensions/outliner/menu.d.ts +8 -0
  126. package/dist/types/src/extensions/outliner/menu.d.ts.map +1 -0
  127. package/dist/types/src/extensions/outliner/outliner.d.ts +1 -1
  128. package/dist/types/src/extensions/outliner/outliner.d.ts.map +1 -1
  129. package/dist/types/src/extensions/outliner/selection.d.ts.map +1 -1
  130. package/dist/types/src/extensions/outliner/tree.d.ts +2 -2
  131. package/dist/types/src/extensions/outliner/tree.d.ts.map +1 -1
  132. package/dist/types/src/extensions/preview/preview.d.ts +8 -8
  133. package/dist/types/src/extensions/preview/preview.d.ts.map +1 -1
  134. package/dist/types/src/extensions/replacer.d.ts +21 -0
  135. package/dist/types/src/extensions/replacer.d.ts.map +1 -0
  136. package/dist/types/src/extensions/replacer.test.d.ts +2 -0
  137. package/dist/types/src/extensions/replacer.test.d.ts.map +1 -0
  138. package/dist/types/src/extensions/scrolling.d.ts +78 -0
  139. package/dist/types/src/extensions/scrolling.d.ts.map +1 -0
  140. package/dist/types/src/extensions/state.d.ts +2 -0
  141. package/dist/types/src/extensions/state.d.ts.map +1 -0
  142. package/dist/types/src/extensions/submit.d.ts +10 -0
  143. package/dist/types/src/extensions/submit.d.ts.map +1 -0
  144. package/dist/types/src/extensions/tab.d.ts +4 -0
  145. package/dist/types/src/extensions/tab.d.ts.map +1 -0
  146. package/dist/types/src/extensions/tags/extended-markdown.d.ts +10 -0
  147. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +1 -0
  148. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +2 -0
  149. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +1 -0
  150. package/dist/types/src/extensions/tags/index.d.ts +4 -0
  151. package/dist/types/src/extensions/tags/index.d.ts.map +1 -0
  152. package/dist/types/src/extensions/tags/streamer.d.ts +12 -0
  153. package/dist/types/src/extensions/tags/streamer.d.ts.map +1 -0
  154. package/dist/types/src/extensions/tags/xml-tags.d.ts +97 -0
  155. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +1 -0
  156. package/dist/types/src/extensions/tags/xml-util.d.ts +10 -0
  157. package/dist/types/src/extensions/tags/xml-util.d.ts.map +1 -0
  158. package/dist/types/src/hooks/useTextEditor.d.ts +5 -9
  159. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  160. package/dist/types/src/stories/CommandDialog.stories.d.ts +14 -0
  161. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  162. package/dist/types/src/stories/Comments.stories.d.ts +22 -10
  163. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  164. package/dist/types/src/stories/EditorToolbar.stories.d.ts +39 -3
  165. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  166. package/dist/types/src/stories/Experimental.stories.d.ts +23 -13
  167. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  168. package/dist/types/src/stories/Markdown.stories.d.ts +33 -43
  169. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  170. package/dist/types/src/stories/Outliner.stories.d.ts +15 -21
  171. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  172. package/dist/types/src/stories/Popover.stories.d.ts +20 -0
  173. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  174. package/dist/types/src/stories/Preview.stories.d.ts +23 -7
  175. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  176. package/dist/types/src/stories/Tags.stories.d.ts +16 -0
  177. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -0
  178. package/dist/types/src/stories/TextEditor.stories.d.ts +38 -52
  179. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  180. package/dist/types/src/stories/components/EditorStory.d.ts +15 -12
  181. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  182. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  183. package/dist/types/src/styles/markdown.d.ts +1 -1
  184. package/dist/types/src/styles/markdown.d.ts.map +1 -1
  185. package/dist/types/src/styles/theme.d.ts +6 -3
  186. package/dist/types/src/styles/theme.d.ts.map +1 -1
  187. package/dist/types/src/translations.d.ts +1 -1
  188. package/dist/types/src/types/types.d.ts +2 -2
  189. package/dist/types/src/types/types.d.ts.map +1 -1
  190. package/dist/types/src/util/cursor.d.ts.map +1 -1
  191. package/dist/types/src/util/debug.d.ts +5 -1
  192. package/dist/types/src/util/debug.d.ts.map +1 -1
  193. package/dist/types/src/util/decorations.d.ts +4 -0
  194. package/dist/types/src/util/decorations.d.ts.map +1 -0
  195. package/dist/types/src/util/dom.d.ts +2 -12
  196. package/dist/types/src/util/dom.d.ts.map +1 -1
  197. package/dist/types/src/util/index.d.ts +1 -0
  198. package/dist/types/src/util/index.d.ts.map +1 -1
  199. package/dist/types/src/util/react.d.ts +1 -1
  200. package/dist/types/src/util/react.d.ts.map +1 -1
  201. package/dist/types/tsconfig.tsbuildinfo +1 -1
  202. package/package.json +74 -68
  203. package/src/components/Editor/Editor.stories.tsx +89 -0
  204. package/src/components/Editor/Editor.tsx +160 -25
  205. package/src/components/EditorContent/EditorContent.stories.tsx +70 -0
  206. package/src/components/EditorContent/EditorContent.tsx +70 -0
  207. package/src/components/EditorContent/controller.ts +50 -0
  208. package/src/components/EditorContent/index.ts +6 -0
  209. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +233 -0
  210. package/src/components/EditorMenuProvider/index.ts +11 -0
  211. package/src/components/EditorMenuProvider/menu-presets.ts +123 -0
  212. package/src/components/EditorMenuProvider/menu.ts +71 -0
  213. package/src/components/EditorMenuProvider/popover.ts +287 -0
  214. package/src/components/EditorMenuProvider/useEditorMenu.ts +175 -0
  215. package/src/components/EditorMenuProvider/util.ts +31 -0
  216. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +82 -0
  217. package/src/components/EditorPreviewProvider/index.ts +5 -0
  218. package/src/components/EditorToolbar/EditorToolbar.tsx +116 -96
  219. package/src/components/EditorToolbar/actions.ts +86 -0
  220. package/src/components/EditorToolbar/blocks.ts +22 -24
  221. package/src/components/EditorToolbar/formatting.ts +23 -25
  222. package/src/components/EditorToolbar/headings.ts +17 -9
  223. package/src/components/EditorToolbar/image.ts +9 -5
  224. package/src/components/EditorToolbar/index.ts +3 -7
  225. package/src/components/EditorToolbar/search.ts +9 -5
  226. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  227. package/src/components/EditorToolbar/view-mode.ts +12 -6
  228. package/src/components/index.ts +8 -2
  229. package/src/defaults.ts +2 -17
  230. package/src/extensions/autocomplete/autocomplete.ts +151 -0
  231. package/src/extensions/autocomplete/index.ts +8 -0
  232. package/src/extensions/autocomplete/match.ts +46 -0
  233. package/src/extensions/{command → autocomplete}/placeholder.ts +22 -18
  234. package/src/extensions/{command → autocomplete}/typeahead.ts +8 -50
  235. package/src/extensions/automerge/automerge.stories.tsx +34 -26
  236. package/src/extensions/automerge/automerge.ts +31 -11
  237. package/src/extensions/automerge/cursor.ts +1 -1
  238. package/src/extensions/automerge/defs.ts +1 -1
  239. package/src/extensions/automerge/sync.ts +9 -5
  240. package/src/extensions/automerge/update-automerge.ts +2 -2
  241. package/src/extensions/autoscroll.ts +163 -0
  242. package/src/extensions/awareness/awareness-provider.ts +12 -12
  243. package/src/extensions/awareness/awareness.ts +2 -2
  244. package/src/extensions/blocks.ts +131 -0
  245. package/src/extensions/bookmarks.ts +75 -0
  246. package/src/extensions/comments.ts +20 -14
  247. package/src/extensions/dnd.ts +1 -1
  248. package/src/extensions/factories.ts +64 -46
  249. package/src/extensions/focus.ts +5 -4
  250. package/src/extensions/folding.tsx +3 -6
  251. package/src/extensions/hashtag.tsx +2 -2
  252. package/src/extensions/index.ts +10 -1
  253. package/src/extensions/json.ts +1 -1
  254. package/src/extensions/listener.ts +14 -20
  255. package/src/extensions/markdown/action.ts +2 -1
  256. package/src/extensions/markdown/bundle.ts +40 -6
  257. package/src/extensions/markdown/changes.ts +1 -1
  258. package/src/extensions/markdown/decorate.ts +95 -64
  259. package/src/extensions/markdown/formatting.test.ts +6 -6
  260. package/src/extensions/markdown/formatting.ts +11 -13
  261. package/src/extensions/markdown/highlight.ts +13 -13
  262. package/src/extensions/markdown/image.ts +5 -6
  263. package/src/extensions/markdown/link.ts +3 -0
  264. package/src/extensions/markdown/table.ts +13 -7
  265. package/src/extensions/mention.ts +1 -1
  266. package/src/extensions/modal.ts +24 -0
  267. package/src/extensions/modes.ts +2 -2
  268. package/src/extensions/{command/floating-menu.ts → outliner/menu.ts} +16 -21
  269. package/src/extensions/outliner/outliner.test.ts +3 -2
  270. package/src/extensions/outliner/outliner.ts +8 -7
  271. package/src/extensions/outliner/selection.ts +1 -1
  272. package/src/extensions/outliner/tree.test.ts +3 -2
  273. package/src/extensions/outliner/tree.ts +2 -2
  274. package/src/extensions/preview/index.ts +1 -1
  275. package/src/extensions/preview/preview.ts +69 -69
  276. package/src/extensions/replacer.test.ts +75 -0
  277. package/src/extensions/replacer.ts +93 -0
  278. package/src/extensions/scrolling.ts +189 -0
  279. package/src/extensions/selection.ts +3 -3
  280. package/src/extensions/state.ts +7 -0
  281. package/src/extensions/submit.ts +62 -0
  282. package/src/extensions/tab.ts +29 -0
  283. package/src/extensions/tags/extended-markdown.test.ts +263 -0
  284. package/src/extensions/tags/extended-markdown.ts +78 -0
  285. package/src/extensions/tags/index.ts +7 -0
  286. package/src/extensions/tags/streamer.ts +243 -0
  287. package/src/extensions/tags/xml-tags.ts +500 -0
  288. package/src/extensions/tags/xml-util.ts +94 -0
  289. package/src/extensions/typewriter.ts +1 -1
  290. package/src/hooks/useTextEditor.ts +31 -43
  291. package/src/stories/CommandDialog.stories.tsx +83 -0
  292. package/src/stories/Comments.stories.tsx +17 -14
  293. package/src/stories/EditorToolbar.stories.tsx +21 -20
  294. package/src/stories/Experimental.stories.tsx +17 -13
  295. package/src/stories/Markdown.stories.tsx +26 -22
  296. package/src/stories/Outliner.stories.tsx +51 -39
  297. package/src/stories/Popover.stories.tsx +162 -0
  298. package/src/stories/Preview.stories.tsx +56 -51
  299. package/src/stories/Tags.stories.tsx +95 -0
  300. package/src/stories/TextEditor.stories.tsx +43 -67
  301. package/src/stories/components/EditorStory.tsx +40 -29
  302. package/src/stories/components/util.tsx +40 -8
  303. package/src/styles/markdown.ts +2 -2
  304. package/src/styles/theme.ts +229 -209
  305. package/src/translations.ts +1 -1
  306. package/src/types/types.ts +1 -1
  307. package/src/util/cursor.ts +2 -1
  308. package/src/util/debug.ts +7 -2
  309. package/src/util/decorations.ts +21 -0
  310. package/src/util/dom.ts +5 -27
  311. package/src/util/index.ts +1 -0
  312. package/src/util/react.tsx +1 -1
  313. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  314. package/dist/lib/browser/testing/index.mjs +0 -6
  315. package/dist/lib/browser/testing/index.mjs.map +0 -7
  316. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  317. package/dist/lib/node-esm/testing/index.mjs +0 -8
  318. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  319. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  320. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  321. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  322. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  323. package/dist/types/src/components/Popover/CommandMenu.d.ts +0 -34
  324. package/dist/types/src/components/Popover/CommandMenu.d.ts.map +0 -1
  325. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts +0 -21
  326. package/dist/types/src/components/Popover/RefDropdownMenu.d.ts.map +0 -1
  327. package/dist/types/src/components/Popover/RefPopover.d.ts +0 -34
  328. package/dist/types/src/components/Popover/RefPopover.d.ts.map +0 -1
  329. package/dist/types/src/components/Popover/index.d.ts +0 -4
  330. package/dist/types/src/components/Popover/index.d.ts.map +0 -1
  331. package/dist/types/src/extensions/autocomplete.d.ts +0 -13
  332. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  333. package/dist/types/src/extensions/command/action.d.ts +0 -17
  334. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  335. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  336. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  337. package/dist/types/src/extensions/command/command.d.ts +0 -6
  338. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  339. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  340. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  341. package/dist/types/src/extensions/command/hint.d.ts +0 -24
  342. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  343. package/dist/types/src/extensions/command/index.d.ts +0 -7
  344. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  345. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  346. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  347. package/dist/types/src/extensions/command/state.d.ts +0 -16
  348. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  349. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  350. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  351. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -26
  352. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  353. package/dist/types/src/stories/Command.stories.d.ts +0 -7
  354. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  355. package/dist/types/src/stories/CommandMenu.stories.d.ts +0 -13
  356. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  357. package/dist/types/src/testing/index.d.ts +0 -2
  358. package/dist/types/src/testing/index.d.ts.map +0 -1
  359. package/dist/types/src/testing/util.d.ts +0 -2
  360. package/dist/types/src/testing/util.d.ts.map +0 -1
  361. package/src/components/EditorToolbar/lists.ts +0 -59
  362. package/src/components/EditorToolbar/util.ts +0 -65
  363. package/src/components/Popover/CommandMenu.tsx +0 -279
  364. package/src/components/Popover/RefDropdownMenu.tsx +0 -85
  365. package/src/components/Popover/RefPopover.tsx +0 -99
  366. package/src/components/Popover/index.ts +0 -7
  367. package/src/extensions/autocomplete.ts +0 -69
  368. package/src/extensions/command/action.ts +0 -56
  369. package/src/extensions/command/command-menu.ts +0 -210
  370. package/src/extensions/command/command.ts +0 -34
  371. package/src/extensions/command/hint.ts +0 -102
  372. package/src/extensions/command/index.ts +0 -10
  373. package/src/extensions/command/state.ts +0 -89
  374. package/src/extensions/command/useCommandMenu.ts +0 -118
  375. package/src/stories/Command.stories.tsx +0 -97
  376. package/src/stories/CommandMenu.stories.tsx +0 -159
  377. package/src/testing/index.ts +0 -5
  378. package/src/testing/util.ts +0 -5
@@ -2,11 +2,14 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { type StyleSpec } from 'style-mod';
5
+ import { type Extension } from '@codemirror/state';
6
+ import { EditorView } from '@codemirror/view';
6
7
 
7
- import { fontBody } from './tokens';
8
+ import { fontBody, fontMono } from './tokens';
8
9
 
9
- export type ThemeStyles = Record<string, StyleSpec>;
10
+ export type ThemeOptions = {
11
+ monospace?: boolean;
12
+ };
10
13
 
11
14
  /**
12
15
  * Minimal styles.
@@ -42,224 +45,241 @@ export type ThemeStyles = Record<string, StyleSpec>;
42
45
  * NOTE: `light` and `dark` selectors are preprocessed by CodeMirror and can only be in the base theme.
43
46
  * NOTE: Use 'unset' to remove default CM style.
44
47
  */
45
- export const defaultTheme: ThemeStyles = {
46
- '&': {},
47
- '&.cm-focused': {
48
- outline: 'none',
49
- },
48
+ export const createBaseTheme = ({ monospace }: ThemeOptions = {}) =>
49
+ EditorView.baseTheme({
50
+ '&': {},
51
+ '&.cm-focused': {
52
+ outline: 'none',
53
+ },
50
54
 
51
- /**
52
- * Scroller
53
- */
54
- '.cm-scroller': {
55
- overflowY: 'auto',
56
- },
55
+ /**
56
+ * Scroller
57
+ */
58
+ '.cm-scroller': {
59
+ overflowY: 'auto',
60
+ },
57
61
 
58
- /**
59
- * Content
60
- * NOTE: Apply margins to content so that scrollbar is at the edge of the container.
61
- */
62
- '.cm-content': {
63
- padding: 'unset',
64
- fontFamily: fontBody,
65
- // NOTE: Base font size (otherwise defined by HTML tag, which might be different for storybook).
66
- fontSize: '16px',
67
- lineHeight: 1.5,
68
- color: 'unset',
69
- },
62
+ /**
63
+ * Content
64
+ * NOTE: Apply margins to content so that scrollbar is at the edge of the container.
65
+ */
66
+ '.cm-content': {
67
+ padding: 'unset',
68
+ lineHeight: '24px',
69
+ fontFamily: monospace ? fontMono : fontBody,
70
+ // NOTE: Base font size (otherwise defined by HTML tag, which might be different for storybook).
71
+ fontSize: '16px',
72
+ color: 'unset',
73
+ },
70
74
 
71
- /**
72
- * Gutters
73
- * NOTE: Gutters should have the same top margin as the content.
74
- */
75
- '.cm-gutters': {
76
- borderRight: 'none',
77
- background: 'transparent',
78
- },
79
- '.cm-gutter': {},
80
- '.cm-gutter.cm-lineNumbers': {
81
- paddingRight: '4px',
82
- borderRight: '1px solid var(--dx-subduedSeparator)',
83
- },
84
- '.cm-gutter.cm-lineNumbers .cm-gutterElement': {
85
- minWidth: '40px',
86
- },
87
- /**
88
- * Height is set to match the corresponding line (which may have wrapped).
89
- */
90
- '.cm-gutterElement': {
91
- fontSize: '12px',
92
- lineHeight: '24px',
93
- },
75
+ /**
76
+ * Gutters
77
+ * NOTE: Gutters should have the same top margin as the content.
78
+ */
79
+ '.cm-gutters': {
80
+ borderRight: 'none',
81
+ },
82
+ '.cm-gutter': {},
83
+ '.cm-gutter.cm-lineNumbers': {
84
+ paddingRight: '4px',
85
+ borderRight: '1px solid var(--dx-subduedSeparator)',
86
+ color: 'var(--dx-subduedText)',
87
+ },
88
+ '.cm-gutter.cm-lineNumbers .cm-gutterElement': {
89
+ minWidth: '40px',
90
+ },
91
+ /**
92
+ * Height is set to match the corresponding line (which may have wrapped).
93
+ */
94
+ '.cm-gutterElement': {
95
+ lineHeight: '24px',
96
+ fontSize: '12px',
97
+ },
94
98
 
95
- /**
96
- * Line.
97
- */
98
- '.cm-line': {
99
- paddingInline: 0,
100
- },
101
- '.cm-activeLine': {
102
- background: 'var(--dx-cmActiveLine)',
103
- },
99
+ /**
100
+ * Line.
101
+ */
102
+ '.cm-line': {
103
+ lineHeight: '24px',
104
+ paddingInline: 0,
105
+ },
106
+ '.cm-activeLine': {
107
+ background: 'var(--dx-cmActiveLine)',
108
+ },
104
109
 
105
- /**
106
- * Cursor (layer).
107
- */
108
- '.cm-cursor, .cm-dropCursor': {
109
- borderLeft: '2px solid var(--dx-cmCursor)',
110
- },
111
- '.cm-placeholder': {
112
- color: 'var(--dx-placeholder)',
113
- },
110
+ /**
111
+ * Cursor (layer).
112
+ */
113
+ '.cm-cursor, .cm-dropCursor': {
114
+ borderLeft: '2px solid var(--dx-cmCursor)',
115
+ },
116
+ '.cm-placeholder': {
117
+ fontFamily: fontBody,
118
+ color: 'var(--dx-placeholder)',
119
+ },
114
120
 
115
- /**
116
- * Selection (layer).
117
- */
118
- '.cm-selectionBackground': {
119
- background: 'var(--dx-cmSelection)',
120
- },
121
- '&.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground': {
122
- background: 'var(--dx-cmFocusedSelection)',
123
- },
121
+ /**
122
+ * Selection (layer).
123
+ */
124
+ '.cm-selectionBackground': {
125
+ background: 'var(--dx-cmSelection)',
126
+ },
127
+ '&.cm-focused > .cm-scroller > .cm-selectionLayer .cm-selectionBackground': {
128
+ background: 'var(--dx-cmFocusedSelection)',
129
+ },
124
130
 
125
- /**
126
- * Search.
127
- * NOTE: Matches comment.
128
- */
129
- '.cm-searchMatch': {
130
- margin: '0 -3px',
131
- padding: '3px',
132
- borderRadius: '3px',
133
- background: 'var(--dx-cmHighlightSurface)',
134
- color: 'var(--dx-cmHighlight)',
135
- },
136
- '.cm-searchMatch-selected': {
137
- textDecoration: 'underline',
138
- },
131
+ /**
132
+ * Search.
133
+ * NOTE: Matches comment.
134
+ */
135
+ '.cm-searchMatch': {
136
+ margin: '0 -3px',
137
+ padding: '3px',
138
+ borderRadius: '3px',
139
+ background: 'var(--dx-cmHighlightSurface)',
140
+ color: 'var(--dx-cmHighlight)',
141
+ },
142
+ '.cm-searchMatch-selected': {
143
+ textDecoration: 'underline',
144
+ },
139
145
 
140
- /**
141
- * Link.
142
- */
143
- '.cm-link': {
144
- textDecorationLine: 'underline',
145
- textDecorationThickness: '1px',
146
- textDecorationColor: 'var(--dx-separator)',
147
- textUnderlineOffset: '2px',
148
- borderRadius: '.125rem',
149
- },
150
- '.cm-link > span': {
151
- color: 'var(--dx-accentText)',
152
- },
146
+ /**
147
+ * Link.
148
+ */
149
+ '.cm-link': {
150
+ textDecorationLine: 'underline',
151
+ textDecorationThickness: '1px',
152
+ textDecorationColor: 'var(--dx-separator)',
153
+ textUnderlineOffset: '2px',
154
+ borderRadius: '.125rem',
155
+ },
156
+ '.cm-link > span': {
157
+ color: 'var(--dx-accentText)',
158
+ },
153
159
 
154
- /**
155
- * Tooltip.
156
- */
157
- '.cm-tooltip': {
158
- background: 'var(--dx-baseSurface)',
159
- },
160
- '.cm-tooltip-below': {},
160
+ /**
161
+ * Tooltip.
162
+ */
163
+ '.cm-tooltip': {
164
+ background: 'var(--dx-baseSurface)',
165
+ },
166
+ '.cm-tooltip-below': {},
161
167
 
162
- /**
163
- * Autocomplete.
164
- * https://github.com/codemirror/autocomplete/blob/main/src/completion.ts
165
- */
166
- '.cm-tooltip.cm-tooltip-autocomplete': {
167
- marginTop: '4px',
168
- marginLeft: '-3px',
169
- borderColor: 'var(--dx-separator)',
170
- borderTop: 'none',
171
- },
172
- '.cm-tooltip.cm-tooltip-autocomplete > ul': {
173
- maxHeight: '20em',
174
- },
175
- '.cm-tooltip.cm-tooltip-autocomplete > ul > li': {
176
- padding: '4px',
177
- },
178
- '.cm-tooltip.cm-tooltip-autocomplete > ul > li[aria-selected]': {
179
- background: 'var(--dx-hoverSurface)',
180
- },
181
- '.cm-tooltip.cm-tooltip-autocomplete > ul > completion-section': {
182
- paddingLeft: '4px !important',
183
- borderBottom: 'none !important',
184
- color: 'var(--dx-accentText)',
185
- },
168
+ /**
169
+ * Autocomplete.
170
+ * https://github.com/codemirror/autocomplete/blob/main/src/completion.ts
171
+ */
172
+ '.cm-tooltip.cm-tooltip-autocomplete': {
173
+ marginTop: '6px',
174
+ marginLeft: '-10px',
175
+ border: '2px solid var(--dx-separator)',
176
+ borderRadius: '4px',
177
+ },
178
+ '.cm-tooltip.cm-tooltip-autocomplete > ul': {
179
+ maxHeight: '20em',
180
+ },
181
+ '.cm-tooltip.cm-tooltip-autocomplete > ul > li': {
182
+ padding: '4px',
183
+ },
184
+ '.cm-tooltip.cm-tooltip-autocomplete > ul > li[aria-selected]': {
185
+ background: 'var(--dx-activeSurface)',
186
+ color: 'var(--dx-activeSurfaceText)',
187
+ },
188
+ '.cm-tooltip.cm-tooltip-autocomplete > ul > completion-section': {
189
+ paddingLeft: '4px !important',
190
+ color: 'var(--dx-hoverSurfaceText)',
191
+ },
186
192
 
187
- '.cm-completionInfo': {
188
- width: '360px !important',
189
- margin: '-10px 1px 0 1px',
190
- padding: '8px !important',
191
- borderColor: 'var(--dx-separator)',
192
- },
193
- '.cm-completionIcon': {
194
- display: 'none',
195
- },
196
- '.cm-completionLabel': {
197
- fontFamily: fontBody,
198
- },
199
- '.cm-completionMatchedText': {
200
- textDecoration: 'none !important',
201
- opacity: 0.5,
202
- },
193
+ /**
194
+ * Completion info.
195
+ */
196
+ '.cm-completionInfo': {
197
+ width: '360px !important',
198
+ margin: '-10px 1px 0 1px',
199
+ padding: '8px !important',
200
+ borderColor: 'var(--dx-separator)',
201
+ },
202
+ '.cm-completionIcon': {
203
+ display: 'none',
204
+ },
205
+ '.cm-completionLabel': {
206
+ fontFamily: fontBody,
207
+ color: 'var(--dx-description)',
208
+ padding: '0 4px',
209
+ },
210
+ '.cm-completionMatchedText': {
211
+ textDecoration: 'none !important',
212
+ color: 'var(--dx-baseText)',
213
+ },
203
214
 
204
- /**
205
- * Panels
206
- * https://github.com/codemirror/search/blob/main/src/search.ts#L745
207
- *
208
- * Find/replace panel.
209
- * <div class="cm-announced">...</div>
210
- * <div class="cm-scroller">...</div>
211
- * <div class="cm-panels cm-panels-bottom">
212
- * <div class="cm-search cm-panel">
213
- * <input class="cm-textfield" />
214
- * <button class="cm-button">...</button>
215
- * <label><input type="checkbox" />...</label>
216
- * </div>
217
- * </div
218
- */
219
- // TODO(burdon): Implement custom panel (with icon buttons).
220
- '.cm-panels': {},
221
- '.cm-panel': {
222
- fontFamily: fontBody,
223
- backgroundColor: 'var(--surface-bg)',
224
- },
225
- '.cm-panel input, .cm-panel button, .cm-panel label': {
226
- color: 'var(--dx-subdued)',
227
- fontFamily: fontBody,
228
- fontSize: '14px',
229
- all: 'unset',
230
- margin: '3px !important',
231
- padding: '2px 6px !important',
232
- outline: '1px solid transparent',
233
- },
234
- '.cm-panel input, .cm-panel button': {
235
- backgroundColor: 'var(--dx-input)',
236
- },
237
- '.cm-panel input:focus, .cm-panel button:focus': {
238
- outline: '1px solid var(--dx-neutralFocusIndicator)',
239
- },
240
- '.cm-panel label': {
241
- display: 'inline-flex',
242
- alignItems: 'center',
243
- cursor: 'pointer',
244
- },
245
- '.cm-panel input.cm-textfield': {},
246
- '.cm-panel input[type=checkbox]': {
247
- width: '8px',
248
- height: '8px',
249
- marginRight: '6px !important',
250
- padding: '2px !important',
251
- color: 'var(--dx-neutralFocusIndicator)',
252
- },
253
- '.cm-panel button': {
254
- '&:hover': {
255
- backgroundColor: 'var(--dx-accentSurfaceHover) !important',
215
+ /**
216
+ * Panels
217
+ * https://github.com/codemirror/search/blob/main/src/search.ts#L745
218
+ *
219
+ * Find/replace panel.
220
+ * <div class="cm-announced">...</div>
221
+ * <div class="cm-scroller">...</div>
222
+ * <div class="cm-panels cm-panels-bottom">
223
+ * <div class="cm-search cm-panel">
224
+ * <input class="cm-textfield" />
225
+ * <button class="cm-button">...</button>
226
+ * <label><input type="checkbox" />...</label>
227
+ * </div>
228
+ * </div
229
+ */
230
+ // TODO(burdon): Implement custom panel (with icon buttons).
231
+ '.cm-panels': {},
232
+ '.cm-panel': {
233
+ fontFamily: fontBody,
234
+ backgroundColor: 'var(--surface-bg)',
256
235
  },
257
- '&:active': {
258
- backgroundColor: 'var(--dx-accentSurfaceHover)',
236
+ '.cm-panel input, .cm-panel button, .cm-panel label': {
237
+ color: 'var(--dx-subdued)',
238
+ fontFamily: fontBody,
239
+ fontSize: '14px',
240
+ all: 'unset',
241
+ margin: '3px !important',
242
+ padding: '2px 6px !important',
243
+ outline: '1px solid transparent',
259
244
  },
245
+ '.cm-panel input, .cm-panel button': {
246
+ backgroundColor: 'var(--dx-inputSurface)',
247
+ },
248
+ '.cm-panel input:focus, .cm-panel button:focus': {
249
+ outline: '1px solid var(--dx-neutralFocusIndicator)',
250
+ },
251
+ '.cm-panel label': {
252
+ display: 'inline-flex',
253
+ alignItems: 'center',
254
+ cursor: 'pointer',
255
+ },
256
+ '.cm-panel input.cm-textfield': {},
257
+ '.cm-panel input[type=checkbox]': {
258
+ width: '8px',
259
+ height: '8px',
260
+ marginRight: '6px !important',
261
+ padding: '2px !important',
262
+ color: 'var(--dx-neutralFocusIndicator)',
263
+ },
264
+ '.cm-panel button': {
265
+ '&:hover': {
266
+ backgroundColor: 'var(--dx-accentSurfaceHover) !important',
267
+ },
268
+ '&:active': {
269
+ backgroundColor: 'var(--dx-accentSurfaceHover)',
270
+ },
271
+ },
272
+ '.cm-panel.cm-search': {
273
+ padding: '4px',
274
+ borderTop: '1px solid var(--dx-separator)',
275
+ },
276
+ });
277
+
278
+ export const editorGutter: Extension = EditorView.theme({
279
+ '.cm-gutters': {
280
+ // NOTE: Color required to cover content if scrolling horizontally.
281
+ // TODO(burdon): Non-transparent background clips the focus ring.
282
+ background: 'var(--dx-baseSurface) !important',
283
+ paddingRight: '1rem',
260
284
  },
261
- '.cm-panel.cm-search': {
262
- padding: '4px',
263
- borderTop: '1px solid var(--dx-separator)',
264
- },
265
- };
285
+ });
@@ -24,8 +24,8 @@ export const translations = [
24
24
  'selection overlaps existing comment label': 'Selection overlaps existing comment',
25
25
  'select text to comment label': 'Select text to comment',
26
26
  'image label': 'Insert image',
27
- 'heading label': 'Heading level',
28
27
  'table label': 'Create table',
28
+ 'heading label': 'Heading level',
29
29
  'heading level label_zero': 'Paragraph',
30
30
  'heading level label_one': 'Heading level {{count}}',
31
31
  'heading level label_other': 'Heading level {{count}}',
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import { type EditorView } from '@codemirror/view';
6
- import { Schema } from 'effect';
6
+ import * as Schema from 'effect/Schema';
7
7
 
8
8
  // Runtime data structure.
9
9
  export type Range = {
@@ -4,9 +4,10 @@
4
4
 
5
5
  import { type EditorState } from '@codemirror/state';
6
6
 
7
- import { singleValueFacet } from './facet';
8
7
  import { type Range } from '../types';
9
8
 
9
+ import { singleValueFacet } from './facet';
10
+
10
11
  /**
11
12
  * Determines if two ranges overlap.
12
13
  * A range is considered to overlap if there is any intersection
package/src/util/debug.ts CHANGED
@@ -7,12 +7,17 @@ import { type EditorView } from '@codemirror/view';
7
7
 
8
8
  import { log } from '@dxos/log';
9
9
 
10
- export const wrapWithCatch = (fn: (...args: any[]) => any) => {
10
+ /**
11
+ * @deprecated Use `trim` from `@dxos/util`.
12
+ */
13
+ export const str = (...lines: string[]) => lines.join('\n');
14
+
15
+ export const wrapWithCatch = (fn: (...args: any[]) => any, label?: string) => {
11
16
  return (...args: any[]) => {
12
17
  try {
13
18
  return fn(...args);
14
19
  } catch (err) {
15
- log.catch(err);
20
+ log.catch(err, { label });
16
21
  }
17
22
  };
18
23
  };
@@ -0,0 +1,21 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Range } from '@codemirror/state';
6
+ import { type Decoration, type DecorationSet } from '@codemirror/view';
7
+
8
+ export const decorationSetToArray = (deco: DecorationSet): readonly Range<Decoration>[] => {
9
+ const ranges: Range<Decoration>[] = [];
10
+ const iter = deco.iter();
11
+ while (iter.value) {
12
+ ranges.push({
13
+ from: iter.from,
14
+ to: iter.to,
15
+ value: iter.value,
16
+ });
17
+ iter.next();
18
+ }
19
+
20
+ return ranges;
21
+ };
package/src/util/dom.ts CHANGED
@@ -2,30 +2,28 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
- // Copied from @codemirror/view
6
-
7
- export interface Rect {
5
+ export type Rect = {
8
6
  readonly left: number;
9
7
  readonly right: number;
10
8
  readonly top: number;
11
9
  readonly bottom: number;
12
- }
10
+ };
13
11
 
14
- export const flattenRect = (rect: Rect, left: boolean) => {
12
+ export const flattenRect = (rect: Rect, left: boolean): Rect => {
15
13
  const x = left ? rect.left : rect.right;
16
14
  return { left: x, right: x, top: rect.top, bottom: rect.bottom };
17
15
  };
18
16
 
19
17
  let scratchRange: Range | null;
20
18
 
21
- export const textRange = (node: Text, from: number, to = from) => {
19
+ export const textRange = (node: Text, from: number, to = from): Range => {
22
20
  const range = scratchRange || (scratchRange = document.createRange());
23
21
  range.setEnd(node, to);
24
22
  range.setStart(node, from);
25
23
  return range;
26
24
  };
27
25
 
28
- export const clientRectsFor = (dom: Node) => {
26
+ export const clientRectsFor = (dom: Node): DOMRectList => {
29
27
  if (dom.nodeType === 3) {
30
28
  return textRange(dom as Text, 0, dom.nodeValue!.length).getClientRects();
31
29
  } else if (dom.nodeType === 1) {
@@ -34,23 +32,3 @@ export const clientRectsFor = (dom: Node) => {
34
32
  return [] as any as DOMRectList;
35
33
  }
36
34
  };
37
-
38
- export type ElementOptions = {
39
- className?: string;
40
- text?: string;
41
- };
42
-
43
- export const createElement = (tag: string, options?: ElementOptions, children?: HTMLElement[]): HTMLElement => {
44
- const el = document.createElement(tag);
45
- if (options?.className) {
46
- el.className = options.className;
47
- }
48
- if (options?.text) {
49
- el.textContent = options.text;
50
- }
51
- if (children) {
52
- el.append(...(Array.isArray(children) ? children : [children]));
53
- }
54
-
55
- return el;
56
- };
package/src/util/index.ts CHANGED
@@ -3,6 +3,7 @@
3
3
  //
4
4
 
5
5
  export * from './cursor';
6
+ export * from './decorations';
6
7
  export * from './debug';
7
8
  export * from './dom';
8
9
  export * from './facet';
@@ -22,7 +22,7 @@ export const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {
22
22
  * @deprecated
23
23
  */
24
24
  export const createRenderer =
25
- <Props extends object>(Component: FC<Props>): RenderCallback<Props> =>
25
+ <TProps extends object>(Component: FC<TProps>): RenderCallback<TProps> =>
26
26
  (el, props) => {
27
27
  renderRoot(
28
28
  el,
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/types/types.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport { Schema } from 'effect';\n\n// Runtime data structure.\nexport type Range = {\n from: number;\n to: number;\n};\n\n// Persistent data structure.\n// TODO(burdon): Rename annotation?\nexport type Comment = {\n id: string;\n cursor?: string;\n};\n\n/**\n * Callback that renders into a DOM element within the editor.\n */\nexport type RenderCallback<Props extends object> = (el: HTMLElement, props: Props, view: EditorView) => void;\n\nexport const EditorViewModes = ['preview', 'readonly', 'source'] as const;\nexport const EditorViewMode = Schema.Union(...EditorViewModes.map((mode) => Schema.Literal(mode)));\nexport type EditorViewMode = Schema.Schema.Type<typeof EditorViewMode>;\n\nexport const EditorInputModes = ['default', 'vim', 'vscode'] as const;\nexport const EditorInputMode = Schema.Union(...EditorInputModes.map((mode) => Schema.Literal(mode)));\nexport type EditorInputMode = Schema.Schema.Type<typeof EditorInputMode>;\n"],
5
- "mappings": ";AAKA,SAASA,cAAc;AAoBhB,IAAMC,kBAAkB;EAAC;EAAW;EAAY;;AAChD,IAAMC,iBAAiBC,OAAOC,MAAK,GAAIH,gBAAgBI,IAAI,CAACC,SAASH,OAAOI,QAAQD,IAAAA,CAAAA,CAAAA;AAGpF,IAAME,mBAAmB;EAAC;EAAW;EAAO;;AAC5C,IAAMC,kBAAkBN,OAAOC,MAAK,GAAII,iBAAiBH,IAAI,CAACC,SAASH,OAAOI,QAAQD,IAAAA,CAAAA,CAAAA;",
6
- "names": ["Schema", "EditorViewModes", "EditorViewMode", "Schema", "Union", "map", "mode", "Literal", "EditorInputModes", "EditorInputMode"]
7
- }
@@ -1,6 +0,0 @@
1
- // src/testing/util.ts
2
- var str = (...lines) => lines.join("\n");
3
- export {
4
- str
5
- };
6
- //# sourceMappingURL=index.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../../src/testing/util.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nexport const str = (...lines: string[]) => lines.join('\\n');\n"],
5
- "mappings": ";AAIO,IAAMA,MAAM,IAAIC,UAAoBA,MAAMC,KAAK,IAAA;",
6
- "names": ["str", "lines", "join"]
7
- }
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/types/types.ts"],
4
- "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport { Schema } from 'effect';\n\n// Runtime data structure.\nexport type Range = {\n from: number;\n to: number;\n};\n\n// Persistent data structure.\n// TODO(burdon): Rename annotation?\nexport type Comment = {\n id: string;\n cursor?: string;\n};\n\n/**\n * Callback that renders into a DOM element within the editor.\n */\nexport type RenderCallback<Props extends object> = (el: HTMLElement, props: Props, view: EditorView) => void;\n\nexport const EditorViewModes = ['preview', 'readonly', 'source'] as const;\nexport const EditorViewMode = Schema.Union(...EditorViewModes.map((mode) => Schema.Literal(mode)));\nexport type EditorViewMode = Schema.Schema.Type<typeof EditorViewMode>;\n\nexport const EditorInputModes = ['default', 'vim', 'vscode'] as const;\nexport const EditorInputMode = Schema.Union(...EditorInputModes.map((mode) => Schema.Literal(mode)));\nexport type EditorInputMode = Schema.Schema.Type<typeof EditorInputMode>;\n"],
5
- "mappings": ";;;AAKA,SAASA,cAAc;AAoBhB,IAAMC,kBAAkB;EAAC;EAAW;EAAY;;AAChD,IAAMC,iBAAiBC,OAAOC,MAAK,GAAIH,gBAAgBI,IAAI,CAACC,SAASH,OAAOI,QAAQD,IAAAA,CAAAA,CAAAA;AAGpF,IAAME,mBAAmB;EAAC;EAAW;EAAO;;AAC5C,IAAMC,kBAAkBN,OAAOC,MAAK,GAAII,iBAAiBH,IAAI,CAACC,SAASH,OAAOI,QAAQD,IAAAA,CAAAA,CAAAA;",
6
- "names": ["Schema", "EditorViewModes", "EditorViewMode", "Schema", "Union", "map", "mode", "Literal", "EditorInputModes", "EditorInputMode"]
7
- }