@dxos/plugin-markdown 0.8.4-main.9735255 → 0.8.4-main.abd8ff62ef

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 (379) hide show
  1. package/dist/lib/browser/blueprints/index.mjs +46 -4
  2. package/dist/lib/browser/blueprints/index.mjs.map +4 -4
  3. package/dist/lib/browser/chunk-DNSKDWUL.mjs +156 -0
  4. package/dist/lib/browser/chunk-DNSKDWUL.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-SW6IK2GJ.mjs +124 -0
  6. package/dist/lib/browser/chunk-SW6IK2GJ.mjs.map +7 -0
  7. package/dist/lib/browser/create-SRADQOTE.mjs +29 -0
  8. package/dist/lib/browser/create-SRADQOTE.mjs.map +7 -0
  9. package/dist/lib/browser/create-markdown-A2ERCEOZ.mjs +21 -0
  10. package/dist/lib/browser/create-markdown-A2ERCEOZ.mjs.map +7 -0
  11. package/dist/lib/browser/index.mjs +109 -126
  12. package/dist/lib/browser/index.mjs.map +4 -4
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/open-ANTKMST5.mjs +20 -0
  15. package/dist/lib/browser/open-ANTKMST5.mjs.map +7 -0
  16. package/dist/lib/browser/operations/index.mjs +13 -0
  17. package/dist/lib/browser/operations/index.mjs.map +7 -0
  18. package/dist/lib/browser/scroll-to-anchor-4RJ6MQ7I.mjs +48 -0
  19. package/dist/lib/browser/scroll-to-anchor-4RJ6MQ7I.mjs.map +7 -0
  20. package/dist/lib/browser/set-view-mode-2S7KKY7C.mjs +25 -0
  21. package/dist/lib/browser/set-view-mode-2S7KKY7C.mjs.map +7 -0
  22. package/dist/lib/browser/types/index.mjs +5 -7
  23. package/dist/lib/browser/update-markdown-CPM5KOQW.mjs +44 -0
  24. package/dist/lib/browser/update-markdown-CPM5KOQW.mjs.map +7 -0
  25. package/dist/lib/node-esm/blueprints/index.mjs +46 -4
  26. package/dist/lib/node-esm/blueprints/index.mjs.map +4 -4
  27. package/dist/lib/node-esm/chunk-MWYFGI2J.mjs +157 -0
  28. package/dist/lib/node-esm/chunk-MWYFGI2J.mjs.map +7 -0
  29. package/dist/lib/node-esm/chunk-ZE6QJ4S5.mjs +125 -0
  30. package/dist/lib/node-esm/chunk-ZE6QJ4S5.mjs.map +7 -0
  31. package/dist/lib/node-esm/create-6JGQPPQ6.mjs +30 -0
  32. package/dist/lib/node-esm/create-6JGQPPQ6.mjs.map +7 -0
  33. package/dist/lib/node-esm/create-markdown-KXSM2I2M.mjs +22 -0
  34. package/dist/lib/node-esm/create-markdown-KXSM2I2M.mjs.map +7 -0
  35. package/dist/lib/node-esm/index.mjs +109 -126
  36. package/dist/lib/node-esm/index.mjs.map +4 -4
  37. package/dist/lib/node-esm/meta.json +1 -1
  38. package/dist/lib/node-esm/open-GB6HNBHS.mjs +21 -0
  39. package/dist/lib/node-esm/open-GB6HNBHS.mjs.map +7 -0
  40. package/dist/lib/node-esm/operations/index.mjs +14 -0
  41. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  42. package/dist/lib/node-esm/scroll-to-anchor-UABP74RR.mjs +49 -0
  43. package/dist/lib/node-esm/scroll-to-anchor-UABP74RR.mjs.map +7 -0
  44. package/dist/lib/node-esm/set-view-mode-JEDC5ZL7.mjs +26 -0
  45. package/dist/lib/node-esm/set-view-mode-JEDC5ZL7.mjs.map +7 -0
  46. package/dist/lib/node-esm/types/index.mjs +5 -7
  47. package/dist/lib/node-esm/update-markdown-AXLYHK6S.mjs +45 -0
  48. package/dist/lib/node-esm/update-markdown-AXLYHK6S.mjs.map +7 -0
  49. package/dist/types/src/MarkdownPlugin.d.ts +1 -0
  50. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  51. package/dist/types/src/{cli/plugin.d.ts → MarkdownPlugin.node.d.ts} +2 -1
  52. package/dist/types/src/MarkdownPlugin.node.d.ts.map +1 -0
  53. package/dist/types/src/MarkdownPlugin.test.d.ts +2 -0
  54. package/dist/types/src/MarkdownPlugin.test.d.ts.map +1 -0
  55. package/dist/types/src/blueprints/index.d.ts +1 -1
  56. package/dist/types/src/blueprints/index.d.ts.map +1 -1
  57. package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
  58. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  59. package/dist/types/src/capabilities/anchor-sort.d.ts +6 -0
  60. package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
  61. package/dist/types/src/capabilities/app-graph-serializer.d.ts +5 -0
  62. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  63. package/dist/types/src/capabilities/artifact-definition.d.ts +5 -0
  64. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -0
  65. package/dist/types/src/capabilities/blueprint-definition.d.ts +6 -0
  66. package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
  67. package/dist/types/src/capabilities/index.d.ts +9 -7
  68. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/node.d.ts +4 -0
  70. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  71. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  72. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  73. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  74. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  75. package/dist/types/src/capabilities/settings.d.ts +6 -0
  76. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  77. package/dist/types/src/capabilities/state.d.ts +6 -0
  78. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  79. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +2 -2
  80. package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -1
  81. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +33 -22
  82. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  83. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +3 -3
  84. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  85. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +6 -3
  86. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  87. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +7 -6
  88. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  89. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +4 -6
  90. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  91. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts +94 -0
  92. package/dist/types/src/components/MarkdownSettings/MarkdownSettings.stories.d.ts.map +1 -0
  93. package/dist/types/src/components/MarkdownSettings/index.d.ts +1 -1
  94. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -1
  95. package/dist/types/src/components/index.d.ts +3 -8
  96. package/dist/types/src/components/index.d.ts.map +1 -1
  97. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +1 -1
  98. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  99. package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +1 -1
  100. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  101. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts +15 -0
  102. package/dist/types/src/containers/MarkdownCard/MarkdownEditableCard.d.ts.map +1 -0
  103. package/dist/types/src/containers/MarkdownCard/index.d.ts +3 -0
  104. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  105. package/dist/types/src/containers/MarkdownCard/snippet.d.ts +17 -0
  106. package/dist/types/src/containers/MarkdownCard/snippet.d.ts.map +1 -0
  107. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts +36 -0
  108. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  109. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts +97 -0
  110. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  111. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  112. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  113. package/dist/types/src/containers/index.d.ts +6 -0
  114. package/dist/types/src/containers/index.d.ts.map +1 -0
  115. package/dist/types/src/hooks/index.d.ts +0 -1
  116. package/dist/types/src/hooks/index.d.ts.map +1 -1
  117. package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -1
  118. package/dist/types/src/hooks/useExtensions.d.ts +10 -6
  119. package/dist/types/src/hooks/useExtensions.d.ts.map +1 -1
  120. package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -1
  121. package/dist/types/src/index.d.ts +2 -1
  122. package/dist/types/src/index.d.ts.map +1 -1
  123. package/dist/types/src/operations/create-markdown.d.ts +5 -0
  124. package/dist/types/src/operations/create-markdown.d.ts.map +1 -0
  125. package/dist/types/src/operations/create.d.ts +5 -0
  126. package/dist/types/src/operations/create.d.ts.map +1 -0
  127. package/dist/types/src/operations/create.test.d.ts.map +1 -0
  128. package/dist/types/src/operations/definitions.d.ts +64 -0
  129. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  130. package/dist/types/src/operations/index.d.ts +4 -0
  131. package/dist/types/src/operations/index.d.ts.map +1 -0
  132. package/dist/types/src/operations/open.d.ts +5 -0
  133. package/dist/types/src/operations/open.d.ts.map +1 -0
  134. package/dist/types/src/operations/scroll-to-anchor.d.ts +5 -0
  135. package/dist/types/src/operations/scroll-to-anchor.d.ts.map +1 -0
  136. package/dist/types/src/operations/set-view-mode.d.ts +5 -0
  137. package/dist/types/src/operations/set-view-mode.d.ts.map +1 -0
  138. package/dist/types/src/operations/update-markdown.d.ts +5 -0
  139. package/dist/types/src/operations/update-markdown.d.ts.map +1 -0
  140. package/dist/types/src/operations/update.test.d.ts.map +1 -0
  141. package/dist/types/src/testing.d.ts.map +1 -1
  142. package/dist/types/src/translations.d.ts +74 -37
  143. package/dist/types/src/translations.d.ts.map +1 -1
  144. package/dist/types/src/types/Markdown.d.ts +15 -16
  145. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  146. package/dist/types/src/types/Settings.d.ts +17 -0
  147. package/dist/types/src/types/Settings.d.ts.map +1 -0
  148. package/dist/types/src/types/capabilities.d.ts +15 -3
  149. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  150. package/dist/types/src/types/events.d.ts.map +1 -1
  151. package/dist/types/src/types/index.d.ts +2 -3
  152. package/dist/types/src/types/index.d.ts.map +1 -1
  153. package/dist/types/src/types/types.d.ts +1 -0
  154. package/dist/types/src/types/types.d.ts.map +1 -1
  155. package/dist/types/src/util.d.ts +2 -2
  156. package/dist/types/src/util.d.ts.map +1 -1
  157. package/dist/types/tsconfig.tsbuildinfo +1 -1
  158. package/package.json +94 -75
  159. package/src/MarkdownPlugin.node.ts +41 -0
  160. package/src/MarkdownPlugin.test.ts +26 -0
  161. package/src/MarkdownPlugin.tsx +52 -45
  162. package/src/blueprints/index.ts +1 -1
  163. package/src/blueprints/markdown-blueprint.ts +14 -9
  164. package/src/capabilities/{anchor-sort/anchor-sort.ts → anchor-sort.ts} +4 -3
  165. package/src/capabilities/{app-graph-serializer/app-graph-serializer.ts → app-graph-serializer.ts} +14 -9
  166. package/src/capabilities/{artifact-definition/artifact-definition.ts → artifact-definition.ts} +6 -6
  167. package/src/capabilities/blueprint-definition.ts +19 -0
  168. package/src/capabilities/index.ts +14 -7
  169. package/src/capabilities/node.ts +11 -0
  170. package/src/capabilities/operation-handler.ts +16 -0
  171. package/src/capabilities/react-surface.tsx +127 -0
  172. package/src/capabilities/{settings/settings.ts → settings.ts} +5 -4
  173. package/src/capabilities/state.ts +47 -0
  174. package/src/components/MarkdownEditor/FileUpload.tsx +2 -2
  175. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +39 -34
  176. package/src/components/MarkdownEditor/MarkdownEditor.tsx +139 -102
  177. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +26 -18
  178. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +37 -56
  179. package/src/components/MarkdownSettings/MarkdownSettings.stories.tsx +40 -0
  180. package/src/components/MarkdownSettings/MarkdownSettings.tsx +22 -109
  181. package/src/components/MarkdownSettings/index.ts +1 -1
  182. package/src/components/index.ts +4 -12
  183. package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +22 -12
  184. package/src/containers/MarkdownCard/MarkdownCard.tsx +68 -0
  185. package/src/containers/MarkdownCard/MarkdownEditableCard.tsx +42 -0
  186. package/src/containers/MarkdownCard/index.ts +6 -0
  187. package/src/containers/MarkdownCard/snippet.ts +54 -0
  188. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +36 -24
  189. package/src/containers/MarkdownContainer/MarkdownContainer.tsx +146 -0
  190. package/src/containers/MarkdownContainer/index.ts +6 -0
  191. package/src/containers/index.ts +13 -0
  192. package/src/hooks/index.ts +0 -1
  193. package/src/hooks/useEditorMenuOptions.ts +3 -3
  194. package/src/hooks/useExtensions.tsx +86 -98
  195. package/src/hooks/useLinkQuery.ts +31 -6
  196. package/src/index.ts +5 -1
  197. package/src/meta.ts +1 -1
  198. package/src/operations/create-markdown.ts +20 -0
  199. package/src/operations/create.conversations.json +1 -0
  200. package/src/operations/create.test.ts +97 -0
  201. package/src/operations/create.ts +27 -0
  202. package/src/operations/definitions.ts +120 -0
  203. package/src/operations/index.ts +16 -0
  204. package/src/operations/open.ts +25 -0
  205. package/src/operations/scroll-to-anchor.ts +39 -0
  206. package/src/operations/set-view-mode.ts +24 -0
  207. package/src/operations/update-markdown.ts +51 -0
  208. package/src/operations/update.conversations.json +1 -0
  209. package/src/operations/update.test.ts +214 -0
  210. package/src/testing.ts +2 -2
  211. package/src/translations.ts +26 -36
  212. package/src/types/Markdown.ts +18 -25
  213. package/src/types/Settings.ts +65 -0
  214. package/src/types/capabilities.ts +19 -6
  215. package/src/types/events.ts +5 -4
  216. package/src/types/index.ts +3 -4
  217. package/src/types/types.ts +4 -1
  218. package/src/util.tsx +5 -5
  219. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs +0 -12
  220. package/dist/lib/browser/MarkdownCard-WHK3ORP7.mjs.map +0 -7
  221. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs +0 -12
  222. package/dist/lib/browser/MarkdownContainer-V7EAADMF.mjs.map +0 -7
  223. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs +0 -32
  224. package/dist/lib/browser/anchor-sort-WQ3TL7ZI.mjs.map +0 -7
  225. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs +0 -58
  226. package/dist/lib/browser/app-graph-serializer-ULZUJKOD.mjs.map +0 -7
  227. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs +0 -19
  228. package/dist/lib/browser/blueprint-definition-TLV4PNZW.mjs.map +0 -7
  229. package/dist/lib/browser/chunk-BX73DASG.mjs +0 -702
  230. package/dist/lib/browser/chunk-BX73DASG.mjs.map +0 -7
  231. package/dist/lib/browser/chunk-CUGDX7KA.mjs +0 -8
  232. package/dist/lib/browser/chunk-CUGDX7KA.mjs.map +0 -7
  233. package/dist/lib/browser/chunk-FWQQW6KU.mjs +0 -144
  234. package/dist/lib/browser/chunk-FWQQW6KU.mjs.map +0 -7
  235. package/dist/lib/browser/chunk-JOXYQLKH.mjs +0 -55
  236. package/dist/lib/browser/chunk-JOXYQLKH.mjs.map +0 -7
  237. package/dist/lib/browser/chunk-KDKXFKDN.mjs +0 -104
  238. package/dist/lib/browser/chunk-KDKXFKDN.mjs.map +0 -7
  239. package/dist/lib/browser/chunk-LMO5UVKL.mjs +0 -167
  240. package/dist/lib/browser/chunk-LMO5UVKL.mjs.map +0 -7
  241. package/dist/lib/browser/chunk-S45ULIOG.mjs +0 -101
  242. package/dist/lib/browser/chunk-S45ULIOG.mjs.map +0 -7
  243. package/dist/lib/browser/chunk-WIPSLZ6L.mjs +0 -60
  244. package/dist/lib/browser/chunk-WIPSLZ6L.mjs.map +0 -7
  245. package/dist/lib/browser/cli/index.mjs +0 -32
  246. package/dist/lib/browser/cli/index.mjs.map +0 -7
  247. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs +0 -53
  248. package/dist/lib/browser/operation-resolver-EGCWOQKJ.mjs.map +0 -7
  249. package/dist/lib/browser/react-surface-SRPLD3ED.mjs +0 -213
  250. package/dist/lib/browser/react-surface-SRPLD3ED.mjs.map +0 -7
  251. package/dist/lib/browser/settings-JY5JE7MI.mjs +0 -35
  252. package/dist/lib/browser/settings-JY5JE7MI.mjs.map +0 -7
  253. package/dist/lib/browser/state-QE7VSJWJ.mjs +0 -29
  254. package/dist/lib/browser/state-QE7VSJWJ.mjs.map +0 -7
  255. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs +0 -13
  256. package/dist/lib/node-esm/MarkdownCard-WJPLQTFS.mjs.map +0 -7
  257. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs +0 -13
  258. package/dist/lib/node-esm/MarkdownContainer-LUSMORP2.mjs.map +0 -7
  259. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs +0 -33
  260. package/dist/lib/node-esm/anchor-sort-G7D5TAI6.mjs.map +0 -7
  261. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs +0 -59
  262. package/dist/lib/node-esm/app-graph-serializer-W5YMQP7P.mjs.map +0 -7
  263. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs +0 -20
  264. package/dist/lib/node-esm/blueprint-definition-HYFA7BKQ.mjs.map +0 -7
  265. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs +0 -105
  266. package/dist/lib/node-esm/chunk-3JYPCC7M.mjs.map +0 -7
  267. package/dist/lib/node-esm/chunk-44VJC3QF.mjs +0 -56
  268. package/dist/lib/node-esm/chunk-44VJC3QF.mjs.map +0 -7
  269. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs +0 -703
  270. package/dist/lib/node-esm/chunk-D4BCFPKK.mjs.map +0 -7
  271. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs +0 -145
  272. package/dist/lib/node-esm/chunk-EYAFC4N7.mjs.map +0 -7
  273. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs +0 -168
  274. package/dist/lib/node-esm/chunk-PRV35A7Z.mjs.map +0 -7
  275. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs +0 -61
  276. package/dist/lib/node-esm/chunk-RQP7G7XW.mjs.map +0 -7
  277. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs +0 -102
  278. package/dist/lib/node-esm/chunk-SDTYEGGL.mjs.map +0 -7
  279. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs +0 -10
  280. package/dist/lib/node-esm/chunk-W3IIKDV5.mjs.map +0 -7
  281. package/dist/lib/node-esm/cli/index.mjs +0 -33
  282. package/dist/lib/node-esm/cli/index.mjs.map +0 -7
  283. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs +0 -54
  284. package/dist/lib/node-esm/operation-resolver-2HIS2AQZ.mjs.map +0 -7
  285. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs +0 -214
  286. package/dist/lib/node-esm/react-surface-RONSOJIQ.mjs.map +0 -7
  287. package/dist/lib/node-esm/settings-4UGMPIRY.mjs +0 -36
  288. package/dist/lib/node-esm/settings-4UGMPIRY.mjs.map +0 -7
  289. package/dist/lib/node-esm/state-LXE5XIN4.mjs +0 -30
  290. package/dist/lib/node-esm/state-LXE5XIN4.mjs.map +0 -7
  291. package/dist/types/src/blueprints/functions/create.d.ts +0 -8
  292. package/dist/types/src/blueprints/functions/create.d.ts.map +0 -1
  293. package/dist/types/src/blueprints/functions/create.test.d.ts.map +0 -1
  294. package/dist/types/src/blueprints/functions/index.d.ts +0 -4
  295. package/dist/types/src/blueprints/functions/index.d.ts.map +0 -1
  296. package/dist/types/src/blueprints/functions/open.d.ts +0 -7
  297. package/dist/types/src/blueprints/functions/open.d.ts.map +0 -1
  298. package/dist/types/src/blueprints/functions/update.d.ts +0 -6
  299. package/dist/types/src/blueprints/functions/update.d.ts.map +0 -1
  300. package/dist/types/src/blueprints/functions/update.test.d.ts.map +0 -1
  301. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +0 -5
  302. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts.map +0 -1
  303. package/dist/types/src/capabilities/anchor-sort/index.d.ts +0 -3
  304. package/dist/types/src/capabilities/anchor-sort/index.d.ts.map +0 -1
  305. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +0 -5
  306. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts.map +0 -1
  307. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts +0 -3
  308. package/dist/types/src/capabilities/app-graph-serializer/index.d.ts.map +0 -1
  309. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +0 -5
  310. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts.map +0 -1
  311. package/dist/types/src/capabilities/artifact-definition/index.d.ts +0 -3
  312. package/dist/types/src/capabilities/artifact-definition/index.d.ts.map +0 -1
  313. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -10
  314. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
  315. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
  316. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
  317. package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
  318. package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
  319. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
  320. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
  321. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  322. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  323. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  324. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  325. package/dist/types/src/capabilities/settings/index.d.ts +0 -3
  326. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  327. package/dist/types/src/capabilities/settings/settings.d.ts +0 -6
  328. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  329. package/dist/types/src/capabilities/state/index.d.ts +0 -3
  330. package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
  331. package/dist/types/src/capabilities/state/state.d.ts +0 -5
  332. package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
  333. package/dist/types/src/cli/index.d.ts +0 -2
  334. package/dist/types/src/cli/index.d.ts.map +0 -1
  335. package/dist/types/src/cli/plugin.d.ts.map +0 -1
  336. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  337. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  338. package/dist/types/src/components/MarkdownCard/index.d.ts +0 -4
  339. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  340. package/dist/types/src/components/MarkdownContainer.d.ts +0 -28
  341. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  342. package/dist/types/src/components/MarkdownContainer.stories.d.ts +0 -59
  343. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  344. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  345. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  346. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  347. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  348. package/dist/types/src/types/MarkdownAction.d.ts +0 -66
  349. package/dist/types/src/types/MarkdownAction.d.ts.map +0 -1
  350. package/src/blueprints/functions/create.conversations.json +0 -1
  351. package/src/blueprints/functions/create.test.ts +0 -125
  352. package/src/blueprints/functions/create.ts +0 -34
  353. package/src/blueprints/functions/index.ts +0 -7
  354. package/src/blueprints/functions/open.ts +0 -33
  355. package/src/blueprints/functions/update.conversations.json +0 -1
  356. package/src/blueprints/functions/update.test.ts +0 -149
  357. package/src/blueprints/functions/update.ts +0 -38
  358. package/src/capabilities/anchor-sort/index.ts +0 -7
  359. package/src/capabilities/app-graph-serializer/index.ts +0 -7
  360. package/src/capabilities/artifact-definition/index.ts +0 -7
  361. package/src/capabilities/blueprint-definition/blueprint-definition.ts +0 -25
  362. package/src/capabilities/blueprint-definition/index.ts +0 -7
  363. package/src/capabilities/operation-resolver/index.ts +0 -7
  364. package/src/capabilities/operation-resolver/operation-resolver.ts +0 -45
  365. package/src/capabilities/react-surface/index.ts +0 -7
  366. package/src/capabilities/react-surface/react-surface.tsx +0 -100
  367. package/src/capabilities/settings/index.ts +0 -7
  368. package/src/capabilities/state/index.ts +0 -7
  369. package/src/capabilities/state/state.ts +0 -31
  370. package/src/cli/index.ts +0 -5
  371. package/src/cli/plugin.ts +0 -29
  372. package/src/components/MarkdownCard/MarkdownCard.tsx +0 -64
  373. package/src/components/MarkdownCard/index.ts +0 -9
  374. package/src/components/MarkdownContainer.tsx +0 -111
  375. package/src/components/Suggestions.stories.tsx +0 -215
  376. package/src/hooks/useSelectCurrentThread.tsx +0 -61
  377. package/src/types/MarkdownAction.ts +0 -59
  378. /package/dist/types/src/{blueprints/functions → operations}/create.test.d.ts +0 -0
  379. /package/dist/types/src/{blueprints/functions → operations}/update.test.d.ts +0 -0
