@dxos/plugin-markdown 0.8.4-main.3eb6e50203 → 0.8.4-main.4a85c3132b

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 (203) hide show
  1. package/dist/lib/browser/{chunk-EZZFREFN.mjs → MarkdownCard-5NPSEJ2M.mjs} +26 -23
  2. package/dist/lib/browser/MarkdownCard-5NPSEJ2M.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-7AQTX6D5.mjs → MarkdownContainer-KER2N5M2.mjs} +19 -16
  4. package/dist/lib/browser/MarkdownContainer-KER2N5M2.mjs.map +7 -0
  5. package/dist/lib/browser/{react-surface-7Z6AB26V.mjs → MarkdownSettings-2N4TT2FG.mjs} +6 -113
  6. package/dist/lib/browser/MarkdownSettings-2N4TT2FG.mjs.map +7 -0
  7. package/dist/lib/browser/{anchor-sort-JBAZRPE7.mjs → anchor-sort-EHJGOCYW.mjs} +3 -2
  8. package/dist/lib/browser/{app-graph-serializer-6Q5YBUPW.mjs → app-graph-serializer-QBZDVASK.mjs} +5 -4
  9. package/dist/lib/browser/app-graph-serializer-QBZDVASK.mjs.map +7 -0
  10. package/dist/lib/browser/{blueprint-definition-6HOAW2E6.mjs → blueprint-definition-ASGDSKKE.mjs} +7 -9
  11. package/dist/lib/browser/blueprint-definition-ASGDSKKE.mjs.map +7 -0
  12. package/dist/lib/browser/blueprints/index.mjs +5 -4
  13. package/dist/lib/browser/{chunk-HHRUUWGH.mjs → chunk-7JEOX3X6.mjs} +169 -182
  14. package/dist/lib/browser/chunk-7JEOX3X6.mjs.map +7 -0
  15. package/dist/lib/browser/{chunk-6SM75KL3.mjs → chunk-HK6EGNP5.mjs} +2 -2
  16. package/dist/lib/browser/{chunk-4GT3QWMK.mjs → chunk-P3TN2W6M.mjs} +20 -33
  17. package/dist/lib/browser/chunk-P3TN2W6M.mjs.map +7 -0
  18. package/dist/lib/browser/{chunk-2AAD3W6X.mjs → chunk-RJO5W5YX.mjs} +5 -3
  19. package/dist/lib/{node-esm/chunk-MLZQCT2N.mjs.map → browser/chunk-RJO5W5YX.mjs.map} +1 -1
  20. package/dist/lib/browser/{chunk-HQTBT5IY.mjs → chunk-W24NJ6WB.mjs} +26 -24
  21. package/dist/lib/browser/chunk-W24NJ6WB.mjs.map +7 -0
  22. package/dist/lib/browser/chunk-YBMRREXE.mjs +28 -0
  23. package/dist/lib/browser/chunk-YBMRREXE.mjs.map +7 -0
  24. package/dist/lib/browser/cli/index.mjs +5 -3
  25. package/dist/lib/browser/cli/index.mjs.map +1 -1
  26. package/dist/lib/browser/index.mjs +16 -14
  27. package/dist/lib/browser/index.mjs.map +3 -3
  28. package/dist/lib/browser/meta.json +1 -1
  29. package/dist/lib/browser/{operation-resolver-UBQUPSXC.mjs → operation-resolver-3KOXJM7P.mjs} +5 -4
  30. package/dist/lib/browser/operation-resolver-3KOXJM7P.mjs.map +7 -0
  31. package/dist/lib/browser/react-surface-WU4VTE43.mjs +115 -0
  32. package/dist/lib/browser/react-surface-WU4VTE43.mjs.map +7 -0
  33. package/dist/lib/browser/{settings-V2XOFSD5.mjs → settings-7FMWKB7N.mjs} +5 -3
  34. package/dist/lib/{node-esm/settings-EXSH2KF4.mjs.map → browser/settings-7FMWKB7N.mjs.map} +1 -1
  35. package/dist/lib/browser/{state-6Y3JB64H.mjs → state-7UJKJDGE.mjs} +5 -3
  36. package/dist/lib/{node-esm/state-TVF2XT2T.mjs.map → browser/state-7UJKJDGE.mjs.map} +1 -1
  37. package/dist/lib/browser/types/index.mjs +2 -1
  38. package/dist/lib/node-esm/{chunk-DCKB3AVD.mjs → MarkdownCard-4MXS7AQR.mjs} +26 -23
  39. package/dist/lib/node-esm/MarkdownCard-4MXS7AQR.mjs.map +7 -0
  40. package/dist/lib/node-esm/{chunk-K2IIYNCG.mjs → MarkdownContainer-BZ637MS3.mjs} +19 -16
  41. package/dist/lib/node-esm/MarkdownContainer-BZ637MS3.mjs.map +7 -0
  42. package/dist/lib/node-esm/{react-surface-VIXAH5CF.mjs → MarkdownSettings-FQTYCTD7.mjs} +6 -113
  43. package/dist/lib/node-esm/MarkdownSettings-FQTYCTD7.mjs.map +7 -0
  44. package/dist/lib/node-esm/{anchor-sort-IQMDZRA3.mjs → anchor-sort-QWZO6B2R.mjs} +3 -2
  45. package/dist/lib/{browser/anchor-sort-JBAZRPE7.mjs.map → node-esm/anchor-sort-QWZO6B2R.mjs.map} +1 -1
  46. package/dist/lib/node-esm/{app-graph-serializer-STEPJH57.mjs → app-graph-serializer-3UVXEHJG.mjs} +5 -4
  47. package/dist/lib/node-esm/app-graph-serializer-3UVXEHJG.mjs.map +7 -0
  48. package/dist/lib/node-esm/{blueprint-definition-UGDFF5OZ.mjs → blueprint-definition-TG7OZIWW.mjs} +7 -9
  49. package/dist/lib/node-esm/blueprint-definition-TG7OZIWW.mjs.map +7 -0
  50. package/dist/lib/node-esm/blueprints/index.mjs +5 -4
  51. package/dist/lib/node-esm/{chunk-MLZQCT2N.mjs → chunk-ANIFP6M2.mjs} +5 -3
  52. package/dist/lib/{browser/chunk-2AAD3W6X.mjs.map → node-esm/chunk-ANIFP6M2.mjs.map} +1 -1
  53. package/dist/lib/node-esm/{chunk-AGZOFIK2.mjs → chunk-KCH3EL53.mjs} +2 -2
  54. package/dist/lib/node-esm/{chunk-D46D75SK.mjs → chunk-N73JZ4CD.mjs} +169 -182
  55. package/dist/lib/node-esm/chunk-N73JZ4CD.mjs.map +7 -0
  56. package/dist/lib/node-esm/{chunk-LOZVC2WA.mjs → chunk-NBGAJPVH.mjs} +26 -24
  57. package/dist/lib/node-esm/chunk-NBGAJPVH.mjs.map +7 -0
  58. package/dist/lib/node-esm/chunk-W7AM4HCG.mjs +29 -0
  59. package/dist/lib/node-esm/chunk-W7AM4HCG.mjs.map +7 -0
  60. package/dist/lib/node-esm/{chunk-USKAPINH.mjs → chunk-WBZQ246U.mjs} +20 -33
  61. package/dist/lib/node-esm/chunk-WBZQ246U.mjs.map +7 -0
  62. package/dist/lib/node-esm/cli/index.mjs +5 -3
  63. package/dist/lib/node-esm/cli/index.mjs.map +1 -1
  64. package/dist/lib/node-esm/index.mjs +16 -14
  65. package/dist/lib/node-esm/index.mjs.map +3 -3
  66. package/dist/lib/node-esm/meta.json +1 -1
  67. package/dist/lib/node-esm/{operation-resolver-QAGXDA5E.mjs → operation-resolver-2MEWKRFP.mjs} +5 -4
  68. package/dist/lib/node-esm/operation-resolver-2MEWKRFP.mjs.map +7 -0
  69. package/dist/lib/node-esm/react-surface-LC5CI6VP.mjs +116 -0
  70. package/dist/lib/node-esm/react-surface-LC5CI6VP.mjs.map +7 -0
  71. package/dist/lib/node-esm/{settings-EXSH2KF4.mjs → settings-DBK2SPWT.mjs} +5 -3
  72. package/dist/lib/{browser/settings-V2XOFSD5.mjs.map → node-esm/settings-DBK2SPWT.mjs.map} +1 -1
  73. package/dist/lib/node-esm/{state-TVF2XT2T.mjs → state-EEPLRAOT.mjs} +5 -3
  74. package/dist/lib/{browser/state-6Y3JB64H.mjs.map → node-esm/state-EEPLRAOT.mjs.map} +1 -1
  75. package/dist/lib/node-esm/types/index.mjs +2 -1
  76. package/dist/types/src/blueprints/functions/index.d.ts +41 -3
  77. package/dist/types/src/blueprints/functions/index.d.ts.map +1 -1
  78. package/dist/types/src/blueprints/index.d.ts +1 -1
  79. package/dist/types/src/blueprints/index.d.ts.map +1 -1
  80. package/dist/types/src/blueprints/markdown-blueprint.d.ts +3 -20
  81. package/dist/types/src/blueprints/markdown-blueprint.d.ts.map +1 -1
  82. package/dist/types/src/capabilities/anchor-sort/anchor-sort.d.ts +1 -1
  83. package/dist/types/src/capabilities/app-graph-serializer/app-graph-serializer.d.ts +1 -1
  84. package/dist/types/src/capabilities/artifact-definition/artifact-definition.d.ts +1 -1
  85. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +1 -6
  86. package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +1 -1
  87. package/dist/types/src/capabilities/blueprint-definition/index.d.ts +1 -1
  88. package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +1 -1
  89. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +1 -1
  90. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +1 -1
  91. package/dist/types/src/capabilities/settings/settings.d.ts +1 -1
  92. package/dist/types/src/capabilities/state/state.d.ts +1 -1
  93. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  94. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  95. package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -1
  96. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +3 -3
  97. package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -1
  98. package/dist/types/src/components/index.d.ts +1 -8
  99. package/dist/types/src/components/index.d.ts.map +1 -1
  100. package/dist/types/src/containers/MarkdownCard/MarkdownCard.d.ts.map +1 -0
  101. package/dist/types/src/containers/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
  102. package/dist/types/src/{components → containers}/MarkdownCard/index.d.ts +0 -1
  103. package/dist/types/src/containers/MarkdownCard/index.d.ts.map +1 -0
  104. package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.d.ts +2 -3
  105. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.d.ts.map +1 -0
  106. package/dist/types/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.d.ts +1 -1
  107. package/dist/types/src/containers/MarkdownContainer/MarkdownContainer.stories.d.ts.map +1 -0
  108. package/dist/types/src/containers/MarkdownContainer/index.d.ts +3 -0
  109. package/dist/types/src/containers/MarkdownContainer/index.d.ts.map +1 -0
  110. package/dist/types/src/{components → containers}/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
  111. package/dist/types/src/containers/MarkdownSettings/index.d.ts +3 -0
  112. package/dist/types/src/containers/MarkdownSettings/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/useExtensions.d.ts.map +1 -1
  116. package/dist/types/src/index.d.ts +1 -1
  117. package/dist/types/src/index.d.ts.map +1 -1
  118. package/dist/types/src/types/Markdown.d.ts +1 -1
  119. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  120. package/dist/types/src/types/MarkdownAction.d.ts +1 -1
  121. package/dist/types/src/util.d.ts +1 -1
  122. package/dist/types/src/util.d.ts.map +1 -1
  123. package/dist/types/tsconfig.tsbuildinfo +1 -1
  124. package/package.json +48 -48
  125. package/src/MarkdownPlugin.tsx +1 -1
  126. package/src/blueprints/functions/create.conversations.json +1 -1
  127. package/src/blueprints/functions/create.test.ts +2 -2
  128. package/src/blueprints/functions/create.ts +2 -2
  129. package/src/blueprints/functions/index.ts +11 -3
  130. package/src/blueprints/functions/open.ts +2 -2
  131. package/src/blueprints/functions/update.conversations.json +1 -1
  132. package/src/blueprints/functions/update.test.ts +2 -2
  133. package/src/blueprints/functions/update.ts +2 -2
  134. package/src/blueprints/index.ts +1 -1
  135. package/src/blueprints/markdown-blueprint.ts +14 -6
  136. package/src/capabilities/app-graph-serializer/app-graph-serializer.ts +1 -1
  137. package/src/capabilities/blueprint-definition/blueprint-definition.ts +4 -13
  138. package/src/capabilities/operation-resolver/operation-resolver.ts +2 -2
  139. package/src/capabilities/react-surface/react-surface.tsx +1 -1
  140. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +10 -8
  141. package/src/components/MarkdownEditor/MarkdownEditor.tsx +13 -3
  142. package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +3 -4
  143. package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +6 -5
  144. package/src/components/index.ts +2 -14
  145. package/src/{components → containers}/MarkdownCard/MarkdownCard.stories.tsx +16 -6
  146. package/src/{components → containers}/MarkdownCard/MarkdownCard.tsx +21 -24
  147. package/src/{components → containers}/MarkdownCard/index.ts +0 -2
  148. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.stories.tsx +18 -5
  149. package/src/{components → containers/MarkdownContainer}/MarkdownContainer.tsx +25 -24
  150. package/src/containers/MarkdownContainer/index.ts +7 -0
  151. package/src/containers/MarkdownSettings/index.ts +7 -0
  152. package/src/containers/index.ts +11 -0
  153. package/src/hooks/useEditorMenuOptions.ts +1 -1
  154. package/src/hooks/useExtensions.tsx +51 -81
  155. package/src/index.ts +1 -1
  156. package/src/testing.ts +1 -1
  157. package/src/types/Markdown.ts +12 -4
  158. package/src/types/MarkdownAction.ts +1 -1
  159. package/src/util.tsx +2 -2
  160. package/dist/lib/browser/MarkdownCard-7VIO7R66.mjs +0 -11
  161. package/dist/lib/browser/MarkdownCard-7VIO7R66.mjs.map +0 -7
  162. package/dist/lib/browser/MarkdownContainer-6E43EDAU.mjs +0 -11
  163. package/dist/lib/browser/MarkdownContainer-6E43EDAU.mjs.map +0 -7
  164. package/dist/lib/browser/app-graph-serializer-6Q5YBUPW.mjs.map +0 -7
  165. package/dist/lib/browser/blueprint-definition-6HOAW2E6.mjs.map +0 -7
  166. package/dist/lib/browser/chunk-4GT3QWMK.mjs.map +0 -7
  167. package/dist/lib/browser/chunk-7AQTX6D5.mjs.map +0 -7
  168. package/dist/lib/browser/chunk-EZZFREFN.mjs.map +0 -7
  169. package/dist/lib/browser/chunk-HHRUUWGH.mjs.map +0 -7
  170. package/dist/lib/browser/chunk-HQTBT5IY.mjs.map +0 -7
  171. package/dist/lib/browser/operation-resolver-UBQUPSXC.mjs.map +0 -7
  172. package/dist/lib/browser/react-surface-7Z6AB26V.mjs.map +0 -7
  173. package/dist/lib/node-esm/MarkdownCard-YC3R2TQW.mjs +0 -12
  174. package/dist/lib/node-esm/MarkdownCard-YC3R2TQW.mjs.map +0 -7
  175. package/dist/lib/node-esm/MarkdownContainer-TTRUOXU6.mjs +0 -12
  176. package/dist/lib/node-esm/MarkdownContainer-TTRUOXU6.mjs.map +0 -7
  177. package/dist/lib/node-esm/app-graph-serializer-STEPJH57.mjs.map +0 -7
  178. package/dist/lib/node-esm/blueprint-definition-UGDFF5OZ.mjs.map +0 -7
  179. package/dist/lib/node-esm/chunk-D46D75SK.mjs.map +0 -7
  180. package/dist/lib/node-esm/chunk-DCKB3AVD.mjs.map +0 -7
  181. package/dist/lib/node-esm/chunk-K2IIYNCG.mjs.map +0 -7
  182. package/dist/lib/node-esm/chunk-LOZVC2WA.mjs.map +0 -7
  183. package/dist/lib/node-esm/chunk-USKAPINH.mjs.map +0 -7
  184. package/dist/lib/node-esm/operation-resolver-QAGXDA5E.mjs.map +0 -7
  185. package/dist/lib/node-esm/react-surface-VIXAH5CF.mjs.map +0 -7
  186. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +0 -1
  187. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +0 -1
  188. package/dist/types/src/components/MarkdownCard/index.d.ts.map +0 -1
  189. package/dist/types/src/components/MarkdownContainer.d.ts.map +0 -1
  190. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +0 -1
  191. package/dist/types/src/components/MarkdownSettings/index.d.ts +0 -2
  192. package/dist/types/src/components/MarkdownSettings/index.d.ts.map +0 -1
  193. package/dist/types/src/components/Suggestions.stories.d.ts +0 -11
  194. package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
  195. package/src/components/MarkdownSettings/index.ts +0 -5
  196. package/src/components/Suggestions.stories.tsx +0 -215
  197. /package/dist/lib/{node-esm/anchor-sort-IQMDZRA3.mjs.map → browser/anchor-sort-EHJGOCYW.mjs.map} +0 -0
  198. /package/dist/lib/browser/{chunk-6SM75KL3.mjs.map → chunk-HK6EGNP5.mjs.map} +0 -0
  199. /package/dist/lib/node-esm/{chunk-AGZOFIK2.mjs.map → chunk-KCH3EL53.mjs.map} +0 -0
  200. /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.d.ts +0 -0
  201. /package/dist/types/src/{components → containers}/MarkdownCard/MarkdownCard.stories.d.ts +0 -0
  202. /package/dist/types/src/{components → containers}/MarkdownSettings/MarkdownSettings.d.ts +0 -0
  203. /package/src/{components → containers}/MarkdownSettings/MarkdownSettings.tsx +0 -0
