@dxos/plugin-markdown 0.8.4-main.2e9d522 → 0.8.4-main.3c1ae3b
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.
- package/dist/lib/browser/MarkdownCard-THZFDOOV.mjs +13 -0
- package/dist/lib/browser/MarkdownCard-THZFDOOV.mjs.map +7 -0
- package/dist/lib/browser/MarkdownContainer-VKPSVI5F.mjs +16 -0
- package/dist/lib/browser/MarkdownContainer-VKPSVI5F.mjs.map +7 -0
- package/dist/lib/browser/{anchor-sort-UKJJ7ZNP.mjs → anchor-sort-3MYLO74J.mjs} +11 -11
- package/dist/lib/browser/anchor-sort-3MYLO74J.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-ICLAF662.mjs → app-graph-serializer-BZJ4TQOE.mjs} +15 -16
- package/dist/lib/browser/app-graph-serializer-BZJ4TQOE.mjs.map +7 -0
- package/dist/lib/browser/blueprint-definition-R5T6LTPN.mjs +13 -0
- package/dist/lib/browser/blueprint-definition-R5T6LTPN.mjs.map +7 -0
- package/dist/lib/browser/chunk-56SUMOIZ.mjs +734 -0
- package/dist/lib/browser/chunk-56SUMOIZ.mjs.map +7 -0
- package/dist/lib/browser/chunk-6OMOMVO7.mjs +107 -0
- package/dist/lib/browser/chunk-6OMOMVO7.mjs.map +7 -0
- package/dist/lib/browser/chunk-BQTYJOFB.mjs +28 -0
- package/dist/lib/browser/chunk-BQTYJOFB.mjs.map +7 -0
- package/dist/lib/browser/chunk-CN35HEBX.mjs +79 -0
- package/dist/lib/browser/chunk-CN35HEBX.mjs.map +7 -0
- package/dist/lib/browser/chunk-IBCHVMZW.mjs +16 -0
- package/dist/lib/browser/chunk-IBCHVMZW.mjs.map +7 -0
- package/dist/lib/browser/chunk-KCOBZZIL.mjs +111 -0
- package/dist/lib/browser/chunk-KCOBZZIL.mjs.map +7 -0
- package/dist/lib/browser/chunk-KPH4ZPQN.mjs +99 -0
- package/dist/lib/browser/chunk-KPH4ZPQN.mjs.map +7 -0
- package/dist/lib/browser/{chunk-LHDCHDBW.mjs → chunk-NXT2E2BG.mjs} +12 -7
- package/dist/lib/browser/chunk-NXT2E2BG.mjs.map +7 -0
- package/dist/lib/browser/chunk-RJPOHSYN.mjs +152 -0
- package/dist/lib/browser/chunk-RJPOHSYN.mjs.map +7 -0
- package/dist/lib/browser/chunk-U6Y53XZK.mjs +20 -0
- package/dist/lib/browser/chunk-U6Y53XZK.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +37 -37
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/intent-resolver-55ASQRIW.mjs +62 -0
- package/dist/lib/browser/intent-resolver-55ASQRIW.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-Q3C5H2KT.mjs +215 -0
- package/dist/lib/browser/react-surface-Q3C5H2KT.mjs.map +7 -0
- package/dist/lib/browser/{settings-KN75ZQY6.mjs → settings-G3ZOXJQY.mjs} +7 -7
- package/dist/lib/browser/settings-G3ZOXJQY.mjs.map +7 -0
- package/dist/lib/browser/{state-LZWTAS65.mjs → state-BTUKVZHY.mjs} +9 -9
- package/dist/lib/browser/state-BTUKVZHY.mjs.map +7 -0
- package/dist/lib/browser/toolkit.mjs +13 -0
- package/dist/lib/browser/toolkit.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +6 -14
- package/dist/lib/node-esm/MarkdownCard-QHSSZGIY.mjs +14 -0
- package/dist/lib/node-esm/MarkdownCard-QHSSZGIY.mjs.map +7 -0
- package/dist/lib/node-esm/MarkdownContainer-G3ZQJS7A.mjs +17 -0
- package/dist/lib/node-esm/MarkdownContainer-G3ZQJS7A.mjs.map +7 -0
- package/dist/lib/node-esm/{anchor-sort-IPIS5D5B.mjs → anchor-sort-W4HCTYUQ.mjs} +11 -11
- package/dist/lib/node-esm/anchor-sort-W4HCTYUQ.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-FLBXQKKR.mjs → app-graph-serializer-OCTHXWLF.mjs} +15 -16
- package/dist/lib/node-esm/app-graph-serializer-OCTHXWLF.mjs.map +7 -0
- package/dist/lib/node-esm/blueprint-definition-2JV3WV22.mjs +14 -0
- package/dist/lib/node-esm/blueprint-definition-2JV3WV22.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-6F6FCTIA.mjs +100 -0
- package/dist/lib/node-esm/chunk-6F6FCTIA.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-C5KXP2ZE.mjs +153 -0
- package/dist/lib/node-esm/chunk-C5KXP2ZE.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-FR6RW6DH.mjs +735 -0
- package/dist/lib/node-esm/chunk-FR6RW6DH.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ACFGXH2K.mjs → chunk-GMMVSXQ6.mjs} +5 -5
- package/dist/lib/node-esm/chunk-GMMVSXQ6.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-VIR2ABYE.mjs → chunk-I5JSQBPI.mjs} +12 -7
- package/dist/lib/node-esm/chunk-I5JSQBPI.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-KM7KYV6W.mjs +22 -0
- package/dist/lib/node-esm/chunk-KM7KYV6W.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-KYWXTMKI.mjs +108 -0
- package/dist/lib/node-esm/chunk-KYWXTMKI.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-R3SGV4ES.mjs +112 -0
- package/dist/lib/node-esm/chunk-R3SGV4ES.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs +29 -0
- package/dist/lib/node-esm/chunk-SHAMSMKQ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-YFRTKXTB.mjs +80 -0
- package/dist/lib/node-esm/chunk-YFRTKXTB.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +37 -37
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs +63 -0
- package/dist/lib/node-esm/intent-resolver-DTBVWCNO.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-QWRT4SD6.mjs +216 -0
- package/dist/lib/node-esm/react-surface-QWRT4SD6.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-KVP7TVX7.mjs → settings-IBFFCGNL.mjs} +7 -7
- package/dist/lib/node-esm/settings-IBFFCGNL.mjs.map +7 -0
- package/dist/lib/node-esm/{state-NW3W4JCQ.mjs → state-K6EH7SRZ.mjs} +9 -9
- package/dist/lib/node-esm/state-K6EH7SRZ.mjs.map +7 -0
- package/dist/lib/node-esm/toolkit.mjs +14 -0
- package/dist/lib/node-esm/toolkit.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +6 -14
- package/dist/types/src/MarkdownPlugin.d.ts +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/anchor-sort.d.ts +2 -4
- package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-serializer.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
- package/dist/types/src/capabilities/artifact-definition.d.ts +1 -9
- package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/blueprint-definition.d.ts +7 -0
- package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
- package/dist/types/src/capabilities/capabilities.d.ts +1 -1
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +10 -12
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings.d.ts +1 -1
- package/dist/types/src/capabilities/state.d.ts +2 -2
- package/dist/types/src/capabilities/state.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts +20 -0
- package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +9 -0
- package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownCard/index.d.ts +4 -0
- package/dist/types/src/components/MarkdownCard/index.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownContainer.d.ts +14 -13
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.stories.d.ts +55 -5
- package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts +11 -0
- package/dist/types/src/components/MarkdownEditor/FileUpload.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +42 -23
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +8 -15
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts +29 -0
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorContent.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts +12 -0
- package/dist/types/src/components/MarkdownEditor/MarkdownEditorToolbar.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts +2 -2
- package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
- package/dist/types/src/components/Suggestions.stories.d.ts +3 -4
- package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +7 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/events.d.ts.map +1 -1
- package/dist/types/src/functions/create.d.ts +8 -0
- package/dist/types/src/functions/create.d.ts.map +1 -0
- package/dist/types/src/functions/create.test.d.ts +2 -0
- package/dist/types/src/functions/create.test.d.ts.map +1 -0
- package/dist/types/src/functions/index.d.ts +18 -0
- package/dist/types/src/functions/index.d.ts.map +1 -0
- package/dist/types/src/functions/open.d.ts +7 -0
- package/dist/types/src/functions/open.d.ts.map +1 -0
- package/dist/types/src/functions/update.d.ts +6 -0
- package/dist/types/src/functions/update.d.ts.map +1 -0
- package/dist/types/src/functions/update.test.d.ts +2 -0
- package/dist/types/src/functions/update.test.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +3 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useEditorMenuOptions.d.ts +9 -0
- package/dist/types/src/hooks/useEditorMenuOptions.d.ts.map +1 -0
- package/dist/types/src/hooks/useExtensions.d.ts +21 -0
- package/dist/types/src/hooks/useExtensions.d.ts.map +1 -0
- package/dist/types/src/hooks/useLinkQuery.d.ts +4 -0
- package/dist/types/src/hooks/useLinkQuery.d.ts.map +1 -0
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +0 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/testing.d.ts +6 -0
- package/dist/types/src/testing.d.ts.map +1 -0
- package/dist/types/src/toolkit.d.ts +3 -0
- package/dist/types/src/toolkit.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +7 -2
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Markdown.d.ts +45 -0
- package/dist/types/src/types/Markdown.d.ts.map +1 -0
- package/dist/types/src/types/MarkdownAction.d.ts +34 -0
- package/dist/types/src/types/MarkdownAction.d.ts.map +1 -0
- package/dist/types/src/types/index.d.ts +2 -1
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +3 -59
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +17 -5
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/src/util.test.d.ts +2 -0
- package/dist/types/src/util.test.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +74 -53
- package/src/MarkdownPlugin.tsx +91 -100
- package/src/capabilities/anchor-sort.ts +8 -7
- package/src/capabilities/app-graph-serializer.ts +12 -10
- package/src/capabilities/artifact-definition.ts +23 -27
- package/src/capabilities/blueprint-definition.ts +43 -0
- package/src/capabilities/capabilities.ts +6 -4
- package/src/capabilities/index.ts +3 -2
- package/src/capabilities/intent-resolver.ts +16 -21
- package/src/capabilities/react-surface.tsx +62 -78
- package/src/capabilities/settings.ts +3 -3
- package/src/capabilities/state.ts +8 -8
- package/src/components/MarkdownCard/MarkdownCard.stories.tsx +76 -0
- package/src/components/MarkdownCard/MarkdownCard.tsx +96 -0
- package/src/components/MarkdownCard/index.ts +9 -0
- package/src/components/MarkdownContainer.stories.tsx +81 -48
- package/src/components/MarkdownContainer.tsx +98 -244
- package/src/components/MarkdownEditor/FileUpload.tsx +63 -0
- package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +57 -34
- package/src/components/MarkdownEditor/MarkdownEditor.tsx +221 -272
- package/src/components/MarkdownEditor/MarkdownEditorContent.tsx +152 -0
- package/src/components/MarkdownEditor/MarkdownEditorToolbar.tsx +63 -0
- package/src/components/MarkdownSettings/MarkdownSettings.tsx +81 -78
- package/src/components/Suggestions.stories.tsx +62 -57
- package/src/components/index.ts +10 -3
- package/src/events.ts +2 -2
- package/src/functions/create.conversations.json +1 -0
- package/src/functions/create.test.ts +124 -0
- package/src/functions/create.ts +34 -0
- package/src/functions/index.ts +13 -0
- package/src/functions/open.ts +33 -0
- package/src/functions/update.conversations.json +1 -0
- package/src/functions/update.test.ts +147 -0
- package/src/functions/update.ts +38 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/useEditorMenuOptions.ts +71 -0
- package/src/{extensions.tsx → hooks/useExtensions.tsx} +66 -115
- package/src/hooks/useLinkQuery.ts +83 -0
- package/src/hooks/useSelectCurrentThread.tsx +17 -7
- package/src/index.ts +4 -1
- package/src/meta.ts +7 -8
- package/src/testing.ts +27 -0
- package/src/toolkit.ts +6 -0
- package/src/translations.ts +7 -2
- package/src/types/Markdown.ts +57 -0
- package/src/types/MarkdownAction.ts +29 -0
- package/src/types/index.ts +3 -1
- package/src/types/types.ts +6 -50
- package/src/util.test.ts +44 -0
- package/src/util.tsx +97 -10
- package/dist/lib/browser/MarkdownContainer-F3WEEIBX.mjs +0 -778
- package/dist/lib/browser/MarkdownContainer-F3WEEIBX.mjs.map +0 -7
- package/dist/lib/browser/MarkdownPreview-S3C7CGAV.mjs +0 -80
- package/dist/lib/browser/MarkdownPreview-S3C7CGAV.mjs.map +0 -7
- package/dist/lib/browser/anchor-sort-UKJJ7ZNP.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-ICLAF662.mjs.map +0 -7
- package/dist/lib/browser/artifact-definition-R2YYWOPN.mjs +0 -145
- package/dist/lib/browser/artifact-definition-R2YYWOPN.mjs.map +0 -7
- package/dist/lib/browser/chunk-777RIED6.mjs +0 -16
- package/dist/lib/browser/chunk-777RIED6.mjs.map +0 -7
- package/dist/lib/browser/chunk-EPTSAJZM.mjs +0 -22
- package/dist/lib/browser/chunk-EPTSAJZM.mjs.map +0 -7
- package/dist/lib/browser/chunk-LFML7LC6.mjs +0 -51
- package/dist/lib/browser/chunk-LFML7LC6.mjs.map +0 -7
- package/dist/lib/browser/chunk-LHDCHDBW.mjs.map +0 -7
- package/dist/lib/browser/chunk-PHTD5DTR.mjs +0 -20
- package/dist/lib/browser/chunk-PHTD5DTR.mjs.map +0 -7
- package/dist/lib/browser/chunk-UANWRJZU.mjs +0 -79
- package/dist/lib/browser/chunk-UANWRJZU.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-3MXYO3MW.mjs +0 -64
- package/dist/lib/browser/intent-resolver-3MXYO3MW.mjs.map +0 -7
- package/dist/lib/browser/react-surface-C3Z423TV.mjs +0 -206
- package/dist/lib/browser/react-surface-C3Z423TV.mjs.map +0 -7
- package/dist/lib/browser/settings-KN75ZQY6.mjs.map +0 -7
- package/dist/lib/browser/state-LZWTAS65.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-VOUHL6IU.mjs +0 -779
- package/dist/lib/node-esm/MarkdownContainer-VOUHL6IU.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownPreview-77UFEWXT.mjs +0 -81
- package/dist/lib/node-esm/MarkdownPreview-77UFEWXT.mjs.map +0 -7
- package/dist/lib/node-esm/anchor-sort-IPIS5D5B.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-FLBXQKKR.mjs.map +0 -7
- package/dist/lib/node-esm/artifact-definition-MLTAY4LK.mjs +0 -146
- package/dist/lib/node-esm/artifact-definition-MLTAY4LK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-7X6TPTJK.mjs +0 -22
- package/dist/lib/node-esm/chunk-7X6TPTJK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ACFGXH2K.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-CWTFQSN7.mjs +0 -52
- package/dist/lib/node-esm/chunk-CWTFQSN7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-CXG7GMYP.mjs +0 -24
- package/dist/lib/node-esm/chunk-CXG7GMYP.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-JEEQLO7C.mjs +0 -80
- package/dist/lib/node-esm/chunk-JEEQLO7C.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-VIR2ABYE.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-BZYWV53A.mjs +0 -65
- package/dist/lib/node-esm/intent-resolver-BZYWV53A.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-TTTBYNI2.mjs +0 -207
- package/dist/lib/node-esm/react-surface-TTTBYNI2.mjs.map +0 -7
- package/dist/lib/node-esm/settings-KVP7TVX7.mjs.map +0 -7
- package/dist/lib/node-esm/state-NW3W4JCQ.mjs.map +0 -7
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +0 -6
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +0 -42
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownPreview/index.d.ts +0 -4
- package/dist/types/src/components/MarkdownPreview/index.d.ts.map +0 -1
- package/dist/types/src/components/Toolbar.stories.d.ts +0 -11
- package/dist/types/src/components/Toolbar.stories.d.ts.map +0 -1
- package/dist/types/src/extensions.d.ts +0 -24
- package/dist/types/src/extensions.d.ts.map +0 -1
- package/dist/types/src/types/schema.d.ts +0 -35
- package/dist/types/src/types/schema.d.ts.map +0 -1
- package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +0 -81
- package/src/components/MarkdownPreview/MarkdownPreview.tsx +0 -73
- package/src/components/MarkdownPreview/index.ts +0 -9
- package/src/components/Toolbar.stories.tsx +0 -113
- package/src/types/schema.ts +0 -39
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/hooks/useLinkQuery.ts", "../../../src/hooks/useEditorMenuOptions.ts", "../../../src/hooks/useExtensions.tsx", "../../../src/hooks/useSelectCurrentThread.tsx", "../../../src/components/MarkdownEditor/MarkdownEditor.tsx", "../../../src/components/MarkdownEditor/MarkdownEditorContent.tsx", "../../../src/components/MarkdownEditor/MarkdownEditorToolbar.tsx", "../../../src/components/MarkdownEditor/FileUpload.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport * as Option from 'effect/Option';\nimport { useCallback, useMemo } from 'react';\n\nimport { Capabilities } from '@dxos/app-framework';\nimport { usePluginManager } from '@dxos/app-framework/react';\nimport { Filter, Obj, Query, Type } from '@dxos/echo';\nimport { EntityKind, SystemTypeAnnotation, getTypeAnnotation } from '@dxos/echo/internal';\nimport { type Space } from '@dxos/react-client/echo';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { type EditorMenuGroup, type EditorMenuItem, insertAtCursor, insertAtLineStart } from '@dxos/react-ui-editor';\n\nexport const useLinkQuery = (space: Space | undefined) => {\n const { t } = useTranslation();\n\n const manager = usePluginManager();\n const resolve = useCallback(\n (typename: string) =>\n manager.context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {},\n [manager],\n );\n\n const filter = useMemo(\n () =>\n Filter.or(\n ...(space?.db.schemaRegistry.query({ location: ['database', 'runtime'] }).runSync() ?? [])\n .filter((schema) => getTypeAnnotation(schema)?.kind !== EntityKind.Relation)\n .filter((schema) => !SystemTypeAnnotation.get(schema).pipe(Option.getOrElse(() => false)))\n .map((schema) => Filter.typename(Type.getTypename(schema))),\n ),\n [space],\n );\n\n const handleLinkQuery = useCallback(\n async (query?: string): Promise<EditorMenuGroup[]> => {\n const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');\n const results = await space?.db.query(Query.select(filter)).run();\n\n // TODO(wittjosiah): Use `Obj.Any` type.\n const getLabel = (object: any) => {\n const label = Obj.getLabel(object);\n if (label) {\n return label;\n }\n\n // TODO(wittjosiah): Remove metadata labels.\n const type = Obj.getTypename(object)!;\n const metadata = resolve(type);\n return metadata.label?.(object) || ['object name placeholder', { ns: type, default: 'New object' }];\n };\n\n const items =\n results\n ?.filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name))\n // TODO(wittjosiah): Remove `any` type.\n .map((object: any): EditorMenuItem => {\n const metadata = resolve(Obj.getTypename(object)!);\n const label = toLocalizedString(getLabel(object), t);\n return {\n id: object.id,\n label,\n icon: metadata.icon,\n onSelect: ({ view, head }) => {\n const link = `[${label}](${Obj.getDXN(object)})`;\n if (query?.startsWith('@')) {\n insertAtLineStart(view, head, `!${link}\\n`);\n } else {\n insertAtCursor(view, head, `${link} `);\n }\n },\n };\n }) ?? [];\n\n return [{ id: 'echo', items }];\n },\n [space, filter, resolve],\n );\n\n return handleLinkQuery;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport { useCallback, useMemo, useRef } from 'react';\n\nimport { Domino, toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport {\n type EditorMenuGroup,\n type UseEditorMenuProps,\n filterMenuGroups,\n formattingCommands,\n linkSlashCommands,\n} from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\n\nexport type UseEditorMenuOptionsProps = {\n editorView?: EditorView;\n slashCommandGroups?: EditorMenuGroup[];\n onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;\n};\n\nexport const useEditorMenuOptions = ({\n editorView,\n slashCommandGroups,\n onLinkQuery,\n}: UseEditorMenuOptionsProps): UseEditorMenuProps => {\n const { t } = useTranslation(meta.id);\n\n const getMenu = useCallback<NonNullable<UseEditorMenuProps['getMenu']>>(\n ({ text, trigger }) => {\n switch (trigger) {\n case '@': {\n return onLinkQuery?.(text) ?? [];\n }\n\n case '/':\n default: {\n return filterMenuGroups([formattingCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>\n text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true,\n );\n }\n }\n },\n [slashCommandGroups, onLinkQuery],\n );\n\n const viewRef = useRef(editorView);\n return useMemo<UseEditorMenuProps>(() => {\n const trigger = onLinkQuery ? ['/', '@'] : ['/'];\n const placeholder = {\n delay: 3_000,\n content: () =>\n Domino.of('div')\n .children(\n Domino.of('span').text('Press'),\n ...trigger.map((text) =>\n Domino.of('span')\n .classNames('mx-1 pli-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm')\n .text(text),\n ),\n Domino.of('span').text('for commands.'),\n )\n .build(),\n };\n\n return { viewRef, getMenu, trigger, placeholder };\n }, [getMenu, onLinkQuery]);\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type ViewUpdate } from '@codemirror/view';\nimport React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport { LayoutAction, type PromiseIntentDispatcher, createIntent } from '@dxos/app-framework';\nimport { useIntentDispatcher } from '@dxos/app-framework/react';\nimport { debounceAndThrottle } from '@dxos/async';\nimport { Obj } from '@dxos/echo';\nimport { createDocAccessor } from '@dxos/echo-db';\nimport { invariant } from '@dxos/invariant';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { useIdentity } from '@dxos/react-client/halo';\nimport { Icon, ThemeProvider } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n Cursor,\n type EditorStateStore,\n EditorView,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n type PreviewOptions,\n type RenderCallback,\n createDataExtensions,\n decorateMarkdown,\n documentId,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n preview,\n replacer,\n selectionState,\n typewriter,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { Text } from '@dxos/schema';\nimport { isTruthy } from '@dxos/util';\n\nimport { Markdown } from '../types';\nimport { setFallbackName } from '../util';\n\nexport type DocumentType = Markdown.Document | Text.Text | { id: string; text: string };\n\nexport type ExtensionsOptions = {\n id: string;\n object?: DocumentType;\n dispatch?: PromiseIntentDispatcher;\n settings?: Markdown.Settings;\n selectionManager?: SelectionManager;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n previewOptions?: PreviewOptions;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({\n id,\n object,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const identity = useIdentity();\n const space = getSpace(object);\n\n let target: Obj.Any | undefined;\n if (Obj.instanceOf(Markdown.Document, object)) {\n target = (object as Markdown.Document).content.target;\n } else if (Obj.instanceOf(Text.Text, object)) {\n target = object;\n }\n\n // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.\n // TODO(burdon): Unsubscribe.\n // const query = space?.db.query(Filter.type(DocumentType));\n // query?.subscribe();\n\n const baseExtensions = useMemo(\n () =>\n createBaseExtensions({\n id,\n object,\n settings,\n selectionManager,\n viewMode,\n previewOptions,\n dispatch,\n }),\n [\n id,\n object,\n viewMode,\n dispatch,\n previewOptions,\n settings,\n settings?.debug,\n settings?.editorInputMode,\n settings?.folding,\n settings?.numberedHeadings,\n settings?.typewriter,\n selectionManager,\n ],\n );\n\n return useMemo<Extension[]>(\n () =>\n [\n // TODO(burdon): Pass this in?\n // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.\n target &&\n createDataExtensions({\n id,\n text: createDocAccessor(target, ['content']),\n messenger: space,\n identity,\n }),\n\n // TODO(burdon): Reconcile with effect in parent.\n Obj.instanceOf(Markdown.Document, object) &&\n listener({\n onChange: ({ text }) => {\n setFallbackName(object as Markdown.Document, text);\n },\n }),\n\n baseExtensions,\n selectionState(editorStateStore),\n ].filter(isTruthy),\n [identity, space, id, object, target, baseExtensions],\n );\n};\n\n/**\n * Create extension instances for editor.\n */\nconst createBaseExtensions = ({\n id,\n object,\n dispatch,\n settings,\n selectionManager,\n viewMode,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n selectionManager && selectionChange(selectionManager),\n settings?.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings?.folding && folding(),\n ].filter(isTruthy);\n\n //\n // Markdown\n //\n if (viewMode !== 'source') {\n extensions.push(\n ...[\n formattingKeymap(),\n decorateMarkdown({\n selectionChangeDelay: 100,\n numberedHeadings: settings?.numberedHeadings ? { from: 2 } : undefined,\n // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.\n // TODO(burdon): Create dx-tag.\n renderLinkButton:\n dispatch && (object || id)\n ? createLinkRenderer((id: string) => {\n void dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [id],\n options: {\n pivotId: object && Obj.isObject(object) ? Obj.getDXN(object).toString() : id,\n },\n }),\n );\n })\n : undefined,\n }),\n linkTooltip(renderLinkTooltip),\n preview(previewOptions),\n replacer(),\n ],\n );\n }\n\n if (settings?.debug) {\n const items = settings.typewriter?.split(/[,\\n]/) ?? '';\n if (items) {\n extensions.push(typewriter({ items }));\n }\n }\n\n return extensions;\n};\n\nconst selectionChange = (selectionManager: SelectionManager) => {\n return EditorView.updateListener.of(\n debounceAndThrottle((update: ViewUpdate) => {\n if (update.selectionSet) {\n const id = update.state.facet(documentId);\n const cursorConverter = update.state.facet(Cursor.converter);\n const selection = update.state.selection;\n const ranges = selection.ranges\n .map((range) => ({\n from: cursorConverter.toCursor(range.from),\n to: cursorConverter.toCursor(range.to),\n }))\n .filter(({ from, to }) => to > from);\n\n selectionManager.updateMultiRange(id, ranges);\n }\n }, 100),\n );\n};\n\n// TODO(burdon): Factor out styles.\nconst style = {\n hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',\n icon: 'inline-block leading-none mis-1 cursor-pointer',\n};\n\nconst createLinkRenderer =\n (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>\n (el, { url }) => {\n // TODO(burdon): Formalize/document internal link format.\n const isInternal =\n url.startsWith('/') ||\n // TODO(wittjosiah): This should probably be parsed out on paste?\n url.startsWith(window.location.origin);\n\n const options: AnchorHTMLAttributes<any> = isInternal\n ? {\n onClick: () => {\n const qualifiedId = url.split('/').at(-1);\n invariant(qualifiedId, 'Invalid link format.');\n onSelectObject(qualifiedId);\n },\n }\n : {\n href: url,\n rel: 'noreferrer',\n target: '_blank',\n };\n\n renderRoot(\n el,\n <a {...options} className={style.hover}>\n <Icon\n icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}\n size={4}\n classNames={style.icon}\n />\n </a>,\n );\n };\n\nconst renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {\n const web = new URL(url);\n renderRoot(\n el,\n <a href={url} rel='noreferrer' target='_blank' className={style.hover}>\n {web.origin}\n <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />\n </a>,\n );\n};\n\n// TODO(burdon): REMOVE.\nconst renderRoot = <T extends Element>(root: T, node: ReactNode): T => {\n createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);\n return root;\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport * as Schema from 'effect/Schema';\nimport { useMemo } from 'react';\n\nimport { LayoutAction, createResolver } from '@dxos/app-framework';\nimport { useIntentResolver } from '@dxos/app-framework/react';\nimport { invariant } from '@dxos/invariant';\nimport { Cursor, setSelection } from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\n\n/**\n * Handle scrolling and selection of the current thread in a markdown editor.\n */\nexport const useSelectCurrentThread = (editorView: EditorView | null, documentId: string) => {\n const scrollIntoViewResolver = useMemo(\n () =>\n createResolver({\n intent: LayoutAction.UpdateLayout,\n position: 'hoist',\n filter: (\n data,\n ): data is {\n part: 'current';\n subject: string;\n options: { cursor: string };\n } => {\n if (!Schema.is(LayoutAction.ScrollIntoView.fields.input)(data)) {\n return false;\n }\n\n return !!editorView && data.subject === documentId && !!data.options?.cursor;\n },\n resolve: ({ options: { cursor } }) => {\n invariant(editorView, 'Editor view is not defined.');\n const range = Cursor.getRangeFromCursor(editorView.state, cursor!);\n if (range) {\n const selection = editorView.state.selection.main.from !== range.from ? { anchor: range.from } : undefined;\n const effects = [\n // NOTE: This does not use the DOM scrollIntoView function.\n EditorView.scrollIntoView(range.from, {\n y: 'start',\n yMargin: 96,\n }),\n ];\n if (selection) {\n // Update the editor selection to get bi-directional highlighting.\n effects.push(setSelection.of({ current: documentId }));\n }\n\n editorView.dispatch({\n effects,\n selection: selection ? { anchor: range.from } : undefined,\n });\n }\n },\n }),\n [documentId, editorView],\n );\n\n useIntentResolver(meta.id, scrollIntoViewResolver);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Extension } from '@codemirror/state';\nimport { type EditorView } from '@codemirror/view';\nimport { createContext } from '@radix-ui/react-context';\nimport React, { type PropsWithChildren, useMemo, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { Surface } from '@dxos/app-framework/react';\nimport { DXN } from '@dxos/keys';\nimport { type Live } from '@dxos/live-object';\nimport { useClient } from '@dxos/react-client';\nimport {\n EditorMenuProvider,\n type EditorToolbarState,\n type PreviewBlock,\n type PreviewOptions,\n type UseEditorMenu,\n useEditorMenu,\n useEditorToolbar,\n} from '@dxos/react-ui-editor';\nimport { isNonNullable } from '@dxos/util';\n\nimport {\n type DocumentType,\n type ExtensionsOptions,\n type UseEditorMenuOptionsProps,\n useEditorMenuOptions,\n useExtensions,\n} from '../../hooks';\n\nimport {\n MarkdownEditorContent as NaturalMarkdownEditorContent,\n type MarkdownEditorContentProps as NaturalMarkdownEditorContentProps,\n} from './MarkdownEditorContent';\nimport {\n MarkdownEditorToolbar as NaturalMarkdownToolbar,\n type MarkdownEditorToolbarProps as NaturalMarkdownToolbarProps,\n} from './MarkdownEditorToolbar';\n\n//\n// Context\n//\n\ntype MarkdownEditorContextValue = {\n id: string;\n setEditorView: (view: EditorView) => void;\n extensions: Extension[];\n previewBlocks: PreviewBlock[];\n toolbarState: Live<EditorToolbarState>;\n popoverMenu: Omit<UseEditorMenu, 'extension'>;\n} & (Pick<ExtensionsOptions, 'viewMode'> &\n Pick<NaturalMarkdownToolbarProps, 'editorView' | 'onFileUpload' | 'onViewModeChange'>);\n\nconst [MarkdownEditorContextProvider, useMarkdownEditorContext] =\n createContext<MarkdownEditorContextValue>('MarkdownEditor.Context');\n\n//\n// MarkdownEditor.Root\n//\n\ntype MarkdownEditorRootProps = PropsWithChildren<\n {\n object?: DocumentType;\n extensions?: Extension[];\n } & Pick<MarkdownEditorContextValue, 'id' | 'onFileUpload' | 'onViewModeChange' | 'viewMode'> &\n Pick<UseEditorMenuOptionsProps, 'slashCommandGroups' | 'onLinkQuery'> &\n Pick<ExtensionsOptions, 'editorStateStore' | 'selectionManager' | 'settings'>\n>;\n\nconst MarkdownEditorRoot = ({\n children,\n id,\n object,\n editorStateStore,\n selectionManager,\n settings,\n viewMode,\n extensions: extensionsParam,\n slashCommandGroups,\n onLinkQuery,\n ...props\n}: MarkdownEditorRootProps) => {\n const [editorView, setEditorView] = useState<EditorView>();\n\n // Preview blocks.\n const [previewBlocks, setPreviewBlocks] = useState<PreviewBlock[]>([]);\n const previewOptions = useMemo<PreviewOptions>(\n () => ({\n addBlockContainer: (block) => {\n setPreviewBlocks((prev) => [...prev, block]);\n },\n removeBlockContainer: ({ link }) => {\n setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));\n },\n }),\n [],\n );\n\n // Toolbar state.\n const toolbarState = useEditorToolbar({ viewMode });\n\n // Context menu.\n const menuOptions = useEditorMenuOptions({\n editorView,\n slashCommandGroups,\n onLinkQuery,\n });\n const { extension: menuExtension, ...menuProps } = useEditorMenu(menuOptions);\n\n // Extensions.\n const coreExtensions = useExtensions({\n id,\n object,\n editorStateStore,\n previewOptions,\n selectionManager,\n settings,\n viewMode,\n });\n\n const extensions = useMemo(\n () => [coreExtensions, menuExtension, extensionsParam].filter(isNonNullable),\n [coreExtensions, menuExtension, extensionsParam],\n );\n\n return (\n <MarkdownEditorContextProvider\n id={id}\n editorView={editorView}\n setEditorView={setEditorView}\n extensions={extensions}\n previewBlocks={previewBlocks}\n toolbarState={toolbarState}\n popoverMenu={menuProps}\n viewMode={viewMode}\n {...props}\n >\n {children}\n </MarkdownEditorContextProvider>\n );\n};\n\nMarkdownEditorRoot.displayName = 'MarkdownEditor.Root';\n\n//\n// MarkdownEditor.Main\n//\n\ntype MarkdownEditorContentProps = Omit<NaturalMarkdownEditorContentProps, 'id' | 'extensions' | 'toolbarState'>;\n\nconst MarkdownEditorContent = (props: MarkdownEditorContentProps) => {\n const {\n id,\n editorView,\n setEditorView,\n viewMode,\n toolbarState,\n extensions,\n popoverMenu: { groupsRef, ...menuProps },\n } = useMarkdownEditorContext(MarkdownEditorContent.displayName);\n\n return (\n <EditorMenuProvider view={editorView} groups={groupsRef.current} {...menuProps}>\n <NaturalMarkdownEditorContent\n {...props}\n id={id}\n viewMode={viewMode}\n toolbarState={toolbarState}\n extensions={extensions}\n ref={setEditorView}\n />\n </EditorMenuProvider>\n );\n};\n\nMarkdownEditorContent.displayName = 'MarkdownEditor.Content';\n\n//\n// MarkdownEditor.Toolbar\n//\n\ntype MarkdownEditorToolbarProps = Omit<\n NaturalMarkdownToolbarProps,\n 'state' | 'editorView' | 'onFileUpload' | 'onViewModeChange'\n>;\n\nconst MarkdownEditorToolbar = (props: MarkdownEditorToolbarProps) => {\n const { toolbarState, ...rootProps } = useMarkdownEditorContext(MarkdownEditorToolbar.displayName);\n\n return <NaturalMarkdownToolbar {...props} {...rootProps} state={toolbarState} />;\n};\n\nMarkdownEditorToolbar.displayName = 'MarkdownEditor.Toolbar';\n\n//\n// MarkdownEditor.Blocks (embedded objects)\n//\n\ntype MarkdownEditorBlocksProps = {};\n\nconst MarkdownEditorBlocks = (_props: MarkdownEditorBlocksProps) => {\n const { previewBlocks } = useMarkdownEditorContext(MarkdownEditorBlocks.displayName);\n\n return (\n <>\n {previewBlocks.map(({ link, el }) => (\n <PreviewBlock key={link.ref} link={link} el={el} />\n ))}\n </>\n );\n};\n\nMarkdownEditorBlocks.displayName = 'MarkdownEditor.Blocks';\n\nconst PreviewBlock = ({ el, link }: PreviewBlock) => {\n const client = useClient();\n const dxn = DXN.parse(link.ref);\n const subject = client.graph.makeRef(dxn).target;\n const data = useMemo(() => ({ subject }), [subject]);\n\n return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);\n};\n\n//\n// MarkdownEditor\n//\n\nexport const MarkdownEditor = {\n Root: MarkdownEditorRoot,\n Content: MarkdownEditorContent,\n Toolbar: MarkdownEditorToolbar,\n Blocks: MarkdownEditorBlocks,\n};\n\nexport type {\n MarkdownEditorRootProps,\n MarkdownEditorContentProps,\n MarkdownEditorToolbarProps,\n MarkdownEditorBlocksProps,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { forwardRef, useEffect, useImperativeHandle, useMemo } from 'react';\n\nimport { type Live } from '@dxos/live-object';\nimport { type ThemedClassName, useDynamicRef, useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type EditorMenuGroup,\n type EditorSelectionState,\n type EditorStateStore,\n type EditorToolbarState,\n type EditorViewMode,\n type ThemeExtensionsOptions,\n type UseTextEditorProps,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorSlots,\n formattingListener,\n processEditorPayload,\n stackItemContentEditorClassNames,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { mx } from '@dxos/react-ui-theme';\nimport { isTruthy } from '@dxos/util';\n\nimport { useSelectCurrentThread } from '../../hooks';\nimport { meta } from '../../meta';\n\nimport { type MarkdownEditorToolbarProps } from './MarkdownEditorToolbar';\n\nexport type MarkdownEditorContentProps = ThemedClassName<{\n id: string;\n role?: string;\n viewMode?: EditorViewMode;\n scrollPastEnd?: boolean;\n slashCommandGroups?: EditorMenuGroup[];\n editorStateStore?: EditorStateStore;\n toolbarState?: Live<EditorToolbarState>;\n onLinkQuery?: (query?: string) => Promise<EditorMenuGroup[]>;\n}> &\n // prettier-ignore\n Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &\n Pick<MarkdownEditorToolbarProps, 'onFileUpload'> &\n Pick<ThemeExtensionsOptions, 'slots'>;\n\nexport const MarkdownEditorContent = forwardRef<EditorView | null, MarkdownEditorContentProps>(\n (\n {\n classNames,\n id,\n role,\n viewMode,\n initialValue,\n editorStateStore,\n toolbarState,\n extensions,\n scrollPastEnd,\n slots = editorSlots,\n onFileUpload,\n },\n forwardedRef,\n ) => {\n const { t } = useTranslation(meta.id);\n const { themeMode } = useThemeContext();\n\n // TODO(burdon): Toolbar state is not reactive.\n const toolbarStateRef = useDynamicRef(toolbarState);\n\n // Restore last selection and scroll point.\n const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);\n\n const {\n parentRef,\n view: editorView,\n focusAttributes,\n } = useTextEditor(\n () => ({\n ...(role !== 'section' && {\n id,\n scrollTo,\n selection,\n // TODO(wittjosiah): Autofocus based on layout is racy.\n // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,\n selectionEnd: true,\n }),\n initialValue,\n extensions: [\n createBasicExtensions({\n readOnly: viewMode === 'readonly',\n placeholder: t('editor placeholder'),\n scrollPastEnd: scrollPastEnd && role !== 'section',\n search: true,\n }),\n createThemeExtensions({\n themeMode,\n slots,\n syntaxHighlighting: true,\n }),\n createMarkdownExtensions(),\n formattingListener(() => toolbarStateRef.current),\n role !== 'section' &&\n onFileUpload &&\n dropFile({\n // TODO(wittjosiah): Factor out to file uploader plugin.\n onDrop: async (view, { files }) => {\n const file = files[0];\n const info = file && onFileUpload ? await onFileUpload(file) : undefined;\n if (info) {\n processEditorPayload(view, { type: 'image', data: info.url });\n }\n },\n }),\n extensions,\n ].filter(isTruthy),\n }),\n [id, viewMode, themeMode, extensions],\n );\n\n useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => editorView, [editorView]);\n\n useSelectCurrentThread(editorView, id);\n\n useTest(editorView);\n\n return (\n <div\n role='none'\n ref={parentRef}\n data-testid='composer.markdownRoot'\n className={mx(stackItemContentEditorClassNames(role), classNames)}\n data-popover-collision-boundary={true}\n {...focusAttributes}\n />\n );\n },\n);\n\n// Expose editor view for playwright tests.\n// TODO(wittjosiah): Find a better way to expose this or find a way to limit it to test runs.\nconst useTest = (view: EditorView | null) => {\n useEffect(() => {\n const composer = (window as any).composer;\n if (composer) {\n composer.editorView = view;\n }\n }, [view]);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { useCallback, useState } from 'react';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { EditorToolbar, type EditorToolbarProps, type EditorViewMode } from '@dxos/react-ui-editor';\n\nimport { FileUpload, type FileUploadAction } from './FileUpload';\n\nexport type MarkdownEditorToolbarProps = ThemedClassName<\n {\n id: string;\n editorView?: EditorView;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n } & Pick<EditorToolbarProps, 'role' | 'state' | 'customActions' | 'onViewModeChange'>\n>;\n\nexport const MarkdownEditorToolbar = ({\n classNames,\n id,\n role,\n state,\n editorView,\n customActions,\n onFileUpload,\n onViewModeChange,\n}: MarkdownEditorToolbarProps) => {\n const [upload, setUpload] = useState<FileUploadAction | null>(null);\n const uploadRef = useCallback((next: FileUploadAction) => setUpload(() => next), []);\n\n const handleViewModeChange = useCallback((mode: EditorViewMode) => onViewModeChange?.(mode), [onViewModeChange]);\n\n const getView = useCallback(() => {\n invariant(editorView);\n return editorView;\n }, [editorView]);\n\n if (!editorView) {\n return <div />;\n }\n\n return (\n <>\n <EditorToolbar\n classNames={classNames}\n attendableId={id}\n role={role}\n state={state}\n customActions={customActions}\n getView={getView}\n onImageUpload={upload ?? undefined}\n onViewModeChange={handleViewModeChange}\n />\n\n {onFileUpload && <FileUpload ref={uploadRef} editorView={editorView} onFileUpload={onFileUpload} />}\n </>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { forwardRef, useEffect, useImperativeHandle } from 'react';\nimport { createPortal } from 'react-dom';\nimport { useDropzone } from 'react-dropzone';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { addLink } from '@dxos/react-ui-editor';\n\nexport const IMAGE_FILES = ['.jpg', '.jpeg', '.png', '.gif'];\n\nexport type FileUploadAction = () => void;\n\nexport type FileUploadProps = {\n editorView?: EditorView;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n};\n\n// TODO(burdon): Factor out.\n// TODO(burdon): Move to root? (support drag into document via dropzone).\nexport const FileUpload = forwardRef<FileUploadAction, FileUploadProps>(\n ({ editorView, onFileUpload }, forwardedRef) => {\n // https://react-dropzone.js.org\n const { acceptedFiles, open, inputRef } = useDropzone({\n disabled: !onFileUpload,\n multiple: false,\n noDrag: true,\n accept: {\n 'image/*': IMAGE_FILES,\n },\n });\n\n useImperativeHandle(forwardedRef, () => open, []);\n\n useEffect(() => {\n if (editorView && acceptedFiles.length && onFileUpload) {\n requestAnimationFrame(async () => {\n // NOTE: Clone file since react-dropzone patches in a non-standard `path` property, which confuses IPFS.\n const f = acceptedFiles[0];\n const file = new File([f], f.name, {\n type: f.type,\n lastModified: f.lastModified,\n });\n\n // TODO(burdon): Factor out.\n const info = await onFileUpload(file);\n if (info) {\n addLink({ url: info.url, image: true })(editorView);\n }\n });\n }\n }, [editorView, acceptedFiles, onFileUpload]);\n\n if (!onFileUpload) {\n return null;\n }\n\n return <>{createPortal(<input ref={inputRef} />, document.body)} </>;\n },\n);\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;AAIA,YAAYA,YAAY;AACxB,SAASC,aAAaC,eAAe;AAErC,SAASC,oBAAoB;AAC7B,SAASC,wBAAwB;AACjC,SAASC,QAAQC,KAAKC,OAAOC,YAAY;AACzC,SAASC,YAAYC,sBAAsBC,yBAAyB;AAEpE,SAASC,mBAAmBC,sBAAsB;AAClD,SAAoDC,gBAAgBC,yBAAyB;AAEtF,IAAMC,eAAe,CAACC,UAAAA;AAC3B,QAAM,EAAEC,EAAC,IAAKC,eAAAA;AAEd,QAAMC,UAAUC,iBAAAA;AAChB,QAAMC,UAAUC,YACd,CAACC,aACCJ,QAAQK,QAAQC,gBAAgBC,aAAaC,QAAQ,EAAEC,KAAK,CAAC,EAAEC,GAAE,MAAOA,OAAON,QAAAA,GAAWO,YAAY,CAAC,GACzG;IAACX;GAAQ;AAGX,QAAMY,SAASC,QACb,MACEC,OAAOC,GAAE,IACHlB,OAAOmB,GAAGC,eAAeC,MAAM;IAAEC,UAAU;MAAC;MAAY;;EAAW,CAAA,EAAGC,QAAAA,KAAa,CAAA,GACpFR,OAAO,CAACS,WAAWC,kBAAkBD,MAAAA,GAASE,SAASC,WAAWC,QAAQ,EAC1Eb,OAAO,CAACS,WAAW,CAACK,qBAAqBC,IAAIN,MAAAA,EAAQO,KAAYC,iBAAU,MAAM,KAAA,CAAA,CAAA,EACjFC,IAAI,CAACT,WAAWP,OAAOV,SAAS2B,KAAKC,YAAYX,MAAAA,CAAAA,CAAAA,CAAAA,GAExD;IAACxB;GAAM;AAGT,QAAMoC,kBAAkB9B,YACtB,OAAOe,UAAAA;AACL,UAAMgB,OAAOhB,OAAOiB,WAAW,GAAA,IAAOjB,MAAMkB,MAAM,CAAA,EAAGC,YAAW,IAAMnB,OAAOmB,YAAAA,KAAiB;AAC9F,UAAMC,UAAU,MAAMzC,OAAOmB,GAAGE,MAAMqB,MAAMC,OAAO5B,MAAAA,CAAAA,EAAS6B,IAAAA;AAG5D,UAAMC,WAAW,CAACC,WAAAA;AAChB,YAAMC,QAAQC,IAAIH,SAASC,MAAAA;AAC3B,UAAIC,OAAO;AACT,eAAOA;MACT;AAGA,YAAME,OAAOD,IAAIb,YAAYW,MAAAA;AAC7B,YAAMhC,WAAWT,QAAQ4C,IAAAA;AACzB,aAAOnC,SAASiC,QAAQD,MAAAA,KAAW;QAAC;QAA2B;UAAEI,IAAID;UAAME,SAAS;QAAa;;IACnG;AAEA,UAAMC,QACJX,SACI1B,OAAO,CAAC+B,WAAWO,kBAAkBR,SAASC,MAAAA,GAAS7C,CAAAA,EAAGuC,YAAW,EAAGc,SAASjB,IAAAA,CAAAA,EAElFJ,IAAI,CAACa,WAAAA;AACJ,YAAMhC,WAAWT,QAAQ2C,IAAIb,YAAYW,MAAAA,CAAAA;AACzC,YAAMC,QAAQM,kBAAkBR,SAASC,MAAAA,GAAS7C,CAAAA;AAClD,aAAO;QACLY,IAAIiC,OAAOjC;QACXkC;QACAQ,MAAMzC,SAASyC;QACfC,UAAU,CAAC,EAAEC,MAAMC,KAAI,MAAE;AACvB,gBAAMC,OAAO,IAAIZ,KAAAA,KAAUC,IAAIY,OAAOd,MAAAA,CAAAA;AACtC,cAAIzB,OAAOiB,WAAW,GAAA,GAAM;AAC1BuB,8BAAkBJ,MAAMC,MAAM,IAAIC,IAAAA;CAAQ;UAC5C,OAAO;AACLG,2BAAeL,MAAMC,MAAM,GAAGC,IAAAA,GAAO;UACvC;QACF;MACF;IACF,CAAA,KAAM,CAAA;AAEV,WAAO;MAAC;QAAE9C,IAAI;QAAQuC;MAAM;;EAC9B,GACA;IAACpD;IAAOe;IAAQV;GAAQ;AAG1B,SAAO+B;AACT;;;AC7EA,SAAS2B,eAAAA,cAAaC,WAAAA,UAASC,cAAc;AAE7C,SAASC,QAAQC,qBAAAA,oBAAmBC,kBAAAA,uBAAsB;AAC1D,SAGEC,kBACAC,oBACAC,yBACK;AAUA,IAAMC,uBAAuB,CAAC,EACnCC,YACAC,oBACAC,YAAW,MACe;AAC1B,QAAM,EAAEC,EAAC,IAAKC,gBAAeC,KAAKC,EAAE;AAEpC,QAAMC,UAAUC,aACd,CAAC,EAAEC,MAAMC,QAAO,MAAE;AAChB,YAAQA,SAAAA;MACN,KAAK,KAAK;AACR,eAAOR,cAAcO,IAAAA,KAAS,CAAA;MAChC;MAEA,KAAK;MACL,SAAS;AACP,eAAOE,iBAAiB;UAACC;UAAoBC;aAAuBZ,sBAAsB,CAAA;WAAM,CAACa,SAC/FL,OAAOM,mBAAkBD,KAAKE,OAAOb,CAAAA,EAAGc,YAAW,EAAGC,SAAST,KAAKQ,YAAW,CAAA,IAAM,IAAA;MAEzF;IACF;EACF,GACA;IAAChB;IAAoBC;GAAY;AAGnC,QAAMiB,UAAUC,OAAOpB,UAAAA;AACvB,SAAOqB,SAA4B,MAAA;AACjC,UAAMX,UAAUR,cAAc;MAAC;MAAK;QAAO;MAAC;;AAC5C,UAAMoB,cAAc;MAClBC,OAAO;MACPC,SAAS,MACPC,OAAOC,GAAG,KAAA,EACPC,SACCF,OAAOC,GAAG,MAAA,EAAQjB,KAAK,OAAA,GAAA,GACpBC,QAAQkB,IAAI,CAACnB,SACdgB,OAAOC,GAAG,MAAA,EACPG,WAAW,mEAAA,EACXpB,KAAKA,IAAAA,CAAAA,GAEVgB,OAAOC,GAAG,MAAA,EAAQjB,KAAK,eAAA,CAAA,EAExBqB,MAAK;IACZ;AAEA,WAAO;MAAEX;MAASZ;MAASG;MAASY;IAAY;EAClD,GAAG;IAACf;IAASL;GAAY;AAC3B;;;ACjEA,OAAO6B,SAAoDC,WAAAA,gBAAe;AAC1E,SAASC,kBAAkB;AAE3B,SAASC,cAA4CC,oBAAoB;AACzE,SAASC,2BAA2B;AACpC,SAASC,2BAA2B;AACpC,SAASC,OAAAA,YAAW;AACpB,SAASC,yBAAyB;AAClC,SAASC,iBAAiB;AAC1B,SAASC,gBAAgB;AACzB,SAASC,mBAAmB;AAC5B,SAASC,MAAMC,qBAAqB;AAEpC,SACEC,QAEAC,YAGAC,qBAGAC,sBACAC,kBACAC,YACAC,SACAC,kBACAC,aACAC,UACAC,SACAC,UACAC,gBACAC,kBACK;AACP,SAASC,iBAAiB;AAC1B,SAASC,YAAY;AACrB,SAASC,gBAAgB;;AAmBlB,IAAMC,gBAAgB,CAAC,EAC5BC,IACAC,QACAC,UACAC,kBACAC,UACAC,kBACAC,eAAc,MACI;AAClB,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,QAAMC,WAAWC,YAAAA;AACjB,QAAMC,QAAQC,SAASZ,MAAAA;AAEvB,MAAIa;AACJ,MAAIC,KAAIC,WAAWC,iBAASC,UAAUjB,MAAAA,GAAS;AAC7Ca,aAAUb,OAA6BkB,QAAQL;EACjD,WAAWC,KAAIC,WAAWI,KAAKA,MAAMnB,MAAAA,GAAS;AAC5Ca,aAASb;EACX;AAOA,QAAMoB,iBAAiBC,SACrB,MACEC,qBAAqB;IACnBvB;IACAC;IACAC;IACAC;IACAC;IACAE;IACAE;EACF,CAAA,GACF;IACER;IACAC;IACAG;IACAI;IACAF;IACAJ;IACAA,UAAUsB;IACVtB,UAAUuB;IACVvB,UAAUwB;IACVxB,UAAUyB;IACVzB,UAAU0B;IACVzB;GACD;AAGH,SAAOmB,SACL,MACE;;;IAGER,UACEe,qBAAqB;MACnB7B;MACA8B,MAAMC,kBAAkBjB,QAAQ;QAAC;OAAU;MAC3CkB,WAAWpB;MACXF;IACF,CAAA;;IAGFK,KAAIC,WAAWC,iBAASC,UAAUjB,MAAAA,KAChCgC,SAAS;MACPC,UAAU,CAAC,EAAEJ,KAAI,MAAE;AACjBK,wBAAgBlC,QAA6B6B,IAAAA;MAC/C;IACF,CAAA;IAEFT;IACAe,eAAe/B,gBAAAA;IACfgC,OAAOC,QAAAA,GACX;IAAC5B;IAAUE;IAAOZ;IAAIC;IAAQa;IAAQO;GAAe;AAEzD;AAKA,IAAME,uBAAuB,CAAC,EAC5BvB,IACAC,QACAO,UACAN,UACAC,kBACAC,UACAE,eAAc,MACI;AAClB,QAAMiC,aAA0B;IAC9BpC,oBAAoBqC,gBAAgBrC,gBAAAA;IACpCD,UAAUuB,mBAAmBgB,oBAAoBvC,SAASuB,eAAe;IACzEvB,UAAUwB,WAAWA,QAAAA;IACrBW,OAAOC,QAAAA;AAKT,MAAIlC,aAAa,UAAU;AACzBmC,eAAWG,KAAI,GACV;MACDC,iBAAAA;MACAC,iBAAiB;QACfC,sBAAsB;QACtBlB,kBAAkBzB,UAAUyB,mBAAmB;UAAEmB,MAAM;QAAE,IAAIC;;;QAG7DC,kBACExC,aAAaP,UAAUD,MACnBiD,mBAAmB,CAACjD,QAAAA;AAClB,eAAKQ,SACH0C,aAAaC,aAAaC,MAAM;YAC9BC,MAAM;YACNC,SAAS;cAACtD;;YACVuD,SAAS;cACPC,SAASvD,UAAUc,KAAI0C,SAASxD,MAAAA,IAAUc,KAAI2C,OAAOzD,MAAAA,EAAQ0D,SAAQ,IAAK3D;YAC5E;UACF,CAAA,CAAA;QAEJ,CAAA,IACA+C;MACR,CAAA;MACAa,YAAYC,iBAAAA;MACZC,QAAQxD,cAAAA;MACRyD,SAAAA;KACD;EAEL;AAEA,MAAI7D,UAAUsB,OAAO;AACnB,UAAMwC,QAAQ9D,SAAS0B,YAAYqC,MAAM,OAAA,KAAY;AACrD,QAAID,OAAO;AACTzB,iBAAWG,KAAKd,WAAW;QAAEoC;MAAM,CAAA,CAAA;IACrC;EACF;AAEA,SAAOzB;AACT;AAEA,IAAMC,kBAAkB,CAACrC,qBAAAA;AACvB,SAAO+D,WAAWC,eAAeC,GAC/BC,oBAAoB,CAACC,WAAAA;AACnB,QAAIA,OAAOC,cAAc;AACvB,YAAMvE,KAAKsE,OAAOE,MAAMC,MAAMC,UAAAA;AAC9B,YAAMC,kBAAkBL,OAAOE,MAAMC,MAAMG,OAAOC,SAAS;AAC3D,YAAMC,YAAYR,OAAOE,MAAMM;AAC/B,YAAMC,SAASD,UAAUC,OACtBC,IAAI,CAACC,WAAW;QACfnC,MAAM6B,gBAAgBO,SAASD,MAAMnC,IAAI;QACzCqC,IAAIR,gBAAgBO,SAASD,MAAME,EAAE;MACvC,EAAA,EACC9C,OAAO,CAAC,EAAES,MAAMqC,GAAE,MAAOA,KAAKrC,IAAAA;AAEjC3C,uBAAiBiF,iBAAiBpF,IAAI+E,MAAAA;IACxC;EACF,GAAG,GAAA,CAAA;AAEP;AAGA,IAAMM,QAAQ;EACZC,OAAO;EACPC,MAAM;AACR;AAEA,IAAMtC,qBACJ,CAACuC,mBACD,CAACC,IAAI,EAAEC,IAAG,MAAE;AAEV,QAAMC,aACJD,IAAIE,WAAW,GAAA;EAEfF,IAAIE,WAAWC,OAAOC,SAASC,MAAM;AAEvC,QAAMxC,UAAqCoC,aACvC;IACEK,SAAS,MAAA;AACP,YAAMC,cAAcP,IAAIzB,MAAM,GAAA,EAAKiC,GAAG,EAAC;AACvCC,gBAAUF,aAAa,wBAAA;;;;;;;;;AACvBT,qBAAeS,WAAAA;IACjB;EACF,IACA;IACEG,MAAMV;IACNW,KAAK;IACLvF,QAAQ;EACV;AAEJwF,aACEb,IACA,sBAAA,cAACc,KAAAA;IAAG,GAAGhD;IAASiD,WAAWnB,MAAMC;KAC/B,sBAAA,cAACmB,MAAAA;IACClB,MAAMI,aAAa,gCAAgC;IACnDe,MAAM;IACNC,YAAYtB,MAAME;;AAI1B;AAEF,IAAM1B,oBAAqD,CAAC4B,IAAI,EAAEC,IAAG,MAAE;AACrE,QAAMkB,MAAM,IAAIC,IAAInB,GAAAA;AACpBY,aACEb,IACA,sBAAA,cAACc,KAAAA;IAAEH,MAAMV;IAAKW,KAAI;IAAavF,QAAO;IAAS0F,WAAWnB,MAAMC;KAC7DsB,IAAIb,QACL,sBAAA,cAACU,MAAAA;IAAKlB,MAAK;IAA6BmB,MAAM;IAAGC,YAAYtB,MAAME;;AAGzE;AAGA,IAAMe,aAAa,CAAoBQ,MAASC,SAAAA;AAC9CC,aAAWF,IAAAA,EAAMG,OAAO,sBAAA,cAACC,eAAAA;IAAcC,IAAIC;KAAYL,IAAAA,CAAAA;AACvD,SAAOD;AACT;;;AClRA,SAASO,cAAAA,mBAAkB;AAC3B,YAAYC,YAAY;AACxB,SAASC,WAAAA,gBAAe;AAExB,SAASC,gBAAAA,eAAcC,sBAAsB;AAC7C,SAASC,yBAAyB;AAClC,SAASC,aAAAA,kBAAiB;AAC1B,SAASC,UAAAA,SAAQC,oBAAoB;;AAO9B,IAAMC,yBAAyB,CAACC,YAA+BC,gBAAAA;AACpE,QAAMC,yBAAyBC,SAC7B,MACEC,eAAe;IACbC,QAAQC,cAAaC;IACrBC,UAAU;IACVC,QAAQ,CACNC,SAAAA;AAMA,UAAI,CAAQC,UAAGL,cAAaM,eAAeC,OAAOC,KAAK,EAAEJ,IAAAA,GAAO;AAC9D,eAAO;MACT;AAEA,aAAO,CAAC,CAACV,cAAcU,KAAKK,YAAYd,eAAc,CAAC,CAACS,KAAKM,SAASC;IACxE;IACAC,SAAS,CAAC,EAAEF,SAAS,EAAEC,OAAM,EAAE,MAAE;AAC/BE,MAAAA,WAAUnB,YAAY,+BAAA;;;;;;;;;AACtB,YAAMoB,QAAQC,QAAOC,mBAAmBtB,WAAWuB,OAAON,MAAAA;AAC1D,UAAIG,OAAO;AACT,cAAMI,YAAYxB,WAAWuB,MAAMC,UAAUC,KAAKC,SAASN,MAAMM,OAAO;UAAEC,QAAQP,MAAMM;QAAK,IAAIE;AACjG,cAAMC,UAAU;;UAEdC,YAAWC,eAAeX,MAAMM,MAAM;YACpCM,GAAG;YACHC,SAAS;UACX,CAAA;;AAEF,YAAIT,WAAW;AAEbK,kBAAQK,KAAKC,aAAaC,GAAG;YAAEC,SAASpC;UAAW,CAAA,CAAA;QACrD;AAEAD,mBAAWsC,SAAS;UAClBT;UACAL,WAAWA,YAAY;YAAEG,QAAQP,MAAMM;UAAK,IAAIE;QAClD,CAAA;MACF;IACF;EACF,CAAA,GACF;IAAC3B;IAAYD;GAAW;AAG1BuC,oBAAkBC,KAAKC,IAAIvC,sBAAAA;AAC7B;;;;AC3DA,SAASwC,qBAAqB;AAC9B,OAAOC,UAAiCC,WAAAA,UAASC,YAAAA,iBAAgB;AACjE,SAASC,gBAAAA,qBAAoB;AAE7B,SAASC,eAAe;AACxB,SAASC,WAAW;AAEpB,SAASC,iBAAiB;AAC1B,SACEC,oBAKAC,eACAC,wBACK;AACP,SAASC,qBAAqB;;;;AClB9B,OAAOC,UAASC,YAAYC,WAAWC,qBAAqBC,WAAAA,gBAAe;AAG3E,SAA+BC,eAAeC,iBAAiBC,kBAAAA,uBAAsB;AACrF,SAQEC,uBACAC,0BACAC,uBACAC,UACAC,aACAC,oBACAC,sBACAC,kCACAC,qBACK;AACP,SAASC,UAAU;AACnB,SAASC,YAAAA,iBAAgB;AAsBlB,IAAMC,wBAAwBC,2BACnC,CACE,EACEC,YACAC,IACAC,MACAC,UACAC,cACAC,kBACAC,cACAC,YACAC,eACAC,QAAQC,aACRC,aAAY,GAEdC,iBAAAA;;;AAEA,UAAM,EAAEC,EAAC,IAAKC,gBAAeC,KAAKd,EAAE;AACpC,UAAM,EAAEe,UAAS,IAAKC,gBAAAA;AAGtB,UAAMC,kBAAkBC,cAAcb,YAAAA;AAGtC,UAAM,EAAEc,UAAUC,UAAS,IAAKC,SAA8B,MAAMjB,kBAAkBkB,SAAStB,EAAAA,KAAO,CAAC,GAAG;MAACA;KAAG;AAE9G,UAAM,EACJuB,WACAC,MAAMC,YACNC,gBAAe,IACbC,cACF,OAAO;MACL,GAAI1B,SAAS,aAAa;QACxBD;QACAmB;QACAC;;;QAGAQ,cAAc;MAChB;MACAzB;MACAG,YAAY;QACVuB,sBAAsB;UACpBC,UAAU5B,aAAa;UACvB6B,aAAanB,EAAE,oBAAA;UACfL,eAAeA,iBAAiBN,SAAS;UACzC+B,QAAQ;QACV,CAAA;QACAC,sBAAsB;UACpBlB;UACAP;UACA0B,oBAAoB;QACtB,CAAA;QACAC,yBAAAA;QACAC,mBAAmB,MAAMnB,gBAAgBoB,OAAO;QAChDpC,SAAS,aACPS,gBACA4B,SAAS;;UAEPC,QAAQ,OAAOf,MAAM,EAAEgB,MAAK,MAAE;AAC5B,kBAAMC,OAAOD,MAAM,CAAA;AACnB,kBAAME,OAAOD,QAAQ/B,eAAe,MAAMA,aAAa+B,IAAAA,IAAQE;AAC/D,gBAAID,MAAM;AACRE,mCAAqBpB,MAAM;gBAAEqB,MAAM;gBAASC,MAAMJ,KAAKK;cAAI,CAAA;YAC7D;UACF;QACF,CAAA;QACFzC;QACA0C,OAAOC,SAAAA;IACX,IACA;MAACjD;MAAIE;MAAUa;MAAWT;KAAW;AAGvC4C,wBAA0DvC,cAAc,MAAMc,YAAY;MAACA;KAAW;AAEtG0B,2BAAuB1B,YAAYzB,EAAAA;AAEnCoD,YAAQ3B,UAAAA;AAER,WACE,gBAAA4B,OAAA,cAACC,OAAAA;MACCrD,MAAK;MACLsD,KAAKhC;MACLiC,eAAY;MACZC,WAAWC,GAAGC,iCAAiC1D,IAAAA,GAAOF,UAAAA;MACtD6D,mCAAiC;MAChC,GAAGlC;;;;;AAGV,CAAA;AAKF,IAAM0B,UAAU,CAAC5B,SAAAA;AACfqC,YAAU,MAAA;AACR,UAAMC,WAAYC,OAAeD;AACjC,QAAIA,UAAU;AACZA,eAASrC,aAAaD;IACxB;EACF,GAAG;IAACA;GAAK;AACX;;;;AClJA,OAAOwC,UAASC,eAAAA,cAAaC,gBAAgB;AAG7C,SAASC,aAAAA,kBAAiB;AAE1B,SAASC,qBAAmE;;;;ACL5E,OAAOC,UAASC,cAAAA,aAAYC,aAAAA,YAAWC,uBAAAA,4BAA2B;AAClE,SAASC,oBAAoB;AAC7B,SAASC,mBAAmB;AAG5B,SAASC,eAAe;AAEjB,IAAMC,cAAc;EAAC;EAAQ;EAAS;EAAQ;;AAW9C,IAAMC,aAAaC,gBAAAA,YACxB,CAAC,EAAEC,YAAYC,aAAY,GAAIC,iBAAAA;;;AAE7B,UAAM,EAAEC,eAAeC,MAAMC,SAAQ,IAAKC,YAAY;MACpDC,UAAU,CAACN;MACXO,UAAU;MACVC,QAAQ;MACRC,QAAQ;QACN,WAAWb;MACb;IACF,CAAA;AAEAc,IAAAA,qBAAoBT,cAAc,MAAME,MAAM,CAAA,CAAE;AAEhDQ,IAAAA,WAAU,MAAA;AACR,UAAIZ,cAAcG,cAAcU,UAAUZ,cAAc;AACtDa,8BAAsB,YAAA;AAEpB,gBAAMC,IAAIZ,cAAc,CAAA;AACxB,gBAAMa,OAAO,IAAIC,KAAK;YAACF;aAAIA,EAAEG,MAAM;YACjCC,MAAMJ,EAAEI;YACRC,cAAcL,EAAEK;UAClB,CAAA;AAGA,gBAAMC,OAAO,MAAMpB,aAAae,IAAAA;AAChC,cAAIK,MAAM;AACRC,oBAAQ;cAAEC,KAAKF,KAAKE;cAAKC,OAAO;YAAK,CAAA,EAAGxB,UAAAA;UAC1C;QACF,CAAA;MACF;IACF,GAAG;MAACA;MAAYG;MAAeF;KAAa;AAE5C,QAAI,CAACA,cAAc;AACjB,aAAO;IACT;AAEA,WAAO,gBAAAwB,OAAA,cAAAA,OAAA,UAAA,MAAGC,6BAAa,gBAAAD,OAAA,cAACE,SAAAA;MAAMC,KAAKvB;QAAcwB,SAASC,IAAI,GAAE,GAAA;;;;AAClE,CAAA;;;;ADvCK,IAAMC,wBAAwB,CAAC,EACpCC,YACAC,IACAC,MACAC,OACAC,YACAC,eACAC,cACAC,iBAAgB,MACW;;;AAC3B,UAAM,CAACC,QAAQC,SAAAA,IAAaC,SAAkC,IAAA;AAC9D,UAAMC,YAAYC,aAAY,CAACC,SAA2BJ,UAAU,MAAMI,IAAAA,GAAO,CAAA,CAAE;AAEnF,UAAMC,uBAAuBF,aAAY,CAACG,SAAyBR,mBAAmBQ,IAAAA,GAAO;MAACR;KAAiB;AAE/G,UAAMS,UAAUJ,aAAY,MAAA;AAC1BK,MAAAA,WAAUb,YAAAA,QAAAA;;;;;;;;;AACV,aAAOA;IACT,GAAG;MAACA;KAAW;AAEf,QAAI,CAACA,YAAY;AACf,aAAO,gBAAAc,OAAA,cAACC,OAAAA,IAAAA;IACV;AAEA,WACE,gBAAAD,OAAA,cAAAA,OAAA,UAAA,MACE,gBAAAA,OAAA,cAACE,eAAAA;MACCpB;MACAqB,cAAcpB;MACdC;MACAC;MACAE;MACAW;MACAM,eAAed,UAAUe;MACzBhB,kBAAkBO;QAGnBR,gBAAgB,gBAAAY,OAAA,cAACM,YAAAA;MAAWC,KAAKd;MAAWP;MAAwBE;;;;;AAG3E;;;AFNA,IAAM,CAACoB,+BAA+BC,wBAAAA,IACpCC,cAA0C,wBAAA;AAe5C,IAAMC,qBAAqB,CAAC,EAC1BC,UACAC,IACAC,QACAC,kBACAC,kBACAC,UACAC,UACAC,YAAYC,iBACZC,oBACAC,aACA,GAAGC,MAAAA,MACqB;;;AACxB,UAAM,CAACC,YAAYC,aAAAA,IAAiBC,UAAAA;AAGpC,UAAM,CAACC,eAAeC,gBAAAA,IAAoBF,UAAyB,CAAA,CAAE;AACrE,UAAMG,iBAAiBC,SACrB,OAAO;MACLC,mBAAmB,CAACC,UAAAA;AAClBJ,yBAAiB,CAACK,SAAS;aAAIA;UAAMD;SAAM;MAC7C;MACAE,sBAAsB,CAAC,EAAEC,KAAI,MAAE;AAC7BP,yBAAiB,CAACK,SAASA,KAAKG,OAAO,CAAC,EAAED,MAAME,SAAQ,MAAOA,SAASC,QAAQH,KAAKG,GAAG,CAAA;MAC1F;IACF,IACA,CAAA,CAAE;AAIJ,UAAMC,eAAeC,iBAAiB;MAAEtB;IAAS,CAAA;AAGjD,UAAMuB,cAAcC,qBAAqB;MACvClB;MACAH;MACAC;IACF,CAAA;AACA,UAAM,EAAEqB,WAAWC,eAAe,GAAGC,UAAAA,IAAcC,cAAcL,WAAAA;AAGjE,UAAMM,iBAAiBC,cAAc;MACnCnC;MACAC;MACAC;MACAc;MACAb;MACAC;MACAC;IACF,CAAA;AAEA,UAAMC,aAAaW,SACjB,MAAM;MAACiB;MAAgBH;MAAexB;MAAiBgB,OAAOa,aAAAA,GAC9D;MAACF;MAAgBH;MAAexB;KAAgB;AAGlD,WACE,gBAAA8B,OAAA,cAAC1C,+BAAAA;MACCK;MACAW;MACAC;MACAN;MACAQ;MACAY;MACAY,aAAaN;MACb3B;MACC,GAAGK;OAEHX,QAAAA;;;;AAGP;AAEAD,mBAAmByC,cAAc;AAQjC,IAAMC,yBAAwB,CAAC9B,UAAAA;;;AAC7B,UAAM,EACJV,IACAW,YACAC,eACAP,UACAqB,cACApB,YACAgC,aAAa,EAAEG,WAAW,GAAGT,UAAAA,EAAW,IACtCpC,yBAAyB4C,uBAAsBD,WAAW;AAE9D,WACE,gBAAAF,OAAA,cAACK,oBAAAA;MAAmBC,MAAMhC;MAAYiC,QAAQH,UAAUI;MAAU,GAAGb;OACnE,gBAAAK,OAAA,cAACS,uBAAAA;MACE,GAAGpC;MACJV;MACAK;MACAqB;MACApB;MACAmB,KAAKb;;;;;AAIb;AAEA4B,uBAAsBD,cAAc;AAWpC,IAAMQ,yBAAwB,CAACrC,UAAAA;;;AAC7B,UAAM,EAAEgB,cAAc,GAAGsB,UAAAA,IAAcpD,yBAAyBmD,uBAAsBR,WAAW;AAEjG,WAAO,gBAAAF,OAAA,cAACY,uBAAAA;MAAwB,GAAGvC;MAAQ,GAAGsC;MAAWE,OAAOxB;;;;;AAClE;AAEAqB,uBAAsBR,cAAc;AAQpC,IAAMY,uBAAuB,CAACC,WAAAA;;;AAC5B,UAAM,EAAEtC,cAAa,IAAKlB,yBAAyBuD,qBAAqBZ,WAAW;AAEnF,WACE,gBAAAF,OAAA,cAAAA,OAAA,UAAA,MACGvB,cAAcuC,IAAI,CAAC,EAAE/B,MAAMgC,GAAE,MAC5B,gBAAAjB,OAAA,cAACkB,cAAAA;MAAaC,KAAKlC,KAAKG;MAAKH;MAAYgC;;;;;AAIjD;AAEAH,qBAAqBZ,cAAc;AAEnC,IAAMgB,eAAe,CAAC,EAAED,IAAIhC,KAAI,MAAgB;;;AAC9C,UAAMmC,SAASC,UAAAA;AACf,UAAMC,MAAMC,IAAIC,MAAMvC,KAAKG,GAAG;AAC9B,UAAMqC,UAAUL,OAAOM,MAAMC,QAAQL,GAAAA,EAAKM;AAC1C,UAAMC,OAAOjD,SAAQ,OAAO;MAAE6C;IAAQ,IAAI;MAACA;KAAQ;AAEnD,WAAOK,gBAAAA,cAAa,gBAAA9B,OAAA,cAAC+B,SAAAA;MAAQC,MAAK;MAAqBH;MAAYI,OAAO;QAAOhB,EAAAA;;;;AACnF;AAMO,IAAMiB,iBAAiB;EAC5BC,MAAM1E;EACN2E,SAASjC;EACTkC,SAAS3B;EACT4B,QAAQxB;AACV;",
|
|
6
|
+
"names": ["Option", "useCallback", "useMemo", "Capabilities", "usePluginManager", "Filter", "Obj", "Query", "Type", "EntityKind", "SystemTypeAnnotation", "getTypeAnnotation", "toLocalizedString", "useTranslation", "insertAtCursor", "insertAtLineStart", "useLinkQuery", "space", "t", "useTranslation", "manager", "usePluginManager", "resolve", "useCallback", "typename", "context", "getCapabilities", "Capabilities", "Metadata", "find", "id", "metadata", "filter", "useMemo", "Filter", "or", "db", "schemaRegistry", "query", "location", "runSync", "schema", "getTypeAnnotation", "kind", "EntityKind", "Relation", "SystemTypeAnnotation", "get", "pipe", "getOrElse", "map", "Type", "getTypename", "handleLinkQuery", "name", "startsWith", "slice", "toLowerCase", "results", "Query", "select", "run", "getLabel", "object", "label", "Obj", "type", "ns", "default", "items", "toLocalizedString", "includes", "icon", "onSelect", "view", "head", "link", "getDXN", "insertAtLineStart", "insertAtCursor", "useCallback", "useMemo", "useRef", "Domino", "toLocalizedString", "useTranslation", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "useEditorMenuOptions", "editorView", "slashCommandGroups", "onLinkQuery", "t", "useTranslation", "meta", "id", "getMenu", "useCallback", "text", "trigger", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "item", "toLocalizedString", "label", "toLowerCase", "includes", "viewRef", "useRef", "useMemo", "placeholder", "delay", "content", "Domino", "of", "children", "map", "classNames", "build", "React", "useMemo", "createRoot", "LayoutAction", "createIntent", "useIntentDispatcher", "debounceAndThrottle", "Obj", "createDocAccessor", "invariant", "getSpace", "useIdentity", "Icon", "ThemeProvider", "Cursor", "EditorView", "InputModeExtensions", "createDataExtensions", "decorateMarkdown", "documentId", "folding", "formattingKeymap", "linkTooltip", "listener", "preview", "replacer", "selectionState", "typewriter", "defaultTx", "Text", "isTruthy", "useExtensions", "id", "object", "settings", "selectionManager", "viewMode", "editorStateStore", "previewOptions", "dispatchPromise", "dispatch", "useIntentDispatcher", "identity", "useIdentity", "space", "getSpace", "target", "Obj", "instanceOf", "Markdown", "Document", "content", "Text", "baseExtensions", "useMemo", "createBaseExtensions", "debug", "editorInputMode", "folding", "numberedHeadings", "typewriter", "createDataExtensions", "text", "createDocAccessor", "messenger", "listener", "onChange", "setFallbackName", "selectionState", "filter", "isTruthy", "extensions", "selectionChange", "InputModeExtensions", "push", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "from", "undefined", "renderLinkButton", "createLinkRenderer", "createIntent", "LayoutAction", "Open", "part", "subject", "options", "pivotId", "isObject", "getDXN", "toString", "linkTooltip", "renderLinkTooltip", "preview", "replacer", "items", "split", "EditorView", "updateListener", "of", "debounceAndThrottle", "update", "selectionSet", "state", "facet", "documentId", "cursorConverter", "Cursor", "converter", "selection", "ranges", "map", "range", "toCursor", "to", "updateMultiRange", "style", "hover", "icon", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "onClick", "qualifiedId", "at", "invariant", "href", "rel", "renderRoot", "a", "className", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "EditorView", "Schema", "useMemo", "LayoutAction", "createResolver", "useIntentResolver", "invariant", "Cursor", "setSelection", "useSelectCurrentThread", "editorView", "documentId", "scrollIntoViewResolver", "useMemo", "createResolver", "intent", "LayoutAction", "UpdateLayout", "position", "filter", "data", "is", "ScrollIntoView", "fields", "input", "subject", "options", "cursor", "resolve", "invariant", "range", "Cursor", "getRangeFromCursor", "state", "selection", "main", "from", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "dispatch", "useIntentResolver", "meta", "id", "createContext", "React", "useMemo", "useState", "createPortal", "Surface", "DXN", "useClient", "EditorMenuProvider", "useEditorMenu", "useEditorToolbar", "isNonNullable", "React", "forwardRef", "useEffect", "useImperativeHandle", "useMemo", "useDynamicRef", "useThemeContext", "useTranslation", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorSlots", "formattingListener", "processEditorPayload", "stackItemContentEditorClassNames", "useTextEditor", "mx", "isTruthy", "MarkdownEditorContent", "forwardRef", "classNames", "id", "role", "viewMode", "initialValue", "editorStateStore", "toolbarState", "extensions", "scrollPastEnd", "slots", "editorSlots", "onFileUpload", "forwardedRef", "t", "useTranslation", "meta", "themeMode", "useThemeContext", "toolbarStateRef", "useDynamicRef", "scrollTo", "selection", "useMemo", "getState", "parentRef", "view", "editorView", "focusAttributes", "useTextEditor", "selectionEnd", "createBasicExtensions", "readOnly", "placeholder", "search", "createThemeExtensions", "syntaxHighlighting", "createMarkdownExtensions", "formattingListener", "current", "dropFile", "onDrop", "files", "file", "info", "undefined", "processEditorPayload", "type", "data", "url", "filter", "isTruthy", "useImperativeHandle", "useSelectCurrentThread", "useTest", "React", "div", "ref", "data-testid", "className", "mx", "stackItemContentEditorClassNames", "data-popover-collision-boundary", "useEffect", "composer", "window", "React", "useCallback", "useState", "invariant", "EditorToolbar", "React", "forwardRef", "useEffect", "useImperativeHandle", "createPortal", "useDropzone", "addLink", "IMAGE_FILES", "FileUpload", "forwardRef", "editorView", "onFileUpload", "forwardedRef", "acceptedFiles", "open", "inputRef", "useDropzone", "disabled", "multiple", "noDrag", "accept", "useImperativeHandle", "useEffect", "length", "requestAnimationFrame", "f", "file", "File", "name", "type", "lastModified", "info", "addLink", "url", "image", "React", "createPortal", "input", "ref", "document", "body", "MarkdownEditorToolbar", "classNames", "id", "role", "state", "editorView", "customActions", "onFileUpload", "onViewModeChange", "upload", "setUpload", "useState", "uploadRef", "useCallback", "next", "handleViewModeChange", "mode", "getView", "invariant", "React", "div", "EditorToolbar", "attendableId", "onImageUpload", "undefined", "FileUpload", "ref", "MarkdownEditorContextProvider", "useMarkdownEditorContext", "createContext", "MarkdownEditorRoot", "children", "id", "object", "editorStateStore", "selectionManager", "settings", "viewMode", "extensions", "extensionsParam", "slashCommandGroups", "onLinkQuery", "props", "editorView", "setEditorView", "useState", "previewBlocks", "setPreviewBlocks", "previewOptions", "useMemo", "addBlockContainer", "block", "prev", "removeBlockContainer", "link", "filter", "prevLink", "ref", "toolbarState", "useEditorToolbar", "menuOptions", "useEditorMenuOptions", "extension", "menuExtension", "menuProps", "useEditorMenu", "coreExtensions", "useExtensions", "isNonNullable", "React", "popoverMenu", "displayName", "MarkdownEditorContent", "groupsRef", "EditorMenuProvider", "view", "groups", "current", "NaturalMarkdownEditorContent", "MarkdownEditorToolbar", "rootProps", "NaturalMarkdownToolbar", "state", "MarkdownEditorBlocks", "_props", "map", "el", "PreviewBlock", "key", "client", "useClient", "dxn", "DXN", "parse", "subject", "graph", "makeRef", "target", "data", "createPortal", "Surface", "role", "limit", "MarkdownEditor", "Root", "Content", "Toolbar", "Blocks"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,107 @@
|
|
|
1
|
+
import {
|
|
2
|
+
MarkdownCapabilities
|
|
3
|
+
} from "./chunk-IBCHVMZW.mjs";
|
|
4
|
+
import {
|
|
5
|
+
MarkdownEditor,
|
|
6
|
+
useLinkQuery
|
|
7
|
+
} from "./chunk-56SUMOIZ.mjs";
|
|
8
|
+
import {
|
|
9
|
+
Markdown_exports
|
|
10
|
+
} from "./chunk-CN35HEBX.mjs";
|
|
11
|
+
|
|
12
|
+
// src/components/MarkdownContainer.tsx
|
|
13
|
+
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
14
|
+
import { Atom } from "@effect-atom/atom-react";
|
|
15
|
+
import React, { forwardRef, useMemo } from "react";
|
|
16
|
+
import { Capabilities } from "@dxos/app-framework";
|
|
17
|
+
import { useAppGraph, useCapabilities } from "@dxos/app-framework/react";
|
|
18
|
+
import { Obj } from "@dxos/echo";
|
|
19
|
+
import { getSpace } from "@dxos/react-client/echo";
|
|
20
|
+
import { StackItem } from "@dxos/react-ui-stack";
|
|
21
|
+
import { Text } from "@dxos/schema";
|
|
22
|
+
var MarkdownContainer = /* @__PURE__ */ forwardRef(({ id, role, object, settings, extensionProviders, ...props }, forwardedRef) => {
|
|
23
|
+
var _effect = _useSignals();
|
|
24
|
+
try {
|
|
25
|
+
const space = getSpace(object);
|
|
26
|
+
const isDocument = Obj.instanceOf(Markdown_exports.Document, object);
|
|
27
|
+
const isText = Obj.instanceOf(Text.Text, object);
|
|
28
|
+
const attendableId = isDocument ? Obj.getDXN(object).toString() : void 0;
|
|
29
|
+
const otherExtensionProviders = useCapabilities(MarkdownCapabilities.Extensions);
|
|
30
|
+
const extensions = useMemo(() => {
|
|
31
|
+
if (!Obj.instanceOf(Markdown_exports.Document, object)) {
|
|
32
|
+
return [];
|
|
33
|
+
}
|
|
34
|
+
return [
|
|
35
|
+
...otherExtensionProviders ?? [],
|
|
36
|
+
...extensionProviders ?? []
|
|
37
|
+
].flat().reduce((acc, provider) => {
|
|
38
|
+
const extension = typeof provider === "function" ? provider({
|
|
39
|
+
document: object
|
|
40
|
+
}) : provider;
|
|
41
|
+
if (extension) {
|
|
42
|
+
acc.push(extension);
|
|
43
|
+
}
|
|
44
|
+
return acc;
|
|
45
|
+
}, []);
|
|
46
|
+
}, [
|
|
47
|
+
extensionProviders,
|
|
48
|
+
otherExtensionProviders,
|
|
49
|
+
object
|
|
50
|
+
]);
|
|
51
|
+
const { graph } = useAppGraph();
|
|
52
|
+
const customActions = useMemo(() => {
|
|
53
|
+
return Atom.make((get) => {
|
|
54
|
+
const actions = get(graph.actions(id));
|
|
55
|
+
const nodes = actions.filter((action) => action.properties.disposition === "toolbar");
|
|
56
|
+
const edges = nodes.map((node) => ({
|
|
57
|
+
source: "root",
|
|
58
|
+
target: node.id
|
|
59
|
+
}));
|
|
60
|
+
return {
|
|
61
|
+
nodes,
|
|
62
|
+
edges
|
|
63
|
+
};
|
|
64
|
+
});
|
|
65
|
+
}, [
|
|
66
|
+
graph
|
|
67
|
+
]);
|
|
68
|
+
const [upload] = useCapabilities(Capabilities.FileUploader);
|
|
69
|
+
const handleFileUpload = useMemo(() => {
|
|
70
|
+
if (!space || !upload) {
|
|
71
|
+
return void 0;
|
|
72
|
+
}
|
|
73
|
+
return async (file) => upload(space, file);
|
|
74
|
+
}, [
|
|
75
|
+
space,
|
|
76
|
+
upload
|
|
77
|
+
]);
|
|
78
|
+
const handleLinkQuery = useLinkQuery(space);
|
|
79
|
+
return /* @__PURE__ */ React.createElement(StackItem.Content, {
|
|
80
|
+
toolbar: settings.toolbar,
|
|
81
|
+
ref: forwardedRef
|
|
82
|
+
}, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
|
|
83
|
+
id: attendableId ?? id,
|
|
84
|
+
object,
|
|
85
|
+
extensions,
|
|
86
|
+
onFileUpload: handleFileUpload,
|
|
87
|
+
onLinkQuery: handleLinkQuery,
|
|
88
|
+
...props
|
|
89
|
+
}, settings.toolbar && /* @__PURE__ */ React.createElement(MarkdownEditor.Toolbar, {
|
|
90
|
+
id: attendableId ?? id,
|
|
91
|
+
role,
|
|
92
|
+
customActions
|
|
93
|
+
}), /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
|
|
94
|
+
initialValue: isDocument ? object.content?.target?.content : isText ? object.content : object.text,
|
|
95
|
+
scrollPastEnd: role === "article"
|
|
96
|
+
}), /* @__PURE__ */ React.createElement(MarkdownEditor.Blocks, null)));
|
|
97
|
+
} finally {
|
|
98
|
+
_effect.f();
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
var MarkdownContainer_default = MarkdownContainer;
|
|
102
|
+
|
|
103
|
+
export {
|
|
104
|
+
MarkdownContainer,
|
|
105
|
+
MarkdownContainer_default
|
|
106
|
+
};
|
|
107
|
+
//# sourceMappingURL=chunk-6OMOMVO7.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownContainer.tsx"],
|
|
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 { Capabilities } from '@dxos/app-framework';\nimport { useAppGraph, useCapabilities } from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { Text } from '@dxos/schema';\n\nimport { MarkdownCapabilities } from '../capabilities';\nimport { type DocumentType, useLinkQuery } from '../hooks';\nimport { Markdown, type MarkdownPluginState } from '../types';\n\nimport { MarkdownEditor, type MarkdownEditorContentProps, type MarkdownEditorRootProps } from './MarkdownEditor';\n\nexport type MarkdownContainerProps = {\n role?: string;\n object: DocumentType;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n} & (Pick<MarkdownEditorRootProps, 'id' | 'viewMode' | 'onViewModeChange'> &\n Pick<MarkdownEditorContentProps, 'editorStateStore'> &\n Pick<MarkdownPluginState, 'extensionProviders'>);\n\nexport const MarkdownContainer = forwardRef<HTMLDivElement, MarkdownContainerProps>(\n ({ id, role, object, settings, extensionProviders, ...props }, forwardedRef) => {\n const space = getSpace(object);\n const isDocument = Obj.instanceOf(Markdown.Document, object);\n const isText = Obj.instanceOf(Text.Text, object);\n const attendableId = isDocument ? Obj.getDXN(object).toString() : undefined;\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)) {\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 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 }));\n return { nodes, edges };\n });\n }, [graph]);\n\n // File upload.\n const [upload] = useCapabilities(Capabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (!space || !upload) {\n return undefined;\n }\n\n return async (file: File) => upload(space, file);\n }, [space, upload]);\n\n // Query for @ refs.\n const handleLinkQuery = useLinkQuery(space);\n\n return (\n <StackItem.Content toolbar={settings.toolbar} ref={forwardedRef}>\n <MarkdownEditor.Root\n id={attendableId ?? id}\n object={object}\n extensions={extensions}\n onFileUpload={handleFileUpload}\n onLinkQuery={handleLinkQuery}\n {...props}\n >\n {settings.toolbar && (\n <MarkdownEditor.Toolbar id={attendableId ?? id} role={role} customActions={customActions} />\n )}\n <MarkdownEditor.Content\n initialValue={isDocument ? object.content?.target?.content : isText ? object.content : object.text}\n scrollPastEnd={role === 'article'}\n />\n <MarkdownEditor.Blocks />\n </MarkdownEditor.Root>\n </StackItem.Content>\n );\n },\n);\n\nexport default MarkdownContainer;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;AAKA,SAASA,YAAY;AACrB,OAAOC,SAASC,YAAYC,eAAe;AAE3C,SAASC,oBAAoB;AAC7B,SAASC,aAAaC,uBAAuB;AAC7C,SAASC,WAAW;AACpB,SAASC,gBAAgB;AAEzB,SAASC,iBAAiB;AAC1B,SAASC,YAAY;AAiBd,IAAMC,oBAAoBC,2BAC/B,CAAC,EAAEC,IAAIC,MAAMC,QAAQC,UAAUC,oBAAoB,GAAGC,MAAAA,GAASC,iBAAAA;;;AAC7D,UAAMC,QAAQC,SAASN,MAAAA;AACvB,UAAMO,aAAaC,IAAIC,WAAWC,iBAASC,UAAUX,MAAAA;AACrD,UAAMY,SAASJ,IAAIC,WAAWI,KAAKA,MAAMb,MAAAA;AACzC,UAAMc,eAAeP,aAAaC,IAAIO,OAAOf,MAAAA,EAAQgB,SAAQ,IAAKC;AAIlE,UAAMC,0BAA0BC,gBAAgBC,qBAAqBC,UAAU;AAC/E,UAAMC,aAAaC,QAAqB,MAAA;AACtC,UAAI,CAACf,IAAIC,WAAWC,iBAASC,UAAUX,MAAAA,GAAS;AAC9C,eAAO,CAAA;MACT;AAEA,aAAO;WAAKkB,2BAA2B,CAAA;WAAShB,sBAAsB,CAAA;QACnEsB,KAAI,EACJC,OAAO,CAACC,KAAkBC,aAAAA;AACzB,cAAMC,YACJ,OAAOD,aAAa,aAAaA,SAAS;UAAEE,UAAU7B;QAA4B,CAAA,IAAK2B;AACzF,YAAIC,WAAW;AACbF,cAAII,KAAKF,SAAAA;QACX;AAEA,eAAOF;MACT,GAAG,CAAA,CAAE;IACT,GAAG;MAACxB;MAAoBgB;MAAyBlB;KAAO;AAGxD,UAAM,EAAE+B,MAAK,IAAKC,YAAAA;AAClB,UAAMC,gBAAgBV,QAAQ,MAAA;AAC5B,aAAOW,KAAKC,KAAK,CAACC,QAAAA;AAChB,cAAMC,UAAUD,IAAIL,MAAMM,QAAQvC,EAAAA,CAAAA;AAClC,cAAMwC,QAAQD,QAAQE,OAAO,CAACC,WAAWA,OAAOC,WAAWC,gBAAgB,SAAA;AAC3E,cAAMC,QAAQL,MAAMM,IAAI,CAACC,UAAU;UAAEC,QAAQ;UAAQC,QAAQF,KAAK/C;QAAG,EAAA;AACrE,eAAO;UAAEwC;UAAOK;QAAM;MACxB,CAAA;IACF,GAAG;MAACZ;KAAM;AAGV,UAAM,CAACiB,MAAAA,IAAU7B,gBAAgB8B,aAAaC,YAAY;AAC1D,UAAMC,mBAAmB5B,QAAQ,MAAA;AAC/B,UAAI,CAAClB,SAAS,CAAC2C,QAAQ;AACrB,eAAO/B;MACT;AAEA,aAAO,OAAOmC,SAAeJ,OAAO3C,OAAO+C,IAAAA;IAC7C,GAAG;MAAC/C;MAAO2C;KAAO;AAGlB,UAAMK,kBAAkBC,aAAajD,KAAAA;AAErC,WACE,sBAAA,cAACkD,UAAUC,SAAO;MAACC,SAASxD,SAASwD;MAASC,KAAKtD;OACjD,sBAAA,cAACuD,eAAeC,MAAI;MAClB9D,IAAIgB,gBAAgBhB;MACpBE;MACAsB;MACAuC,cAAcV;MACdW,aAAaT;MACZ,GAAGlD;OAEHF,SAASwD,WACR,sBAAA,cAACE,eAAeI,SAAO;MAACjE,IAAIgB,gBAAgBhB;MAAIC;MAAYkC;QAE9D,sBAAA,cAAC0B,eAAeH,SAAO;MACrBQ,cAAczD,aAAaP,OAAOiE,SAASlB,QAAQkB,UAAUrD,SAASZ,OAAOiE,UAAUjE,OAAOkE;MAC9FC,eAAepE,SAAS;QAE1B,sBAAA,cAAC4D,eAAeS,QAAM,IAAA,CAAA,CAAA;;;;AAI9B,CAAA;AAGF,IAAA,4BAAexE;",
|
|
6
|
+
"names": ["Atom", "React", "forwardRef", "useMemo", "Capabilities", "useAppGraph", "useCapabilities", "Obj", "getSpace", "StackItem", "Text", "MarkdownContainer", "forwardRef", "id", "role", "object", "settings", "extensionProviders", "props", "forwardedRef", "space", "getSpace", "isDocument", "Obj", "instanceOf", "Markdown", "Document", "isText", "Text", "attendableId", "getDXN", "toString", "undefined", "otherExtensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "extensions", "useMemo", "flat", "reduce", "acc", "provider", "extension", "document", "push", "graph", "useAppGraph", "customActions", "Atom", "make", "get", "actions", "nodes", "filter", "action", "properties", "disposition", "edges", "map", "node", "source", "target", "upload", "Capabilities", "FileUploader", "handleFileUpload", "file", "handleLinkQuery", "useLinkQuery", "StackItem", "Content", "toolbar", "ref", "MarkdownEditor", "Root", "onFileUpload", "onLinkQuery", "Toolbar", "initialValue", "content", "text", "scrollPastEnd", "Blocks"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
var __defProp = Object.defineProperty;
|
|
2
|
+
var __export = (target, all) => {
|
|
3
|
+
for (var name in all)
|
|
4
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
5
|
+
};
|
|
6
|
+
|
|
7
|
+
// src/meta.ts
|
|
8
|
+
import { trim } from "@dxos/util";
|
|
9
|
+
var meta = {
|
|
10
|
+
id: "dxos.org/plugin/markdown",
|
|
11
|
+
name: "Markdown",
|
|
12
|
+
description: trim`
|
|
13
|
+
Full-featured collaborative markdown editor with real-time editing, inline comments, and rich formatting.
|
|
14
|
+
Supports AI-powered editing assistance and seamlessly integrates with other workspace objects.
|
|
15
|
+
`,
|
|
16
|
+
icon: "ph--text-aa--regular",
|
|
17
|
+
iconHue: "indigo",
|
|
18
|
+
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-markdown",
|
|
19
|
+
screenshots: [
|
|
20
|
+
"https://dxos.network/plugin-details-markdown-dark.png"
|
|
21
|
+
]
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
export {
|
|
25
|
+
__export,
|
|
26
|
+
meta
|
|
27
|
+
};
|
|
28
|
+
//# sourceMappingURL=chunk-BQTYJOFB.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/meta.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/markdown',\n name: 'Markdown',\n description: trim`\n Full-featured collaborative markdown editor with real-time editing, inline comments, and rich formatting.\n Supports AI-powered editing assistance and seamlessly integrates with other workspace objects.\n `,\n icon: 'ph--text-aa--regular',\n iconHue: 'indigo',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-markdown',\n screenshots: ['https://dxos.network/plugin-details-markdown-dark.png'],\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;;AAKA,SAASA,YAAY;AAEd,IAAMC,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aAAaC;;;;EAIbC,MAAM;EACNC,SAAS;EACTC,QAAQ;EACRC,aAAa;IAAC;;AAChB;",
|
|
6
|
+
"names": ["trim", "meta", "id", "name", "description", "trim", "icon", "iconHue", "source", "screenshots"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import {
|
|
2
|
+
__export,
|
|
3
|
+
meta
|
|
4
|
+
} from "./chunk-BQTYJOFB.mjs";
|
|
5
|
+
|
|
6
|
+
// src/types/MarkdownAction.ts
|
|
7
|
+
var MarkdownAction_exports = {};
|
|
8
|
+
__export(MarkdownAction_exports, {
|
|
9
|
+
Create: () => Create,
|
|
10
|
+
SetViewMode: () => SetViewMode
|
|
11
|
+
});
|
|
12
|
+
import * as Schema2 from "effect/Schema";
|
|
13
|
+
import { EditorViewMode as EditorViewMode2 } from "@dxos/react-ui-editor/types";
|
|
14
|
+
|
|
15
|
+
// src/types/Markdown.ts
|
|
16
|
+
var Markdown_exports = {};
|
|
17
|
+
__export(Markdown_exports, {
|
|
18
|
+
Document: () => Document,
|
|
19
|
+
Settings: () => Settings,
|
|
20
|
+
make: () => make
|
|
21
|
+
});
|
|
22
|
+
import * as Schema from "effect/Schema";
|
|
23
|
+
import { Obj, Ref, Type } from "@dxos/echo";
|
|
24
|
+
import { DescriptionAnnotation, FormInputAnnotation, LabelAnnotation } from "@dxos/echo/internal";
|
|
25
|
+
import { EditorInputMode, EditorViewMode } from "@dxos/react-ui-editor/types";
|
|
26
|
+
import { Text } from "@dxos/schema";
|
|
27
|
+
var Document = Schema.Struct({
|
|
28
|
+
name: Schema.optional(Schema.String),
|
|
29
|
+
description: Schema.optional(Schema.String),
|
|
30
|
+
fallbackName: Schema.String.pipe(FormInputAnnotation.set(false), Schema.optional),
|
|
31
|
+
content: Type.Ref(Text.Text).pipe(FormInputAnnotation.set(false))
|
|
32
|
+
}).pipe(Type.Obj({
|
|
33
|
+
typename: "dxos.org/type/Document",
|
|
34
|
+
version: "0.1.0"
|
|
35
|
+
}), LabelAnnotation.set([
|
|
36
|
+
"name",
|
|
37
|
+
"fallbackName"
|
|
38
|
+
]), DescriptionAnnotation.set("description"));
|
|
39
|
+
var make = ({ content = "", ...props } = {}) => Obj.make(Document, {
|
|
40
|
+
...props,
|
|
41
|
+
content: Ref.make(Text.make(content))
|
|
42
|
+
});
|
|
43
|
+
var Settings = Schema.mutable(Schema.Struct({
|
|
44
|
+
defaultViewMode: EditorViewMode,
|
|
45
|
+
editorInputMode: Schema.optional(EditorInputMode),
|
|
46
|
+
experimental: Schema.optional(Schema.Boolean),
|
|
47
|
+
debug: Schema.optional(Schema.Boolean),
|
|
48
|
+
toolbar: Schema.optional(Schema.Boolean),
|
|
49
|
+
typewriter: Schema.optional(Schema.String),
|
|
50
|
+
// TODO(burdon): Per document settings.
|
|
51
|
+
numberedHeadings: Schema.optional(Schema.Boolean),
|
|
52
|
+
folding: Schema.optional(Schema.Boolean)
|
|
53
|
+
}));
|
|
54
|
+
|
|
55
|
+
// src/types/MarkdownAction.ts
|
|
56
|
+
var Create = class extends Schema2.TaggedClass()(`${meta.id}/action/create`, {
|
|
57
|
+
input: Schema2.Struct({
|
|
58
|
+
name: Schema2.optional(Schema2.String),
|
|
59
|
+
content: Schema2.optional(Schema2.String)
|
|
60
|
+
}),
|
|
61
|
+
output: Schema2.Struct({
|
|
62
|
+
object: Document
|
|
63
|
+
})
|
|
64
|
+
}) {
|
|
65
|
+
};
|
|
66
|
+
var SetViewMode = class extends Schema2.TaggedClass()(`${meta.id}/action/set-view-mode`, {
|
|
67
|
+
input: Schema2.Struct({
|
|
68
|
+
id: Schema2.String,
|
|
69
|
+
viewMode: EditorViewMode2
|
|
70
|
+
}),
|
|
71
|
+
output: Schema2.Void
|
|
72
|
+
}) {
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
export {
|
|
76
|
+
Markdown_exports,
|
|
77
|
+
MarkdownAction_exports
|
|
78
|
+
};
|
|
79
|
+
//# sourceMappingURL=chunk-CN35HEBX.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/types/MarkdownAction.ts", "../../../src/types/Markdown.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\n\nimport { EditorViewMode } from '@dxos/react-ui-editor/types';\n\nimport { meta } from '../meta';\n\nimport { Document } from './Markdown';\n\nexport class Create extends Schema.TaggedClass<Create>()(`${meta.id}/action/create`, {\n input: Schema.Struct({\n name: Schema.optional(Schema.String),\n content: Schema.optional(Schema.String),\n }),\n output: Schema.Struct({\n object: Document,\n }),\n}) {}\n\nexport class SetViewMode extends Schema.TaggedClass<SetViewMode>()(`${meta.id}/action/set-view-mode`, {\n input: Schema.Struct({\n id: Schema.String,\n viewMode: EditorViewMode,\n }),\n output: Schema.Void,\n}) {}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\n\nimport { Obj, Ref, Type } from '@dxos/echo';\nimport { DescriptionAnnotation, FormInputAnnotation, LabelAnnotation } from '@dxos/echo/internal';\nimport { EditorInputMode, EditorViewMode } from '@dxos/react-ui-editor/types';\nimport { Text } from '@dxos/schema';\n\n/**\n * Document Item type.\n */\nexport const Document = Schema.Struct({\n name: Schema.optional(Schema.String),\n description: Schema.optional(Schema.String),\n fallbackName: Schema.String.pipe(FormInputAnnotation.set(false), Schema.optional),\n content: Type.Ref(Text.Text).pipe(FormInputAnnotation.set(false)),\n}).pipe(\n Type.Obj({\n typename: 'dxos.org/type/Document',\n version: '0.1.0',\n }),\n LabelAnnotation.set(['name', 'fallbackName']),\n DescriptionAnnotation.set('description'),\n);\n\nexport type Document = Schema.Schema.Type<typeof Document>;\n\n/**\n * Document factory.\n */\nexport const make = ({\n content = '',\n ...props\n}: Partial<{ name: string; fallbackName: string; content: string }> = {}) =>\n Obj.make(Document, { ...props, content: Ref.make(Text.make(content)) });\n\n/**\n * Plugin settings.\n */\nexport const Settings = Schema.mutable(\n Schema.Struct({\n defaultViewMode: EditorViewMode,\n editorInputMode: Schema.optional(EditorInputMode),\n experimental: Schema.optional(Schema.Boolean),\n debug: Schema.optional(Schema.Boolean),\n toolbar: Schema.optional(Schema.Boolean),\n typewriter: Schema.optional(Schema.String),\n // TODO(burdon): Per document settings.\n numberedHeadings: Schema.optional(Schema.Boolean),\n folding: Schema.optional(Schema.Boolean),\n }),\n);\n\nexport interface Settings extends Schema.Schema.Type<typeof Settings> {}\n"],
|
|
5
|
+
"mappings": ";;;;;;AAAA;;;;;AAIA,YAAYA,aAAY;AAExB,SAASC,kBAAAA,uBAAsB;;;ACN/B;;;;;;AAIA,YAAYC,YAAY;AAExB,SAASC,KAAKC,KAAKC,YAAY;AAC/B,SAASC,uBAAuBC,qBAAqBC,uBAAuB;AAC5E,SAASC,iBAAiBC,sBAAsB;AAChD,SAASC,YAAY;AAKd,IAAMC,WAAkBC,cAAO;EACpCC,MAAaC,gBAAgBC,aAAM;EACnCC,aAAoBF,gBAAgBC,aAAM;EAC1CE,cAAqBF,cAAOG,KAAKC,oBAAoBC,IAAI,KAAA,GAAeN,eAAQ;EAChFO,SAASC,KAAKC,IAAIC,KAAKA,IAAI,EAAEN,KAAKC,oBAAoBC,IAAI,KAAA,CAAA;AAC5D,CAAA,EAAGF,KACDI,KAAKG,IAAI;EACPC,UAAU;EACVC,SAAS;AACX,CAAA,GACAC,gBAAgBR,IAAI;EAAC;EAAQ;CAAe,GAC5CS,sBAAsBT,IAAI,aAAA,CAAA;AAQrB,IAAMU,OAAO,CAAC,EACnBT,UAAU,IACV,GAAGU,MAAAA,IACiE,CAAC,MACrEN,IAAIK,KAAKnB,UAAU;EAAE,GAAGoB;EAAOV,SAASE,IAAIO,KAAKN,KAAKM,KAAKT,OAAAA,CAAAA;AAAU,CAAA;AAKhE,IAAMW,WAAkBC,eACtBrB,cAAO;EACZsB,iBAAiBC;EACjBC,iBAAwBtB,gBAASuB,eAAAA;EACjCC,cAAqBxB,gBAAgByB,cAAO;EAC5CC,OAAc1B,gBAAgByB,cAAO;EACrCE,SAAgB3B,gBAAgByB,cAAO;EACvCG,YAAmB5B,gBAAgBC,aAAM;;EAEzC4B,kBAAyB7B,gBAAgByB,cAAO;EAChDK,SAAgB9B,gBAAgByB,cAAO;AACzC,CAAA,CAAA;;;ADzCK,IAAMM,SAAN,cAA4BC,oBAAW,EAAW,GAAGC,KAAKC,EAAE,kBAAkB;EACnFC,OAAcC,eAAO;IACnBC,MAAaC,iBAAgBC,cAAM;IACnCC,SAAgBF,iBAAgBC,cAAM;EACxC,CAAA;EACAE,QAAeL,eAAO;IACpBM,QAAQC;EACV,CAAA;AACF,CAAA,EAAA;AAAI;AAEG,IAAMC,cAAN,cAAiCZ,oBAAW,EAAgB,GAAGC,KAAKC,EAAE,yBAAyB;EACpGC,OAAcC,eAAO;IACnBF,IAAWK;IACXM,UAAUC;EACZ,CAAA;EACAL,QAAeM;AACjB,CAAA,EAAA;AAAI;",
|
|
6
|
+
"names": ["Schema", "EditorViewMode", "Schema", "Obj", "Ref", "Type", "DescriptionAnnotation", "FormInputAnnotation", "LabelAnnotation", "EditorInputMode", "EditorViewMode", "Text", "Document", "Struct", "name", "optional", "String", "description", "fallbackName", "pipe", "FormInputAnnotation", "set", "content", "Type", "Ref", "Text", "Obj", "typename", "version", "LabelAnnotation", "DescriptionAnnotation", "make", "props", "Settings", "mutable", "defaultViewMode", "EditorViewMode", "editorInputMode", "EditorInputMode", "experimental", "Boolean", "debug", "toolbar", "typewriter", "numberedHeadings", "folding", "Create", "TaggedClass", "meta", "id", "input", "Struct", "name", "optional", "String", "content", "output", "object", "Document", "SetViewMode", "viewMode", "EditorViewMode", "Void"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import {
|
|
2
|
+
meta
|
|
3
|
+
} from "./chunk-BQTYJOFB.mjs";
|
|
4
|
+
|
|
5
|
+
// src/capabilities/capabilities.ts
|
|
6
|
+
import { defineCapability } from "@dxos/app-framework";
|
|
7
|
+
(function(MarkdownCapabilities2) {
|
|
8
|
+
MarkdownCapabilities2.State = defineCapability(`${meta.id}/capability/state`);
|
|
9
|
+
MarkdownCapabilities2.Extensions = defineCapability(`${meta.id}/capability/extensions`);
|
|
10
|
+
})(MarkdownCapabilities || (MarkdownCapabilities = {}));
|
|
11
|
+
var MarkdownCapabilities;
|
|
12
|
+
|
|
13
|
+
export {
|
|
14
|
+
MarkdownCapabilities
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=chunk-IBCHVMZW.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/capabilities.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { defineCapability } from '@dxos/app-framework';\nimport { type EditorStateStore, type EditorViewMode } from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\nimport { type MarkdownExtensionProvider, type MarkdownPluginState } from '../types';\n\nexport namespace MarkdownCapabilities {\n export const State = defineCapability<{\n state: MarkdownPluginState;\n editorState: EditorStateStore;\n getViewMode: (id: string) => EditorViewMode;\n // TODO(burdon): Event object.\n setViewMode: (id: string, viewMode: EditorViewMode) => void;\n }>(`${meta.id}/capability/state`);\n\n // TODO(burdon): Move to ./types (external API)?\n export const Extensions = defineCapability<MarkdownExtensionProvider[]>(`${meta.id}/capability/extensions`);\n}\n"],
|
|
5
|
+
"mappings": ";;;;;AAIA,SAASA,wBAAwB;UAMhBC,uBAAAA;wBACFC,QAAQC,iBAMlB,GAAGC,KAAKC,EAAE,mBAAmB;wBAGnBC,aAAaH,iBAA8C,GAAGC,KAAKC,EAAE,wBAAwB;AAC5G,GAXiBJ,yBAAAA,uBAAAA,CAAAA,EAAAA;;",
|
|
6
|
+
"names": ["defineCapability", "MarkdownCapabilities", "State", "defineCapability", "meta", "id", "Extensions"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
import {
|
|
2
|
+
MarkdownEditor
|
|
3
|
+
} from "./chunk-56SUMOIZ.mjs";
|
|
4
|
+
import {
|
|
5
|
+
getContentSnippet,
|
|
6
|
+
getFallbackName
|
|
7
|
+
} from "./chunk-KPH4ZPQN.mjs";
|
|
8
|
+
import {
|
|
9
|
+
Markdown_exports
|
|
10
|
+
} from "./chunk-CN35HEBX.mjs";
|
|
11
|
+
import {
|
|
12
|
+
meta
|
|
13
|
+
} from "./chunk-BQTYJOFB.mjs";
|
|
14
|
+
|
|
15
|
+
// src/components/MarkdownCard/MarkdownCard.tsx
|
|
16
|
+
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
17
|
+
import * as Function from "effect/Function";
|
|
18
|
+
import React, { forwardRef, useCallback, useMemo } from "react";
|
|
19
|
+
import { LayoutAction, chain, createIntent } from "@dxos/app-framework";
|
|
20
|
+
import { useIntentDispatcher } from "@dxos/app-framework/react";
|
|
21
|
+
import { Obj } from "@dxos/echo";
|
|
22
|
+
import { IconButton, useTranslation } from "@dxos/react-ui";
|
|
23
|
+
import { Card } from "@dxos/react-ui-stack";
|
|
24
|
+
import { Text } from "@dxos/schema";
|
|
25
|
+
var MarkdownCard = /* @__PURE__ */ forwardRef(({ subject, role }, forwardedRef) => {
|
|
26
|
+
var _effect = _useSignals();
|
|
27
|
+
try {
|
|
28
|
+
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
29
|
+
const { t } = useTranslation(meta.id);
|
|
30
|
+
const snippet = useMemo(() => getSnippet(subject, t("fallback abstract")), [
|
|
31
|
+
subject
|
|
32
|
+
]);
|
|
33
|
+
const info = getInfo(subject);
|
|
34
|
+
const handleNavigate = useCallback(() => {
|
|
35
|
+
void dispatch(Function.pipe(createIntent(LayoutAction.UpdatePopover, {
|
|
36
|
+
part: "popover",
|
|
37
|
+
subject: null,
|
|
38
|
+
options: {
|
|
39
|
+
state: false,
|
|
40
|
+
anchorId: ""
|
|
41
|
+
}
|
|
42
|
+
}), chain(LayoutAction.Open, {
|
|
43
|
+
part: "main",
|
|
44
|
+
subject: [
|
|
45
|
+
Obj.getDXN(subject).toString()
|
|
46
|
+
]
|
|
47
|
+
})));
|
|
48
|
+
}, [
|
|
49
|
+
dispatch,
|
|
50
|
+
subject
|
|
51
|
+
]);
|
|
52
|
+
return /* @__PURE__ */ React.createElement(Card.SurfaceRoot, {
|
|
53
|
+
role,
|
|
54
|
+
ref: forwardedRef
|
|
55
|
+
}, /* @__PURE__ */ React.createElement(Card.Heading, {
|
|
56
|
+
classNames: "flex items-center"
|
|
57
|
+
}, getTitle(subject, t("fallback title")), /* @__PURE__ */ React.createElement("span", {
|
|
58
|
+
className: "grow"
|
|
59
|
+
}), /* @__PURE__ */ React.createElement(IconButton, {
|
|
60
|
+
iconOnly: true,
|
|
61
|
+
icon: "ph--arrow-right--regular",
|
|
62
|
+
label: t("navigate to document label"),
|
|
63
|
+
onClick: handleNavigate
|
|
64
|
+
})), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
|
|
65
|
+
classNames: "flex max-h-[300px] overflow-hidden"
|
|
66
|
+
}, /* @__PURE__ */ React.createElement(MarkdownEditor.Root, {
|
|
67
|
+
id: subject.id,
|
|
68
|
+
viewMode: "readonly"
|
|
69
|
+
}, /* @__PURE__ */ React.createElement(MarkdownEditor.Content, {
|
|
70
|
+
initialValue: snippet,
|
|
71
|
+
slots: {},
|
|
72
|
+
classNames: "!bg-transparent"
|
|
73
|
+
}))), /* @__PURE__ */ React.createElement(Card.Text, {
|
|
74
|
+
classNames: "text-xs text-description"
|
|
75
|
+
}, info.words, " ", t("words label", {
|
|
76
|
+
count: info.words
|
|
77
|
+
})));
|
|
78
|
+
} finally {
|
|
79
|
+
_effect.f();
|
|
80
|
+
}
|
|
81
|
+
});
|
|
82
|
+
var getInfo = (subject) => {
|
|
83
|
+
const text = (Obj.instanceOf(Markdown_exports.Document, subject) ? subject.content?.target?.content : subject.content) ?? "";
|
|
84
|
+
return {
|
|
85
|
+
words: text.split(" ").length
|
|
86
|
+
};
|
|
87
|
+
};
|
|
88
|
+
var getTitle = (subject, fallback) => {
|
|
89
|
+
if (Obj.instanceOf(Markdown_exports.Document, subject)) {
|
|
90
|
+
const title = Obj.getLabel(subject);
|
|
91
|
+
return title ?? getFallbackName(subject.content?.target?.content ?? fallback);
|
|
92
|
+
} else if (Obj.instanceOf(Text.Text, subject)) {
|
|
93
|
+
return getFallbackName(subject.content);
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
var getSnippet = (subject, fallback) => {
|
|
97
|
+
if (Obj.instanceOf(Markdown_exports.Document, subject)) {
|
|
98
|
+
return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
|
|
99
|
+
} else if (Obj.instanceOf(Text.Text, subject)) {
|
|
100
|
+
return getContentSnippet(subject.content ?? fallback);
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
// src/components/MarkdownCard/index.ts
|
|
105
|
+
var MarkdownCard_default = MarkdownCard;
|
|
106
|
+
|
|
107
|
+
export {
|
|
108
|
+
MarkdownCard,
|
|
109
|
+
MarkdownCard_default
|
|
110
|
+
};
|
|
111
|
+
//# sourceMappingURL=chunk-KCOBZZIL.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownCard/MarkdownCard.tsx", "../../../src/components/MarkdownCard/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Function from 'effect/Function';\nimport React, { forwardRef, useCallback, useMemo } from 'react';\n\nimport { LayoutAction, chain, createIntent } from '@dxos/app-framework';\nimport { useIntentDispatcher } from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { type CardPreviewProps } from '@dxos/plugin-preview';\nimport { IconButton, useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui-stack';\nimport { Text } from '@dxos/schema';\n\nimport { meta } from '../../meta';\nimport { Markdown } from '../../types';\nimport { getContentSnippet, getFallbackName } from '../../util';\nimport { MarkdownEditor } from '../MarkdownEditor';\n\nexport type MarkdownCardProps = CardPreviewProps<Markdown.Document | Text.Text>;\n\nexport const MarkdownCard = forwardRef<HTMLDivElement, MarkdownCardProps>(\n ({ subject, role }: MarkdownCardProps, forwardedRef) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { t } = useTranslation(meta.id);\n const snippet = useMemo(() => getSnippet(subject, t('fallback abstract')), [subject]);\n const info = getInfo(subject);\n\n // TODO(wittjosiah): Factor out so this component isn't dependent on the app framework.\n const handleNavigate = useCallback(() => {\n void dispatch(\n Function.pipe(\n createIntent(LayoutAction.UpdatePopover, {\n part: 'popover',\n subject: null,\n options: { state: false, anchorId: '' },\n }),\n chain(LayoutAction.Open, {\n part: 'main',\n subject: [Obj.getDXN(subject).toString()],\n }),\n ),\n );\n }, [dispatch, subject]);\n\n return (\n <Card.SurfaceRoot role={role} ref={forwardedRef}>\n <Card.Heading classNames='flex items-center'>\n {getTitle(subject, t('fallback title'))}\n <span className='grow' />\n <IconButton\n iconOnly\n icon='ph--arrow-right--regular'\n label={t('navigate to document label')}\n onClick={handleNavigate}\n />\n </Card.Heading>\n {snippet && (\n <Card.Text classNames='flex max-h-[300px] overflow-hidden'>\n <MarkdownEditor.Root id={subject.id} viewMode='readonly'>\n <MarkdownEditor.Content initialValue={snippet} slots={{}} classNames='!bg-transparent' />\n </MarkdownEditor.Root>\n </Card.Text>\n )}\n <Card.Text classNames='text-xs text-description'>\n {info.words} {t('words label', { count: info.words })}\n </Card.Text>\n </Card.SurfaceRoot>\n );\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// TODO(burdon): Factor out.\nconst getTitle = (subject: Markdown.Document | Text.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n const title = Obj.getLabel(subject);\n return title ?? getFallbackName(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(Text.Text, subject)) {\n return getFallbackName(subject.content);\n }\n};\n\n// TODO(burdon): Factor out.\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);\n } else if (Obj.instanceOf(Text.Text, subject)) {\n return getContentSnippet(subject.content ?? fallback);\n }\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownCard } from './MarkdownCard';\n\nexport * from './MarkdownCard';\n\nexport default MarkdownCard;\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Function", "React", "forwardRef", "useCallback", "useMemo", "LayoutAction", "chain", "createIntent", "useIntentDispatcher", "Obj", "IconButton", "useTranslation", "Card", "Text", "MarkdownCard", "forwardRef", "subject", "role", "forwardedRef", "dispatchPromise", "dispatch", "useIntentDispatcher", "t", "useTranslation", "meta", "id", "snippet", "useMemo", "getSnippet", "info", "getInfo", "handleNavigate", "useCallback", "pipe", "createIntent", "LayoutAction", "UpdatePopover", "part", "options", "state", "anchorId", "chain", "Open", "Obj", "getDXN", "toString", "Card", "SurfaceRoot", "ref", "Heading", "classNames", "getTitle", "span", "className", "IconButton", "iconOnly", "icon", "label", "onClick", "Text", "MarkdownEditor", "Root", "viewMode", "Content", "initialValue", "slots", "words", "count", "text", "instanceOf", "Markdown", "Document", "content", "target", "split", "length", "fallback", "title", "getLabel", "getFallbackName", "getDescription", "getContentSnippet", "MarkdownCard"]
|
|
7
|
+
}
|