@dxos/plugin-markdown 0.8.2-staging.7ac8446 → 0.8.3-main.672df60
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/MarkdownContainer-DGPA7SEG.mjs +588 -0
- package/dist/lib/browser/MarkdownContainer-DGPA7SEG.mjs.map +7 -0
- package/dist/lib/browser/MarkdownPreview-KQN2TGK6.mjs +80 -0
- package/dist/lib/browser/MarkdownPreview-KQN2TGK6.mjs.map +7 -0
- package/dist/lib/browser/anchor-sort-VS4OZVPP.mjs +32 -0
- package/dist/lib/browser/anchor-sort-VS4OZVPP.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-NOXI4IQ5.mjs → app-graph-serializer-V6RLEHVY.mjs} +5 -6
- package/dist/lib/browser/app-graph-serializer-V6RLEHVY.mjs.map +7 -0
- package/dist/lib/browser/{artifact-definition-CE6J6NY4.mjs → artifact-definition-5NAODQLG.mjs} +65 -17
- package/dist/lib/browser/artifact-definition-5NAODQLG.mjs.map +7 -0
- package/dist/lib/browser/{chunk-3ULJ4FIJ.mjs → chunk-77NGW7EO.mjs} +12 -26
- package/dist/lib/browser/chunk-77NGW7EO.mjs.map +7 -0
- package/dist/lib/browser/{chunk-QXDKFACU.mjs → chunk-C5RABVIX.mjs} +6 -5
- package/dist/lib/browser/chunk-C5RABVIX.mjs.map +7 -0
- package/dist/lib/browser/chunk-ECSM56YC.mjs +80 -0
- package/dist/lib/browser/chunk-ECSM56YC.mjs.map +7 -0
- package/dist/lib/browser/chunk-OTOPAFWC.mjs +20 -0
- package/dist/lib/browser/chunk-OTOPAFWC.mjs.map +7 -0
- package/dist/lib/browser/{chunk-NAGMSX77.mjs → chunk-QVJETNGS.mjs} +2 -2
- package/dist/lib/{node-esm/chunk-ETXPC5VP.mjs.map → browser/chunk-QVJETNGS.mjs.map} +1 -1
- package/dist/lib/browser/index.mjs +34 -18
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/intent-resolver-4GDYST4Y.mjs +65 -0
- package/dist/lib/browser/intent-resolver-4GDYST4Y.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-DM6B4UUJ.mjs +200 -0
- package/dist/lib/browser/react-surface-DM6B4UUJ.mjs.map +7 -0
- package/dist/lib/browser/{settings-GCSS3Y4Z.mjs → settings-W5CK4PXP.mjs} +4 -4
- package/dist/lib/browser/settings-W5CK4PXP.mjs.map +7 -0
- package/dist/lib/browser/{state-O7P5JDIH.mjs → state-KI6PJ6DT.mjs} +3 -3
- package/dist/lib/browser/state-KI6PJ6DT.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +3 -1
- package/dist/lib/node/MarkdownContainer-BZK66EQD.cjs +601 -0
- package/dist/lib/node/MarkdownContainer-BZK66EQD.cjs.map +7 -0
- package/dist/lib/node/MarkdownPreview-H7FFIWJH.cjs +103 -0
- package/dist/lib/node/MarkdownPreview-H7FFIWJH.cjs.map +7 -0
- package/dist/lib/node/{thread-42R57L4K.cjs → anchor-sort-NHVF23EU.cjs} +15 -20
- package/dist/lib/node/anchor-sort-NHVF23EU.cjs.map +7 -0
- package/dist/lib/node/{app-graph-serializer-HKK3SEDN.cjs → app-graph-serializer-CLALIYN3.cjs} +10 -11
- package/dist/lib/node/app-graph-serializer-CLALIYN3.cjs.map +7 -0
- package/dist/lib/node/{artifact-definition-XGADFWCQ.cjs → artifact-definition-VEAHK7BX.cjs} +68 -21
- package/dist/lib/node/artifact-definition-VEAHK7BX.cjs.map +7 -0
- package/dist/lib/node/chunk-BBDDZLQH.cjs +58 -0
- package/dist/lib/node/chunk-BBDDZLQH.cjs.map +7 -0
- package/dist/lib/node/{chunk-7QVONRSI.cjs → chunk-G7RBJX22.cjs} +13 -41
- package/dist/lib/node/chunk-G7RBJX22.cjs.map +7 -0
- package/dist/lib/node/{chunk-DZXTXSXX.cjs → chunk-IFYSBQE5.cjs} +5 -5
- package/dist/lib/node/{chunk-DZXTXSXX.cjs.map → chunk-IFYSBQE5.cjs.map} +1 -1
- package/dist/lib/node/{chunk-UEXGNGSS.cjs → chunk-RQS4KBMG.cjs} +45 -39
- package/dist/lib/node/chunk-RQS4KBMG.cjs.map +7 -0
- package/dist/lib/node/{chunk-H5MYVP6F.cjs → chunk-ZDTL47I7.cjs} +9 -8
- package/dist/lib/node/chunk-ZDTL47I7.cjs.map +7 -0
- package/dist/lib/node/index.cjs +43 -28
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/intent-resolver-AUZVK3NZ.cjs +78 -0
- package/dist/lib/node/intent-resolver-AUZVK3NZ.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-QBW4FFXF.cjs +213 -0
- package/dist/lib/node/react-surface-QBW4FFXF.cjs.map +7 -0
- package/dist/lib/node/{settings-S2ISUVIH.cjs → settings-IRKU3WPM.cjs} +7 -7
- package/dist/lib/node/settings-IRKU3WPM.cjs.map +7 -0
- package/dist/lib/node/{state-L44SG3ZM.cjs → state-KKDRAG7X.cjs} +7 -7
- package/dist/lib/node/state-KKDRAG7X.cjs.map +7 -0
- package/dist/lib/node/types/index.cjs +8 -6
- package/dist/lib/node/types/index.cjs.map +2 -2
- package/dist/lib/node-esm/MarkdownContainer-2DYVQ6RC.mjs +589 -0
- package/dist/lib/node-esm/MarkdownContainer-2DYVQ6RC.mjs.map +7 -0
- package/dist/lib/node-esm/MarkdownPreview-JUIXYYKF.mjs +81 -0
- package/dist/lib/node-esm/MarkdownPreview-JUIXYYKF.mjs.map +7 -0
- package/dist/lib/node-esm/anchor-sort-G2HLCYFK.mjs +33 -0
- package/dist/lib/node-esm/anchor-sort-G2HLCYFK.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-QQ2CTHOQ.mjs → app-graph-serializer-C3RNTQGM.mjs} +5 -6
- package/dist/lib/node-esm/app-graph-serializer-C3RNTQGM.mjs.map +7 -0
- package/dist/lib/node-esm/{artifact-definition-WRG5ZRN5.mjs → artifact-definition-7TIJW2CO.mjs} +65 -17
- package/dist/lib/node-esm/artifact-definition-7TIJW2CO.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-F6UHVLH7.mjs → chunk-6RPARLIK.mjs} +12 -26
- package/dist/lib/node-esm/chunk-6RPARLIK.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ETXPC5VP.mjs → chunk-JXXDCSMW.mjs} +2 -2
- package/dist/lib/{browser/chunk-NAGMSX77.mjs.map → node-esm/chunk-JXXDCSMW.mjs.map} +1 -1
- package/dist/lib/node-esm/chunk-KK7LP3UQ.mjs +22 -0
- package/dist/lib/node-esm/chunk-KK7LP3UQ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-NCMPVEXO.mjs +81 -0
- package/dist/lib/node-esm/chunk-NCMPVEXO.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-JAVD67QP.mjs → chunk-TCFJNUAE.mjs} +6 -5
- package/dist/lib/node-esm/chunk-TCFJNUAE.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +34 -18
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/intent-resolver-FTNXUNI2.mjs +66 -0
- package/dist/lib/node-esm/intent-resolver-FTNXUNI2.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-A4VAOQG6.mjs +201 -0
- package/dist/lib/node-esm/react-surface-A4VAOQG6.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-ZDIFTK4N.mjs → settings-MK7D7LHQ.mjs} +4 -4
- package/dist/lib/node-esm/settings-MK7D7LHQ.mjs.map +7 -0
- package/dist/lib/node-esm/{state-DWPOKLEY.mjs → state-LLGVRYKL.mjs} +3 -3
- package/dist/lib/node-esm/state-LLGVRYKL.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +3 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/anchor-sort.d.ts +6 -0
- package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-serializer.d.ts +2 -2
- package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
- package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +7 -7
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +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/MarkdownContainer.d.ts +5 -3
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +24 -0
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -0
- package/dist/types/src/components/{MarkdownEditor.stories.d.ts → MarkdownEditor/MarkdownEditor.stories.d.ts} +3 -3
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownEditor/index.d.ts +2 -0
- package/dist/types/src/components/MarkdownEditor/index.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +6 -0
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +23 -0
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownPreview/index.d.ts +4 -0
- package/dist/types/src/components/MarkdownPreview/index.d.ts.map +1 -0
- package/dist/types/src/components/{MarkdownSettings.d.ts → MarkdownSettings/MarkdownSettings.d.ts} +1 -1
- package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownSettings/index.d.ts +2 -0
- package/dist/types/src/components/MarkdownSettings/index.d.ts.map +1 -0
- package/dist/types/src/components/Suggestions.stories.d.ts +12 -0
- package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar.stories.d.ts +2 -2
- package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +2 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts +8 -5
- package/dist/types/src/extensions.d.ts.map +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +4 -42
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +29 -129
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +40 -88
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +1 -0
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +47 -34
- package/src/MarkdownPlugin.tsx +22 -12
- package/src/capabilities/anchor-sort.ts +30 -0
- package/src/capabilities/app-graph-serializer.ts +4 -5
- package/src/capabilities/artifact-definition.ts +48 -10
- package/src/capabilities/index.ts +1 -1
- package/src/capabilities/intent-resolver.ts +40 -12
- package/src/capabilities/react-surface.tsx +20 -5
- package/src/capabilities/settings.ts +2 -2
- package/src/capabilities/state.ts +4 -4
- package/src/components/MarkdownContainer.tsx +20 -7
- package/src/components/{MarkdownEditor.stories.tsx → MarkdownEditor/MarkdownEditor.stories.tsx} +22 -35
- package/src/components/{MarkdownEditor.tsx → MarkdownEditor/MarkdownEditor.tsx} +32 -73
- package/src/components/MarkdownEditor/index.ts +5 -0
- package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +73 -0
- package/src/components/MarkdownPreview/MarkdownPreview.tsx +71 -0
- package/src/components/MarkdownPreview/index.ts +9 -0
- package/src/components/{MarkdownSettings.tsx → MarkdownSettings/MarkdownSettings.tsx} +2 -2
- package/src/components/MarkdownSettings/index.ts +5 -0
- package/src/components/Suggestions.stories.tsx +217 -0
- package/src/components/Toolbar.stories.tsx +29 -29
- package/src/components/index.ts +1 -0
- package/src/extensions.tsx +82 -48
- package/src/hooks/useSelectCurrentThread.tsx +2 -2
- package/src/translations.ts +3 -3
- package/src/types/schema.ts +22 -15
- package/src/types/types.ts +23 -21
- package/src/util.tsx +8 -4
- package/dist/lib/browser/MarkdownContainer-T3HU27RE.mjs +0 -563
- package/dist/lib/browser/MarkdownContainer-T3HU27RE.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-NOXI4IQ5.mjs.map +0 -7
- package/dist/lib/browser/artifact-definition-CE6J6NY4.mjs.map +0 -7
- package/dist/lib/browser/chunk-3ULJ4FIJ.mjs.map +0 -7
- package/dist/lib/browser/chunk-QXDKFACU.mjs.map +0 -7
- package/dist/lib/browser/chunk-YCJNW2RU.mjs +0 -75
- package/dist/lib/browser/chunk-YCJNW2RU.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-42GQ6HNZ.mjs +0 -50
- package/dist/lib/browser/intent-resolver-42GQ6HNZ.mjs.map +0 -7
- package/dist/lib/browser/react-surface-RQX3CPFV.mjs +0 -176
- package/dist/lib/browser/react-surface-RQX3CPFV.mjs.map +0 -7
- package/dist/lib/browser/settings-GCSS3Y4Z.mjs.map +0 -7
- package/dist/lib/browser/state-O7P5JDIH.mjs.map +0 -7
- package/dist/lib/browser/thread-3QGCFNVZ.mjs +0 -37
- package/dist/lib/browser/thread-3QGCFNVZ.mjs.map +0 -7
- package/dist/lib/node/MarkdownContainer-6ZJIFAP6.cjs +0 -576
- package/dist/lib/node/MarkdownContainer-6ZJIFAP6.cjs.map +0 -7
- package/dist/lib/node/app-graph-serializer-HKK3SEDN.cjs.map +0 -7
- package/dist/lib/node/artifact-definition-XGADFWCQ.cjs.map +0 -7
- package/dist/lib/node/chunk-7QVONRSI.cjs.map +0 -7
- package/dist/lib/node/chunk-H5MYVP6F.cjs.map +0 -7
- package/dist/lib/node/chunk-UEXGNGSS.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-NW27BF3W.cjs +0 -63
- package/dist/lib/node/intent-resolver-NW27BF3W.cjs.map +0 -7
- package/dist/lib/node/react-surface-5X3SMHGI.cjs +0 -189
- package/dist/lib/node/react-surface-5X3SMHGI.cjs.map +0 -7
- package/dist/lib/node/settings-S2ISUVIH.cjs.map +0 -7
- package/dist/lib/node/state-L44SG3ZM.cjs.map +0 -7
- package/dist/lib/node/thread-42R57L4K.cjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-URAPTO37.mjs +0 -564
- package/dist/lib/node-esm/MarkdownContainer-URAPTO37.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-QQ2CTHOQ.mjs.map +0 -7
- package/dist/lib/node-esm/artifact-definition-WRG5ZRN5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-4AM4VU3Y.mjs +0 -76
- package/dist/lib/node-esm/chunk-4AM4VU3Y.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-F6UHVLH7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-JAVD67QP.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-7HOMUVHR.mjs +0 -51
- package/dist/lib/node-esm/intent-resolver-7HOMUVHR.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-6IKC3G46.mjs +0 -177
- package/dist/lib/node-esm/react-surface-6IKC3G46.mjs.map +0 -7
- package/dist/lib/node-esm/settings-ZDIFTK4N.mjs.map +0 -7
- package/dist/lib/node-esm/state-DWPOKLEY.mjs.map +0 -7
- package/dist/lib/node-esm/thread-R2KHZD6V.mjs +0 -38
- package/dist/lib/node-esm/thread-R2KHZD6V.mjs.map +0 -7
- package/dist/types/src/capabilities/thread.d.ts +0 -6
- package/dist/types/src/capabilities/thread.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownEditor.d.ts +0 -39
- package/dist/types/src/components/MarkdownEditor.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownEditor.stories.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownSettings.d.ts.map +0 -1
- package/src/capabilities/thread.ts +0 -35
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownContainer.tsx", "../../../src/components/MarkdownEditor/MarkdownEditor.tsx", "../../../src/hooks/useSelectCurrentThread.tsx", "../../../src/extensions.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Rx } from '@effect-rx/rx-react';\nimport React, { useEffect, useMemo } from 'react';\n\nimport { Capabilities, useAppGraph, useCapabilities } from '@dxos/app-framework';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport { DataType } from '@dxos/schema';\n\nimport { MarkdownEditor, type MarkdownEditorProps } from './MarkdownEditor';\nimport { useExtensions } from '../extensions';\nimport { DocumentType, type MarkdownSettingsProps } from '../types';\nimport { getFallbackName } from '../util';\n\nexport type MarkdownContainerProps = Pick<\n MarkdownEditorProps,\n 'role' | 'extensionProviders' | 'viewMode' | 'editorStateStore' | 'onViewModeChange'\n> & {\n id: string;\n object: DocumentType | DataType.Text | any;\n settings: MarkdownSettingsProps;\n selectionManager?: SelectionManager;\n};\n\n// TODO(burdon): Factor out difference for ECHO and non-ECHO objects; i.e., single component.\nconst MarkdownContainer = ({\n id,\n role,\n object,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n onViewModeChange,\n}: MarkdownContainerProps) => {\n const scrollPastEnd = role === 'article';\n const doc = isInstanceOf(DocumentType, object) ? object : undefined;\n const text = isInstanceOf(DataType.Text, object) ? object : undefined;\n const extensions = useExtensions({ document: doc, text, id, settings, selectionManager, viewMode, editorStateStore });\n\n if (doc) {\n return (\n <DocumentEditor\n id={fullyQualifiedId(object)}\n role={role}\n document={doc}\n extensions={extensions}\n viewMode={viewMode}\n settings={settings}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n />\n );\n } else if (text) {\n return (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={text.content}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n />\n );\n } else {\n // TODO(burdon): Normalize with above.\n return (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={object.text}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n />\n );\n }\n};\n\ntype DocumentEditorProps = Omit<MarkdownContainerProps, 'object' | 'extensionProviders' | 'editorStateStore'> &\n Pick<MarkdownEditorProps, 'id' | 'scrollPastEnd' | 'extensions'> & {\n document: DocumentType;\n };\n\nexport const DocumentEditor = ({ id, document: doc, settings, viewMode, ...props }: DocumentEditorProps) => {\n const space = getSpace(doc);\n\n // Migrate gradually to `fallbackName`.\n useEffect(() => {\n if (typeof doc.fallbackName === 'string') {\n return;\n }\n\n const fallbackName = doc.content?.target?.content ? getFallbackName(doc.content.target.content) : undefined;\n if (fallbackName) {\n doc.fallbackName = fallbackName;\n }\n }, [doc, doc.content]);\n\n // File dragging.\n const [upload] = useCapabilities(Capabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (space === undefined || upload === undefined) {\n return undefined;\n }\n\n // TODO(burdon): Re-order props: space, file.\n return async (file: File) => upload!(file, space);\n }, [space, upload]);\n\n const { graph } = useAppGraph();\n const customActions = useMemo(() => {\n return Rx.make((get) => {\n const actions = get(graph.actions(id));\n const nodes = actions.filter((action) => action.properties.disposition === 'toolbar');\n return { nodes, edges: nodes.map((node) => ({ source: 'root', target: node.id })) };\n });\n }, [graph]);\n\n return (\n <MarkdownEditor\n id={id}\n initialValue={doc.content?.target?.content}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n customActions={customActions}\n inputMode={settings.editorInputMode}\n onFileUpload={handleFileUpload}\n {...props}\n />\n );\n};\n\nexport default MarkdownContainer;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { useMemo, useEffect, useCallback } from 'react';\nimport { useDropzone } from 'react-dropzone';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type DNDOptions,\n type EditorViewMode,\n type EditorInputMode,\n type EditorSelectionState,\n type EditorStateStore,\n EditorToolbar,\n type UseTextEditorProps,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorSlots,\n editorGutter,\n processEditorPayload,\n stackItemContentEditorClassNames,\n useFormattingState,\n useTextEditor,\n useEditorToolbarState,\n addLink,\n type EditorToolbarActionGraphProps,\n} from '@dxos/react-ui-editor';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { isNotFalsy, isNonNullable } from '@dxos/util';\n\nimport { useSelectCurrentThread } from '../../hooks';\nimport { MARKDOWN_PLUGIN } from '../../meta';\nimport { type MarkdownPluginState } from '../../types';\n\nexport type MarkdownEditorProps = {\n id: string;\n role?: string;\n inputMode?: EditorInputMode;\n scrollPastEnd?: boolean;\n toolbar?: boolean;\n customActions?: EditorToolbarActionGraphProps['customActions'];\n // TODO(wittjosiah): Generalize custom toolbar actions (e.g. comment, upload, etc.)\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n onViewModeChange?: (id: string, mode: EditorViewMode) => void;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n} & Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &\n Partial<Pick<MarkdownPluginState, 'extensionProviders'>>;\n\n/**\n * Base markdown editor component.\n *\n * This component provides all the features of the markdown editor that do no depend on ECHO.\n * This allows it to be used as a common editor for markdown content on arbitrary backends (e.g. files).\n */\nexport const MarkdownEditor = ({\n id,\n role = 'article',\n initialValue,\n extensions,\n extensionProviders,\n scrollPastEnd,\n toolbar,\n customActions,\n viewMode,\n editorStateStore,\n onFileUpload,\n onViewModeChange,\n}: MarkdownEditorProps) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n const { themeMode } = useThemeContext();\n const toolbarState = useEditorToolbarState({ viewMode });\n const formattingObserver = useFormattingState(toolbarState);\n\n // Restore last selection and scroll point.\n const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);\n\n // Extensions from other plugins.\n // TODO(burdon): Reconcile with DocumentEditor.useExtensions.\n const providerExtensions = useMemo(\n () => extensionProviders?.flatMap((provider) => provider({})).filter(isNonNullable),\n [extensionProviders],\n );\n\n // TODO(wittjosiah): Factor out to file uploader plugin.\n // Drag files.\n const handleDrop: DNDOptions['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 const {\n parentRef,\n view: editorView,\n focusAttributes,\n } = useTextEditor(\n () => ({\n initialValue,\n extensions: [\n formattingObserver,\n createBasicExtensions({\n readOnly: viewMode === 'readonly',\n placeholder: t('editor placeholder'),\n scrollPastEnd: role === 'section' ? false : scrollPastEnd,\n }),\n createMarkdownExtensions({ themeMode }),\n createThemeExtensions({ themeMode, syntaxHighlighting: true, slots: editorSlots }),\n editorGutter,\n role !== 'section' && onFileUpload && dropFile({ onDrop: handleDrop }),\n providerExtensions,\n extensions,\n ].filter(isNotFalsy),\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 moveToEndOfLine: true,\n }),\n }),\n [id, formattingObserver, viewMode, themeMode, extensions, providerExtensions],\n );\n\n useTest(editorView);\n useSelectCurrentThread(editorView, id);\n\n // https://react-dropzone.js.org/#src\n const { acceptedFiles, getInputProps, open } = useDropzone({\n multiple: false,\n noDrag: true,\n accept: {\n 'image/*': ['.jpg', '.jpeg', '.png', '.gif'],\n },\n });\n\n useEffect(() => {\n if (editorView && onFileUpload && acceptedFiles.length) {\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 const info = await onFileUpload(file);\n if (info) {\n addLink({ url: info.url, image: true })(editorView);\n }\n });\n }\n }, [acceptedFiles, editorView, onFileUpload]);\n\n const getView = useCallback(() => {\n invariant(editorView);\n return editorView;\n }, [editorView]);\n\n const handleViewModeChange = useCallback(\n (mode: EditorViewMode) => onViewModeChange?.(id, mode),\n [id, onViewModeChange],\n );\n\n const handleImageUpload = useCallback(() => {\n if (onFileUpload) {\n open();\n }\n }, [onFileUpload]);\n\n return (\n <StackItem.Content toolbar={!!toolbar}>\n {toolbar && (\n <>\n <EditorToolbar\n attendableId={id}\n role={role}\n state={toolbarState}\n customActions={customActions}\n getView={getView}\n image={handleImageUpload}\n viewMode={handleViewModeChange}\n />\n <input {...getInputProps()} />\n </>\n )}\n <div\n role='none'\n ref={parentRef}\n data-testid='composer.markdownRoot'\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n className={stackItemContentEditorClassNames(role)}\n data-popover-collision-boundary={true}\n {...focusAttributes}\n />\n </StackItem.Content>\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) => {\n useEffect(() => {\n const composer = (window as any).composer;\n if (composer) {\n composer.editorView = view;\n }\n }, [view]);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport { Schema } from 'effect';\nimport { useMemo } from 'react';\n\nimport { createResolver, LayoutAction, useIntentResolver } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { Cursor, setSelection } from '@dxos/react-ui-editor';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\n\n/**\n * Handle scrolling and selection of the current thread in a markdown editor.\n */\nexport const useSelectCurrentThread = (editorView: EditorView | undefined, documentId: string) => {\n const scrollIntoViewResolver = useMemo(\n () =>\n createResolver({\n intent: LayoutAction.UpdateLayout,\n position: 'hoist',\n filter: (data): data is { part: 'current'; subject: string; options: { cursor: string } } => {\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, { y: 'start', yMargin: 96 }),\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(MARKDOWN_PLUGIN, scrollIntoViewResolver);\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport {\n createIntent,\n LayoutAction,\n type PromiseIntentDispatcher,\n useCapabilities,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { createDocAccessor, fullyQualifiedId, getSpace, type QueryResult } 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 type AutocompleteResult,\n type EditorStateStore,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n createDataExtensions,\n autocomplete,\n decorateMarkdown,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n preview,\n selectionState,\n typewriter,\n type RenderCallback,\n EditorView,\n documentId,\n Cursor,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { type DataType } from '@dxos/schema';\nimport { isNotFalsy } from '@dxos/util';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { type DocumentType, type MarkdownSettingsProps } from './types';\nimport { setFallbackName } from './util';\n\ntype ExtensionsOptions = {\n document?: DocumentType;\n id?: string;\n text?: DataType.Text;\n dispatch?: PromiseIntentDispatcher;\n query?: QueryResult<DocumentType>;\n settings: MarkdownSettingsProps;\n selectionManager?: SelectionManager;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({\n document,\n id,\n text,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n}: ExtensionsOptions): Extension[] => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const identity = useIdentity();\n const space = getSpace(document) ?? getSpace(text);\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 const baseExtensions = useMemo(\n () =>\n createBaseExtensions({\n document,\n id,\n text,\n settings,\n selectionManager,\n viewMode,\n dispatch,\n // query,\n }),\n [\n document,\n id,\n text,\n viewMode,\n dispatch,\n settings,\n settings.editorInputMode,\n settings.folding,\n settings.numberedHeadings,\n settings.debug,\n settings.typewriter,\n selectionManager,\n ],\n );\n\n const extensionProviders = useCapabilities(MarkdownCapabilities.Extensions);\n\n //\n // External extensions from other plugins.\n //\n const pluginExtensions = useMemo<Extension[]>(() => {\n if (!document) {\n return [];\n }\n\n return extensionProviders.flat().reduce((acc: Extension[], provider) => {\n const extension = typeof provider === 'function' ? provider({ document }) : provider;\n if (extension) {\n acc.push(extension);\n }\n\n return acc;\n }, []);\n }, [extensionProviders, document]);\n\n //\n // Basic plugins.\n //\n return useMemo<Extension[]>(\n () =>\n [\n // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.\n document &&\n createDataExtensions({\n id: document.id,\n text: document.content.target && createDocAccessor(document.content.target, ['content']),\n space,\n identity,\n }),\n text &&\n id &&\n createDataExtensions({\n id,\n text: createDocAccessor(text, ['content']),\n space,\n identity,\n }),\n selectionState(editorStateStore),\n document &&\n listener({\n onChange: (text) => setFallbackName(document, text),\n }),\n baseExtensions,\n pluginExtensions,\n ].filter(isNotFalsy),\n [baseExtensions, pluginExtensions, document, document?.content?.target, text, id, space, identity],\n );\n};\n\n/**\n * Create extension instances for editor.\n */\nconst createBaseExtensions = ({\n document,\n id,\n dispatch,\n settings,\n selectionManager,\n query,\n viewMode,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n selectionManager && selectionChange(selectionManager),\n settings.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings.folding && folding(),\n ].filter(isNotFalsy);\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 renderLinkButton:\n dispatch && (document || id)\n ? createLinkRenderer((id: string) => {\n void dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [id],\n options: {\n pivotId: document ? fullyQualifiedId(document) : id,\n },\n }),\n );\n })\n : undefined,\n }),\n linkTooltip(renderLinkTooltip),\n preview(),\n ],\n );\n }\n\n //\n // Autocomplete object links.\n //\n if (query) {\n extensions.push(\n autocomplete({\n onSearch: (text: string) => {\n // TODO(burdon): Specify filter (e.g., stack).\n return query.objects\n .map<AutocompleteResult | undefined>((object) =>\n object.name?.length && object.id !== document?.id\n ? {\n label: object.name,\n // TODO(burdon): Factor out URL builder.\n apply: `[${object.name}](/${fullyQualifiedId(object)})`,\n }\n : undefined,\n )\n .filter(isNotFalsy);\n },\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\nexport const selectionChange = (selectionManager: SelectionManager) => {\n return EditorView.updateListener.of((update) => {\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 selectionManager.updateMultiRange(id, ranges);\n }\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 react rendering; use DOM directly.\nexport const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {\n createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);\n return root;\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Rx", "React", "useEffect", "useMemo", "Capabilities", "useAppGraph", "useCapabilities", "isInstanceOf", "fullyQualifiedId", "getSpace", "DataType", "React", "useMemo", "useEffect", "useCallback", "useDropzone", "invariant", "useThemeContext", "useTranslation", "EditorToolbar", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorSlots", "editorGutter", "processEditorPayload", "stackItemContentEditorClassNames", "useFormattingState", "useTextEditor", "useEditorToolbarState", "addLink", "StackItem", "isNotFalsy", "isNonNullable", "EditorView", "Schema", "useMemo", "createResolver", "LayoutAction", "useIntentResolver", "invariant", "Cursor", "setSelection", "useSelectCurrentThread", "editorView", "documentId", "scrollIntoViewResolver", "useMemo", "createResolver", "intent", "LayoutAction", "UpdateLayout", "position", "filter", "data", "Schema", "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", "MARKDOWN_PLUGIN", "MarkdownEditor", "id", "role", "initialValue", "extensions", "extensionProviders", "scrollPastEnd", "toolbar", "customActions", "viewMode", "editorStateStore", "onFileUpload", "onViewModeChange", "t", "useTranslation", "MARKDOWN_PLUGIN", "themeMode", "useThemeContext", "toolbarState", "useEditorToolbarState", "formattingObserver", "useFormattingState", "scrollTo", "selection", "useMemo", "getState", "providerExtensions", "flatMap", "provider", "filter", "isNonNullable", "handleDrop", "view", "files", "file", "info", "undefined", "processEditorPayload", "type", "data", "url", "parentRef", "editorView", "focusAttributes", "useTextEditor", "createBasicExtensions", "readOnly", "placeholder", "createMarkdownExtensions", "createThemeExtensions", "syntaxHighlighting", "slots", "editorSlots", "editorGutter", "dropFile", "onDrop", "isNotFalsy", "moveToEndOfLine", "useTest", "useSelectCurrentThread", "acceptedFiles", "getInputProps", "open", "useDropzone", "multiple", "noDrag", "accept", "useEffect", "length", "requestAnimationFrame", "f", "File", "name", "lastModified", "addLink", "image", "getView", "useCallback", "invariant", "handleViewModeChange", "mode", "handleImageUpload", "StackItem", "Content", "EditorToolbar", "attendableId", "state", "input", "div", "ref", "data-testid", "data-toolbar", "className", "stackItemContentEditorClassNames", "data-popover-collision-boundary", "composer", "window", "React", "useMemo", "createRoot", "createIntent", "LayoutAction", "useCapabilities", "useIntentDispatcher", "invariant", "createDocAccessor", "fullyQualifiedId", "getSpace", "useIdentity", "Icon", "ThemeProvider", "InputModeExtensions", "createDataExtensions", "autocomplete", "decorateMarkdown", "folding", "formattingKeymap", "linkTooltip", "listener", "preview", "selectionState", "typewriter", "EditorView", "documentId", "Cursor", "defaultTx", "isNotFalsy", "useExtensions", "document", "id", "text", "settings", "selectionManager", "viewMode", "editorStateStore", "dispatchPromise", "dispatch", "useIntentDispatcher", "identity", "useIdentity", "space", "getSpace", "baseExtensions", "useMemo", "createBaseExtensions", "editorInputMode", "folding", "numberedHeadings", "debug", "typewriter", "extensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "pluginExtensions", "flat", "reduce", "acc", "provider", "extension", "push", "createDataExtensions", "content", "target", "createDocAccessor", "selectionState", "listener", "onChange", "setFallbackName", "filter", "isNotFalsy", "query", "extensions", "selectionChange", "InputModeExtensions", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "from", "undefined", "renderLinkButton", "createLinkRenderer", "createIntent", "LayoutAction", "Open", "part", "subject", "options", "pivotId", "fullyQualifiedId", "linkTooltip", "renderLinkTooltip", "preview", "autocomplete", "onSearch", "objects", "map", "object", "name", "length", "label", "apply", "items", "split", "EditorView", "updateListener", "of", "update", "selectionSet", "state", "facet", "documentId", "cursorConverter", "Cursor", "converter", "selection", "ranges", "range", "toCursor", "to", "updateMultiRange", "style", "hover", "icon", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "onClick", "qualifiedId", "at", "invariant", "href", "rel", "renderRoot", "React", "a", "className", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "MarkdownContainer", "id", "role", "object", "settings", "selectionManager", "viewMode", "editorStateStore", "onViewModeChange", "scrollPastEnd", "doc", "isInstanceOf", "DocumentType", "undefined", "text", "DataType", "Text", "extensions", "useExtensions", "document", "React", "DocumentEditor", "fullyQualifiedId", "MarkdownEditor", "initialValue", "content", "toolbar", "inputMode", "editorInputMode", "props", "space", "getSpace", "useEffect", "fallbackName", "target", "getFallbackName", "upload", "useCapabilities", "Capabilities", "FileUploader", "handleFileUpload", "useMemo", "file", "graph", "useAppGraph", "customActions", "Rx", "make", "get", "actions", "nodes", "filter", "action", "properties", "disposition", "edges", "map", "node", "source", "onFileUpload"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
getAbstract,
|
|
4
|
+
getFallbackName
|
|
5
|
+
} from "./chunk-6RPARLIK.mjs";
|
|
6
|
+
import {
|
|
7
|
+
DocumentType
|
|
8
|
+
} from "./chunk-NCMPVEXO.mjs";
|
|
9
|
+
import {
|
|
10
|
+
MARKDOWN_PLUGIN
|
|
11
|
+
} from "./chunk-RX63ZNML.mjs";
|
|
12
|
+
|
|
13
|
+
// packages/plugins/plugin-markdown/src/components/MarkdownPreview/MarkdownPreview.tsx
|
|
14
|
+
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
15
|
+
import { pipe } from "effect";
|
|
16
|
+
import React, { useCallback } from "react";
|
|
17
|
+
import { chain, createIntent, LayoutAction, useIntentDispatcher } from "@dxos/app-framework";
|
|
18
|
+
import { isInstanceOf } from "@dxos/echo-schema";
|
|
19
|
+
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
20
|
+
import { Button, Icon, useTranslation } from "@dxos/react-ui";
|
|
21
|
+
import { Card } from "@dxos/react-ui-stack";
|
|
22
|
+
import { DataType } from "@dxos/schema";
|
|
23
|
+
var getTitle = (subject, fallback) => {
|
|
24
|
+
if (isInstanceOf(DocumentType, subject)) {
|
|
25
|
+
return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);
|
|
26
|
+
} else if (isInstanceOf(DataType.Text, subject)) {
|
|
27
|
+
return getFallbackName(subject.content);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
var getSnippet = (subject, fallback) => {
|
|
31
|
+
if (isInstanceOf(DocumentType, subject)) {
|
|
32
|
+
return getAbstract(subject.content?.target?.content ?? fallback);
|
|
33
|
+
} else if (isInstanceOf(DataType.Text, subject)) {
|
|
34
|
+
return getAbstract(subject.content);
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
var MarkdownPreview = ({ subject, role }) => {
|
|
38
|
+
var _effect = _useSignals();
|
|
39
|
+
try {
|
|
40
|
+
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
41
|
+
const { t } = useTranslation(MARKDOWN_PLUGIN);
|
|
42
|
+
const snippet = getSnippet(subject, t("fallback abstract"));
|
|
43
|
+
const handleNavigate = useCallback(() => dispatch(pipe(createIntent(LayoutAction.UpdatePopover, {
|
|
44
|
+
part: "popover",
|
|
45
|
+
subject: null,
|
|
46
|
+
options: {
|
|
47
|
+
state: false,
|
|
48
|
+
anchorId: ""
|
|
49
|
+
}
|
|
50
|
+
}), chain(LayoutAction.Open, {
|
|
51
|
+
part: "main",
|
|
52
|
+
subject: [
|
|
53
|
+
fullyQualifiedId(subject)
|
|
54
|
+
]
|
|
55
|
+
}))), [
|
|
56
|
+
dispatch,
|
|
57
|
+
subject
|
|
58
|
+
]);
|
|
59
|
+
return /* @__PURE__ */ React.createElement(Card.Container, {
|
|
60
|
+
role
|
|
61
|
+
}, /* @__PURE__ */ React.createElement(Card.Heading, null, getTitle(subject, t("fallback title"))), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
|
|
62
|
+
classNames: "line-clamp-3 break-words col-span-2"
|
|
63
|
+
}, snippet), /* @__PURE__ */ React.createElement(Card.Chrome, null, /* @__PURE__ */ React.createElement(Button, {
|
|
64
|
+
onClick: handleNavigate
|
|
65
|
+
}, /* @__PURE__ */ React.createElement("span", {
|
|
66
|
+
className: "grow"
|
|
67
|
+
}, t("navigate to document label")), /* @__PURE__ */ React.createElement(Icon, {
|
|
68
|
+
icon: "ph--arrow-right--regular"
|
|
69
|
+
}))));
|
|
70
|
+
} finally {
|
|
71
|
+
_effect.f();
|
|
72
|
+
}
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
// packages/plugins/plugin-markdown/src/components/MarkdownPreview/index.ts
|
|
76
|
+
var MarkdownPreview_default = MarkdownPreview;
|
|
77
|
+
export {
|
|
78
|
+
MarkdownPreview,
|
|
79
|
+
MarkdownPreview_default as default
|
|
80
|
+
};
|
|
81
|
+
//# sourceMappingURL=MarkdownPreview-JUIXYYKF.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownPreview/MarkdownPreview.tsx", "../../../src/components/MarkdownPreview/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe } from 'effect';\nimport React, { useCallback } from 'react';\n\nimport { chain, createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { type PreviewProps } from '@dxos/plugin-preview';\nimport { fullyQualifiedId } from '@dxos/react-client/echo';\nimport { Button, Icon, useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui-stack';\nimport { DataType } from '@dxos/schema';\n\nimport { MARKDOWN_PLUGIN } from '../../meta';\nimport { DocumentType } from '../../types';\nimport { getAbstract, getFallbackName } from '../../util';\n\n// TODO(burdon): Factor out.\nconst getTitle = (subject: DocumentType | DataType.Text, fallback: string) => {\n if (isInstanceOf(DocumentType, subject)) {\n return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);\n } else if (isInstanceOf(DataType.Text, subject)) {\n return getFallbackName(subject.content);\n }\n};\n\n// TODO(burdon): Factor out.\nconst getSnippet = (subject: DocumentType | DataType.Text, fallback: string) => {\n if (isInstanceOf(DocumentType, subject)) {\n return getAbstract(subject.content?.target?.content ?? fallback);\n } else if (isInstanceOf(DataType.Text, subject)) {\n return getAbstract(subject.content);\n }\n};\n\nexport const MarkdownPreview = ({ subject, role }: PreviewProps<DocumentType | DataType.Text>) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n const snippet = getSnippet(subject, t('fallback abstract'));\n\n // TODO(wittjosiah): Factor out so this component isn't dependent on the app framework.\n const handleNavigate = useCallback(\n () =>\n dispatch(\n pipe(\n createIntent(LayoutAction.UpdatePopover, {\n part: 'popover',\n subject: null,\n options: { state: false, anchorId: '' },\n }),\n chain(LayoutAction.Open, { part: 'main', subject: [fullyQualifiedId(subject)] }),\n ),\n ),\n [dispatch, subject],\n );\n\n return (\n <Card.Container role={role}>\n <Card.Heading>{getTitle(subject, t('fallback title'))}</Card.Heading>\n {snippet && <Card.Text classNames='line-clamp-3 break-words col-span-2'>{snippet}</Card.Text>}\n <Card.Chrome>\n <Button onClick={handleNavigate}>\n <span className='grow'>{t('navigate to document label')}</span>\n <Icon icon='ph--arrow-right--regular' />\n </Button>\n </Card.Chrome>\n </Card.Container>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownPreview } from './MarkdownPreview';\n\nexport * from './MarkdownPreview';\n\nexport default MarkdownPreview;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;AAIA,SAASA,YAAY;AACrB,OAAOC,SAASC,mBAAmB;AAEnC,SAASC,OAAOC,cAAcC,cAAcC,2BAA2B;AACvE,SAASC,oBAAoB;AAE7B,SAASC,wBAAwB;AACjC,SAASC,QAAQC,MAAMC,sBAAsB;AAC7C,SAASC,YAAY;AACrB,SAASC,gBAAgB;AAOzB,IAAMC,WAAW,CAACC,SAAuCC,aAAAA;AACvD,MAAIC,aAAaC,cAAcH,OAAAA,GAAU;AACvC,WAAOA,QAAQI,QAAQJ,QAAQK,gBAAgBC,gBAAgBN,QAAQO,SAASC,QAAQD,WAAWN,QAAAA;EACrG,WAAWC,aAAaO,SAASC,MAAMV,OAAAA,GAAU;AAC/C,WAAOM,gBAAgBN,QAAQO,OAAO;EACxC;AACF;AAGA,IAAMI,aAAa,CAACX,SAAuCC,aAAAA;AACzD,MAAIC,aAAaC,cAAcH,OAAAA,GAAU;AACvC,WAAOY,YAAYZ,QAAQO,SAASC,QAAQD,WAAWN,QAAAA;EACzD,WAAWC,aAAaO,SAASC,MAAMV,OAAAA,GAAU;AAC/C,WAAOY,YAAYZ,QAAQO,OAAO;EACpC;AACF;AAEO,IAAMM,kBAAkB,CAAC,EAAEb,SAASc,KAAI,MAA8C;;;AAC3F,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,UAAM,EAAEC,EAAC,IAAKC,eAAeC,eAAAA;AAC7B,UAAMC,UAAUV,WAAWX,SAASkB,EAAE,mBAAA,CAAA;AAGtC,UAAMI,iBAAiBC,YACrB,MACEP,SACEQ,KACEC,aAAaC,aAAaC,eAAe;MACvCC,MAAM;MACN5B,SAAS;MACT6B,SAAS;QAAEC,OAAO;QAAOC,UAAU;MAAG;IACxC,CAAA,GACAC,MAAMN,aAAaO,MAAM;MAAEL,MAAM;MAAQ5B,SAAS;QAACkC,iBAAiBlC,OAAAA;;IAAU,CAAA,CAAA,CAAA,GAGpF;MAACgB;MAAUhB;KAAQ;AAGrB,WACE,sBAAA,cAACmC,KAAKC,WAAS;MAACtB;OACd,sBAAA,cAACqB,KAAKE,SAAO,MAAEtC,SAASC,SAASkB,EAAE,gBAAA,CAAA,CAAA,GAClCG,WAAW,sBAAA,cAACc,KAAKzB,MAAI;MAAC4B,YAAW;OAAuCjB,OAAAA,GACzE,sBAAA,cAACc,KAAKI,QAAM,MACV,sBAAA,cAACC,QAAAA;MAAOC,SAASnB;OACf,sBAAA,cAACoB,QAAAA;MAAKC,WAAU;OAAQzB,EAAE,4BAAA,CAAA,GAC1B,sBAAA,cAAC0B,MAAAA;MAAKC,MAAK;;;;;AAKrB;;;AC9DA,IAAA,0BAAeC;",
|
|
6
|
+
"names": ["pipe", "React", "useCallback", "chain", "createIntent", "LayoutAction", "useIntentDispatcher", "isInstanceOf", "fullyQualifiedId", "Button", "Icon", "useTranslation", "Card", "DataType", "getTitle", "subject", "fallback", "isInstanceOf", "DocumentType", "name", "fallbackName", "getFallbackName", "content", "target", "DataType", "Text", "getSnippet", "getAbstract", "MarkdownPreview", "role", "dispatchPromise", "dispatch", "useIntentDispatcher", "t", "useTranslation", "MARKDOWN_PLUGIN", "snippet", "handleNavigate", "useCallback", "pipe", "createIntent", "LayoutAction", "UpdatePopover", "part", "options", "state", "anchorId", "chain", "Open", "fullyQualifiedId", "Card", "Container", "Heading", "classNames", "Chrome", "Button", "onClick", "span", "className", "Icon", "icon", "MarkdownPreview"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
DocumentType
|
|
4
|
+
} from "./chunk-NCMPVEXO.mjs";
|
|
5
|
+
import "./chunk-RX63ZNML.mjs";
|
|
6
|
+
|
|
7
|
+
// packages/plugins/plugin-markdown/src/capabilities/anchor-sort.ts
|
|
8
|
+
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
9
|
+
import { getSchemaTypename } from "@dxos/echo-schema";
|
|
10
|
+
import { createDocAccessor, getRangeFromCursor, getTarget } from "@dxos/react-client/echo";
|
|
11
|
+
var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
|
|
12
|
+
key: getSchemaTypename(DocumentType),
|
|
13
|
+
sort: (anchorA, anchorB) => {
|
|
14
|
+
const doc = getTarget(anchorA);
|
|
15
|
+
const accessor = doc.content.target ? createDocAccessor(doc.content.target, [
|
|
16
|
+
"content"
|
|
17
|
+
]) : void 0;
|
|
18
|
+
if (doc !== getTarget(anchorB) || !accessor) {
|
|
19
|
+
return 0;
|
|
20
|
+
}
|
|
21
|
+
const getStartPosition = (cursor) => {
|
|
22
|
+
const range = cursor ? getRangeFromCursor(accessor, cursor) : void 0;
|
|
23
|
+
return range?.start ?? Number.MAX_SAFE_INTEGER;
|
|
24
|
+
};
|
|
25
|
+
const posA = getStartPosition(anchorA.anchor);
|
|
26
|
+
const posB = getStartPosition(anchorB.anchor);
|
|
27
|
+
return posA - posB;
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
export {
|
|
31
|
+
anchor_sort_default as default
|
|
32
|
+
};
|
|
33
|
+
//# sourceMappingURL=anchor-sort-G2HLCYFK.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/anchor-sort.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes } from '@dxos/app-framework';\nimport { getSchemaTypename } from '@dxos/echo-schema';\nimport { createDocAccessor, getRangeFromCursor, getTarget } from '@dxos/react-client/echo';\n\nimport { DocumentType } from '../types';\n\nexport default () =>\n contributes(Capabilities.AnchorSort, {\n key: getSchemaTypename(DocumentType)!,\n sort: (anchorA, anchorB) => {\n const doc = getTarget(anchorA) as DocumentType;\n const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;\n if (doc !== getTarget(anchorB) || !accessor) {\n return 0;\n }\n\n const getStartPosition = (cursor: string | undefined) => {\n const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;\n return range?.start ?? Number.MAX_SAFE_INTEGER;\n };\n\n const posA = getStartPosition(anchorA.anchor);\n const posB = getStartPosition(anchorB.anchor);\n return posA - posB;\n },\n });\n"],
|
|
5
|
+
"mappings": ";;;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,yBAAyB;AAClC,SAASC,mBAAmBC,oBAAoBC,iBAAiB;AAIjE,IAAA,sBAAe,MACbC,YAAYC,aAAaC,YAAY;EACnCC,KAAKC,kBAAkBC,YAAAA;EACvBC,MAAM,CAACC,SAASC,YAAAA;AACd,UAAMC,MAAMC,UAAUH,OAAAA;AACtB,UAAMI,WAAWF,IAAIG,QAAQC,SAASC,kBAAkBL,IAAIG,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIN,QAAQC,UAAUF,OAAAA,KAAY,CAACG,UAAU;AAC3C,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBT,QAAQiB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBR,QAAQgB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA;",
|
|
6
|
+
"names": ["Capabilities", "contributes", "getSchemaTypename", "createDocAccessor", "getRangeFromCursor", "getTarget", "contributes", "Capabilities", "AnchorSort", "key", "getSchemaTypename", "DocumentType", "sort", "anchorA", "anchorB", "doc", "getTarget", "accessor", "content", "target", "createDocAccessor", "undefined", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "posA", "anchor", "posB"]
|
|
7
|
+
}
|
package/dist/lib/node-esm/{app-graph-serializer-QQ2CTHOQ.mjs → app-graph-serializer-C3RNTQGM.mjs}
RENAMED
|
@@ -1,22 +1,21 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
translations_default
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-TCFJNUAE.mjs";
|
|
5
5
|
import {
|
|
6
6
|
DocumentType,
|
|
7
7
|
MarkdownAction
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-NCMPVEXO.mjs";
|
|
9
9
|
import "./chunk-RX63ZNML.mjs";
|
|
10
10
|
|
|
11
11
|
// packages/plugins/plugin-markdown/src/capabilities/app-graph-serializer.ts
|
|
12
12
|
import { pipe } from "effect";
|
|
13
13
|
import { contributes, Capabilities, chain, createIntent } from "@dxos/app-framework";
|
|
14
|
-
import { getSchemaTypename } from "@dxos/echo-schema";
|
|
15
14
|
import { SpaceAction, CollectionType } from "@dxos/plugin-space/types";
|
|
16
15
|
import { isSpace } from "@dxos/react-client/echo";
|
|
17
16
|
var app_graph_serializer_default = (context) => contributes(Capabilities.AppGraphSerializer, [
|
|
18
17
|
{
|
|
19
|
-
inputType:
|
|
18
|
+
inputType: DocumentType.typename,
|
|
20
19
|
outputType: "text/markdown",
|
|
21
20
|
// Reconcile with metadata serializers.
|
|
22
21
|
serialize: async (node) => {
|
|
@@ -34,7 +33,7 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
34
33
|
if (!space || !target) {
|
|
35
34
|
return;
|
|
36
35
|
}
|
|
37
|
-
const { dispatchPromise: dispatch } = context.
|
|
36
|
+
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
38
37
|
const result = await dispatch(pipe(createIntent(MarkdownAction.Create, {
|
|
39
38
|
spaceId: space.id,
|
|
40
39
|
name: data.name,
|
|
@@ -49,4 +48,4 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
49
48
|
export {
|
|
50
49
|
app_graph_serializer_default as default
|
|
51
50
|
};
|
|
52
|
-
//# sourceMappingURL=app-graph-serializer-
|
|
51
|
+
//# sourceMappingURL=app-graph-serializer-C3RNTQGM.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/app-graph-serializer.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe } from 'effect';\n\nimport { contributes, Capabilities, type PluginContext, chain, createIntent } from '@dxos/app-framework';\nimport { SpaceAction, CollectionType } from '@dxos/plugin-space/types';\nimport { isSpace } from '@dxos/react-client/echo';\n\nimport translations from '../translations';\nimport { MarkdownAction, DocumentType } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.AppGraphSerializer, [\n {\n inputType: DocumentType.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await doc.content.load();\n return {\n name:\n doc.name || doc.fallbackName || translations[0]['en-US'][DocumentType.typename]['object name placeholder'],\n data: content.content,\n type: 'text/markdown',\n };\n },\n deserialize: async (data, ancestors) => {\n const space = ancestors.find(isSpace);\n const target =\n ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ??\n space?.properties[CollectionType.typename]?.target;\n if (!space || !target) {\n return;\n }\n\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const result = await dispatch(\n pipe(\n createIntent(MarkdownAction.Create, { spaceId: space.id, name: data.name, content: data.data }),\n chain(SpaceAction.AddObject, { target }),\n ),\n );\n\n return result.data?.object;\n },\n },\n ]);\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;AAIA,SAASA,YAAY;AAErB,SAASC,aAAaC,cAAkCC,OAAOC,oBAAoB;AACnF,SAASC,aAAaC,sBAAsB;AAC5C,SAASC,eAAe;AAKxB,IAAA,+BAAe,CAACC,YACdC,YAAYC,aAAaC,oBAAoB;EAC3C;IACEC,WAAWC,aAAaC;IACxBC,YAAY;;IAEZC,WAAW,OAAOC,SAAAA;AAChB,YAAMC,MAAMD,KAAKE;AACjB,YAAMC,UAAU,MAAMF,IAAIE,QAAQC,KAAI;AACtC,aAAO;QACLC,MACEJ,IAAII,QAAQJ,IAAIK,gBAAgBC,qBAAa,CAAA,EAAG,OAAA,EAASX,aAAaC,QAAQ,EAAE,yBAAA;QAClFK,MAAMC,QAAQA;QACdK,MAAM;MACR;IACF;IACAC,aAAa,OAAOP,MAAMQ,cAAAA;AACxB,YAAMC,QAAQD,UAAUE,KAAKC,OAAAA;AAC7B,YAAMC,SACJJ,UAAUK,SAAS,CAACC,aAAaA,oBAAoBC,cAAAA,KACrDN,OAAOO,WAAWD,eAAepB,QAAQ,GAAGiB;AAC9C,UAAI,CAACH,SAAS,CAACG,QAAQ;AACrB;MACF;AAEA,YAAM,EAAEK,iBAAiBC,SAAQ,IAAK7B,QAAQ8B,cAAc5B,aAAa6B,gBAAgB;AACzF,YAAMC,SAAS,MAAMH,SACnBI,KACEC,aAAaC,eAAeC,QAAQ;QAAEC,SAASjB,MAAMkB;QAAIxB,MAAMH,KAAKG;QAAMF,SAASD,KAAKA;MAAK,CAAA,GAC7F4B,MAAMC,YAAYC,WAAW;QAAElB;MAAO,CAAA,CAAA,CAAA;AAI1C,aAAOS,OAAOrB,MAAM+B;IACtB;EACF;CACD;",
|
|
6
|
+
"names": ["pipe", "contributes", "Capabilities", "chain", "createIntent", "SpaceAction", "CollectionType", "isSpace", "context", "contributes", "Capabilities", "AppGraphSerializer", "inputType", "DocumentType", "typename", "outputType", "serialize", "node", "doc", "data", "content", "load", "name", "fallbackName", "translations", "type", "deserialize", "ancestors", "space", "find", "isSpace", "target", "findLast", "ancestor", "CollectionType", "properties", "dispatchPromise", "dispatch", "getCapability", "IntentDispatcher", "result", "pipe", "createIntent", "MarkdownAction", "Create", "spaceId", "id", "chain", "SpaceAction", "AddObject", "object"]
|
|
7
|
+
}
|
package/dist/lib/node-esm/{artifact-definition-WRG5ZRN5.mjs → artifact-definition-7TIJW2CO.mjs}
RENAMED
|
@@ -1,16 +1,21 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
|
-
DocumentType
|
|
4
|
-
|
|
3
|
+
DocumentType,
|
|
4
|
+
MarkdownAction
|
|
5
|
+
} from "./chunk-NCMPVEXO.mjs";
|
|
5
6
|
import {
|
|
6
7
|
meta
|
|
7
8
|
} from "./chunk-RX63ZNML.mjs";
|
|
8
9
|
|
|
9
10
|
// packages/plugins/plugin-markdown/src/capabilities/artifact-definition.ts
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
11
|
+
import { pipe, Schema } from "effect";
|
|
12
|
+
import { createTool, ToolResult } from "@dxos/ai";
|
|
13
|
+
import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
|
|
14
|
+
import { ArtifactId, defineArtifact } from "@dxos/artifact";
|
|
15
|
+
import { createArtifactElement } from "@dxos/assistant";
|
|
16
|
+
import { isInstanceOf } from "@dxos/echo-schema";
|
|
13
17
|
import { invariant, assertArgument } from "@dxos/invariant";
|
|
18
|
+
import { SpaceAction } from "@dxos/plugin-space/types";
|
|
14
19
|
import { Filter, fullyQualifiedId } from "@dxos/react-client/echo";
|
|
15
20
|
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-markdown/src/capabilities/artifact-definition.ts";
|
|
16
21
|
var artifact_definition_default = () => {
|
|
@@ -24,15 +29,60 @@ var artifact_definition_default = () => {
|
|
|
24
29
|
`,
|
|
25
30
|
schema: DocumentType,
|
|
26
31
|
tools: [
|
|
27
|
-
|
|
32
|
+
createTool(meta.id, {
|
|
33
|
+
name: "create",
|
|
34
|
+
description: "Create a new markdown document",
|
|
35
|
+
caption: "Creating document...",
|
|
36
|
+
schema: Schema.Struct({
|
|
37
|
+
name: Schema.optional(Schema.String).annotations({
|
|
38
|
+
description: "Optional name for the document."
|
|
39
|
+
}),
|
|
40
|
+
content: Schema.String.annotations({
|
|
41
|
+
description: "The content of the document."
|
|
42
|
+
})
|
|
43
|
+
}),
|
|
44
|
+
execute: async ({ name, content }, { extensions }) => {
|
|
45
|
+
invariant(extensions?.space, "No space", {
|
|
46
|
+
F: __dxlog_file,
|
|
47
|
+
L: 51,
|
|
48
|
+
S: void 0,
|
|
49
|
+
A: [
|
|
50
|
+
"extensions?.space",
|
|
51
|
+
"'No space'"
|
|
52
|
+
]
|
|
53
|
+
});
|
|
54
|
+
invariant(extensions?.dispatch, "No intent dispatcher", {
|
|
55
|
+
F: __dxlog_file,
|
|
56
|
+
L: 52,
|
|
57
|
+
S: void 0,
|
|
58
|
+
A: [
|
|
59
|
+
"extensions?.dispatch",
|
|
60
|
+
"'No intent dispatcher'"
|
|
61
|
+
]
|
|
62
|
+
});
|
|
63
|
+
const intent = pipe(createIntent(MarkdownAction.Create, {
|
|
64
|
+
spaceId: extensions.space.id,
|
|
65
|
+
name,
|
|
66
|
+
content
|
|
67
|
+
}), chain(SpaceAction.AddObject, {
|
|
68
|
+
target: extensions.space
|
|
69
|
+
}));
|
|
70
|
+
const { data, error } = await extensions.dispatch(intent);
|
|
71
|
+
if (!data || error) {
|
|
72
|
+
return ToolResult.Error(error?.message ?? "Failed to create document");
|
|
73
|
+
}
|
|
74
|
+
return ToolResult.Success(createArtifactElement(data.id));
|
|
75
|
+
}
|
|
76
|
+
}),
|
|
77
|
+
createTool(meta.id, {
|
|
28
78
|
name: "list",
|
|
29
79
|
description: "List all markdown documents in the current space.",
|
|
30
80
|
caption: "Listing markdown documents...",
|
|
31
|
-
schema:
|
|
81
|
+
schema: Schema.Struct({}),
|
|
32
82
|
execute: async (_input, { extensions }) => {
|
|
33
83
|
invariant(extensions?.space, "No space", {
|
|
34
84
|
F: __dxlog_file,
|
|
35
|
-
L:
|
|
85
|
+
L: 77,
|
|
36
86
|
S: void 0,
|
|
37
87
|
A: [
|
|
38
88
|
"extensions?.space",
|
|
@@ -40,11 +90,11 @@ var artifact_definition_default = () => {
|
|
|
40
90
|
]
|
|
41
91
|
});
|
|
42
92
|
const space = extensions.space;
|
|
43
|
-
const { objects: documents } = await space.db.query(Filter.
|
|
93
|
+
const { objects: documents } = await space.db.query(Filter.type(DocumentType)).run();
|
|
44
94
|
const documentInfo = documents.map((doc) => {
|
|
45
95
|
invariant(isInstanceOf(DocumentType, doc), void 0, {
|
|
46
96
|
F: __dxlog_file,
|
|
47
|
-
L:
|
|
97
|
+
L: 81,
|
|
48
98
|
S: void 0,
|
|
49
99
|
A: [
|
|
50
100
|
"isInstanceOf(DocumentType, doc)",
|
|
@@ -59,26 +109,24 @@ var artifact_definition_default = () => {
|
|
|
59
109
|
return ToolResult.Success(documentInfo);
|
|
60
110
|
}
|
|
61
111
|
}),
|
|
62
|
-
|
|
112
|
+
createTool(meta.id, {
|
|
63
113
|
name: "inspect",
|
|
64
114
|
description: "Read the content of a markdown document.",
|
|
65
115
|
caption: "Inspecting markdown document...",
|
|
66
|
-
schema:
|
|
116
|
+
schema: Schema.Struct({
|
|
67
117
|
id: ArtifactId
|
|
68
118
|
}),
|
|
69
119
|
execute: async ({ id }, { extensions }) => {
|
|
70
120
|
invariant(extensions?.space, "No space", {
|
|
71
121
|
F: __dxlog_file,
|
|
72
|
-
L:
|
|
122
|
+
L: 100,
|
|
73
123
|
S: void 0,
|
|
74
124
|
A: [
|
|
75
125
|
"extensions?.space",
|
|
76
126
|
"'No space'"
|
|
77
127
|
]
|
|
78
128
|
});
|
|
79
|
-
const document = await extensions.space.db.query(
|
|
80
|
-
id: ArtifactId.toDXN(id).toString()
|
|
81
|
-
}).first();
|
|
129
|
+
const document = await extensions.space.db.query(Filter.ids(ArtifactId.toDXN(id).toString())).first();
|
|
82
130
|
assertArgument(isInstanceOf(DocumentType, document), "Invalid type");
|
|
83
131
|
const { content } = await document.content?.load();
|
|
84
132
|
return ToolResult.Success({
|
|
@@ -95,4 +143,4 @@ var artifact_definition_default = () => {
|
|
|
95
143
|
export {
|
|
96
144
|
artifact_definition_default as default
|
|
97
145
|
};
|
|
98
|
-
//# sourceMappingURL=artifact-definition-
|
|
146
|
+
//# sourceMappingURL=artifact-definition-7TIJW2CO.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/artifact-definition.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe, Schema } from 'effect';\n\nimport { createTool, ToolResult } from '@dxos/ai';\nimport { Capabilities, chain, contributes, createIntent, type PromiseIntentDispatcher } from '@dxos/app-framework';\nimport { ArtifactId, defineArtifact } from '@dxos/artifact';\nimport { createArtifactElement } from '@dxos/assistant';\nimport { isInstanceOf } from '@dxos/echo-schema';\nimport { invariant, assertArgument } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter, fullyQualifiedId, type Space } from '@dxos/react-client/echo';\n\nimport { meta } from '../meta';\nimport { DocumentType, MarkdownAction } from '../types';\n\n// TODO(burdon): Factor out.\ndeclare global {\n interface ToolContextExtensions {\n space?: Space;\n dispatch?: PromiseIntentDispatcher;\n }\n}\n\nexport default () => {\n const definition = defineArtifact({\n id: `artifact:${meta.id}`,\n name: meta.name,\n instructions: `\n - The markdown plugin allows you to work with text documents in the current space.\n - Use these tools to interact with documents, including listing available documents and retrieving their content.\n - Documents are stored in Markdown format.\n `,\n schema: DocumentType,\n tools: [\n createTool(meta.id, {\n name: 'create',\n description: 'Create a new markdown document',\n caption: 'Creating document...',\n schema: Schema.Struct({\n name: Schema.optional(Schema.String).annotations({\n description: 'Optional name for the document.',\n }),\n content: Schema.String.annotations({\n description: 'The content of the document.',\n }),\n }),\n execute: async ({ name, content }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n invariant(extensions?.dispatch, 'No intent dispatcher');\n\n const intent = pipe(\n createIntent(MarkdownAction.Create, {\n spaceId: extensions.space.id,\n name,\n content,\n }),\n chain(SpaceAction.AddObject, { target: extensions.space }),\n );\n\n const { data, error } = await extensions.dispatch(intent);\n if (!data || error) {\n return ToolResult.Error(error?.message ?? 'Failed to create document');\n }\n\n return ToolResult.Success(createArtifactElement(data.id));\n },\n }),\n createTool(meta.id, {\n name: 'list',\n description: 'List all markdown documents in the current space.',\n caption: 'Listing markdown documents...',\n schema: Schema.Struct({}),\n execute: async (_input, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const space = extensions.space;\n const { objects: documents } = await space.db.query(Filter.type(DocumentType)).run();\n const documentInfo = documents.map((doc) => {\n invariant(isInstanceOf(DocumentType, doc));\n return {\n id: fullyQualifiedId(doc),\n name: doc.name || doc.fallbackName || 'Unnamed Document',\n // TODO(ZaymonFC): Include updatedAt?\n };\n });\n\n return ToolResult.Success(documentInfo);\n },\n }),\n createTool(meta.id, {\n name: 'inspect',\n description: 'Read the content of a markdown document.',\n caption: 'Inspecting markdown document...',\n schema: Schema.Struct({\n id: ArtifactId,\n }),\n execute: async ({ id }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const document = await extensions.space.db.query(Filter.ids(ArtifactId.toDXN(id).toString())).first();\n assertArgument(isInstanceOf(DocumentType, document), 'Invalid type');\n\n const { content } = await document.content?.load();\n return ToolResult.Success({\n id: fullyQualifiedId(document),\n name: document.name || document.fallbackName || 'Unnamed Document',\n content,\n });\n },\n }),\n ],\n });\n\n return contributes(Capabilities.ArtifactDefinition, definition);\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["pipe", "Schema", "createTool", "ToolResult", "Capabilities", "chain", "contributes", "createIntent", "ArtifactId", "defineArtifact", "createArtifactElement", "isInstanceOf", "invariant", "assertArgument", "SpaceAction", "Filter", "fullyQualifiedId", "definition", "defineArtifact", "id", "meta", "name", "instructions", "schema", "DocumentType", "tools", "createTool", "description", "caption", "Schema", "Struct", "optional", "String", "annotations", "content", "execute", "extensions", "invariant", "space", "dispatch", "intent", "pipe", "createIntent", "MarkdownAction", "Create", "spaceId", "chain", "SpaceAction", "AddObject", "target", "data", "error", "ToolResult", "Error", "message", "Success", "createArtifactElement", "_input", "objects", "documents", "db", "query", "Filter", "type", "run", "documentInfo", "map", "doc", "isInstanceOf", "fullyQualifiedId", "fallbackName", "ArtifactId", "document", "ids", "toDXN", "toString", "first", "assertArgument", "load", "contributes", "Capabilities", "ArtifactDefinition"]
|
|
7
|
+
}
|
|
@@ -1,17 +1,20 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
DocumentType
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-NCMPVEXO.mjs";
|
|
5
5
|
|
|
6
6
|
// packages/plugins/plugin-markdown/src/util.tsx
|
|
7
7
|
import { debounce } from "@dxos/async";
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
8
|
+
import { live, createObject, isEchoObject, loadObjectReferences, Ref } from "@dxos/react-client/echo";
|
|
9
|
+
import { DataType } from "@dxos/schema";
|
|
10
10
|
var isMarkdownProperties = (data) => isEchoObject(data) ? true : data && typeof data === "object" ? "title" in data && typeof data.title === "string" : false;
|
|
11
11
|
var nonTitleChars = /[^\w ]/g;
|
|
12
12
|
var getFallbackName = (content) => {
|
|
13
13
|
return content.substring(0, 31).split("\n")[0].replaceAll(nonTitleChars, "").trim();
|
|
14
14
|
};
|
|
15
|
+
var getAbstract = (content) => {
|
|
16
|
+
return content.substring(0, 128).split("\n")[0].replaceAll(nonTitleChars, "").trim();
|
|
17
|
+
};
|
|
15
18
|
var setFallbackName = debounce((doc, content) => {
|
|
16
19
|
const name = getFallbackName(content);
|
|
17
20
|
if (doc.fallbackName !== name) {
|
|
@@ -29,38 +32,21 @@ var serializer = {
|
|
|
29
32
|
},
|
|
30
33
|
deserialize: async ({ content: serialized }) => {
|
|
31
34
|
const { name, fallbackName, content } = JSON.parse(serialized);
|
|
32
|
-
return createObject(
|
|
35
|
+
return createObject(live(DocumentType, {
|
|
33
36
|
name,
|
|
34
37
|
fallbackName,
|
|
35
|
-
content:
|
|
38
|
+
content: Ref.make(live(DataType.Text, {
|
|
36
39
|
content
|
|
37
|
-
}))
|
|
38
|
-
threads: []
|
|
40
|
+
}))
|
|
39
41
|
}));
|
|
40
42
|
}
|
|
41
43
|
};
|
|
42
44
|
|
|
43
|
-
// packages/plugins/plugin-markdown/src/capabilities/index.ts
|
|
44
|
-
import { lazy } from "@dxos/app-framework";
|
|
45
|
-
var AppGraphSerializer = lazy(() => import("./app-graph-serializer-QQ2CTHOQ.mjs"));
|
|
46
|
-
var ArtifactDefinition = lazy(() => import("./artifact-definition-WRG5ZRN5.mjs"));
|
|
47
|
-
var IntentResolver = lazy(() => import("./intent-resolver-7HOMUVHR.mjs"));
|
|
48
|
-
var ReactSurface = lazy(() => import("./react-surface-6IKC3G46.mjs"));
|
|
49
|
-
var MarkdownSettings = lazy(() => import("./settings-ZDIFTK4N.mjs"));
|
|
50
|
-
var MarkdownState = lazy(() => import("./state-DWPOKLEY.mjs"));
|
|
51
|
-
var Thread = lazy(() => import("./thread-R2KHZD6V.mjs"));
|
|
52
|
-
|
|
53
45
|
export {
|
|
54
46
|
isMarkdownProperties,
|
|
55
47
|
getFallbackName,
|
|
48
|
+
getAbstract,
|
|
56
49
|
setFallbackName,
|
|
57
|
-
serializer
|
|
58
|
-
AppGraphSerializer,
|
|
59
|
-
ArtifactDefinition,
|
|
60
|
-
IntentResolver,
|
|
61
|
-
ReactSurface,
|
|
62
|
-
MarkdownSettings,
|
|
63
|
-
MarkdownState,
|
|
64
|
-
Thread
|
|
50
|
+
serializer
|
|
65
51
|
};
|
|
66
|
-
//# sourceMappingURL=chunk-
|
|
52
|
+
//# sourceMappingURL=chunk-6RPARLIK.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/util.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { debounce } from '@dxos/async';\nimport { type TypedObjectSerializer } from '@dxos/plugin-space/types';\nimport { live, createObject, isEchoObject, loadObjectReferences, Ref } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { DocumentType, type MarkdownProperties } from './types';\n\nexport const isMarkdownProperties = (data: unknown): data is MarkdownProperties =>\n (isEchoObject(data) as boolean)\n ? true\n : data && typeof data === 'object'\n ? 'title' in data && typeof data.title === 'string'\n : false;\n\nconst nonTitleChars = /[^\\w ]/g;\n\nexport const getFallbackName = (content: string) => {\n return content.substring(0, 31).split('\\n')[0].replaceAll(nonTitleChars, '').trim();\n};\n\nexport const getAbstract = (content: string) => {\n return content.substring(0, 128).split('\\n')[0].replaceAll(nonTitleChars, '').trim();\n};\n\nexport const setFallbackName = debounce((doc: DocumentType, content: string) => {\n const name = getFallbackName(content);\n if (doc.fallbackName !== name) {\n doc.fallbackName = name;\n }\n}, 200);\n\nexport const serializer: TypedObjectSerializer<DocumentType> = {\n serialize: async ({ object }): Promise<string> => {\n const content = await loadObjectReferences(object, (doc) => doc.content);\n return JSON.stringify({ name: object.name, fallbackName: object.fallbackName, content: content.target?.content });\n },\n\n deserialize: async ({ content: serialized }) => {\n const { name, fallbackName, content } = JSON.parse(serialized);\n return createObject(\n live(DocumentType, { name, fallbackName, content: Ref.make(live(DataType.Text, { content })) }),\n );\n },\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;AAIA,SAASA,gBAAgB;AAEzB,SAASC,MAAMC,cAAcC,cAAcC,sBAAsBC,WAAW;AAC5E,SAASC,gBAAgB;AAIlB,IAAMC,uBAAuB,CAACC,SAClCC,aAAaD,IAAAA,IACV,OACAA,QAAQ,OAAOA,SAAS,WACtB,WAAWA,QAAQ,OAAOA,KAAKE,UAAU,WACzC;AAER,IAAMC,gBAAgB;AAEf,IAAMC,kBAAkB,CAACC,YAAAA;AAC9B,SAAOA,QAAQC,UAAU,GAAG,EAAA,EAAIC,MAAM,IAAA,EAAM,CAAA,EAAGC,WAAWL,eAAe,EAAA,EAAIM,KAAI;AACnF;AAEO,IAAMC,cAAc,CAACL,YAAAA;AAC1B,SAAOA,QAAQC,UAAU,GAAG,GAAA,EAAKC,MAAM,IAAA,EAAM,CAAA,EAAGC,WAAWL,eAAe,EAAA,EAAIM,KAAI;AACpF;AAEO,IAAME,kBAAkBC,SAAS,CAACC,KAAmBR,YAAAA;AAC1D,QAAMS,OAAOV,gBAAgBC,OAAAA;AAC7B,MAAIQ,IAAIE,iBAAiBD,MAAM;AAC7BD,QAAIE,eAAeD;EACrB;AACF,GAAG,GAAA;AAEI,IAAME,aAAkD;EAC7DC,WAAW,OAAO,EAAEC,OAAM,MAAE;AAC1B,UAAMb,UAAU,MAAMc,qBAAqBD,QAAQ,CAACL,QAAQA,IAAIR,OAAO;AACvE,WAAOe,KAAKC,UAAU;MAAEP,MAAMI,OAAOJ;MAAMC,cAAcG,OAAOH;MAAcV,SAASA,QAAQiB,QAAQjB;IAAQ,CAAA;EACjH;EAEAkB,aAAa,OAAO,EAAElB,SAASmB,WAAU,MAAE;AACzC,UAAM,EAAEV,MAAMC,cAAcV,QAAO,IAAKe,KAAKK,MAAMD,UAAAA;AACnD,WAAOE,aACLC,KAAKC,cAAc;MAAEd;MAAMC;MAAcV,SAASwB,IAAIC,KAAKH,KAAKI,SAASC,MAAM;QAAE3B;MAAQ,CAAA,CAAA;IAAI,CAAA,CAAA;EAEjG;AACF;",
|
|
6
|
+
"names": ["debounce", "live", "createObject", "isEchoObject", "loadObjectReferences", "Ref", "DataType", "isMarkdownProperties", "data", "isEchoObject", "title", "nonTitleChars", "getFallbackName", "content", "substring", "split", "replaceAll", "trim", "getAbstract", "setFallbackName", "debounce", "doc", "name", "fallbackName", "serializer", "serialize", "object", "loadObjectReferences", "JSON", "stringify", "target", "deserialize", "serialized", "parse", "createObject", "live", "DocumentType", "Ref", "make", "DataType", "Text"]
|
|
7
|
+
}
|
|
@@ -5,13 +5,13 @@ import {
|
|
|
5
5
|
|
|
6
6
|
// packages/plugins/plugin-markdown/src/capabilities/capabilities.ts
|
|
7
7
|
import { defineCapability } from "@dxos/app-framework";
|
|
8
|
-
var MarkdownCapabilities;
|
|
9
8
|
(function(MarkdownCapabilities2) {
|
|
10
9
|
MarkdownCapabilities2.State = defineCapability(`${MARKDOWN_PLUGIN}/capability/state`);
|
|
11
10
|
MarkdownCapabilities2.Extensions = defineCapability(`${MARKDOWN_PLUGIN}/capability/extensions`);
|
|
12
11
|
})(MarkdownCapabilities || (MarkdownCapabilities = {}));
|
|
12
|
+
var MarkdownCapabilities;
|
|
13
13
|
|
|
14
14
|
export {
|
|
15
15
|
MarkdownCapabilities
|
|
16
16
|
};
|
|
17
|
-
//# sourceMappingURL=chunk-
|
|
17
|
+
//# sourceMappingURL=chunk-JXXDCSMW.mjs.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/capabilities/capabilities.ts"],
|
|
4
4
|
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { defineCapability } from '@dxos/app-framework';\nimport { type EditorViewMode, type EditorStateStore } from '@dxos/react-ui-editor';\n\nimport { MARKDOWN_PLUGIN } 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 setViewMode: (id: string, viewMode: EditorViewMode) => void;\n }>(`${MARKDOWN_PLUGIN}/capability/state`);\n\n export const Extensions = defineCapability<MarkdownExtensionProvider[]>(`${MARKDOWN_PLUGIN}/capability/extensions`);\n}\n"],
|
|
5
|
-
"mappings": "
|
|
5
|
+
"mappings": ";;;;;;AAIA,SAASA,wBAAwB;UAMhBC,uBAAAA;wBACFC,QAAQC,iBAKlB,GAAGC,eAAAA,mBAAkC;wBAE3BC,aAAaF,iBAA8C,GAAGC,eAAAA,wBAAuC;AACpH,GATiBH,yBAAAA,uBAAAA,CAAAA,EAAAA;;",
|
|
6
6
|
"names": ["defineCapability", "MarkdownCapabilities", "State", "defineCapability", "MARKDOWN_PLUGIN", "Extensions"]
|
|
7
7
|
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
|
|
3
|
+
// packages/plugins/plugin-markdown/src/capabilities/index.ts
|
|
4
|
+
import { lazy } from "@dxos/app-framework";
|
|
5
|
+
var AnchorSort = lazy(() => import("./anchor-sort-G2HLCYFK.mjs"));
|
|
6
|
+
var AppGraphSerializer = lazy(() => import("./app-graph-serializer-C3RNTQGM.mjs"));
|
|
7
|
+
var ArtifactDefinition = lazy(() => import("./artifact-definition-7TIJW2CO.mjs"));
|
|
8
|
+
var IntentResolver = lazy(() => import("./intent-resolver-FTNXUNI2.mjs"));
|
|
9
|
+
var ReactSurface = lazy(() => import("./react-surface-A4VAOQG6.mjs"));
|
|
10
|
+
var MarkdownSettings = lazy(() => import("./settings-MK7D7LHQ.mjs"));
|
|
11
|
+
var MarkdownState = lazy(() => import("./state-LLGVRYKL.mjs"));
|
|
12
|
+
|
|
13
|
+
export {
|
|
14
|
+
AnchorSort,
|
|
15
|
+
AppGraphSerializer,
|
|
16
|
+
ArtifactDefinition,
|
|
17
|
+
IntentResolver,
|
|
18
|
+
ReactSurface,
|
|
19
|
+
MarkdownSettings,
|
|
20
|
+
MarkdownState
|
|
21
|
+
};
|
|
22
|
+
//# sourceMappingURL=chunk-KK7LP3UQ.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AnchorSort = lazy(() => import('./anchor-sort'));\nexport const AppGraphSerializer = lazy(() => import('./app-graph-serializer'));\nexport const ArtifactDefinition = lazy(() => import('./artifact-definition'));\nexport const IntentResolver = lazy(() => import('./intent-resolver'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\nexport const MarkdownSettings = lazy(() => import('./settings'));\nexport const MarkdownState = lazy(() => import('./state'));\n\nexport * from './capabilities';\n"],
|
|
5
|
+
"mappings": ";;;AAIA,SAASA,YAAY;AAEd,IAAMC,aAAaC,KAAK,MAAM,OAAO,4BAAA,CAAA;AACrC,IAAMC,qBAAqBD,KAAK,MAAM,OAAO,qCAAA,CAAA;AAC7C,IAAME,qBAAqBF,KAAK,MAAM,OAAO,oCAAA,CAAA;AAC7C,IAAMG,iBAAiBH,KAAK,MAAM,OAAO,gCAAA,CAAA;AACzC,IAAMI,eAAeJ,KAAK,MAAM,OAAO,8BAAA,CAAA;AACvC,IAAMK,mBAAmBL,KAAK,MAAM,OAAO,yBAAA,CAAA;AAC3C,IAAMM,gBAAgBN,KAAK,MAAM,OAAO,sBAAA,CAAA;",
|
|
6
|
+
"names": ["lazy", "AnchorSort", "lazy", "AppGraphSerializer", "ArtifactDefinition", "IntentResolver", "ReactSurface", "MarkdownSettings", "MarkdownState"]
|
|
7
|
+
}
|