@dxos/plugin-markdown 0.8.4-main.ae835ea → 0.8.4-main.bcb3aa67d6

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 (357) hide show
  1. package/dist/lib/browser/MarkdownSettings-5AD3X3II.mjs +124 -0
  2. package/dist/lib/browser/MarkdownSettings-5AD3X3II.mjs.map +7 -0
  3. package/dist/lib/browser/blueprints/index.mjs +51 -0
  4. package/dist/lib/browser/blueprints/index.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-46WIDM4R.mjs +98 -0
  6. package/dist/lib/browser/chunk-46WIDM4R.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-GQKARRJU.mjs +158 -0
  8. package/dist/lib/browser/chunk-GQKARRJU.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  10. package/dist/lib/browser/cli/index.mjs +39 -0
  11. package/dist/lib/browser/cli/index.mjs.map +7 -0
  12. package/dist/lib/browser/create-I7QWPBMS.mjs +30 -0
  13. package/dist/lib/browser/create-I7QWPBMS.mjs.map +7 -0
  14. package/dist/lib/browser/create-markdown-6QQXSF3Q.mjs +22 -0
  15. package/dist/lib/browser/create-markdown-6QQXSF3Q.mjs.map +7 -0
  16. package/dist/lib/browser/index.mjs +632 -153
  17. package/dist/lib/browser/index.mjs.map +4 -4
  18. package/dist/lib/browser/meta.json +1 -1
  19. package/dist/lib/browser/open-NSBN4NKR.mjs +21 -0
  20. package/dist/lib/browser/open-NSBN4NKR.mjs.map +7 -0
  21. package/dist/lib/browser/operations/index.mjs +14 -0
  22. package/dist/lib/browser/operations/index.mjs.map +7 -0
  23. package/dist/lib/browser/scroll-to-anchor-RA5OMQCP.mjs +49 -0
  24. package/dist/lib/browser/scroll-to-anchor-RA5OMQCP.mjs.map +7 -0
  25. package/dist/lib/browser/set-view-mode-75MBU6CB.mjs +26 -0
  26. package/dist/lib/browser/set-view-mode-75MBU6CB.mjs.map +7 -0
  27. package/dist/lib/browser/types/index.mjs +11 -5
  28. package/dist/lib/browser/update-QQJYONAC.mjs +45 -0
  29. package/dist/lib/browser/update-QQJYONAC.mjs.map +7 -0
  30. package/dist/lib/node-esm/MarkdownSettings-ODDM67XG.mjs +125 -0
  31. package/dist/lib/node-esm/MarkdownSettings-ODDM67XG.mjs.map +7 -0
  32. package/dist/lib/node-esm/blueprints/index.mjs +52 -0
  33. package/dist/lib/node-esm/blueprints/index.mjs.map +7 -0
  34. package/dist/lib/node-esm/chunk-4MSJO6IJ.mjs +99 -0
  35. package/dist/lib/node-esm/chunk-4MSJO6IJ.mjs.map +7 -0
  36. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  37. package/dist/lib/node-esm/chunk-QRCQ55W7.mjs +159 -0
  38. package/dist/lib/node-esm/chunk-QRCQ55W7.mjs.map +7 -0
  39. package/dist/lib/node-esm/cli/index.mjs +40 -0
  40. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  41. package/dist/lib/node-esm/create-VJ5SIKYF.mjs +31 -0
  42. package/dist/lib/node-esm/create-VJ5SIKYF.mjs.map +7 -0
  43. package/dist/lib/node-esm/create-markdown-P5KNGLZ5.mjs +23 -0
  44. package/dist/lib/node-esm/create-markdown-P5KNGLZ5.mjs.map +7 -0
  45. package/dist/lib/node-esm/index.mjs +632 -153
  46. package/dist/lib/node-esm/index.mjs.map +4 -4
  47. package/dist/lib/node-esm/meta.json +1 -1
  48. package/dist/lib/node-esm/open-U3T6IVHN.mjs +22 -0
  49. package/dist/lib/node-esm/open-U3T6IVHN.mjs.map +7 -0
  50. package/dist/lib/node-esm/operations/index.mjs +15 -0
  51. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  52. package/dist/lib/node-esm/scroll-to-anchor-CVM3LVSQ.mjs +50 -0
  53. package/dist/lib/node-esm/scroll-to-anchor-CVM3LVSQ.mjs.map +7 -0
  54. package/dist/lib/node-esm/set-view-mode-WQJBCUXY.mjs +27 -0
  55. package/dist/lib/node-esm/set-view-mode-WQJBCUXY.mjs.map +7 -0
  56. package/dist/lib/node-esm/types/index.mjs +11 -5
  57. package/dist/lib/node-esm/update-24CQM75C.mjs +46 -0
  58. package/dist/lib/node-esm/update-24CQM75C.mjs.map +7 -0
  59. package/dist/types/src/MarkdownPlugin.d.ts +2 -1
  60. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  61. package/dist/types/src/blueprints/index.d.ts +2 -0
  62. package/dist/types/src/blueprints/index.d.ts.map +1 -0
  63. package/dist/types/src/blueprints/markdown-blueprint.d.ts +4 -0
  64. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -0
  65. package/dist/types/src/capabilities/anchor-sort.d.ts +4 -4
  66. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
  67. package/dist/types/src/capabilities/app-graph-serializer.d.ts +3 -2
  68. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/artifact-definition.d.ts +3 -1
  70. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  71. package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -4
  72. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
  73. package/dist/types/src/capabilities/index.d.ts +27 -18
  74. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/node.d.ts +4 -0
  76. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  77. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  78. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  79. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  80. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  81. package/dist/types/src/capabilities/settings.d.ts +22 -2
  82. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  83. package/dist/types/src/capabilities/state.d.ts +4 -9
  84. package/dist/types/src/capabilities/state.d.ts.map +1 -1
  85. package/dist/types/src/cli/index.d.ts +2 -0
  86. package/dist/types/src/cli/index.d.ts.map +1 -0
  87. package/dist/types/src/cli/plugin.d.ts +3 -0
  88. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  89. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +1 -1
  90. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  91. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +19 -13
  92. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  93. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +2 -2
  94. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  95. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +20 -14
  96. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  97. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +10 -5
  98. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  99. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -4
  100. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  101. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +138 -0
  102. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  103. package/dist/types/src/components/MarkdownSettings/index.d.ts +2 -1
  104. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  105. package/dist/types/src/components/index.d.ts +3 -5
  106. package/dist/types/src/components/index.d.ts.map +1 -1
  107. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts +8 -0
  108. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  109. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
  110. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  111. package/dist/types/src/{components → containers}/MarkdownCard/index.d.ts +0 -1
  112. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  113. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +15 -0
  114. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  115. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +31 -0
  116. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  117. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +99 -0
  118. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  119. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  120. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  121. package/dist/types/src/containers/index.d.ts +5 -0
  122. package/dist/types/src/containers/index.d.ts.map +1 -0
  123. package/dist/types/src/hooks/index.d.ts +1 -2
  124. package/dist/types/src/hooks/index.d.ts.map +1 -1
  125. package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
  126. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
  127. package/dist/types/src/hooks/useExtensions.d.ts +10 -8
  128. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  129. package/dist/types/src/hooks/useLinkQuery.d.ts +3 -3
  130. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  131. package/dist/types/src/index.d.ts +2 -2
  132. package/dist/types/src/index.d.ts.map +1 -1
  133. package/dist/types/src/meta.d.ts +2 -2
  134. package/dist/types/src/meta.d.ts.map +1 -1
  135. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  136. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  137. package/dist/types/src/operations/create.d.ts +5 -0
  138. package/dist/types/src/operations/create.d.ts.map +1 -0
  139. package/dist/types/src/operations/create.test.d.ts +2 -0
  140. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  141. package/dist/types/src/operations/definitions.d.ts +64 -0
  142. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  143. package/dist/types/src/operations/index.d.ts +4 -0
  144. package/dist/types/src/operations/index.d.ts.map +1 -0
  145. package/dist/types/src/operations/open.d.ts +5 -0
  146. package/dist/types/src/operations/open.d.ts.map +1 -0
  147. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  148. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  149. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  150. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  151. package/dist/types/src/operations/update.d.ts +5 -0
  152. package/dist/types/src/operations/update.d.ts.map +1 -0
  153. package/dist/types/src/operations/update.test.d.ts +2 -0
  154. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  155. package/dist/types/src/testing.d.ts +6 -0
  156. package/dist/types/src/testing.d.ts.map +1 -0
  157. package/dist/types/src/translations.d.ts +75 -34
  158. package/dist/types/src/translations.d.ts.map +1 -1
  159. package/dist/types/src/types/Markdown.d.ts +30 -31
  160. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  161. package/dist/types/src/types/Settings.d.ts +16 -0
  162. package/dist/types/src/types/Settings.d.ts.map +1 -0
  163. package/dist/types/src/types/capabilities.d.ts +51 -0
  164. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  165. package/dist/types/src/types/events.d.ts +5 -0
  166. package/dist/types/src/types/events.d.ts.map +1 -0
  167. package/dist/types/src/types/index.d.ts +4 -2
  168. package/dist/types/src/types/index.d.ts.map +1 -1
  169. package/dist/types/src/types/types.d.ts +2 -2
  170. package/dist/types/src/types/types.d.ts.map +1 -1
  171. package/dist/types/src/util.d.ts +7 -4
  172. package/dist/types/src/util.d.ts.map +1 -1
  173. package/dist/types/src/util.test.d.ts +2 -0
  174. package/dist/types/src/util.test.d.ts.map +1 -0
  175. package/dist/types/tsconfig.tsbuildinfo +1 -1
  176. package/package.json +119 -59
  177. package/src/MarkdownPlugin.tsx +77 -103
  178. package/src/blueprints/index.ts +5 -0
  179. package/src/blueprints/markdown-blueprint.ts +44 -0
  180. package/src/capabilities/anchor-sort.ts +29 -22
  181. package/src/capabilities/app-graph-serializer.ts +51 -41
  182. package/src/capabilities/artifact-definition.ts +82 -84
  183. package/src/capabilities/blueprint-definition.ts +9 -31
  184. package/src/capabilities/index.ts +12 -12
  185. package/src/capabilities/node.ts +11 -0
  186. package/src/capabilities/operation-handler.ts +16 -0
  187. package/src/capabilities/react-surface.tsx +108 -80
  188. package/src/capabilities/settings.ts +30 -18
  189. package/src/capabilities/state.ts +41 -25
  190. package/src/cli/index.ts +5 -0
  191. package/src/cli/plugin.ts +40 -0
  192. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  193. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +39 -41
  194. package/src/components/MarkdownEditor/MarkdownEditor.tsx +87 -57
  195. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +69 -34
  196. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +48 -53
  197. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  198. package/src/components/MarkdownSettings/MarkdownSettings.tsx +116 -86
  199. package/src/components/MarkdownSettings/index.ts +3 -1
  200. package/src/components/index.ts +4 -7
  201. package/src/containers/MarkdownCard/MarkdownCard.stories.tsx +68 -0
  202. package/src/containers/MarkdownCard/MarkdownCard.tsx +57 -0
  203. package/src/{components → containers}/MarkdownCard/index.ts +0 -2
  204. package/src/containers/MarkdownCard/snippet.ts +75 -0
  205. package/src/containers/MarkdownContainer/MarkdownContainer.stories.tsx +133 -0
  206. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +134 -0
  207. package/src/containers/MarkdownContainer/index.ts +6 -0
  208. package/src/containers/index.ts +10 -0
  209. package/src/hooks/index.ts +1 -2
  210. package/src/hooks/{usePopoverMenuOptions.ts → useEditorMenuOptions.ts} +20 -23
  211. package/src/hooks/useExtensions.tsx +100 -109
  212. package/src/hooks/useLinkQuery.ts +49 -23
  213. package/src/index.ts +3 -2
  214. package/src/meta.ts +3 -3
  215. package/src/operations/create-markdown.ts +21 -0
  216. package/src/operations/create.conversations.json +1 -0
  217. package/src/operations/create.test.ts +98 -0
  218. package/src/operations/create.ts +27 -0
  219. package/src/operations/definitions.ts +119 -0
  220. package/src/operations/index.ts +16 -0
  221. package/src/operations/open.ts +25 -0
  222. package/src/operations/scroll-to-anchor.ts +40 -0
  223. package/src/operations/set-view-mode.ts +25 -0
  224. package/src/operations/update.conversations.json +1 -0
  225. package/src/operations/update.test.ts +215 -0
  226. package/src/operations/update.ts +51 -0
  227. package/src/testing.ts +27 -0
  228. package/src/translations.ts +49 -34
  229. package/src/types/Markdown.ts +23 -31
  230. package/src/types/Settings.ts +28 -0
  231. package/src/types/capabilities.ts +50 -0
  232. package/src/types/events.ts +14 -0
  233. package/src/types/index.ts +5 -2
  234. package/src/types/types.ts +3 -2
  235. package/src/util.test.ts +44 -0
  236. package/src/util.tsx +80 -12
  237. package/dist/lib/browser/MarkdownCard-SLM6QZYC.mjs +0 -12
  238. package/dist/lib/browser/MarkdownContainer-UZFQC6XY.mjs +0 -15
  239. package/dist/lib/browser/anchor-sort-4XPPLMZS.mjs +0 -32
  240. package/dist/lib/browser/anchor-sort-4XPPLMZS.mjs.map +0 -7
  241. package/dist/lib/browser/app-graph-serializer-QQFV4K6P.mjs +0 -51
  242. package/dist/lib/browser/app-graph-serializer-QQFV4K6P.mjs.map +0 -7
  243. package/dist/lib/browser/blueprint-definition-BC5R3T72.mjs +0 -11
  244. package/dist/lib/browser/blueprint-definition-BC5R3T72.mjs.map +0 -7
  245. package/dist/lib/browser/chunk-2LLVTQCK.mjs +0 -51
  246. package/dist/lib/browser/chunk-2LLVTQCK.mjs.map +0 -7
  247. package/dist/lib/browser/chunk-3VILQLA4.mjs +0 -95
  248. package/dist/lib/browser/chunk-3VILQLA4.mjs.map +0 -7
  249. package/dist/lib/browser/chunk-5AYTOIUF.mjs +0 -822
  250. package/dist/lib/browser/chunk-5AYTOIUF.mjs.map +0 -7
  251. package/dist/lib/browser/chunk-A3CQYGCN.mjs +0 -56
  252. package/dist/lib/browser/chunk-A3CQYGCN.mjs.map +0 -7
  253. package/dist/lib/browser/chunk-BQTYJOFB.mjs +0 -28
  254. package/dist/lib/browser/chunk-BQTYJOFB.mjs.map +0 -7
  255. package/dist/lib/browser/chunk-GLEYXJX3.mjs +0 -22
  256. package/dist/lib/browser/chunk-GLEYXJX3.mjs.map +0 -7
  257. package/dist/lib/browser/chunk-IBCHVMZW.mjs +0 -16
  258. package/dist/lib/browser/chunk-IBCHVMZW.mjs.map +0 -7
  259. package/dist/lib/browser/chunk-JAETS5LE.mjs +0 -106
  260. package/dist/lib/browser/chunk-JAETS5LE.mjs.map +0 -7
  261. package/dist/lib/browser/chunk-UKTCPHLI.mjs +0 -79
  262. package/dist/lib/browser/chunk-UKTCPHLI.mjs.map +0 -7
  263. package/dist/lib/browser/intent-resolver-VQGMBNXZ.mjs +0 -62
  264. package/dist/lib/browser/intent-resolver-VQGMBNXZ.mjs.map +0 -7
  265. package/dist/lib/browser/react-surface-WOMJOPJE.mjs +0 -217
  266. package/dist/lib/browser/react-surface-WOMJOPJE.mjs.map +0 -7
  267. package/dist/lib/browser/settings-LBXJHVBU.mjs +0 -28
  268. package/dist/lib/browser/settings-LBXJHVBU.mjs.map +0 -7
  269. package/dist/lib/browser/state-BTUKVZHY.mjs +0 -37
  270. package/dist/lib/browser/state-BTUKVZHY.mjs.map +0 -7
  271. package/dist/lib/browser/toolkit-YPIVDB4A.mjs +0 -66
  272. package/dist/lib/browser/toolkit-YPIVDB4A.mjs.map +0 -7
  273. package/dist/lib/node-esm/MarkdownCard-MCWEFW4F.mjs +0 -13
  274. package/dist/lib/node-esm/MarkdownCard-MCWEFW4F.mjs.map +0 -7
  275. package/dist/lib/node-esm/MarkdownContainer-KAQOK7K5.mjs +0 -16
  276. package/dist/lib/node-esm/MarkdownContainer-KAQOK7K5.mjs.map +0 -7
  277. package/dist/lib/node-esm/anchor-sort-4SXYVYXT.mjs +0 -33
  278. package/dist/lib/node-esm/anchor-sort-4SXYVYXT.mjs.map +0 -7
  279. package/dist/lib/node-esm/app-graph-serializer-KBVRLQN2.mjs +0 -52
  280. package/dist/lib/node-esm/app-graph-serializer-KBVRLQN2.mjs.map +0 -7
  281. package/dist/lib/node-esm/blueprint-definition-FPNOTEYC.mjs +0 -12
  282. package/dist/lib/node-esm/blueprint-definition-FPNOTEYC.mjs.map +0 -7
  283. package/dist/lib/node-esm/chunk-2Q4WCKWT.mjs +0 -823
  284. package/dist/lib/node-esm/chunk-2Q4WCKWT.mjs.map +0 -7
  285. package/dist/lib/node-esm/chunk-DOB2MJAX.mjs +0 -107
  286. package/dist/lib/node-esm/chunk-DOB2MJAX.mjs.map +0 -7
  287. package/dist/lib/node-esm/chunk-GGKPPGWA.mjs +0 -24
  288. package/dist/lib/node-esm/chunk-GGKPPGWA.mjs.map +0 -7
  289. package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs +0 -17
  290. package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs.map +0 -7
  291. package/dist/lib/node-esm/chunk-JELROKGD.mjs +0 -80
  292. package/dist/lib/node-esm/chunk-JELROKGD.mjs.map +0 -7
  293. package/dist/lib/node-esm/chunk-QH4MC5BE.mjs +0 -52
  294. package/dist/lib/node-esm/chunk-QH4MC5BE.mjs.map +0 -7
  295. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs +0 -29
  296. package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs.map +0 -7
  297. package/dist/lib/node-esm/chunk-SJ2QRGPM.mjs +0 -57
  298. package/dist/lib/node-esm/chunk-SJ2QRGPM.mjs.map +0 -7
  299. package/dist/lib/node-esm/chunk-YYSASY7X.mjs +0 -96
  300. package/dist/lib/node-esm/chunk-YYSASY7X.mjs.map +0 -7
  301. package/dist/lib/node-esm/intent-resolver-Q4XVI5EX.mjs +0 -63
  302. package/dist/lib/node-esm/intent-resolver-Q4XVI5EX.mjs.map +0 -7
  303. package/dist/lib/node-esm/react-surface-FAMZTAXK.mjs +0 -218
  304. package/dist/lib/node-esm/react-surface-FAMZTAXK.mjs.map +0 -7
  305. package/dist/lib/node-esm/settings-2YRA67H6.mjs +0 -29
  306. package/dist/lib/node-esm/settings-2YRA67H6.mjs.map +0 -7
  307. package/dist/lib/node-esm/state-K6EH7SRZ.mjs +0 -38
  308. package/dist/lib/node-esm/state-K6EH7SRZ.mjs.map +0 -7
  309. package/dist/lib/node-esm/toolkit-36BFLIR3.mjs +0 -67
  310. package/dist/lib/node-esm/toolkit-36BFLIR3.mjs.map +0 -7
  311. package/dist/types/src/capabilities/capabilities.d.ts +0 -12
  312. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  313. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -4
  314. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  315. package/dist/types/src/capabilities/toolkit.d.ts +0 -20
  316. package/dist/types/src/capabilities/toolkit.d.ts.map +0 -1
  317. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +0 -7
  318. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  319. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -9
  320. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  321. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  322. package/dist/types/src/components/MarkdownContainer.d.ts +0 -14
  323. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  324. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -58
  325. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  326. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  327. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  328. package/dist/types/src/events.d.ts +0 -4
  329. package/dist/types/src/events.d.ts.map +0 -1
  330. package/dist/types/src/functions/diff.d.ts +0 -6
  331. package/dist/types/src/functions/diff.d.ts.map +0 -1
  332. package/dist/types/src/functions/index.d.ts +0 -3
  333. package/dist/types/src/functions/index.d.ts.map +0 -1
  334. package/dist/types/src/functions/open.d.ts +0 -7
  335. package/dist/types/src/functions/open.d.ts.map +0 -1
  336. package/dist/types/src/hooks/usePopoverMenuOptions.d.ts +0 -9
  337. package/dist/types/src/hooks/usePopoverMenuOptions.d.ts.map +0 -1
  338. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  339. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  340. package/dist/types/src/types/MarkdownAction.d.ts +0 -34
  341. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  342. package/src/capabilities/capabilities.ts +0 -22
  343. package/src/capabilities/intent-resolver.ts +0 -58
  344. package/src/capabilities/toolkit.ts +0 -53
  345. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +0 -76
  346. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -85
  347. package/src/components/MarkdownContainer.stories.tsx +0 -137
  348. package/src/components/MarkdownContainer.tsx +0 -121
  349. package/src/components/Suggestions.stories.tsx +0 -219
  350. package/src/events.ts +0 -11
  351. package/src/functions/diff.ts +0 -37
  352. package/src/functions/index.ts +0 -6
  353. package/src/functions/open.ts +0 -32
  354. package/src/hooks/useSelectCurrentThread.tsx +0 -56
  355. package/src/types/MarkdownAction.ts +0 -29
  356. /package/dist/lib/browser/{MarkdownCard-SLM6QZYC.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  357. /package/dist/lib/{browser/MarkdownContainer-UZFQC6XY.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
@@ -1,169 +1,648 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- translations
4
- } from "./chunk-SJ2QRGPM.mjs";
5
- import {
6
- AnchorSort,
7
- AppGraphSerializer,
8
- BlueprintDefinition,
9
- IntentResolver,
10
- MarkdownSettings,
11
- MarkdownState,
12
- ReactSurface,
13
- Toolkit
14
- } from "./chunk-GGKPPGWA.mjs";
15
- import {
16
- ASSISTANT_BLUEPRINT_KEY
17
- } from "./chunk-DOB2MJAX.mjs";
18
- import {
19
- MarkdownCapabilities
20
- } from "./chunk-GMMVSXQ6.mjs";
21
- import {
22
- getContentSnippet,
23
- getFallbackName,
24
- isEditorModel,
25
- isMarkdownProperties,
26
- serializer,
27
- setFallbackName
28
- } from "./chunk-QH4MC5BE.mjs";
29
- import {
30
- MarkdownAction_exports,
31
- Markdown_exports
32
- } from "./chunk-JELROKGD.mjs";
33
- import {
34
- meta
35
- } from "./chunk-SHAMSMKQ.mjs";
3
+ MarkdownCapabilities,
4
+ MarkdownEvents,
5
+ MarkdownStateSchema,
6
+ Markdown_exports,
7
+ Settings_exports
8
+ } from "./chunk-4MSJO6IJ.mjs";
9
+ import "./chunk-HSLMI22Q.mjs";
36
10
 