@@ -0,0 +1,115 @@
1
+ import {
2
+ MarkdownCapabilities,
3
+ Markdown_exports
4
+ } from "./chunk-P3TN2W6M.mjs";
5
+ import {
6
+ meta
7
+ } from "./chunk-YBMRREXE.mjs";
8
+
9
+ // src/capabilities/react-surface/react-surface.tsx
10
+ import * as Effect from "effect/Effect";
11
+ import React, { forwardRef, useCallback, useMemo } from "react";
12
+ import { Capabilities, Capability } from "@dxos/app-framework";
13
+ import { Surface, useAtomCapability, useAtomCapabilityState, useCapability, useSettingsState } from "@dxos/app-framework/ui";
14
+ import { AppCapabilities } from "@dxos/app-toolkit";
15
+ import { Obj } from "@dxos/echo";
16
+ import { AttentionCapabilities } from "@dxos/plugin-attention";
17
+ import { Text } from "@dxos/schema";
18
+
19
+ // src/containers/index.ts
20
+ import { lazy } from "react";
21
+ var MarkdownCard = lazy(() => import("./MarkdownCard-5NPSEJ2M.mjs"));
22
+ var MarkdownContainer = lazy(() => import("./MarkdownContainer-KER2N5M2.mjs"));
23
+ var MarkdownSettings = lazy(() => import("./MarkdownSettings-2N4TT2FG.mjs"));
24
+
25
+ // src/capabilities/react-surface/react-surface.tsx
26
+ var react_surface_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(Capabilities.ReactSurface, [
27
+ Surface.create({
28
+ id: `${meta.id}/surface/document`,
29
+ role: [
30
+ "article",
31
+ "section",
32
+ "tabpanel"
33
+ ],
34
+ filter: (data) => Obj.instanceOf(Markdown_exports.Document, data.subject) && !data.variant,
35
+ component: ({ data, role, ref }) => {
36
+ return /* @__PURE__ */ React.createElement(Container, {
37
+ id: Obj.getDXN(data.subject).toString(),
38
+ subject: data.subject,
39
+ role,
40
+ ref
41
+ });
42
+ }
43
+ }),
44
+ Surface.create({
45
+ id: `${meta.id}/surface/text`,
46
+ role: [
47
+ "article",
48
+ "section",
49
+ "tabpanel"
50
+ ],
51
+ filter: (data) => typeof data.id === "string" && Obj.instanceOf(Text.Text, data.subject),
52
+ component: ({ data, role }) => {
53
+ return /* @__PURE__ */ React.createElement(Container, {
54
+ id: data.id,
55
+ subject: data.subject,
56
+ role
57
+ });
58
+ }
59
+ }),
60
+ Surface.create({
61
+ id: `${meta.id}/surface/plugin-settings`,
62
+ role: "article",
63
+ filter: (data) => AppCapabilities.isSettings(data.subject) && data.subject.prefix === meta.id,
64
+ component: ({ data: { subject } }) => {
65
+ const { settings, updateSettings } = useSettingsState(subject.atom);
66
+ return /* @__PURE__ */ React.createElement(MarkdownSettings, {
67
+ settings,
68
+ onSettingsChange: updateSettings
69
+ });
70
+ }
71
+ }),
72
+ Surface.create({
73
+ id: `${meta.id}/surface/preview`,
74
+ role: "card--content",
75
+ filter: (data) => Obj.instanceOf(Markdown_exports.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),
76
+ component: ({ data }) => /* @__PURE__ */ React.createElement(MarkdownCard, data)
77
+ })
78
+ ])));
79
+ var Container = /* @__PURE__ */ forwardRef(({ id, subject, role }, forwardedRef) => {
80
+ const selectionManager = useCapability(AttentionCapabilities.Selection);
81
+ const settings = useAtomCapability(MarkdownCapabilities.Settings);
82
+ const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
83
+ const editorState = useCapability(MarkdownCapabilities.EditorState);
84
+ const extensions = useCapability(MarkdownCapabilities.Extensions);
85
+ const extensionProviders = useMemo(() => extensions.flat(), [
86
+ extensions
87
+ ]);
88
+ const viewMode = id && state.viewMode[id] || settings?.defaultViewMode || "source";
89
+ const handleViewModeChange = useCallback((mode) => setState((current) => ({
90
+ ...current,
91
+ viewMode: {
92
+ ...current.viewMode,
93
+ [id]: mode
94
+ }
95
+ })), [
96
+ id,
97
+ setState
98
+ ]);
99
+ return /* @__PURE__ */ React.createElement(MarkdownContainer, {
100
+ role,
101
+ subject,
102
+ id,
103
+ settings,
104
+ selectionManager,
105
+ extensionProviders,
106
+ editorStateStore: editorState,
107
+ viewMode,
108
+ onViewModeChange: handleViewModeChange,
109
+ ref: forwardedRef
110
+ });
111
+ });
112
+ export {
113
+ react_surface_default as default
114
+ };
115
+ //# sourceMappingURL=react-surface-WU4VTE43.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/react-surface/react-surface.tsx", "../../../src/containers/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\nimport React, { forwardRef, useCallback, useMemo } from 'react';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport {\n Surface,\n useAtomCapability,\n useAtomCapabilityState,\n useCapability,\n useSettingsState,\n} from '@dxos/app-framework/ui';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { type SurfaceComponentProps } from '@dxos/app-toolkit/ui';\nimport { Obj } from '@dxos/echo';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { Text } from '@dxos/schema';\nimport { type EditorViewMode } from '@dxos/ui-editor';\n\nimport { MarkdownCard, MarkdownContainer, type MarkdownContainerProps, MarkdownSettings } from '../../containers';\nimport { meta } from '../../meta';\nimport { Markdown, MarkdownCapabilities } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.succeed(\n Capability.contributes(Capabilities.ReactSurface, [\n Surface.create({\n id: `${meta.id}/surface/document`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { subject: Markdown.Document; variant: undefined } =>\n Obj.instanceOf(Markdown.Document, data.subject) && !data.variant,\n component: ({ data, role, ref }) => {\n return <Container id={Obj.getDXN(data.subject).toString()} subject={data.subject} role={role} ref={ref} />;\n },\n }),\n Surface.create({\n id: `${meta.id}/surface/text`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { id: string; subject: Text.Text } =>\n typeof data.id === 'string' && Obj.instanceOf(Text.Text, data.subject),\n component: ({ data, role }) => {\n return <Container id={data.id} subject={data.subject} role={role} />;\n },\n }),\n Surface.create({\n id: `${meta.id}/surface/plugin-settings`,\n role: 'article',\n filter: (data): data is { subject: AppCapabilities.Settings } =>\n AppCapabilities.isSettings(data.subject) && data.subject.prefix === meta.id,\n component: ({ data: { subject } }) => {\n const { settings, updateSettings } = useSettingsState<Markdown.Settings>(subject.atom);\n return <MarkdownSettings settings={settings} onSettingsChange={updateSettings} />;\n },\n }),\n Surface.create({\n id: `${meta.id}/surface/preview`,\n role: 'card--content',\n filter: (data): data is { subject: Markdown.Document | Text.Text } =>\n Obj.instanceOf(Markdown.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),\n component: ({ data }) => <MarkdownCard {...data} />,\n }),\n ]),\n ),\n);\n\n/**\n * Common wrapper.\n */\nconst Container = forwardRef<HTMLDivElement, SurfaceComponentProps<Markdown.Document | Text.Text, { id: string }>>(\n ({ id, subject, role }, forwardedRef) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settings = useAtomCapability(MarkdownCapabilities.Settings);\n const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);\n const editorState = useCapability(MarkdownCapabilities.EditorState);\n const extensions = useCapability(MarkdownCapabilities.Extensions);\n const extensionProviders = useMemo(() => extensions.flat(), [extensions]);\n\n const viewMode: EditorViewMode = (id && state.viewMode[id]) || settings?.defaultViewMode || 'source';\n const handleViewModeChange = useCallback<NonNullable<MarkdownContainerProps['onViewModeChange']>>(\n (mode) => setState((current) => ({ ...current, viewMode: { ...current.viewMode, [id]: mode } })),\n [id, setState],\n );\n\n return (\n <MarkdownContainer\n role={role}\n subject={subject}\n id={id}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={extensionProviders}\n editorStateStore={editorState}\n viewMode={viewMode}\n onViewModeChange={handleViewModeChange}\n ref={forwardedRef}\n />\n );\n },\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type ComponentType, lazy } from 'react';\n\nexport type { MarkdownContainerProps } from './MarkdownContainer/MarkdownContainer';\n\nexport const MarkdownCard: ComponentType<any> = lazy(() => import('./MarkdownCard'));\nexport const MarkdownContainer: ComponentType<any> = lazy(() => import('./MarkdownContainer'));\nexport const MarkdownSettings: ComponentType<any> = lazy(() => import('./MarkdownSettings'));\n"],
5
+ "mappings": "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",
6
+ "names": ["Effect", "React", "forwardRef", "useCallback", "useMemo", "Capabilities", "Capability", "Surface", "useAtomCapability", "useAtomCapabilityState", "useCapability", "useSettingsState", "AppCapabilities", "Obj", "AttentionCapabilities", "Text", "lazy", "MarkdownCard", "lazy", "MarkdownContainer", "MarkdownSettings", "Capability", "makeModule", "succeed", "contributes", "Capabilities", "ReactSurface", "Surface", "create", "id", "meta", "role", "filter", "data", "Obj", "instanceOf", "Markdown", "Document", "subject", "variant", "component", "ref", "Container", "getDXN", "toString", "Text", "AppCapabilities", "isSettings", "prefix", "settings", "updateSettings", "useSettingsState", "atom", "MarkdownSettings", "onSettingsChange", "MarkdownCard", "forwardRef", "forwardedRef", "selectionManager", "useCapability", "AttentionCapabilities", "Selection", "useAtomCapability", "MarkdownCapabilities", "Settings", "state", "setState", "useAtomCapabilityState", "State", "editorState", "EditorState", "extensions", "Extensions", "extensionProviders", "useMemo", "flat", "viewMode", "defaultViewMode", "handleViewModeChange", "useCallback", "mode", "current", "MarkdownContainer", "editorStateStore", "onViewModeChange"]
7
+ }
@@ -1,8 +1,10 @@
1
1
  import {
2
2
  MarkdownCapabilities,
3
- Markdown_exports,
3
+ Markdown_exports
4
+ } from "./chunk-P3TN2W6M.mjs";
5
+ import {
4
6
  meta
5
- } from "./chunk-4GT3QWMK.mjs";
7
+ } from "./chunk-YBMRREXE.mjs";
6
8
 
