@dxos/plugin-markdown 0.8.2 → 0.8.3-main.7f5a14c
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-5IEINNQB.mjs → MarkdownContainer-3KTC7Q4C.mjs} +132 -18
- package/dist/lib/browser/MarkdownContainer-3KTC7Q4C.mjs.map +7 -0
- package/dist/lib/browser/{MarkdownPreview-YW5CS3ID.mjs → MarkdownPreview-F4PYFW5L.mjs} +15 -22
- package/dist/lib/browser/MarkdownPreview-F4PYFW5L.mjs.map +7 -0
- package/dist/lib/browser/{anchor-sort-VS4OZVPP.mjs → anchor-sort-BMAN2ABT.mjs} +4 -4
- package/dist/lib/browser/anchor-sort-BMAN2ABT.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-V6RLEHVY.mjs → app-graph-serializer-FLQI6GFL.mjs} +3 -3
- package/dist/lib/browser/{artifact-definition-5NAODQLG.mjs → artifact-definition-FQ2R6KPT.mjs} +6 -6
- package/dist/lib/browser/artifact-definition-FQ2R6KPT.mjs.map +7 -0
- package/dist/lib/browser/{chunk-C5RABVIX.mjs → chunk-CX5GYZYO.mjs} +2 -2
- package/dist/lib/browser/{chunk-ACAID3XF.mjs → chunk-LCMXUTQB.mjs} +7 -7
- package/dist/lib/browser/{chunk-77NGW7EO.mjs → chunk-LXSRQPEP.mjs} +9 -9
- package/dist/lib/browser/chunk-LXSRQPEP.mjs.map +7 -0
- package/dist/lib/browser/{chunk-ECSM56YC.mjs → chunk-N2D26K6W.mjs} +4 -5
- package/dist/lib/browser/chunk-N2D26K6W.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +7 -8
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-resolver-4GDYST4Y.mjs → intent-resolver-6ZOABX2J.mjs} +6 -7
- package/dist/lib/browser/intent-resolver-6ZOABX2J.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-QE4SKXBT.mjs → react-surface-RJQKYJJQ.mjs} +8 -8
- package/dist/lib/browser/react-surface-RJQKYJJQ.mjs.map +7 -0
- package/dist/lib/browser/{settings-W5CK4PXP.mjs → settings-PLH54VC7.mjs} +4 -4
- package/dist/lib/browser/settings-PLH54VC7.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -1
- package/dist/lib/node/{MarkdownContainer-LSNNPNRB.cjs → MarkdownContainer-NG4H6AZJ.cjs} +181 -67
- package/dist/lib/node/MarkdownContainer-NG4H6AZJ.cjs.map +7 -0
- package/dist/lib/node/{MarkdownPreview-G34HSQEB.cjs → MarkdownPreview-GCJJCXY6.cjs} +24 -31
- package/dist/lib/node/MarkdownPreview-GCJJCXY6.cjs.map +7 -0
- package/dist/lib/node/{anchor-sort-NHVF23EU.cjs → anchor-sort-V3T4SFFI.cjs} +12 -12
- package/dist/lib/node/anchor-sort-V3T4SFFI.cjs.map +7 -0
- package/dist/lib/node/{app-graph-serializer-CLALIYN3.cjs → app-graph-serializer-BZPM7HHJ.cjs} +9 -9
- package/dist/lib/node/{artifact-definition-VEAHK7BX.cjs → artifact-definition-U27MH5SC.cjs} +16 -16
- package/dist/lib/node/artifact-definition-U27MH5SC.cjs.map +7 -0
- package/dist/lib/node/{chunk-RQS4KBMG.cjs → chunk-3HHV4MM6.cjs} +6 -7
- package/dist/lib/node/chunk-3HHV4MM6.cjs.map +7 -0
- package/dist/lib/node/{chunk-C4HR7UXE.cjs → chunk-4DYNEQG3.cjs} +10 -10
- package/dist/lib/node/{chunk-G7RBJX22.cjs → chunk-CJLYFGPI.cjs} +12 -12
- package/dist/lib/node/chunk-CJLYFGPI.cjs.map +7 -0
- package/dist/lib/node/{chunk-ZDTL47I7.cjs → chunk-SYEFGLXN.cjs} +6 -6
- package/dist/lib/node/index.cjs +26 -27
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/{intent-resolver-AUZVK3NZ.cjs → intent-resolver-OEFLRNEJ.cjs} +14 -15
- package/dist/lib/node/intent-resolver-OEFLRNEJ.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{react-surface-WJZTEBYO.cjs → react-surface-5RKEWAXS.cjs} +15 -15
- package/dist/lib/node/react-surface-5RKEWAXS.cjs.map +7 -0
- package/dist/lib/node/{settings-IRKU3WPM.cjs → settings-E3NUTXJ4.cjs} +7 -7
- package/dist/lib/node/settings-E3NUTXJ4.cjs.map +7 -0
- package/dist/lib/node/types/index.cjs +7 -7
- package/dist/lib/node/types/index.cjs.map +1 -1
- package/dist/lib/node-esm/{MarkdownContainer-UZSLXMWO.mjs → MarkdownContainer-DZPXCA6J.mjs} +132 -18
- package/dist/lib/node-esm/MarkdownContainer-DZPXCA6J.mjs.map +7 -0
- package/dist/lib/node-esm/{MarkdownPreview-TCV7BI32.mjs → MarkdownPreview-KFDRV4GC.mjs} +15 -22
- package/dist/lib/node-esm/MarkdownPreview-KFDRV4GC.mjs.map +7 -0
- package/dist/lib/node-esm/{anchor-sort-G2HLCYFK.mjs → anchor-sort-BXL7BE67.mjs} +4 -4
- package/dist/lib/node-esm/anchor-sort-BXL7BE67.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-C3RNTQGM.mjs → app-graph-serializer-EBH54X6Z.mjs} +3 -3
- package/dist/lib/node-esm/{artifact-definition-7TIJW2CO.mjs → artifact-definition-NQOHB6S5.mjs} +6 -6
- package/dist/lib/node-esm/artifact-definition-NQOHB6S5.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-6RPARLIK.mjs → chunk-K26TX5V4.mjs} +9 -9
- package/dist/lib/node-esm/chunk-K26TX5V4.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-TCFJNUAE.mjs → chunk-Q7WUBLL3.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-NCMPVEXO.mjs → chunk-T2Y2BT53.mjs} +4 -5
- package/dist/lib/node-esm/chunk-T2Y2BT53.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-EIUTPXGL.mjs → chunk-WANCCPU7.mjs} +7 -7
- package/dist/lib/node-esm/index.mjs +7 -8
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-resolver-FTNXUNI2.mjs → intent-resolver-CLMSVF2K.mjs} +6 -7
- package/dist/lib/node-esm/intent-resolver-CLMSVF2K.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-XNM3YDFB.mjs → react-surface-Z3DX37JV.mjs} +8 -8
- package/dist/lib/node-esm/react-surface-Z3DX37JV.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-MK7D7LHQ.mjs → settings-SIY33P3F.mjs} +4 -4
- package/dist/lib/node-esm/settings-SIY33P3F.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +4 -2
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +2 -6
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +1 -1
- package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/util.d.ts.map +1 -1
- package/package.json +38 -39
- package/src/MarkdownPlugin.tsx +3 -5
- package/src/capabilities/anchor-sort.ts +2 -2
- package/src/capabilities/artifact-definition.ts +3 -3
- package/src/capabilities/intent-resolver.ts +4 -5
- package/src/capabilities/react-surface.tsx +4 -4
- package/src/capabilities/settings.ts +2 -2
- package/src/components/MarkdownContainer.tsx +61 -7
- package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +3 -3
- package/src/components/MarkdownEditor/MarkdownEditor.tsx +196 -144
- package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +8 -7
- package/src/components/MarkdownPreview/MarkdownPreview.tsx +14 -28
- package/src/components/Suggestions.stories.tsx +8 -9
- package/src/components/Toolbar.stories.tsx +3 -3
- package/src/types/schema.ts +2 -3
- package/src/util.tsx +5 -7
- package/dist/lib/browser/MarkdownContainer-5IEINNQB.mjs.map +0 -7
- package/dist/lib/browser/MarkdownPreview-YW5CS3ID.mjs.map +0 -7
- package/dist/lib/browser/anchor-sort-VS4OZVPP.mjs.map +0 -7
- package/dist/lib/browser/artifact-definition-5NAODQLG.mjs.map +0 -7
- package/dist/lib/browser/chunk-77NGW7EO.mjs.map +0 -7
- package/dist/lib/browser/chunk-ECSM56YC.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-4GDYST4Y.mjs.map +0 -7
- package/dist/lib/browser/react-surface-QE4SKXBT.mjs.map +0 -7
- package/dist/lib/browser/settings-W5CK4PXP.mjs.map +0 -7
- package/dist/lib/node/MarkdownContainer-LSNNPNRB.cjs.map +0 -7
- package/dist/lib/node/MarkdownPreview-G34HSQEB.cjs.map +0 -7
- package/dist/lib/node/anchor-sort-NHVF23EU.cjs.map +0 -7
- package/dist/lib/node/artifact-definition-VEAHK7BX.cjs.map +0 -7
- package/dist/lib/node/chunk-G7RBJX22.cjs.map +0 -7
- package/dist/lib/node/chunk-RQS4KBMG.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-AUZVK3NZ.cjs.map +0 -7
- package/dist/lib/node/react-surface-WJZTEBYO.cjs.map +0 -7
- package/dist/lib/node/settings-IRKU3WPM.cjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-UZSLXMWO.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownPreview-TCV7BI32.mjs.map +0 -7
- package/dist/lib/node-esm/anchor-sort-G2HLCYFK.mjs.map +0 -7
- package/dist/lib/node-esm/artifact-definition-7TIJW2CO.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-6RPARLIK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NCMPVEXO.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-FTNXUNI2.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-XNM3YDFB.mjs.map +0 -7
- package/dist/lib/node-esm/settings-MK7D7LHQ.mjs.map +0 -7
- /package/dist/lib/browser/{app-graph-serializer-V6RLEHVY.mjs.map → app-graph-serializer-FLQI6GFL.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-C5RABVIX.mjs.map → chunk-CX5GYZYO.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-ACAID3XF.mjs.map → chunk-LCMXUTQB.mjs.map} +0 -0
- /package/dist/lib/node/{app-graph-serializer-CLALIYN3.cjs.map → app-graph-serializer-BZPM7HHJ.cjs.map} +0 -0
- /package/dist/lib/node/{chunk-C4HR7UXE.cjs.map → chunk-4DYNEQG3.cjs.map} +0 -0
- /package/dist/lib/node/{chunk-ZDTL47I7.cjs.map → chunk-SYEFGLXN.cjs.map} +0 -0
- /package/dist/lib/node-esm/{app-graph-serializer-C3RNTQGM.mjs.map → app-graph-serializer-EBH54X6Z.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-TCFJNUAE.mjs.map → chunk-Q7WUBLL3.mjs.map} +0 -0
- /package/dist/lib/node-esm/{chunk-EIUTPXGL.mjs.map → chunk-WANCCPU7.mjs.map} +0 -0
|
@@ -1,14 +1,14 @@
|
|
|
1
|
-
import "./chunk-
|
|
1
|
+
import "./chunk-LCMXUTQB.mjs";
|
|
2
2
|
import {
|
|
3
3
|
MarkdownCapabilities
|
|
4
4
|
} from "./chunk-QVJETNGS.mjs";
|
|
5
5
|
import {
|
|
6
6
|
getFallbackName,
|
|
7
7
|
setFallbackName
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-LXSRQPEP.mjs";
|
|
9
9
|
import {
|
|
10
10
|
DocumentType
|
|
11
|
-
} from "./chunk-
|
|
11
|
+
} from "./chunk-N2D26K6W.mjs";
|
|
12
12
|
import {
|
|
13
13
|
MARKDOWN_PLUGIN
|
|
14
14
|
} from "./chunk-JX6XNEHE.mjs";
|
|
@@ -16,19 +16,22 @@ import {
|
|
|
16
16
|
// packages/plugins/plugin-markdown/src/components/MarkdownContainer.tsx
|
|
17
17
|
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
18
18
|
import { Rx } from "@effect-rx/rx-react";
|
|
19
|
-
import React3, { useEffect as useEffect2, useMemo as useMemo4 } from "react";
|
|
20
|
-
import { Capabilities, useAppGraph, useCapabilities as useCapabilities2 } from "@dxos/app-framework";
|
|
21
|
-
import {
|
|
19
|
+
import React3, { useCallback as useCallback2, useEffect as useEffect2, useMemo as useMemo4 } from "react";
|
|
20
|
+
import { Capabilities, useAppGraph, useCapabilities as useCapabilities2, usePluginManager } from "@dxos/app-framework";
|
|
21
|
+
import { Filter, Obj, Query } from "@dxos/echo";
|
|
22
|
+
import { SpaceCapabilities } from "@dxos/plugin-space";
|
|
22
23
|
import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2 } from "@dxos/react-client/echo";
|
|
24
|
+
import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
25
|
+
import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
|
|
23
26
|
import { DataType } from "@dxos/schema";
|
|
24
27
|
|
|
25
28
|
// packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditor.tsx
|
|
26
29
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
27
|
-
import React, { useMemo as useMemo2, useEffect, useCallback } from "react";
|
|
30
|
+
import React, { useMemo as useMemo2, useEffect, useCallback, forwardRef, useImperativeHandle, useRef } from "react";
|
|
28
31
|
import { useDropzone } from "react-dropzone";
|
|
29
32
|
import { invariant as invariant2 } from "@dxos/invariant";
|
|
30
|
-
import { useThemeContext, useTranslation } from "@dxos/react-ui";
|
|
31
|
-
import {
|
|
33
|
+
import { toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
|
|
34
|
+
import { addLink, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorGutter, editorSlots, EditorToolbar, processEditorPayload, RefPopover, stackItemContentEditorClassNames, useEditorToolbarState, useFormattingState, useCommandMenu, useTextEditor, filterItems, coreSlashCommands, CommandMenu, linkSlashCommands } from "@dxos/react-ui-editor";
|
|
32
35
|
import { StackItem } from "@dxos/react-ui-stack";
|
|
33
36
|
import { isNotFalsy, isNonNullable } from "@dxos/util";
|
|
34
37
|
|
|
@@ -94,7 +97,59 @@ var useSelectCurrentThread = (editorView, documentId2) => {
|
|
|
94
97
|
|
|
95
98
|
// packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditor.tsx
|
|
96
99
|
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-markdown/src/components/MarkdownEditor/MarkdownEditor.tsx";
|
|
97
|
-
var MarkdownEditor = ({
|
|
100
|
+
var MarkdownEditor = ({ extensions: _extensions, slashCommandGroups, onLinkQuery, ...props }) => {
|
|
101
|
+
var _effect = _useSignals();
|
|
102
|
+
try {
|
|
103
|
+
const { t } = useTranslation();
|
|
104
|
+
const viewRef = useRef();
|
|
105
|
+
const getGroups = useCallback((trigger, query) => {
|
|
106
|
+
switch (trigger) {
|
|
107
|
+
case "@":
|
|
108
|
+
return onLinkQuery?.(query) ?? [];
|
|
109
|
+
case "/":
|
|
110
|
+
default:
|
|
111
|
+
return filterItems([
|
|
112
|
+
coreSlashCommands,
|
|
113
|
+
linkSlashCommands,
|
|
114
|
+
...slashCommandGroups ?? []
|
|
115
|
+
], (item) => query ? toLocalizedString(item.label, t).toLowerCase().includes(query.toLowerCase()) : true);
|
|
116
|
+
}
|
|
117
|
+
}, [
|
|
118
|
+
onLinkQuery,
|
|
119
|
+
slashCommandGroups
|
|
120
|
+
]);
|
|
121
|
+
const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu({
|
|
122
|
+
viewRef,
|
|
123
|
+
getGroups,
|
|
124
|
+
trigger: onLinkQuery ? [
|
|
125
|
+
"/",
|
|
126
|
+
"@"
|
|
127
|
+
] : "/"
|
|
128
|
+
});
|
|
129
|
+
const extensions = useMemo2(() => [
|
|
130
|
+
_extensions,
|
|
131
|
+
commandMenu
|
|
132
|
+
].filter(isNotFalsy), [
|
|
133
|
+
_extensions,
|
|
134
|
+
commandMenu
|
|
135
|
+
]);
|
|
136
|
+
return /* @__PURE__ */ React.createElement(RefPopover, {
|
|
137
|
+
modal: false,
|
|
138
|
+
...refPopoverProps
|
|
139
|
+
}, /* @__PURE__ */ React.createElement(MarkdownEditorImpl, {
|
|
140
|
+
ref: viewRef,
|
|
141
|
+
...props,
|
|
142
|
+
extensions
|
|
143
|
+
}), /* @__PURE__ */ React.createElement(CommandMenu, {
|
|
144
|
+
groups: groupsRef.current,
|
|
145
|
+
currentItem,
|
|
146
|
+
onSelect
|
|
147
|
+
}));
|
|
148
|
+
} finally {
|
|
149
|
+
_effect.f();
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
var MarkdownEditorImpl = /* @__PURE__ */ forwardRef(({ id, role = "article", initialValue, extensions, extensionProviders, scrollPastEnd, toolbar, customActions, viewMode, editorStateStore, onFileUpload, onViewModeChange }, forwardedRef) => {
|
|
98
153
|
var _effect = _useSignals();
|
|
99
154
|
try {
|
|
100
155
|
const { t } = useTranslation(MARKDOWN_PLUGIN);
|
|
@@ -159,6 +214,9 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
159
214
|
extensions,
|
|
160
215
|
providerExtensions
|
|
161
216
|
]);
|
|
217
|
+
useImperativeHandle(forwardedRef, () => editorView, [
|
|
218
|
+
editorView
|
|
219
|
+
]);
|
|
162
220
|
useTest(editorView);
|
|
163
221
|
useSelectCurrentThread(editorView, id);
|
|
164
222
|
const { acceptedFiles, getInputProps, open } = useDropzone({
|
|
@@ -200,7 +258,7 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
200
258
|
const getView = useCallback(() => {
|
|
201
259
|
invariant2(editorView, void 0, {
|
|
202
260
|
F: __dxlog_file2,
|
|
203
|
-
L:
|
|
261
|
+
L: 216,
|
|
204
262
|
S: void 0,
|
|
205
263
|
A: [
|
|
206
264
|
"editorView",
|
|
@@ -244,7 +302,7 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
244
302
|
} finally {
|
|
245
303
|
_effect.f();
|
|
246
304
|
}
|
|
247
|
-
};
|
|
305
|
+
});
|
|
248
306
|
var useTest = (view) => {
|
|
249
307
|
useEffect(() => {
|
|
250
308
|
const composer = window.composer;
|
|
@@ -472,9 +530,10 @@ var renderRoot = (root, node) => {
|
|
|
472
530
|
var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMode, editorStateStore, onViewModeChange }) => {
|
|
473
531
|
var _effect = _useSignals2();
|
|
474
532
|
try {
|
|
533
|
+
const { t } = useTranslation2();
|
|
475
534
|
const scrollPastEnd = role === "article";
|
|
476
|
-
const doc =
|
|
477
|
-
const text =
|
|
535
|
+
const doc = Obj.instanceOf(DocumentType, object) ? object : void 0;
|
|
536
|
+
const text = Obj.instanceOf(DataType.Text, object) ? object : void 0;
|
|
478
537
|
const extensions = useExtensions({
|
|
479
538
|
document: doc,
|
|
480
539
|
text,
|
|
@@ -484,6 +543,58 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
484
543
|
viewMode,
|
|
485
544
|
editorStateStore
|
|
486
545
|
});
|
|
546
|
+
const manager = usePluginManager();
|
|
547
|
+
const resolve = useCallback2((typename) => manager.context.getCapabilities(Capabilities.Metadata).find(({ id: id2 }) => id2 === typename)?.metadata ?? {}, [
|
|
548
|
+
manager
|
|
549
|
+
]);
|
|
550
|
+
const space = getSpace2(object);
|
|
551
|
+
const objectForms = useCapabilities2(SpaceCapabilities.ObjectForm);
|
|
552
|
+
const filter = useMemo4(() => Filter.or(...objectForms.map((form) => Filter.type(form.objectSchema))), [
|
|
553
|
+
objectForms
|
|
554
|
+
]);
|
|
555
|
+
const onLinkQuery = useCallback2(async (query) => {
|
|
556
|
+
const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
|
|
557
|
+
const results = await space?.db.query(Query.select(filter)).run();
|
|
558
|
+
const getLabel = (object2) => {
|
|
559
|
+
const type = Obj.getTypename(object2);
|
|
560
|
+
const metadata = resolve(type);
|
|
561
|
+
return metadata.label?.(object2) || object2.name || [
|
|
562
|
+
"object name placeholder",
|
|
563
|
+
{
|
|
564
|
+
ns: type,
|
|
565
|
+
default: "New object"
|
|
566
|
+
}
|
|
567
|
+
];
|
|
568
|
+
};
|
|
569
|
+
const items = results?.objects.filter((object2) => toLocalizedString2(getLabel(object2), t).toLowerCase().includes(name)).map((object2) => {
|
|
570
|
+
const metadata = resolve(Obj.getTypename(object2));
|
|
571
|
+
const label = toLocalizedString2(getLabel(object2), t);
|
|
572
|
+
return {
|
|
573
|
+
id: object2.id,
|
|
574
|
+
label,
|
|
575
|
+
icon: metadata.icon,
|
|
576
|
+
onSelect: (view, head) => {
|
|
577
|
+
const link = `[${label}][${Obj.getDXN(object2)}]`;
|
|
578
|
+
if (query?.startsWith("@")) {
|
|
579
|
+
insertAtLineStart(view, head, `!${link}
|
|
580
|
+
`);
|
|
581
|
+
} else {
|
|
582
|
+
insertAtCursor(view, head, `${link} `);
|
|
583
|
+
}
|
|
584
|
+
}
|
|
585
|
+
};
|
|
586
|
+
}) ?? [];
|
|
587
|
+
return [
|
|
588
|
+
{
|
|
589
|
+
id: "echo",
|
|
590
|
+
items
|
|
591
|
+
}
|
|
592
|
+
];
|
|
593
|
+
}, [
|
|
594
|
+
filter,
|
|
595
|
+
resolve,
|
|
596
|
+
space
|
|
597
|
+
]);
|
|
487
598
|
if (doc) {
|
|
488
599
|
return /* @__PURE__ */ React3.createElement(DocumentEditor, {
|
|
489
600
|
id: fullyQualifiedId2(object),
|
|
@@ -493,7 +604,8 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
493
604
|
viewMode,
|
|
494
605
|
settings,
|
|
495
606
|
scrollPastEnd,
|
|
496
|
-
onViewModeChange
|
|
607
|
+
onViewModeChange,
|
|
608
|
+
onLinkQuery: space ? onLinkQuery : void 0
|
|
497
609
|
});
|
|
498
610
|
} else if (text) {
|
|
499
611
|
return /* @__PURE__ */ React3.createElement(MarkdownEditor, {
|
|
@@ -505,7 +617,8 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
505
617
|
toolbar: settings.toolbar,
|
|
506
618
|
inputMode: settings.editorInputMode,
|
|
507
619
|
scrollPastEnd,
|
|
508
|
-
onViewModeChange
|
|
620
|
+
onViewModeChange,
|
|
621
|
+
onLinkQuery: space ? onLinkQuery : void 0
|
|
509
622
|
});
|
|
510
623
|
} else {
|
|
511
624
|
return /* @__PURE__ */ React3.createElement(MarkdownEditor, {
|
|
@@ -517,7 +630,8 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
|
|
|
517
630
|
toolbar: settings.toolbar,
|
|
518
631
|
inputMode: settings.editorInputMode,
|
|
519
632
|
scrollPastEnd,
|
|
520
|
-
onViewModeChange
|
|
633
|
+
onViewModeChange,
|
|
634
|
+
onLinkQuery: space ? onLinkQuery : void 0
|
|
521
635
|
});
|
|
522
636
|
}
|
|
523
637
|
} finally {
|
|
@@ -585,4 +699,4 @@ export {
|
|
|
585
699
|
DocumentEditor,
|
|
586
700
|
MarkdownContainer_default as default
|
|
587
701
|
};
|
|
588
|
-
//# sourceMappingURL=MarkdownContainer-
|
|
702
|
+
//# sourceMappingURL=MarkdownContainer-3KTC7Q4C.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 } from 'react';\n\nimport { Capabilities, useAppGraph, useCapabilities, usePluginManager } from '@dxos/app-framework';\nimport { Filter, Obj, Query } from '@dxos/echo';\nimport { SpaceCapabilities } from '@dxos/plugin-space';\nimport { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport { type CommandMenuGroup, type CommandMenuItem, insertAtCursor, insertAtLineStart } 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 extensions = useExtensions({ document: doc, text, id, settings, selectionManager, viewMode, editorStateStore });\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 filter = useMemo(() => Filter.or(...objectForms.map((form) => Filter.type(form.objectSchema))), [objectForms]);\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 type = Obj.getTypename(object)!;\n const metadata = resolve(type);\n return (\n metadata.label?.(object) || object.name || ['object name placeholder', { ns: type, default: 'New object' }]\n );\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 if (doc) {\n return (\n <DocumentEditor\n id={fullyQualifiedId(object)}\n role={role}\n document={doc}\n extensions={extensions}\n viewMode={viewMode}\n settings={settings}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n onLinkQuery={space ? onLinkQuery : undefined}\n />\n );\n } else if (text) {\n return (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={text.content}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n onLinkQuery={space ? onLinkQuery : undefined}\n />\n );\n } else {\n // TODO(burdon): Normalize with above.\n return (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={object.text}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n onLinkQuery={space ? onLinkQuery : undefined}\n />\n );\n }\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, { useMemo, useEffect, useCallback, forwardRef, 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 addLink,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorGutter,\n editorSlots,\n EditorToolbar,\n processEditorPayload,\n RefPopover,\n stackItemContentEditorClassNames,\n type DNDOptions,\n type EditorInputMode,\n type EditorSelectionState,\n type EditorStateStore,\n type EditorToolbarActionGraphProps,\n type EditorViewMode,\n type CommandMenuGroup,\n type UseTextEditorProps,\n useEditorToolbarState,\n useFormattingState,\n useCommandMenu,\n useTextEditor,\n filterItems,\n coreSlashCommands,\n CommandMenu,\n linkSlashCommands,\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 *\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 const getGroups = 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 const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu({\n viewRef,\n getGroups,\n trigger: onLinkQuery ? ['/', '@'] : '/',\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 extensions,\n extensionProviders,\n scrollPastEnd,\n toolbar,\n customActions,\n viewMode,\n editorStateStore,\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 React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport {\n createIntent,\n LayoutAction,\n type PromiseIntentDispatcher,\n useCapabilities,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { createDocAccessor, fullyQualifiedId, getSpace, type QueryResult } from '@dxos/react-client/echo';\nimport { useIdentity } from '@dxos/react-client/halo';\nimport { Icon, ThemeProvider } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n type AutocompleteResult,\n type EditorStateStore,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n createDataExtensions,\n autocomplete,\n decorateMarkdown,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n preview,\n selectionState,\n typewriter,\n type RenderCallback,\n EditorView,\n documentId,\n Cursor,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { type DataType } from '@dxos/schema';\nimport { isNotFalsy } from '@dxos/util';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { type DocumentType, type MarkdownSettingsProps } from './types';\nimport { setFallbackName } from './util';\n\ntype ExtensionsOptions = {\n document?: DocumentType;\n id?: string;\n text?: DataType.Text;\n dispatch?: PromiseIntentDispatcher;\n query?: QueryResult<DocumentType>;\n settings: MarkdownSettingsProps;\n selectionManager?: SelectionManager;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({\n document,\n id,\n text,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n}: ExtensionsOptions): Extension[] => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const identity = useIdentity();\n const space = getSpace(document) ?? getSpace(text);\n\n // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.\n // TODO(burdon): Unsubscribe.\n // const query = space?.db.query(Filter.type(DocumentType));\n // query?.subscribe();\n const baseExtensions = useMemo(\n () =>\n createBaseExtensions({\n document,\n id,\n text,\n settings,\n selectionManager,\n viewMode,\n dispatch,\n // query,\n }),\n [\n document,\n id,\n text,\n viewMode,\n dispatch,\n settings,\n settings.editorInputMode,\n settings.folding,\n settings.numberedHeadings,\n settings.debug,\n settings.typewriter,\n selectionManager,\n ],\n );\n\n const extensionProviders = useCapabilities(MarkdownCapabilities.Extensions);\n\n //\n // External extensions from other plugins.\n //\n const pluginExtensions = useMemo<Extension[]>(() => {\n if (!document) {\n return [];\n }\n\n return extensionProviders.flat().reduce((acc: Extension[], provider) => {\n const extension = typeof provider === 'function' ? provider({ document }) : provider;\n if (extension) {\n acc.push(extension);\n }\n\n return acc;\n }, []);\n }, [extensionProviders, document]);\n\n //\n // Basic plugins.\n //\n return useMemo<Extension[]>(\n () =>\n [\n // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.\n document &&\n createDataExtensions({\n id: document.id,\n text: document.content.target && createDocAccessor(document.content.target, ['content']),\n space,\n identity,\n }),\n text &&\n id &&\n createDataExtensions({\n id,\n text: createDocAccessor(text, ['content']),\n space,\n identity,\n }),\n selectionState(editorStateStore),\n document &&\n listener({\n onChange: (text) => setFallbackName(document, text),\n }),\n baseExtensions,\n pluginExtensions,\n ].filter(isNotFalsy),\n [baseExtensions, pluginExtensions, document, document?.content?.target, text, id, space, identity],\n );\n};\n\n/**\n * Create extension instances for editor.\n */\nconst createBaseExtensions = ({\n document,\n id,\n dispatch,\n settings,\n selectionManager,\n query,\n viewMode,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n selectionManager && selectionChange(selectionManager),\n settings.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings.folding && folding(),\n ].filter(isNotFalsy);\n\n //\n // Markdown\n //\n if (viewMode !== 'source') {\n extensions.push(\n ...[\n formattingKeymap(),\n decorateMarkdown({\n selectionChangeDelay: 100,\n numberedHeadings: settings.numberedHeadings ? { from: 2 } : undefined,\n // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.\n renderLinkButton:\n dispatch && (document || id)\n ? createLinkRenderer((id: string) => {\n void dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [id],\n options: {\n pivotId: document ? fullyQualifiedId(document) : id,\n },\n }),\n );\n })\n : undefined,\n }),\n linkTooltip(renderLinkTooltip),\n preview(),\n ],\n );\n }\n\n //\n // Autocomplete object links.\n //\n if (query) {\n extensions.push(\n autocomplete({\n onSearch: (text: string) => {\n // TODO(burdon): Specify filter (e.g., stack).\n return query.objects\n .map<AutocompleteResult | undefined>((object) =>\n object.name?.length && object.id !== document?.id\n ? {\n label: object.name,\n // TODO(burdon): Factor out URL builder.\n apply: `[${object.name}](/${fullyQualifiedId(object)})`,\n }\n : undefined,\n )\n .filter(isNotFalsy);\n },\n }),\n );\n }\n\n if (settings.debug) {\n const items = settings.typewriter?.split(/[,\\n]/) ?? '';\n if (items) {\n extensions.push(typewriter({ items }));\n }\n }\n\n return extensions;\n};\n\nexport const selectionChange = (selectionManager: SelectionManager) => {\n return EditorView.updateListener.of((update) => {\n if (update.selectionSet) {\n const id = update.state.facet(documentId);\n const cursorConverter = update.state.facet(Cursor.converter);\n const selection = update.state.selection;\n const ranges = selection.ranges\n .map((range) => ({\n from: cursorConverter.toCursor(range.from),\n to: cursorConverter.toCursor(range.to),\n }))\n .filter(({ from, to }) => to > from);\n selectionManager.updateMultiRange(id, ranges);\n }\n });\n};\n\n// TODO(burdon): Factor out styles.\nconst style = {\n hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',\n icon: 'inline-block leading-none mis-1 cursor-pointer',\n};\n\nconst createLinkRenderer =\n (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>\n (el, { url }) => {\n // TODO(burdon): Formalize/document internal link format.\n const isInternal =\n url.startsWith('/') ||\n // TODO(wittjosiah): This should probably be parsed out on paste?\n url.startsWith(window.location.origin);\n\n const options: AnchorHTMLAttributes<any> = isInternal\n ? {\n onClick: () => {\n const qualifiedId = url.split('/').at(-1);\n invariant(qualifiedId, 'Invalid link format.');\n onSelectObject(qualifiedId);\n },\n }\n : {\n href: url,\n rel: 'noreferrer',\n target: '_blank',\n };\n\n renderRoot(\n el,\n <a {...options} className={style.hover}>\n <Icon\n icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}\n size={4}\n classNames={style.icon}\n />\n </a>,\n );\n };\n\nconst renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {\n const web = new URL(url);\n renderRoot(\n el,\n <a href={url} rel='noreferrer' target='_blank' className={style.hover}>\n {web.origin}\n <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />\n </a>,\n );\n};\n\n// TODO(burdon): Remove react rendering; use DOM directly.\nexport const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {\n createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);\n return root;\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Rx", "React", "useCallback", "useEffect", "useMemo", "Capabilities", "useAppGraph", "useCapabilities", "usePluginManager", "Filter", "Obj", "Query", "SpaceCapabilities", "fullyQualifiedId", "getSpace", "toLocalizedString", "useTranslation", "insertAtCursor", "insertAtLineStart", "DataType", "React", "useMemo", "useEffect", "useCallback", "forwardRef", "useImperativeHandle", "useRef", "useDropzone", "invariant", "toLocalizedString", "useThemeContext", "useTranslation", "addLink", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorGutter", "editorSlots", "EditorToolbar", "processEditorPayload", "RefPopover", "stackItemContentEditorClassNames", "useEditorToolbarState", "useFormattingState", "useCommandMenu", "useTextEditor", "filterItems", "coreSlashCommands", "CommandMenu", "linkSlashCommands", "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", "getGroups", "useCallback", "trigger", "query", "filterItems", "coreSlashCommands", "linkSlashCommands", "item", "toLocalizedString", "label", "toLowerCase", "includes", "commandMenu", "groupsRef", "currentItem", "onSelect", "refPopoverProps", "useCommandMenu", "useMemo", "filter", "isNotFalsy", "RefPopover", "modal", "MarkdownEditorImpl", "ref", "CommandMenu", "groups", "current", "forwardRef", "id", "role", "initialValue", "extensionProviders", "scrollPastEnd", "toolbar", "customActions", "viewMode", "editorStateStore", "onFileUpload", "onViewModeChange", "forwardedRef", "MARKDOWN_PLUGIN", "themeMode", "useThemeContext", "toolbarState", "useEditorToolbarState", "formattingObserver", "useFormattingState", "scrollTo", "selection", "getState", "providerExtensions", "flatMap", "provider", "isNonNullable", "handleDrop", "view", "files", "file", "info", "undefined", "processEditorPayload", "type", "data", "url", "parentRef", "editorView", "focusAttributes", "useTextEditor", "createBasicExtensions", "readOnly", "placeholder", "createMarkdownExtensions", "createThemeExtensions", "syntaxHighlighting", "slots", "editorSlots", "editorGutter", "dropFile", "onDrop", "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", "React", "useMemo", "createRoot", "createIntent", "LayoutAction", "useCapabilities", "useIntentDispatcher", "invariant", "createDocAccessor", "fullyQualifiedId", "getSpace", "useIdentity", "Icon", "ThemeProvider", "InputModeExtensions", "createDataExtensions", "autocomplete", "decorateMarkdown", "folding", "formattingKeymap", "linkTooltip", "listener", "preview", "selectionState", "typewriter", "EditorView", "documentId", "Cursor", "defaultTx", "isNotFalsy", "useExtensions", "document", "id", "text", "settings", "selectionManager", "viewMode", "editorStateStore", "dispatchPromise", "dispatch", "useIntentDispatcher", "identity", "useIdentity", "space", "getSpace", "baseExtensions", "useMemo", "createBaseExtensions", "editorInputMode", "folding", "numberedHeadings", "debug", "typewriter", "extensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "pluginExtensions", "flat", "reduce", "acc", "provider", "extension", "push", "createDataExtensions", "content", "target", "createDocAccessor", "selectionState", "listener", "onChange", "setFallbackName", "filter", "isNotFalsy", "query", "extensions", "selectionChange", "InputModeExtensions", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "from", "undefined", "renderLinkButton", "createLinkRenderer", "createIntent", "LayoutAction", "Open", "part", "subject", "options", "pivotId", "fullyQualifiedId", "linkTooltip", "renderLinkTooltip", "preview", "autocomplete", "onSearch", "objects", "map", "object", "name", "length", "label", "apply", "items", "split", "EditorView", "updateListener", "of", "update", "selectionSet", "state", "facet", "documentId", "cursorConverter", "Cursor", "converter", "selection", "ranges", "range", "toCursor", "to", "updateMultiRange", "style", "hover", "icon", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "onClick", "qualifiedId", "at", "invariant", "href", "rel", "renderRoot", "React", "a", "className", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "MarkdownContainer", "id", "role", "object", "settings", "selectionManager", "viewMode", "editorStateStore", "onViewModeChange", "t", "useTranslation", "scrollPastEnd", "doc", "Obj", "instanceOf", "DocumentType", "undefined", "text", "DataType", "Text", "extensions", "useExtensions", "document", "manager", "usePluginManager", "resolve", "useCallback", "typename", "context", "getCapabilities", "Capabilities", "Metadata", "find", "metadata", "space", "getSpace", "objectForms", "useCapabilities", "SpaceCapabilities", "ObjectForm", "filter", "useMemo", "Filter", "or", "map", "form", "type", "objectSchema", "onLinkQuery", "query", "name", "startsWith", "slice", "toLowerCase", "results", "db", "Query", "select", "run", "getLabel", "getTypename", "label", "ns", "default", "items", "objects", "toLocalizedString", "includes", "icon", "onSelect", "view", "head", "link", "getDXN", "insertAtLineStart", "insertAtCursor", "React", "DocumentEditor", "fullyQualifiedId", "MarkdownEditor", "initialValue", "content", "toolbar", "inputMode", "editorInputMode", "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
|
+
}
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
2
|
getAbstract,
|
|
3
3
|
getFallbackName
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-LXSRQPEP.mjs";
|
|
5
5
|
import {
|
|
6
6
|
DocumentType
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-N2D26K6W.mjs";
|
|
8
8
|
import {
|
|
9
9
|
MARKDOWN_PLUGIN
|
|
10
10
|
} from "./chunk-JX6XNEHE.mjs";
|
|
@@ -14,27 +14,26 @@ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
|
14
14
|
import { pipe } from "effect";
|
|
15
15
|
import React, { useCallback } from "react";
|
|
16
16
|
import { chain, createIntent, LayoutAction, useIntentDispatcher } from "@dxos/app-framework";
|
|
17
|
-
import {
|
|
18
|
-
import { defaultCard, kanbanCardWithoutPoster, popoverCard, previewTitle, previewProse, previewChrome } from "@dxos/plugin-preview";
|
|
17
|
+
import { Obj } from "@dxos/echo";
|
|
19
18
|
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
20
19
|
import { Button, Icon, useTranslation } from "@dxos/react-ui";
|
|
21
|
-
import {
|
|
20
|
+
import { Card } from "@dxos/react-ui-stack";
|
|
22
21
|
import { DataType } from "@dxos/schema";
|
|
23
22
|
var getTitle = (subject, fallback) => {
|
|
24
|
-
if (
|
|
23
|
+
if (Obj.instanceOf(DocumentType, subject)) {
|
|
25
24
|
return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);
|
|
26
|
-
} else if (
|
|
25
|
+
} else if (Obj.instanceOf(DataType.Text, subject)) {
|
|
27
26
|
return getFallbackName(subject.content);
|
|
28
27
|
}
|
|
29
28
|
};
|
|
30
29
|
var getSnippet = (subject, fallback) => {
|
|
31
|
-
if (
|
|
30
|
+
if (Obj.instanceOf(DocumentType, subject)) {
|
|
32
31
|
return getAbstract(subject.content?.target?.content ?? fallback);
|
|
33
|
-
} else if (
|
|
32
|
+
} else if (Obj.instanceOf(DataType.Text, subject)) {
|
|
34
33
|
return getAbstract(subject.content);
|
|
35
34
|
}
|
|
36
35
|
};
|
|
37
|
-
var MarkdownPreview = ({
|
|
36
|
+
var MarkdownPreview = ({ subject, role }) => {
|
|
38
37
|
var _effect = _useSignals();
|
|
39
38
|
try {
|
|
40
39
|
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
@@ -56,17 +55,11 @@ var MarkdownPreview = ({ classNames, subject, role }) => {
|
|
|
56
55
|
dispatch,
|
|
57
56
|
subject
|
|
58
57
|
]);
|
|
59
|
-
return /* @__PURE__ */ React.createElement(
|
|
60
|
-
role
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
}, getTitle(subject, t("fallback title"))), snippet && /* @__PURE__ */ React.createElement("p", {
|
|
65
|
-
className: mx(previewProse, "line-clamp-3 break-words col-span-2")
|
|
66
|
-
}, snippet), /* @__PURE__ */ React.createElement("div", {
|
|
67
|
-
role: "none",
|
|
68
|
-
className: previewChrome
|
|
69
|
-
}, /* @__PURE__ */ React.createElement(Button, {
|
|
58
|
+
return /* @__PURE__ */ React.createElement(Card.Container, {
|
|
59
|
+
role
|
|
60
|
+
}, /* @__PURE__ */ React.createElement(Card.Heading, null, getTitle(subject, t("fallback title"))), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
|
|
61
|
+
classNames: "line-clamp-3 break-words col-span-2"
|
|
62
|
+
}, snippet), /* @__PURE__ */ React.createElement(Card.Chrome, null, /* @__PURE__ */ React.createElement(Button, {
|
|
70
63
|
onClick: handleNavigate
|
|
71
64
|
}, /* @__PURE__ */ React.createElement("span", {
|
|
72
65
|
className: "grow"
|
|
@@ -84,4 +77,4 @@ export {
|
|
|
84
77
|
MarkdownPreview,
|
|
85
78
|
MarkdownPreview_default as default
|
|
86
79
|
};
|
|
87
|
-
//# sourceMappingURL=MarkdownPreview-
|
|
80
|
+
//# sourceMappingURL=MarkdownPreview-F4PYFW5L.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownPreview/MarkdownPreview.tsx", "../../../src/components/MarkdownPreview/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe } from 'effect';\nimport React, { useCallback } from 'react';\n\nimport { chain, createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { 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.Container role={role}>\n <Card.Heading>{getTitle(subject, t('fallback title'))}</Card.Heading>\n {snippet && <Card.Text classNames='line-clamp-3 break-words col-span-2'>{snippet}</Card.Text>}\n <Card.Chrome>\n <Button onClick={handleNavigate}>\n <span className='grow'>{t('navigate to document label')}</span>\n <Icon icon='ph--arrow-right--regular' />\n </Button>\n </Card.Chrome>\n </Card.Container>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownPreview } from './MarkdownPreview';\n\nexport * from './MarkdownPreview';\n\nexport default MarkdownPreview;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;AAIA,SAASA,YAAY;AACrB,OAAOC,SAASC,mBAAmB;AAEnC,SAASC,OAAOC,cAAcC,cAAcC,2BAA2B;AACvE,SAASC,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,WAAS;MAACtB;OACd,sBAAA,cAACqB,KAAKE,SAAO,MAAEvC,SAASC,SAASmB,EAAE,gBAAA,CAAA,CAAA,GAClCG,WAAW,sBAAA,cAACc,KAAKzB,MAAI;MAAC4B,YAAW;OAAuCjB,OAAAA,GACzE,sBAAA,cAACc,KAAKI,QAAM,MACV,sBAAA,cAACC,QAAAA;MAAOC,SAASnB;OACf,sBAAA,cAACoB,QAAAA;MAAKC,WAAU;OAAQzB,EAAE,4BAAA,CAAA,GAC1B,sBAAA,cAAC0B,MAAAA;MAAKC,MAAK;;;;;AAKrB;;;AC9DA,IAAA,0BAAeC;",
|
|
6
|
+
"names": ["pipe", "React", "useCallback", "chain", "createIntent", "LayoutAction", "useIntentDispatcher", "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", "Container", "Heading", "classNames", "Chrome", "Button", "onClick", "span", "className", "Icon", "icon", "MarkdownPreview"]
|
|
7
|
+
}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
import {
|
|
2
2
|
DocumentType
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-N2D26K6W.mjs";
|
|
4
4
|
import "./chunk-JX6XNEHE.mjs";
|
|
5
5
|
|
|
6
6
|
// packages/plugins/plugin-markdown/src/capabilities/anchor-sort.ts
|
|
7
7
|
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
8
|
-
import {
|
|
8
|
+
import { Type } from "@dxos/echo";
|
|
9
9
|
import { createDocAccessor, getRangeFromCursor, getTarget } from "@dxos/react-client/echo";
|
|
10
10
|
var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
|
|
11
|
-
key:
|
|
11
|
+
key: Type.getTypename(DocumentType),
|
|
12
12
|
sort: (anchorA, anchorB) => {
|
|
13
13
|
const doc = getTarget(anchorA);
|
|
14
14
|
const accessor = doc.content.target ? createDocAccessor(doc.content.target, [
|
|
@@ -29,4 +29,4 @@ var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
|
|
|
29
29
|
export {
|
|
30
30
|
anchor_sort_default as default
|
|
31
31
|
};
|
|
32
|
-
//# sourceMappingURL=anchor-sort-
|
|
32
|
+
//# sourceMappingURL=anchor-sort-BMAN2ABT.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/anchor-sort.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes } from '@dxos/app-framework';\nimport { Type } from '@dxos/echo';\nimport { createDocAccessor, getRangeFromCursor, getTarget } from '@dxos/react-client/echo';\n\nimport { DocumentType } from '../types';\n\nexport default () =>\n contributes(Capabilities.AnchorSort, {\n key: Type.getTypename(DocumentType)!,\n sort: (anchorA, anchorB) => {\n const doc = getTarget(anchorA) as DocumentType;\n const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;\n if (doc !== getTarget(anchorB) || !accessor) {\n return 0;\n }\n\n const getStartPosition = (cursor: string | undefined) => {\n const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;\n return range?.start ?? Number.MAX_SAFE_INTEGER;\n };\n\n const posA = getStartPosition(anchorA.anchor);\n const posB = getStartPosition(anchorB.anchor);\n return posA - posB;\n },\n });\n"],
|
|
5
|
+
"mappings": ";;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,YAAY;AACrB,SAASC,mBAAmBC,oBAAoBC,iBAAiB;AAIjE,IAAA,sBAAe,MACbC,YAAYC,aAAaC,YAAY;EACnCC,KAAKC,KAAKC,YAAYC,YAAAA;EACtBC,MAAM,CAACC,SAASC,YAAAA;AACd,UAAMC,MAAMC,UAAUH,OAAAA;AACtB,UAAMI,WAAWF,IAAIG,QAAQC,SAASC,kBAAkBL,IAAIG,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIN,QAAQC,UAAUF,OAAAA,KAAY,CAACG,UAAU;AAC3C,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBT,QAAQiB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBR,QAAQgB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA;",
|
|
6
|
+
"names": ["Capabilities", "contributes", "Type", "createDocAccessor", "getRangeFromCursor", "getTarget", "contributes", "Capabilities", "AnchorSort", "key", "Type", "getTypename", "DocumentType", "sort", "anchorA", "anchorB", "doc", "getTarget", "accessor", "content", "target", "createDocAccessor", "undefined", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "posA", "anchor", "posB"]
|
|
7
|
+
}
|
package/dist/lib/browser/{app-graph-serializer-V6RLEHVY.mjs → app-graph-serializer-FLQI6GFL.mjs}
RENAMED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import {
|
|
2
2
|
translations_default
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-CX5GYZYO.mjs";
|
|
4
4
|
import {
|
|
5
5
|
DocumentType,
|
|
6
6
|
MarkdownAction
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-N2D26K6W.mjs";
|
|
8
8
|
import "./chunk-JX6XNEHE.mjs";
|
|
9
9
|
|
|
10
10
|
// packages/plugins/plugin-markdown/src/capabilities/app-graph-serializer.ts
|
|
@@ -47,4 +47,4 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
|
|
|
47
47
|
export {
|
|
48
48
|
app_graph_serializer_default as default
|
|
49
49
|
};
|
|
50
|
-
//# sourceMappingURL=app-graph-serializer-
|
|
50
|
+
//# sourceMappingURL=app-graph-serializer-FLQI6GFL.mjs.map
|
package/dist/lib/browser/{artifact-definition-5NAODQLG.mjs → artifact-definition-FQ2R6KPT.mjs}
RENAMED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
2
|
DocumentType,
|
|
3
3
|
MarkdownAction
|
|
4
|
-
} from "./chunk-
|
|
4
|
+
} from "./chunk-N2D26K6W.mjs";
|
|
5
5
|
import {
|
|
6
6
|
meta
|
|
7
7
|
} from "./chunk-JX6XNEHE.mjs";
|
|
@@ -12,7 +12,7 @@ import { createTool, ToolResult } from "@dxos/ai";
|
|
|
12
12
|
import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
|
|
13
13
|
import { ArtifactId, defineArtifact } from "@dxos/artifact";
|
|
14
14
|
import { createArtifactElement } from "@dxos/assistant";
|
|
15
|
-
import {
|
|
15
|
+
import { Obj } from "@dxos/echo";
|
|
16
16
|
import { invariant, assertArgument } from "@dxos/invariant";
|
|
17
17
|
import { SpaceAction } from "@dxos/plugin-space/types";
|
|
18
18
|
import { Filter, fullyQualifiedId } from "@dxos/react-client/echo";
|
|
@@ -91,12 +91,12 @@ var artifact_definition_default = () => {
|
|
|
91
91
|
const space = extensions.space;
|
|
92
92
|
const { objects: documents } = await space.db.query(Filter.type(DocumentType)).run();
|
|
93
93
|
const documentInfo = documents.map((doc) => {
|
|
94
|
-
invariant(
|
|
94
|
+
invariant(Obj.instanceOf(DocumentType, doc), void 0, {
|
|
95
95
|
F: __dxlog_file,
|
|
96
96
|
L: 81,
|
|
97
97
|
S: void 0,
|
|
98
98
|
A: [
|
|
99
|
-
"
|
|
99
|
+
"Obj.instanceOf(DocumentType, doc)",
|
|
100
100
|
""
|
|
101
101
|
]
|
|
102
102
|
});
|
|
@@ -126,7 +126,7 @@ var artifact_definition_default = () => {
|
|
|
126
126
|
]
|
|
127
127
|
});
|
|
128
128
|
const document = await extensions.space.db.query(Filter.ids(ArtifactId.toDXN(id).toString())).first();
|
|
129
|
-
assertArgument(
|
|
129
|
+
assertArgument(Obj.instanceOf(DocumentType, document), "Invalid type");
|
|
130
130
|
const { content } = await document.content?.load();
|
|
131
131
|
return ToolResult.Success({
|
|
132
132
|
id: fullyQualifiedId(document),
|
|
@@ -142,4 +142,4 @@ var artifact_definition_default = () => {
|
|
|
142
142
|
export {
|
|
143
143
|
artifact_definition_default as default
|
|
144
144
|
};
|
|
145
|
-
//# sourceMappingURL=artifact-definition-
|
|
145
|
+
//# sourceMappingURL=artifact-definition-FQ2R6KPT.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/artifact-definition.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe, Schema } from 'effect';\n\nimport { createTool, ToolResult } from '@dxos/ai';\nimport { Capabilities, chain, contributes, createIntent, type PromiseIntentDispatcher } from '@dxos/app-framework';\nimport { ArtifactId, defineArtifact } from '@dxos/artifact';\nimport { createArtifactElement } from '@dxos/assistant';\nimport { Obj } from '@dxos/echo';\nimport { invariant, assertArgument } from '@dxos/invariant';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { Filter, fullyQualifiedId, type Space } from '@dxos/react-client/echo';\n\nimport { meta } from '../meta';\nimport { DocumentType, MarkdownAction } from '../types';\n\n// TODO(burdon): Factor out.\ndeclare global {\n interface ToolContextExtensions {\n space?: Space;\n dispatch?: PromiseIntentDispatcher;\n }\n}\n\nexport default () => {\n const definition = defineArtifact({\n id: `artifact:${meta.id}`,\n name: meta.name,\n instructions: `\n - The markdown plugin allows you to work with text documents in the current space.\n - Use these tools to interact with documents, including listing available documents and retrieving their content.\n - Documents are stored in Markdown format.\n `,\n schema: DocumentType,\n tools: [\n createTool(meta.id, {\n name: 'create',\n description: 'Create a new markdown document',\n caption: 'Creating document...',\n schema: Schema.Struct({\n name: Schema.optional(Schema.String).annotations({\n description: 'Optional name for the document.',\n }),\n content: Schema.String.annotations({\n description: 'The content of the document.',\n }),\n }),\n execute: async ({ name, content }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n invariant(extensions?.dispatch, 'No intent dispatcher');\n\n const intent = pipe(\n createIntent(MarkdownAction.Create, {\n spaceId: extensions.space.id,\n name,\n content,\n }),\n chain(SpaceAction.AddObject, { target: extensions.space }),\n );\n\n const { data, error } = await extensions.dispatch(intent);\n if (!data || error) {\n return ToolResult.Error(error?.message ?? 'Failed to create document');\n }\n\n return ToolResult.Success(createArtifactElement(data.id));\n },\n }),\n createTool(meta.id, {\n name: 'list',\n description: 'List all markdown documents in the current space.',\n caption: 'Listing markdown documents...',\n schema: Schema.Struct({}),\n execute: async (_input, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const space = extensions.space;\n const { objects: documents } = await space.db.query(Filter.type(DocumentType)).run();\n const documentInfo = documents.map((doc) => {\n invariant(Obj.instanceOf(DocumentType, doc));\n return {\n id: fullyQualifiedId(doc),\n name: doc.name || doc.fallbackName || 'Unnamed Document',\n // TODO(ZaymonFC): Include updatedAt?\n };\n });\n\n return ToolResult.Success(documentInfo);\n },\n }),\n createTool(meta.id, {\n name: 'inspect',\n description: 'Read the content of a markdown document.',\n caption: 'Inspecting markdown document...',\n schema: Schema.Struct({\n id: ArtifactId,\n }),\n execute: async ({ id }, { extensions }) => {\n invariant(extensions?.space, 'No space');\n const document = await extensions.space.db.query(Filter.ids(ArtifactId.toDXN(id).toString())).first();\n assertArgument(Obj.instanceOf(DocumentType, document), 'Invalid type');\n\n const { content } = await document.content?.load();\n return ToolResult.Success({\n id: fullyQualifiedId(document),\n name: document.name || document.fallbackName || 'Unnamed Document',\n content,\n });\n },\n }),\n ],\n });\n\n return contributes(Capabilities.ArtifactDefinition, definition);\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["pipe", "Schema", "createTool", "ToolResult", "Capabilities", "chain", "contributes", "createIntent", "ArtifactId", "defineArtifact", "createArtifactElement", "Obj", "invariant", "assertArgument", "SpaceAction", "Filter", "fullyQualifiedId", "definition", "defineArtifact", "id", "meta", "name", "instructions", "schema", "DocumentType", "tools", "createTool", "description", "caption", "Schema", "Struct", "optional", "String", "annotations", "content", "execute", "extensions", "invariant", "space", "dispatch", "intent", "pipe", "createIntent", "MarkdownAction", "Create", "spaceId", "chain", "SpaceAction", "AddObject", "target", "data", "error", "ToolResult", "Error", "message", "Success", "createArtifactElement", "_input", "objects", "documents", "db", "query", "Filter", "type", "run", "documentInfo", "map", "doc", "Obj", "instanceOf", "fullyQualifiedId", "fallbackName", "ArtifactId", "document", "ids", "toDXN", "toString", "first", "assertArgument", "load", "contributes", "Capabilities", "ArtifactDefinition"]
|
|
7
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
DocumentType
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-N2D26K6W.mjs";
|
|
4
4
|
import {
|
|
5
5
|
MARKDOWN_PLUGIN
|
|
6
6
|
} from "./chunk-JX6XNEHE.mjs";
|
|
@@ -44,4 +44,4 @@ var translations_default = [
|
|
|
44
44
|
export {
|
|
45
45
|
translations_default
|
|
46
46
|
};
|
|
47
|
-
//# sourceMappingURL=chunk-
|
|
47
|
+
//# sourceMappingURL=chunk-CX5GYZYO.mjs.map
|