37
- // src/events.ts
38
- import { Events } from "@dxos/app-framework";
39
- (function(MarkdownEvents2) {
40
- MarkdownEvents2.SetupExtensions = Events.createStateEvent(`${meta.id}/event/setup-extensions`);
41
- })(MarkdownEvents || (MarkdownEvents = {}));
42
- var MarkdownEvents;
11
+ // src/meta.ts
12
+ import { trim } from "@dxos/util";
13
+ var meta = {
14
+ id: "org.dxos.plugin.markdown",
15
+ name: "Markdown",
16
+ description: trim`
17
+ Full-featured collaborative markdown editor with real-time editing, inline comments, and rich formatting.
18
+ Supports AI-powered editing assistance and seamlessly integrates with other workspace objects.
19
+ `,
20
+ icon: "ph--text-aa--regular",
21
+ iconHue: "indigo",
22
+ source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-markdown",
23
+ screenshots: [
24
+ "https://dxos.network/plugin-details-markdown-dark.png"
25
+ ]
26
+ };
27
+
28
+ // src/util.tsx
29
+ import { debounce } from "@dxos/async";
30
+ import { Obj } from "@dxos/echo";
31
+ import { Markdown } from "#types";
32
+ var isEditorModel = (data) => data && typeof data === "object" && "id" in data && typeof data.id === "string" && "text" in data && typeof data.text === "string";
33
+ var isMarkdownProperties = (data) => Obj.isObject(data) ? true : data && typeof data === "object" ? "title" in data && typeof data.title === "string" : false;
34
+ var nonTitleChars = /[^\w ]/g;
35
+ var skipPatterns = [
36
+ /^!\[/,
37
+ /^---\s*$/,
38
+ /^```/,
39
+ /^\s*$/
40
+ ];
41
+ var titlePatterns = [
42
+ /^#{1,6}\s+(.+)/
43
+ ];
44
+ var getFallbackName = (content = "") => {
45
+ const len = content.length;
46
+ let i = 0;
47
+ while (i < len) {
48
+ let lineEnd = i;
49
+ while (lineEnd < len && content[lineEnd] !== "\n") {
50
+ lineEnd++;
51
+ }
52
+ const line = content.slice(i, lineEnd).trim();
53
+ i = lineEnd + 1;
54
+ if (skipPatterns.some((pattern) => pattern.test(line))) {
55
+ continue;
56
+ }
57
+ for (const pattern of titlePatterns) {
58
+ const match = pattern.exec(line);
59
+ if (match) {
60
+ const text2 = match[1].replaceAll(nonTitleChars, "").trim();
61
+ if (text2.length > 0) {
62
+ return text2;
63
+ }
64
+ }
65
+ }
66
+ const maxLen = 32;
67
+ const text = line.replaceAll(nonTitleChars, "").trim();
68
+ if (text.length > 0) {
69
+ if (text.length > maxLen) {
70
+ const words = text.split(/\s+/);
71
+ let result = "";
72
+ for (const word of words) {
73
+ const next = result.length === 0 ? word : result + " " + word;
74
+ if (next.length > maxLen) {
75
+ break;
76
+ }
77
+ result = next;
78
+ }
79
+ return result + "\u2026";
80
+ }
81
+ return text;
82
+ }
83
+ }
84
+ return "";
85
+ };
86
+ var getContentSnippet = (content = "", maxLines = 3) => {
87
+ const abstract = content.split("\n").filter((line) => !line.startsWith("!")).filter((line) => line.trim() !== "");
88
+ return abstract.slice(0, maxLines).join("\n") ?? "";
89
+ };
90
+ var setFallbackName = debounce((doc, content = "") => {
91
+ const name = getFallbackName(content);
92
+ if (doc.fallbackName !== name) {
93
+ Obj.change(doc, (obj) => {
94
+ obj.fallbackName = name;
95
+ });
96
+ }
97
+ }, 200);
98
+ var serializer = {
99
+ serialize: async ({ object }) => {
100
+ const { content } = await object.content.load();
101
+ return JSON.stringify({
102
+ name: object.name,
103
+ fallbackName: object.fallbackName,
104
+ content
105
+ });
106
+ },
107
+ deserialize: async ({ content: serialized }) => {
108
+ const { name, fallbackName, content } = JSON.parse(serialized);
109
+ return Markdown.make({
110
+ name,
111
+ fallbackName,
112
+ content
113
+ });
114
+ }
115
+ };
43
116
 
44
117
  // src/MarkdownPlugin.tsx
45
- import { Capabilities, Events as Events2, contributes, createIntent, defineModule, definePlugin } from "@dxos/app-framework";
46
- import { Ref } from "@dxos/echo";
47
- import { ClientCapabilities, ClientEvents } from "@dxos/plugin-client";
48
- import { SpaceCapabilities } from "@dxos/plugin-space";
49
- import { defineObjectForm } from "@dxos/plugin-space/types";
50
- import { createDocAccessor, getTextInRange } from "@dxos/react-client/echo";
118
+ import * as Effect from "effect/Effect";
119
+ import * as Option from "effect/Option";
120
+ import { Plugin } from "@dxos/app-framework";
121
+ import { AppActivationEvents, AppPlugin } from "@dxos/app-toolkit";
122
+ import { Annotation, Ref } from "@dxos/echo";
123
+ import { createDocAccessor, getTextInRange } from "@dxos/echo-db";
124
+ import { Operation } from "@dxos/operation";
125
+ import { SpaceOperation } from "@dxos/plugin-space/operations";
126
+ import { translations as editorTranslations2 } from "@dxos/react-ui-editor";
127
+ import { Text } from "@dxos/schema";
128
+ import { MarkdownBlueprint } from "#blueprints";
129
+ import { meta as meta3 } from "#meta";
130
+
131
+ // src/translations.ts
51
132
  import { translations as editorTranslations } from "@dxos/react-ui-editor";
52
- import { DataType } from "@dxos/schema";
53
- var MarkdownPlugin = definePlugin(meta, () => [
54
- defineModule({
55
- id: `${meta.id}/module/translations`,
56
- activatesOn: Events2.SetupTranslations,
57
- activate: () => contributes(Capabilities.Translations, [
58
- ...translations,
59
- ...editorTranslations
60
- ])
61
- }),
62
- defineModule({
63
- id: `${meta.id}/module/settings`,
64
- activatesOn: Events2.SetupSettings,
65
- activate: MarkdownSettings
66
- }),
67
- defineModule({
68
- id: `${meta.id}/module/state`,
69
- // TODO(wittjosiah): Does not integrate with settings store.
70
- // Should this be a different event?
71
- // Should settings store be renamed to be more generic?
72
- activatesOn: Events2.SetupSettings,
73
- activate: MarkdownState
74
- }),
75
- defineModule({
76
- id: `${meta.id}/module/metadata`,
77
- activatesOn: Events2.SetupMetadata,
78
- activate: () => contributes(Capabilities.Metadata, {
79
- id: Markdown_exports.Document.typename,
80
- metadata: {
81
- label: (object) => object.name || object.fallbackName,
82
- icon: "ph--text-aa--regular",
83
- iconHue: "indigo",
84
- blueprints: [
85
- ASSISTANT_BLUEPRINT_KEY
86
- ],
87
- graphProps: {
88
- managesAutofocus: true
89
- },
90
- // TODO(wittjosiah): Move out of metadata.
91
- loadReferences: async (doc) => await Ref.Array.loadAll([
92
- doc.content
93
- ]),
94
- serializer,
95
- // TODO(wittjosiah): Consider how to do generic comments without these.
96
- comments: "anchored",
97
- selectionMode: "multi-range",
98
- getAnchorLabel: (doc, anchor) => {
99
- if (doc.content) {
100
- const [start, end] = anchor.split(":");
101
- return getTextInRange(createDocAccessor(doc.content.target, [
102
- "content"
103
- ]), start, end);
133
+ import { meta as meta2 } from "#meta";
134
+ import { Markdown as Markdown2 } from "#types";
135
+ var translations = [
136
+ {
137
+ "en-US": {
138
+ [Markdown2.Document.typename]: {
139
+ "typename.label": "Document",
140
+ "typename.label_zero": "Documents",
141
+ "typename.label_one": "Document",
142
+ "typename.label_other": "Documents",
143
+ "object-name.placeholder": "New document",
144
+ "add-object.label": "Add document",
145
+ "rename-object.label": "Rename document",
146
+ "delete-object.label": "Delete document",
147
+ "object-deleted.label": "Document deleted"
148
+ },
149
+ [meta2.id]: {
150
+ "plugin.name": "Editor",
151
+ "settings.title": "Editor settings",
152
+ "choose-markdown-from-space-dialog.title": "Choose one or more documents to add",
153
+ // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)
154
+ "empty-choose-markdown-from-space.message": "None available; try creating a new one instead?",
155
+ "chooser-done.label": "Add selected",
156
+ "editor.placeholder": "Start typing\u2026",
157
+ "editor-input-mode.label": "Editor input mode",
158
+ "editor-input-mode.description": "Choose keyboard bindings for the editor.",
159
+ "select-editor-input-mode.placeholder": "Select editor input mode\u2026",
160
+ "settings.editor-input-mode.default.label": "Default",
161
+ "settings.editor-input-mode.vim.label": "Vim",
162
+ "settings.editor-input-mode.vscode.label": "VS Code",
163
+ "settings.toolbar.label": "Show toolbar",
164
+ "settings.toolbar.description": "Display a formatting toolbar above the editor.",
165
+ "settings.numbered-headings.label": "Numbered headings",
166
+ "settings.numbered-headings.description": "Automatically number heading levels in the document.",
167
+ "settings.folding.label": "Folding",
168
+ "settings.folding.description": "Allow collapsing and expanding sections by heading.",
169
+ "settings.experimental.label": "Enable experimental features",
170
+ "settings.experimental.description": "Turn on features that are still in development.",
171
+ "settings.debug.label": "Enable debugging features",
172
+ "settings.debug.description": "Show developer tools and diagnostics for the editor.",
173
+ "settings.debug-typewriter.label": "Typewriter script",
174
+ "settings.debug-typewriter.description": "Script to replay typed input for testing purposes.",
175
+ "settings.debug-typewriter.placeholder": "Typewriter script...",
176
+ "toggle-view-mode.label": "Toggle read-only",
177
+ "default-view-mode.label": "Default view mode",
178
+ "default-view-mode.description": "Set whether documents open in editing or read-only mode.",
179
+ "upload-image.label": "Upload image",
180
+ "fallback.title": "Untitled",
181
+ "navigate-to-document.label": "Open document",
182
+ "words.label": "words",
183
+ "words.label_zero": "words",
184
+ "words.label_one": "word",
185
+ "words.label_other": "words"
186
+ }
187
+ }
188
+ },
189
+ ...editorTranslations
190
+ ];
191
+
192
+ // src/MarkdownPlugin.tsx
193
+ import { Markdown as Markdown3, MarkdownEvents as MarkdownEvents2 } from "#types";
194
+ import { MarkdownOperation } from "#operations";
195
+ import { AnchorSort, AppGraphSerializer, BlueprintDefinition, MarkdownSettings, MarkdownState, OperationHandler, ReactSurface } from "#capabilities";
196
+ var MarkdownPlugin = Plugin.define(meta3).pipe(AppPlugin.addBlueprintDefinitionModule({
197
+ activate: BlueprintDefinition
198
+ }), AppPlugin.addMetadataModule({
199
+ metadata: {
200
+ id: Markdown3.Document.typename,
201
+ metadata: {
202
+ // TODO(dmaretskyi): Remove label, icon and iconHue and query them of schema.
203
+ label: (object) => object.name || object.fallbackName,
204
+ icon: Annotation.IconAnnotation.get(Markdown3.Document).pipe(Option.getOrThrow).icon,
205
+ iconHue: Annotation.IconAnnotation.get(Markdown3.Document).pipe(Option.getOrThrow).hue ?? "white",
206
+ blueprints: [
207
+ MarkdownBlueprint.key
208
+ ],
209
+ graphProps: {
210
+ managesAutofocus: true
211
+ },
212
+ // TODO(wittjosiah): Move out of metadata.
213
+ loadReferences: async (doc) => await Ref.Array.loadAll([
214
+ doc.content
215
+ ]),
216
+ serializer,
217
+ // TODO(wittjosiah): Consider how to do generic comments without these.
218
+ comments: "anchored",
219
+ selectionMode: "multi-range",
220
+ getAnchorLabel: (doc, anchor) => {
221
+ if (doc.content) {
222
+ const [start, end] = anchor.split(":");
223
+ return getTextInRange(createDocAccessor(doc.content.target, [
224
+ "content"
225
+ ]), start, end);
226
+ }
227
+ },
228
+ createObject: (props, options) => Effect.gen(function* () {
229
+ const object = Markdown3.make(props);
230
+ return yield* Operation.invoke(SpaceOperation.AddObject, {
231
+ object,
232
+ target: options.target,
233
+ hidden: true,
234
+ targetNodeId: options.targetNodeId
235
+ });
236
+ }),
237
+ scrollToAnchor: MarkdownOperation.ScrollToAnchor
238
+ }
239
+ }
240
+ }), AppPlugin.addOperationHandlerModule({
241
+ activate: OperationHandler
242
+ }), AppPlugin.addSchemaModule({
243
+ schema: [
244
+ Markdown3.Document,
245
+ Text.Text
246
+ ]
247
+ }), AppPlugin.addSurfaceModule({
248
+ activate: ReactSurface,
249
+ activatesBefore: [
250
+ MarkdownEvents2.SetupExtensions
251
+ ]
252
+ }), AppPlugin.addTranslationsModule({
253
+ translations: [
254
+ ...translations,
255
+ ...editorTranslations2
256
+ ]
257
+ }), Plugin.addModule({
258
+ activatesOn: AppActivationEvents.SetupSettings,
259
+ activate: MarkdownSettings
260
+ }), Plugin.addModule({
261
+ id: "state",
262
+ // TODO(wittjosiah): Does not integrate with settings store.
263
+ // Should this be a different event?
264
+ // Should settings store be renamed to be more generic?
265
+ activatesOn: AppActivationEvents.SetupSettings,
266
+ activate: MarkdownState
267
+ }), Plugin.addModule({
268
+ activatesOn: AppActivationEvents.AppGraphReady,
269
+ activate: AppGraphSerializer
270
+ }), Plugin.addModule({
271
+ // TODO(wittjosiah): More relevant event?
272
+ activatesOn: AppActivationEvents.AppGraphReady,
273
+ activate: AnchorSort
274
+ }), Plugin.make);
275
+
276
+ // src/components/index.ts
277
+ import { lazy } from "react";
278
+
279
+ // src/components/MarkdownEditor/MarkdownEditor.tsx
280
+ import { createContext } from "@radix-ui/react-context";
281
+ import React4, { useMemo as useMemo2, useState as useState2 } from "react";
282
+ import { createPortal as createPortal2 } from "react-dom";
283
+ import { Surface } from "@dxos/app-framework/ui";
284
+ import { Obj as Obj2 } from "@dxos/echo";
285
+ import { DXN } from "@dxos/keys";
286
+ import { useClient } from "@dxos/react-client";
287
+ import { EditorMenuProvider, useEditorMenu, useEditorToolbar } from "@dxos/react-ui-editor";
288
+ import { composable as composable2, composableProps as composableProps2 } from "@dxos/ui-theme";
289
+ import { isNonNullable } from "@dxos/util";
290
+ import { useEditorMenuOptions, useExtensions } from "#hooks";
291
+
292
+ // src/components/MarkdownEditor/MarkdownEditorContent.tsx
293
+ import { RegistryContext } from "@effect-atom/atom-react";
294
+ import React, { forwardRef, useCallback, useContext, useEffect, useImperativeHandle, useMemo } from "react";
295
+ import { useCapabilities } from "@dxos/app-framework/ui";
296
+ import { useThemeContext, useTranslation } from "@dxos/react-ui";
297
+ import { useTextEditor } from "@dxos/react-ui-editor";
298
+ import { compactSlots, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, documentSlots, formattingListener, processEditorPayload, editorClassNames } from "@dxos/ui-editor";
299
+ import { mx } from "@dxos/ui-theme";
300
+ import { isTruthy } from "@dxos/util";
301
+ import { meta as meta4 } from "#meta";
302
+ import { MarkdownCapabilities as MarkdownCapabilities2 } from "#types";
303
+ var MarkdownEditorContent = /* @__PURE__ */ forwardRef(({ classNames, id, attendableId, role, compact, viewMode, initialValue, editorStateStore, toolbarState, extensions, slots, onFileUpload }, forwardedRef) => {
304
+ const { t } = useTranslation(meta4.id);
305
+ const { themeMode } = useThemeContext();
306
+ const registry = useContext(RegistryContext);
307
+ const updateToolbarState = useCallback((formatting) => {
308
+ if (toolbarState) {
309
+ registry.set(toolbarState, {
310
+ ...registry.get(toolbarState),
311
+ ...formatting
312
+ });
313
+ }
314
+ }, [
315
+ registry,
316
+ toolbarState
317
+ ]);
318
+ const { scrollTo, selection } = useMemo(() => editorStateStore?.getState(id) ?? {}, [
319
+ id
320
+ ]);
321
+ const { parentRef, view: editorView, focusAttributes } = useTextEditor(() => ({
322
+ ...role !== "section" && {
323
+ id,
324
+ scrollTo,
325
+ selection,
326
+ selectionEnd: true
327
+ },
328
+ initialValue,
329
+ extensions: [
330
+ createBasicExtensions({
331
+ readOnly: viewMode === "readonly",
332
+ placeholder: t("editor.placeholder"),
333
+ scrollPastEnd: !compact,
334
+ search: true
335
+ }),
336
+ createThemeExtensions({
337
+ themeMode,
338
+ slots: slots ?? (compact ? compactSlots : documentSlots),
339
+ syntaxHighlighting: true
340
+ }),
341
+ createMarkdownExtensions(),
342
+ toolbarState && formattingListener(updateToolbarState),
343
+ role !== "section" && onFileUpload && dropFile({
344
+ // TODO(wittjosiah): Factor out to file uploader plugin.
345
+ onDrop: async (view, { files }) => {
346
+ const file = files[0];
347
+ const info = file && onFileUpload ? await onFileUpload(file) : void 0;
348
+ if (info) {
349
+ processEditorPayload(view, {
350
+ type: "image",
351
+ data: info.url
352
+ });
104
353
  }
105
354
  }
106
- }
107
- })
108
- }),
109
- defineModule({
110
- id: `${meta.id}/module/object-form`,
111
- activatesOn: ClientEvents.SetupSchema,
112
- activate: () => contributes(SpaceCapabilities.ObjectForm, defineObjectForm({
113
- objectSchema: Markdown_exports.Document,
114
- getIntent: () => createIntent(MarkdownAction_exports.Create, {})
115
- }))
116
- }),
117
- defineModule({
118
- id: `${meta.id}/module/schema`,
119
- activatesOn: ClientEvents.SetupSchema,
120
- activate: () => contributes(ClientCapabilities.Schema, [
121
- DataType.Text
122
- ])
123
- }),
124
- defineModule({
125
- id: `${meta.id}/module/react-surface`,
126
- activatesOn: Events2.SetupReactSurface,
127
- // TODO(wittjosiah): Should occur before the editor is loaded when surfaces activation is more granular.
128
- activatesBefore: [
129
- MarkdownEvents.SetupExtensions
130
- ],
131
- activate: ReactSurface
132
- }),
133
- defineModule({
134
- id: `${meta.id}/module/intent-resolver`,
135
- activatesOn: Events2.SetupIntentResolver,
136
- activate: IntentResolver
137
- }),
138
- defineModule({
139
- id: `${meta.id}/module/app-graph-serializer`,
140
- activatesOn: Events2.AppGraphReady,
141
- activate: AppGraphSerializer
142
- }),
143
- defineModule({
144
- id: `${meta.id}/module/anchor-sort`,
145
- // TODO(wittjosiah): More relevant event?
146
- activatesOn: Events2.AppGraphReady,
147
- activate: AnchorSort
148
- }),
149
- defineModule({
150
- id: `${meta.id}/module/blueprint`,
151
- activatesOn: Events2.SetupArtifactDefinition,
152
- activate: BlueprintDefinition
153
- }),
154
- defineModule({
155
- id: `${meta.id}/module/toolkit`,
156
- // TODO(wittjosiah): Use a different event.
157
- activatesOn: Events2.Startup,
158
- activate: Toolkit
159
- })
160
- ]);
355
+ }),
356
+ extensions
357
+ ].filter(isTruthy)
358
+ }), [
359
+ id,
360
+ viewMode,
361
+ themeMode,
362
+ extensions
363
+ ]);
364
+ useImperativeHandle(forwardedRef, () => editorView, [
365
+ editorView
366
+ ]);
367
+ const [editorViewRegistry] = useCapabilities(MarkdownCapabilities2.EditorViews);
368
+ useEffect(() => {
369
+ if (editorView && editorViewRegistry) {
370
+ editorViewRegistry.register(attendableId ?? id, editorView, id);
371
+ return () => editorViewRegistry.unregister(attendableId ?? id);
372
+ }
373
+ }, [
374
+ editorView,
375
+ editorViewRegistry,
376
+ attendableId,
377
+ id
378
+ ]);
379
+ useTest(editorView);
380
+ return /* @__PURE__ */ React.createElement("div", {
381
+ ...focusAttributes,
382
+ className: mx(editorClassNames(role), classNames),
383
+ role: "none",
384
+ "data-testid": "composer.markdownRoot",
385
+ "data-popover-collision-boundary": true,
386
+ ref: parentRef
387
+ });
388
+ });
389
+ var useTest = (view) => {
390
+ useEffect(() => {
391
+ const composer = window.composer;
392
+ if (composer) {
393
+ composer.editorView = view;
394
+ }
395
+ }, [
396
+ view
397
+ ]);
398
+ };
399
+
400
+ // src/components/MarkdownEditor/MarkdownEditorToolbar.tsx
401
+ import React3, { useCallback as useCallback2, useState } from "react";
402
+ import { invariant } from "@dxos/invariant";
403
+ import { EditorToolbar } from "@dxos/react-ui-editor";
404
+
405
+ // src/components/MarkdownEditor/FileUpload.tsx
406
+ import React2, { forwardRef as forwardRef2, useEffect as useEffect2, useImperativeHandle as useImperativeHandle2 } from "react";
407
+ import { createPortal } from "react-dom";
408
+ import { useDropzone } from "react-dropzone";
409
+ import { addLink } from "@dxos/ui-editor";
410
+ var IMAGE_FILES = [
411
+ ".jpg",
412
+ ".jpeg",
413
+ ".png",
414
+ ".gif"
415
+ ];
416
+ var FileUpload = /* @__PURE__ */ forwardRef2(({ editorView, onFileUpload }, forwardedRef) => {
417
+ const { acceptedFiles, open, inputRef } = useDropzone({
418
+ disabled: !onFileUpload,
419
+ multiple: false,
420
+ noDrag: true,
421
+ accept: {
422
+ "image/*": IMAGE_FILES
423
+ }
424
+ });
425
+ useImperativeHandle2(forwardedRef, () => open, []);
426
+ useEffect2(() => {
427
+ if (editorView && acceptedFiles.length && onFileUpload) {
428
+ requestAnimationFrame(async () => {
429
+ const f = acceptedFiles[0];
430
+ const file = new File([
431
+ f
432
+ ], f.name, {
433
+ type: f.type,
434
+ lastModified: f.lastModified
435
+ });
436
+ const info = await onFileUpload(file);
437
+ if (info) {
438
+ addLink({
439
+ url: info.url,
440
+ image: true
441
+ })(editorView);
442
+ }
443
+ });
444
+ }
445
+ }, [
446
+ editorView,
447
+ acceptedFiles,
448
+ onFileUpload
449
+ ]);
450
+ if (!onFileUpload) {
451
+ return null;
452
+ }
453
+ return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ createPortal(/* @__PURE__ */ React2.createElement("input", {
454
+ ref: inputRef
455
+ }), document.body), " ");
456
+ });
457
+
458
+ // src/components/MarkdownEditor/MarkdownEditorToolbar.tsx
459
+ import { composable, composableProps } from "@dxos/ui-theme";
460
+ var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx";
461
+ var MarkdownEditorToolbar = composable(({ id, role, state, editorView, customActions, onAction, onFileUpload, onViewModeChange, ...props }, forwardedRef) => {
462
+ const { className, ...rest } = composableProps(props);
463
+ const [upload, setUpload] = useState(null);
464
+ const uploadRef = useCallback2((next) => setUpload(() => next), []);
465
+ const getView = useCallback2(() => {
466
+ invariant(editorView, void 0, {
467
+ F: __dxlog_file,
468
+ L: 31,
469
+ S: void 0,
470
+ A: [
471
+ "editorView",
472
+ ""
473
+ ]
474
+ });
475
+ return editorView;
476
+ }, [
477
+ editorView
478
+ ]);
479
+ if (!editorView) {
480
+ return /* @__PURE__ */ React3.createElement("div", {
481
+ className,
482
+ ...rest,
483
+ ref: forwardedRef
484
+ });
485
+ }
486
+ return /* @__PURE__ */ React3.createElement("div", {
487
+ role: "none",
488
+ className: "contents",
489
+ ref: forwardedRef
490
+ }, /* @__PURE__ */ React3.createElement(EditorToolbar, {
491
+ ...rest,
492
+ classNames: className,
493
+ attendableId: id,
494
+ role,
495
+ state,
496
+ customActions,
497
+ getView,
498
+ onAction,
499
+ onImageUpload: upload ?? void 0,
500
+ onViewModeChange
501
+ }), onFileUpload && /* @__PURE__ */ React3.createElement(FileUpload, {
502
+ ref: uploadRef,
503
+ editorView,
504
+ onFileUpload
505
+ }));
506
+ });
507
+
508
+ // src/components/MarkdownEditor/MarkdownEditor.tsx
509
+ var [MarkdownEditorContextProvider, useMarkdownEditorContext] = createContext("MarkdownEditor.Context");
510
+ var MarkdownEditorRoot = ({ children, id, attendableId, object, settings, compact, viewMode, selectionManager, editorStateStore, extensions: extensionsProp, slashCommandGroups, onLinkQuery, onSelectObject, ...props }) => {
511
+ const [editorView, setEditorView] = useState2();
512
+ const [previewBlocks, setPreviewBlocks] = useState2([]);
513
+ const previewOptions = useMemo2(() => ({
514
+ db: Obj2.isObject(object) ? Obj2.getDatabase(object) : void 0,
515
+ addBlockContainer: (block) => {
516
+ setPreviewBlocks((prev) => [
517
+ ...prev,
518
+ block
519
+ ]);
520
+ },
521
+ removeBlockContainer: ({ link }) => {
522
+ setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.dxn !== link.dxn));
523
+ }
524
+ }), [
525
+ object
526
+ ]);
527
+ const toolbarState = useEditorToolbar({
528
+ viewMode
529
+ });
530
+ const menuOptions = useEditorMenuOptions({
531
+ editorView,
532
+ slashCommandGroups,
533
+ onLinkQuery
534
+ });
535
+ const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
536
+ const coreExtensions = useExtensions({
537
+ id,
538
+ object,
539
+ compact,
540
+ viewMode,
541
+ selectionManager,
542
+ editorStateStore,
543
+ previewOptions,
544
+ settings,
545
+ onSelectObject
546
+ });
547
+ const extensions = useMemo2(() => [
548
+ coreExtensions,
549
+ menuExtension,
550
+ extensionsProp
551
+ ].filter(isNonNullable), [
552
+ coreExtensions,
553
+ menuExtension,
554
+ extensionsProp
555
+ ]);
556
+ return /* @__PURE__ */ React4.createElement(MarkdownEditorContextProvider, {
557
+ id,
558
+ attendableId,
559
+ compact,
560
+ editorView,
561
+ setEditorView,
562
+ extensions,
563
+ previewBlocks,
564
+ toolbarState,
565
+ popoverMenu: menuProps,
566
+ viewMode,
567
+ ...props
568
+ }, children);
569
+ };
570
+ MarkdownEditorRoot.displayName = "MarkdownEditor.Root";
571
+ var MARKDOWN_EDITOR_CONTENT_NAME = "MarkdownEditor.Content";
572
+ var MarkdownEditorContent2 = composable2(({ ...props }, _forwardedRef) => {
573
+ const { id, attendableId, compact, editorView, setEditorView, viewMode, toolbarState, extensions, popoverMenu: { groupsRef, ...menuProps } } = useMarkdownEditorContext(MARKDOWN_EDITOR_CONTENT_NAME);
574
+ return /* @__PURE__ */ React4.createElement(EditorMenuProvider, {
575
+ view: editorView,
576
+ groups: groupsRef.current,
577
+ ...menuProps
578
+ }, /* @__PURE__ */ React4.createElement(MarkdownEditorContent, {
579
+ ...composableProps2(props),
580
+ id,
581
+ attendableId,
582
+ compact,
583
+ viewMode,
584
+ toolbarState,
585
+ extensions,
586
+ ref: setEditorView
587
+ }));
588
+ });
589
+ MarkdownEditorContent2.displayName = MARKDOWN_EDITOR_CONTENT_NAME;
590
+ var MARKDOWN_EDITOR_TOOLBAR_NAME = "MarkdownEditor.Toolbar";
591
+ var MarkdownEditorToolbar2 = (props) => {
592
+ const { id, attendableId, editorView, toolbarState, onAction, onFileUpload, onViewModeChange } = useMarkdownEditorContext(MARKDOWN_EDITOR_TOOLBAR_NAME);
593
+ return /* @__PURE__ */ React4.createElement(MarkdownEditorToolbar, {
594
+ ...props,
595
+ id: attendableId ?? id,
596
+ editorView,
597
+ state: toolbarState,
598
+ onAction,
599
+ onFileUpload,
600
+ onViewModeChange
601
+ });
602
+ };
603
+ MarkdownEditorToolbar2.displayName = MARKDOWN_EDITOR_TOOLBAR_NAME;
604
+ var MARKDOWN_EDITOR_BLOCKS_NAME = "MarkdownEditor.Blocks";
605
+ var MarkdownEditorBlocks = (_props) => {
606
+ const { previewBlocks } = useMarkdownEditorContext(MARKDOWN_EDITOR_BLOCKS_NAME);
607
+ return /* @__PURE__ */ React4.createElement(React4.Fragment, null, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React4.createElement(PreviewBlock, {
608
+ key: link.dxn,
609
+ link,
610
+ el
611
+ })));
612
+ };
613
+ MarkdownEditorBlocks.displayName = MARKDOWN_EDITOR_BLOCKS_NAME;
614
+ var PreviewBlock = ({ el, link }) => {
615
+ const client = useClient();
616
+ const dxn = DXN.parse(link.dxn);
617
+ const subject = client.graph.makeRef(dxn).target;
618
+ const data = useMemo2(() => ({
619
+ subject
620
+ }), [
621
+ subject
622
+ ]);
623
+ return /* @__PURE__ */ createPortal2(/* @__PURE__ */ React4.createElement(Surface.Surface, {
624
+ role: "card--content",
625
+ data,
626
+ limit: 1
627
+ }), el);
628
+ };
629
+ var MarkdownEditor = {
630
+ Root: MarkdownEditorRoot,
631
+ Content: MarkdownEditorContent2,
632
+ Toolbar: MarkdownEditorToolbar2,
633
+ Blocks: MarkdownEditorBlocks
634
+ };
635
+
636
+ // src/components/index.ts
637
+ var MarkdownSettings2 = lazy(() => import("./MarkdownSettings-ODDM67XG.mjs"));
161
638
  export {
162
639
  Markdown_exports as Markdown,
163
- MarkdownAction_exports as MarkdownAction,
164
640
  MarkdownCapabilities,
641
+ MarkdownEditor,
165
642
  MarkdownEvents,
166
643
  MarkdownPlugin,
644
+ MarkdownStateSchema,
645
+ Settings_exports as Settings,
167
646
  getContentSnippet,
168
647
  getFallbackName,
169
648
  isEditorModel,