7
9
  // src/capabilities/settings/settings.ts
8
10
  import * as Effect from "effect/Effect";
@@ -33,4 +35,4 @@ var settings_default = Capability.makeModule(() => Effect.sync(() => {
33
35
  export {
34
36
  settings_default as default
35
37
  };
36
- //# sourceMappingURL=settings-V2XOFSD5.mjs.map
38
+ //# sourceMappingURL=settings-7FMWKB7N.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/capabilities/settings/settings.ts"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { createKvsStore } from '@dxos/effect';\n\nimport { meta } from '../../meta';\nimport { Markdown, MarkdownCapabilities } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.sync(() => {\n const settingsAtom = createKvsStore({\n key: meta.id,\n schema: Markdown.Settings,\n defaultValue: () => ({\n defaultViewMode: 'preview' as const,\n toolbar: true,\n numberedHeadings: true,\n folding: true,\n experimental: false,\n }),\n });\n\n return [\n Capability.contributes(MarkdownCapabilities.Settings, settingsAtom),\n Capability.contributes(AppCapabilities.Settings, {\n prefix: meta.id,\n schema: Markdown.Settings,\n atom: settingsAtom,\n }),\n ];\n }),\n);\n"],
5
- "mappings": ";;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,sBAAsB;AAK/B,IAAA,mBAAeC,WAAWC,WAAW,MAC5BC,YAAK,MAAA;AACV,QAAMC,eAAeC,eAAe;IAClCC,KAAKC,KAAKC;IACVC,QAAQC,iBAASC;IACjBC,cAAc,OAAO;MACnBC,iBAAiB;MACjBC,SAAS;MACTC,kBAAkB;MAClBC,SAAS;MACTC,cAAc;IAChB;EACF,CAAA;AAEA,SAAO;IACLhB,WAAWiB,YAAYC,qBAAqBR,UAAUP,YAAAA;IACtDH,WAAWiB,YAAYE,gBAAgBT,UAAU;MAC/CU,QAAQd,KAAKC;MACbC,QAAQC,iBAASC;MACjBW,MAAMlB;IACR,CAAA;;AAEJ,CAAA,CAAA;",
5
+ "mappings": ";;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,sBAAsB;AAK/B,IAAA,mBAAeC,WAAWC,WAAW,MAC5BC,YAAK,MAAA;AACV,QAAMC,eAAeC,eAAe;IAClCC,KAAKC,KAAKC;IACVC,QAAQC,iBAASC;IACjBC,cAAc,OAAO;MACnBC,iBAAiB;MACjBC,SAAS;MACTC,kBAAkB;MAClBC,SAAS;MACTC,cAAc;IAChB;EACF,CAAA;AAEA,SAAO;IACLhB,WAAWiB,YAAYC,qBAAqBR,UAAUP,YAAAA;IACtDH,WAAWiB,YAAYE,gBAAgBT,UAAU;MAC/CU,QAAQd,KAAKC;MACbC,QAAQC,iBAASC;MACjBW,MAAMlB;IACR,CAAA;;AAEJ,CAAA,CAAA;",
6
6
  "names": ["Effect", "Capability", "AppCapabilities", "createKvsStore", "Capability", "makeModule", "sync", "settingsAtom", "createKvsStore", "key", "meta", "id", "schema", "Markdown", "Settings", "defaultValue", "defaultViewMode", "toolbar", "numberedHeadings", "folding", "experimental", "contributes", "MarkdownCapabilities", "AppCapabilities", "prefix", "atom"]
7
7
  }
@@ -1,8 +1,10 @@
1
1
  import {
2
2
  MarkdownCapabilities,
3
- MarkdownStateSchema,
3
+ MarkdownStateSchema
4
+ } from "./chunk-P3TN2W6M.mjs";
5
+ import {
4
6
  meta
5
- } from "./chunk-4GT3QWMK.mjs";
7
+ } from "./chunk-YBMRREXE.mjs";
6
8
 
7
9
  // src/capabilities/state/state.ts
8
10
  import * as Effect from "effect/Effect";
@@ -26,4 +28,4 @@ var state_default = Capability.makeModule(Effect.fnUntraced(function* () {
26
28
  export {
27
29
  state_default as default
28
30
  };
29
- //# sourceMappingURL=state-6Y3JB64H.mjs.map
31
+ //# sourceMappingURL=state-7UJKJDGE.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/capabilities/state/state.ts"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { createKvsStore } from '@dxos/effect';\nimport { createEditorStateStore } from '@dxos/ui-editor';\n\nimport { meta } from '../../meta';\nimport { MarkdownCapabilities, MarkdownStateSchema } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n // Persisted state using KVS store.\n const stateAtom = createKvsStore({\n key: `${meta.id}/state`,\n schema: MarkdownStateSchema,\n defaultValue: () => ({ viewMode: {} }),\n });\n\n // TODO(wittjosiah): Fold into state.\n const editorState = createEditorStateStore(`${meta.id}/editor`);\n\n return [\n Capability.contributes(MarkdownCapabilities.State, stateAtom),\n Capability.contributes(MarkdownCapabilities.EditorState, editorState),\n ];\n }),\n);\n"],
5
- "mappings": ";;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAC/B,SAASC,8BAA8B;AAKvC,IAAA,gBAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAEhB,QAAMC,YAAYC,eAAe;IAC/BC,KAAK,GAAGC,KAAKC,EAAE;IACfC,QAAQC;IACRC,cAAc,OAAO;MAAEC,UAAU,CAAC;IAAE;EACtC,CAAA;AAGA,QAAMC,cAAcC,uBAAuB,GAAGP,KAAKC,EAAE,SAAS;AAE9D,SAAO;IACLP,WAAWc,YAAYC,qBAAqBC,OAAOb,SAAAA;IACnDH,WAAWc,YAAYC,qBAAqBE,aAAaL,WAAAA;;AAE7D,CAAA,CAAA;",
5
+ "mappings": ";;;;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,sBAAsB;AAC/B,SAASC,8BAA8B;AAKvC,IAAA,gBAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAEhB,QAAMC,YAAYC,eAAe;IAC/BC,KAAK,GAAGC,KAAKC,EAAE;IACfC,QAAQC;IACRC,cAAc,OAAO;MAAEC,UAAU,CAAC;IAAE;EACtC,CAAA;AAGA,QAAMC,cAAcC,uBAAuB,GAAGP,KAAKC,EAAE,SAAS;AAE9D,SAAO;IACLP,WAAWc,YAAYC,qBAAqBC,OAAOb,SAAAA;IACnDH,WAAWc,YAAYC,qBAAqBE,aAAaL,WAAAA;;AAE7D,CAAA,CAAA;",
6
6
  "names": ["Effect", "Capability", "createKvsStore", "createEditorStateStore", "Capability", "makeModule", "fnUntraced", "stateAtom", "createKvsStore", "key", "meta", "id", "schema", "MarkdownStateSchema", "defaultValue", "viewMode", "editorState", "createEditorStateStore", "contributes", "MarkdownCapabilities", "State", "EditorState"]
7
7
  }
@@ -5,7 +5,8 @@ import {
5
5
  MarkdownOperation,
6
6
  MarkdownStateSchema,
7
7
  Markdown_exports
8
- } from "../chunk-4GT3QWMK.mjs";
8
+ } from "../chunk-P3TN2W6M.mjs";
9
+ import "../chunk-YBMRREXE.mjs";
9
10
  export {
10
11
  Markdown_exports as Markdown,
11
12
  MarkdownAction_exports as MarkdownAction,
@@ -2,17 +2,19 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  MarkdownEditor,
4
4
  getContentSnippet
5
- } from "./chunk-D46D75SK.mjs";
5
+ } from "./chunk-N73JZ4CD.mjs";
6
+ import {
7
+ Markdown_exports
8
+ } from "./chunk-WBZQ246U.mjs";
6
9
  import {
7
- Markdown_exports,
8
10
  meta
9
- } from "./chunk-USKAPINH.mjs";
11
+ } from "./chunk-W7AM4HCG.mjs";
10
12
 
