@dxos/plugin-markdown 0.8.3 → 0.8.4-main.c1de068
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-EFWQ6DHD.mjs → MarkdownContainer-F3WEEIBX.mjs} +31 -23
- package/dist/lib/browser/MarkdownContainer-F3WEEIBX.mjs.map +7 -0
- package/dist/lib/browser/{MarkdownPreview-F4PYFW5L.mjs → MarkdownPreview-S3C7CGAV.mjs} +8 -8
- package/dist/lib/browser/{MarkdownPreview-F4PYFW5L.mjs.map → MarkdownPreview-S3C7CGAV.mjs.map} +3 -3
- package/dist/lib/browser/{anchor-sort-BMAN2ABT.mjs → anchor-sort-UKJJ7ZNP.mjs} +4 -4
- package/dist/lib/browser/{app-graph-serializer-EI6TEHRQ.mjs → app-graph-serializer-ICLAF662.mjs} +9 -9
- package/dist/lib/browser/app-graph-serializer-ICLAF662.mjs.map +7 -0
- package/dist/lib/browser/{artifact-definition-FQ2R6KPT.mjs → artifact-definition-R2YYWOPN.mjs} +7 -7
- package/dist/lib/browser/artifact-definition-R2YYWOPN.mjs.map +7 -0
- package/dist/lib/browser/{chunk-QVJETNGS.mjs → chunk-777RIED6.mjs} +3 -3
- package/dist/lib/browser/{chunk-JX6XNEHE.mjs → chunk-EPTSAJZM.mjs} +2 -2
- package/dist/lib/browser/{chunk-LXSRQPEP.mjs → chunk-LFML7LC6.mjs} +3 -3
- package/dist/lib/browser/{chunk-D767LUGU.mjs → chunk-LHDCHDBW.mjs} +12 -11
- package/dist/lib/browser/chunk-LHDCHDBW.mjs.map +7 -0
- package/dist/lib/browser/chunk-PHTD5DTR.mjs +20 -0
- package/dist/lib/browser/{chunk-N2D26K6W.mjs → chunk-UANWRJZU.mjs} +5 -5
- package/dist/lib/browser/chunk-UANWRJZU.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +10 -10
- package/dist/lib/browser/index.mjs.map +1 -1
- package/dist/lib/browser/{intent-resolver-6ZOABX2J.mjs → intent-resolver-3MXYO3MW.mjs} +5 -5
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-4B5ELMEW.mjs → react-surface-C3Z423TV.mjs} +15 -14
- package/dist/lib/browser/{react-surface-4B5ELMEW.mjs.map → react-surface-C3Z423TV.mjs.map} +2 -2
- package/dist/lib/browser/{settings-PLH54VC7.mjs → settings-KN75ZQY6.mjs} +4 -4
- package/dist/lib/browser/{state-KI6PJ6DT.mjs → state-LZWTAS65.mjs} +4 -4
- package/dist/lib/browser/types/index.mjs +2 -2
- package/dist/lib/node-esm/{MarkdownContainer-O3SGMH4G.mjs → MarkdownContainer-VOUHL6IU.mjs} +31 -23
- package/dist/lib/node-esm/MarkdownContainer-VOUHL6IU.mjs.map +7 -0
- package/dist/lib/node-esm/{MarkdownPreview-KFDRV4GC.mjs → MarkdownPreview-77UFEWXT.mjs} +8 -8
- package/dist/lib/node-esm/{MarkdownPreview-KFDRV4GC.mjs.map → MarkdownPreview-77UFEWXT.mjs.map} +3 -3
- package/dist/lib/node-esm/{anchor-sort-BXL7BE67.mjs → anchor-sort-IPIS5D5B.mjs} +4 -4
- package/dist/lib/node-esm/{app-graph-serializer-F7DGNF3G.mjs → app-graph-serializer-FLBXQKKR.mjs} +9 -9
- package/dist/lib/node-esm/app-graph-serializer-FLBXQKKR.mjs.map +7 -0
- package/dist/lib/node-esm/{artifact-definition-NQOHB6S5.mjs → artifact-definition-MLTAY4LK.mjs} +7 -7
- package/dist/lib/node-esm/artifact-definition-MLTAY4LK.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-7X6TPTJK.mjs +22 -0
- package/dist/lib/node-esm/{chunk-JXXDCSMW.mjs → chunk-ACFGXH2K.mjs} +3 -3
- package/dist/lib/node-esm/{chunk-K26TX5V4.mjs → chunk-CWTFQSN7.mjs} +3 -3
- package/dist/lib/node-esm/{chunk-RX63ZNML.mjs → chunk-CXG7GMYP.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-T2Y2BT53.mjs → chunk-JEEQLO7C.mjs} +5 -5
- package/dist/lib/{browser/chunk-N2D26K6W.mjs.map → node-esm/chunk-JEEQLO7C.mjs.map} +2 -2
- package/dist/lib/node-esm/{chunk-BWDDFDJY.mjs → chunk-VIR2ABYE.mjs} +12 -11
- package/dist/lib/node-esm/chunk-VIR2ABYE.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +10 -10
- package/dist/lib/node-esm/index.mjs.map +1 -1
- package/dist/lib/node-esm/{intent-resolver-CLMSVF2K.mjs → intent-resolver-BZYWV53A.mjs} +5 -5
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-YHFOQTVO.mjs → react-surface-TTTBYNI2.mjs} +15 -14
- package/dist/lib/node-esm/{react-surface-YHFOQTVO.mjs.map → react-surface-TTTBYNI2.mjs.map} +2 -2
- package/dist/lib/node-esm/{settings-SIY33P3F.mjs → settings-KVP7TVX7.mjs} +4 -4
- package/dist/lib/node-esm/{state-LLGVRYKL.mjs → state-NW3W4JCQ.mjs} +4 -4
- package/dist/lib/node-esm/types/index.mjs +2 -2
- package/dist/types/src/capabilities/artifact-definition.d.ts +1 -1
- package/dist/types/src/capabilities/index.d.ts +1 -1
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.stories.d.ts +1 -1
- package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +27 -2
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +1 -1
- package/dist/types/src/components/Suggestions.stories.d.ts +1 -1
- package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar.stories.d.ts +1 -1
- package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +35 -80
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +2 -2
- package/dist/types/src/types/types.d.ts +4 -3
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +1 -1
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +43 -45
- package/src/MarkdownPlugin.tsx +1 -1
- package/src/capabilities/app-graph-serializer.ts +3 -3
- package/src/capabilities/artifact-definition.ts +2 -2
- package/src/capabilities/react-surface.tsx +1 -1
- package/src/components/MarkdownContainer.stories.tsx +2 -2
- package/src/components/MarkdownContainer.tsx +20 -7
- package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +2 -2
- package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +24 -17
- package/src/components/MarkdownPreview/MarkdownPreview.tsx +10 -8
- package/src/components/Suggestions.stories.tsx +11 -5
- package/src/components/Toolbar.stories.tsx +1 -1
- package/src/extensions.tsx +18 -14
- package/src/translations.ts +8 -6
- package/src/types/types.ts +2 -2
- package/dist/lib/browser/MarkdownContainer-EFWQ6DHD.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-EI6TEHRQ.mjs.map +0 -7
- package/dist/lib/browser/artifact-definition-FQ2R6KPT.mjs.map +0 -7
- package/dist/lib/browser/chunk-354IBM5X.mjs +0 -20
- package/dist/lib/browser/chunk-D767LUGU.mjs.map +0 -7
- package/dist/lib/node/MarkdownContainer-KYGUEZIL.cjs +0 -783
- package/dist/lib/node/MarkdownContainer-KYGUEZIL.cjs.map +0 -7
- package/dist/lib/node/MarkdownPreview-GCJJCXY6.cjs +0 -103
- package/dist/lib/node/MarkdownPreview-GCJJCXY6.cjs.map +0 -7
- package/dist/lib/node/anchor-sort-V3T4SFFI.cjs +0 -48
- package/dist/lib/node/anchor-sort-V3T4SFFI.cjs.map +0 -7
- package/dist/lib/node/app-graph-serializer-E6BXEDEL.cjs +0 -65
- package/dist/lib/node/app-graph-serializer-E6BXEDEL.cjs.map +0 -7
- package/dist/lib/node/artifact-definition-U27MH5SC.cjs +0 -158
- package/dist/lib/node/artifact-definition-U27MH5SC.cjs.map +0 -7
- package/dist/lib/node/chunk-3HHV4MM6.cjs +0 -101
- package/dist/lib/node/chunk-3HHV4MM6.cjs.map +0 -7
- package/dist/lib/node/chunk-CJLYFGPI.cjs +0 -74
- package/dist/lib/node/chunk-CJLYFGPI.cjs.map +0 -7
- package/dist/lib/node/chunk-FU3XZZCO.cjs +0 -58
- package/dist/lib/node/chunk-FU3XZZCO.cjs.map +0 -7
- package/dist/lib/node/chunk-IFYSBQE5.cjs +0 -35
- package/dist/lib/node/chunk-IFYSBQE5.cjs.map +0 -7
- package/dist/lib/node/chunk-LQAC5HL7.cjs +0 -68
- package/dist/lib/node/chunk-LQAC5HL7.cjs.map +0 -7
- package/dist/lib/node/chunk-ZU5OIHCY.cjs +0 -45
- package/dist/lib/node/chunk-ZU5OIHCY.cjs.map +0 -7
- package/dist/lib/node/index.cjs +0 -165
- package/dist/lib/node/index.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-OEFLRNEJ.cjs +0 -77
- package/dist/lib/node/intent-resolver-OEFLRNEJ.cjs.map +0 -7
- package/dist/lib/node/meta.json +0 -1
- package/dist/lib/node/react-surface-456HQ4KZ.cjs +0 -218
- package/dist/lib/node/react-surface-456HQ4KZ.cjs.map +0 -7
- package/dist/lib/node/settings-E3NUTXJ4.cjs +0 -42
- package/dist/lib/node/settings-E3NUTXJ4.cjs.map +0 -7
- package/dist/lib/node/state-KKDRAG7X.cjs +0 -51
- package/dist/lib/node/state-KKDRAG7X.cjs.map +0 -7
- package/dist/lib/node/types/index.cjs +0 -40
- package/dist/lib/node/types/index.cjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-O3SGMH4G.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-F7DGNF3G.mjs.map +0 -7
- package/dist/lib/node-esm/artifact-definition-NQOHB6S5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-BWDDFDJY.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-T2Y2BT53.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YOABAQ7A.mjs +0 -22
- /package/dist/lib/browser/{anchor-sort-BMAN2ABT.mjs.map → anchor-sort-UKJJ7ZNP.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-QVJETNGS.mjs.map → chunk-777RIED6.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-JX6XNEHE.mjs.map → chunk-EPTSAJZM.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-LXSRQPEP.mjs.map → chunk-LFML7LC6.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-354IBM5X.mjs.map → chunk-PHTD5DTR.mjs.map} +0 -0
- /package/dist/lib/browser/{intent-resolver-6ZOABX2J.mjs.map → intent-resolver-3MXYO3MW.mjs.map} +0 -0
- /package/dist/lib/browser/{settings-PLH54VC7.mjs.map → settings-KN75ZQY6.mjs.map} +0 -0
- /package/dist/lib/browser/{state-KI6PJ6DT.mjs.map → state-LZWTAS65.mjs.map} +0 -0
- /package/dist/lib/node-esm/{anchor-sort-BXL7BE67.mjs.map → anchor-sort-IPIS5D5B.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-YOABAQ7A.mjs.map → chunk-7X6TPTJK.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-JXXDCSMW.mjs.map → chunk-ACFGXH2K.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-K26TX5V4.mjs.map → chunk-CWTFQSN7.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-RX63ZNML.mjs.map → chunk-CXG7GMYP.mjs.map} +0 -0
- /package/dist/lib/node-esm/{intent-resolver-CLMSVF2K.mjs.map → intent-resolver-BZYWV53A.mjs.map} +0 -0
- /package/dist/lib/node-esm/{settings-SIY33P3F.mjs.map → settings-KVP7TVX7.mjs.map} +0 -0
- /package/dist/lib/node-esm/{state-LLGVRYKL.mjs.map → state-NW3W4JCQ.mjs.map} +0 -0
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/capabilities/react-surface.tsx", "../../../src/components/index.ts", "../../../src/components/MarkdownSettings/MarkdownSettings.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { createSurface, contributes, Capabilities, useCapability } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { SettingsStore } from '@dxos/local-storage';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { fullyQualifiedId } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { MarkdownContainer, MarkdownSettings, MarkdownPreview } from '../components';\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { DocumentType, isEditorModel, type MarkdownSettingsProps } from '../types';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${MARKDOWN_PLUGIN}/document`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { subject: DocumentType; variant: undefined } =>\n Obj.instanceOf(DocumentType, data.subject) && !data.variant,\n component: ({ data, role }) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settingsStore = useCapability(Capabilities.SettingsStore);\n const settings = settingsStore.getStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN)!.value;\n const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);\n const viewMode = getViewMode(fullyQualifiedId(data.subject));\n\n return (\n <MarkdownContainer\n id={fullyQualifiedId(data.subject)}\n object={data.subject}\n role={role}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={state.extensionProviders}\n viewMode={viewMode}\n editorStateStore={editorState}\n onViewModeChange={setViewMode}\n />\n );\n },\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/text`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { id: string; subject: DataType.Text } =>\n typeof data.id === 'string' && Obj.instanceOf(DataType.Text, data.subject),\n component: ({ data, role }) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settingsStore = useCapability(Capabilities.SettingsStore);\n const settings = settingsStore.getStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN)!.value;\n const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);\n\n return (\n <MarkdownContainer\n id={data.id}\n object={data.subject}\n role={role}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={state.extensionProviders}\n viewMode={getViewMode(data.id)}\n editorStateStore={editorState}\n onViewModeChange={setViewMode}\n />\n );\n },\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/editor`,\n role: ['article', 'section'],\n filter: (data): data is { subject: { id: string; text: string } } => isEditorModel(data.subject),\n component: ({ data, role }) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settingsStore = useCapability(Capabilities.SettingsStore);\n const settings = settingsStore.getStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN)!.value;\n const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);\n\n return (\n <MarkdownContainer\n id={data.subject.id}\n object={data.subject}\n role={role}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={state.extensionProviders}\n viewMode={getViewMode(data.subject.id)}\n editorStateStore={editorState}\n onViewModeChange={setViewMode}\n />\n );\n },\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/plugin-settings`,\n role: 'article',\n filter: (data): data is { subject: SettingsStore<MarkdownSettingsProps> } =>\n data.subject instanceof SettingsStore && data.subject.prefix === MARKDOWN_PLUGIN,\n component: ({ data: { subject } }) => <MarkdownSettings settings={subject.value} />,\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/preview`,\n role: ['popover', 'card--
|
|
5
|
-
"mappings": "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
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { createSurface, contributes, Capabilities, useCapability } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { SettingsStore } from '@dxos/local-storage';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { fullyQualifiedId } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { MarkdownContainer, MarkdownSettings, MarkdownPreview } from '../components';\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { DocumentType, isEditorModel, type MarkdownSettingsProps } from '../types';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${MARKDOWN_PLUGIN}/document`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { subject: DocumentType; variant: undefined } =>\n Obj.instanceOf(DocumentType, data.subject) && !data.variant,\n component: ({ data, role }) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settingsStore = useCapability(Capabilities.SettingsStore);\n const settings = settingsStore.getStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN)!.value;\n const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);\n const viewMode = getViewMode(fullyQualifiedId(data.subject));\n\n return (\n <MarkdownContainer\n id={fullyQualifiedId(data.subject)}\n object={data.subject}\n role={role}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={state.extensionProviders}\n viewMode={viewMode}\n editorStateStore={editorState}\n onViewModeChange={setViewMode}\n />\n );\n },\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/text`,\n role: ['article', 'section', 'tabpanel'],\n filter: (data): data is { id: string; subject: DataType.Text } =>\n typeof data.id === 'string' && Obj.instanceOf(DataType.Text, data.subject),\n component: ({ data, role }) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settingsStore = useCapability(Capabilities.SettingsStore);\n const settings = settingsStore.getStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN)!.value;\n const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);\n\n return (\n <MarkdownContainer\n id={data.id}\n object={data.subject}\n role={role}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={state.extensionProviders}\n viewMode={getViewMode(data.id)}\n editorStateStore={editorState}\n onViewModeChange={setViewMode}\n />\n );\n },\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/editor`,\n role: ['article', 'section'],\n filter: (data): data is { subject: { id: string; text: string } } => isEditorModel(data.subject),\n component: ({ data, role }) => {\n const selectionManager = useCapability(AttentionCapabilities.Selection);\n const settingsStore = useCapability(Capabilities.SettingsStore);\n const settings = settingsStore.getStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN)!.value;\n const { state, editorState, getViewMode, setViewMode } = useCapability(MarkdownCapabilities.State);\n\n return (\n <MarkdownContainer\n id={data.subject.id}\n object={data.subject}\n role={role}\n settings={settings}\n selectionManager={selectionManager}\n extensionProviders={state.extensionProviders}\n viewMode={getViewMode(data.subject.id)}\n editorStateStore={editorState}\n onViewModeChange={setViewMode}\n />\n );\n },\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/plugin-settings`,\n role: 'article',\n filter: (data): data is { subject: SettingsStore<MarkdownSettingsProps> } =>\n data.subject instanceof SettingsStore && data.subject.prefix === MARKDOWN_PLUGIN,\n component: ({ data: { subject } }) => <MarkdownSettings settings={subject.value} />,\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/preview`,\n role: ['card--popover', 'card--intrinsic', 'card--extrinsic', 'card--transclusion', 'card'],\n filter: (data): data is { subject: DocumentType | DataType.Text } =>\n Obj.instanceOf(DocumentType, data.subject) || Obj.instanceOf(DataType.Text, data.subject),\n component: ({ data, role }) => <MarkdownPreview {...data} role={role} />,\n }),\n ]);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './MarkdownSettings';\n\nexport const MarkdownContainer = lazy(() => import('./MarkdownContainer'));\nexport const MarkdownPreview = lazy(() => import('./MarkdownPreview'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';\nimport { DeprecatedFormContainer, DeprecatedFormInput } from '@dxos/react-ui-form';\n\nimport { MARKDOWN_PLUGIN } from '../../meta';\nimport { type MarkdownSettingsProps } from '../../types';\n\nexport const MarkdownSettings = ({ settings }: { settings: MarkdownSettingsProps }) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <DeprecatedFormContainer>\n <DeprecatedFormInput label={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n settings.defaultViewMode = value as EditorViewMode;\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: 'react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n settings.editorInputMode = value as EditorInputMode;\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings toolbar label')}>\n <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings folding label')}>\n <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => (settings.experimental = !!checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput\n label={t('settings debug label')}\n secondary={\n settings.debug ? (\n <Input.Root>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => (settings.typewriter = value)}\n placeholder={t('settings debug placeholder')}\n />\n </Input.Root>\n ) : undefined\n }\n >\n <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />\n </DeprecatedFormInput>\n </DeprecatedFormContainer>\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["React", "createSurface", "contributes", "Capabilities", "useCapability", "Obj", "SettingsStore", "AttentionCapabilities", "fullyQualifiedId", "DataType", "lazy", "React", "Input", "Select", "useTranslation", "EditorInputModes", "EditorViewModes", "DeprecatedFormContainer", "DeprecatedFormInput", "MarkdownSettings", "settings", "t", "useTranslation", "MARKDOWN_PLUGIN", "DeprecatedFormContainer", "DeprecatedFormInput", "label", "Select", "Root", "value", "defaultViewMode", "onValueChange", "TriggerButton", "Portal", "Content", "Viewport", "EditorViewModes", "map", "mode", "Option", "key", "ns", "editorInputMode", "placeholder", "EditorInputModes", "Input", "Switch", "checked", "toolbar", "onCheckedChange", "numberedHeadings", "folding", "experimental", "secondary", "debug", "TextArea", "rows", "typewriter", "onChange", "target", "undefined", "MarkdownContainer", "lazy", "MarkdownPreview", "contributes", "Capabilities", "ReactSurface", "createSurface", "id", "MARKDOWN_PLUGIN", "role", "filter", "data", "Obj", "instanceOf", "DocumentType", "subject", "variant", "component", "selectionManager", "useCapability", "AttentionCapabilities", "Selection", "settingsStore", "SettingsStore", "settings", "getStore", "value", "state", "editorState", "getViewMode", "setViewMode", "MarkdownCapabilities", "State", "viewMode", "fullyQualifiedId", "React", "MarkdownContainer", "object", "extensionProviders", "editorStateStore", "onViewModeChange", "DataType", "Text", "isEditorModel", "prefix", "MarkdownSettings", "MarkdownPreview"]
|
|
7
7
|
}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
2
|
MarkdownSettingsSchema
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-UANWRJZU.mjs";
|
|
4
4
|
import {
|
|
5
5
|
meta
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-EPTSAJZM.mjs";
|
|
7
7
|
|
|
8
|
-
//
|
|
8
|
+
// src/capabilities/settings.ts
|
|
9
9
|
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
10
10
|
import { live } from "@dxos/live-object";
|
|
11
11
|
var settings_default = () => {
|
|
@@ -25,4 +25,4 @@ var settings_default = () => {
|
|
|
25
25
|
export {
|
|
26
26
|
settings_default as default
|
|
27
27
|
};
|
|
28
|
-
//# sourceMappingURL=settings-
|
|
28
|
+
//# sourceMappingURL=settings-KN75ZQY6.mjs.map
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
2
|
MarkdownCapabilities
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-777RIED6.mjs";
|
|
4
4
|
import {
|
|
5
5
|
MARKDOWN_PLUGIN
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-EPTSAJZM.mjs";
|
|
7
7
|
|
|
8
|
-
//
|
|
8
|
+
// src/capabilities/state.ts
|
|
9
9
|
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
10
10
|
import { LocalStorageStore } from "@dxos/local-storage";
|
|
11
11
|
import { createEditorStateStore } from "@dxos/react-ui-editor";
|
|
@@ -34,4 +34,4 @@ var state_default = (context) => {
|
|
|
34
34
|
export {
|
|
35
35
|
state_default as default
|
|
36
36
|
};
|
|
37
|
-
//# sourceMappingURL=state-
|
|
37
|
+
//# sourceMappingURL=state-LZWTAS65.mjs.map
|
|
@@ -1,33 +1,34 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import "./chunk-
|
|
2
|
+
import "./chunk-7X6TPTJK.mjs";
|
|
3
3
|
import {
|
|
4
4
|
MarkdownCapabilities
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-ACFGXH2K.mjs";
|
|
6
6
|
import {
|
|
7
7
|
getFallbackName,
|
|
8
8
|
setFallbackName
|
|
9
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-CWTFQSN7.mjs";
|
|
10
10
|
import {
|
|
11
11
|
DocumentType
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-JEEQLO7C.mjs";
|
|
13
13
|
import {
|
|
14
14
|
MARKDOWN_PLUGIN
|
|
15
|
-
} from "./chunk-
|
|
15
|
+
} from "./chunk-CXG7GMYP.mjs";
|
|
16
16
|
|
|
17
|
-
//
|
|
17
|
+
// src/components/MarkdownContainer.tsx
|
|
18
18
|
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
19
19
|
import { Rx } from "@effect-rx/rx-react";
|
|
20
20
|
import React3, { useCallback as useCallback2, useEffect as useEffect2, useMemo as useMemo4, useState } from "react";
|
|
21
21
|
import { createPortal } from "react-dom";
|
|
22
22
|
import { Capabilities, Surface, useAppGraph, useCapabilities as useCapabilities2, usePluginManager } from "@dxos/app-framework";
|
|
23
|
-
import { DXN, Filter, Obj, Query } from "@dxos/echo";
|
|
23
|
+
import { DXN, Filter, Obj, Query, Type } from "@dxos/echo";
|
|
24
|
+
import { ClientCapabilities } from "@dxos/plugin-client";
|
|
24
25
|
import { SpaceCapabilities } from "@dxos/plugin-space";
|
|
25
26
|
import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2, useQuery, useSpace } from "@dxos/react-client/echo";
|
|
26
27
|
import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
27
28
|
import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
|
|
28
29
|
import { DataType } from "@dxos/schema";
|
|
29
30
|
|
|
30
|
-
//
|
|
31
|
+
// src/components/MarkdownEditor/MarkdownEditor.tsx
|
|
31
32
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
32
33
|
import React, { forwardRef, useMemo as useMemo2, useEffect, useCallback, useImperativeHandle, useRef } from "react";
|
|
33
34
|
import { useDropzone } from "react-dropzone";
|
|
@@ -37,14 +38,14 @@ import { CommandMenu, EditorToolbar, RefPopover, addLink, createElement, coreSla
|
|
|
37
38
|
import { StackItem } from "@dxos/react-ui-stack";
|
|
38
39
|
import { isNotFalsy, isNonNullable } from "@dxos/util";
|
|
39
40
|
|
|
40
|
-
//
|
|
41
|
+
// src/hooks/useSelectCurrentThread.tsx
|
|
41
42
|
import { EditorView } from "@codemirror/view";
|
|
42
43
|
import { Schema } from "effect";
|
|
43
44
|
import { useMemo } from "react";
|
|
44
45
|
import { createResolver, LayoutAction, useIntentResolver } from "@dxos/app-framework";
|
|
45
46
|
import { invariant } from "@dxos/invariant";
|
|
46
47
|
import { Cursor, setSelection } from "@dxos/react-ui-editor";
|
|
47
|
-
var __dxlog_file = "/
|
|
48
|
+
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useSelectCurrentThread.tsx";
|
|
48
49
|
var useSelectCurrentThread = (editorView, documentId2) => {
|
|
49
50
|
const scrollIntoViewResolver = useMemo(() => createResolver({
|
|
50
51
|
intent: LayoutAction.UpdateLayout,
|
|
@@ -97,8 +98,8 @@ var useSelectCurrentThread = (editorView, documentId2) => {
|
|
|
97
98
|
useIntentResolver(MARKDOWN_PLUGIN, scrollIntoViewResolver);
|
|
98
99
|
};
|
|
99
100
|
|
|
100
|
-
//
|
|
101
|
-
var __dxlog_file2 = "/
|
|
101
|
+
// src/components/MarkdownEditor/MarkdownEditor.tsx
|
|
102
|
+
var __dxlog_file2 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditor.tsx";
|
|
102
103
|
var MarkdownEditor = ({ extensions: _extensions, slashCommandGroups, onLinkQuery, ...props }) => {
|
|
103
104
|
var _effect = _useSignals();
|
|
104
105
|
try {
|
|
@@ -341,10 +342,11 @@ var useTest = (view) => {
|
|
|
341
342
|
]);
|
|
342
343
|
};
|
|
343
344
|
|
|
344
|
-
//
|
|
345
|
+
// src/extensions.tsx
|
|
345
346
|
import React2, { useMemo as useMemo3 } from "react";
|
|
346
347
|
import { createRoot } from "react-dom/client";
|
|
347
348
|
import { createIntent, LayoutAction as LayoutAction2, useCapabilities, useIntentDispatcher } from "@dxos/app-framework";
|
|
349
|
+
import { debounceAndThrottle } from "@dxos/async";
|
|
348
350
|
import { invariant as invariant3 } from "@dxos/invariant";
|
|
349
351
|
import { createDocAccessor, fullyQualifiedId, getSpace } from "@dxos/react-client/echo";
|
|
350
352
|
import { useIdentity } from "@dxos/react-client/halo";
|
|
@@ -352,7 +354,7 @@ import { Icon, ThemeProvider } from "@dxos/react-ui";
|
|
|
352
354
|
import { InputModeExtensions, createDataExtensions, autocomplete, decorateMarkdown, folding, formattingKeymap, linkTooltip, listener, preview, selectionState, typewriter, EditorView as EditorView2, documentId, Cursor as Cursor2 } from "@dxos/react-ui-editor";
|
|
353
355
|
import { defaultTx } from "@dxos/react-ui-theme";
|
|
354
356
|
import { isNotFalsy as isNotFalsy2 } from "@dxos/util";
|
|
355
|
-
var __dxlog_file3 = "/
|
|
357
|
+
var __dxlog_file3 = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
|
|
356
358
|
var useExtensions = ({ document, id, text, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
|
|
357
359
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
358
360
|
const identity = useIdentity();
|
|
@@ -487,7 +489,7 @@ var createBaseExtensions = ({ document, id, dispatch, settings, selectionManager
|
|
|
487
489
|
return extensions;
|
|
488
490
|
};
|
|
489
491
|
var selectionChange = (selectionManager) => {
|
|
490
|
-
return EditorView2.updateListener.of((update) => {
|
|
492
|
+
return EditorView2.updateListener.of(debounceAndThrottle((update) => {
|
|
491
493
|
if (update.selectionSet) {
|
|
492
494
|
const id = update.state.facet(documentId);
|
|
493
495
|
const cursorConverter = update.state.facet(Cursor2.converter);
|
|
@@ -498,7 +500,7 @@ var selectionChange = (selectionManager) => {
|
|
|
498
500
|
})).filter(({ from, to }) => to > from);
|
|
499
501
|
selectionManager.updateMultiRange(id, ranges);
|
|
500
502
|
}
|
|
501
|
-
});
|
|
503
|
+
}, 100));
|
|
502
504
|
};
|
|
503
505
|
var style = {
|
|
504
506
|
hover: "rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400",
|
|
@@ -512,7 +514,7 @@ var createLinkRenderer = (onSelectObject) => (el, { url }) => {
|
|
|
512
514
|
const qualifiedId = url.split("/").at(-1);
|
|
513
515
|
invariant3(qualifiedId, "Invalid link format.", {
|
|
514
516
|
F: __dxlog_file3,
|
|
515
|
-
L:
|
|
517
|
+
L: 291,
|
|
516
518
|
S: void 0,
|
|
517
519
|
A: [
|
|
518
520
|
"qualifiedId",
|
|
@@ -555,7 +557,7 @@ var renderRoot = (root, node) => {
|
|
|
555
557
|
return root;
|
|
556
558
|
};
|
|
557
559
|
|
|
558
|
-
//
|
|
560
|
+
// src/components/MarkdownContainer.tsx
|
|
559
561
|
var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMode, editorStateStore, onViewModeChange }) => {
|
|
560
562
|
var _effect = _useSignals2();
|
|
561
563
|
try {
|
|
@@ -594,16 +596,22 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
594
596
|
]);
|
|
595
597
|
const space = getSpace2(object);
|
|
596
598
|
const objectForms = useCapabilities2(SpaceCapabilities.ObjectForm);
|
|
597
|
-
const
|
|
598
|
-
|
|
599
|
+
const schemaWhiteList = useCapabilities2(ClientCapabilities.SchemaWhiteList);
|
|
600
|
+
const filter = useMemo4(() => Filter.or(...objectForms.map((form) => Filter.type(form.objectSchema)), ...schemaWhiteList.flat().map((schema) => Filter.typename(Type.getTypename(schema)))), [
|
|
601
|
+
objectForms,
|
|
602
|
+
schemaWhiteList
|
|
599
603
|
]);
|
|
600
604
|
const onLinkQuery = useCallback2(async (query) => {
|
|
601
605
|
const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
|
|
602
606
|
const results = await space?.db.query(Query.select(filter)).run();
|
|
603
607
|
const getLabel = (object2) => {
|
|
608
|
+
const label = Obj.getLabel(object2);
|
|
609
|
+
if (label) {
|
|
610
|
+
return label;
|
|
611
|
+
}
|
|
604
612
|
const type = Obj.getTypename(object2);
|
|
605
613
|
const metadata = resolve(type);
|
|
606
|
-
return metadata.label?.(object2) ||
|
|
614
|
+
return metadata.label?.(object2) || [
|
|
607
615
|
"object name placeholder",
|
|
608
616
|
{
|
|
609
617
|
ns: type,
|
|
@@ -699,7 +707,7 @@ var PreviewBlock = ({ link, el }) => {
|
|
|
699
707
|
subject
|
|
700
708
|
]);
|
|
701
709
|
return /* @__PURE__ */ createPortal(/* @__PURE__ */ React3.createElement(Surface, {
|
|
702
|
-
role: "card--
|
|
710
|
+
role: "card--transclusion",
|
|
703
711
|
data,
|
|
704
712
|
limit: 1
|
|
705
713
|
}), el);
|
|
@@ -768,4 +776,4 @@ export {
|
|
|
768
776
|
DocumentEditor,
|
|
769
777
|
MarkdownContainer_default as default
|
|
770
778
|
};
|
|
771
|
-
//# sourceMappingURL=MarkdownContainer-
|
|
779
|
+
//# sourceMappingURL=MarkdownContainer-VOUHL6IU.mjs.map
|
|
@@ -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, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { Capabilities, Surface, useAppGraph, useCapabilities, usePluginManager } from '@dxos/app-framework';\nimport { DXN, Filter, Obj, Query, Type } from '@dxos/echo';\nimport { ClientCapabilities } from '@dxos/plugin-client';\nimport { SpaceCapabilities } from '@dxos/plugin-space';\nimport { fullyQualifiedId, getSpace, useQuery, useSpace } from '@dxos/react-client/echo';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n type CommandMenuGroup,\n type CommandMenuItem,\n insertAtCursor,\n insertAtLineStart,\n type PreviewLinkRef,\n type PreviewOptions,\n} from '@dxos/react-ui-editor';\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\nconst MarkdownContainer = ({\n id,\n role,\n object,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n onViewModeChange,\n}: MarkdownContainerProps) => {\n const { t } = useTranslation();\n const scrollPastEnd = role === 'article';\n const doc = Obj.instanceOf(DocumentType, object) ? object : undefined;\n const text = Obj.instanceOf(DataType.Text, object) ? object : undefined;\n const [previewBlocks, setPreviewBlocks] = useState<{ link: PreviewLinkRef; el: HTMLElement }[]>([]);\n const previewOptions = useMemo(\n (): PreviewOptions => ({\n addBlockContainer: (link, el) => {\n setPreviewBlocks((prev) => [...prev, { link, el }]);\n },\n removeBlockContainer: (link) => {\n setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));\n },\n }),\n [],\n );\n const extensions = useExtensions({\n document: doc,\n text,\n id,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n previewOptions,\n });\n\n // TODO(wittjosiah): Factor out.\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 const space = getSpace(object);\n const objectForms = useCapabilities(SpaceCapabilities.ObjectForm);\n const schemaWhiteList = useCapabilities(ClientCapabilities.SchemaWhiteList);\n const filter = useMemo(\n () =>\n Filter.or(\n ...objectForms.map((form) => Filter.type(form.objectSchema)),\n ...schemaWhiteList.flat().map((schema) => Filter.typename(Type.getTypename(schema))),\n ),\n [objectForms, schemaWhiteList],\n );\n const onLinkQuery = useCallback(\n async (query?: string): Promise<CommandMenuGroup[]> => {\n const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');\n const results = await space?.db.query(Query.select(filter)).run();\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 const items =\n results?.objects\n .filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name))\n // TODO(wittjosiah): Remove `any` type.\n .map((object: any): CommandMenuItem => {\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 return [{ id: 'echo', items }];\n },\n [filter, resolve, space],\n );\n\n const editor = doc ? (\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 onLinkQuery={space ? onLinkQuery : undefined}\n />\n ) : text ? (\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 onLinkQuery={space ? onLinkQuery : undefined}\n />\n ) : (\n // TODO(burdon): Normalize with above.\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 onLinkQuery={space ? onLinkQuery : undefined}\n />\n );\n\n return (\n <>\n {editor}\n {previewBlocks.map(({ link, el }) => (\n <PreviewBlock key={link.ref} link={link} el={el} />\n ))}\n </>\n );\n};\n\n// TODO(wittjosiah): This shouldn't be \"card\" but \"block\".\n// It's not a preview card but an interactive embedded object.\nconst PreviewBlock = ({ link, el }: { link: PreviewLinkRef; el: HTMLElement }) => {\n const echoDXN = useMemo(() => DXN.parse(link.ref).asEchoDXN(), [link.ref]);\n const space = useSpace(echoDXN?.spaceId);\n const [subject] = useQuery(space, Query.select(Filter.ids(echoDXN?.echoId ?? '')));\n const data = useMemo(() => ({ subject }), [subject]);\n\n return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);\n};\n\ntype DocumentEditorProps = Omit<MarkdownContainerProps, 'object' | 'extensionProviders' | 'editorStateStore'> &\n Pick<MarkdownEditorProps, 'id' | 'scrollPastEnd' | 'extensions' | 'onLinkQuery'> & {\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, { forwardRef, useMemo, useEffect, useCallback, useImperativeHandle, useRef } from 'react';\nimport { useDropzone } from 'react-dropzone';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { toLocalizedString, useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n CommandMenu,\n type CommandMenuGroup,\n type DNDOptions,\n type EditorInputMode,\n type EditorSelectionState,\n type EditorStateStore,\n EditorToolbar,\n type EditorToolbarActionGraphProps,\n type EditorViewMode,\n RefPopover,\n type UseTextEditorProps,\n addLink,\n createElement,\n coreSlashCommands,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorGutter,\n editorSlots,\n filterItems,\n linkSlashCommands,\n processEditorPayload,\n stackItemContentEditorClassNames,\n useEditorToolbarState,\n useFormattingState,\n useTextEditor,\n useCommandMenu,\n type UseCommandMenuOptions,\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 slashCommandGroups?: CommandMenuGroup[];\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 onLinkQuery?: (query?: string) => Promise<CommandMenuGroup[]>;\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 * 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 extensions: _extensions,\n slashCommandGroups,\n onLinkQuery,\n ...props\n}: MarkdownEditorProps) => {\n const { t } = useTranslation();\n const viewRef = useRef<EditorView>();\n\n const getMenu = useCallback(\n (trigger: string, query?: string) => {\n switch (trigger) {\n case '@':\n return onLinkQuery?.(query) ?? [];\n case '/':\n default:\n return filterItems([coreSlashCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>\n query ? toLocalizedString(item.label, t).toLowerCase().includes(query.toLowerCase()) : true,\n );\n }\n },\n [onLinkQuery, slashCommandGroups],\n );\n\n const options = useMemo<UseCommandMenuOptions>(() => {\n const trigger = onLinkQuery ? ['/', '@'] : ['/'];\n return {\n viewRef,\n trigger,\n placeholder: {\n delay: 3_000,\n content: () => {\n return createElement('div', undefined, [\n createElement('span', { text: 'Press' }),\n ...trigger.map((text) =>\n createElement('span', {\n className: 'border border-separator rounded-sm mx-1 px-1.5 pt-[1px] pb-[2px]',\n text,\n }),\n ),\n createElement('span', { text: 'for commands.' }),\n ]);\n },\n },\n getMenu,\n };\n }, [getMenu]);\n\n const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu(options);\n\n const extensions = useMemo(() => [_extensions, commandMenu].filter(isNotFalsy), [_extensions, commandMenu]);\n\n return (\n <RefPopover modal={false} {...refPopoverProps}>\n <MarkdownEditorImpl ref={viewRef} {...props} extensions={extensions} />\n <CommandMenu groups={groupsRef.current} currentItem={currentItem} onSelect={onSelect} />\n </RefPopover>\n );\n};\n\nconst MarkdownEditorImpl = forwardRef<EditorView | undefined, MarkdownEditorProps>(\n (\n {\n id,\n role = 'article',\n initialValue,\n customActions,\n editorStateStore,\n extensions,\n extensionProviders,\n scrollPastEnd,\n toolbar,\n viewMode,\n onFileUpload,\n onViewModeChange,\n },\n forwardedRef,\n ) => {\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 useImperativeHandle(forwardedRef, () => editorView, [editorView]);\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\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 { type ViewUpdate } from '@codemirror/view';\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 { debounceAndThrottle } from '@dxos/async';\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 type PreviewOptions,\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 previewOptions?: PreviewOptions;\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 previewOptions,\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 previewOptions,\n dispatch,\n // query,\n }),\n [\n document,\n id,\n text,\n viewMode,\n dispatch,\n previewOptions,\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 previewOptions,\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(previewOptions),\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(\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 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 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", "useCallback", "useEffect", "useMemo", "useState", "createPortal", "Capabilities", "Surface", "useAppGraph", "useCapabilities", "usePluginManager", "DXN", "Filter", "Obj", "Query", "Type", "ClientCapabilities", "SpaceCapabilities", "fullyQualifiedId", "getSpace", "useQuery", "useSpace", "toLocalizedString", "useTranslation", "insertAtCursor", "insertAtLineStart", "DataType", "React", "forwardRef", "useMemo", "useEffect", "useCallback", "useImperativeHandle", "useRef", "useDropzone", "invariant", "toLocalizedString", "useThemeContext", "useTranslation", "CommandMenu", "EditorToolbar", "RefPopover", "addLink", "createElement", "coreSlashCommands", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorGutter", "editorSlots", "filterItems", "linkSlashCommands", "processEditorPayload", "stackItemContentEditorClassNames", "useEditorToolbarState", "useFormattingState", "useTextEditor", "useCommandMenu", "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", "extensions", "_extensions", "slashCommandGroups", "onLinkQuery", "props", "t", "useTranslation", "viewRef", "useRef", "getMenu", "useCallback", "trigger", "query", "filterItems", "coreSlashCommands", "linkSlashCommands", "item", "toLocalizedString", "label", "toLowerCase", "includes", "options", "useMemo", "placeholder", "delay", "content", "createElement", "undefined", "text", "map", "className", "commandMenu", "groupsRef", "currentItem", "onSelect", "refPopoverProps", "useCommandMenu", "filter", "isNotFalsy", "RefPopover", "modal", "MarkdownEditorImpl", "ref", "CommandMenu", "groups", "current", "forwardRef", "id", "role", "initialValue", "customActions", "editorStateStore", "extensionProviders", "scrollPastEnd", "toolbar", "viewMode", "onFileUpload", "onViewModeChange", "forwardedRef", "MARKDOWN_PLUGIN", "themeMode", "useThemeContext", "toolbarState", "useEditorToolbarState", "formattingObserver", "useFormattingState", "scrollTo", "selection", "getState", "providerExtensions", "flatMap", "provider", "isNonNullable", "handleDrop", "view", "files", "file", "info", "processEditorPayload", "type", "data", "url", "parentRef", "editorView", "focusAttributes", "useTextEditor", "createBasicExtensions", "readOnly", "createMarkdownExtensions", "createThemeExtensions", "syntaxHighlighting", "slots", "editorSlots", "editorGutter", "dropFile", "onDrop", "moveToEndOfLine", "useImperativeHandle", "useTest", "useSelectCurrentThread", "acceptedFiles", "getInputProps", "open", "useDropzone", "multiple", "noDrag", "accept", "useEffect", "length", "requestAnimationFrame", "f", "File", "name", "lastModified", "addLink", "image", "getView", "invariant", "handleViewModeChange", "mode", "handleImageUpload", "StackItem", "Content", "EditorToolbar", "attendableId", "state", "input", "div", "data-testid", "data-toolbar", "stackItemContentEditorClassNames", "data-popover-collision-boundary", "composer", "window", "React", "useMemo", "createRoot", "createIntent", "LayoutAction", "useCapabilities", "useIntentDispatcher", "debounceAndThrottle", "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", "previewOptions", "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", "debounceAndThrottle", "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", "t", "useTranslation", "scrollPastEnd", "doc", "Obj", "instanceOf", "DocumentType", "undefined", "text", "DataType", "Text", "previewBlocks", "setPreviewBlocks", "useState", "previewOptions", "useMemo", "addBlockContainer", "link", "el", "prev", "removeBlockContainer", "filter", "prevLink", "ref", "extensions", "useExtensions", "document", "manager", "usePluginManager", "resolve", "useCallback", "typename", "context", "getCapabilities", "Capabilities", "Metadata", "find", "metadata", "space", "getSpace", "objectForms", "useCapabilities", "SpaceCapabilities", "ObjectForm", "schemaWhiteList", "ClientCapabilities", "SchemaWhiteList", "Filter", "or", "map", "form", "type", "objectSchema", "flat", "schema", "Type", "getTypename", "onLinkQuery", "query", "name", "startsWith", "slice", "toLowerCase", "results", "db", "Query", "select", "run", "getLabel", "label", "ns", "default", "items", "objects", "toLocalizedString", "includes", "icon", "onSelect", "view", "head", "getDXN", "insertAtLineStart", "insertAtCursor", "editor", "React", "DocumentEditor", "fullyQualifiedId", "MarkdownEditor", "initialValue", "content", "toolbar", "inputMode", "editorInputMode", "PreviewBlock", "key", "echoDXN", "DXN", "parse", "asEchoDXN", "useSpace", "spaceId", "subject", "useQuery", "ids", "echoId", "data", "createPortal", "Surface", "limit", "props", "useEffect", "fallbackName", "target", "getFallbackName", "upload", "FileUploader", "handleFileUpload", "file", "graph", "useAppGraph", "customActions", "Rx", "make", "get", "actions", "nodes", "action", "properties", "disposition", "edges", "node", "source", "onFileUpload"]
|
|
7
|
+
}
|
|
@@ -2,15 +2,15 @@ import { createRequire } from 'node:module';const require = createRequire(import
|
|
|
2
2
|
import {
|
|
3
3
|
getAbstract,
|
|
4
4
|
getFallbackName
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-CWTFQSN7.mjs";
|
|
6
6
|
import {
|
|
7
7
|
DocumentType
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-JEEQLO7C.mjs";
|
|
9
9
|
import {
|
|
10
10
|
MARKDOWN_PLUGIN
|
|
11
|
-
} from "./chunk-
|
|
11
|
+
} from "./chunk-CXG7GMYP.mjs";
|
|
12
12
|
|
|
13
|
-
//
|
|
13
|
+
// src/components/MarkdownPreview/MarkdownPreview.tsx
|
|
14
14
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
15
15
|
import { pipe } from "effect";
|
|
16
16
|
import React, { useCallback } from "react";
|
|
@@ -56,11 +56,11 @@ var MarkdownPreview = ({ subject, role }) => {
|
|
|
56
56
|
dispatch,
|
|
57
57
|
subject
|
|
58
58
|
]);
|
|
59
|
-
return /* @__PURE__ */ React.createElement(Card.
|
|
59
|
+
return /* @__PURE__ */ React.createElement(Card.SurfaceRoot, {
|
|
60
60
|
role
|
|
61
61
|
}, /* @__PURE__ */ React.createElement(Card.Heading, null, getTitle(subject, t("fallback title"))), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
|
|
62
62
|
classNames: "line-clamp-3 break-words col-span-2"
|
|
63
|
-
}, snippet), /* @__PURE__ */ React.createElement(Card.Chrome, null, /* @__PURE__ */ React.createElement(Button, {
|
|
63
|
+
}, snippet), role === "card--popover" && /* @__PURE__ */ React.createElement(Card.Chrome, null, /* @__PURE__ */ React.createElement(Button, {
|
|
64
64
|
onClick: handleNavigate
|
|
65
65
|
}, /* @__PURE__ */ React.createElement("span", {
|
|
66
66
|
className: "grow"
|
|
@@ -72,10 +72,10 @@ var MarkdownPreview = ({ subject, role }) => {
|
|
|
72
72
|
}
|
|
73
73
|
};
|
|
74
74
|
|
|
75
|
-
//
|
|
75
|
+
// src/components/MarkdownPreview/index.ts
|
|
76
76
|
var MarkdownPreview_default = MarkdownPreview;
|
|
77
77
|
export {
|
|
78
78
|
MarkdownPreview,
|
|
79
79
|
MarkdownPreview_default as default
|
|
80
80
|
};
|
|
81
|
-
//# sourceMappingURL=MarkdownPreview-
|
|
81
|
+
//# sourceMappingURL=MarkdownPreview-77UFEWXT.mjs.map
|
package/dist/lib/node-esm/{MarkdownPreview-KFDRV4GC.mjs.map → MarkdownPreview-77UFEWXT.mjs.map}
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
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 { Obj } from '@dxos/echo';\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 (Obj.instanceOf(DocumentType, subject)) {\n return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(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 (Obj.instanceOf(DocumentType, subject)) {\n return getAbstract(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(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.
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;AAIA,SAASA,YAAY;AACrB,OAAOC,SAASC,mBAAmB;AAEnC,SAASC,OAAOC,cAAcC,cAAcC,2BAA2B;AACvE,SAASC,WAAW;AAEpB,SAASC,wBAAwB;AACjC,SAASC,QAAQC,MAAMC,sBAAsB;AAC7C,SAASC,YAAY;AACrB,SAASC,gBAAgB;AAOzB,IAAMC,WAAW,CAACC,SAAuCC,aAAAA;AACvD,MAAIC,IAAIC,WAAWC,cAAcJ,OAAAA,GAAU;AACzC,WAAOA,QAAQK,QAAQL,QAAQM,gBAAgBC,gBAAgBP,QAAQQ,SAASC,QAAQD,WAAWP,QAAAA;EACrG,WAAWC,IAAIC,WAAWO,SAASC,MAAMX,OAAAA,GAAU;AACjD,WAAOO,gBAAgBP,QAAQQ,OAAO;EACxC;AACF;AAGA,IAAMI,aAAa,CAACZ,SAAuCC,aAAAA;AACzD,MAAIC,IAAIC,WAAWC,cAAcJ,OAAAA,GAAU;AACzC,WAAOa,YAAYb,QAAQQ,SAASC,QAAQD,WAAWP,QAAAA;EACzD,WAAWC,IAAIC,WAAWO,SAASC,MAAMX,OAAAA,GAAU;AACjD,WAAOa,YAAYb,QAAQQ,OAAO;EACpC;AACF;AAEO,IAAMM,kBAAkB,CAAC,EAAEd,SAASe,KAAI,MAA8C;;;AAC3F,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,UAAM,EAAEC,EAAC,IAAKC,eAAeC,eAAAA;AAC7B,UAAMC,UAAUV,WAAWZ,SAASmB,EAAE,mBAAA,CAAA;AAGtC,UAAMI,iBAAiBC,YACrB,MACEP,SACEQ,KACEC,aAAaC,aAAaC,eAAe;MACvCC,MAAM;MACN7B,SAAS;MACT8B,SAAS;QAAEC,OAAO;QAAOC,UAAU;MAAG;IACxC,CAAA,GACAC,MAAMN,aAAaO,MAAM;MAAEL,MAAM;MAAQ7B,SAAS;QAACmC,iBAAiBnC,OAAAA;;IAAU,CAAA,CAAA,CAAA,GAGpF;MAACiB;MAAUjB;KAAQ;AAGrB,WACE,sBAAA,cAACoC,KAAKC,
|
|
6
|
-
"names": ["pipe", "React", "useCallback", "chain", "createIntent", "LayoutAction", "useIntentDispatcher", "Obj", "fullyQualifiedId", "Button", "Icon", "useTranslation", "Card", "DataType", "getTitle", "subject", "fallback", "Obj", "instanceOf", "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", "
|
|
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 { Obj } from '@dxos/echo';\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 (Obj.instanceOf(DocumentType, subject)) {\n return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(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 (Obj.instanceOf(DocumentType, subject)) {\n return getAbstract(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(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.SurfaceRoot 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 {role === 'card--popover' && (\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 )}\n </Card.SurfaceRoot>\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,WAAW;AAEpB,SAASC,wBAAwB;AACjC,SAASC,QAAQC,MAAMC,sBAAsB;AAC7C,SAASC,YAAY;AACrB,SAASC,gBAAgB;AAOzB,IAAMC,WAAW,CAACC,SAAuCC,aAAAA;AACvD,MAAIC,IAAIC,WAAWC,cAAcJ,OAAAA,GAAU;AACzC,WAAOA,QAAQK,QAAQL,QAAQM,gBAAgBC,gBAAgBP,QAAQQ,SAASC,QAAQD,WAAWP,QAAAA;EACrG,WAAWC,IAAIC,WAAWO,SAASC,MAAMX,OAAAA,GAAU;AACjD,WAAOO,gBAAgBP,QAAQQ,OAAO;EACxC;AACF;AAGA,IAAMI,aAAa,CAACZ,SAAuCC,aAAAA;AACzD,MAAIC,IAAIC,WAAWC,cAAcJ,OAAAA,GAAU;AACzC,WAAOa,YAAYb,QAAQQ,SAASC,QAAQD,WAAWP,QAAAA;EACzD,WAAWC,IAAIC,WAAWO,SAASC,MAAMX,OAAAA,GAAU;AACjD,WAAOa,YAAYb,QAAQQ,OAAO;EACpC;AACF;AAEO,IAAMM,kBAAkB,CAAC,EAAEd,SAASe,KAAI,MAA8C;;;AAC3F,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,UAAM,EAAEC,EAAC,IAAKC,eAAeC,eAAAA;AAC7B,UAAMC,UAAUV,WAAWZ,SAASmB,EAAE,mBAAA,CAAA;AAGtC,UAAMI,iBAAiBC,YACrB,MACEP,SACEQ,KACEC,aAAaC,aAAaC,eAAe;MACvCC,MAAM;MACN7B,SAAS;MACT8B,SAAS;QAAEC,OAAO;QAAOC,UAAU;MAAG;IACxC,CAAA,GACAC,MAAMN,aAAaO,MAAM;MAAEL,MAAM;MAAQ7B,SAAS;QAACmC,iBAAiBnC,OAAAA;;IAAU,CAAA,CAAA,CAAA,GAGpF;MAACiB;MAAUjB;KAAQ;AAGrB,WACE,sBAAA,cAACoC,KAAKC,aAAW;MAACtB;OAChB,sBAAA,cAACqB,KAAKE,SAAO,MAAEvC,SAASC,SAASmB,EAAE,gBAAA,CAAA,CAAA,GAClCG,WAAW,sBAAA,cAACc,KAAKzB,MAAI;MAAC4B,YAAW;OAAuCjB,OAAAA,GACxEP,SAAS,mBACR,sBAAA,cAACqB,KAAKI,QAAM,MACV,sBAAA,cAACC,QAAAA;MAAOC,SAASnB;OACf,sBAAA,cAACoB,QAAAA;MAAKC,WAAU;OAAQzB,EAAE,4BAAA,CAAA,GAC1B,sBAAA,cAAC0B,MAAAA;MAAKC,MAAK;;;;;AAMvB;;;AChEA,IAAA,0BAAeC;",
|
|
6
|
+
"names": ["pipe", "React", "useCallback", "chain", "createIntent", "LayoutAction", "useIntentDispatcher", "Obj", "fullyQualifiedId", "Button", "Icon", "useTranslation", "Card", "DataType", "getTitle", "subject", "fallback", "Obj", "instanceOf", "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", "SurfaceRoot", "Heading", "classNames", "Chrome", "Button", "onClick", "span", "className", "Icon", "icon", "MarkdownPreview"]
|
|
7
7
|
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
DocumentType
|
|
4
|
-
} from "./chunk-
|
|
5
|
-
import "./chunk-
|
|
4
|
+
} from "./chunk-JEEQLO7C.mjs";
|
|
5
|
+
import "./chunk-CXG7GMYP.mjs";
|
|
6
6
|
|
|
7
|
-
//
|
|
7
|
+
// src/capabilities/anchor-sort.ts
|
|
8
8
|
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
9
9
|
import { Type } from "@dxos/echo";
|
|
10
10
|
import { createDocAccessor, getRangeFromCursor, getTarget } from "@dxos/react-client/echo";
|
|
@@ -30,4 +30,4 @@ var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
|
|
|
30
30
|
export {
|
|
31
31
|
anchor_sort_default as default
|
|
32
32
|
};
|
|
33
|
-
//# sourceMappingURL=anchor-sort-
|
|
33
|
+
//# sourceMappingURL=anchor-sort-IPIS5D5B.mjs.map
|
package/dist/lib/node-esm/{app-graph-serializer-F7DGNF3G.mjs → app-graph-serializer-FLBXQKKR.mjs}
RENAMED
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
|
-
|
|
4
|
-
} from "./chunk-
|
|
3
|
+
translations
|
|
4
|
+
} from "./chunk-VIR2ABYE.mjs";
|
|
5
5
|
import {
|
|
6
6
|
DocumentType,
|
|
7
7
|
MarkdownAction
|
|
8
|
-
} from "./chunk-
|
|
9
|
-
import "./chunk-
|
|
8
|
+
} from "./chunk-JEEQLO7C.mjs";
|
|
9
|
+
import "./chunk-CXG7GMYP.mjs";
|
|
10
10
|
|
|
11
|
-
//
|
|
11
|
+
// 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 { Obj
|
|
14
|
+
import { Obj } from "@dxos/echo";
|
|
15
15
|
import { SpaceAction } from "@dxos/plugin-space/types";
|
|
16
16
|
import { isSpace } from "@dxos/react-client/echo";
|
|
17
17
|
import { DataType } from "@dxos/schema";
|
|
@@ -24,14 +24,14 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
24
24
|
const doc = node.data;
|
|
25
25
|
const content = await doc.content.load();
|
|
26
26
|
return {
|
|
27
|
-
name: doc.name || doc.fallbackName ||
|
|
27
|
+
name: doc.name || doc.fallbackName || translations[0]["en-US"][DocumentType.typename]["object name placeholder"],
|
|
28
28
|
data: content.content,
|
|
29
29
|
type: "text/markdown"
|
|
30
30
|
};
|
|
31
31
|
},
|
|
32
32
|
deserialize: async (data, ancestors) => {
|
|
33
33
|
const space = ancestors.find(isSpace);
|
|
34
|
-
const target = ancestors.findLast((ancestor) => Obj.instanceOf(DataType.Collection, ancestor)) ?? space?.properties[
|
|
34
|
+
const target = ancestors.findLast((ancestor) => Obj.instanceOf(DataType.Collection, ancestor)) ?? space?.properties[DataType.Collection.typename]?.target;
|
|
35
35
|
if (!space || !target) {
|
|
36
36
|
return;
|
|
37
37
|
}
|
|
@@ -50,4 +50,4 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
50
50
|
export {
|
|
51
51
|
app_graph_serializer_default as default
|
|
52
52
|
};
|
|
53
|
-
//# sourceMappingURL=app-graph-serializer-
|
|
53
|
+
//# sourceMappingURL=app-graph-serializer-FLBXQKKR.mjs.map
|