@dxos/plugin-markdown 0.8.4-main.e098934 → 0.8.4-main.ead640a
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/{MarkdownCard-JLUQITYK.mjs → MarkdownCard-AGWOTODZ.mjs} +20 -17
- package/dist/lib/browser/MarkdownCard-AGWOTODZ.mjs.map +7 -0
- package/dist/lib/browser/{MarkdownContainer-HMPNQMNG.mjs → MarkdownContainer-MV2UNAUV.mjs} +52 -52
- package/dist/lib/browser/MarkdownContainer-MV2UNAUV.mjs.map +7 -0
- package/dist/lib/browser/{anchor-sort-E33BSTYF.mjs → anchor-sort-YWJI3BKT.mjs} +4 -4
- package/dist/lib/browser/{anchor-sort-E33BSTYF.mjs.map → anchor-sort-YWJI3BKT.mjs.map} +1 -1
- package/dist/lib/browser/{app-graph-serializer-OX62DNPT.mjs → app-graph-serializer-KYDFCUOW.mjs} +7 -7
- package/dist/lib/browser/app-graph-serializer-KYDFCUOW.mjs.map +7 -0
- package/dist/lib/browser/{blueprint-definition-5YKFUHRU.mjs → blueprint-definition-BHRMFZAC.mjs} +3 -3
- package/dist/lib/browser/{chunk-LAVZ2W6X.mjs → chunk-6KU5DKP7.mjs} +6 -5
- package/dist/lib/browser/chunk-6KU5DKP7.mjs.map +7 -0
- package/dist/lib/browser/{chunk-F6JJLKLN.mjs → chunk-HBBEHOP3.mjs} +12 -8
- package/dist/lib/browser/chunk-HBBEHOP3.mjs.map +7 -0
- package/dist/lib/browser/{chunk-Z7P6JGGW.mjs → chunk-O6XUPW6S.mjs} +2 -2
- package/dist/lib/browser/{chunk-BEE7VQPU.mjs → chunk-XMT6PMU5.mjs} +6 -5
- package/dist/lib/browser/chunk-XMT6PMU5.mjs.map +7 -0
- package/dist/lib/browser/chunk-Z5PDJNBV.mjs +22 -0
- package/dist/lib/browser/index.mjs +9 -8
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-resolver-WDDH56JC.mjs → intent-resolver-XHVCZZHU.mjs} +5 -5
- package/dist/lib/browser/intent-resolver-XHVCZZHU.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-NY5K2I5R.mjs → react-surface-3A2GO3BN.mjs} +7 -7
- package/dist/lib/browser/{react-surface-NY5K2I5R.mjs.map → react-surface-3A2GO3BN.mjs.map} +1 -1
- package/dist/lib/browser/{settings-AABBTB4Q.mjs → settings-XY265Y2Q.mjs} +4 -4
- package/dist/lib/browser/{settings-AABBTB4Q.mjs.map → settings-XY265Y2Q.mjs.map} +1 -1
- package/dist/lib/browser/{state-FTHQQX7V.mjs → state-6QODXCSZ.mjs} +3 -3
- package/dist/lib/browser/{state-FTHQQX7V.mjs.map → state-6QODXCSZ.mjs.map} +1 -1
- package/dist/lib/browser/{toolkit-2AJTHG74.mjs → toolkit-YA65QX2S.mjs} +15 -13
- package/dist/lib/browser/toolkit-YA65QX2S.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -1
- package/dist/lib/node-esm/{MarkdownCard-XL5EVSJ7.mjs → MarkdownCard-B2IWTFOC.mjs} +20 -17
- package/dist/lib/node-esm/MarkdownCard-B2IWTFOC.mjs.map +7 -0
- package/dist/lib/node-esm/{MarkdownContainer-5FTROSXN.mjs → MarkdownContainer-J2R3DLCQ.mjs} +52 -52
- package/dist/lib/node-esm/MarkdownContainer-J2R3DLCQ.mjs.map +7 -0
- package/dist/lib/node-esm/{anchor-sort-ALP2NH24.mjs → anchor-sort-FCRYL2FX.mjs} +4 -4
- package/dist/lib/node-esm/{anchor-sort-ALP2NH24.mjs.map → anchor-sort-FCRYL2FX.mjs.map} +1 -1
- package/dist/lib/node-esm/{app-graph-serializer-56TD3BMX.mjs → app-graph-serializer-FAUQM3BH.mjs} +7 -7
- package/dist/lib/node-esm/app-graph-serializer-FAUQM3BH.mjs.map +7 -0
- package/dist/lib/node-esm/{blueprint-definition-GVW67KGV.mjs → blueprint-definition-XYFKMIDR.mjs} +3 -3
- package/dist/lib/node-esm/chunk-7RDNIMTF.mjs +24 -0
- package/dist/lib/node-esm/{chunk-DVK63TD3.mjs → chunk-FVI7LPC3.mjs} +12 -8
- package/dist/lib/node-esm/chunk-FVI7LPC3.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-FXILAQ5F.mjs → chunk-FWZKC6X5.mjs} +6 -5
- package/dist/lib/node-esm/chunk-FWZKC6X5.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-J7A6TUB2.mjs → chunk-XO3IEQJE.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-O6EXWGGS.mjs → chunk-ZBXV4ON7.mjs} +6 -5
- package/dist/lib/node-esm/chunk-ZBXV4ON7.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +9 -8
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-resolver-2I5HKCUU.mjs → intent-resolver-7A2EXGZQ.mjs} +5 -5
- package/dist/lib/node-esm/intent-resolver-7A2EXGZQ.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-AUWSLYJS.mjs → react-surface-RCLL5WVQ.mjs} +7 -7
- package/dist/lib/node-esm/{react-surface-AUWSLYJS.mjs.map → react-surface-RCLL5WVQ.mjs.map} +1 -1
- package/dist/lib/node-esm/{settings-CXGR6DH4.mjs → settings-H3UDD3KO.mjs} +4 -4
- package/dist/lib/node-esm/{settings-CXGR6DH4.mjs.map → settings-H3UDD3KO.mjs.map} +1 -1
- package/dist/lib/node-esm/{state-NWMQ3XAI.mjs → state-W3PECOJX.mjs} +3 -3
- package/dist/lib/node-esm/{state-NWMQ3XAI.mjs.map → state-W3PECOJX.mjs.map} +1 -1
- package/dist/lib/node-esm/{toolkit-RC44I2MI.mjs → toolkit-HSIKUGNK.mjs} +15 -13
- package/dist/lib/node-esm/toolkit-HSIKUGNK.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -1
- package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.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 +4 -4
- package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +4 -4
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.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/Suggestions.stories.d.ts +1 -2
- 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/functions/diff.d.ts.map +1 -1
- package/dist/types/src/functions/open.d.ts.map +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
- package/dist/types/src/types/Markdown.d.ts +5 -3
- package/dist/types/src/types/Markdown.d.ts.map +1 -1
- package/dist/types/src/types/MarkdownAction.d.ts +2 -1
- package/dist/types/src/types/MarkdownAction.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 +54 -54
- package/src/MarkdownPlugin.tsx +98 -98
- package/src/capabilities/app-graph-serializer.ts +2 -2
- package/src/capabilities/artifact-definition.ts +3 -2
- package/src/capabilities/intent-resolver.ts +2 -1
- package/src/capabilities/toolkit.ts +9 -7
- package/src/components/MarkdownCard/MarkdownCard.stories.tsx +3 -6
- package/src/components/MarkdownCard/MarkdownCard.tsx +17 -16
- package/src/components/MarkdownContainer.stories.tsx +42 -33
- package/src/components/MarkdownContainer.tsx +15 -13
- package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +11 -10
- package/src/components/MarkdownEditor/MarkdownEditor.tsx +35 -33
- package/src/components/Suggestions.stories.tsx +27 -26
- package/src/components/Toolbar.stories.tsx +5 -5
- package/src/extensions.tsx +3 -3
- package/src/functions/diff.ts +4 -2
- package/src/functions/open.ts +4 -2
- package/src/hooks/useSelectCurrentThread.tsx +2 -2
- package/src/types/Markdown.ts +4 -2
- package/src/types/MarkdownAction.ts +1 -1
- package/src/util.tsx +8 -2
- package/dist/lib/browser/MarkdownCard-JLUQITYK.mjs.map +0 -7
- package/dist/lib/browser/MarkdownContainer-HMPNQMNG.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-OX62DNPT.mjs.map +0 -7
- package/dist/lib/browser/chunk-BEE7VQPU.mjs.map +0 -7
- package/dist/lib/browser/chunk-F6JJLKLN.mjs.map +0 -7
- package/dist/lib/browser/chunk-LAVZ2W6X.mjs.map +0 -7
- package/dist/lib/browser/chunk-XE66SH4O.mjs +0 -22
- package/dist/lib/browser/intent-resolver-WDDH56JC.mjs.map +0 -7
- package/dist/lib/browser/toolkit-2AJTHG74.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownCard-XL5EVSJ7.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-5FTROSXN.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-56TD3BMX.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-DVK63TD3.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-FXILAQ5F.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-O6EXWGGS.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-Q2BREK2M.mjs +0 -24
- package/dist/lib/node-esm/intent-resolver-2I5HKCUU.mjs.map +0 -7
- package/dist/lib/node-esm/toolkit-RC44I2MI.mjs.map +0 -7
- /package/dist/lib/browser/{blueprint-definition-5YKFUHRU.mjs.map → blueprint-definition-BHRMFZAC.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-Z7P6JGGW.mjs.map → chunk-O6XUPW6S.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-XE66SH4O.mjs.map → chunk-Z5PDJNBV.mjs.map} +0 -0
- /package/dist/lib/node-esm/{blueprint-definition-GVW67KGV.mjs.map → blueprint-definition-XYFKMIDR.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-Q2BREK2M.mjs.map → chunk-7RDNIMTF.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-J7A6TUB2.mjs.map → chunk-XO3IEQJE.mjs.map} +0 -0
|
@@ -1,23 +1,23 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
|
-
|
|
3
|
+
getContentSnippet,
|
|
4
4
|
getFallbackName
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-ZBXV4ON7.mjs";
|
|
6
6
|
import {
|
|
7
7
|
Markdown_exports
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-FWZKC6X5.mjs";
|
|
9
9
|
import {
|
|
10
10
|
meta
|
|
11
11
|
} from "./chunk-VCG2U522.mjs";
|
|
12
12
|
|
|
13
13
|
// src/components/MarkdownCard/MarkdownCard.tsx
|
|
14
14
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
15
|
-
import
|
|
15
|
+
import * as Function from "effect/Function";
|
|
16
16
|
import React, { useCallback } from "react";
|
|
17
17
|
import { LayoutAction, chain, createIntent, useIntentDispatcher } from "@dxos/app-framework";
|
|
18
18
|
import { Obj } from "@dxos/echo";
|
|
19
19
|
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
20
|
-
import {
|
|
20
|
+
import { IconButton, useTranslation } from "@dxos/react-ui";
|
|
21
21
|
import { Card } from "@dxos/react-ui-stack";
|
|
22
22
|
import { DataType } from "@dxos/schema";
|
|
23
23
|
var getTitle = (subject, fallback) => {
|
|
@@ -29,9 +29,9 @@ var getTitle = (subject, fallback) => {
|
|
|
29
29
|
};
|
|
30
30
|
var getSnippet = (subject, fallback) => {
|
|
31
31
|
if (Obj.instanceOf(Markdown_exports.Document, subject)) {
|
|
32
|
-
return
|
|
32
|
+
return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
|
|
33
33
|
} else if (Obj.instanceOf(DataType.Text, subject)) {
|
|
34
|
-
return
|
|
34
|
+
return getContentSnippet(subject.content ?? fallback);
|
|
35
35
|
}
|
|
36
36
|
};
|
|
37
37
|
var MarkdownCard = ({ subject, role }) => {
|
|
@@ -40,7 +40,7 @@ var MarkdownCard = ({ subject, role }) => {
|
|
|
40
40
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
41
41
|
const { t } = useTranslation(meta.id);
|
|
42
42
|
const snippet = getSnippet(subject, t("fallback abstract"));
|
|
43
|
-
const handleNavigate = useCallback(() => dispatch(pipe(createIntent(LayoutAction.UpdatePopover, {
|
|
43
|
+
const handleNavigate = useCallback(() => dispatch(Function.pipe(createIntent(LayoutAction.UpdatePopover, {
|
|
44
44
|
part: "popover",
|
|
45
45
|
subject: null,
|
|
46
46
|
options: {
|
|
@@ -58,15 +58,18 @@ var MarkdownCard = ({ subject, role }) => {
|
|
|
58
58
|
]);
|
|
59
59
|
return /* @__PURE__ */ React.createElement(Card.SurfaceRoot, {
|
|
60
60
|
role
|
|
61
|
-
}, /* @__PURE__ */ React.createElement(Card.Heading,
|
|
62
|
-
classNames: "
|
|
63
|
-
},
|
|
64
|
-
onClick: handleNavigate
|
|
65
|
-
}, /* @__PURE__ */ React.createElement("span", {
|
|
61
|
+
}, /* @__PURE__ */ React.createElement(Card.Heading, {
|
|
62
|
+
classNames: "flex items-center"
|
|
63
|
+
}, getTitle(subject, t("fallback title")), /* @__PURE__ */ React.createElement("span", {
|
|
66
64
|
className: "grow"
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
|
|
65
|
+
}), /* @__PURE__ */ React.createElement(IconButton, {
|
|
66
|
+
iconOnly: true,
|
|
67
|
+
icon: "ph--arrow-right--regular",
|
|
68
|
+
label: t("navigate to document label"),
|
|
69
|
+
onClick: handleNavigate
|
|
70
|
+
})), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
|
|
71
|
+
classNames: "line-clamp-3 text-sm text-description"
|
|
72
|
+
}, snippet));
|
|
70
73
|
} finally {
|
|
71
74
|
_effect.f();
|
|
72
75
|
}
|
|
@@ -78,4 +81,4 @@ export {
|
|
|
78
81
|
MarkdownCard,
|
|
79
82
|
MarkdownCard_default as default
|
|
80
83
|
};
|
|
81
|
-
//# sourceMappingURL=MarkdownCard-
|
|
84
|
+
//# sourceMappingURL=MarkdownCard-B2IWTFOC.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownCard/MarkdownCard.tsx", "../../../src/components/MarkdownCard/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Function from 'effect/Function';\nimport React, { useCallback } from 'react';\n\nimport { LayoutAction, chain, createIntent, 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 { IconButton, useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui-stack';\nimport { DataType } from '@dxos/schema';\n\nimport { meta } from '../../meta';\nimport { Markdown } from '../../types';\nimport { getContentSnippet, getFallbackName } from '../../util';\n\n// TODO(burdon): Factor out.\nconst getTitle = (subject: Markdown.Document | DataType.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, 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: Markdown.Document | DataType.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(DataType.Text, subject)) {\n return getContentSnippet(subject.content ?? fallback);\n }\n};\n\nexport type MarkdownCardProps = PreviewProps<Markdown.Document | DataType.Text>;\n\nexport const MarkdownCard = ({ subject, role }: MarkdownCardProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { t } = useTranslation(meta.id);\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 Function.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 classNames='flex items-center'>\n {getTitle(subject, t('fallback title'))}\n <span className='grow' />\n <IconButton\n iconOnly\n icon='ph--arrow-right--regular'\n label={t('navigate to document label')}\n onClick={handleNavigate}\n />\n </Card.Heading>\n {snippet && <Card.Text classNames='line-clamp-3 text-sm text-description'>{snippet}</Card.Text>}\n </Card.SurfaceRoot>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownCard } from './MarkdownCard';\n\nexport * from './MarkdownCard';\n\nexport default MarkdownCard;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;AAIA,YAAYA,cAAc;AAC1B,OAAOC,SAASC,mBAAmB;AAEnC,SAASC,cAAcC,OAAOC,cAAcC,2BAA2B;AACvE,SAASC,WAAW;AAEpB,SAASC,wBAAwB;AACjC,SAASC,YAAYC,sBAAsB;AAC3C,SAASC,YAAY;AACrB,SAASC,gBAAgB;AAOzB,IAAMC,WAAW,CAACC,SAA4CC,aAAAA;AAC5D,MAAIC,IAAIC,WAAWC,iBAASC,UAAUL,OAAAA,GAAU;AAC9C,WAAOA,QAAQM,QAAQN,QAAQO,gBAAgBC,gBAAgBR,QAAQS,SAASC,QAAQD,WAAWR,QAAAA;EACrG,WAAWC,IAAIC,WAAWQ,SAASC,MAAMZ,OAAAA,GAAU;AACjD,WAAOQ,gBAAgBR,QAAQS,OAAO;EACxC;AACF;AAGA,IAAMI,aAAa,CAACb,SAA4CC,aAAAA;AAC9D,MAAIC,IAAIC,WAAWC,iBAASC,UAAUL,OAAAA,GAAU;AAC9C,WAAOE,IAAIY,eAAed,OAAAA,KAAYe,kBAAkBf,QAAQS,SAASC,QAAQD,WAAWR,QAAAA;EAC9F,WAAWC,IAAIC,WAAWQ,SAASC,MAAMZ,OAAAA,GAAU;AACjD,WAAOe,kBAAkBf,QAAQS,WAAWR,QAAAA;EAC9C;AACF;AAIO,IAAMe,eAAe,CAAC,EAAEhB,SAASiB,KAAI,MAAqB;;;AAC/D,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,UAAMC,UAAUZ,WAAWb,SAASqB,EAAE,mBAAA,CAAA;AAGtC,UAAMK,iBAAiBC,YACrB,MACER,SACWS,cACPC,aAAaC,aAAaC,eAAe;MACvCC,MAAM;MACNhC,SAAS;MACTiC,SAAS;QAAEC,OAAO;QAAOC,UAAU;MAAG;IACxC,CAAA,GACAC,MAAMN,aAAaO,MAAM;MAAEL,MAAM;MAAQhC,SAAS;QAACsC,iBAAiBtC,OAAAA;;IAAU,CAAA,CAAA,CAAA,GAGpF;MAACmB;MAAUnB;KAAQ;AAGrB,WACE,sBAAA,cAACuC,KAAKC,aAAW;MAACvB;OAChB,sBAAA,cAACsB,KAAKE,SAAO;MAACC,YAAW;OACtB3C,SAASC,SAASqB,EAAE,gBAAA,CAAA,GACrB,sBAAA,cAACsB,QAAAA;MAAKC,WAAU;QAChB,sBAAA,cAACC,YAAAA;MACCC,UAAAA;MACAC,MAAK;MACLC,OAAO3B,EAAE,4BAAA;MACT4B,SAASvB;SAGZD,WAAW,sBAAA,cAACc,KAAK3B,MAAI;MAAC8B,YAAW;OAAyCjB,OAAAA,CAAAA;;;;AAGjF;;;ACnEA,IAAA,uBAAeyB;",
|
|
6
|
+
"names": ["Function", "React", "useCallback", "LayoutAction", "chain", "createIntent", "useIntentDispatcher", "Obj", "fullyQualifiedId", "IconButton", "useTranslation", "Card", "DataType", "getTitle", "subject", "fallback", "Obj", "instanceOf", "Markdown", "Document", "name", "fallbackName", "getFallbackName", "content", "target", "DataType", "Text", "getSnippet", "getDescription", "getContentSnippet", "MarkdownCard", "role", "dispatchPromise", "dispatch", "useIntentDispatcher", "t", "useTranslation", "meta", "id", "snippet", "handleNavigate", "useCallback", "pipe", "createIntent", "LayoutAction", "UpdatePopover", "part", "options", "state", "anchorId", "chain", "Open", "fullyQualifiedId", "Card", "SurfaceRoot", "Heading", "classNames", "span", "className", "IconButton", "iconOnly", "icon", "label", "onClick", "MarkdownCard"]
|
|
7
|
+
}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import "./chunk-
|
|
3
|
-
import "./chunk-
|
|
2
|
+
import "./chunk-7RDNIMTF.mjs";
|
|
3
|
+
import "./chunk-FVI7LPC3.mjs";
|
|
4
4
|
import {
|
|
5
5
|
MarkdownCapabilities
|
|
6
6
|
} from "./chunk-CB2R4YIY.mjs";
|
|
7
7
|
import {
|
|
8
8
|
getFallbackName,
|
|
9
9
|
setFallbackName
|
|
10
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-ZBXV4ON7.mjs";
|
|
11
11
|
import {
|
|
12
12
|
Markdown_exports
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-FWZKC6X5.mjs";
|
|
14
14
|
import {
|
|
15
15
|
meta
|
|
16
16
|
} from "./chunk-VCG2U522.mjs";
|
|
@@ -24,7 +24,8 @@ import { Capabilities, Surface, useAppGraph, useCapabilities as useCapabilities2
|
|
|
24
24
|
import { DXN, Filter, Obj, Query, Type } from "@dxos/echo";
|
|
25
25
|
import { ClientCapabilities } from "@dxos/plugin-client";
|
|
26
26
|
import { SpaceCapabilities } from "@dxos/plugin-space";
|
|
27
|
-
import {
|
|
27
|
+
import { useClient } from "@dxos/react-client";
|
|
28
|
+
import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2 } from "@dxos/react-client/echo";
|
|
28
29
|
import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
29
30
|
import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
|
|
30
31
|
import { DataType } from "@dxos/schema";
|
|
@@ -40,7 +41,7 @@ import { useIdentity } from "@dxos/react-client/halo";
|
|
|
40
41
|
import { Icon, ThemeProvider } from "@dxos/react-ui";
|
|
41
42
|
import { Cursor, EditorView, InputModeExtensions, createDataExtensions, decorateMarkdown, documentId, folding, formattingKeymap, linkTooltip, listener, preview, selectionState, typewriter } from "@dxos/react-ui-editor";
|
|
42
43
|
import { defaultTx } from "@dxos/react-ui-theme";
|
|
43
|
-
import {
|
|
44
|
+
import { isTruthy } from "@dxos/util";
|
|
44
45
|
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
|
|
45
46
|
var useExtensions = ({ document, id, text, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
|
|
46
47
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
@@ -112,7 +113,7 @@ var useExtensions = ({ document, id, text, settings, selectionManager, viewMode,
|
|
|
112
113
|
}),
|
|
113
114
|
baseExtensions,
|
|
114
115
|
pluginExtensions
|
|
115
|
-
].filter(
|
|
116
|
+
].filter(isTruthy), [
|
|
116
117
|
baseExtensions,
|
|
117
118
|
pluginExtensions,
|
|
118
119
|
document,
|
|
@@ -128,7 +129,7 @@ var createBaseExtensions = ({ document, id, dispatch, settings, selectionManager
|
|
|
128
129
|
selectionManager && selectionChange(selectionManager),
|
|
129
130
|
settings.editorInputMode && InputModeExtensions[settings.editorInputMode],
|
|
130
131
|
settings.folding && folding()
|
|
131
|
-
].filter(
|
|
132
|
+
].filter(isTruthy);
|
|
132
133
|
if (viewMode !== "source") {
|
|
133
134
|
extensions.push(...[
|
|
134
135
|
formattingKeymap(),
|
|
@@ -238,14 +239,14 @@ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
|
238
239
|
import React2, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo as useMemo3, useRef } from "react";
|
|
239
240
|
import { useDropzone } from "react-dropzone";
|
|
240
241
|
import { invariant as invariant3 } from "@dxos/invariant";
|
|
241
|
-
import { toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
|
|
242
|
-
import {
|
|
242
|
+
import { Domino, toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
|
|
243
|
+
import { EditorToolbar, PopoverMenuProvider, addLink, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorGutter, editorSlots, filterMenuGroups, formattingCommands, linkSlashCommands, processEditorPayload, stackItemContentEditorClassNames, useEditorToolbarState, useFormattingState, usePopoverMenu, useTextEditor } from "@dxos/react-ui-editor";
|
|
243
244
|
import { StackItem } from "@dxos/react-ui-stack";
|
|
244
|
-
import { isNonNullable,
|
|
245
|
+
import { isNonNullable, isTruthy as isTruthy2 } from "@dxos/util";
|
|
245
246
|
|
|
246
247
|
// src/hooks/useSelectCurrentThread.tsx
|
|
247
248
|
import { EditorView as EditorView2 } from "@codemirror/view";
|
|
248
|
-
import
|
|
249
|
+
import * as Schema from "effect/Schema";
|
|
249
250
|
import { useMemo as useMemo2 } from "react";
|
|
250
251
|
import { LayoutAction as LayoutAction2, createResolver, useIntentResolver } from "@dxos/app-framework";
|
|
251
252
|
import { invariant as invariant2 } from "@dxos/invariant";
|
|
@@ -309,18 +310,20 @@ var MarkdownEditor = ({ extensions: extensionsParam, slashCommandGroups, onLinkQ
|
|
|
309
310
|
var _effect = _useSignals();
|
|
310
311
|
try {
|
|
311
312
|
const { t } = useTranslation();
|
|
312
|
-
const viewRef = useRef();
|
|
313
|
-
const getMenu = useCallback((
|
|
313
|
+
const viewRef = useRef(null);
|
|
314
|
+
const getMenu = useCallback(({ text, trigger }) => {
|
|
314
315
|
switch (trigger) {
|
|
315
|
-
case "@":
|
|
316
|
-
return onLinkQuery?.(
|
|
316
|
+
case "@": {
|
|
317
|
+
return onLinkQuery?.(text) ?? [];
|
|
318
|
+
}
|
|
317
319
|
case "/":
|
|
318
|
-
default:
|
|
319
|
-
return
|
|
320
|
-
|
|
320
|
+
default: {
|
|
321
|
+
return filterMenuGroups([
|
|
322
|
+
formattingCommands,
|
|
321
323
|
linkSlashCommands,
|
|
322
324
|
...slashCommandGroups ?? []
|
|
323
|
-
], (item) =>
|
|
325
|
+
], (item) => text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true);
|
|
326
|
+
}
|
|
324
327
|
}
|
|
325
328
|
}, [
|
|
326
329
|
onLinkQuery,
|
|
@@ -338,22 +341,24 @@ var MarkdownEditor = ({ extensions: extensionsParam, slashCommandGroups, onLinkQ
|
|
|
338
341
|
trigger,
|
|
339
342
|
placeholder: {
|
|
340
343
|
delay: 3e3,
|
|
341
|
-
content: () => Domino.of("div").
|
|
344
|
+
content: () => Domino.of("div").children(Domino.of("span").text("Press"), ...trigger.map((text) => Domino.of("span").classNames("mx-1 px-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm").text(text)), Domino.of("span").text("for commands.")).build()
|
|
342
345
|
},
|
|
343
346
|
getMenu
|
|
344
347
|
};
|
|
345
348
|
}, [
|
|
349
|
+
onLinkQuery,
|
|
346
350
|
getMenu
|
|
347
351
|
]);
|
|
348
|
-
const {
|
|
352
|
+
const { groupsRef, extension, ...commandMenuProps } = usePopoverMenu(options);
|
|
349
353
|
const extensions = useMemo3(() => [
|
|
350
354
|
extensionsParam,
|
|
351
|
-
|
|
352
|
-
].filter(
|
|
355
|
+
extension
|
|
356
|
+
].filter(isTruthy2), [
|
|
353
357
|
extensionsParam,
|
|
354
|
-
|
|
358
|
+
extension
|
|
355
359
|
]);
|
|
356
|
-
return /* @__PURE__ */ React2.createElement(
|
|
360
|
+
return /* @__PURE__ */ React2.createElement(PopoverMenuProvider, {
|
|
361
|
+
view: viewRef.current,
|
|
357
362
|
groups: groupsRef.current,
|
|
358
363
|
...commandMenuProps
|
|
359
364
|
}, /* @__PURE__ */ React2.createElement(MarkdownEditorImpl, {
|
|
@@ -412,7 +417,7 @@ var MarkdownEditorImpl = /* @__PURE__ */ forwardRef(({ id, role = "article", ini
|
|
|
412
417
|
}),
|
|
413
418
|
providerExtensions,
|
|
414
419
|
extensions
|
|
415
|
-
].filter(
|
|
420
|
+
].filter(isTruthy2),
|
|
416
421
|
...role !== "section" && {
|
|
417
422
|
id,
|
|
418
423
|
scrollTo,
|
|
@@ -473,7 +478,7 @@ var MarkdownEditorImpl = /* @__PURE__ */ forwardRef(({ id, role = "article", ini
|
|
|
473
478
|
const getView = useCallback(() => {
|
|
474
479
|
invariant3(editorView, void 0, {
|
|
475
480
|
F: __dxlog_file3,
|
|
476
|
-
L:
|
|
481
|
+
L: 240,
|
|
477
482
|
S: void 0,
|
|
478
483
|
A: [
|
|
479
484
|
"editorView",
|
|
@@ -573,7 +578,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
573
578
|
objectForms,
|
|
574
579
|
schemaWhiteList
|
|
575
580
|
]);
|
|
576
|
-
const
|
|
581
|
+
const handleLinkQuery = useCallback2(async (query) => {
|
|
577
582
|
const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
|
|
578
583
|
const results = await space?.db.query(Query.select(filter)).run();
|
|
579
584
|
const getLabel = (object2) => {
|
|
@@ -629,7 +634,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
629
634
|
settings,
|
|
630
635
|
scrollPastEnd,
|
|
631
636
|
onViewModeChange,
|
|
632
|
-
onLinkQuery: space ?
|
|
637
|
+
onLinkQuery: space ? handleLinkQuery : void 0
|
|
633
638
|
}) : text ? /* @__PURE__ */ React3.createElement(MarkdownEditor, {
|
|
634
639
|
id,
|
|
635
640
|
role,
|
|
@@ -640,22 +645,19 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
640
645
|
inputMode: settings.editorInputMode,
|
|
641
646
|
scrollPastEnd,
|
|
642
647
|
onViewModeChange,
|
|
643
|
-
onLinkQuery: space ?
|
|
644
|
-
}) : (
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
onLinkQuery: space ? onLinkQuery : void 0
|
|
657
|
-
})
|
|
658
|
-
);
|
|
648
|
+
onLinkQuery: space ? handleLinkQuery : void 0
|
|
649
|
+
}) : /* @__PURE__ */ React3.createElement(MarkdownEditor, {
|
|
650
|
+
id,
|
|
651
|
+
role,
|
|
652
|
+
initialValue: object.text,
|
|
653
|
+
extensions,
|
|
654
|
+
viewMode,
|
|
655
|
+
toolbar: settings.toolbar,
|
|
656
|
+
inputMode: settings.editorInputMode,
|
|
657
|
+
scrollPastEnd,
|
|
658
|
+
onViewModeChange,
|
|
659
|
+
onLinkQuery: space ? handleLinkQuery : void 0
|
|
660
|
+
});
|
|
659
661
|
return /* @__PURE__ */ React3.createElement(React3.Fragment, null, editor, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React3.createElement(PreviewBlock, {
|
|
660
662
|
key: link.ref,
|
|
661
663
|
link,
|
|
@@ -668,11 +670,9 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
668
670
|
var PreviewBlock = ({ link, el }) => {
|
|
669
671
|
var _effect = _useSignals2();
|
|
670
672
|
try {
|
|
671
|
-
const
|
|
672
|
-
|
|
673
|
-
|
|
674
|
-
const space = useSpace(echoDXN?.spaceId);
|
|
675
|
-
const [subject] = useQuery(space, Query.select(Filter.ids(echoDXN?.echoId ?? "")));
|
|
673
|
+
const client = useClient();
|
|
674
|
+
const dxn = DXN.parse(link.ref);
|
|
675
|
+
const subject = client.graph.ref(dxn).target;
|
|
676
676
|
const data = useMemo4(() => ({
|
|
677
677
|
subject
|
|
678
678
|
}), [
|
|
@@ -749,4 +749,4 @@ export {
|
|
|
749
749
|
MarkdownContainer,
|
|
750
750
|
MarkdownContainer_default as default
|
|
751
751
|
};
|
|
752
|
-
//# sourceMappingURL=MarkdownContainer-
|
|
752
|
+
//# sourceMappingURL=MarkdownContainer-J2R3DLCQ.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownContainer.tsx", "../../../src/extensions.tsx", "../../../src/components/MarkdownEditor/MarkdownEditor.tsx", "../../../src/hooks/useSelectCurrentThread.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 { useClient } from '@dxos/react-client';\nimport { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n type PopoverMenuGroup,\n type PopoverMenuItem,\n type PreviewLinkRef,\n type PreviewOptions,\n insertAtCursor,\n insertAtLineStart,\n} from '@dxos/react-ui-editor';\nimport { DataType } from '@dxos/schema';\n\nimport { useExtensions } from '../extensions';\nimport { Markdown } from '../types';\nimport { getFallbackName } from '../util';\n\nimport { MarkdownEditor, type MarkdownEditorProps } from './MarkdownEditor';\n\nexport type MarkdownContainerProps = Pick<\n MarkdownEditorProps,\n 'role' | 'extensionProviders' | 'viewMode' | 'editorStateStore' | 'onViewModeChange'\n> & {\n id: string;\n object: Markdown.Document | DataType.Text | any;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n};\n\nexport const 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(Markdown.Document, 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\n const handleLinkQuery = useCallback(\n async (query?: string): Promise<PopoverMenuGroup[]> => {\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): PopoverMenuItem => {\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 // TODO(burdon): Reconcile variants.\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 ? handleLinkQuery : 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 ? handleLinkQuery : undefined}\n />\n ) : (\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 ? handleLinkQuery : 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 client = useClient();\n const dxn = DXN.parse(link.ref);\n const subject = client.graph.ref(dxn).target;\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: Markdown.Document;\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 ViewUpdate } from '@codemirror/view';\nimport React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport {\n LayoutAction,\n type PromiseIntentDispatcher,\n createIntent,\n useCapabilities,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { debounceAndThrottle } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { createDocAccessor, fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { useIdentity } from '@dxos/react-client/halo';\nimport { Icon, ThemeProvider } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n Cursor,\n type EditorStateStore,\n EditorView,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n type PreviewOptions,\n type RenderCallback,\n createDataExtensions,\n decorateMarkdown,\n documentId,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n preview,\n selectionState,\n typewriter,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { type DataType } from '@dxos/schema';\nimport { isTruthy } from '@dxos/util';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { type Markdown } from './types';\nimport { setFallbackName } from './util';\n\ntype ExtensionsOptions = {\n document?: Markdown.Document;\n id?: string;\n text?: DataType.Text;\n dispatch?: PromiseIntentDispatcher;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n previewOptions?: PreviewOptions;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({\n 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(isTruthy),\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 viewMode,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n selectionManager && selectionChange(selectionManager),\n settings.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings.folding && folding(),\n ].filter(isTruthy);\n\n //\n // Markdown\n //\n if (viewMode !== 'source') {\n extensions.push(\n ...[\n formattingKeymap(),\n decorateMarkdown({\n selectionChangeDelay: 100,\n numberedHeadings: settings.numberedHeadings ? { from: 2 } : undefined,\n // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.\n 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 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", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef } from 'react';\nimport { useDropzone } from 'react-dropzone';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { Domino, toLocalizedString, useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type DNDOptions,\n type EditorInputMode,\n type EditorSelectionState,\n type EditorStateStore,\n EditorToolbar,\n type EditorToolbarActionGraphProps,\n type EditorViewMode,\n type PopoverMenuGroup,\n PopoverMenuProvider,\n type UsePopoverMenuProps,\n type UseTextEditorProps,\n addLink,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorGutter,\n editorSlots,\n filterMenuGroups,\n formattingCommands,\n linkSlashCommands,\n processEditorPayload,\n stackItemContentEditorClassNames,\n useEditorToolbarState,\n useFormattingState,\n usePopoverMenu,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { isNonNullable, isTruthy } from '@dxos/util';\n\nimport { useSelectCurrentThread } from '../../hooks';\nimport { meta } from '../../meta';\nimport { type MarkdownPluginState } from '../../types';\n\nexport type MarkdownEditorProps = {\n id: string;\n role?: string;\n toolbar?: boolean;\n inputMode?: EditorInputMode;\n scrollPastEnd?: boolean;\n slashCommandGroups?: PopoverMenuGroup[];\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<PopoverMenuGroup[]>;\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: extensionsParam,\n slashCommandGroups,\n onLinkQuery,\n ...props\n}: MarkdownEditorProps) => {\n const { t } = useTranslation();\n const viewRef = useRef<EditorView>(null);\n\n const getMenu = useCallback<NonNullable<UsePopoverMenuProps['getMenu']>>(\n ({ text, trigger }) => {\n switch (trigger) {\n case '@': {\n return onLinkQuery?.(text) ?? [];\n }\n\n case '/':\n default: {\n return filterMenuGroups([formattingCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>\n text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true,\n );\n }\n }\n },\n [onLinkQuery, slashCommandGroups],\n );\n\n const options = useMemo<UsePopoverMenuProps>(() => {\n const trigger = onLinkQuery ? ['/', '@'] : ['/'];\n return {\n viewRef,\n trigger,\n placeholder: {\n delay: 3_000,\n content: () =>\n Domino.of('div')\n .children(\n Domino.of('span').text('Press'),\n ...trigger.map((text) =>\n Domino.of('span')\n .classNames('mx-1 px-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm')\n .text(text),\n ),\n Domino.of('span').text('for commands.'),\n )\n .build(),\n },\n getMenu,\n };\n }, [onLinkQuery, getMenu]);\n\n const { groupsRef, extension, ...commandMenuProps } = usePopoverMenu(options);\n const extensions = useMemo(() => [extensionsParam, extension].filter(isTruthy), [extensionsParam, extension]);\n\n return (\n <PopoverMenuProvider view={viewRef.current} groups={groupsRef.current} {...commandMenuProps}>\n <MarkdownEditorImpl ref={viewRef} {...props} extensions={extensions} />\n </PopoverMenuProvider>\n );\n};\n\nconst MarkdownEditorImpl = forwardRef<EditorView | null, 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(meta.id);\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 search: true,\n }),\n createMarkdownExtensions(),\n createThemeExtensions({ themeMode, syntaxHighlighting: true, slots: editorSlots }),\n editorGutter,\n role !== 'section' && onFileUpload && dropFile({ onDrop: handleDrop }),\n providerExtensions,\n extensions,\n ].filter(isTruthy),\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<EditorView | null, EditorView | null>(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 | null) => {\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 * as Schema from 'effect/Schema';\nimport { useMemo } from 'react';\n\nimport { LayoutAction, createResolver, useIntentResolver } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { Cursor, setSelection } from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\n\n/**\n * Handle scrolling and selection of the current thread in a markdown editor.\n */\nexport const useSelectCurrentThread = (editorView: EditorView | null, documentId: string) => {\n const scrollIntoViewResolver = useMemo(\n () =>\n createResolver({\n intent: LayoutAction.UpdateLayout,\n position: 'hoist',\n filter: (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(meta.id, scrollIntoViewResolver);\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", "useClient", "fullyQualifiedId", "getSpace", "toLocalizedString", "useTranslation", "insertAtCursor", "insertAtLineStart", "DataType", "React", "useMemo", "createRoot", "LayoutAction", "createIntent", "useCapabilities", "useIntentDispatcher", "debounceAndThrottle", "invariant", "createDocAccessor", "fullyQualifiedId", "getSpace", "useIdentity", "Icon", "ThemeProvider", "Cursor", "EditorView", "InputModeExtensions", "createDataExtensions", "decorateMarkdown", "documentId", "folding", "formattingKeymap", "linkTooltip", "listener", "preview", "selectionState", "typewriter", "defaultTx", "isTruthy", "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", "isTruthy", "extensions", "selectionChange", "InputModeExtensions", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "from", "undefined", "renderLinkButton", "createLinkRenderer", "createIntent", "LayoutAction", "Open", "part", "subject", "options", "pivotId", "fullyQualifiedId", "linkTooltip", "renderLinkTooltip", "preview", "items", "split", "EditorView", "updateListener", "of", "debounceAndThrottle", "update", "selectionSet", "state", "facet", "documentId", "cursorConverter", "Cursor", "converter", "selection", "ranges", "map", "range", "toCursor", "to", "updateMultiRange", "style", "hover", "icon", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "onClick", "qualifiedId", "at", "invariant", "href", "rel", "renderRoot", "a", "className", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "React", "forwardRef", "useCallback", "useEffect", "useImperativeHandle", "useMemo", "useRef", "useDropzone", "invariant", "Domino", "toLocalizedString", "useThemeContext", "useTranslation", "EditorToolbar", "PopoverMenuProvider", "addLink", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorGutter", "editorSlots", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "processEditorPayload", "stackItemContentEditorClassNames", "useEditorToolbarState", "useFormattingState", "usePopoverMenu", "useTextEditor", "StackItem", "isNonNullable", "isTruthy", "EditorView", "Schema", "useMemo", "LayoutAction", "createResolver", "useIntentResolver", "invariant", "Cursor", "setSelection", "useSelectCurrentThread", "editorView", "documentId", "scrollIntoViewResolver", "useMemo", "createResolver", "intent", "LayoutAction", "UpdateLayout", "position", "filter", "data", "is", "ScrollIntoView", "fields", "input", "subject", "options", "cursor", "resolve", "invariant", "range", "Cursor", "getRangeFromCursor", "state", "selection", "main", "from", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "dispatch", "useIntentResolver", "meta", "id", "MarkdownEditor", "extensions", "extensionsParam", "slashCommandGroups", "onLinkQuery", "props", "t", "useTranslation", "viewRef", "useRef", "getMenu", "useCallback", "text", "trigger", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "item", "toLocalizedString", "label", "toLowerCase", "includes", "options", "useMemo", "placeholder", "delay", "content", "Domino", "of", "children", "map", "classNames", "build", "groupsRef", "extension", "commandMenuProps", "usePopoverMenu", "filter", "isTruthy", "React", "PopoverMenuProvider", "view", "current", "groups", "MarkdownEditorImpl", "ref", "forwardRef", "id", "role", "initialValue", "customActions", "editorStateStore", "extensionProviders", "scrollPastEnd", "toolbar", "viewMode", "onFileUpload", "onViewModeChange", "forwardedRef", "meta", "themeMode", "useThemeContext", "toolbarState", "useEditorToolbarState", "formattingObserver", "useFormattingState", "scrollTo", "selection", "getState", "providerExtensions", "flatMap", "provider", "isNonNullable", "handleDrop", "files", "file", "info", "undefined", "processEditorPayload", "type", "data", "url", "parentRef", "editorView", "focusAttributes", "useTextEditor", "createBasicExtensions", "readOnly", "search", "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", "className", "stackItemContentEditorClassNames", "data-popover-collision-boundary", "composer", "window", "MarkdownContainer", "id", "role", "object", "settings", "selectionManager", "viewMode", "editorStateStore", "onViewModeChange", "t", "useTranslation", "scrollPastEnd", "doc", "Obj", "instanceOf", "Markdown", "Document", "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", "handleLinkQuery", "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", "onLinkQuery", "MarkdownEditor", "initialValue", "content", "toolbar", "inputMode", "editorInputMode", "PreviewBlock", "key", "client", "useClient", "dxn", "DXN", "parse", "subject", "graph", "target", "data", "createPortal", "Surface", "limit", "props", "useEffect", "fallbackName", "getFallbackName", "upload", "FileUploader", "handleFileUpload", "file", "useAppGraph", "customActions", "Rx", "make", "get", "actions", "nodes", "action", "properties", "disposition", "edges", "node", "source", "onFileUpload"]
|
|
7
|
+
}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
Markdown_exports
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-FWZKC6X5.mjs";
|
|
5
5
|
import "./chunk-VCG2U522.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";
|
|
11
|
-
var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
|
|
11
|
+
var anchor_sort_default = (() => contributes(Capabilities.AnchorSort, {
|
|
12
12
|
key: Type.getTypename(Markdown_exports.Document),
|
|
13
13
|
sort: (anchorA, anchorB) => {
|
|
14
14
|
const doc = getTarget(anchorA);
|
|
@@ -26,8 +26,8 @@ var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
|
|
|
26
26
|
const posB = getStartPosition(anchorB.anchor);
|
|
27
27
|
return posA - posB;
|
|
28
28
|
}
|
|
29
|
-
});
|
|
29
|
+
}));
|
|
30
30
|
export {
|
|
31
31
|
anchor_sort_default as default
|
|
32
32
|
};
|
|
33
|
-
//# sourceMappingURL=anchor-sort-
|
|
33
|
+
//# sourceMappingURL=anchor-sort-FCRYL2FX.mjs.map
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/capabilities/anchor-sort.ts"],
|
|
4
4
|
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes } from '@dxos/app-framework';\nimport { Type } from '@dxos/echo';\nimport { createDocAccessor, getRangeFromCursor, getTarget } from '@dxos/react-client/echo';\n\nimport { Markdown } from '../types';\n\nexport default () =>\n contributes(Capabilities.AnchorSort, {\n key: Type.getTypename(Markdown.Document)!,\n sort: (anchorA, anchorB) => {\n const doc = getTarget(anchorA) as Markdown.Document;\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,YAAY;AACrB,SAASC,mBAAmBC,oBAAoBC,iBAAiB;AAIjE,IAAA,
|
|
5
|
+
"mappings": ";;;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,YAAY;AACrB,SAASC,mBAAmBC,oBAAoBC,iBAAiB;AAIjE,IAAA,uBAAe,MACbC,YAAYC,aAAaC,YAAY;EACnCC,KAAKC,KAAKC,YAAYC,iBAASC,QAAQ;EACvCC,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
6
|
"names": ["Capabilities", "contributes", "Type", "createDocAccessor", "getRangeFromCursor", "getTarget", "contributes", "Capabilities", "AnchorSort", "key", "Type", "getTypename", "Markdown", "Document", "sort", "anchorA", "anchorB", "doc", "getTarget", "accessor", "content", "target", "createDocAccessor", "undefined", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "posA", "anchor", "posB"]
|
|
7
7
|
}
|
package/dist/lib/node-esm/{app-graph-serializer-56TD3BMX.mjs → app-graph-serializer-FAUQM3BH.mjs}
RENAMED
|
@@ -1,21 +1,21 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
translations
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-XO3IEQJE.mjs";
|
|
5
5
|
import {
|
|
6
6
|
MarkdownAction_exports,
|
|
7
7
|
Markdown_exports
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-FWZKC6X5.mjs";
|
|
9
9
|
import "./chunk-VCG2U522.mjs";
|
|
10
10
|
|
|
11
11
|
// src/capabilities/app-graph-serializer.ts
|
|
12
|
-
import
|
|
12
|
+
import * as Function from "effect/Function";
|
|
13
13
|
import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
|
|
14
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";
|
|
18
|
-
var app_graph_serializer_default = (context) => contributes(Capabilities.AppGraphSerializer, [
|
|
18
|
+
var app_graph_serializer_default = ((context) => contributes(Capabilities.AppGraphSerializer, [
|
|
19
19
|
{
|
|
20
20
|
inputType: Markdown_exports.Document.typename,
|
|
21
21
|
outputType: "text/markdown",
|
|
@@ -36,7 +36,7 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
36
36
|
return;
|
|
37
37
|
}
|
|
38
38
|
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
39
|
-
const result = await dispatch(pipe(createIntent(MarkdownAction_exports.Create, {
|
|
39
|
+
const result = await dispatch(Function.pipe(createIntent(MarkdownAction_exports.Create, {
|
|
40
40
|
name: data.name,
|
|
41
41
|
content: data.data
|
|
42
42
|
}), chain(SpaceAction.AddObject, {
|
|
@@ -45,8 +45,8 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
45
45
|
return result.data?.object;
|
|
46
46
|
}
|
|
47
47
|
}
|
|
48
|
-
]);
|
|
48
|
+
]));
|
|
49
49
|
export {
|
|
50
50
|
app_graph_serializer_default as default
|
|
51
51
|
};
|
|
52
|
-
//# sourceMappingURL=app-graph-serializer-
|
|
52
|
+
//# sourceMappingURL=app-graph-serializer-FAUQM3BH.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 * as Function from 'effect/Function';\n\nimport { Capabilities, type PluginContext, chain, contributes, createIntent } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { isSpace } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { translations } from '../translations';\nimport { Markdown, MarkdownAction } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.AppGraphSerializer, [\n {\n inputType: Markdown.Document.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 ||\n doc.fallbackName ||\n translations[0]['en-US'][Markdown.Document.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) => Obj.instanceOf(DataType.Collection, ancestor)) ??\n space?.properties[DataType.Collection.typename]?.target;\n if (!space || !target) {\n return;\n }\n\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const result = await dispatch(\n Function.pipe(\n createIntent(MarkdownAction.Create, { 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,YAAYA,cAAc;AAE1B,SAASC,cAAkCC,OAAOC,aAAaC,oBAAoB;AACnF,SAASC,WAAW;AACpB,SAASC,mBAAmB;AAC5B,SAASC,eAAe;AACxB,SAASC,gBAAgB;AAKzB,IAAA,gCAAe,CAACC,YACdC,YAAYC,aAAaC,oBAAoB;EAC3C;IACEC,WAAWC,iBAASC,SAASC;IAC7BC,YAAY;;IAEZC,WAAW,OAAOC,SAAAA;AAChB,YAAMC,MAAMD,KAAKE;AACjB,YAAMC,UAAU,MAAMF,IAAIE,QAAQC,KAAI;AACtC,aAAO;QACLC,MACEJ,IAAII,QACJJ,IAAIK,gBACJC,aAAa,CAAA,EAAG,OAAA,EAASZ,iBAASC,SAASC,QAAQ,EAAE,yBAAA;QACvDK,MAAMC,QAAQA;QACdK,MAAM;MACR;IACF;IACAC,aAAa,OAAOP,MAAMQ,cAAAA;AACxB,YAAMC,QAAQD,UAAUE,KAAKC,OAAAA;AAC7B,YAAMC,SACJJ,UAAUK,SAAS,CAACC,aAAaC,IAAIC,WAAWC,SAASC,YAAYJ,QAAAA,CAAAA,KACrEL,OAAOU,WAAWF,SAASC,WAAWvB,QAAQ,GAAGiB;AACnD,UAAI,CAACH,SAAS,CAACG,QAAQ;AACrB;MACF;AAEA,YAAM,EAAEQ,iBAAiBC,SAAQ,IAAKjC,QAAQkC,cAAchC,aAAaiC,gBAAgB;AACzF,YAAMC,SAAS,MAAMH,SACVI,cACPC,aAAaC,uBAAeC,QAAQ;QAAEzB,MAAMH,KAAKG;QAAMF,SAASD,KAAKA;MAAK,CAAA,GAC1E6B,MAAMC,YAAYC,WAAW;QAAEnB;MAAO,CAAA,CAAA,CAAA;AAI1C,aAAOY,OAAOxB,MAAMgC;IACtB;EACF;CACD;",
|
|
6
|
+
"names": ["Function", "Capabilities", "chain", "contributes", "createIntent", "Obj", "SpaceAction", "isSpace", "DataType", "context", "contributes", "Capabilities", "AppGraphSerializer", "inputType", "Markdown", "Document", "typename", "outputType", "serialize", "node", "doc", "data", "content", "load", "name", "fallbackName", "translations", "type", "deserialize", "ancestors", "space", "find", "isSpace", "target", "findLast", "ancestor", "Obj", "instanceOf", "DataType", "Collection", "properties", "dispatchPromise", "dispatch", "getCapability", "IntentDispatcher", "result", "pipe", "createIntent", "MarkdownAction", "Create", "chain", "SpaceAction", "AddObject", "object"]
|
|
7
|
+
}
|
package/dist/lib/node-esm/{blueprint-definition-GVW67KGV.mjs → blueprint-definition-XYFKMIDR.mjs}
RENAMED
|
@@ -2,11 +2,11 @@ import { createRequire } from 'node:module';const require = createRequire(import
|
|
|
2
2
|
import {
|
|
3
3
|
BLUEPRINT_KEY,
|
|
4
4
|
blueprint_definition_default
|
|
5
|
-
} from "./chunk-
|
|
6
|
-
import "./chunk-
|
|
5
|
+
} from "./chunk-FVI7LPC3.mjs";
|
|
6
|
+
import "./chunk-FWZKC6X5.mjs";
|
|
7
7
|
import "./chunk-VCG2U522.mjs";
|
|
8
8
|
export {
|
|
9
9
|
BLUEPRINT_KEY,
|
|
10
10
|
blueprint_definition_default as default
|
|
11
11
|
};
|
|
12
|
-
//# sourceMappingURL=blueprint-definition-
|
|
12
|
+
//# sourceMappingURL=blueprint-definition-XYFKMIDR.mjs.map
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
|
|
3
|
+
// src/capabilities/index.ts
|
|
4
|
+
import { lazy } from "@dxos/app-framework";
|
|
5
|
+
var AnchorSort = lazy(() => import("./anchor-sort-FCRYL2FX.mjs"));
|
|
6
|
+
var AppGraphSerializer = lazy(() => import("./app-graph-serializer-FAUQM3BH.mjs"));
|
|
7
|
+
var BlueprintDefinition = lazy(() => import("./blueprint-definition-XYFKMIDR.mjs"));
|
|
8
|
+
var IntentResolver = lazy(() => import("./intent-resolver-7A2EXGZQ.mjs"));
|
|
9
|
+
var ReactSurface = lazy(() => import("./react-surface-RCLL5WVQ.mjs"));
|
|
10
|
+
var MarkdownSettings = lazy(() => import("./settings-H3UDD3KO.mjs"));
|
|
11
|
+
var MarkdownState = lazy(() => import("./state-W3PECOJX.mjs"));
|
|
12
|
+
var Toolkit = lazy(() => import("./toolkit-HSIKUGNK.mjs"));
|
|
13
|
+
|
|
14
|
+
export {
|
|
15
|
+
AnchorSort,
|
|
16
|
+
AppGraphSerializer,
|
|
17
|
+
BlueprintDefinition,
|
|
18
|
+
IntentResolver,
|
|
19
|
+
ReactSurface,
|
|
20
|
+
MarkdownSettings,
|
|
21
|
+
MarkdownState,
|
|
22
|
+
Toolkit
|
|
23
|
+
};
|
|
24
|
+
//# sourceMappingURL=chunk-7RDNIMTF.mjs.map
|