11
- // src/components/MarkdownCard/MarkdownCard.tsx
13
+ // src/containers/MarkdownCard/MarkdownCard.tsx
12
14
  import React, { useMemo } from "react";
13
15
  import { Obj } from "@dxos/echo";
14
16
  import { useTranslation } from "@dxos/react-ui";
15
- import { Card } from "@dxos/react-ui-mosaic";
17
+ import { Card } from "@dxos/react-ui";
16
18
  import { Text } from "@dxos/schema";
17
19
  var MarkdownCard = ({ subject }) => {
18
20
  const { t } = useTranslation(meta.id);
@@ -20,40 +22,41 @@ var MarkdownCard = ({ subject }) => {
20
22
  subject
21
23
  ]);
22
24
  const info = getInfo(subject);
23
- return /* @__PURE__ */ React.createElement(Card.Content, null, snippet && /* @__PURE__ */ React.createElement(Card.Row, {
24
- className: "max-h-[300px] overflow-hidden"
25
- }, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
25
+ return /* @__PURE__ */ React.createElement(Card.Content, null, snippet && /* @__PURE__ */ React.createElement(Card.Section, null, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
26
26
  id: subject.id,
27
27
  viewMode: "readonly"
28
28
  }, /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
29
29
  initialValue: snippet,
30
- slots: {},
31
- classNames: "!bg-transparent"
32
- }))), /* @__PURE__ */ React.createElement(Card.Row, null, /* @__PURE__ */ React.createElement(Card.Text, {
30
+ classNames: "bg-transparent",
31
+ slots: {
32
+ editor: {
33
+ className: "max-h-[240px]"
34
+ }
35
+ }
36
+ }))), /* @__PURE__ */ React.createElement(Card.Section, null, /* @__PURE__ */ React.createElement(Card.Text, {
33
37
  classNames: "text-xs text-description"
34
38
  }, info.words, " ", t("words label", {
35
39
  count: info.words
36
40
  }))));
