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