@@ -1,702 +0,0 @@
1
- import {
2
- setFallbackName
3
- } from "./chunk-S45ULIOG.mjs";
4
- import {
5
- Markdown_exports,
6
- meta
7
- } from "./chunk-LMO5UVKL.mjs";
8
-
9
- // src/hooks/useLinkQuery.ts
10
- import * as Option from "effect/Option";
11
- import { useCallback, useMemo } from "react";
12
- import { Common } from "@dxos/app-framework";
13
- import { usePluginManager } from "@dxos/app-framework/react";
14
- import { Filter, Obj, Query, Type } from "@dxos/echo";
15
- import { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from "@dxos/echo/internal";
16
- import { toLocalizedString, useTranslation } from "@dxos/react-ui";
17
- import { insertAtCursor, insertAtLineStart } from "@dxos/ui-editor";
18
- var useLinkQuery = (db) => {
19
- const { t } = useTranslation();
20
- const manager = usePluginManager();
21
- const resolve = useCallback((typename) => manager.capabilities.getAll(Common.Capability.Metadata).find(({ id }) => id === typename)?.metadata ?? {}, [
22
- manager
23
- ]);
24
- const filter = useMemo(() => Filter.or(...(db?.schemaRegistry.query({
25
- location: [
26
- "database",
27
- "runtime"
28
- ]
29
- }).runSync() ?? []).filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation).filter((schema) => !SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false))).map((schema) => Filter.typename(Type.getTypename(schema)))), [
30
- db
31
- ]);
32
- const handleLinkQuery = useCallback(async (query) => {
33
- const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
34
- const results = await db?.query(Query.select(filter)).run();
35
- const getLabel = (object) => {
36
- const label = Obj.getLabel(object);
37
- if (label) {
38
- return label;
39
- }
40
- const type = Obj.getTypename(object);
41
- const metadata = resolve(type);
42
- return metadata.label?.(object) || [
43
- "object name placeholder",
44
- {
45
- ns: type,
46
- default: "New object"
47
- }
48
- ];
49
- };
50
- const items = results?.filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name)).map((object) => {
51
- const metadata = resolve(Obj.getTypename(object));
52
- const label = toLocalizedString(getLabel(object), t);
53
- return {
54
- id: object.id,
55
- label,
56
- icon: metadata.icon,
57
- onSelect: ({ view, head }) => {
58
- const link = `[${label}](${Obj.getDXN(object)})`;
59
- if (query?.startsWith("@")) {
60
- insertAtLineStart(view, head, `!${link}
61
- `);
62
- } else {
63
- insertAtCursor(view, head, `${link} `);
64
- }
65
- }
66
- };
67
- }) ?? [];
68
- return [
69
- {
70
- id: "echo",
71
- items
72
- }
73
- ];
74
- }, [
75
- db,
76
- filter,
77
- resolve
78
- ]);
79
- return handleLinkQuery;
80
- };
81
-
82
- // src/hooks/useEditorMenuOptions.ts
83
- import { useCallback as useCallback2, useMemo as useMemo2, useRef } from "react";
84
- import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
85
- import { filterMenuGroups, formattingCommands, linkSlashCommands } from "@dxos/react-ui-editor";
86
- import { Domino } from "@dxos/ui";
87
- var useEditorMenuOptions = ({ editorView, slashCommandGroups, onLinkQuery }) => {
88
- const { t } = useTranslation2(meta.id);
89
- const getMenu = useCallback2(({ text, trigger }) => {
90
- switch (trigger) {
91
- case "@": {
92
- return onLinkQuery?.(text) ?? [];
93
- }
94
- case "/":
95
- default: {
96
- return filterMenuGroups([
97
- formattingCommands,
98
- linkSlashCommands,
99
- ...slashCommandGroups ?? []
100
- ], (item) => text ? toLocalizedString2(item.label, t).toLowerCase().includes(text.toLowerCase()) : true);
101
- }
102
- }
103
- }, [
104
- slashCommandGroups,
105
- onLinkQuery
106
- ]);
107
- const viewRef = useRef(editorView);
108
- return useMemo2(() => {
109
- const trigger = onLinkQuery ? [
110
- "/",
111
- "@"
112
- ] : [
113
- "/"
114
- ];
115
- const placeholder = {
116
- delay: 3e3,
117
- content: () => {
118
- const pressEl = Domino.of("span").text("Press");
119
- const triggerEls = trigger.map((text) => Domino.of("span").classNames("mx-1 pli-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm").text(text));
120
- const forCommandsEl = Domino.of("span").text("for commands.");
121
- return Domino.of("div").children(pressEl, ...triggerEls, forCommandsEl).root;
122
- }
123
- };
124
- return {
125
- viewRef,
126
- getMenu,
127
- trigger,
128
- placeholder
129
- };
130
- }, [
131
- getMenu,
132
- onLinkQuery
133
- ]);
134
- };
135
-
136
- // src/hooks/useExtensions.tsx
137
- import React, { useMemo as useMemo3 } from "react";
138
- import { createRoot } from "react-dom/client";
139
- import { Common as Common2 } from "@dxos/app-framework";
140
- import { useOperationInvoker } from "@dxos/app-framework/react";
141
- import { debounceAndThrottle } from "@dxos/async";
142
- import { Obj as Obj2 } from "@dxos/echo";
143
- import { createDocAccessor } from "@dxos/echo-db";
144
- import { invariant } from "@dxos/invariant";
145
- import { getSpace, useObject } from "@dxos/react-client/echo";
146
- import { useIdentity } from "@dxos/react-client/halo";
147
- import { Icon, ThemeProvider } from "@dxos/react-ui";
148
- import { Text } from "@dxos/schema";
149
- import { Cursor, EditorView, InputModeExtensions, createDataExtensions, decorateMarkdown, documentId, folding, formattingKeymap, linkTooltip, listener, preview, replacer, selectionState, typewriter } from "@dxos/ui-editor";
150
- import { defaultTx } from "@dxos/ui-theme";
151
- import { isTruthy } from "@dxos/util";
152
- var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useExtensions.tsx";
153
- var useExtensions = ({ id, object, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
154
- const { invokePromise } = useOperationInvoker();
155
- const identity = useIdentity();
156
- const space = getSpace(object);
157
- const contentRef = Obj2.instanceOf(Markdown_exports.Document, object) ? object.content : void 0;
158
- useObject(contentRef);
159
- const target = contentRef?.target ?? (Obj2.instanceOf(Text.Text, object) ? object : void 0);
160
- const baseExtensions = useMemo3(() => createBaseExtensions({
161
- id,
162
- object,
163
- settings,
164
- selectionManager,
165
- viewMode,
166
- previewOptions,
167
- invokePromise
168
- }), [
169
- id,
170
- object,
171
- viewMode,
172
- invokePromise,
173
- previewOptions,
174
- settings,
175
- settings?.debug,
176
- settings?.editorInputMode,
177
- settings?.folding,
178
- settings?.numberedHeadings,
179
- settings?.typewriter,
180
- selectionManager
181
- ]);
182
- return useMemo3(() => [
183
- // TODO(burdon): Pass this in?
184
- // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.
185
- target && createDataExtensions({
186
- id,
187
- text: createDocAccessor(target, [
188
- "content"
189
- ]),
190
- messenger: space,
191
- identity
192
- }),
193
- // TODO(burdon): Reconcile with effect in parent.
194
- Obj2.instanceOf(Markdown_exports.Document, object) && listener({
195
- onChange: ({ text }) => {
196
- setFallbackName(object, text);
197
- }
198
- }),
199
- baseExtensions,
200
- selectionState(editorStateStore)
201
- ].filter(isTruthy), [
202
- identity,
203
- space,
204
- id,
205
- object,
206
- target,
207
- baseExtensions
208
- ]);
209
- };
210
- var createBaseExtensions = ({ id, object, invokePromise, settings, selectionManager, viewMode, previewOptions }) => {
211
- const extensions = [
212
- selectionManager && selectionChange(selectionManager),
213
- settings?.editorInputMode && InputModeExtensions[settings.editorInputMode],
214
- settings?.folding && folding()
215
- ].filter(isTruthy);
216
- if (viewMode !== "source") {
217
- extensions.push(...[
218
- formattingKeymap(),
219
- decorateMarkdown({
220
- selectionChangeDelay: 100,
221
- numberedHeadings: settings?.numberedHeadings ? {
222
- from: 2
223
- } : void 0,
224
- // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.
225
- // TODO(burdon): Create dx-tag.
226
- renderLinkButton: invokePromise && (object || id) ? createLinkRenderer((targetId) => {
227
- void invokePromise(Common2.LayoutOperation.Open, {
228
- subject: [
229
- targetId
230
- ],
231
- pivotId: object && Obj2.isObject(object) ? Obj2.getDXN(object).toString() : id
232
- });
233
- }) : void 0
234
- }),
235
- linkTooltip(renderLinkTooltip),
236
- preview(previewOptions),
237
- replacer()
238
- ]);
239
- }
240
- if (settings?.debug) {
241
- const items = settings.typewriter?.split(/[,\n]/) ?? "";
242
- if (items) {
243
- extensions.push(typewriter({
244
- items
245
- }));
246
- }
247
- }
248
- return extensions;
249
- };
250
- var selectionChange = (selectionManager) => {
251
- return EditorView.updateListener.of(debounceAndThrottle((update) => {
252
- if (update.selectionSet) {
253
- const id = update.state.facet(documentId);
254
- const cursorConverter = update.state.facet(Cursor.converter);
255
- const selection = update.state.selection;
256
- const ranges = selection.ranges.map((range) => ({
257
- from: cursorConverter.toCursor(range.from),
258
- to: cursorConverter.toCursor(range.to)
259
- })).filter(({ from, to }) => to > from);
260
- selectionManager.updateMultiRange(id, ranges);
261
- }
262
- }, 100));
263
- };
264
- var style = {
265
- hover: "rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400",
266
- icon: "inline-block leading-none mis-1 cursor-pointer"
267
- };
268
- var createLinkRenderer = (onSelectObject) => (el, { url }) => {
269
- const isInternal = url.startsWith("/") || // TODO(wittjosiah): This should probably be parsed out on paste?
270
- url.startsWith(window.location.origin);
271
- const options = isInternal ? {
272
- onClick: () => {
273
- const qualifiedId = url.split("/").at(-1);
274
- invariant(qualifiedId, "Invalid link format.", {
275
- F: __dxlog_file,
276
- L: 237,
277
- S: void 0,
278
- A: [
279
- "qualifiedId",
280
- "'Invalid link format.'"
281
- ]
282
- });
283
- onSelectObject(qualifiedId);
284
- }
285
- } : {
286
- href: url,
287
- rel: "noreferrer",
288
- target: "_blank"
289
- };
290
- renderRoot(el, /* @__PURE__ */ React.createElement("a", {
291
- ...options,
292
- className: style.hover
293
- }, /* @__PURE__ */ React.createElement(Icon, {
294
- icon: isInternal ? "ph--arrow-square-down--bold" : "ph--arrow-square-out--bold",
295
- size: 4,
296
- classNames: style.icon
297
- })));
298
- };
299
- var renderLinkTooltip = (el, { url }) => {
300
- const web = new URL(url);
301
- renderRoot(el, /* @__PURE__ */ React.createElement("a", {
302
- href: url,
303
- rel: "noreferrer",
304
- target: "_blank",
305
- className: style.hover
306
- }, web.origin, /* @__PURE__ */ React.createElement(Icon, {
307
- icon: "ph--arrow-square-out--bold",
308
- size: 4,
309
- classNames: style.icon
310
- })));
311
- };
312
- var renderRoot = (root, node) => {
313
- createRoot(root).render(/* @__PURE__ */ React.createElement(ThemeProvider, {
314
- tx: defaultTx
315
- }, node));
316
- return root;
317
- };
318
-
319
- // src/hooks/useSelectCurrentThread.tsx
320
- import { EditorView as EditorView2 } from "@codemirror/view";
321
- import * as Effect from "effect/Effect";
322
- import { useMemo as useMemo4 } from "react";
323
- import { Common as Common3 } from "@dxos/app-framework";
324
- import { useOperationResolver } from "@dxos/app-framework/react";
325
- import { invariant as invariant2 } from "@dxos/invariant";
326
- import { OperationResolver } from "@dxos/operation";
327
- import { Cursor as Cursor2, setSelection } from "@dxos/ui-editor";
328
- var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useSelectCurrentThread.tsx";
329
- var useSelectCurrentThread = (editorView, documentId2) => {
330
- const scrollIntoViewHandler = useMemo4(() => OperationResolver.make({
331
- operation: Common3.LayoutOperation.ScrollIntoView,
332
- position: "hoist",
333
- filter: (input) => !!editorView && input.subject === documentId2 && !!input.cursor,
334
- handler: (input) => Effect.sync(() => {
335
- invariant2(editorView, "Editor view is not defined.", {
336
- F: __dxlog_file2,
337
- L: 29,
338
- S: void 0,
339
- A: [
340
- "editorView",
341
- "'Editor view is not defined.'"
342
- ]
343
- });
344
- const cursor = input.cursor;
345
- if (!cursor) {
346
- return;
347
- }
348
- const range = Cursor2.getRangeFromCursor(editorView.state, cursor);
349
- if (range) {
350
- const selection = editorView.state.selection.main.from !== range.from ? {
351
- anchor: range.from
352
- } : void 0;
353
- const effects = [
354
- // NOTE: This does not use the DOM scrollIntoView function.
355
- EditorView2.scrollIntoView(range.from, {
356
- y: "start",
357
- yMargin: 96
358
- })
359
- ];
360
- if (selection) {
361
- effects.push(setSelection.of({
362
- current: documentId2
363
- }));
364
- }
365
- editorView.dispatch({
366
- effects,
367
- selection: selection ? {
368
- anchor: range.from
369
- } : void 0
370
- });
371
- }
372
- })
373
- }), [
374
- documentId2,
375
- editorView
376
- ]);
377
- useOperationResolver(meta.id, scrollIntoViewHandler);
378
- };
379
-
380
- // src/components/MarkdownEditor/MarkdownEditor.tsx
381
- import { createContext } from "@radix-ui/react-context";
382
- import React5, { useMemo as useMemo6, useState as useState2 } from "react";
383
- import { createPortal as createPortal2 } from "react-dom";
384
- import { Surface } from "@dxos/app-framework/react";
385
- import { DXN } from "@dxos/keys";
386
- import { useClient } from "@dxos/react-client";
387
- import { EditorMenuProvider, useEditorMenu, useEditorToolbar } from "@dxos/react-ui-editor";
388
- import { isNonNullable } from "@dxos/util";
389
-
390
- // src/components/MarkdownEditor/MarkdownEditorContent.tsx
391
- import { RegistryContext } from "@effect-atom/atom-react";
392
- import React2, { forwardRef, useCallback as useCallback3, useContext, useEffect, useImperativeHandle, useMemo as useMemo5 } from "react";
393
- import { useThemeContext, useTranslation as useTranslation3 } from "@dxos/react-ui";
394
- import { useTextEditor } from "@dxos/react-ui-editor";
395
- import { createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorSlots, formattingListener, processEditorPayload, stackItemContentEditorClassNames } from "@dxos/ui-editor";
396
- import { mx } from "@dxos/ui-theme";
397
- import { isTruthy as isTruthy2 } from "@dxos/util";
398
- var MarkdownEditorContent = /* @__PURE__ */ forwardRef(({ classNames, id, role, viewMode, initialValue, editorStateStore, toolbarState, extensions, scrollPastEnd, slots = editorSlots, onFileUpload }, forwardedRef) => {
399
- const { t } = useTranslation3(meta.id);
400
- const { themeMode } = useThemeContext();
401
- const registry = useContext(RegistryContext);
402
- const updateToolbarState = useCallback3((formatting) => {
403
- if (toolbarState) {
404
- registry.set(toolbarState, {
405
- ...registry.get(toolbarState),
406
- ...formatting
407
- });
408
- }
409
- }, [
410
- registry,
411
- toolbarState
412
- ]);
413
- const { scrollTo, selection } = useMemo5(() => editorStateStore?.getState(id) ?? {}, [
414
- id
415
- ]);
416
- const { parentRef, view: editorView, focusAttributes } = useTextEditor(() => ({
417
- ...role !== "section" && {
418
- id,
419
- scrollTo,
420
- selection,
421
- // TODO(wittjosiah): Autofocus based on layout is racy.
422
- // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,
423
- selectionEnd: true
424
- },
425
- initialValue,
426
- extensions: [
427
- createBasicExtensions({
428
- readOnly: viewMode === "readonly",
429
- placeholder: t("editor placeholder"),
430
- scrollPastEnd: scrollPastEnd && role !== "section",
431
- search: true
432
- }),
433
- createThemeExtensions({
434
- themeMode,
435
- slots,
436
- syntaxHighlighting: true
437
- }),
438
- createMarkdownExtensions(),
439
- toolbarState && formattingListener(updateToolbarState),
440
- role !== "section" && onFileUpload && dropFile({
441
- // TODO(wittjosiah): Factor out to file uploader plugin.
442
- onDrop: async (view, { files }) => {
443
- const file = files[0];
444
- const info = file && onFileUpload ? await onFileUpload(file) : void 0;
445
- if (info) {
446
- processEditorPayload(view, {
447
- type: "image",
448
- data: info.url
449
- });
450
- }
451
- }
452
- }),
453
- extensions
454
- ].filter(isTruthy2)
455
- }), [
456
- id,
457
- viewMode,
458
- themeMode,
459
- extensions
460
- ]);
461
- useImperativeHandle(forwardedRef, () => editorView, [
462
- editorView
463
- ]);
464
- useSelectCurrentThread(editorView, id);
465
- useTest(editorView);
466
- return /* @__PURE__ */ React2.createElement("div", {
467
- role: "none",
468
- ref: parentRef,
469
- "data-testid": "composer.markdownRoot",
470
- className: mx(stackItemContentEditorClassNames(role), classNames),
471
- "data-popover-collision-boundary": true,
472
- ...focusAttributes
473
- });
474
- });
475
- var useTest = (view) => {
476
- useEffect(() => {
477
- const composer = window.composer;
478
- if (composer) {
479
- composer.editorView = view;
480
- }
481
- }, [
482
- view
483
- ]);
484
- };
485
-
486
- // src/components/MarkdownEditor/MarkdownEditorToolbar.tsx
487
- import React4, { useCallback as useCallback4, useState } from "react";
488
- import { invariant as invariant3 } from "@dxos/invariant";
489
- import { EditorToolbar } from "@dxos/react-ui-editor";
490
-
491
- // src/components/MarkdownEditor/FileUpload.tsx
492
- import React3, { forwardRef as forwardRef2, useEffect as useEffect2, useImperativeHandle as useImperativeHandle2 } from "react";
493
- import { createPortal } from "react-dom";
494
- import { useDropzone } from "react-dropzone";
495
- import { addLink } from "@dxos/ui-editor";
496
- var IMAGE_FILES = [
497
- ".jpg",
498
- ".jpeg",
499
- ".png",
500
- ".gif"
501
- ];
502
- var FileUpload = /* @__PURE__ */ forwardRef2(({ editorView, onFileUpload }, forwardedRef) => {
503
- const { acceptedFiles, open, inputRef } = useDropzone({
504
- disabled: !onFileUpload,
505
- multiple: false,
506
- noDrag: true,
507
- accept: {
508
- "image/*": IMAGE_FILES
509
- }
510
- });
511
- useImperativeHandle2(forwardedRef, () => open, []);
512
- useEffect2(() => {
513
- if (editorView && acceptedFiles.length && onFileUpload) {
514
- requestAnimationFrame(async () => {
515
- const f = acceptedFiles[0];
516
- const file = new File([
517
- f
518
- ], f.name, {
519
- type: f.type,
520
- lastModified: f.lastModified
521
- });
522
- const info = await onFileUpload(file);
523
- if (info) {
524
- addLink({
525
- url: info.url,
526
- image: true
527
- })(editorView);
528
- }
529
- });
530
- }
531
- }, [
532
- editorView,
533
- acceptedFiles,
534
- onFileUpload
535
- ]);
536
- if (!onFileUpload) {
537
- return null;
538
- }
539
- return /* @__PURE__ */ React3.createElement(React3.Fragment, null, /* @__PURE__ */ createPortal(/* @__PURE__ */ React3.createElement("input", {
540
- ref: inputRef
541
- }), document.body), " ");
542
- });
543
-
544
- // src/components/MarkdownEditor/MarkdownEditorToolbar.tsx
545
- var __dxlog_file3 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx";
546
- var MarkdownEditorToolbar = ({ classNames, id, role, state, editorView, customActions, onAction, onFileUpload, onViewModeChange }) => {
547
- const [upload, setUpload] = useState(null);
548
- const uploadRef = useCallback4((next) => setUpload(() => next), []);
549
- const handleViewModeChange = useCallback4((mode) => onViewModeChange?.(mode), [
550
- onViewModeChange
551
- ]);
552
- const getView = useCallback4(() => {
553
- invariant3(editorView, void 0, {
554
- F: __dxlog_file3,
555
- L: 41,
556
- S: void 0,
557
- A: [
558
- "editorView",
559
- ""
560
- ]
561
- });
562
- return editorView;
563
- }, [
564
- editorView
565
- ]);
566
- if (!editorView) {
567
- return /* @__PURE__ */ React4.createElement("div", null);
568
- }
569
- return /* @__PURE__ */ React4.createElement(React4.Fragment, null, /* @__PURE__ */ React4.createElement(EditorToolbar, {
570
- classNames,
571
- attendableId: id,
572
- role,
573
- state,
574
- customActions,
575
- getView,
576
- onAction,
577
- onImageUpload: upload ?? void 0,
578
- onViewModeChange: handleViewModeChange
579
- }), onFileUpload && /* @__PURE__ */ React4.createElement(FileUpload, {
580
- ref: uploadRef,
581
- editorView,
582
- onFileUpload
583
- }));
584
- };
585
-
586
- // src/components/MarkdownEditor/MarkdownEditor.tsx
587
- var [MarkdownEditorContextProvider, useMarkdownEditorContext] = createContext("MarkdownEditor.Context");
588
- var MarkdownEditorRoot = ({ children, id, object, editorStateStore, selectionManager, settings, viewMode, extensions: extensionsProp, slashCommandGroups, onLinkQuery, ...props }) => {
589
- const [editorView, setEditorView] = useState2();
590
- const [previewBlocks, setPreviewBlocks] = useState2([]);
591
- const previewOptions = useMemo6(() => ({
592
- addBlockContainer: (block) => {
593
- setPreviewBlocks((prev) => [
594
- ...prev,
595
- block
596
- ]);
597
- },
598
- removeBlockContainer: ({ link }) => {
599
- setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));
600
- }
601
- }), []);
602
- const toolbarState = useEditorToolbar({
603
- viewMode
604
- });
605
- const menuOptions = useEditorMenuOptions({
606
- editorView,
607
- slashCommandGroups,
608
- onLinkQuery
609
- });
610
- const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);
611
- const coreExtensions = useExtensions({
612
- id,
613
- object,
614
- editorStateStore,
615
- previewOptions,
616
- selectionManager,
617
- settings,
618
- viewMode
619
- });
620
- const extensions = useMemo6(() => [
621
- coreExtensions,
622
- menuExtension,
623
- extensionsProp
624
- ].filter(isNonNullable), [
625
- coreExtensions,
626
- menuExtension,
627
- extensionsProp
628
- ]);
629
- return /* @__PURE__ */ React5.createElement(MarkdownEditorContextProvider, {
630
- id,
631
- editorView,
632
- setEditorView,
633
- extensions,
634
- previewBlocks,
635
- toolbarState,
636
- popoverMenu: menuProps,
637
- viewMode,
638
- ...props
639
- }, children);
640
- };
641
- MarkdownEditorRoot.displayName = "MarkdownEditor.Root";
642
- var MarkdownEditorContent2 = (props) => {
643
- const { id, editorView, setEditorView, viewMode, toolbarState, extensions, popoverMenu: { groupsRef, ...menuProps } } = useMarkdownEditorContext(MarkdownEditorContent2.displayName);
644
- return /* @__PURE__ */ React5.createElement(EditorMenuProvider, {
645
- view: editorView,
646
- groups: groupsRef.current,
647
- ...menuProps
648
- }, /* @__PURE__ */ React5.createElement(MarkdownEditorContent, {
649
- ...props,
650
- id,
651
- viewMode,
652
- toolbarState,
653
- extensions,
654
- ref: setEditorView
655
- }));
656
- };
657
- MarkdownEditorContent2.displayName = "MarkdownEditor.Content";
658
- var MarkdownEditorToolbar2 = (props) => {
659
- const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar2.displayName);
660
- return /* @__PURE__ */ React5.createElement(MarkdownEditorToolbar, {
661
- ...props,
662
- ...rootProps,
663
- state: toolbarState
664
- });
665
- };
666
- MarkdownEditorToolbar2.displayName = "MarkdownEditor.Toolbar";
667
- var MarkdownEditorBlocks = (_props) => {
668
- const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);
669
- return /* @__PURE__ */ React5.createElement(React5.Fragment, null, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React5.createElement(PreviewBlock, {
670
- key: link.ref,
671
- link,
672
- el
673
- })));
674
- };
675
- MarkdownEditorBlocks.displayName = "MarkdownEditor.Blocks";
676
- var PreviewBlock = ({ el, link }) => {
677
- const client = useClient();
678
- const dxn = DXN.parse(link.ref);
679
- const subject = client.graph.makeRef(dxn).target;
680
- const data = useMemo6(() => ({
681
- subject
682
- }), [
683
- subject
684
- ]);
685
- return /* @__PURE__ */ createPortal2(/* @__PURE__ */ React5.createElement(Surface, {
686
- role: "card--transclusion",
687
- data,
688
- limit: 1
689
- }), el);
690
- };
691
- var MarkdownEditor = {
692
- Root: MarkdownEditorRoot,
693
- Content: MarkdownEditorContent2,
694
- Toolbar: MarkdownEditorToolbar2,
695
- Blocks: MarkdownEditorBlocks
696
- };
697
-
698
- export {
699
- useLinkQuery,
700
- MarkdownEditor
701
- };
702
- //# sourceMappingURL=chunk-BX73DASG.mjs.map