37
41
  };
42
+ var MAX_LINES = 5;
43
+ var getSnippet = (subject, fallback) => {
44
+ if (Obj.instanceOf(Markdown_exports.Document, subject)) {
45
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback, MAX_LINES);
46
+ } else if (Obj.instanceOf(Text.Text, subject)) {
47
+ return getContentSnippet(subject.content ?? fallback, MAX_LINES);
48
+ }
49
+ };
38
50
  var getInfo = (subject) => {
39
51
  const text = (Obj.instanceOf(Markdown_exports.Document, subject) ? subject.content?.target?.content : subject.content) ?? "";
40
52
  return {
41
53
  words: text.split(" ").length
42
54
  };
43
55
  };
44
- var getSnippet = (subject, fallback) => {
45
- if (Obj.instanceOf(Markdown_exports.Document, subject)) {
46
- return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
47
- } else if (Obj.instanceOf(Text.Text, subject)) {
48
- return getContentSnippet(subject.content ?? fallback);
49
- }
50
- };
51
56
 
52
- // src/components/MarkdownCard/index.ts
57
+ // src/containers/MarkdownCard/index.ts
53
58
  var MarkdownCard_default = MarkdownCard;
54
-
55
59
  export {
56
- MarkdownCard,
57
- MarkdownCard_default
60
+ MarkdownCard_default as default
58
61
  };
