@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
@@ -8,9 +8,10 @@ import { next as A } from '@automerge/automerge';
8
8
  import { type StateField } from '@codemirror/state';
9
9
  import { type EditorView } from '@codemirror/view';
10
10
 
11
- import { type IDocHandle } from '@dxos/react-client/echo';
11
+ import { type IDocHandle } from '@dxos/echo-db';
12
+ import { log } from '@dxos/log';
12
13
 
13
- import { getLastHeads, getPath, isReconcile, reconcileAnnotation, type State, updateHeads } from './defs';
14
+ import { type State, getLastHeads, getPath, isReconcile, reconcileAnnotation, updateHeads } from './defs';
14
15
  import { updateAutomerge } from './update-automerge';
15
16
  import { updateCodeMirror } from './update-codemirror';
16
17
 
@@ -27,7 +28,6 @@ export class Syncer {
27
28
  ) {}
28
29
 
29
30
  reconcile(view: EditorView, editor: boolean): void {
30
- // TODO(burdon): Better way to do mutex?
31
31
  if (this._pending) {
32
32
  return;
33
33
  }
@@ -41,7 +41,9 @@ export class Syncer {
41
41
  this._pending = false;
42
42
  }
43
43
 
44
- onEditorChange(view: EditorView): void {
44
+ private onEditorChange(view: EditorView): void {
45
+ log('onEditorChange');
46
+
45
47
  // Apply the unreconciled transactions to the document.
46
48
  const transactions = view.state.field(this._state).unreconciledTransactions.filter((tx) => !isReconcile(tx));
47
49
  const newHeads = updateAutomerge(this._state, this._handle, transactions, view.state);
@@ -54,7 +56,9 @@ export class Syncer {
54
56
  }
55
57
  }
56
58
 
57
- onAutomergeChange(view: EditorView): void {
59
+ private onAutomergeChange(view: EditorView): void {
60
+ log('onAutomergeChange');
61
+
58
62
  // Get the diff between the updated state of the document and the heads and apply that to the codemirror doc.
59
63
  const oldHeads = getLastHeads(view.state, this._state);
60
64
  const newHeads = A.getHeads(this._handle.doc()!);
@@ -5,9 +5,9 @@
5
5
  //
6
6
 
7
7
  import { next as A, type Heads } from '@automerge/automerge';
8
- import { type EditorState, type StateField, type Transaction, type Text } from '@codemirror/state';
8
+ import { type EditorState, type StateField, type Text, type Transaction } from '@codemirror/state';
9
9
 
10
- import { type IDocHandle } from '@dxos/react-client/echo';
10
+ import { type IDocHandle } from '@dxos/echo-db';
11
11
 
12
12
  import { type State } from './defs';
13
13
 
@@ -0,0 +1,163 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { StateEffect } from '@codemirror/state';
6
+ import { EditorView, ViewPlugin } from '@codemirror/view';
7
+
8
+ import { debounce } from '@dxos/async';
9
+ import { Domino } from '@dxos/react-ui';
10
+
11
+ import { scrollToLineEffect } from './scrolling';
12
+
13
+ // TODO(burdon): Reconcile with scrollToLineEffect (scrolling).
14
+ export const scrollToBottomEffect = StateEffect.define<ScrollBehavior | undefined>();
15
+
16
+ export type AutoScrollOptions = {
17
+ /** Auto-scroll when reaches the bottom. */
18
+ autoScroll?: boolean;
19
+ /** Threshold in px to trigger scroll from bottom. */
20
+ threshold?: number;
21
+ /** Throttle time in ms. */
22
+ throttleDelay?: number;
23
+ /** Callback when auto-scrolling. */
24
+ onAutoScroll?: (props: { view: EditorView; distanceFromBottom: number }) => boolean | void;
25
+ };
26
+
27
+ /**
28
+ * Extension that supports pinning the scroll position and automatically scrolls to the bottom when content is added.
29
+ */
30
+ // TODO(burdon): Reconcile with transcript-extension.
31
+ export const autoScroll = ({
32
+ autoScroll = true,
33
+ threshold = 100,
34
+ throttleDelay = 1_000,
35
+ onAutoScroll,
36
+ }: Partial<AutoScrollOptions> = {}) => {
37
+ let buttonContainer: HTMLDivElement | undefined;
38
+ let hideTimeout: NodeJS.Timeout | undefined;
39
+ let lastScrollTop = 0;
40
+ let isPinned = true;
41
+
42
+ const setPinned = (pin: boolean) => {
43
+ isPinned = pin;
44
+ buttonContainer?.classList.toggle('opacity-0', pin);
45
+ };
46
+
47
+ // Temporarily hide the scrollbar while auto-scrolling.
48
+ const hideScrollbar = (view: EditorView) => {
49
+ view.scrollDOM.classList.add('cm-hide-scrollbar');
50
+ clearTimeout(hideTimeout);
51
+ hideTimeout = setTimeout(() => {
52
+ view.scrollDOM.classList.remove('cm-hide-scrollbar');
53
+ }, 1_000);
54
+ };
55
+
56
+ // Throttled scroll to bottom.
57
+ const scrollToBottom = (view: EditorView, behavior?: ScrollBehavior) => {
58
+ setPinned(true);
59
+ hideScrollbar(view);
60
+ const line = view.state.doc.lineAt(view.state.doc.length);
61
+ view.dispatch({
62
+ selection: { anchor: line.to, head: line.to },
63
+ effects: scrollToLineEffect.of({ line: line.number, options: { position: 'end', offset: threshold, behavior } }),
64
+ });
65
+ };
66
+
67
+ // Throttled check for distance from bottom (for downward scrolls only).
68
+ const checkDistance = debounce((view: EditorView) => {
69
+ const scrollerRect = view.scrollDOM.getBoundingClientRect();
70
+ const coords = view.coordsAtPos(view.state.doc.length);
71
+ const distanceFromBottom = coords ? coords.bottom - scrollerRect.bottom : 0;
72
+ setPinned(distanceFromBottom < 0);
73
+ }, 1_000);
74
+
75
+ // Debounce scroll updates so rapid edits don't cause clunky scrolling.
76
+ const triggerUpdate = debounce((view: EditorView) => scrollToBottom(view), throttleDelay);
77
+
78
+ return [
79
+ // Update listener for logging when scrolling is needed.
80
+ EditorView.updateListener.of(({ view, transactions, heightChanged }) => {
81
+ // TODO(burdon): Remove and use scrollToLineEffect instead.
82
+ transactions.forEach((transaction) => {
83
+ for (const effect of transaction.effects) {
84
+ if (effect.is(scrollToBottomEffect)) {
85
+ scrollToBottom(view, effect.value);
86
+ }
87
+ }
88
+ });
89
+
90
+ // Maybe scroll if doc changed and pinned.
91
+ // NOTE: Geometry changed is triggered when widgets change height (e.g., toggle tool block).
92
+ if (heightChanged && isPinned) {
93
+ const coords = view.coordsAtPos(view.state.doc.length);
94
+ const scrollerRect = view.scrollDOM.getBoundingClientRect();
95
+ const distanceFromBottom = coords ? scrollerRect.bottom - coords.bottom : 0;
96
+ if (autoScroll && distanceFromBottom < threshold) {
97
+ const shouldScroll = onAutoScroll?.({ view, distanceFromBottom }) ?? true;
98
+ if (shouldScroll) {
99
+ triggerUpdate(view);
100
+ }
101
+ } else if (distanceFromBottom < 0) {
102
+ setPinned(false);
103
+ }
104
+ }
105
+ }),
106
+
107
+ // Detect user scroll.
108
+ EditorView.domEventHandlers({
109
+ scroll: (event, view) => {
110
+ const currentScrollTop = view.scrollDOM.scrollTop;
111
+ const scrollingUp = currentScrollTop < lastScrollTop;
112
+ lastScrollTop = currentScrollTop;
113
+
114
+ // If user scrolls up, immediately unpin auto-scroll.
115
+ if (scrollingUp) {
116
+ setPinned(false);
117
+ } else {
118
+ checkDistance(view);
119
+ }
120
+ },
121
+ }),
122
+
123
+ // Scroll button.
124
+ ViewPlugin.fromClass(
125
+ class {
126
+ constructor(view: EditorView) {
127
+ buttonContainer = Domino.of('div')
128
+ .classNames(true && 'cm-scroll-button transition-opacity duration-300 opacity-0')
129
+ .children(
130
+ Domino.of('button')
131
+ .classNames('dx-button bg-accentSurface')
132
+ .data('density', 'fine')
133
+ .children(Domino.of<any>('dx-icon').attributes({ icon: 'ph--arrow-down--regular' }))
134
+ .on('click', () => {
135
+ scrollToBottom(view);
136
+ }),
137
+ )
138
+ .build();
139
+
140
+ view.scrollDOM.parentElement!.appendChild(buttonContainer);
141
+ }
142
+ },
143
+ ),
144
+
145
+ // Styles.
146
+ EditorView.theme({
147
+ '.cm-scroller': {
148
+ scrollbarWidth: 'thin',
149
+ },
150
+ '.cm-scroller.cm-hide-scrollbar': {
151
+ scrollbarWidth: 'none',
152
+ },
153
+ '.cm-scroller.cm-hide-scrollbar::-webkit-scrollbar': {
154
+ display: 'none',
155
+ },
156
+ '.cm-scroll-button': {
157
+ position: 'absolute',
158
+ bottom: '0.5rem',
159
+ right: '1rem',
160
+ },
161
+ }),
162
+ ];
163
+ };
@@ -6,8 +6,8 @@ import { DeferredTask, Event, sleep } from '@dxos/async';
6
6
  import { Context } from '@dxos/context';
7
7
  import { invariant } from '@dxos/invariant';
8
8
  import { log } from '@dxos/log';
9
- import { type Space } from '@dxos/react-client/echo';
10
- import { type GossipMessage } from '@dxos/react-client/mesh';
9
+ import { type Messenger } from '@dxos/protocols';
10
+ import { type GossipMessage } from '@dxos/protocols/proto/dxos/mesh/teleport/gossip';
11
11
 
12
12
  import { type AwarenessInfo, type AwarenessPosition, type AwarenessProvider, type AwarenessState } from './awareness';
13
13
 
@@ -23,7 +23,7 @@ type ProtocolMessage =
23
23
  const DEBOUNCE_INTERVAL = 100; // ms
24
24
 
25
25
  export type AwarenessProviderParams = {
26
- space: Space;
26
+ messenger: Messenger;
27
27
  channel: string;
28
28
  peerId: string;
29
29
  info: AwarenessInfo;
@@ -35,7 +35,7 @@ export type AwarenessProviderParams = {
35
35
  export class SpaceAwarenessProvider implements AwarenessProvider {
36
36
  private readonly _remoteStates = new Map<string, AwarenessState>();
37
37
 
38
- private readonly _space: Space;
38
+ private readonly _messenger: Messenger;
39
39
  private readonly _channel: string;
40
40
  private readonly _peerId: string;
41
41
  private readonly _info: AwarenessInfo;
@@ -46,18 +46,18 @@ export class SpaceAwarenessProvider implements AwarenessProvider {
46
46
 
47
47
  public readonly remoteStateChange = new Event<void>();
48
48
 
49
- constructor(params: AwarenessProviderParams) {
50
- this._space = params.space;
51
- this._channel = params.channel;
52
- this._peerId = params.peerId;
53
- this._info = params.info;
49
+ constructor({ messenger, channel, peerId, info }: AwarenessProviderParams) {
50
+ this._messenger = messenger;
51
+ this._channel = channel;
52
+ this._peerId = peerId;
53
+ this._info = info;
54
54
  }
55
55
 
56
56
  open(): void {
57
57
  this._ctx = new Context();
58
58
  this._postTask = new DeferredTask(this._ctx, async () => {
59
59
  if (this._localState) {
60
- await this._space.postMessage(this._channel, {
60
+ await this._messenger.postMessage(this._channel, {
61
61
  kind: 'post',
62
62
  state: this._localState,
63
63
  } satisfies ProtocolMessage);
@@ -69,7 +69,7 @@ export class SpaceAwarenessProvider implements AwarenessProvider {
69
69
  });
70
70
 
71
71
  this._ctx.onDispose(
72
- this._space.listen(this._channel, (message: GossipMessage) => {
72
+ this._messenger.listen(this._channel, (message: GossipMessage) => {
73
73
  switch (message.payload.kind) {
74
74
  case 'query': {
75
75
  this._handleQueryMessage();
@@ -83,7 +83,7 @@ export class SpaceAwarenessProvider implements AwarenessProvider {
83
83
  }),
84
84
  );
85
85
 
86
- void this._space
86
+ void this._messenger
87
87
  .postMessage(this._channel, {
88
88
  kind: 'query',
89
89
  } satisfies ProtocolMessage)
@@ -2,7 +2,7 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
- import { Annotation, type Extension, RangeSet, type Range } from '@codemirror/state';
5
+ import { Annotation, type Extension, type Range, RangeSet } from '@codemirror/state';
6
6
  import {
7
7
  Decoration,
8
8
  type DecorationSet,
@@ -16,7 +16,7 @@ import {
16
16
  import { Event } from '@dxos/async';
17
17
  import { Context } from '@dxos/context';
18
18
 
19
- import { singleValueFacet, Cursor, type CursorConverter } from '../../util';
19
+ import { Cursor, type CursorConverter, singleValueFacet } from '../../util';
20
20
 
21
21
  export interface AwarenessProvider {
22
22
  remoteStateChange: Event<void>;
@@ -0,0 +1,131 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { RangeSetBuilder } from '@codemirror/state';
6
+ import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate } from '@codemirror/view';
7
+
8
+ import { mx } from '@dxos/react-ui-theme';
9
+
10
+ const paragraphBlockPlugin = ViewPlugin.fromClass(
11
+ class {
12
+ decorations: DecorationSet;
13
+
14
+ constructor(view: EditorView) {
15
+ this.decorations = this.build(view);
16
+ }
17
+
18
+ update(update: ViewUpdate) {
19
+ if (update.docChanged || update.viewportChanged) {
20
+ this.decorations = this.build(update.view);
21
+ }
22
+ }
23
+
24
+ build({ state }: EditorView) {
25
+ const builder = new RangeSetBuilder<Decoration>();
26
+
27
+ // Helper: commit a block from blockStart to endLine (inclusive).
28
+ const pushBlock = (fromLine: number, toLine: number) => {
29
+ // Add line decorations for each line in the block.
30
+ for (let lineNum = fromLine; lineNum <= toLine; lineNum++) {
31
+ const line = state.doc.line(lineNum);
32
+ builder.add(
33
+ line.from,
34
+ line.from,
35
+ Decoration.line({
36
+ class: mx(
37
+ 'block-line',
38
+ fromLine === toLine && 'block-single',
39
+ lineNum === fromLine && 'block-first',
40
+ lineNum > fromLine && lineNum < toLine && 'block-middle',
41
+ lineNum === toLine && 'block-last',
42
+ ),
43
+ }),
44
+ );
45
+ }
46
+ };
47
+
48
+ let blockStart: number | null = null;
49
+ let consecutiveBlankLines = 0;
50
+ const totalLines = state.doc.lines;
51
+ for (let i = 1; i <= totalLines; i++) {
52
+ const line = state.doc.line(i);
53
+ const isBlank = /^\s*$/.test(line.text);
54
+
55
+ if (!isBlank) {
56
+ // Reset blank line counter.
57
+ consecutiveBlankLines = 0;
58
+ // Start a new block if we're not already in one.
59
+ if (blockStart === null) {
60
+ blockStart = i;
61
+ }
62
+ } else {
63
+ // Increment blank line counter.
64
+ consecutiveBlankLines++;
65
+
66
+ // End the current block if we have 2+ consecutive blank lines.
67
+ if (consecutiveBlankLines >= 2 && blockStart !== null) {
68
+ pushBlock(blockStart, i - consecutiveBlankLines);
69
+ blockStart = null;
70
+ }
71
+ }
72
+ }
73
+
74
+ // Handle any remaining block at the end of the document.
75
+ if (blockStart !== null) {
76
+ // Find the last non-blank line for the block end.
77
+ let lastNonBlankLine = totalLines;
78
+ while (lastNonBlankLine >= blockStart) {
79
+ const line = state.doc.line(lastNonBlankLine);
80
+ if (!/^\s*$/.test(line.text)) {
81
+ break;
82
+ }
83
+ lastNonBlankLine--;
84
+ }
85
+ if (lastNonBlankLine >= blockStart) {
86
+ pushBlock(blockStart, lastNonBlankLine);
87
+ }
88
+ }
89
+
90
+ return builder.finish();
91
+ }
92
+ },
93
+ {
94
+ decorations: (v) => v.decorations,
95
+ },
96
+ );
97
+
98
+ export const blocks = () => [
99
+ paragraphBlockPlugin,
100
+ EditorView.baseTheme({
101
+ '.cm-line.block-line': {
102
+ paddingLeft: '0.75rem',
103
+ paddingRight: '0.75rem',
104
+ borderLeft: '1px solid var(--dx-subduedSeparator)',
105
+ borderRight: '1px solid var(--dx-subduedSeparator)',
106
+ },
107
+ '.cm-line.block-single': {
108
+ border: '1px solid var(--dx-subduedSeparator)',
109
+ borderRadius: '6px',
110
+ paddingTop: '0.5rem',
111
+ paddingBottom: '0.5rem',
112
+ marginTop: '0.5rem',
113
+ marginBottom: '0.5rem',
114
+ },
115
+ '.cm-line.block-first': {
116
+ borderTop: '1px solid var(--dx-subduedSeparator)',
117
+ borderTopLeftRadius: '6px',
118
+ borderTopRightRadius: '6px',
119
+ paddingTop: '0.5rem',
120
+ marginTop: '0.5rem',
121
+ },
122
+ '.cm-line.block-middle': {},
123
+ '.cm-line.block-last': {
124
+ borderBottom: '1px solid var(--dx-subduedSeparator)',
125
+ borderBottomLeftRadius: '6px',
126
+ borderBottomRightRadius: '6px',
127
+ paddingBottom: '0.5rem',
128
+ marginBottom: '0.5rem',
129
+ },
130
+ }),
131
+ ];
@@ -0,0 +1,75 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Extension, Prec, StateEffect, StateField } from '@codemirror/state';
6
+ import { keymap } from '@codemirror/view';
7
+
8
+ type Bookmark = {
9
+ id: string;
10
+ pos: number;
11
+ name: string;
12
+ };
13
+
14
+ export const addBookmark = StateEffect.define<Bookmark>();
15
+ export const removeBookmark = StateEffect.define<string>();
16
+ export const clearBookmarks = StateEffect.define<void>();
17
+
18
+ export const bookmarks = (): Extension => {
19
+ return [
20
+ bookmarksField,
21
+ Prec.highest(
22
+ keymap.of([
23
+ {
24
+ key: 'Mod-ArrowUp',
25
+ run: (view) => {
26
+ const bookmarks = view.state.field(bookmarksField);
27
+ console.log('up', bookmarks);
28
+ return true;
29
+ },
30
+ },
31
+ {
32
+ key: 'Mod-ArrowDown',
33
+ run: (view) => {
34
+ const bookmarks = view.state.field(bookmarksField);
35
+ console.log('down', bookmarks);
36
+ return true;
37
+ },
38
+ },
39
+ ]),
40
+ ),
41
+ ];
42
+ };
43
+
44
+ type BookmarkFieldState = {
45
+ bookmarks: Bookmark[];
46
+ };
47
+
48
+ const bookmarksField = StateField.define<BookmarkFieldState>({
49
+ create: (): BookmarkFieldState => ({
50
+ bookmarks: [],
51
+ }),
52
+
53
+ update: (value: BookmarkFieldState, tr): BookmarkFieldState => {
54
+ // Map bookmark positions through document changes.
55
+ let bookmarks = value.bookmarks.map((bookmark) => ({
56
+ ...bookmark,
57
+ pos: tr.changes.mapPos(bookmark.pos),
58
+ }));
59
+
60
+ // Process effects.
61
+ for (const effect of tr.effects) {
62
+ if (effect.is(addBookmark)) {
63
+ bookmarks = [...bookmarks, effect.value];
64
+ } else if (effect.is(removeBookmark)) {
65
+ bookmarks = bookmarks.filter((b) => b.id !== effect.value);
66
+ } else if (effect.is(clearBookmarks)) {
67
+ bookmarks = [];
68
+ }
69
+ }
70
+
71
+ // Sort bookmarks by position.
72
+ bookmarks.sort(({ pos: a }, { pos: b }) => a - b);
73
+ return { bookmarks };
74
+ },
75
+ });
@@ -5,25 +5,26 @@
5
5
  import { invertedEffects } from '@codemirror/commands';
6
6
  import { type ChangeDesc, type Extension, StateEffect, StateField, type Text } from '@codemirror/state';
7
7
  import {
8
- hoverTooltip,
9
- keymap,
10
8
  type Command,
11
9
  Decoration,
12
10
  EditorView,
13
- type Rect,
14
11
  type PluginValue,
12
+ type Rect,
15
13
  ViewPlugin,
14
+ hoverTooltip,
15
+ keymap,
16
16
  } from '@codemirror/view';
17
17
  import sortBy from 'lodash.sortby';
18
18
  import { useEffect } from 'react';
19
19
 
20
- import { debounce, type CleanupFn } from '@dxos/async';
20
+ import { type CleanupFn, debounce } from '@dxos/async';
21
21
  import { log } from '@dxos/log';
22
22
  import { isNonNullable } from '@dxos/util';
23
23
 
24
+ import { type Comment, type Range, type RenderCallback } from '../types';
25
+ import { Cursor, callbackWrapper, singleValueFacet } from '../util';
26
+
24
27
  import { documentId } from './selection';
25
- import { type RenderCallback, type Comment, type Range } from '../types';
26
- import { Cursor, singleValueFacet, callbackWrapper } from '../util';
27
28
 
28
29
  //
29
30
  // State management.
@@ -57,7 +58,11 @@ const setCommentState = StateEffect.define<CommentsState>();
57
58
  * The ranges are tracked as Automerge cursors from which the absolute indexed ranges can be computed.
58
59
  */
59
60
  export const commentsState = StateField.define<CommentsState>({
60
- create: (state) => ({ id: state.facet(documentId), comments: [], selection: {} }),
61
+ create: (state) => ({
62
+ id: state.facet(documentId),
63
+ comments: [],
64
+ selection: {},
65
+ }),
61
66
  update: (value, tr) => {
62
67
  for (const effect of tr.effects) {
63
68
  // Update selection.
@@ -98,15 +103,16 @@ export const commentsState = StateField.define<CommentsState>({
98
103
  */
99
104
  const styles = EditorView.theme({
100
105
  '.cm-comment, .cm-comment-current': {
101
- margin: '0 -3px',
102
- padding: '3px',
103
- borderRadius: '3px',
106
+ padding: '3px 0',
107
+ color: 'var(--dx-cmCommentText)',
104
108
  backgroundColor: 'var(--dx-cmCommentSurface)',
105
- color: 'var(--dx-cmComment)',
106
- cursor: 'pointer',
107
109
  },
108
- '.cm-comment:hover, .cm-comment-current': {
109
- textDecoration: 'underline',
110
+ '.cm-comment > span, .cm-comment-current > span': {
111
+ boxDecorationBreak: 'clone',
112
+ boxShadow: '0 0 1px 3px var(--dx-cmCommentSurface)',
113
+ backgroundColor: 'var(--dx-cmCommentSurface)',
114
+ color: 'var(--dx-cmCommentText)',
115
+ cursor: 'pointer',
110
116
  },
111
117
  });
112
118
 
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import type { Extension } from '@codemirror/state';
6
- import { dropCursor, EditorView } from '@codemirror/view';
6
+ import { EditorView, dropCursor } from '@codemirror/view';
7
7
 
8
8
  export type DNDOptions = { onDrop?: (view: EditorView, event: { files: FileList }) => void };
9
9