@dxos/react-ui-editor 0.8.4-main.1da679c → 0.8.4-main.21d9917

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 (426) hide show
  1. package/dist/lib/browser/index.mjs +1171 -8426
  2. package/dist/lib/browser/index.mjs.map +4 -4
  3. package/dist/lib/browser/meta.json +1 -1
  4. package/dist/lib/node-esm/index.mjs +1171 -8425
  5. package/dist/lib/node-esm/index.mjs.map +4 -4
  6. package/dist/lib/node-esm/meta.json +1 -1
  7. package/dist/types/src/components/Editor/Editor.d.ts +43 -15
  8. package/dist/types/src/components/Editor/Editor.d.ts.map +1 -1
  9. package/dist/types/src/components/Editor/Editor.stories.d.ts +23 -0
  10. package/dist/types/src/components/Editor/Editor.stories.d.ts.map +1 -0
  11. package/dist/types/src/components/EditorContent/EditorContent.d.ts +31 -0
  12. package/dist/types/src/components/EditorContent/EditorContent.d.ts.map +1 -0
  13. package/dist/types/src/components/EditorContent/controller.d.ts +10 -0
  14. package/dist/types/src/components/EditorContent/controller.d.ts.map +1 -0
  15. package/dist/types/src/components/EditorContent/index.d.ts +3 -0
  16. package/dist/types/src/components/EditorContent/index.d.ts.map +1 -0
  17. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts +36 -0
  18. package/dist/types/src/components/EditorMenuProvider/EditorMenuProvider.d.ts.map +1 -0
  19. package/dist/types/src/components/EditorMenuProvider/index.d.ts +6 -0
  20. package/dist/types/src/components/EditorMenuProvider/index.d.ts.map +1 -0
  21. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts +4 -0
  22. package/dist/types/src/components/EditorMenuProvider/menu-presets.d.ts.map +1 -0
  23. package/dist/types/src/components/EditorMenuProvider/menu.d.ts +28 -0
  24. package/dist/types/src/components/EditorMenuProvider/menu.d.ts.map +1 -0
  25. package/dist/types/src/components/EditorMenuProvider/popover.d.ts +46 -0
  26. package/dist/types/src/components/EditorMenuProvider/popover.d.ts.map +1 -0
  27. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts +34 -0
  28. package/dist/types/src/components/EditorMenuProvider/useEditorMenu.d.ts.map +1 -0
  29. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts +16 -0
  30. package/dist/types/src/components/EditorPreviewProvider/EditorPreviewProvider.d.ts.map +1 -0
  31. package/dist/types/src/components/EditorPreviewProvider/index.d.ts +2 -0
  32. package/dist/types/src/components/EditorPreviewProvider/index.d.ts.map +1 -0
  33. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts +28 -2
  34. package/dist/types/src/components/EditorToolbar/EditorToolbar.d.ts.map +1 -1
  35. package/dist/types/src/components/EditorToolbar/actions.d.ts +24 -0
  36. package/dist/types/src/components/EditorToolbar/actions.d.ts.map +1 -0
  37. package/dist/types/src/components/EditorToolbar/blocks.d.ts +8 -7
  38. package/dist/types/src/components/EditorToolbar/blocks.d.ts.map +1 -1
  39. package/dist/types/src/components/EditorToolbar/formatting.d.ts +8 -7
  40. package/dist/types/src/components/EditorToolbar/formatting.d.ts.map +1 -1
  41. package/dist/types/src/components/EditorToolbar/headings.d.ts +8 -7
  42. package/dist/types/src/components/EditorToolbar/headings.d.ts.map +1 -1
  43. package/dist/types/src/components/EditorToolbar/image.d.ts +4 -11
  44. package/dist/types/src/components/EditorToolbar/image.d.ts.map +1 -1
  45. package/dist/types/src/components/EditorToolbar/index.d.ts +2 -1
  46. package/dist/types/src/components/EditorToolbar/index.d.ts.map +1 -1
  47. package/dist/types/src/components/EditorToolbar/search.d.ts +4 -11
  48. package/dist/types/src/components/EditorToolbar/search.d.ts.map +1 -1
  49. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts +11 -0
  50. package/dist/types/src/components/EditorToolbar/useEditorToolbar.d.ts.map +1 -0
  51. package/dist/types/src/components/EditorToolbar/view-mode.d.ts +9 -8
  52. package/dist/types/src/components/EditorToolbar/view-mode.d.ts.map +1 -1
  53. package/dist/types/src/components/index.d.ts +4 -2
  54. package/dist/types/src/components/index.d.ts.map +1 -1
  55. package/dist/types/src/hooks/useTextEditor.d.ts +6 -10
  56. package/dist/types/src/hooks/useTextEditor.d.ts.map +1 -1
  57. package/dist/types/src/index.d.ts +0 -8
  58. package/dist/types/src/index.d.ts.map +1 -1
  59. package/dist/types/src/{extensions/automerge/automerge.stories.d.ts → stories/Automerge.stories.d.ts} +6 -10
  60. package/dist/types/src/stories/Automerge.stories.d.ts.map +1 -0
  61. package/dist/types/src/stories/{Command.stories.d.ts → CommandDialog.stories.d.ts} +2 -3
  62. package/dist/types/src/stories/CommandDialog.stories.d.ts.map +1 -0
  63. package/dist/types/src/stories/Comments.stories.d.ts +4 -4
  64. package/dist/types/src/stories/Comments.stories.d.ts.map +1 -1
  65. package/dist/types/src/stories/EditorToolbar.stories.d.ts +5 -6
  66. package/dist/types/src/stories/EditorToolbar.stories.d.ts.map +1 -1
  67. package/dist/types/src/stories/Experimental.stories.d.ts +4 -4
  68. package/dist/types/src/stories/Experimental.stories.d.ts.map +1 -1
  69. package/dist/types/src/stories/Markdown.stories.d.ts +4 -4
  70. package/dist/types/src/stories/Markdown.stories.d.ts.map +1 -1
  71. package/dist/types/src/stories/Outliner.stories.d.ts +0 -1
  72. package/dist/types/src/stories/Outliner.stories.d.ts.map +1 -1
  73. package/dist/types/src/stories/{CommandMenu.stories.d.ts → Popover.stories.d.ts} +6 -6
  74. package/dist/types/src/stories/Popover.stories.d.ts.map +1 -0
  75. package/dist/types/src/stories/Preview.stories.d.ts +5 -4
  76. package/dist/types/src/stories/Preview.stories.d.ts.map +1 -1
  77. package/dist/types/src/stories/Tags.stories.d.ts +0 -1
  78. package/dist/types/src/stories/Tags.stories.d.ts.map +1 -1
  79. package/dist/types/src/stories/TextEditor.stories.d.ts +4 -5
  80. package/dist/types/src/stories/TextEditor.stories.d.ts.map +1 -1
  81. package/dist/types/src/stories/Theme.stories.d.ts +8 -0
  82. package/dist/types/src/stories/Theme.stories.d.ts.map +1 -0
  83. package/dist/types/src/stories/components/EditorStory.d.ts +10 -19
  84. package/dist/types/src/stories/components/EditorStory.d.ts.map +1 -1
  85. package/dist/types/src/stories/components/util.d.ts +3 -3
  86. package/dist/types/src/stories/components/util.d.ts.map +1 -1
  87. package/dist/types/src/translations.d.ts +5 -5
  88. package/dist/types/src/translations.d.ts.map +1 -1
  89. package/dist/types/src/util/index.d.ts +0 -6
  90. package/dist/types/src/util/index.d.ts.map +1 -1
  91. package/dist/types/src/util/react.d.ts +5 -1
  92. package/dist/types/src/util/react.d.ts.map +1 -1
  93. package/dist/types/tsconfig.tsbuildinfo +1 -1
  94. package/package.json +70 -73
  95. package/src/components/Editor/Editor.stories.tsx +95 -0
  96. package/src/components/Editor/Editor.tsx +164 -24
  97. package/src/components/EditorContent/EditorContent.tsx +83 -0
  98. package/src/components/EditorContent/controller.ts +50 -0
  99. package/src/components/EditorContent/index.ts +6 -0
  100. package/src/components/EditorMenuProvider/EditorMenuProvider.tsx +233 -0
  101. package/src/components/EditorMenuProvider/index.ts +10 -0
  102. package/src/components/EditorMenuProvider/menu-presets.ts +124 -0
  103. package/src/components/EditorMenuProvider/menu.ts +70 -0
  104. package/src/components/EditorMenuProvider/popover.ts +285 -0
  105. package/src/components/EditorMenuProvider/useEditorMenu.ts +173 -0
  106. package/src/components/EditorPreviewProvider/EditorPreviewProvider.tsx +81 -0
  107. package/src/components/EditorPreviewProvider/index.ts +5 -0
  108. package/src/components/EditorToolbar/EditorToolbar.tsx +105 -91
  109. package/src/components/EditorToolbar/{lists.ts → actions.ts} +48 -17
  110. package/src/components/EditorToolbar/blocks.ts +5 -5
  111. package/src/components/EditorToolbar/formatting.ts +5 -5
  112. package/src/components/EditorToolbar/headings.ts +11 -8
  113. package/src/components/EditorToolbar/image.ts +9 -2
  114. package/src/components/EditorToolbar/index.ts +3 -7
  115. package/src/components/EditorToolbar/search.ts +9 -2
  116. package/src/components/EditorToolbar/useEditorToolbar.ts +20 -0
  117. package/src/components/EditorToolbar/view-mode.ts +5 -4
  118. package/src/components/index.ts +6 -2
  119. package/src/hooks/useTextEditor.ts +39 -33
  120. package/src/index.ts +0 -10
  121. package/src/stories/Automerge.stories.tsx +175 -0
  122. package/src/stories/{Command.stories.tsx → CommandDialog.stories.tsx} +21 -30
  123. package/src/stories/Comments.stories.tsx +51 -47
  124. package/src/stories/EditorToolbar.stories.tsx +39 -23
  125. package/src/stories/Experimental.stories.tsx +10 -12
  126. package/src/stories/Markdown.stories.tsx +19 -19
  127. package/src/stories/Outliner.stories.tsx +23 -24
  128. package/src/stories/Popover.stories.tsx +158 -0
  129. package/src/stories/Preview.stories.tsx +94 -85
  130. package/src/stories/Tags.stories.tsx +37 -14
  131. package/src/stories/TextEditor.stories.tsx +20 -51
  132. package/src/stories/Theme.stories.tsx +61 -0
  133. package/src/stories/components/EditorStory.tsx +36 -27
  134. package/src/stories/components/util.tsx +43 -11
  135. package/src/translations.ts +4 -4
  136. package/src/util/index.ts +1 -7
  137. package/src/util/react.tsx +6 -2
  138. package/dist/lib/browser/chunk-22UMM3QJ.mjs +0 -22
  139. package/dist/lib/browser/chunk-22UMM3QJ.mjs.map +0 -7
  140. package/dist/lib/browser/testing/index.mjs +0 -76
  141. package/dist/lib/browser/testing/index.mjs.map +0 -7
  142. package/dist/lib/browser/types/index.mjs +0 -13
  143. package/dist/lib/browser/types/index.mjs.map +0 -7
  144. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs +0 -24
  145. package/dist/lib/node-esm/chunk-YXYQPV6R.mjs.map +0 -7
  146. package/dist/lib/node-esm/testing/index.mjs +0 -78
  147. package/dist/lib/node-esm/testing/index.mjs.map +0 -7
  148. package/dist/lib/node-esm/types/index.mjs +0 -14
  149. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  150. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts +0 -38
  151. package/dist/types/src/components/CommandMenu/CommandMenu.d.ts.map +0 -1
  152. package/dist/types/src/components/CommandMenu/index.d.ts +0 -2
  153. package/dist/types/src/components/CommandMenu/index.d.ts.map +0 -1
  154. package/dist/types/src/components/EditorToolbar/lists.d.ts +0 -19
  155. package/dist/types/src/components/EditorToolbar/lists.d.ts.map +0 -1
  156. package/dist/types/src/components/EditorToolbar/util.d.ts +0 -51
  157. package/dist/types/src/components/EditorToolbar/util.d.ts.map +0 -1
  158. package/dist/types/src/defaults.d.ts +0 -14
  159. package/dist/types/src/defaults.d.ts.map +0 -1
  160. package/dist/types/src/extensions/annotations.d.ts +0 -9
  161. package/dist/types/src/extensions/annotations.d.ts.map +0 -1
  162. package/dist/types/src/extensions/autocomplete.d.ts +0 -26
  163. package/dist/types/src/extensions/autocomplete.d.ts.map +0 -1
  164. package/dist/types/src/extensions/automerge/automerge.d.ts +0 -4
  165. package/dist/types/src/extensions/automerge/automerge.d.ts.map +0 -1
  166. package/dist/types/src/extensions/automerge/automerge.stories.d.ts.map +0 -1
  167. package/dist/types/src/extensions/automerge/automerge.test.d.ts +0 -2
  168. package/dist/types/src/extensions/automerge/automerge.test.d.ts.map +0 -1
  169. package/dist/types/src/extensions/automerge/cursor.d.ts +0 -4
  170. package/dist/types/src/extensions/automerge/cursor.d.ts.map +0 -1
  171. package/dist/types/src/extensions/automerge/defs.d.ts +0 -17
  172. package/dist/types/src/extensions/automerge/defs.d.ts.map +0 -1
  173. package/dist/types/src/extensions/automerge/index.d.ts +0 -2
  174. package/dist/types/src/extensions/automerge/index.d.ts.map +0 -1
  175. package/dist/types/src/extensions/automerge/sync.d.ts +0 -17
  176. package/dist/types/src/extensions/automerge/sync.d.ts.map +0 -1
  177. package/dist/types/src/extensions/automerge/update-automerge.d.ts +0 -6
  178. package/dist/types/src/extensions/automerge/update-automerge.d.ts.map +0 -1
  179. package/dist/types/src/extensions/automerge/update-codemirror.d.ts +0 -5
  180. package/dist/types/src/extensions/automerge/update-codemirror.d.ts.map +0 -1
  181. package/dist/types/src/extensions/autoscroll.d.ts +0 -10
  182. package/dist/types/src/extensions/autoscroll.d.ts.map +0 -1
  183. package/dist/types/src/extensions/awareness/awareness-provider.d.ts +0 -31
  184. package/dist/types/src/extensions/awareness/awareness-provider.d.ts.map +0 -1
  185. package/dist/types/src/extensions/awareness/awareness.d.ts +0 -46
  186. package/dist/types/src/extensions/awareness/awareness.d.ts.map +0 -1
  187. package/dist/types/src/extensions/awareness/index.d.ts +0 -3
  188. package/dist/types/src/extensions/awareness/index.d.ts.map +0 -1
  189. package/dist/types/src/extensions/blast.d.ts +0 -25
  190. package/dist/types/src/extensions/blast.d.ts.map +0 -1
  191. package/dist/types/src/extensions/command/action.d.ts +0 -17
  192. package/dist/types/src/extensions/command/action.d.ts.map +0 -1
  193. package/dist/types/src/extensions/command/command-menu.d.ts +0 -20
  194. package/dist/types/src/extensions/command/command-menu.d.ts.map +0 -1
  195. package/dist/types/src/extensions/command/command.d.ts +0 -6
  196. package/dist/types/src/extensions/command/command.d.ts.map +0 -1
  197. package/dist/types/src/extensions/command/floating-menu.d.ts +0 -7
  198. package/dist/types/src/extensions/command/floating-menu.d.ts.map +0 -1
  199. package/dist/types/src/extensions/command/hint.d.ts +0 -19
  200. package/dist/types/src/extensions/command/hint.d.ts.map +0 -1
  201. package/dist/types/src/extensions/command/index.d.ts +0 -7
  202. package/dist/types/src/extensions/command/index.d.ts.map +0 -1
  203. package/dist/types/src/extensions/command/placeholder.d.ts +0 -10
  204. package/dist/types/src/extensions/command/placeholder.d.ts.map +0 -1
  205. package/dist/types/src/extensions/command/state.d.ts +0 -16
  206. package/dist/types/src/extensions/command/state.d.ts.map +0 -1
  207. package/dist/types/src/extensions/command/typeahead.d.ts +0 -22
  208. package/dist/types/src/extensions/command/typeahead.d.ts.map +0 -1
  209. package/dist/types/src/extensions/command/useCommandMenu.d.ts +0 -25
  210. package/dist/types/src/extensions/command/useCommandMenu.d.ts.map +0 -1
  211. package/dist/types/src/extensions/comments.d.ts +0 -95
  212. package/dist/types/src/extensions/comments.d.ts.map +0 -1
  213. package/dist/types/src/extensions/debug.d.ts +0 -3
  214. package/dist/types/src/extensions/debug.d.ts.map +0 -1
  215. package/dist/types/src/extensions/dnd.d.ts +0 -9
  216. package/dist/types/src/extensions/dnd.d.ts.map +0 -1
  217. package/dist/types/src/extensions/factories.d.ts +0 -78
  218. package/dist/types/src/extensions/factories.d.ts.map +0 -1
  219. package/dist/types/src/extensions/focus.d.ts +0 -7
  220. package/dist/types/src/extensions/focus.d.ts.map +0 -1
  221. package/dist/types/src/extensions/folding.d.ts +0 -7
  222. package/dist/types/src/extensions/folding.d.ts.map +0 -1
  223. package/dist/types/src/extensions/hashtag.d.ts +0 -3
  224. package/dist/types/src/extensions/hashtag.d.ts.map +0 -1
  225. package/dist/types/src/extensions/index.d.ts +0 -25
  226. package/dist/types/src/extensions/index.d.ts.map +0 -1
  227. package/dist/types/src/extensions/json.d.ts +0 -7
  228. package/dist/types/src/extensions/json.d.ts.map +0 -1
  229. package/dist/types/src/extensions/listener.d.ts +0 -11
  230. package/dist/types/src/extensions/listener.d.ts.map +0 -1
  231. package/dist/types/src/extensions/markdown/action.d.ts +0 -12
  232. package/dist/types/src/extensions/markdown/action.d.ts.map +0 -1
  233. package/dist/types/src/extensions/markdown/bundle.d.ts +0 -22
  234. package/dist/types/src/extensions/markdown/bundle.d.ts.map +0 -1
  235. package/dist/types/src/extensions/markdown/changes.d.ts +0 -10
  236. package/dist/types/src/extensions/markdown/changes.d.ts.map +0 -1
  237. package/dist/types/src/extensions/markdown/changes.test.d.ts +0 -2
  238. package/dist/types/src/extensions/markdown/changes.test.d.ts.map +0 -1
  239. package/dist/types/src/extensions/markdown/debug.d.ts +0 -11
  240. package/dist/types/src/extensions/markdown/debug.d.ts.map +0 -1
  241. package/dist/types/src/extensions/markdown/decorate.d.ts +0 -25
  242. package/dist/types/src/extensions/markdown/decorate.d.ts.map +0 -1
  243. package/dist/types/src/extensions/markdown/formatting.d.ts +0 -63
  244. package/dist/types/src/extensions/markdown/formatting.d.ts.map +0 -1
  245. package/dist/types/src/extensions/markdown/formatting.test.d.ts +0 -3
  246. package/dist/types/src/extensions/markdown/formatting.test.d.ts.map +0 -1
  247. package/dist/types/src/extensions/markdown/highlight.d.ts +0 -37
  248. package/dist/types/src/extensions/markdown/highlight.d.ts.map +0 -1
  249. package/dist/types/src/extensions/markdown/image.d.ts +0 -7
  250. package/dist/types/src/extensions/markdown/image.d.ts.map +0 -1
  251. package/dist/types/src/extensions/markdown/index.d.ts +0 -10
  252. package/dist/types/src/extensions/markdown/index.d.ts.map +0 -1
  253. package/dist/types/src/extensions/markdown/link.d.ts +0 -7
  254. package/dist/types/src/extensions/markdown/link.d.ts.map +0 -1
  255. package/dist/types/src/extensions/markdown/parser.test.d.ts +0 -2
  256. package/dist/types/src/extensions/markdown/parser.test.d.ts.map +0 -1
  257. package/dist/types/src/extensions/markdown/styles.d.ts +0 -4
  258. package/dist/types/src/extensions/markdown/styles.d.ts.map +0 -1
  259. package/dist/types/src/extensions/markdown/table.d.ts +0 -8
  260. package/dist/types/src/extensions/markdown/table.d.ts.map +0 -1
  261. package/dist/types/src/extensions/mention.d.ts +0 -7
  262. package/dist/types/src/extensions/mention.d.ts.map +0 -1
  263. package/dist/types/src/extensions/modes.d.ts +0 -10
  264. package/dist/types/src/extensions/modes.d.ts.map +0 -1
  265. package/dist/types/src/extensions/outliner/commands.d.ts +0 -10
  266. package/dist/types/src/extensions/outliner/commands.d.ts.map +0 -1
  267. package/dist/types/src/extensions/outliner/editor.d.ts +0 -5
  268. package/dist/types/src/extensions/outliner/editor.d.ts.map +0 -1
  269. package/dist/types/src/extensions/outliner/editor.test.d.ts +0 -2
  270. package/dist/types/src/extensions/outliner/editor.test.d.ts.map +0 -1
  271. package/dist/types/src/extensions/outliner/index.d.ts +0 -4
  272. package/dist/types/src/extensions/outliner/index.d.ts.map +0 -1
  273. package/dist/types/src/extensions/outliner/outliner.d.ts +0 -11
  274. package/dist/types/src/extensions/outliner/outliner.d.ts.map +0 -1
  275. package/dist/types/src/extensions/outliner/outliner.test.d.ts +0 -2
  276. package/dist/types/src/extensions/outliner/outliner.test.d.ts.map +0 -1
  277. package/dist/types/src/extensions/outliner/selection.d.ts +0 -12
  278. package/dist/types/src/extensions/outliner/selection.d.ts.map +0 -1
  279. package/dist/types/src/extensions/outliner/tree.d.ts +0 -79
  280. package/dist/types/src/extensions/outliner/tree.d.ts.map +0 -1
  281. package/dist/types/src/extensions/outliner/tree.test.d.ts +0 -2
  282. package/dist/types/src/extensions/outliner/tree.test.d.ts.map +0 -1
  283. package/dist/types/src/extensions/preview/index.d.ts +0 -2
  284. package/dist/types/src/extensions/preview/index.d.ts.map +0 -1
  285. package/dist/types/src/extensions/preview/preview.d.ts +0 -29
  286. package/dist/types/src/extensions/preview/preview.d.ts.map +0 -1
  287. package/dist/types/src/extensions/selection.d.ts +0 -24
  288. package/dist/types/src/extensions/selection.d.ts.map +0 -1
  289. package/dist/types/src/extensions/tags/extended-markdown.d.ts +0 -10
  290. package/dist/types/src/extensions/tags/extended-markdown.d.ts.map +0 -1
  291. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts +0 -2
  292. package/dist/types/src/extensions/tags/extended-markdown.test.d.ts.map +0 -1
  293. package/dist/types/src/extensions/tags/index.d.ts +0 -4
  294. package/dist/types/src/extensions/tags/index.d.ts.map +0 -1
  295. package/dist/types/src/extensions/tags/streamer.d.ts +0 -12
  296. package/dist/types/src/extensions/tags/streamer.d.ts.map +0 -1
  297. package/dist/types/src/extensions/tags/xml-tags.d.ts +0 -71
  298. package/dist/types/src/extensions/tags/xml-tags.d.ts.map +0 -1
  299. package/dist/types/src/extensions/tags/xml-util.d.ts +0 -10
  300. package/dist/types/src/extensions/tags/xml-util.d.ts.map +0 -1
  301. package/dist/types/src/extensions/typewriter.d.ts +0 -10
  302. package/dist/types/src/extensions/typewriter.d.ts.map +0 -1
  303. package/dist/types/src/stories/Command.stories.d.ts.map +0 -1
  304. package/dist/types/src/stories/CommandMenu.stories.d.ts.map +0 -1
  305. package/dist/types/src/styles/index.d.ts +0 -4
  306. package/dist/types/src/styles/index.d.ts.map +0 -1
  307. package/dist/types/src/styles/markdown.d.ts +0 -8
  308. package/dist/types/src/styles/markdown.d.ts.map +0 -1
  309. package/dist/types/src/styles/theme.d.ts +0 -38
  310. package/dist/types/src/styles/theme.d.ts.map +0 -1
  311. package/dist/types/src/styles/tokens.d.ts +0 -3
  312. package/dist/types/src/styles/tokens.d.ts.map +0 -1
  313. package/dist/types/src/testing/PreviewPopover.d.ts +0 -20
  314. package/dist/types/src/testing/PreviewPopover.d.ts.map +0 -1
  315. package/dist/types/src/testing/index.d.ts +0 -3
  316. package/dist/types/src/testing/index.d.ts.map +0 -1
  317. package/dist/types/src/testing/util.d.ts +0 -3
  318. package/dist/types/src/testing/util.d.ts.map +0 -1
  319. package/dist/types/src/types/index.d.ts +0 -2
  320. package/dist/types/src/types/index.d.ts.map +0 -1
  321. package/dist/types/src/types/types.d.ts +0 -21
  322. package/dist/types/src/types/types.d.ts.map +0 -1
  323. package/dist/types/src/util/cursor.d.ts +0 -31
  324. package/dist/types/src/util/cursor.d.ts.map +0 -1
  325. package/dist/types/src/util/debug.d.ts +0 -17
  326. package/dist/types/src/util/debug.d.ts.map +0 -1
  327. package/dist/types/src/util/decorations.d.ts +0 -4
  328. package/dist/types/src/util/decorations.d.ts.map +0 -1
  329. package/dist/types/src/util/dom.d.ts +0 -10
  330. package/dist/types/src/util/dom.d.ts.map +0 -1
  331. package/dist/types/src/util/domino.d.ts +0 -18
  332. package/dist/types/src/util/domino.d.ts.map +0 -1
  333. package/dist/types/src/util/facet.d.ts +0 -3
  334. package/dist/types/src/util/facet.d.ts.map +0 -1
  335. package/src/components/CommandMenu/CommandMenu.tsx +0 -346
  336. package/src/components/CommandMenu/index.ts +0 -5
  337. package/src/components/EditorToolbar/util.ts +0 -76
  338. package/src/defaults.ts +0 -52
  339. package/src/extensions/annotations.ts +0 -55
  340. package/src/extensions/autocomplete.ts +0 -219
  341. package/src/extensions/automerge/automerge.stories.tsx +0 -149
  342. package/src/extensions/automerge/automerge.test.tsx +0 -78
  343. package/src/extensions/automerge/automerge.ts +0 -86
  344. package/src/extensions/automerge/cursor.ts +0 -28
  345. package/src/extensions/automerge/defs.ts +0 -31
  346. package/src/extensions/automerge/index.ts +0 -5
  347. package/src/extensions/automerge/sync.ts +0 -75
  348. package/src/extensions/automerge/update-automerge.ts +0 -50
  349. package/src/extensions/automerge/update-codemirror.ts +0 -115
  350. package/src/extensions/autoscroll.ts +0 -157
  351. package/src/extensions/awareness/awareness-provider.ts +0 -127
  352. package/src/extensions/awareness/awareness.ts +0 -315
  353. package/src/extensions/awareness/index.ts +0 -6
  354. package/src/extensions/blast.ts +0 -363
  355. package/src/extensions/command/action.ts +0 -55
  356. package/src/extensions/command/command-menu.ts +0 -211
  357. package/src/extensions/command/command.ts +0 -34
  358. package/src/extensions/command/floating-menu.ts +0 -128
  359. package/src/extensions/command/hint.ts +0 -103
  360. package/src/extensions/command/index.ts +0 -10
  361. package/src/extensions/command/placeholder.ts +0 -113
  362. package/src/extensions/command/state.ts +0 -90
  363. package/src/extensions/command/typeahead.ts +0 -129
  364. package/src/extensions/command/useCommandMenu.ts +0 -115
  365. package/src/extensions/comments.ts +0 -597
  366. package/src/extensions/debug.ts +0 -15
  367. package/src/extensions/dnd.ts +0 -37
  368. package/src/extensions/factories.ts +0 -247
  369. package/src/extensions/focus.ts +0 -35
  370. package/src/extensions/folding.tsx +0 -46
  371. package/src/extensions/hashtag.tsx +0 -68
  372. package/src/extensions/index.ts +0 -28
  373. package/src/extensions/json.ts +0 -57
  374. package/src/extensions/listener.ts +0 -38
  375. package/src/extensions/markdown/action.ts +0 -117
  376. package/src/extensions/markdown/bundle.ts +0 -93
  377. package/src/extensions/markdown/changes.test.ts +0 -26
  378. package/src/extensions/markdown/changes.ts +0 -149
  379. package/src/extensions/markdown/debug.ts +0 -44
  380. package/src/extensions/markdown/decorate.ts +0 -600
  381. package/src/extensions/markdown/formatting.test.ts +0 -498
  382. package/src/extensions/markdown/formatting.ts +0 -1267
  383. package/src/extensions/markdown/highlight.ts +0 -183
  384. package/src/extensions/markdown/image.ts +0 -118
  385. package/src/extensions/markdown/index.ts +0 -13
  386. package/src/extensions/markdown/link.ts +0 -50
  387. package/src/extensions/markdown/parser.test.ts +0 -75
  388. package/src/extensions/markdown/styles.ts +0 -135
  389. package/src/extensions/markdown/table.ts +0 -150
  390. package/src/extensions/mention.ts +0 -41
  391. package/src/extensions/modes.ts +0 -41
  392. package/src/extensions/outliner/commands.ts +0 -270
  393. package/src/extensions/outliner/editor.test.ts +0 -33
  394. package/src/extensions/outliner/editor.ts +0 -184
  395. package/src/extensions/outliner/index.ts +0 -7
  396. package/src/extensions/outliner/outliner.test.ts +0 -100
  397. package/src/extensions/outliner/outliner.ts +0 -167
  398. package/src/extensions/outliner/selection.ts +0 -50
  399. package/src/extensions/outliner/tree.test.ts +0 -168
  400. package/src/extensions/outliner/tree.ts +0 -317
  401. package/src/extensions/preview/index.ts +0 -5
  402. package/src/extensions/preview/preview.ts +0 -190
  403. package/src/extensions/selection.ts +0 -100
  404. package/src/extensions/tags/extended-markdown.test.ts +0 -261
  405. package/src/extensions/tags/extended-markdown.ts +0 -78
  406. package/src/extensions/tags/index.ts +0 -7
  407. package/src/extensions/tags/streamer.ts +0 -244
  408. package/src/extensions/tags/xml-tags.ts +0 -335
  409. package/src/extensions/tags/xml-util.ts +0 -94
  410. package/src/extensions/typewriter.ts +0 -68
  411. package/src/stories/CommandMenu.stories.tsx +0 -158
  412. package/src/styles/index.ts +0 -7
  413. package/src/styles/markdown.ts +0 -26
  414. package/src/styles/theme.ts +0 -267
  415. package/src/styles/tokens.ts +0 -17
  416. package/src/testing/PreviewPopover.tsx +0 -78
  417. package/src/testing/index.ts +0 -6
  418. package/src/testing/util.ts +0 -7
  419. package/src/types/index.ts +0 -5
  420. package/src/types/types.ts +0 -32
  421. package/src/util/cursor.ts +0 -56
  422. package/src/util/debug.ts +0 -64
  423. package/src/util/decorations.ts +0 -21
  424. package/src/util/dom.ts +0 -34
  425. package/src/util/domino.ts +0 -51
  426. package/src/util/facet.ts +0 -13