59
- //# sourceMappingURL=chunk-DCKB3AVD.mjs.map
62
+ //# sourceMappingURL=MarkdownCard-4MXS7AQR.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/MarkdownCard/MarkdownCard.tsx", "../../../src/containers/MarkdownCard/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { useMemo } from 'react';\n\nimport { Obj } from '@dxos/echo';\nimport { useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui';\nimport { Text } from '@dxos/schema';\n\nimport { MarkdownEditor } from '../../components';\nimport { meta } from '../../meta';\nimport { Markdown } from '../../types';\nimport { getContentSnippet } from '../../util';\n\nexport type MarkdownCardProps = { subject: Markdown.Document | Text.Text };\n\nexport const MarkdownCard = ({ subject }: MarkdownCardProps) => {\n const { t } = useTranslation(meta.id);\n const snippet = useMemo(() => getSnippet(subject), [subject]);\n const info = getInfo(subject);\n\n return (\n <Card.Content>\n {snippet && (\n <Card.Section>\n <MarkdownEditor.Root id={subject.id} viewMode='readonly'>\n <MarkdownEditor.Content\n initialValue={snippet}\n classNames='bg-transparent'\n slots={{\n editor: { className: 'max-h-[240px]' },\n }}\n />\n </MarkdownEditor.Root>\n </Card.Section>\n )}\n <Card.Section>\n <Card.Text classNames='text-xs text-description'>\n {info.words} {t('words label', { count: info.words })}\n </Card.Text>\n </Card.Section>\n </Card.Content>\n );\n};\n\nconst MAX_LINES = 5;\n\nconst getSnippet = (subject: Markdown.Document | Text.Text, fallback?: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback, MAX_LINES);\n } else if (Obj.instanceOf(Text.Text, subject)) {\n return getContentSnippet(subject.content ?? fallback, MAX_LINES);\n }\n};\n\nconst getInfo = (subject: Markdown.Document | Text.Text) => {\n const text = (Obj.instanceOf(Markdown.Document, subject) ? subject.content?.target?.content : subject.content) ?? '';\n return { words: text.split(' ').length };\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownCard } from './MarkdownCard';\n\nexport default MarkdownCard;\n"],
5
+ "mappings": ";;;;;;;;;;;;;AAIA,OAAOA,SAASC,eAAe;AAE/B,SAASC,WAAW;AACpB,SAASC,sBAAsB;AAC/B,SAASC,YAAY;AACrB,SAASC,YAAY;AASd,IAAMC,eAAe,CAAC,EAAEC,QAAO,MAAqB;AACzD,QAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,QAAMC,UAAUC,QAAQ,MAAMC,WAAWP,OAAAA,GAAU;IAACA;GAAQ;AAC5D,QAAMQ,OAAOC,QAAQT,OAAAA;AAErB,SACE,sBAAA,cAACU,KAAKC,SAAO,MACVN,WACC,sBAAA,cAACK,KAAKE,SAAO,MACX,sBAAA,cAACC,eAAeC,MAAI;IAACV,IAAIJ,QAAQI;IAAIW,UAAS;KAC5C,sBAAA,cAACF,eAAeF,SAAO;IACrBK,cAAcX;IACdY,YAAW;IACXC,OAAO;MACLC,QAAQ;QAAEC,WAAW;MAAgB;IACvC;QAKR,sBAAA,cAACV,KAAKE,SAAO,MACX,sBAAA,cAACF,KAAKW,MAAI;IAACJ,YAAW;KACnBT,KAAKc,OAAM,KAAErB,EAAE,eAAe;IAAEsB,OAAOf,KAAKc;EAAM,CAAA,CAAA,CAAA,CAAA;AAK7D;AAEA,IAAME,YAAY;AAElB,IAAMjB,aAAa,CAACP,SAAwCyB,aAAAA;AAC1D,MAAIC,IAAIC,WAAWC,iBAASC,UAAU7B,OAAAA,GAAU;AAC9C,WAAO0B,IAAII,eAAe9B,OAAAA,KAAY+B,kBAAkB/B,QAAQgC,SAASC,QAAQD,WAAWP,UAAUD,SAAAA;EACxG,WAAWE,IAAIC,WAAWN,KAAKA,MAAMrB,OAAAA,GAAU;AAC7C,WAAO+B,kBAAkB/B,QAAQgC,WAAWP,UAAUD,SAAAA;EACxD;AACF;AAEA,IAAMf,UAAU,CAACT,YAAAA;AACf,QAAMkC,QAAQR,IAAIC,WAAWC,iBAASC,UAAU7B,OAAAA,IAAWA,QAAQgC,SAASC,QAAQD,UAAUhC,QAAQgC,YAAY;AAClH,SAAO;IAAEV,OAAOY,KAAKC,MAAM,GAAA,EAAKC;EAAO;AACzC;;;ACtDA,IAAA,uBAAeC;",
6
+ "names": ["React", "useMemo", "Obj", "useTranslation", "Card", "Text", "MarkdownCard", "subject", "t", "useTranslation", "meta", "id", "snippet", "useMemo", "getSnippet", "info", "getInfo", "Card", "Content", "Section", "MarkdownEditor", "Root", "viewMode", "initialValue", "classNames", "slots", "editor", "className", "Text", "words", "count", "MAX_LINES", "fallback", "Obj", "instanceOf", "Markdown", "Document", "getDescription", "getContentSnippet", "content", "target", "text", "split", "length", "MarkdownCard"]
7
+ }
@@ -2,13 +2,14 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  MarkdownEditor,
4
4
  useLinkQuery
5
- } from "./chunk-D46D75SK.mjs";
5
+ } from "./chunk-N73JZ4CD.mjs";
6
6
  import {
7
7
  MarkdownCapabilities,
8
8
  Markdown_exports
9
- } from "./chunk-USKAPINH.mjs";
9
+ } from "./chunk-WBZQ246U.mjs";
10
+ import "./chunk-W7AM4HCG.mjs";
10
11
 
11
- // src/components/MarkdownContainer.tsx
12
+ // src/containers/MarkdownContainer/MarkdownContainer.tsx
12
13
  import { Atom } from "@effect-atom/atom-react";
13
14
  import React, { forwardRef, useMemo } from "react";
14
15
  import { useCapabilities } from "@dxos/app-framework/ui";
@@ -17,7 +18,7 @@ import { useAppGraph } from "@dxos/app-toolkit/ui";
17
18
  import { Obj } from "@dxos/echo";
18
19
  import { useActionRunner } from "@dxos/plugin-graph";
19
20
  import { useObject } from "@dxos/react-client/echo";
20
- import { Layout } from "@dxos/react-ui";
21
+ import { Panel } from "@dxos/react-ui";
21
22
  import { Text } from "@dxos/schema";
22
23
  var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id, settings, extensionProviders, ...props }, forwardedRef) => {
23
24
  const db = Obj.isObject(object) ? Obj.getDatabase(object) : void 0;
@@ -55,7 +56,8 @@ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id,
55
56
  const nodes = actions.filter((action) => action.properties.disposition === "toolbar");
56
57
  const edges = nodes.map((node) => ({
57
58
  source: "root",
58
- target: node.id
59
+ target: node.id,
60
+ relation: "child"
59
61
  }));
60
62
  return {
61
63
  nodes,
@@ -76,10 +78,7 @@ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id,
76
78
  upload
77
79
  ]);
78
80
  const handleLinkQuery = useLinkQuery(db);
79
- return /* @__PURE__ */ React.createElement(Layout.Main, {
80
- toolbar: settings.toolbar,
81
- ref: forwardedRef
82
- }, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
81
+ return /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
83
82
  id: attendableId ?? id,
84
83
  object,
85
84
  extensions,
@@ -88,19 +87,23 @@ var MarkdownContainer = /* @__PURE__ */ forwardRef(({ role, subject: object, id,
88
87
  onFileUpload: handleFileUpload,
89
88
  onLinkQuery: handleLinkQuery,
90
89
  ...props
91
- }, settings.toolbar && /* @__PURE__ */ React.createElement(MarkdownEditor.Toolbar, {
90
+ }, /* @__PURE__ */ React.createElement(Panel.Root, {
91
+ ref: forwardedRef
92
+ }, settings.toolbar && /* @__PURE__ */ React.createElement(Panel.Toolbar, {
93
+ asChild: true
94
+ }, /* @__PURE__ */ React.createElement(MarkdownEditor.Toolbar, {
92
95
  id: attendableId ?? id,
93
96
  role,
94
97
  customActions
95
- }), /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
98
+ })), /* @__PURE__ */ React.createElement(Panel.Content, null, /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
96
99
  initialValue,
97
100
  scrollPastEnd: role === "article"
98
- }), /* @__PURE__ */ React.createElement(MarkdownEditor.Blocks, null)));
101
+ }), /* @__PURE__ */ React.createElement(MarkdownEditor.Blocks, null))));
99
102
  });
100
- var MarkdownContainer_default = MarkdownContainer;
101
103
 
104
+ // src/containers/MarkdownContainer/index.ts
105
+ var MarkdownContainer_default = MarkdownContainer;
102
106
  export {
103
- MarkdownContainer,
104
- MarkdownContainer_default
107
+ MarkdownContainer_default as default
105
108
  };
