@dxos/plugin-markdown 0.8.2-main.f11618f → 0.8.2-staging.42af850
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 +588 -0
- package/dist/lib/browser/MarkdownContainer-5IEINNQB.mjs.map +7 -0
- package/dist/lib/browser/MarkdownPreview-YW5CS3ID.mjs +87 -0
- package/dist/lib/browser/MarkdownPreview-YW5CS3ID.mjs.map +7 -0
- package/dist/lib/browser/anchor-sort-VS4OZVPP.mjs +32 -0
- package/dist/lib/browser/anchor-sort-VS4OZVPP.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-OCXP7PCK.mjs → app-graph-serializer-V6RLEHVY.mjs} +5 -6
- package/dist/lib/browser/app-graph-serializer-V6RLEHVY.mjs.map +7 -0
- package/dist/lib/browser/{artifact-definition-XTVOUMMI.mjs → artifact-definition-5NAODQLG.mjs} +65 -17
- package/dist/lib/browser/artifact-definition-5NAODQLG.mjs.map +7 -0
- package/dist/lib/browser/{chunk-QV6ZIXAD.mjs → chunk-77NGW7EO.mjs} +6 -7
- package/dist/lib/browser/chunk-77NGW7EO.mjs.map +7 -0
- package/dist/lib/browser/chunk-ACAID3XF.mjs +20 -0
- package/dist/lib/browser/chunk-ACAID3XF.mjs.map +7 -0
- package/dist/lib/browser/{chunk-LJ2UFBJ2.mjs → chunk-C5RABVIX.mjs} +3 -4
- package/dist/lib/browser/chunk-C5RABVIX.mjs.map +7 -0
- package/dist/lib/browser/chunk-ECSM56YC.mjs +80 -0
- package/dist/lib/browser/chunk-ECSM56YC.mjs.map +7 -0
- package/dist/lib/browser/{chunk-NAGMSX77.mjs → chunk-QVJETNGS.mjs} +2 -2
- package/dist/lib/{node-esm/chunk-ETXPC5VP.mjs.map → browser/chunk-QVJETNGS.mjs.map} +1 -1
- package/dist/lib/browser/index.mjs +31 -19
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/intent-resolver-4GDYST4Y.mjs +65 -0
- package/dist/lib/browser/intent-resolver-4GDYST4Y.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-LBCMSLJ5.mjs → react-surface-QE4SKXBT.mjs} +80 -66
- package/dist/lib/browser/react-surface-QE4SKXBT.mjs.map +7 -0
- package/dist/lib/browser/{settings-EQSDBX6O.mjs → settings-W5CK4PXP.mjs} +2 -2
- package/dist/lib/browser/{state-AIN4J7N5.mjs → state-KI6PJ6DT.mjs} +3 -3
- package/dist/lib/browser/state-KI6PJ6DT.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -1
- package/dist/lib/node/MarkdownContainer-LSNNPNRB.cjs +601 -0
- package/dist/lib/node/MarkdownContainer-LSNNPNRB.cjs.map +7 -0
- package/dist/lib/node/MarkdownPreview-G34HSQEB.cjs +110 -0
- package/dist/lib/node/MarkdownPreview-G34HSQEB.cjs.map +7 -0
- package/dist/lib/node/{thread-MXEGV6HS.cjs → anchor-sort-NHVF23EU.cjs} +15 -20
- package/dist/lib/node/anchor-sort-NHVF23EU.cjs.map +7 -0
- package/dist/lib/node/{app-graph-serializer-KBDLASRP.cjs → app-graph-serializer-CLALIYN3.cjs} +10 -11
- package/dist/lib/node/app-graph-serializer-CLALIYN3.cjs.map +7 -0
- package/dist/lib/node/{artifact-definition-ADEN2KD6.cjs → artifact-definition-VEAHK7BX.cjs} +68 -21
- package/dist/lib/node/artifact-definition-VEAHK7BX.cjs.map +7 -0
- package/dist/lib/node/{chunk-QRE5L6ZC.cjs → chunk-C4HR7UXE.cjs} +15 -15
- package/dist/lib/node/chunk-C4HR7UXE.cjs.map +7 -0
- package/dist/lib/node/{chunk-WGMVEPB3.cjs → chunk-G7RBJX22.cjs} +8 -9
- package/dist/lib/node/chunk-G7RBJX22.cjs.map +7 -0
- package/dist/lib/node/{chunk-DZXTXSXX.cjs → chunk-IFYSBQE5.cjs} +5 -5
- package/dist/lib/node/{chunk-DZXTXSXX.cjs.map → chunk-IFYSBQE5.cjs.map} +1 -1
- package/dist/lib/node/{chunk-YHL4JSA6.cjs → chunk-RQS4KBMG.cjs} +38 -42
- package/dist/lib/node/chunk-RQS4KBMG.cjs.map +7 -0
- package/dist/lib/node/{chunk-JO4SBK36.cjs → chunk-ZDTL47I7.cjs} +6 -7
- package/dist/lib/node/chunk-ZDTL47I7.cjs.map +7 -0
- package/dist/lib/node/index.cjs +42 -30
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/intent-resolver-AUZVK3NZ.cjs +78 -0
- package/dist/lib/node/intent-resolver-AUZVK3NZ.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-WJZTEBYO.cjs +213 -0
- package/dist/lib/node/react-surface-WJZTEBYO.cjs.map +7 -0
- package/dist/lib/node/{settings-2JXASSLU.cjs → settings-IRKU3WPM.cjs} +6 -6
- package/dist/lib/node/{state-PC7IVXFP.cjs → state-KKDRAG7X.cjs} +7 -7
- package/dist/lib/node/state-KKDRAG7X.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 +589 -0
- package/dist/lib/node-esm/MarkdownContainer-UZSLXMWO.mjs.map +7 -0
- package/dist/lib/node-esm/MarkdownPreview-TCV7BI32.mjs +88 -0
- package/dist/lib/node-esm/MarkdownPreview-TCV7BI32.mjs.map +7 -0
- package/dist/lib/node-esm/anchor-sort-G2HLCYFK.mjs +33 -0
- package/dist/lib/node-esm/anchor-sort-G2HLCYFK.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-67CO7ST3.mjs → app-graph-serializer-C3RNTQGM.mjs} +5 -6
- package/dist/lib/node-esm/app-graph-serializer-C3RNTQGM.mjs.map +7 -0
- package/dist/lib/node-esm/{artifact-definition-KTS5M2FW.mjs → artifact-definition-7TIJW2CO.mjs} +65 -17
- package/dist/lib/node-esm/artifact-definition-7TIJW2CO.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-4U2F4EB7.mjs → chunk-6RPARLIK.mjs} +6 -7
- package/dist/lib/node-esm/chunk-6RPARLIK.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-PALFXZBY.mjs → chunk-EIUTPXGL.mjs} +10 -10
- package/dist/lib/node-esm/chunk-EIUTPXGL.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ETXPC5VP.mjs → chunk-JXXDCSMW.mjs} +2 -2
- package/dist/lib/{browser/chunk-NAGMSX77.mjs.map → node-esm/chunk-JXXDCSMW.mjs.map} +1 -1
- package/dist/lib/node-esm/chunk-NCMPVEXO.mjs +81 -0
- package/dist/lib/node-esm/chunk-NCMPVEXO.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-VQA6BQGT.mjs → chunk-TCFJNUAE.mjs} +3 -4
- package/dist/lib/node-esm/chunk-TCFJNUAE.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +31 -19
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/intent-resolver-FTNXUNI2.mjs +66 -0
- package/dist/lib/node-esm/intent-resolver-FTNXUNI2.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-737EXAWT.mjs → react-surface-XNM3YDFB.mjs} +80 -66
- package/dist/lib/node-esm/react-surface-XNM3YDFB.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-67RVIH3N.mjs → settings-MK7D7LHQ.mjs} +2 -2
- package/dist/lib/node-esm/{state-PNOPM4TS.mjs → state-LLGVRYKL.mjs} +3 -3
- package/dist/lib/node-esm/state-LLGVRYKL.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/anchor-sort.d.ts +6 -0
- package/dist/types/src/capabilities/anchor-sort.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-serializer.d.ts +2 -2
- package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -1
- package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +7 -7
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/state.d.ts +2 -2
- package/dist/types/src/capabilities/state.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts +5 -3
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +3 -18
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +2 -2
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +4 -172
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +1 -1
- package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +2 -2
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts +8 -5
- package/dist/types/src/extensions.d.ts.map +1 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +2 -46
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +21 -525
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +40 -200
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +48 -39
- package/src/MarkdownPlugin.tsx +19 -9
- package/src/capabilities/anchor-sort.ts +30 -0
- package/src/capabilities/app-graph-serializer.ts +4 -5
- package/src/capabilities/artifact-definition.ts +48 -10
- package/src/capabilities/index.ts +1 -1
- package/src/capabilities/intent-resolver.ts +29 -34
- package/src/capabilities/react-surface.tsx +14 -6
- package/src/capabilities/state.ts +3 -3
- package/src/components/MarkdownContainer.tsx +19 -7
- package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +1 -1
- package/src/components/MarkdownEditor/MarkdownEditor.tsx +29 -71
- package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +9 -4
- package/src/components/MarkdownPreview/MarkdownPreview.tsx +8 -8
- package/src/components/Suggestions.stories.tsx +53 -21
- package/src/components/Toolbar.stories.tsx +16 -16
- package/src/extensions.tsx +45 -16
- package/src/hooks/useSelectCurrentThread.tsx +2 -2
- package/src/translations.ts +1 -3
- package/src/types/schema.ts +19 -17
- package/src/types/types.ts +23 -21
- package/src/util.tsx +4 -4
- package/dist/lib/browser/MarkdownContainer-5XV7K2NX.mjs +0 -567
- package/dist/lib/browser/MarkdownContainer-5XV7K2NX.mjs.map +0 -7
- package/dist/lib/browser/MarkdownPreview-DX5U5LCX.mjs +0 -81
- package/dist/lib/browser/MarkdownPreview-DX5U5LCX.mjs.map +0 -7
- package/dist/lib/browser/app-graph-serializer-OCXP7PCK.mjs.map +0 -7
- package/dist/lib/browser/artifact-definition-XTVOUMMI.mjs.map +0 -7
- package/dist/lib/browser/chunk-5QXYEKSX.mjs +0 -20
- package/dist/lib/browser/chunk-5QXYEKSX.mjs.map +0 -7
- package/dist/lib/browser/chunk-GVOEHF7E.mjs +0 -84
- package/dist/lib/browser/chunk-GVOEHF7E.mjs.map +0 -7
- package/dist/lib/browser/chunk-LJ2UFBJ2.mjs.map +0 -7
- package/dist/lib/browser/chunk-QV6ZIXAD.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-H37L3DBD.mjs +0 -86
- package/dist/lib/browser/intent-resolver-H37L3DBD.mjs.map +0 -7
- package/dist/lib/browser/react-surface-LBCMSLJ5.mjs.map +0 -7
- package/dist/lib/browser/state-AIN4J7N5.mjs.map +0 -7
- package/dist/lib/browser/thread-MFKBUVCB.mjs +0 -37
- package/dist/lib/browser/thread-MFKBUVCB.mjs.map +0 -7
- package/dist/lib/node/MarkdownContainer-5EQTBXV3.cjs +0 -580
- package/dist/lib/node/MarkdownContainer-5EQTBXV3.cjs.map +0 -7
- package/dist/lib/node/MarkdownPreview-W7QIN2KJ.cjs +0 -104
- package/dist/lib/node/MarkdownPreview-W7QIN2KJ.cjs.map +0 -7
- package/dist/lib/node/app-graph-serializer-KBDLASRP.cjs.map +0 -7
- package/dist/lib/node/artifact-definition-ADEN2KD6.cjs.map +0 -7
- package/dist/lib/node/chunk-JO4SBK36.cjs.map +0 -7
- package/dist/lib/node/chunk-QRE5L6ZC.cjs.map +0 -7
- package/dist/lib/node/chunk-WGMVEPB3.cjs.map +0 -7
- package/dist/lib/node/chunk-YHL4JSA6.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-NX5QNRYF.cjs +0 -99
- package/dist/lib/node/intent-resolver-NX5QNRYF.cjs.map +0 -7
- package/dist/lib/node/react-surface-DJIZSVMN.cjs +0 -199
- package/dist/lib/node/react-surface-DJIZSVMN.cjs.map +0 -7
- package/dist/lib/node/state-PC7IVXFP.cjs.map +0 -7
- package/dist/lib/node/thread-MXEGV6HS.cjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-LONZOJJX.mjs +0 -568
- package/dist/lib/node-esm/MarkdownContainer-LONZOJJX.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownPreview-T3OW2EN4.mjs +0 -82
- package/dist/lib/node-esm/MarkdownPreview-T3OW2EN4.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-serializer-67CO7ST3.mjs.map +0 -7
- package/dist/lib/node-esm/artifact-definition-KTS5M2FW.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-4U2F4EB7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NUZHKZSZ.mjs +0 -85
- package/dist/lib/node-esm/chunk-NUZHKZSZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-PALFXZBY.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-VQA6BQGT.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-XES4ZCA6.mjs +0 -87
- package/dist/lib/node-esm/intent-resolver-XES4ZCA6.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-737EXAWT.mjs.map +0 -7
- package/dist/lib/node-esm/state-PNOPM4TS.mjs.map +0 -7
- package/dist/lib/node-esm/thread-5U4KSBED.mjs +0 -38
- package/dist/lib/node-esm/thread-5U4KSBED.mjs.map +0 -7
- package/dist/types/src/capabilities/thread.d.ts +0 -6
- package/dist/types/src/capabilities/thread.d.ts.map +0 -1
- package/src/capabilities/thread.ts +0 -35
- /package/dist/lib/browser/{settings-EQSDBX6O.mjs.map → settings-W5CK4PXP.mjs.map} +0 -0
- /package/dist/lib/node/{settings-2JXASSLU.cjs.map → settings-IRKU3WPM.cjs.map} +0 -0
- /package/dist/lib/node-esm/{settings-67RVIH3N.mjs.map → settings-MK7D7LHQ.mjs.map} +0 -0
|
@@ -1,204 +1,44 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Schema } from 'effect';
|
|
2
|
+
import { Type } from '@dxos/echo';
|
|
2
3
|
import { type Extension, EditorViewMode } from '@dxos/react-ui-editor';
|
|
3
4
|
import { DocumentType } from './schema';
|
|
4
5
|
export declare namespace MarkdownAction {
|
|
5
|
-
const Create_base:
|
|
6
|
-
readonly _tag:
|
|
6
|
+
const Create_base: Schema.TaggedClass<Create, "dxos.org/plugin/markdown/action", {
|
|
7
|
+
readonly _tag: Schema.tag<"dxos.org/plugin/markdown/action">;
|
|
7
8
|
} & {
|
|
8
|
-
input:
|
|
9
|
-
spaceId:
|
|
10
|
-
|
|
11
|
-
|
|
9
|
+
input: Schema.Struct<{
|
|
10
|
+
spaceId: Schema.Schema<Type.SpaceId, string, never> & {
|
|
11
|
+
byteLength: number;
|
|
12
|
+
encode: (value: Uint8Array) => Type.SpaceId;
|
|
13
|
+
decode: (value: Type.SpaceId) => Uint8Array;
|
|
14
|
+
isValid: (value: string) => value is Type.SpaceId;
|
|
15
|
+
make: (value: string) => Type.SpaceId;
|
|
16
|
+
random: () => Type.SpaceId;
|
|
17
|
+
};
|
|
18
|
+
name: Schema.optional<typeof Schema.String>;
|
|
19
|
+
content: Schema.optional<typeof Schema.String>;
|
|
12
20
|
}>;
|
|
13
|
-
output:
|
|
14
|
-
object: import("@dxos/echo-schema").
|
|
15
|
-
name:
|
|
16
|
-
fallbackName:
|
|
17
|
-
content: import("@dxos/echo-schema").Ref$<
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
anchor: S.optional<typeof S.String>;
|
|
23
|
-
status: S.optional<S.Union<[S.Literal<["staged"]>, S.Literal<["active"]>, S.Literal<["resolved"]>]>>;
|
|
24
|
-
messages: S.mutable<S.Array$<import("@dxos/echo-schema").Ref$<import("@dxos/echo-schema").TypedObjectFields<{
|
|
25
|
-
id: import("@dxos/echo-schema").ObjectIdClass;
|
|
26
|
-
created: S.SchemaClass<string, string, never>;
|
|
27
|
-
sender: S.mutable<S.Struct<{
|
|
28
|
-
contact: S.optional<import("@dxos/echo-schema").Ref$<{
|
|
29
|
-
readonly id: string;
|
|
30
|
-
fields?: {
|
|
31
|
-
readonly value: string;
|
|
32
|
-
readonly label: string;
|
|
33
|
-
readonly category?: string | undefined;
|
|
34
|
-
}[] | undefined;
|
|
35
|
-
organization?: import("@dxos/echo-schema").Ref<{
|
|
36
|
-
readonly id: string;
|
|
37
|
-
description?: string | undefined;
|
|
38
|
-
name?: string | undefined;
|
|
39
|
-
status?: "prospect" | "qualified" | "active" | "commit" | "reject" | undefined;
|
|
40
|
-
image?: string | undefined;
|
|
41
|
-
website?: string | undefined;
|
|
42
|
-
}> | undefined;
|
|
43
|
-
image?: string | undefined;
|
|
44
|
-
fullName?: string | undefined;
|
|
45
|
-
preferredName?: string | undefined;
|
|
46
|
-
nickname?: string | undefined;
|
|
47
|
-
jobTitle?: string | undefined;
|
|
48
|
-
department?: string | undefined;
|
|
49
|
-
notes?: string | undefined;
|
|
50
|
-
emails?: {
|
|
51
|
-
readonly value: string;
|
|
52
|
-
readonly label?: string | undefined;
|
|
53
|
-
}[] | undefined;
|
|
54
|
-
identities?: {
|
|
55
|
-
readonly value: string;
|
|
56
|
-
readonly label?: string | undefined;
|
|
57
|
-
}[] | undefined;
|
|
58
|
-
phoneNumbers?: {
|
|
59
|
-
readonly value: string;
|
|
60
|
-
readonly label?: string | undefined;
|
|
61
|
-
}[] | undefined;
|
|
62
|
-
addresses?: {
|
|
63
|
-
readonly value: {
|
|
64
|
-
readonly street?: string | undefined;
|
|
65
|
-
readonly extended?: string | undefined;
|
|
66
|
-
readonly locality?: string | undefined;
|
|
67
|
-
readonly region?: string | undefined;
|
|
68
|
-
readonly postalCode?: string | undefined;
|
|
69
|
-
readonly postOfficeBoxNumber?: string | undefined;
|
|
70
|
-
readonly country?: string | undefined;
|
|
71
|
-
};
|
|
72
|
-
readonly label?: string | undefined;
|
|
73
|
-
}[] | undefined;
|
|
74
|
-
urls?: {
|
|
75
|
-
readonly value: string;
|
|
76
|
-
readonly label?: string | undefined;
|
|
77
|
-
}[] | undefined;
|
|
78
|
-
birthday?: {
|
|
79
|
-
toString: () => string;
|
|
80
|
-
toDateString: () => string;
|
|
81
|
-
toTimeString: () => string;
|
|
82
|
-
toLocaleString: {
|
|
83
|
-
(): string;
|
|
84
|
-
(locales?: string | string[], options?: Intl.DateTimeFormatOptions): string;
|
|
85
|
-
(locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions): string;
|
|
86
|
-
};
|
|
87
|
-
toLocaleDateString: {
|
|
88
|
-
(): string;
|
|
89
|
-
(locales?: string | string[], options?: Intl.DateTimeFormatOptions): string;
|
|
90
|
-
(locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions): string;
|
|
91
|
-
};
|
|
92
|
-
toLocaleTimeString: {
|
|
93
|
-
(): string;
|
|
94
|
-
(locales?: string | string[], options?: Intl.DateTimeFormatOptions): string;
|
|
95
|
-
(locales?: Intl.LocalesArgument, options?: Intl.DateTimeFormatOptions): string;
|
|
96
|
-
};
|
|
97
|
-
valueOf: () => number;
|
|
98
|
-
getTime: () => number;
|
|
99
|
-
getFullYear: () => number;
|
|
100
|
-
getUTCFullYear: () => number;
|
|
101
|
-
getMonth: () => number;
|
|
102
|
-
getUTCMonth: () => number;
|
|
103
|
-
getDate: () => number;
|
|
104
|
-
getUTCDate: () => number;
|
|
105
|
-
getDay: () => number;
|
|
106
|
-
getUTCDay: () => number;
|
|
107
|
-
getHours: () => number;
|
|
108
|
-
getUTCHours: () => number;
|
|
109
|
-
getMinutes: () => number;
|
|
110
|
-
getUTCMinutes: () => number;
|
|
111
|
-
getSeconds: () => number;
|
|
112
|
-
getUTCSeconds: () => number;
|
|
113
|
-
getMilliseconds: () => number;
|
|
114
|
-
getUTCMilliseconds: () => number;
|
|
115
|
-
getTimezoneOffset: () => number;
|
|
116
|
-
setTime: (time: number) => number;
|
|
117
|
-
setMilliseconds: (ms: number) => number;
|
|
118
|
-
setUTCMilliseconds: (ms: number) => number;
|
|
119
|
-
setSeconds: (sec: number, ms?: number) => number;
|
|
120
|
-
setUTCSeconds: (sec: number, ms?: number) => number;
|
|
121
|
-
setMinutes: (min: number, sec?: number, ms?: number) => number;
|
|
122
|
-
setUTCMinutes: (min: number, sec?: number, ms?: number) => number;
|
|
123
|
-
setHours: (hours: number, min?: number, sec?: number, ms?: number) => number;
|
|
124
|
-
setUTCHours: (hours: number, min?: number, sec?: number, ms?: number) => number;
|
|
125
|
-
setDate: (date: number) => number;
|
|
126
|
-
setUTCDate: (date: number) => number;
|
|
127
|
-
setMonth: (month: number, date?: number) => number;
|
|
128
|
-
setUTCMonth: (month: number, date?: number) => number;
|
|
129
|
-
setFullYear: (year: number, month?: number, date?: number) => number;
|
|
130
|
-
setUTCFullYear: (year: number, month?: number, date?: number) => number;
|
|
131
|
-
toUTCString: () => string;
|
|
132
|
-
toISOString: () => string;
|
|
133
|
-
toJSON: (key?: any) => string;
|
|
134
|
-
[Symbol.toPrimitive]: {
|
|
135
|
-
(hint: "default"): string;
|
|
136
|
-
(hint: "string"): string;
|
|
137
|
-
(hint: "number"): number;
|
|
138
|
-
(hint: string): string | number;
|
|
139
|
-
};
|
|
140
|
-
} | undefined;
|
|
141
|
-
}>>;
|
|
142
|
-
identityDid: S.optional<typeof S.String>;
|
|
143
|
-
identityKey: S.optional<typeof S.String>;
|
|
144
|
-
email: S.optional<typeof S.String>;
|
|
145
|
-
name: S.optional<typeof S.String>;
|
|
146
|
-
role: S.optional<S.Literal<["user", "assistant"]>>;
|
|
147
|
-
}>>;
|
|
148
|
-
blocks: S.mutable<S.Array$<S.Union<[S.mutable<S.extend<S.Struct<{
|
|
149
|
-
pending: S.optional<typeof S.Boolean>;
|
|
150
|
-
}>, S.Struct<{
|
|
151
|
-
type: S.Literal<["text"]>;
|
|
152
|
-
disposition: S.optional<typeof S.String>;
|
|
153
|
-
text: typeof S.String;
|
|
154
|
-
}>>>, S.mutable<S.extend<S.Struct<{
|
|
155
|
-
pending: S.optional<typeof S.Boolean>;
|
|
156
|
-
}>, S.Struct<{
|
|
157
|
-
type: S.Literal<["json"]>;
|
|
158
|
-
disposition: S.optional<typeof S.String>;
|
|
159
|
-
data: typeof S.String;
|
|
160
|
-
}>>>, S.mutable<S.extend<S.Struct<{
|
|
161
|
-
pending: S.optional<typeof S.Boolean>;
|
|
162
|
-
}>, S.Struct<{
|
|
163
|
-
type: S.Literal<["image"]>;
|
|
164
|
-
id: S.optional<typeof S.String>;
|
|
165
|
-
source: S.optional<S.Union<[S.mutable<S.Struct<{
|
|
166
|
-
type: S.Literal<["base64"]>;
|
|
167
|
-
mediaType: typeof S.String;
|
|
168
|
-
data: typeof S.String;
|
|
169
|
-
}>>, S.mutable<S.Struct<{
|
|
170
|
-
type: S.Literal<["http"]>;
|
|
171
|
-
url: typeof S.String;
|
|
172
|
-
}>>]>>;
|
|
173
|
-
}>>>, S.mutable<S.extend<S.Struct<{
|
|
174
|
-
pending: S.optional<typeof S.Boolean>;
|
|
175
|
-
}>, S.Struct<{
|
|
176
|
-
type: S.Literal<["reference"]>;
|
|
177
|
-
reference: import("@dxos/echo-schema").Ref$<import("@dxos/echo-schema").Expando>;
|
|
178
|
-
}>>>, S.mutable<S.extend<S.Struct<{
|
|
179
|
-
pending: S.optional<typeof S.Boolean>;
|
|
180
|
-
}>, S.Struct<{
|
|
181
|
-
type: S.Literal<["transcription"]>;
|
|
182
|
-
started: typeof S.String;
|
|
183
|
-
text: typeof S.String;
|
|
184
|
-
}>>>]>>>;
|
|
185
|
-
properties: S.optional<S.mutable<S.Record$<typeof S.String, typeof S.Any>>>;
|
|
186
|
-
}, import("@dxos/echo-schema").TypedObjectOptions>>>>;
|
|
187
|
-
}, import("@dxos/echo-schema").TypedObjectOptions>>>>;
|
|
188
|
-
assistantChatQueue: S.optional<import("@dxos/echo-schema").Ref$<import("@dxos/echo-schema").Expando>>;
|
|
189
|
-
}>>;
|
|
21
|
+
output: Schema.Struct<{
|
|
22
|
+
object: import("@dxos/echo-schema").EchoTypeSchema<Schema.Struct<{
|
|
23
|
+
name: Schema.optional<typeof Schema.String>;
|
|
24
|
+
fallbackName: Schema.optional<typeof Schema.String>;
|
|
25
|
+
content: import("@dxos/echo-schema").Ref$<{
|
|
26
|
+
readonly id: string;
|
|
27
|
+
content: string;
|
|
28
|
+
}>;
|
|
29
|
+
}>, {}>;
|
|
190
30
|
}>;
|
|
191
31
|
}>;
|
|
192
32
|
export class Create extends Create_base {
|
|
193
33
|
}
|
|
194
|
-
const SetViewMode_base:
|
|
195
|
-
readonly _tag:
|
|
34
|
+
const SetViewMode_base: Schema.TaggedClass<SetViewMode, "dxos.org/plugin/markdown/action/set-view-mode", {
|
|
35
|
+
readonly _tag: Schema.tag<"dxos.org/plugin/markdown/action/set-view-mode">;
|
|
196
36
|
} & {
|
|
197
|
-
input:
|
|
198
|
-
id: typeof
|
|
199
|
-
viewMode:
|
|
37
|
+
input: Schema.Struct<{
|
|
38
|
+
id: typeof Schema.String;
|
|
39
|
+
viewMode: Schema.Schema<"source" | "preview" | "readonly", "source" | "preview" | "readonly", never>;
|
|
200
40
|
}>;
|
|
201
|
-
output: typeof
|
|
41
|
+
output: typeof Schema.Void;
|
|
202
42
|
}>;
|
|
203
43
|
export class SetViewMode extends SetViewMode_base {
|
|
204
44
|
}
|
|
@@ -213,15 +53,15 @@ export type MarkdownPluginState = {
|
|
|
213
53
|
extensionProviders?: MarkdownExtensionProvider[];
|
|
214
54
|
viewMode: Record<string, EditorViewMode>;
|
|
215
55
|
};
|
|
216
|
-
export declare const MarkdownSettingsSchema:
|
|
217
|
-
defaultViewMode:
|
|
218
|
-
editorInputMode:
|
|
219
|
-
experimental:
|
|
220
|
-
debug:
|
|
221
|
-
toolbar:
|
|
222
|
-
typewriter:
|
|
223
|
-
numberedHeadings:
|
|
224
|
-
folding:
|
|
56
|
+
export declare const MarkdownSettingsSchema: Schema.mutable<Schema.Struct<{
|
|
57
|
+
defaultViewMode: Schema.Schema<"source" | "preview" | "readonly", "source" | "preview" | "readonly", never>;
|
|
58
|
+
editorInputMode: Schema.optional<Schema.Schema<"default" | "vim" | "vscode", "default" | "vim" | "vscode", never>>;
|
|
59
|
+
experimental: Schema.optional<typeof Schema.Boolean>;
|
|
60
|
+
debug: Schema.optional<typeof Schema.Boolean>;
|
|
61
|
+
toolbar: Schema.optional<typeof Schema.Boolean>;
|
|
62
|
+
typewriter: Schema.optional<typeof Schema.String>;
|
|
63
|
+
numberedHeadings: Schema.optional<typeof Schema.Boolean>;
|
|
64
|
+
folding: Schema.optional<typeof Schema.Boolean>;
|
|
225
65
|
}>>;
|
|
226
|
-
export type MarkdownSettingsProps =
|
|
66
|
+
export type MarkdownSettingsProps = Schema.Schema.Type<typeof MarkdownSettingsSchema>;
|
|
227
67
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/types/types.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/types/types.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAEhC,OAAO,EAAE,IAAI,EAAE,MAAM,YAAY,CAAC;AAElC,OAAO,EAAE,KAAK,SAAS,EAAmB,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAExF,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAKxC,yBAAiB,cAAc,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;IAC9B,MAAM,OAAO,MAAO,SAAQ,WAS1B;KAAG;;;;;;;;;;IAEL,MAAM,OAAO,WAAY,SAAQ,gBAM/B;KAAG;;CACN;AAED,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;AAGrD,MAAM,MAAM,yBAAyB,GAAG,CAAC,KAAK,EAAE;IAAE,QAAQ,CAAC,EAAE,YAAY,CAAA;CAAE,KAAK,SAAS,GAAG,SAAS,CAAC;AAEtG,MAAM,MAAM,QAAQ,GAAG,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;AAE9C,MAAM,MAAM,mBAAmB,GAAG;IAEhC,kBAAkB,CAAC,EAAE,yBAAyB,EAAE,CAAC;IAIjD,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;CAC1C,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;;;;;;GAYlC,CAAC;AAEF,MAAM,MAAM,qBAAqB,GAAG,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,sBAAsB,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/util.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,KAAK,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAItE,OAAO,EAAE,YAAY,EAAE,KAAK,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAEhE,eAAO,MAAM,oBAAoB,
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../src/util.tsx"],"names":[],"mappings":"AAKA,OAAO,EAAE,KAAK,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAItE,OAAO,EAAE,YAAY,EAAE,KAAK,kBAAkB,EAAE,MAAM,SAAS,CAAC;AAEhE,eAAO,MAAM,oBAAoB,GAAI,MAAM,OAAO,KAAG,IAAI,IAAI,kBAKhD,CAAC;AAId,eAAO,MAAM,eAAe,GAAI,SAAS,MAAM,WAE9C,CAAC;AAEF,eAAO,MAAM,WAAW,GAAI,SAAS,MAAM,WAE1C,CAAC;AAEF,eAAO,MAAM,eAAe,0BAKrB,CAAC;AAER,eAAO,MAAM,UAAU,EAAE,qBAAqB,CAAC,YAAY,CAY1D,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":"5.
|
|
1
|
+
{"version":"5.8.3"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dxos/plugin-markdown",
|
|
3
|
-
"version": "0.8.2-
|
|
3
|
+
"version": "0.8.2-staging.42af850",
|
|
4
4
|
"description": "DXOS Surface plugin for interacting with Markdown",
|
|
5
5
|
"homepage": "https://dxos.org",
|
|
6
6
|
"bugs": "https://github.com/dxos/dxos/issues",
|
|
@@ -33,60 +33,69 @@
|
|
|
33
33
|
"src"
|
|
34
34
|
],
|
|
35
35
|
"dependencies": {
|
|
36
|
+
"@automerge/automerge": "3.0.0-beta.4",
|
|
36
37
|
"@codemirror/search": "^6.5.6",
|
|
37
38
|
"@codemirror/view": "^6.34.1",
|
|
38
|
-
"@preact/
|
|
39
|
-
"
|
|
39
|
+
"@preact-signals/safe-react": "^0.9.0",
|
|
40
|
+
"@preact/signals-core": "^1.9.0",
|
|
40
41
|
"react-dropzone": "^14.2.3",
|
|
41
|
-
"@dxos/
|
|
42
|
-
"@dxos/
|
|
43
|
-
"@dxos/
|
|
44
|
-
"@dxos/
|
|
45
|
-
"@dxos/
|
|
46
|
-
"@dxos/
|
|
47
|
-
"@dxos/
|
|
48
|
-
"@dxos/
|
|
49
|
-
"@dxos/
|
|
50
|
-
"@dxos/
|
|
51
|
-
"@dxos/
|
|
52
|
-
"@dxos/
|
|
53
|
-
"@dxos/
|
|
54
|
-
"@dxos/plugin-
|
|
55
|
-
"@dxos/
|
|
56
|
-
"@dxos/plugin-
|
|
57
|
-
"@dxos/plugin-
|
|
58
|
-
"@dxos/
|
|
59
|
-
"@dxos/plugin-
|
|
60
|
-
"@dxos/react-
|
|
61
|
-
"@dxos/react-
|
|
62
|
-
"@dxos/
|
|
63
|
-
"@dxos/react-ui-
|
|
64
|
-
"@dxos/react-ui-
|
|
65
|
-
"@dxos/react-ui-
|
|
66
|
-
"@dxos/
|
|
67
|
-
"@dxos/
|
|
42
|
+
"@dxos/ai": "0.8.2-staging.42af850",
|
|
43
|
+
"@dxos/app-framework": "0.8.2-staging.42af850",
|
|
44
|
+
"@dxos/assistant": "0.8.2-staging.42af850",
|
|
45
|
+
"@dxos/artifact": "0.8.2-staging.42af850",
|
|
46
|
+
"@dxos/async": "0.8.2-staging.42af850",
|
|
47
|
+
"@dxos/echo-schema": "0.8.2-staging.42af850",
|
|
48
|
+
"@dxos/echo": "0.8.2-staging.42af850",
|
|
49
|
+
"@dxos/invariant": "0.8.2-staging.42af850",
|
|
50
|
+
"@dxos/live-object": "0.8.2-staging.42af850",
|
|
51
|
+
"@dxos/keys": "0.8.2-staging.42af850",
|
|
52
|
+
"@dxos/local-storage": "0.8.2-staging.42af850",
|
|
53
|
+
"@dxos/log": "0.8.2-staging.42af850",
|
|
54
|
+
"@dxos/lit-ui": "0.8.2-staging.42af850",
|
|
55
|
+
"@dxos/plugin-client": "0.8.2-staging.42af850",
|
|
56
|
+
"@dxos/plugin-deck": "0.8.2-staging.42af850",
|
|
57
|
+
"@dxos/plugin-graph": "0.8.2-staging.42af850",
|
|
58
|
+
"@dxos/plugin-attention": "0.8.2-staging.42af850",
|
|
59
|
+
"@dxos/plugin-preview": "0.8.2-staging.42af850",
|
|
60
|
+
"@dxos/plugin-space": "0.8.2-staging.42af850",
|
|
61
|
+
"@dxos/react-client": "0.8.2-staging.42af850",
|
|
62
|
+
"@dxos/react-hooks": "0.8.2-staging.42af850",
|
|
63
|
+
"@dxos/plugin-theme": "0.8.2-staging.42af850",
|
|
64
|
+
"@dxos/react-ui-attention": "0.8.2-staging.42af850",
|
|
65
|
+
"@dxos/react-ui-card": "0.8.2-staging.42af850",
|
|
66
|
+
"@dxos/react-ui-form": "0.8.2-staging.42af850",
|
|
67
|
+
"@dxos/react-ui-stack": "0.8.2-staging.42af850",
|
|
68
|
+
"@dxos/schema": "0.8.2-staging.42af850",
|
|
69
|
+
"@dxos/util": "0.8.2-staging.42af850",
|
|
70
|
+
"@dxos/react-ui-editor": "0.8.2-staging.42af850"
|
|
68
71
|
},
|
|
69
72
|
"devDependencies": {
|
|
73
|
+
"@effect-rx/rx-react": "^0.34.1",
|
|
74
|
+
"@effect/platform": "0.80.12",
|
|
70
75
|
"@phosphor-icons/react": "^2.1.5",
|
|
71
76
|
"@types/react": "~18.2.0",
|
|
72
77
|
"@types/react-dom": "~18.2.0",
|
|
78
|
+
"effect": "3.14.21",
|
|
73
79
|
"react": "~18.2.0",
|
|
74
80
|
"react-dom": "~18.2.0",
|
|
75
81
|
"vite": "5.4.7",
|
|
76
|
-
"@dxos/debug": "0.8.2-
|
|
77
|
-
"@dxos/plugin-theme": "0.8.2-
|
|
78
|
-
"@dxos/plugin-storybook-layout": "0.8.2-
|
|
79
|
-
"@dxos/random": "0.8.2-
|
|
80
|
-
"@dxos/react-ui": "0.8.2-
|
|
81
|
-
"@dxos/react-ui-theme": "0.8.2-
|
|
82
|
-
"@dxos/storybook-utils": "0.8.2-
|
|
82
|
+
"@dxos/debug": "0.8.2-staging.42af850",
|
|
83
|
+
"@dxos/plugin-theme": "0.8.2-staging.42af850",
|
|
84
|
+
"@dxos/plugin-storybook-layout": "0.8.2-staging.42af850",
|
|
85
|
+
"@dxos/random": "0.8.2-staging.42af850",
|
|
86
|
+
"@dxos/react-ui": "0.8.2-staging.42af850",
|
|
87
|
+
"@dxos/react-ui-theme": "0.8.2-staging.42af850",
|
|
88
|
+
"@dxos/storybook-utils": "0.8.2-staging.42af850"
|
|
83
89
|
},
|
|
84
90
|
"peerDependencies": {
|
|
91
|
+
"@effect-rx/rx-react": "^0.34.1",
|
|
92
|
+
"@effect/platform": "0.80.12",
|
|
85
93
|
"@phosphor-icons/react": "^2.1.5",
|
|
94
|
+
"effect": "^3.13.3",
|
|
86
95
|
"react": "~18.2.0",
|
|
87
96
|
"react-dom": "~18.2.0",
|
|
88
|
-
"@dxos/react-ui": "0.8.2-
|
|
89
|
-
"@dxos/react-ui-theme": "0.8.2-
|
|
97
|
+
"@dxos/react-ui": "0.8.2-staging.42af850",
|
|
98
|
+
"@dxos/react-ui-theme": "0.8.2-staging.42af850"
|
|
90
99
|
},
|
|
91
100
|
"publishConfig": {
|
|
92
101
|
"access": "public"
|
package/src/MarkdownPlugin.tsx
CHANGED
|
@@ -6,19 +6,20 @@ import { Capabilities, contributes, createIntent, defineModule, definePlugin, Ev
|
|
|
6
6
|
import { isInstanceOf, type BaseObject } from '@dxos/echo-schema';
|
|
7
7
|
import { RefArray } from '@dxos/live-object';
|
|
8
8
|
import { ClientCapabilities, ClientEvents } from '@dxos/plugin-client';
|
|
9
|
-
import { SpaceCapabilities
|
|
9
|
+
import { SpaceCapabilities } from '@dxos/plugin-space';
|
|
10
10
|
import { defineObjectForm } from '@dxos/plugin-space/types';
|
|
11
|
+
import { createDocAccessor, getTextInRange } from '@dxos/react-client/echo';
|
|
11
12
|
import { translations as editorTranslations } from '@dxos/react-ui-editor';
|
|
12
|
-
import {
|
|
13
|
+
import { DataType } from '@dxos/schema';
|
|
13
14
|
|
|
14
15
|
import {
|
|
16
|
+
AnchorSort,
|
|
15
17
|
AppGraphSerializer,
|
|
16
18
|
ArtifactDefinition,
|
|
17
19
|
IntentResolver,
|
|
18
20
|
MarkdownState,
|
|
19
21
|
MarkdownSettings,
|
|
20
22
|
ReactSurface,
|
|
21
|
-
Thread,
|
|
22
23
|
} from './capabilities';
|
|
23
24
|
import { MarkdownEvents } from './events';
|
|
24
25
|
import { meta } from './meta';
|
|
@@ -60,9 +61,17 @@ export const MarkdownPlugin = () =>
|
|
|
60
61
|
managesAutofocus: true,
|
|
61
62
|
},
|
|
62
63
|
// TODO(wittjosiah): Move out of metadata.
|
|
63
|
-
loadReferences: async (doc: DocumentType) =>
|
|
64
|
-
await RefArray.loadAll<BaseObject>([doc.content, ...doc.threads]),
|
|
64
|
+
loadReferences: async (doc: DocumentType) => await RefArray.loadAll<BaseObject>([doc.content]),
|
|
65
65
|
serializer,
|
|
66
|
+
// TODO(wittjosiah): Consider how to do generic comments without these.
|
|
67
|
+
comments: 'anchored',
|
|
68
|
+
selectionMode: 'multi-range',
|
|
69
|
+
getAnchorLabel: (doc: DocumentType, anchor: string): string | undefined => {
|
|
70
|
+
if (doc.content) {
|
|
71
|
+
const [start, end] = anchor.split(':');
|
|
72
|
+
return getTextInRange(createDocAccessor(doc.content.target!, ['content']), start, end);
|
|
73
|
+
}
|
|
74
|
+
},
|
|
66
75
|
},
|
|
67
76
|
}),
|
|
68
77
|
}),
|
|
@@ -81,7 +90,7 @@ export const MarkdownPlugin = () =>
|
|
|
81
90
|
defineModule({
|
|
82
91
|
id: `${meta.id}/module/schema`,
|
|
83
92
|
activatesOn: ClientEvents.SetupSchema,
|
|
84
|
-
activate: () => contributes(ClientCapabilities.Schema, [
|
|
93
|
+
activate: () => contributes(ClientCapabilities.Schema, [DataType.Text]),
|
|
85
94
|
}),
|
|
86
95
|
defineModule({
|
|
87
96
|
id: `${meta.id}/module/react-surface`,
|
|
@@ -101,9 +110,10 @@ export const MarkdownPlugin = () =>
|
|
|
101
110
|
activate: AppGraphSerializer,
|
|
102
111
|
}),
|
|
103
112
|
defineModule({
|
|
104
|
-
id: `${meta.id}/module/
|
|
105
|
-
|
|
106
|
-
|
|
113
|
+
id: `${meta.id}/module/anchor-sort`,
|
|
114
|
+
// TODO(wittjosiah): More relevant event?
|
|
115
|
+
activatesOn: Events.AppGraphReady,
|
|
116
|
+
activate: AnchorSort,
|
|
107
117
|
}),
|
|
108
118
|
defineModule({
|
|
109
119
|
id: `${meta.id}/module/artifact-definition`,
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { Capabilities, contributes } from '@dxos/app-framework';
|
|
6
|
+
import { getSchemaTypename } from '@dxos/echo-schema';
|
|
7
|
+
import { createDocAccessor, getRangeFromCursor, getTarget } from '@dxos/react-client/echo';
|
|
8
|
+
|
|
9
|
+
import { DocumentType } from '../types';
|
|
10
|
+
|
|
11
|
+
export default () =>
|
|
12
|
+
contributes(Capabilities.AnchorSort, {
|
|
13
|
+
key: getSchemaTypename(DocumentType)!,
|
|
14
|
+
sort: (anchorA, anchorB) => {
|
|
15
|
+
const doc = getTarget(anchorA) as DocumentType;
|
|
16
|
+
const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;
|
|
17
|
+
if (doc !== getTarget(anchorB) || !accessor) {
|
|
18
|
+
return 0;
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
const getStartPosition = (cursor: string | undefined) => {
|
|
22
|
+
const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;
|
|
23
|
+
return range?.start ?? Number.MAX_SAFE_INTEGER;
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
const posA = getStartPosition(anchorA.anchor);
|
|
27
|
+
const posB = getStartPosition(anchorB.anchor);
|
|
28
|
+
return posA - posB;
|
|
29
|
+
},
|
|
30
|
+
});
|
|
@@ -4,18 +4,17 @@
|
|
|
4
4
|
|
|
5
5
|
import { pipe } from 'effect';
|
|
6
6
|
|
|
7
|
-
import { contributes, Capabilities, type
|
|
8
|
-
import { getSchemaTypename } from '@dxos/echo-schema';
|
|
7
|
+
import { contributes, Capabilities, type PluginContext, chain, createIntent } from '@dxos/app-framework';
|
|
9
8
|
import { SpaceAction, CollectionType } from '@dxos/plugin-space/types';
|
|
10
9
|
import { isSpace } from '@dxos/react-client/echo';
|
|
11
10
|
|
|
12
11
|
import translations from '../translations';
|
|
13
12
|
import { MarkdownAction, DocumentType } from '../types';
|
|
14
13
|
|
|
15
|
-
export default (context:
|
|
14
|
+
export default (context: PluginContext) =>
|
|
16
15
|
contributes(Capabilities.AppGraphSerializer, [
|
|
17
16
|
{
|
|
18
|
-
inputType:
|
|
17
|
+
inputType: DocumentType.typename,
|
|
19
18
|
outputType: 'text/markdown',
|
|
20
19
|
// Reconcile with metadata serializers.
|
|
21
20
|
serialize: async (node) => {
|
|
@@ -37,7 +36,7 @@ export default (context: PluginsContext) =>
|
|
|
37
36
|
return;
|
|
38
37
|
}
|
|
39
38
|
|
|
40
|
-
const { dispatchPromise: dispatch } = context.
|
|
39
|
+
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
41
40
|
const result = await dispatch(
|
|
42
41
|
pipe(
|
|
43
42
|
createIntent(MarkdownAction.Create, { spaceId: space.id, name: data.name, content: data.data }),
|
|
@@ -2,14 +2,19 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
import {
|
|
5
|
+
import { pipe, Schema } from 'effect';
|
|
6
|
+
|
|
7
|
+
import { createTool, ToolResult } from '@dxos/ai';
|
|
8
|
+
import { Capabilities, chain, contributes, createIntent, type PromiseIntentDispatcher } from '@dxos/app-framework';
|
|
9
|
+
import { ArtifactId, defineArtifact } from '@dxos/artifact';
|
|
10
|
+
import { createArtifactElement } from '@dxos/assistant';
|
|
11
|
+
import { isInstanceOf } from '@dxos/echo-schema';
|
|
8
12
|
import { invariant, assertArgument } from '@dxos/invariant';
|
|
13
|
+
import { SpaceAction } from '@dxos/plugin-space/types';
|
|
9
14
|
import { Filter, fullyQualifiedId, type Space } from '@dxos/react-client/echo';
|
|
10
15
|
|
|
11
16
|
import { meta } from '../meta';
|
|
12
|
-
import { DocumentType } from '../types';
|
|
17
|
+
import { DocumentType, MarkdownAction } from '../types';
|
|
13
18
|
|
|
14
19
|
// TODO(burdon): Factor out.
|
|
15
20
|
declare global {
|
|
@@ -30,15 +35,48 @@ export default () => {
|
|
|
30
35
|
`,
|
|
31
36
|
schema: DocumentType,
|
|
32
37
|
tools: [
|
|
33
|
-
|
|
38
|
+
createTool(meta.id, {
|
|
39
|
+
name: 'create',
|
|
40
|
+
description: 'Create a new markdown document',
|
|
41
|
+
caption: 'Creating document...',
|
|
42
|
+
schema: Schema.Struct({
|
|
43
|
+
name: Schema.optional(Schema.String).annotations({
|
|
44
|
+
description: 'Optional name for the document.',
|
|
45
|
+
}),
|
|
46
|
+
content: Schema.String.annotations({
|
|
47
|
+
description: 'The content of the document.',
|
|
48
|
+
}),
|
|
49
|
+
}),
|
|
50
|
+
execute: async ({ name, content }, { extensions }) => {
|
|
51
|
+
invariant(extensions?.space, 'No space');
|
|
52
|
+
invariant(extensions?.dispatch, 'No intent dispatcher');
|
|
53
|
+
|
|
54
|
+
const intent = pipe(
|
|
55
|
+
createIntent(MarkdownAction.Create, {
|
|
56
|
+
spaceId: extensions.space.id,
|
|
57
|
+
name,
|
|
58
|
+
content,
|
|
59
|
+
}),
|
|
60
|
+
chain(SpaceAction.AddObject, { target: extensions.space }),
|
|
61
|
+
);
|
|
62
|
+
|
|
63
|
+
const { data, error } = await extensions.dispatch(intent);
|
|
64
|
+
if (!data || error) {
|
|
65
|
+
return ToolResult.Error(error?.message ?? 'Failed to create document');
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
return ToolResult.Success(createArtifactElement(data.id));
|
|
69
|
+
},
|
|
70
|
+
}),
|
|
71
|
+
createTool(meta.id, {
|
|
34
72
|
name: 'list',
|
|
35
73
|
description: 'List all markdown documents in the current space.',
|
|
36
74
|
caption: 'Listing markdown documents...',
|
|
37
|
-
schema:
|
|
75
|
+
schema: Schema.Struct({}),
|
|
38
76
|
execute: async (_input, { extensions }) => {
|
|
39
77
|
invariant(extensions?.space, 'No space');
|
|
40
78
|
const space = extensions.space;
|
|
41
|
-
const { objects: documents } = await space.db.query(Filter.
|
|
79
|
+
const { objects: documents } = await space.db.query(Filter.type(DocumentType)).run();
|
|
42
80
|
const documentInfo = documents.map((doc) => {
|
|
43
81
|
invariant(isInstanceOf(DocumentType, doc));
|
|
44
82
|
return {
|
|
@@ -51,16 +89,16 @@ export default () => {
|
|
|
51
89
|
return ToolResult.Success(documentInfo);
|
|
52
90
|
},
|
|
53
91
|
}),
|
|
54
|
-
|
|
92
|
+
createTool(meta.id, {
|
|
55
93
|
name: 'inspect',
|
|
56
94
|
description: 'Read the content of a markdown document.',
|
|
57
95
|
caption: 'Inspecting markdown document...',
|
|
58
|
-
schema:
|
|
96
|
+
schema: Schema.Struct({
|
|
59
97
|
id: ArtifactId,
|
|
60
98
|
}),
|
|
61
99
|
execute: async ({ id }, { extensions }) => {
|
|
62
100
|
invariant(extensions?.space, 'No space');
|
|
63
|
-
const document = await extensions.space.db.query(
|
|
101
|
+
const document = await extensions.space.db.query(Filter.ids(ArtifactId.toDXN(id).toString())).first();
|
|
64
102
|
assertArgument(isInstanceOf(DocumentType, document), 'Invalid type');
|
|
65
103
|
|
|
66
104
|
const { content } = await document.content?.load();
|