@@ -1,184 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { type ChangeSpec, EditorSelection, EditorState } from '@codemirror/state';
6
- import { type EditorView, ViewPlugin } from '@codemirror/view';
7
-
8
- import { log } from '@dxos/log';
9
-
10
- import { getSelection } from './selection';
11
- import { treeFacet } from './tree';
12
-
13
- const LIST_ITEM_REGEX = /^\s*- (\[ \]|\[x\])? /;
14
-
15
- /**
16
- * Initialize empty document.
17
- */
18
- const initialize = () => {
19
- return ViewPlugin.fromClass(
20
- class {
21
- constructor(view: EditorView) {
22
- const first = view.state.doc.lineAt(0);
23
- const text = view.state.sliceDoc(first.from, first.to);
24
- const match = text.match(LIST_ITEM_REGEX);
25
- if (!match) {
26
- setTimeout(() => {
27
- const insert = '- [ ] ';
28
- view.dispatch({
29
- changes: [{ from: 0, to: 0, insert }],
30
- selection: EditorSelection.cursor(insert.length),
31
- });
32
- });
33
- }
34
- }
35
- },
36
- );
37
- };
38
-
39
- /**
40
- * Handle cursor movement, selection, and editing.
41
- */
42
- export const editor = () => [
43
- initialize(),
44
-
45
- EditorState.transactionFilter.of((tr) => {
46
- const tree = tr.state.facet(treeFacet);
47
-
48
- //
49
- // Check cursor is in a valid position.
50
- //
51
- if (!tr.docChanged) {
52
- const current = getSelection(tr.state).from;
53
- if (current != null) {
54
- const currentItem = tree.find(current);
55
- if (!currentItem) {
56
- return [];
57
- }
58
-
59
- // Check if outside of editable range.
60
- if (current < currentItem.contentRange.from || current > currentItem.contentRange.to) {
61
- const prev = getSelection(tr.startState).from;
62
- const prevItem = prev != null ? tree.find(prev) : undefined;
63
- if (!prevItem) {
64
- return [{ selection: EditorSelection.cursor(currentItem.contentRange.from) }];
65
- } else {
66
- if (currentItem.index < prevItem.index) {
67
- // Moving line up.
68
- return [{ selection: EditorSelection.cursor(currentItem.contentRange.to) }];
69
- } else if (currentItem.index > prevItem.index) {
70
- // Moving line down.
71
- return [{ selection: EditorSelection.cursor(currentItem.contentRange.from) }];
72
- } else {
73
- // Moving left.
74
- if (current < prev) {
75
- if (currentItem.index === 0) {
76
- // At start of the list.
77
- return [];
78
- } else {
79
- // Go to previous line.
80
- return [{ selection: EditorSelection.cursor(currentItem.lineRange.from - 1) }];
81
- }
82
- } else {
83
- // Go to end of line.
84
- return [{ selection: EditorSelection.cursor(currentItem.contentRange.to) }];
85
- }
86
- }
87
- }
88
- }
89
- }
90
-
91
- return tr;
92
- }
93
-
94
- //
95
- // Validate changes that don't break the tree.
96
- //
97
- let cancel = false;
98
- const changes: ChangeSpec[] = [];
99
- tr.changes.iterChanges((fromA, toA, fromB, toB, insert) => {
100
- const line = tr.startState.doc.lineAt(fromA);
101
- const match = line.text.match(LIST_ITEM_REGEX);
102
- if (match) {
103
- // Check cursor was in a valid position.
104
- const startTree = tr.startState.facet(treeFacet);
105
- const startItem = startTree.find(tr.startState.selection.main.from);
106
-
107
- // Check if entire line was deleted (which is ok).
108
- const deleteLine = fromA === startItem?.lineRange.from && toA === startItem?.lineRange.to + 1;
109
- if (deleteLine) {
110
- return;
111
- }
112
-
113
- // if (!deleteLine && (!startItem || fromA < startItem.contentRange.from || toA > startItem.contentRange.to)) {
114
- // cancel = true;
115
- // return;
116
- // }
117
-
118
- // Check valid item.
119
- const currentItem = tree.find(tr.state.selection.main.from);
120
- if (!currentItem?.contentRange) {
121
- cancel = true;
122
- return;
123
- }
124
-
125
- // Detect and cancel replacement of task marker with continuation indent.
126
- // Task markers are atomic so will be deleted when backspace is pressed.
127
- // The markdown extension inserts 2 or 6 spaces when deleting a list or task marker in order to create a continuation.
128
- // - [ ] <- backspace here deletes the task marker.
129
- // - [ ] <- backspace here inserts 6 spaces (creates continuation).
130
- // - [ ] <- backspace here deletes the task marker.
131
- const start = line.from + (match?.[0]?.length ?? 0);
132
- const replace = start === toA && toA - fromA === insert.length;
133
- if (replace) {
134
- changes.push({ from: line.from - 1, to: toA });
135
- return;
136
- }
137
-
138
- // Detect deletion of marker.
139
- if (fromB === toB) {
140
- if (toA === line.to) {
141
- const line = tr.state.doc.lineAt(fromA);
142
- if (line.text.match(/^\s*$/)) {
143
- if (line.from === 0) {
144
- // Don't delete first line.
145
- cancel = true;
146
- return;
147
- } else {
148
- // Delete indent and marker.
149
- changes.push({ from: line.from - 1, to: toA });
150
- return;
151
- }
152
- }
153
- }
154
- return;
155
- }
156
-
157
- // Prevent newline if line is empty.
158
- const item = tree.find(fromA);
159
- if (item?.contentRange.from === item?.contentRange.to && fromA === toA) {
160
- cancel = true;
161
- return;
162
- }
163
-
164
- log('change', {
165
- item,
166
- line: { from: line.from, to: line.to },
167
- a: [fromA, toA],
168
- b: [fromB, toB],
169
- insert: { text: insert.toString(), length: insert.length },
170
- });
171
- }
172
- });
173
-
174
- if (changes.length > 0) {
175
- log('modified,', { changes });
176
- return [{ changes }];
177
- } else if (cancel) {
178
- log('cancel');
179
- return [];
180
- }
181
-
182
- return tr;
183
- }),
184
- ];
@@ -1,7 +0,0 @@
1
- //
2
- // Copyright 2023 DXOS.org
3
- //
4
-
5
- export * from './commands';
6
- export * from './outliner';
7
- export * from './tree';
@@ -1,100 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { EditorSelection, EditorState } from '@codemirror/state';
6
- import { EditorView } from '@codemirror/view';
7
- import { describe, test } from 'vitest';
8
-
9
- import { str } from '../../testing';
10
- import { createMarkdownExtensions } from '../markdown';
11
-
12
- import { indentItemLess, indentItemMore, moveItemDown, moveItemUp } from './commands';
13
- import { listItemToString, outlinerTree, treeFacet } from './tree';
14
-
15
- const lines = [
16
- '- [ ] 1',
17
- '- [ ] 2',
18
- ' - [ ] 2.1',
19
- ' - [ ] 2.2',
20
- ' - 2.2.1',
21
- ' - 2.2.2',
22
- ' - 2.2.3',
23
- ' - [ ] 2.3',
24
- '- [ ] 3',
25
- ];
26
-
27
- const getPos = (line: number) => {
28
- return lines.slice(0, line).reduce((acc, line) => acc + line.length + 1, 0);
29
- };
30
-
31
- const extensions = [createMarkdownExtensions(), outlinerTree()];
32
-
33
- // TODO(burdon): Flaky.
34
- describe.runIf(!process.env.CI)('outliner', () => {
35
- const state = EditorState.create({ doc: str(...lines), extensions });
36
-
37
- test('sanity', ({ expect }) => {
38
- const tree = state.facet(treeFacet);
39
- let i = 0;
40
- tree.traverse((item, level) => {
41
- const pos = getPos(i++);
42
- expect(item.lineRange.from).toBe(pos);
43
- console.log(listItemToString(item, level), pos);
44
- });
45
- });
46
-
47
- test('indent', ({ expect }) => {
48
- const view = new EditorView({ state });
49
- const pos = getPos(1);
50
-
51
- {
52
- const tree = view.state.facet(treeFacet);
53
- const item = tree.find(pos);
54
- expect(item?.level).toBe(0);
55
- }
56
-
57
- view.dispatch({ selection: EditorSelection.cursor(pos) });
58
- indentItemMore(view);
59
-
60
- {
61
- const tree = view.state.facet(treeFacet);
62
- const item = tree.find(pos);
63
- expect(item?.level).toBe(1);
64
- }
65
- });
66
-
67
- test('unindent', ({ expect }) => {
68
- const view = new EditorView({ state });
69
- const pos = getPos(2);
70
-
71
- {
72
- const tree = view.state.facet(treeFacet);
73
- const item = tree.find(pos);
74
- expect(item?.level).toBe(1);
75
- }
76
-
77
- view.dispatch({ selection: EditorSelection.cursor(pos) });
78
- indentItemLess(view);
79
-
80
- {
81
- const tree = view.state.facet(treeFacet);
82
- const item = tree.find(pos);
83
- expect(item?.level).toBe(0);
84
- }
85
- });
86
-
87
- test('move down', ({ expect }) => {
88
- const view = new EditorView({ state });
89
- view.dispatch({ selection: EditorSelection.cursor(getPos(0)) });
90
- moveItemDown(view);
91
- expect(view.state.doc.sliceString(0, view.state.doc.length)).toBe(str(...lines.slice(1, 8), lines[0], lines[8]));
92
- });
93
-
94
- test('move up', ({ expect }) => {
95
- const view = new EditorView({ state });
96
- view.dispatch({ selection: EditorSelection.cursor(getPos(8)) });
97
- moveItemUp(view);
98
- expect(view.state.doc.sliceString(0, view.state.doc.length)).toBe(str(lines[0], lines[8], ...lines.slice(1, 8)));
99
- });
100
- });
@@ -1,167 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { type EditorState, type Extension, Prec, type Range } 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
- import { floatingMenu } from '../command';
11
- import { decorateMarkdown } from '../markdown';
12
-
13
- import { commands } from './commands';
14
- import { editor } from './editor';
15
- import { selectionCompartment, selectionEquals, selectionFacet } from './selection';
16
- import { outlinerTree, treeFacet } from './tree';
17
-
18
- // ISSUES:
19
- // TODO(burdon): Remove requirement for continuous lines to be indented (so that user's can't accidentally delete them and break the layout).
20
- // TODO(burdon): Prevent unterminated fenced code from breaking subsequent items ("firewall" markdown parsing within each item?)
21
- // TODO(burdon): What if a different editor "breaks" the layout?
22
- // TODO(burdon): Check Automerge recognizes text that is moved/indented (e.g., concurrent editing item while being moved).
23
-
24
- // NEXT:
25
- // TODO(burdon): Update selection when adding/removing items.
26
- // TODO(burdon): When selecting across items, select entire items (don't show selection that spans the gaps).
27
- // TODO(burdon): Handle backspace at start of line (or empty line).
28
- // TODO(burdon): Convert to task object and insert link (menu button).
29
- // TODO(burdon): Smart Cut-and-paste.
30
- // TODO(burdon): DND.
31
-
32
- export type OutlinerProps = {};
33
-
34
- /**
35
- * Outliner extension.
36
- * - Stores outline as a standard markdown document with task and list markers.
37
- * - Supports continuation lines and rich formatting (with Shift+Enter).
38
- * - Constrains editor to outline structure.
39
- * - Supports smart cut-and-paste.
40
- */
41
- export const outliner = (_options: OutlinerProps = {}): Extension => [
42
- // Commands.
43
- Prec.highest(commands()),
44
-
45
- // Selection.
46
- selectionCompartment.of(selectionFacet.of([])),
47
-
48
- // State.
49
- outlinerTree(),
50
-
51
- // Filter and possibly modify changes.
52
- editor(),
53
-
54
- // Floating menu.
55
- floatingMenu(),
56
-
57
- // Line decorations.
58
- decorations(),
59
-
60
- // Default markdown decorations.
61
- decorateMarkdown({ listPaddingLeft: 8 }),
62
-
63
- // Researve space for menu.
64
- EditorView.contentAttributes.of({ class: 'is-full !mr-[3rem]' }),
65
- ];
66
-
67
- /**
68
- * Line decorations (for border and selection).
69
- */
70
- const decorations = () => [
71
- ViewPlugin.fromClass(
72
- class {
73
- decorations: DecorationSet = Decoration.none;
74
- constructor(view: EditorView) {
75
- this.updateDecorations(view.state, view);
76
- }
77
-
78
- update(update: ViewUpdate) {
79
- const selectionChanged = !selectionEquals(
80
- update.state.facet(selectionFacet),
81
- update.startState.facet(selectionFacet),
82
- );
83
-
84
- if (
85
- update.focusChanged ||
86
- update.docChanged ||
87
- update.viewportChanged ||
88
- update.selectionSet ||
89
- selectionChanged
90
- ) {
91
- this.updateDecorations(update.state, update.view);
92
- }
93
- }
94
-
95
- private updateDecorations(state: EditorState, { viewport: { from, to }, hasFocus }: EditorView) {
96
- const selection = state.facet(selectionFacet);
97
- const tree = state.facet(treeFacet);
98
- const current = tree.find(state.selection.ranges[state.selection.mainIndex]?.from);
99
- const doc = state.doc;
100
-
101
- const decorations: Range<Decoration>[] = [];
102
- for (let lineNum = doc.lineAt(from).number; lineNum <= doc.lineAt(to).number; lineNum++) {
103
- const line = doc.line(lineNum);
104
- const item = tree.find(line.from);
105
- if (item) {
106
- const lineFrom = doc.lineAt(item.contentRange.from);
107
- const lineTo = doc.lineAt(item.contentRange.to);
108
- const isSelected = selection.includes(item.index) || item === current;
109
- decorations.push(
110
- Decoration.line({
111
- class: mx(
112
- 'cm-list-item',
113
- lineFrom.number === line.number && 'cm-list-item-start',
114
- lineTo.number === line.number && 'cm-list-item-end',
115
- isSelected && (hasFocus ? 'cm-list-item-focused' : 'cm-list-item-selected'),
116
- ),
117
- }).range(line.from, line.from),
118
- );
119
- }
120
- }
121
-
122
- this.decorations = Decoration.set(decorations);
123
- }
124
- },
125
- {
126
- decorations: (v) => v.decorations,
127
- },
128
- ),
129
-
130
- // Theme.
131
- EditorView.theme(
132
- Object.assign({
133
- '.cm-list-item': {
134
- borderLeftWidth: '1px',
135
- borderRightWidth: '1px',
136
- paddingLeft: '32px',
137
- borderColor: 'transparent',
138
- },
139
- '.cm-list-item.cm-codeblock-start': {
140
- borderRadius: '0',
141
- },
142
-
143
- '.cm-list-item-start': {
144
- borderTopWidth: '1px',
145
- borderTopLeftRadius: '4px',
146
- borderTopRightRadius: '4px',
147
- paddingTop: '4px',
148
- marginTop: '2px',
149
- },
150
-
151
- '.cm-list-item-end': {
152
- borderBottomWidth: '1px',
153
- borderBottomLeftRadius: '4px',
154
- borderBottomRightRadius: '4px',
155
- paddingBottom: '4px',
156
- marginBottom: '2px',
157
- },
158
-
159
- '.cm-list-item-focused': {
160
- borderColor: 'var(--dx-accentFocusIndicator)',
161
- },
162
- '&:focus-within .cm-list-item-selected': {
163
- borderColor: 'var(--dx-separator)',
164
- },
165
- }),
166
- ),
167
- ];
@@ -1,50 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { Compartment, type EditorState, Facet, type SelectionRange } from '@codemirror/state';
6
- import { type Command, type EditorView } from '@codemirror/view';
7
-
8
- import { treeFacet } from './tree';
9
-
10
- export type Selection = number[];
11
-
12
- export const getSelection = (state: EditorState): SelectionRange => state.selection.main;
13
-
14
- export const selectionEquals = (a: number[], b: number[]) => a.length === b.length && a.every((i) => b.includes(i));
15
-
16
- export const selectionFacet = Facet.define<Selection, Selection>({
17
- combine: (values) => values[0],
18
- });
19
-
20
- export const selectionCompartment = new Compartment();
21
-
22
- export const selectNone: Command = (view: EditorView) => {
23
- view.dispatch({
24
- effects: selectionCompartment.reconfigure(selectionFacet.of([])),
25
- });
26
-
27
- return true;
28
- };
29
-
30
- export const selectAll: Command = (view: EditorView) => {
31
- const tree = view.state.facet(treeFacet);
32
- const selection = view.state.facet(selectionFacet);
33
- const items: Selection = [];
34
- tree.traverse((item) => items.push(item.index));
35
- view.dispatch({
36
- effects: selectionCompartment.reconfigure(selectionFacet.of(selectionEquals(selection, items) ? [] : items)),
37
- });
38
-
39
- return true;
40
- };
41
-
42
- // TODO(burdon): Implement.
43
- export const selectUp: Command = (view: EditorView) => {
44
- return true;
45
- };
46
-
47
- // TODO(burdon): Implement.
48
- export const selectDown: Command = (view: EditorView) => {
49
- return true;
50
- };
@@ -1,168 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
-
5
- import { markdown, markdownLanguage } from '@codemirror/lang-markdown';
6
- import { EditorState } from '@codemirror/state';
7
- import { beforeEach, describe, test } from 'vitest';
8
-
9
- import { str } from '../../testing';
10
- import { type Range } from '../../types';
11
-
12
- import { type Item, listItemToString, outlinerTree, treeFacet } from './tree';
13
-
14
- const lines = [
15
- '- [ ] 1',
16
- '- [ ] 2',
17
- ' - [ ] 2.1',
18
- ' - [ ] 2.2',
19
- ' - 2.2.1',
20
- ' - 2.2.2',
21
- ' - 2.2.3',
22
- ' - [ ] 2.3',
23
- '- [ ] 3',
24
- ];
25
-
26
- const getPos = (line: number) => {
27
- return lines.slice(0, line).reduce((acc, line) => acc + line.length + 1, 0);
28
- };
29
-
30
- const extensions = [markdown({ base: markdownLanguage }), outlinerTree()];
31
-
32
- describe('tree (boundary conditions)', () => {
33
- test('empty', ({ expect }) => {
34
- const state = EditorState.create({ doc: str(''), extensions });
35
- const tree = state.facet(treeFacet);
36
- expect(tree).to.exist;
37
- });
38
-
39
- test('content range', ({ expect }) => {
40
- const state = EditorState.create({ doc: '- [ ] A', extensions });
41
- const tree = state.facet(treeFacet);
42
- console.log(JSON.stringify(tree, null, 2));
43
- expect(tree.toJSON()).to.deep.eq({
44
- type: 'root',
45
- index: -1,
46
- level: -1,
47
- lineRange: { from: 0, to: -1 },
48
- contentRange: { from: 0, to: -1 },
49
- children: [
50
- {
51
- type: 'task',
52
- index: 0,
53
- level: 0,
54
- lineRange: { from: 0, to: 7 },
55
- contentRange: { from: 6, to: 7 },
56
- children: [],
57
- },
58
- ],
59
- });
60
-
61
- const item = tree.find(0);
62
- expect(item?.contentRange).to.include({ from: 6, to: state.doc.length });
63
- });
64
-
65
- test('empty continuation', ({ expect }) => {
66
- const state = EditorState.create({ doc: str('- [ ] A', ' '), extensions });
67
- const tree = state.facet(treeFacet);
68
- tree.traverse((item, level) => {
69
- console.log(listItemToString(item, level));
70
- });
71
- });
72
- });
73
-
74
- describe('tree (advanced)', () => {
75
- let state: EditorState;
76
-
77
- beforeEach(() => {
78
- state = EditorState.create({ doc: str(...lines), extensions });
79
- });
80
-
81
- test('traverse', ({ expect }) => {
82
- const tree = state.facet(treeFacet);
83
- let count = 0;
84
- tree.traverse((item, level) => {
85
- console.log(listItemToString(item, level));
86
- count++;
87
- });
88
- expect(count).to.eq(9);
89
- });
90
-
91
- test('continguous', ({ expect }) => {
92
- const tree = state.facet(treeFacet);
93
- const ranges: Range[] = [];
94
- tree.traverse((item) => {
95
- console.log(listItemToString(item));
96
- ranges.push(item.lineRange);
97
- });
98
-
99
- // Check no gaps between ranges.
100
- expect(ranges[0].from).toBe(0);
101
- expect(ranges[ranges.length - 1].to).toBe(state.doc.length);
102
- for (let i = 0; i < ranges.length - 1; i++) {
103
- const current = ranges[i];
104
- const next = ranges[i + 1];
105
- expect(current.to + 1).to.eq(next.from);
106
- }
107
- });
108
-
109
- test('find', ({ expect }) => {
110
- const tree = state.facet(treeFacet);
111
- expect(tree.find(0)).to.include({ type: 'task' });
112
- expect(tree.find(state.doc.length)).to.include({ type: 'task' });
113
-
114
- expect(tree.find(getPos(1))).to.include({ type: 'task' });
115
- expect(tree.find(getPos(1))).to.eq(tree.find(getPos(1) + 4));
116
- expect(tree.find(getPos(5))).to.include({ type: 'bullet' });
117
- });
118
-
119
- test('siblings', ({ expect }) => {
120
- const tree = state.facet(treeFacet);
121
- const items: Item[] = [];
122
- tree.traverse((item) => {
123
- items.push(item);
124
- });
125
-
126
- expect(items[0].nextSibling).toBe(items[1]);
127
- expect(items[1].prevSibling).toBe(items[0]);
128
-
129
- expect(items[1].nextSibling).toBe(items[8]);
130
- expect(items[8].prevSibling).toBe(items[1]);
131
- });
132
-
133
- test('next/previous', ({ expect }) => {
134
- const tree = state.facet(treeFacet);
135
- const items: Item[] = [];
136
- tree.traverse((item) => {
137
- items.push(item);
138
- });
139
-
140
- expect(tree.prev(items[0])).not.to.exist;
141
- expect(tree.next(items[items.length - 1])).not.to.exist;
142
-
143
- for (let i = 0; i < items.length - 1; i++) {
144
- const current = items[i];
145
- const next = items[i + 1];
146
- expect(tree.next(current)?.index).toEqual(next.index);
147
- expect(tree.prev(next)?.index).toEqual(current.index);
148
- }
149
- });
150
-
151
- test('lastDescendant', ({ expect }) => {
152
- const tree = state.facet(treeFacet);
153
- {
154
- const item = tree.find(getPos(0))!;
155
- expect(tree.lastDescendant(item).index).to.eq(item.index);
156
- }
157
- {
158
- const item = tree.find(getPos(1))!;
159
- const last = tree.find(getPos(7))!;
160
- expect(tree.lastDescendant(item).index).to.eq(last.index);
161
- }
162
- {
163
- const item = tree.find(getPos(3))!;
164
- const last = tree.find(getPos(6))!;
165
- expect(tree.lastDescendant(item).index).to.eq(last.index);
166
- }
167
- });
168
- });