106
- //# sourceMappingURL=chunk-K2IIYNCG.mjs.map
109
+ //# sourceMappingURL=MarkdownContainer-BZ637MS3.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/MarkdownContainer/MarkdownContainer.tsx", "../../../src/containers/MarkdownContainer/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Extension } from '@codemirror/state';\nimport { Atom } from '@effect-atom/atom-react';\nimport React, { forwardRef, useMemo } from 'react';\n\nimport { useCapabilities } from '@dxos/app-framework/ui';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { type SurfaceComponentProps } from '@dxos/app-toolkit/ui';\nimport { useAppGraph } from '@dxos/app-toolkit/ui';\nimport { Obj } from '@dxos/echo';\nimport { useActionRunner } from '@dxos/plugin-graph';\nimport { useObject } from '@dxos/react-client/echo';\nimport { Panel } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport { Text } from '@dxos/schema';\n\nimport { MarkdownEditor, type MarkdownEditorContentProps, type MarkdownEditorRootProps } from '../../components';\nimport { useLinkQuery } from '../../hooks';\nimport { Markdown, MarkdownCapabilities, type MarkdownPluginState } from '../../types';\n\nexport type MarkdownContainerProps = SurfaceComponentProps<\n Markdown.Document | Text.Text,\n {\n id: string;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n } & Pick<MarkdownEditorRootProps, 'viewMode' | 'onViewModeChange'> &\n Pick<MarkdownEditorContentProps, 'editorStateStore'> &\n Pick<MarkdownPluginState, 'extensionProviders'>\n>;\n\nexport const MarkdownContainer = forwardRef<HTMLDivElement, MarkdownContainerProps>(\n ({ role, subject: object, id, settings, extensionProviders, ...props }, forwardedRef) => {\n const db = Obj.isObject(object) ? Obj.getDatabase(object) : undefined;\n const attendableId = Obj.instanceOf(Markdown.Document, object) ? Obj.getDXN(object).toString() : undefined;\n const [docContent] = useObject(Obj.instanceOf(Markdown.Document, object) ? object.content : undefined, 'content');\n const [textContent] = useObject(Obj.instanceOf(Text.Text, object) ? object : undefined, 'content');\n const initialValue = docContent ?? textContent;\n\n // Extensions from other plugins.\n // TODO(burdon): Document MarkdownPluginState.extensionProviders\n const otherExtensionProviders = useCapabilities(MarkdownCapabilities.Extensions);\n const extensions = useMemo<Extension[]>(() => {\n if (!Obj.instanceOf(Markdown.Document, object) && !Obj.instanceOf(Text.Text, object)) {\n return [];\n }\n\n return [...(otherExtensionProviders ?? []), ...(extensionProviders ?? [])]\n .flat()\n .reduce((acc: Extension[], provider) => {\n const extension =\n typeof provider === 'function' ? provider({ document: object as Markdown.Document }) : provider;\n if (extension) {\n acc.push(extension);\n }\n\n return acc;\n }, []);\n }, [extensionProviders, otherExtensionProviders, object]);\n\n // Toolbar actions from app graph.\n const { graph } = useAppGraph();\n const runAction = useActionRunner();\n const customActions = useMemo(() => {\n return Atom.make((get) => {\n const actions = get(graph.actions(id));\n const nodes = actions.filter((action) => action.properties.disposition === 'toolbar');\n const edges = nodes.map((node) => ({ source: 'root', target: node.id, relation: 'child' }));\n return { nodes, edges };\n });\n }, [graph]);\n\n // File upload.\n const [upload] = useCapabilities(AppCapabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (!db || !upload) {\n return undefined;\n }\n\n return async (file: File) => upload(db, file);\n }, [db, upload]);\n\n // Query for @ refs.\n const handleLinkQuery = useLinkQuery(db);\n\n return (\n <MarkdownEditor.Root\n id={attendableId ?? id}\n object={object}\n extensions={extensions}\n settings={settings}\n onAction={runAction}\n onFileUpload={handleFileUpload}\n onLinkQuery={handleLinkQuery}\n {...props}\n >\n <Panel.Root ref={forwardedRef}>\n {settings.toolbar && (\n <Panel.Toolbar asChild>\n <MarkdownEditor.Toolbar id={attendableId ?? id} role={role} customActions={customActions} />\n </Panel.Toolbar>\n )}\n <Panel.Content>\n <MarkdownEditor.Content initialValue={initialValue} scrollPastEnd={role === 'article'} />\n <MarkdownEditor.Blocks />\n </Panel.Content>\n </Panel.Root>\n </MarkdownEditor.Root>\n );\n },\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownContainer } from './MarkdownContainer';\n\nexport default MarkdownContainer;\n"],
5
+ "mappings": "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",
6
+ "names": ["Atom", "React", "forwardRef", "useMemo", "useCapabilities", "AppCapabilities", "useAppGraph", "Obj", "useActionRunner", "useObject", "Panel", "Text", "MarkdownContainer", "forwardRef", "role", "subject", "object", "id", "settings", "extensionProviders", "props", "forwardedRef", "db", "Obj", "isObject", "getDatabase", "undefined", "attendableId", "instanceOf", "Markdown", "Document", "getDXN", "toString", "docContent", "useObject", "content", "textContent", "Text", "initialValue", "otherExtensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "extensions", "useMemo", "flat", "reduce", "acc", "provider", "extension", "document", "push", "graph", "useAppGraph", "runAction", "useActionRunner", "customActions", "Atom", "make", "get", "actions", "nodes", "filter", "action", "properties", "disposition", "edges", "map", "node", "source", "target", "relation", "upload", "AppCapabilities", "FileUploader", "handleFileUpload", "file", "handleLinkQuery", "useLinkQuery", "MarkdownEditor", "Root", "onAction", "onFileUpload", "onLinkQuery", "Panel", "ref", "toolbar", "Toolbar", "asChild", "Content", "scrollPastEnd", "Blocks", "MarkdownContainer"]
7
+ }
@@ -1,27 +1,9 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import "./chunk-DCKB3AVD.mjs";
3
- import "./chunk-K2IIYNCG.mjs";
4
- import "./chunk-D46D75SK.mjs";
5
2
  import {
6
- MarkdownCapabilities,
7
- Markdown_exports,
8
3
  meta
9
- } from "./chunk-USKAPINH.mjs";
4
+ } from "./chunk-W7AM4HCG.mjs";
10
5
 
11
- // src/capabilities/react-surface/react-surface.tsx
12
- import * as Effect from "effect/Effect";
13
- import React2, { forwardRef, useCallback, useMemo } from "react";
14
- import { Capabilities, Capability } from "@dxos/app-framework";
15
- import { Surface, useAtomCapability, useAtomCapabilityState, useCapability, useSettingsState } from "@dxos/app-framework/ui";
16
- import { AppCapabilities } from "@dxos/app-toolkit";
17
- import { Obj } from "@dxos/echo";
18
- import { AttentionCapabilities } from "@dxos/plugin-attention";
19
- import { Text } from "@dxos/schema";
20
-
21
- // src/components/index.ts
22
- import { lazy } from "react";
23
-
24
- // src/components/MarkdownSettings/MarkdownSettings.tsx
6
+ // src/containers/MarkdownSettings/MarkdownSettings.tsx
25
7
  import React from "react";
26
8
  import { Input, Select, useTranslation } from "@dxos/react-ui";
27
9
  import { Settings } from "@dxos/react-ui-form";
@@ -117,98 +99,9 @@ var MarkdownSettings = ({ settings, onSettingsChange }) => {
117
99
  })))));
118
100
  };
119
101
 
120
- // src/components/index.ts
121
- var MarkdownCard = lazy(() => import("./MarkdownCard-YC3R2TQW.mjs"));
122
- var MarkdownContainer = lazy(() => import("./MarkdownContainer-TTRUOXU6.mjs"));
123
-
124
- // src/capabilities/react-surface/react-surface.tsx
125
- var react_surface_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(Capabilities.ReactSurface, [
126
- Surface.create({
127
- id: `${meta.id}/surface/document`,
128
- role: [
129
- "article",
130
- "section",
131
- "tabpanel"
132
- ],
133
- filter: (data) => Obj.instanceOf(Markdown_exports.Document, data.subject) && !data.variant,
134
- component: ({ data, role, ref }) => {
135
- return /* @__PURE__ */ React2.createElement(Container, {
136
- id: Obj.getDXN(data.subject).toString(),
137
- subject: data.subject,
138
- role,
139
- ref
140
- });
141
- }
142
- }),
143
- Surface.create({
144
- id: `${meta.id}/surface/text`,
145
- role: [
146
- "article",
147
- "section",
148
- "tabpanel"
149
- ],
150
- filter: (data) => typeof data.id === "string" && Obj.instanceOf(Text.Text, data.subject),
151
- component: ({ data, role }) => {
152
- return /* @__PURE__ */ React2.createElement(Container, {
153
- id: data.id,
154
- subject: data.subject,
155
- role
156
- });
157
- }
158
- }),
159
- Surface.create({
160
- id: `${meta.id}/surface/plugin-settings`,
161
- role: "article",
162
- filter: (data) => AppCapabilities.isSettings(data.subject) && data.subject.prefix === meta.id,
163
- component: ({ data: { subject } }) => {
164
- const { settings, updateSettings } = useSettingsState(subject.atom);
165
- return /* @__PURE__ */ React2.createElement(MarkdownSettings, {
166
- settings,
167
- onSettingsChange: updateSettings
168
- });
169
- }
170
- }),
171
- Surface.create({
172
- id: `${meta.id}/surface/preview`,
173
- role: "card--content",
174
- filter: (data) => Obj.instanceOf(Markdown_exports.Document, data.subject) || Obj.instanceOf(Text.Text, data.subject),
175
- component: ({ data }) => /* @__PURE__ */ React2.createElement(MarkdownCard, data)
176
- })
177
- ])));
178
- var Container = /* @__PURE__ */ forwardRef(({ id, subject, role }, forwardedRef) => {
179
- const selectionManager = useCapability(AttentionCapabilities.Selection);
180
- const settings = useAtomCapability(MarkdownCapabilities.Settings);
181
- const [state, setState] = useAtomCapabilityState(MarkdownCapabilities.State);
182
- const editorState = useCapability(MarkdownCapabilities.EditorState);
183
- const extensions = useCapability(MarkdownCapabilities.Extensions);
184
- const extensionProviders = useMemo(() => extensions.flat(), [
185
- extensions
186
- ]);
187
- const viewMode = id && state.viewMode[id] || settings?.defaultViewMode || "source";
188
- const handleViewModeChange = useCallback((mode) => setState((current) => ({
189
- ...current,
190
- viewMode: {
191
- ...current.viewMode,
192
- [id]: mode
193
- }
194
- })), [
195
- id,
196
- setState
197
- ]);
198
- return /* @__PURE__ */ React2.createElement(MarkdownContainer, {
199
- role,
200
- subject,
201
- id,
202
- settings,
203
- selectionManager,
204
- extensionProviders,
205
- editorStateStore: editorState,
206
- viewMode,
207
- onViewModeChange: handleViewModeChange,
208
- ref: forwardedRef
209
- });
210
- });
102
+ // src/containers/MarkdownSettings/index.ts
103
+ var MarkdownSettings_default = MarkdownSettings;
211
104
  export {
212
- react_surface_default as default
105
+ MarkdownSettings_default as default
213
106
  };
214
- //# sourceMappingURL=react-surface-VIXAH5CF.mjs.map
107
+ //# sourceMappingURL=MarkdownSettings-FQTYCTD7.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/containers/MarkdownSettings/MarkdownSettings.tsx", "../../../src/containers/MarkdownSettings/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { Settings } from '@dxos/react-ui-form';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/ui-editor';\n\nimport { meta } from '../../meta';\nimport { type Markdown } from '../../types';\n\nexport type MarkdownSettingsComponentProps = {\n settings: Markdown.Settings;\n onSettingsChange: (fn: (current: Markdown.Settings) => Markdown.Settings) => void;\n};\n\nexport const MarkdownSettings = ({ settings, onSettingsChange }: MarkdownSettingsComponentProps) => {\n const { t } = useTranslation(meta.id);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <Settings.Root>\n <Settings.Section title={t('settings title', { ns: meta.id })}>\n <Settings.Group>\n <Settings.ItemInput title={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n onSettingsChange((s) => ({ ...s, defaultViewMode: value as EditorViewMode }));\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: '@dxos/react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n onSettingsChange((s) => ({ ...s, editorInputMode: value as EditorInputMode }));\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n <Select.Arrow />\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings toolbar label')}>\n <Input.Switch\n checked={settings.toolbar}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, toolbar: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, numberedHeadings: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings folding label')}>\n <Input.Switch\n checked={settings.folding}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, folding: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, experimental: !!checked }))}\n />\n </Settings.ItemInput>\n\n <Settings.ItemInput title={t('settings debug label')}>\n <Input.Switch\n checked={settings.debug}\n onCheckedChange={(checked) => onSettingsChange((s) => ({ ...s, debug: !!checked }))}\n />\n </Settings.ItemInput>\n\n {settings.debug && (\n <Settings.ItemInput title={t('settings debug textarea label', { ns: meta.id })}>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => onSettingsChange((s) => ({ ...s, typewriter: value }))}\n placeholder={t('settings debug placeholder')}\n />\n </Settings.ItemInput>\n )}\n </Settings.Group>\n </Settings.Section>\n </Settings.Root>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownSettings } from './MarkdownSettings';\n\nexport default MarkdownSettings;\n"],
5
+ "mappings": "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",
6
+ "names": ["React", "Input", "Select", "useTranslation", "Settings", "EditorInputModes", "EditorViewModes", "MarkdownSettings", "settings", "onSettingsChange", "t", "useTranslation", "meta", "id", "Settings", "Root", "Section", "title", "ns", "Group", "ItemInput", "Select", "value", "defaultViewMode", "onValueChange", "s", "TriggerButton", "Portal", "Content", "Viewport", "EditorViewModes", "map", "mode", "Option", "key", "Arrow", "editorInputMode", "placeholder", "EditorInputModes", "Input", "Switch", "checked", "toolbar", "onCheckedChange", "numberedHeadings", "folding", "experimental", "debug", "TextArea", "rows", "typewriter", "onChange", "target", "MarkdownSettings"]
7
+ }
@@ -1,7 +1,8 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  Markdown_exports
4
- } from "./chunk-USKAPINH.mjs";
4
+ } from "./chunk-WBZQ246U.mjs";
5
+ import "./chunk-W7AM4HCG.mjs";
5
6
 
6
7
  // src/capabilities/anchor-sort/anchor-sort.ts
7
8
  import * as Effect from "effect/Effect";
@@ -31,4 +32,4 @@ var anchor_sort_default = Capability.makeModule(() => Effect.succeed(Capability.
31
32
  export {
32
33
  anchor_sort_default as default
33
34
  };
34
- //# sourceMappingURL=anchor-sort-IQMDZRA3.mjs.map
35
+ //# sourceMappingURL=anchor-sort-QWZO6B2R.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/capabilities/anchor-sort/anchor-sort.ts"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { Relation } from '@dxos/echo';\nimport { createDocAccessor, getRangeFromCursor } from '@dxos/echo-db';\nimport { type AnchoredTo } from '@dxos/types';\n\nimport { Markdown } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.succeed(\n Capability.contributes(AppCapabilities.AnchorSort, {\n key: Markdown.Document.typename,\n sort: (anchorA: AnchoredTo.AnchoredTo, anchorB: AnchoredTo.AnchoredTo) => {\n const doc = Relation.getTarget(anchorA) as Markdown.Document;\n const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;\n if (doc !== Relation.getTarget(anchorB) || !accessor) {\n return 0;\n }\n\n const getStartPosition = (cursor: string | undefined) => {\n const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;\n return range?.start ?? Number.MAX_SAFE_INTEGER;\n };\n\n const posA = getStartPosition(anchorA.anchor);\n const posB = getStartPosition(anchorB.anchor);\n return posA - posB;\n },\n }),\n ),\n);\n"],
5
- "mappings": ";;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,gBAAgB;AACzB,SAASC,mBAAmBC,0BAA0B;AAKtD,IAAA,sBAAeC,WAAWC,WAAW,MAC5BC,eACLF,WAAWG,YAAYC,gBAAgBC,YAAY;EACjDC,KAAKC,iBAASC,SAASC;EACvBC,MAAM,CAACC,SAAgCC,YAAAA;AACrC,UAAMC,MAAMC,SAASC,UAAUJ,OAAAA;AAC/B,UAAMK,WAAWH,IAAII,QAAQC,SAASC,kBAAkBN,IAAII,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIP,QAAQC,SAASC,UAAUH,OAAAA,KAAY,CAACI,UAAU;AACpD,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBV,QAAQkB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBT,QAAQiB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA,CAAA,CAAA;",
5
+ "mappings": ";;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,gBAAgB;AACzB,SAASC,mBAAmBC,0BAA0B;AAKtD,IAAA,sBAAeC,WAAWC,WAAW,MAC5BC,eACLF,WAAWG,YAAYC,gBAAgBC,YAAY;EACjDC,KAAKC,iBAASC,SAASC;EACvBC,MAAM,CAACC,SAAgCC,YAAAA;AACrC,UAAMC,MAAMC,SAASC,UAAUJ,OAAAA;AAC/B,UAAMK,WAAWH,IAAII,QAAQC,SAASC,kBAAkBN,IAAII,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIP,QAAQC,SAASC,UAAUH,OAAAA,KAAY,CAACI,UAAU;AACpD,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBV,QAAQkB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBT,QAAQiB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA,CAAA,CAAA;",
6
6
  "names": ["Effect", "Capability", "AppCapabilities", "Relation", "createDocAccessor", "getRangeFromCursor", "Capability", "makeModule", "succeed", "contributes", "AppCapabilities", "AnchorSort", "key", "Markdown", "Document", "typename", "sort", "anchorA", "anchorB", "doc", "Relation", "getTarget", "accessor", "content", "target", "createDocAccessor", "undefined", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "posA", "anchor", "posB"]
7
7
  }