@dxos/plugin-markdown 0.8.2-main.f11618f → 0.8.2-staging.7ac8446
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-5XV7K2NX.mjs → MarkdownContainer-T3HU27RE.mjs} +12 -16
- package/dist/lib/browser/MarkdownContainer-T3HU27RE.mjs.map +7 -0
- package/dist/lib/browser/{app-graph-serializer-OCXP7PCK.mjs → app-graph-serializer-NOXI4IQ5.mjs} +3 -3
- package/dist/lib/browser/{artifact-definition-XTVOUMMI.mjs → artifact-definition-CE6J6NY4.mjs} +2 -2
- package/dist/lib/browser/{chunk-QV6ZIXAD.mjs → chunk-3ULJ4FIJ.mjs} +23 -10
- package/dist/lib/browser/chunk-3ULJ4FIJ.mjs.map +7 -0
- package/dist/lib/browser/{chunk-LJ2UFBJ2.mjs → chunk-QXDKFACU.mjs} +3 -5
- package/dist/lib/browser/{chunk-LJ2UFBJ2.mjs.map → chunk-QXDKFACU.mjs.map} +2 -2
- package/dist/lib/browser/{chunk-GVOEHF7E.mjs → chunk-YCJNW2RU.mjs} +1 -10
- package/dist/lib/browser/chunk-YCJNW2RU.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +4 -8
- package/dist/lib/browser/index.mjs.map +2 -2
- package/dist/lib/browser/intent-resolver-42GQ6HNZ.mjs +50 -0
- package/dist/lib/browser/intent-resolver-42GQ6HNZ.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-LBCMSLJ5.mjs → react-surface-RQX3CPFV.mjs} +4 -14
- package/dist/lib/browser/react-surface-RQX3CPFV.mjs.map +7 -0
- package/dist/lib/browser/{settings-EQSDBX6O.mjs → settings-GCSS3Y4Z.mjs} +4 -4
- package/dist/lib/browser/settings-GCSS3Y4Z.mjs.map +7 -0
- package/dist/lib/browser/{state-AIN4J7N5.mjs → state-O7P5JDIH.mjs} +1 -1
- package/dist/lib/browser/{state-AIN4J7N5.mjs.map → state-O7P5JDIH.mjs.map} +2 -2
- package/dist/lib/browser/{thread-MFKBUVCB.mjs → thread-3QGCFNVZ.mjs} +2 -2
- package/dist/lib/browser/types/index.mjs +1 -3
- package/dist/lib/node/{MarkdownContainer-5EQTBXV3.cjs → MarkdownContainer-6ZJIFAP6.cjs} +15 -19
- package/dist/lib/node/MarkdownContainer-6ZJIFAP6.cjs.map +7 -0
- package/dist/lib/node/{app-graph-serializer-KBDLASRP.cjs → app-graph-serializer-HKK3SEDN.cjs} +9 -9
- package/dist/lib/node/{artifact-definition-ADEN2KD6.cjs → artifact-definition-XGADFWCQ.cjs} +9 -9
- package/dist/lib/node/{chunk-QRE5L6ZC.cjs → chunk-7QVONRSI.cjs} +57 -13
- package/dist/lib/node/chunk-7QVONRSI.cjs.map +7 -0
- package/dist/lib/node/{chunk-JO4SBK36.cjs → chunk-H5MYVP6F.cjs} +7 -9
- package/dist/lib/node/{chunk-JO4SBK36.cjs.map → chunk-H5MYVP6F.cjs.map} +2 -2
- package/dist/lib/node/{chunk-YHL4JSA6.cjs → chunk-UEXGNGSS.cjs} +4 -14
- package/dist/lib/node/chunk-UEXGNGSS.cjs.map +7 -0
- package/dist/lib/node/index.cjs +20 -23
- package/dist/lib/node/index.cjs.map +2 -2
- package/dist/lib/node/{intent-resolver-NX5QNRYF.cjs → intent-resolver-NW27BF3W.cjs} +9 -45
- package/dist/lib/node/intent-resolver-NW27BF3W.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{react-surface-DJIZSVMN.cjs → react-surface-5X3SMHGI.cjs} +8 -18
- package/dist/lib/node/react-surface-5X3SMHGI.cjs.map +7 -0
- package/dist/lib/node/{settings-2JXASSLU.cjs → settings-S2ISUVIH.cjs} +7 -7
- package/dist/lib/node/settings-S2ISUVIH.cjs.map +7 -0
- package/dist/lib/node/{state-PC7IVXFP.cjs → state-L44SG3ZM.cjs} +4 -4
- package/dist/lib/node/{state-PC7IVXFP.cjs.map → state-L44SG3ZM.cjs.map} +2 -2
- package/dist/lib/node/{thread-MXEGV6HS.cjs → thread-42R57L4K.cjs} +6 -6
- package/dist/lib/node/types/index.cjs +6 -8
- package/dist/lib/node/types/index.cjs.map +2 -2
- package/dist/lib/node-esm/{MarkdownContainer-LONZOJJX.mjs → MarkdownContainer-URAPTO37.mjs} +12 -16
- package/dist/lib/node-esm/MarkdownContainer-URAPTO37.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-serializer-67CO7ST3.mjs → app-graph-serializer-QQ2CTHOQ.mjs} +3 -3
- package/dist/lib/node-esm/{artifact-definition-KTS5M2FW.mjs → artifact-definition-WRG5ZRN5.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-NUZHKZSZ.mjs → chunk-4AM4VU3Y.mjs} +1 -10
- package/dist/lib/node-esm/chunk-4AM4VU3Y.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-4U2F4EB7.mjs → chunk-F6UHVLH7.mjs} +23 -10
- package/dist/lib/node-esm/chunk-F6UHVLH7.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-VQA6BQGT.mjs → chunk-JAVD67QP.mjs} +3 -5
- package/dist/lib/node-esm/{chunk-VQA6BQGT.mjs.map → chunk-JAVD67QP.mjs.map} +2 -2
- package/dist/lib/node-esm/index.mjs +4 -8
- package/dist/lib/node-esm/index.mjs.map +2 -2
- package/dist/lib/node-esm/intent-resolver-7HOMUVHR.mjs +51 -0
- package/dist/lib/node-esm/intent-resolver-7HOMUVHR.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{react-surface-737EXAWT.mjs → react-surface-6IKC3G46.mjs} +4 -14
- package/dist/lib/node-esm/react-surface-6IKC3G46.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-67RVIH3N.mjs → settings-ZDIFTK4N.mjs} +4 -4
- package/dist/lib/node-esm/settings-ZDIFTK4N.mjs.map +7 -0
- package/dist/lib/node-esm/{state-PNOPM4TS.mjs → state-DWPOKLEY.mjs} +1 -1
- package/dist/lib/node-esm/{state-PNOPM4TS.mjs.map → state-DWPOKLEY.mjs.map} +2 -2
- package/dist/lib/node-esm/{thread-5U4KSBED.mjs → thread-R2KHZD6V.mjs} +2 -2
- package/dist/lib/node-esm/types/index.mjs +1 -3
- 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/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/{MarkdownEditor/MarkdownEditor.d.ts → MarkdownEditor.d.ts} +1 -1
- package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -0
- package/dist/types/src/components/{MarkdownEditor/MarkdownEditor.stories.d.ts → MarkdownEditor.stories.d.ts} +3 -3
- package/dist/types/src/components/MarkdownEditor.stories.d.ts.map +1 -0
- package/dist/types/src/components/{MarkdownSettings/MarkdownSettings.d.ts → MarkdownSettings.d.ts} +1 -1
- package/dist/types/src/components/MarkdownSettings.d.ts.map +1 -0
- package/dist/types/src/components/Toolbar.stories.d.ts +2 -2
- package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +0 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +0 -6
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +17 -421
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +8 -120
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +0 -1
- package/dist/types/src/util.d.ts.map +1 -1
- package/package.json +32 -37
- package/src/MarkdownPlugin.tsx +3 -3
- package/src/capabilities/intent-resolver.ts +5 -38
- package/src/capabilities/react-surface.tsx +1 -8
- package/src/capabilities/settings.ts +2 -2
- package/src/capabilities/state.ts +1 -1
- package/src/components/MarkdownContainer.tsx +0 -1
- package/src/components/{MarkdownEditor/MarkdownEditor.stories.tsx → MarkdownEditor.stories.tsx} +35 -22
- package/src/components/{MarkdownEditor/MarkdownEditor.tsx → MarkdownEditor.tsx} +4 -5
- package/src/components/{MarkdownSettings/MarkdownSettings.tsx → MarkdownSettings.tsx} +2 -2
- package/src/components/Toolbar.stories.tsx +15 -15
- package/src/components/index.ts +0 -1
- package/src/extensions.tsx +32 -37
- package/src/translations.ts +0 -2
- package/src/types/schema.ts +0 -5
- package/src/util.tsx +2 -6
- 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/chunk-5QXYEKSX.mjs +0 -20
- package/dist/lib/browser/chunk-5QXYEKSX.mjs.map +0 -7
- package/dist/lib/browser/chunk-GVOEHF7E.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/settings-EQSDBX6O.mjs.map +0 -7
- 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/chunk-QRE5L6ZC.cjs.map +0 -7
- package/dist/lib/node/chunk-WGMVEPB3.cjs +0 -75
- 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.map +0 -7
- package/dist/lib/node/react-surface-DJIZSVMN.cjs.map +0 -7
- package/dist/lib/node/settings-2JXASSLU.cjs.map +0 -7
- 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/chunk-4U2F4EB7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NUZHKZSZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-PALFXZBY.mjs +0 -22
- package/dist/lib/node-esm/chunk-PALFXZBY.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/settings-67RVIH3N.mjs.map +0 -7
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownEditor/index.d.ts +0 -2
- package/dist/types/src/components/MarkdownEditor/index.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts +0 -6
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts +0 -191
- package/dist/types/src/components/MarkdownPreview/MarkdownPreview.stories.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownPreview/index.d.ts +0 -4
- package/dist/types/src/components/MarkdownPreview/index.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownSettings/MarkdownSettings.d.ts.map +0 -1
- package/dist/types/src/components/MarkdownSettings/index.d.ts +0 -2
- package/dist/types/src/components/MarkdownSettings/index.d.ts.map +0 -1
- package/dist/types/src/components/Suggestions.stories.d.ts +0 -12
- package/dist/types/src/components/Suggestions.stories.d.ts.map +0 -1
- package/src/components/MarkdownEditor/index.ts +0 -5
- package/src/components/MarkdownPreview/MarkdownPreview.stories.tsx +0 -68
- package/src/components/MarkdownPreview/MarkdownPreview.tsx +0 -85
- package/src/components/MarkdownPreview/index.ts +0 -9
- package/src/components/MarkdownSettings/index.ts +0 -5
- package/src/components/Suggestions.stories.tsx +0 -184
- /package/dist/lib/browser/{app-graph-serializer-OCXP7PCK.mjs.map → app-graph-serializer-NOXI4IQ5.mjs.map} +0 -0
- /package/dist/lib/browser/{artifact-definition-XTVOUMMI.mjs.map → artifact-definition-CE6J6NY4.mjs.map} +0 -0
- /package/dist/lib/browser/{thread-MFKBUVCB.mjs.map → thread-3QGCFNVZ.mjs.map} +0 -0
- /package/dist/lib/node/{app-graph-serializer-KBDLASRP.cjs.map → app-graph-serializer-HKK3SEDN.cjs.map} +0 -0
- /package/dist/lib/node/{artifact-definition-ADEN2KD6.cjs.map → artifact-definition-XGADFWCQ.cjs.map} +0 -0
- /package/dist/lib/node/{thread-MXEGV6HS.cjs.map → thread-42R57L4K.cjs.map} +0 -0
- /package/dist/lib/node-esm/{app-graph-serializer-67CO7ST3.mjs.map → app-graph-serializer-QQ2CTHOQ.mjs.map} +0 -0
- /package/dist/lib/node-esm/{artifact-definition-KTS5M2FW.mjs.map → artifact-definition-WRG5ZRN5.mjs.map} +0 -0
- /package/dist/lib/node-esm/{thread-5U4KSBED.mjs.map → thread-R2KHZD6V.mjs.map} +0 -0
|
@@ -24,128 +24,22 @@ export declare namespace MarkdownAction {
|
|
|
24
24
|
messages: S.mutable<S.Array$<import("@dxos/echo-schema").Ref$<import("@dxos/echo-schema").TypedObjectFields<{
|
|
25
25
|
id: import("@dxos/echo-schema").ObjectIdClass;
|
|
26
26
|
created: S.SchemaClass<string, string, never>;
|
|
27
|
-
sender: S.
|
|
27
|
+
sender: S.Struct<{
|
|
28
28
|
contact: S.optional<import("@dxos/echo-schema").Ref$<{
|
|
29
29
|
readonly id: string;
|
|
30
|
-
|
|
30
|
+
name?: string | undefined;
|
|
31
|
+
identifiers: {
|
|
31
32
|
readonly value: string;
|
|
32
|
-
readonly
|
|
33
|
-
|
|
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;
|
|
33
|
+
readonly type: string;
|
|
34
|
+
}[];
|
|
141
35
|
}>>;
|
|
142
36
|
identityDid: S.optional<typeof S.String>;
|
|
143
37
|
identityKey: S.optional<typeof S.String>;
|
|
144
38
|
email: S.optional<typeof S.String>;
|
|
145
39
|
name: S.optional<typeof S.String>;
|
|
146
40
|
role: S.optional<S.Literal<["user", "assistant"]>>;
|
|
147
|
-
}
|
|
148
|
-
blocks: S.
|
|
41
|
+
}>;
|
|
42
|
+
blocks: S.Array$<S.Union<[S.mutable<S.extend<S.Struct<{
|
|
149
43
|
pending: S.optional<typeof S.Boolean>;
|
|
150
44
|
}>, S.Struct<{
|
|
151
45
|
type: S.Literal<["text"]>;
|
|
@@ -175,13 +69,7 @@ export declare namespace MarkdownAction {
|
|
|
175
69
|
}>, S.Struct<{
|
|
176
70
|
type: S.Literal<["reference"]>;
|
|
177
71
|
reference: import("@dxos/echo-schema").Ref$<import("@dxos/echo-schema").Expando>;
|
|
178
|
-
}
|
|
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
|
-
}>>>]>>>;
|
|
72
|
+
}>>>]>>;
|
|
185
73
|
properties: S.optional<S.mutable<S.Record$<typeof S.String, typeof S.Any>>>;
|
|
186
74
|
}, import("@dxos/echo-schema").TypedObjectOptions>>>>;
|
|
187
75
|
}, import("@dxos/echo-schema").TypedObjectOptions>>>>;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/types/types.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,CAAC,EAAE,MAAM,mBAAmB,CAAC;AAEtC,OAAO,EAAE,KAAK,SAAS,EAAmB,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAExF,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAKxC,yBAAiB,cAAc,CAAC;;;;;;;;;;;;;;oCAPU,EAAE,MAAM;;;
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/types/types.ts"],"names":[],"mappings":"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"}
|
package/dist/types/src/util.d.ts
CHANGED
|
@@ -2,7 +2,6 @@ import { type TypedObjectSerializer } from '@dxos/plugin-space/types';
|
|
|
2
2
|
import { DocumentType, type MarkdownProperties } from './types';
|
|
3
3
|
export declare const isMarkdownProperties: (data: unknown) => data is MarkdownProperties;
|
|
4
4
|
export declare const getFallbackName: (content: string) => string;
|
|
5
|
-
export declare const getAbstract: (content: string) => string;
|
|
6
5
|
export declare const setFallbackName: (...args: any[]) => void;
|
|
7
6
|
export declare const serializer: TypedObjectSerializer<DocumentType>;
|
|
8
7
|
//# sourceMappingURL=util.d.ts.map
|
|
@@ -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,SAAU,OAAO,KAAG,IAAI,IAAI,kBAKhD,CAAC;AAId,eAAO,MAAM,eAAe,YAAa,MAAM,WAE9C,CAAC;AAEF,eAAO,MAAM,
|
|
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,SAAU,OAAO,KAAG,IAAI,IAAI,kBAKhD,CAAC;AAId,eAAO,MAAM,eAAe,YAAa,MAAM,WAE9C,CAAC;AAEF,eAAO,MAAM,eAAe,0BAKrB,CAAC;AAER,eAAO,MAAM,UAAU,EAAE,qBAAqB,CAAC,YAAY,CAY1D,CAAC"}
|
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.7ac8446",
|
|
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",
|
|
@@ -38,33 +38,30 @@
|
|
|
38
38
|
"@preact/signals-core": "^1.6.0",
|
|
39
39
|
"effect": "3.13.3",
|
|
40
40
|
"react-dropzone": "^14.2.3",
|
|
41
|
-
"@dxos/app-framework": "0.8.2-
|
|
42
|
-
"@dxos/
|
|
43
|
-
"@dxos/
|
|
44
|
-
"@dxos/
|
|
45
|
-
"@dxos/
|
|
46
|
-
"@dxos/
|
|
47
|
-
"@dxos/
|
|
48
|
-
"@dxos/
|
|
49
|
-
"@dxos/
|
|
50
|
-
"@dxos/local-storage": "0.8.2-
|
|
51
|
-
"@dxos/plugin-
|
|
52
|
-
"@dxos/plugin-
|
|
53
|
-
"@dxos/plugin-
|
|
54
|
-
"@dxos/plugin-
|
|
55
|
-
"@dxos/
|
|
56
|
-
"@dxos/plugin-
|
|
57
|
-
"@dxos/
|
|
58
|
-
"@dxos/react-
|
|
59
|
-
"@dxos/
|
|
60
|
-
"@dxos/react-
|
|
61
|
-
"@dxos/react-ui-
|
|
62
|
-
"@dxos/react-ui-
|
|
63
|
-
"@dxos/
|
|
64
|
-
"@dxos/
|
|
65
|
-
"@dxos/react-ui-stack": "0.8.2-main.f11618f",
|
|
66
|
-
"@dxos/schema": "0.8.2-main.f11618f",
|
|
67
|
-
"@dxos/util": "0.8.2-main.f11618f"
|
|
41
|
+
"@dxos/app-framework": "0.8.2-staging.7ac8446",
|
|
42
|
+
"@dxos/async": "0.8.2-staging.7ac8446",
|
|
43
|
+
"@dxos/echo-schema": "0.8.2-staging.7ac8446",
|
|
44
|
+
"@dxos/artifact": "0.8.2-staging.7ac8446",
|
|
45
|
+
"@dxos/invariant": "0.8.2-staging.7ac8446",
|
|
46
|
+
"@dxos/keys": "0.8.2-staging.7ac8446",
|
|
47
|
+
"@dxos/live-object": "0.8.2-staging.7ac8446",
|
|
48
|
+
"@dxos/log": "0.8.2-staging.7ac8446",
|
|
49
|
+
"@dxos/plugin-attention": "0.8.2-staging.7ac8446",
|
|
50
|
+
"@dxos/local-storage": "0.8.2-staging.7ac8446",
|
|
51
|
+
"@dxos/plugin-client": "0.8.2-staging.7ac8446",
|
|
52
|
+
"@dxos/plugin-deck": "0.8.2-staging.7ac8446",
|
|
53
|
+
"@dxos/plugin-graph": "0.8.2-staging.7ac8446",
|
|
54
|
+
"@dxos/plugin-space": "0.8.2-staging.7ac8446",
|
|
55
|
+
"@dxos/react-client": "0.8.2-staging.7ac8446",
|
|
56
|
+
"@dxos/plugin-theme": "0.8.2-staging.7ac8446",
|
|
57
|
+
"@dxos/react-hooks": "0.8.2-staging.7ac8446",
|
|
58
|
+
"@dxos/react-ui-card": "0.8.2-staging.7ac8446",
|
|
59
|
+
"@dxos/react-ui-attention": "0.8.2-staging.7ac8446",
|
|
60
|
+
"@dxos/react-ui-form": "0.8.2-staging.7ac8446",
|
|
61
|
+
"@dxos/react-ui-editor": "0.8.2-staging.7ac8446",
|
|
62
|
+
"@dxos/react-ui-stack": "0.8.2-staging.7ac8446",
|
|
63
|
+
"@dxos/schema": "0.8.2-staging.7ac8446",
|
|
64
|
+
"@dxos/util": "0.8.2-staging.7ac8446"
|
|
68
65
|
},
|
|
69
66
|
"devDependencies": {
|
|
70
67
|
"@phosphor-icons/react": "^2.1.5",
|
|
@@ -73,20 +70,18 @@
|
|
|
73
70
|
"react": "~18.2.0",
|
|
74
71
|
"react-dom": "~18.2.0",
|
|
75
72
|
"vite": "5.4.7",
|
|
76
|
-
"@dxos/debug": "0.8.2-
|
|
77
|
-
"@dxos/
|
|
78
|
-
"@dxos/
|
|
79
|
-
"@dxos/
|
|
80
|
-
"@dxos/
|
|
81
|
-
"@dxos/react-ui-theme": "0.8.2-main.f11618f",
|
|
82
|
-
"@dxos/storybook-utils": "0.8.2-main.f11618f"
|
|
73
|
+
"@dxos/debug": "0.8.2-staging.7ac8446",
|
|
74
|
+
"@dxos/react-ui": "0.8.2-staging.7ac8446",
|
|
75
|
+
"@dxos/react-ui-theme": "0.8.2-staging.7ac8446",
|
|
76
|
+
"@dxos/storybook-utils": "0.8.2-staging.7ac8446",
|
|
77
|
+
"@dxos/random": "0.8.2-staging.7ac8446"
|
|
83
78
|
},
|
|
84
79
|
"peerDependencies": {
|
|
85
80
|
"@phosphor-icons/react": "^2.1.5",
|
|
86
81
|
"react": "~18.2.0",
|
|
87
82
|
"react-dom": "~18.2.0",
|
|
88
|
-
"@dxos/react-ui": "0.8.2-
|
|
89
|
-
"@dxos/react-ui-theme": "0.8.2-
|
|
83
|
+
"@dxos/react-ui": "0.8.2-staging.7ac8446",
|
|
84
|
+
"@dxos/react-ui-theme": "0.8.2-staging.7ac8446"
|
|
90
85
|
},
|
|
91
86
|
"publishConfig": {
|
|
92
87
|
"access": "public"
|
package/src/MarkdownPlugin.tsx
CHANGED
|
@@ -12,13 +12,13 @@ import { translations as editorTranslations } from '@dxos/react-ui-editor';
|
|
|
12
12
|
import { TextType } from '@dxos/schema';
|
|
13
13
|
|
|
14
14
|
import {
|
|
15
|
-
AppGraphSerializer,
|
|
16
|
-
ArtifactDefinition,
|
|
17
|
-
IntentResolver,
|
|
18
15
|
MarkdownState,
|
|
19
16
|
MarkdownSettings,
|
|
20
17
|
ReactSurface,
|
|
18
|
+
IntentResolver,
|
|
19
|
+
AppGraphSerializer,
|
|
21
20
|
Thread,
|
|
21
|
+
ArtifactDefinition,
|
|
22
22
|
} from './capabilities';
|
|
23
23
|
import { MarkdownEvents } from './events';
|
|
24
24
|
import { meta } from './meta';
|
|
@@ -2,21 +2,10 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
CollaborationActions,
|
|
8
|
-
contributes,
|
|
9
|
-
createResolver,
|
|
10
|
-
type PluginsContext,
|
|
11
|
-
} from '@dxos/app-framework';
|
|
12
|
-
import { next as A } from '@dxos/automerge/automerge';
|
|
13
|
-
import { isInstanceOf, ObjectId } from '@dxos/echo-schema';
|
|
5
|
+
import { Capabilities, contributes, createResolver, type PluginsContext } from '@dxos/app-framework';
|
|
6
|
+
import { ObjectId } from '@dxos/echo-schema';
|
|
14
7
|
import { DXN, QueueSubspaceTags } from '@dxos/keys';
|
|
15
|
-
import { makeRef,
|
|
16
|
-
import { log } from '@dxos/log';
|
|
17
|
-
import { ClientCapabilities } from '@dxos/plugin-client';
|
|
18
|
-
import { resolveRef } from '@dxos/react-client';
|
|
19
|
-
import { createDocAccessor } from '@dxos/react-client/echo';
|
|
8
|
+
import { makeRef, create, refFromDXN } from '@dxos/live-object';
|
|
20
9
|
import { TextType } from '@dxos/schema';
|
|
21
10
|
|
|
22
11
|
import { MarkdownCapabilities } from './capabilities';
|
|
@@ -27,9 +16,9 @@ export default (context: PluginsContext) =>
|
|
|
27
16
|
createResolver({
|
|
28
17
|
intent: MarkdownAction.Create,
|
|
29
18
|
resolve: ({ name, spaceId, content }) => {
|
|
30
|
-
const doc =
|
|
19
|
+
const doc = create(DocumentType, {
|
|
31
20
|
name,
|
|
32
|
-
content: makeRef(
|
|
21
|
+
content: makeRef(create(TextType, { content: content ?? '' })),
|
|
33
22
|
assistantChatQueue: refFromDXN(new DXN(DXN.kind.QUEUE, [QueueSubspaceTags.DATA, spaceId, ObjectId.random()])),
|
|
34
23
|
threads: [],
|
|
35
24
|
});
|
|
@@ -44,26 +33,4 @@ export default (context: PluginsContext) =>
|
|
|
44
33
|
state.viewMode[id] = viewMode;
|
|
45
34
|
},
|
|
46
35
|
}),
|
|
47
|
-
// TODO(burdon): What is the error boundary for intents? Are errors reported back to caller?
|
|
48
|
-
createResolver({
|
|
49
|
-
intent: CollaborationActions.InsertContent,
|
|
50
|
-
resolve: async ({ spaceId, target: targetRef, object: objectRef, label }) => {
|
|
51
|
-
const client = context.requestCapability(ClientCapabilities.Client);
|
|
52
|
-
const space = client.spaces.get(spaceId);
|
|
53
|
-
const target = await resolveRef(client, targetRef.dxn, space);
|
|
54
|
-
if (target && isInstanceOf(DocumentType, target)) {
|
|
55
|
-
const accessor = createDocAccessor(target, ['content']);
|
|
56
|
-
// TODO(burdon): Should be a cursor that references a selected position.
|
|
57
|
-
const index = 0;
|
|
58
|
-
accessor.handle.change((doc) => {
|
|
59
|
-
// TODO(burdon): Throws error:
|
|
60
|
-
// intent-dispatcher.ts:270 Cannot read properties of undefined (reading 'annotations') (FiberFailure) TypeError: Cannot read properties of undefined (reading 'annotations')
|
|
61
|
-
const ref = `[${label ?? 'Generated content'}]](${objectRef.dxn.toString()})\n`;
|
|
62
|
-
A.splice(doc, accessor.path.slice(), index, 0, ref);
|
|
63
|
-
});
|
|
64
|
-
} else {
|
|
65
|
-
log.warn('target is not a document', { targetRef, objectRef });
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
}),
|
|
69
36
|
]);
|
|
@@ -11,7 +11,7 @@ import { fullyQualifiedId } from '@dxos/react-client/echo';
|
|
|
11
11
|
import { TextType } from '@dxos/schema';
|
|
12
12
|
|
|
13
13
|
import { MarkdownCapabilities } from './capabilities';
|
|
14
|
-
import { MarkdownContainer, MarkdownSettings
|
|
14
|
+
import { MarkdownContainer, MarkdownSettings } from '../components';
|
|
15
15
|
import { MARKDOWN_PLUGIN } from '../meta';
|
|
16
16
|
import { DocumentType, isEditorModel, type MarkdownSettingsProps } from '../types';
|
|
17
17
|
|
|
@@ -95,11 +95,4 @@ export default () =>
|
|
|
95
95
|
data.subject instanceof SettingsStore && data.subject.prefix === MARKDOWN_PLUGIN,
|
|
96
96
|
component: ({ data: { subject } }) => <MarkdownSettings settings={subject.value} />,
|
|
97
97
|
}),
|
|
98
|
-
createSurface({
|
|
99
|
-
id: `${MARKDOWN_PLUGIN}/preview`,
|
|
100
|
-
role: 'popover',
|
|
101
|
-
filter: (data): data is { subject: DocumentType | TextType } =>
|
|
102
|
-
isInstanceOf(DocumentType, data.subject) || isInstanceOf(TextType, data.subject),
|
|
103
|
-
component: ({ data, role }) => <MarkdownPreview {...data} role={role} />,
|
|
104
|
-
}),
|
|
105
98
|
]);
|
|
@@ -3,13 +3,13 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { Capabilities, contributes } from '@dxos/app-framework';
|
|
6
|
-
import {
|
|
6
|
+
import { create } from '@dxos/live-object';
|
|
7
7
|
|
|
8
8
|
import { MARKDOWN_PLUGIN } from '../meta';
|
|
9
9
|
import { type MarkdownSettingsProps, MarkdownSettingsSchema } from '../types';
|
|
10
10
|
|
|
11
11
|
export default () => {
|
|
12
|
-
const settings =
|
|
12
|
+
const settings = create<MarkdownSettingsProps>({
|
|
13
13
|
defaultViewMode: 'preview',
|
|
14
14
|
toolbar: true,
|
|
15
15
|
numberedHeadings: true,
|
|
@@ -12,6 +12,7 @@ import { type MarkdownPluginState, type MarkdownSettingsProps } from '../types';
|
|
|
12
12
|
|
|
13
13
|
export default (context: PluginsContext) => {
|
|
14
14
|
const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });
|
|
15
|
+
|
|
15
16
|
state.prop({ key: 'viewMode', type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>() });
|
|
16
17
|
|
|
17
18
|
// TODO(wittjosiah): Fold into state.
|
|
@@ -26,6 +27,5 @@ export default (context: PluginsContext) => {
|
|
|
26
27
|
|
|
27
28
|
const setViewMode = (id: string, viewMode: EditorViewMode) => (state.values.viewMode[id] = viewMode);
|
|
28
29
|
|
|
29
|
-
// Return object with methods.
|
|
30
30
|
return contributes(MarkdownCapabilities.State, { state: state.values, editorState, getViewMode, setViewMode });
|
|
31
31
|
};
|
package/src/components/{MarkdownEditor/MarkdownEditor.stories.tsx → MarkdownEditor.stories.tsx}
RENAMED
|
@@ -10,14 +10,19 @@ import React, { useMemo } from 'react';
|
|
|
10
10
|
import { IntentPlugin } from '@dxos/app-framework';
|
|
11
11
|
import { withPluginManager } from '@dxos/app-framework/testing';
|
|
12
12
|
import { createDocAccessor, createObject } from '@dxos/react-client/echo';
|
|
13
|
+
import { Main } from '@dxos/react-ui';
|
|
14
|
+
import { AttendableContainer } from '@dxos/react-ui-attention';
|
|
13
15
|
import { withAttention } from '@dxos/react-ui-attention/testing';
|
|
14
|
-
import { automerge, translations as editorTranslations } from '@dxos/react-ui-editor';
|
|
16
|
+
import { editorWithToolbarLayout, automerge, translations as editorTranslations } from '@dxos/react-ui-editor';
|
|
17
|
+
import { topbarBlockPaddingStart } from '@dxos/react-ui-theme';
|
|
15
18
|
import { withLayout, withTheme } from '@dxos/storybook-utils';
|
|
16
19
|
|
|
17
20
|
import { MarkdownEditor, type MarkdownEditorProps } from './MarkdownEditor';
|
|
18
|
-
import translations from '
|
|
21
|
+
import translations from '../translations';
|
|
19
22
|
|
|
20
|
-
const content = Array.from({ length: 100 }
|
|
23
|
+
const content = Array.from({ length: 100 })
|
|
24
|
+
.map((_, i) => `Line ${i + 1}`)
|
|
25
|
+
.join('\n');
|
|
21
26
|
|
|
22
27
|
type StoryProps = MarkdownEditorProps & {
|
|
23
28
|
content?: string;
|
|
@@ -27,26 +32,19 @@ type StoryProps = MarkdownEditorProps & {
|
|
|
27
32
|
const DefaultStory = ({ content = '# Test', toolbar }: StoryProps) => {
|
|
28
33
|
const doc = useMemo(() => createObject({ content }), [content]);
|
|
29
34
|
const extensions = useMemo(() => [automerge(createDocAccessor(doc, ['content']))], [doc]);
|
|
30
|
-
return
|
|
35
|
+
return (
|
|
36
|
+
<Main.Content
|
|
37
|
+
bounce
|
|
38
|
+
data-toolbar={toolbar ? 'enabled' : 'disabled'}
|
|
39
|
+
classNames={[topbarBlockPaddingStart, editorWithToolbarLayout]}
|
|
40
|
+
>
|
|
41
|
+
<AttendableContainer id='test'>
|
|
42
|
+
<MarkdownEditor id='test' initialValue={doc.content} extensions={extensions} toolbar={toolbar} />
|
|
43
|
+
</AttendableContainer>
|
|
44
|
+
</Main.Content>
|
|
45
|
+
);
|
|
31
46
|
};
|
|
32
47
|
|
|
33
|
-
const meta: Meta<typeof MarkdownEditor> = {
|
|
34
|
-
title: 'plugins/plugin-markdown/MarkdownEditor',
|
|
35
|
-
component: MarkdownEditor,
|
|
36
|
-
render: DefaultStory,
|
|
37
|
-
decorators: [
|
|
38
|
-
withTheme,
|
|
39
|
-
withLayout({ tooltips: true, fullscreen: true }),
|
|
40
|
-
withAttention,
|
|
41
|
-
withPluginManager({ plugins: [IntentPlugin()] }),
|
|
42
|
-
],
|
|
43
|
-
parameters: {
|
|
44
|
-
translations: [...translations, ...editorTranslations],
|
|
45
|
-
},
|
|
46
|
-
};
|
|
47
|
-
|
|
48
|
-
export default meta;
|
|
49
|
-
|
|
50
48
|
export const Default = {
|
|
51
49
|
args: {
|
|
52
50
|
content,
|
|
@@ -55,7 +53,22 @@ export const Default = {
|
|
|
55
53
|
|
|
56
54
|
export const WithToolbar = {
|
|
57
55
|
args: {
|
|
58
|
-
toolbar: true,
|
|
59
56
|
content,
|
|
57
|
+
toolbar: true,
|
|
60
58
|
},
|
|
61
59
|
};
|
|
60
|
+
|
|
61
|
+
const meta: Meta<typeof MarkdownEditor> = {
|
|
62
|
+
title: 'plugins/plugin-markdown/EditorMain',
|
|
63
|
+
component: MarkdownEditor,
|
|
64
|
+
render: DefaultStory,
|
|
65
|
+
decorators: [
|
|
66
|
+
withTheme,
|
|
67
|
+
withLayout({ tooltips: true }),
|
|
68
|
+
withAttention,
|
|
69
|
+
withPluginManager({ plugins: [IntentPlugin()] }),
|
|
70
|
+
],
|
|
71
|
+
parameters: { layout: 'fullscreen', translations: [...translations, ...editorTranslations] },
|
|
72
|
+
};
|
|
73
|
+
|
|
74
|
+
export default meta;
|
|
@@ -38,9 +38,9 @@ import {
|
|
|
38
38
|
import { StackItem } from '@dxos/react-ui-stack';
|
|
39
39
|
import { isNotFalsy, isNonNullable } from '@dxos/util';
|
|
40
40
|
|
|
41
|
-
import { useSelectCurrentThread } from '
|
|
42
|
-
import { MARKDOWN_PLUGIN } from '
|
|
43
|
-
import { type MarkdownPluginState } from '
|
|
41
|
+
import { useSelectCurrentThread } from '../hooks';
|
|
42
|
+
import { MARKDOWN_PLUGIN } from '../meta';
|
|
43
|
+
import { type MarkdownPluginState } from '../types';
|
|
44
44
|
|
|
45
45
|
export type MarkdownEditorProps = {
|
|
46
46
|
id: string;
|
|
@@ -211,7 +211,7 @@ export const MarkdownEditor = ({
|
|
|
211
211
|
);
|
|
212
212
|
|
|
213
213
|
return (
|
|
214
|
-
<StackItem.Content toolbar={!!toolbar}
|
|
214
|
+
<StackItem.Content toolbar={!!toolbar}>
|
|
215
215
|
{toolbar && (
|
|
216
216
|
<>
|
|
217
217
|
<EditorToolbar
|
|
@@ -231,7 +231,6 @@ export const MarkdownEditor = ({
|
|
|
231
231
|
data-testid='composer.markdownRoot'
|
|
232
232
|
data-toolbar={toolbar ? 'enabled' : 'disabled'}
|
|
233
233
|
className={stackItemContentEditorClassNames(role)}
|
|
234
|
-
data-popover-collision-boundary={true}
|
|
235
234
|
{...focusAttributes}
|
|
236
235
|
/>
|
|
237
236
|
</StackItem.Content>
|
|
@@ -8,8 +8,8 @@ import { Input, Select, useTranslation } from '@dxos/react-ui';
|
|
|
8
8
|
import { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';
|
|
9
9
|
import { DeprecatedFormContainer, DeprecatedFormInput } from '@dxos/react-ui-form';
|
|
10
10
|
|
|
11
|
-
import { MARKDOWN_PLUGIN } from '
|
|
12
|
-
import { type MarkdownSettingsProps } from '
|
|
11
|
+
import { MARKDOWN_PLUGIN } from '../meta';
|
|
12
|
+
import { type MarkdownSettingsProps } from '../types';
|
|
13
13
|
|
|
14
14
|
export const MarkdownSettings = ({ settings }: { settings: MarkdownSettingsProps }) => {
|
|
15
15
|
const { t } = useTranslation(MARKDOWN_PLUGIN);
|
|
@@ -8,12 +8,11 @@ import { type Meta } from '@storybook/react';
|
|
|
8
8
|
import React, { type FC, useState } from 'react';
|
|
9
9
|
|
|
10
10
|
import { PublicKey } from '@dxos/keys';
|
|
11
|
-
import {
|
|
11
|
+
import { create } from '@dxos/live-object';
|
|
12
12
|
import { faker } from '@dxos/random';
|
|
13
13
|
import { createDocAccessor, createObject } from '@dxos/react-client/echo';
|
|
14
14
|
import { useThemeContext } from '@dxos/react-ui';
|
|
15
15
|
import {
|
|
16
|
-
EditorToolbar,
|
|
17
16
|
type EditorAction,
|
|
18
17
|
type Comment,
|
|
19
18
|
comments,
|
|
@@ -24,6 +23,7 @@ import {
|
|
|
24
23
|
decorateMarkdown,
|
|
25
24
|
editorContent,
|
|
26
25
|
formattingKeymap,
|
|
26
|
+
EditorToolbar,
|
|
27
27
|
translations,
|
|
28
28
|
useActionHandler,
|
|
29
29
|
useComments,
|
|
@@ -36,9 +36,11 @@ import { withLayout, withTheme } from '@dxos/storybook-utils';
|
|
|
36
36
|
|
|
37
37
|
faker.seed(101);
|
|
38
38
|
|
|
39
|
+
const _onUpload = async (file: File) => ({ url: file.name });
|
|
40
|
+
|
|
39
41
|
const DefaultStory: FC<{ content?: string }> = ({ content = '' }) => {
|
|
40
42
|
const { themeMode } = useThemeContext();
|
|
41
|
-
const [text] = useState(createObject(
|
|
43
|
+
const [text] = useState(createObject(create(TextType, { content })));
|
|
42
44
|
const toolbarState = useEditorToolbarState({ viewMode: 'preview' });
|
|
43
45
|
const formattingObserver = useFormattingState(toolbarState);
|
|
44
46
|
const { parentRef, view } = useTextEditor(() => {
|
|
@@ -77,9 +79,9 @@ const DefaultStory: FC<{ content?: string }> = ({ content = '' }) => {
|
|
|
77
79
|
useComments(view, text.id, _comments);
|
|
78
80
|
|
|
79
81
|
return (
|
|
80
|
-
<div role='none' className='flex flex-col'>
|
|
82
|
+
<div role='none' className='fixed inset-0 flex flex-col'>
|
|
81
83
|
<EditorToolbar onAction={handleAction} state={toolbarState ?? {}} />
|
|
82
|
-
<div
|
|
84
|
+
<div ref={parentRef} />
|
|
83
85
|
</div>
|
|
84
86
|
);
|
|
85
87
|
};
|
|
@@ -94,20 +96,18 @@ const content = [
|
|
|
94
96
|
'',
|
|
95
97
|
].join('\n');
|
|
96
98
|
|
|
99
|
+
export const Default = {
|
|
100
|
+
args: {
|
|
101
|
+
content,
|
|
102
|
+
},
|
|
103
|
+
};
|
|
104
|
+
|
|
97
105
|
const meta: Meta<typeof EditorToolbar> = {
|
|
98
106
|
title: 'plugins/plugin-markdown/Toolbar',
|
|
99
107
|
component: EditorToolbar,
|
|
100
108
|
render: DefaultStory as any,
|
|
101
|
-
decorators: [withTheme, withLayout({ tooltips: true
|
|
102
|
-
parameters: {
|
|
103
|
-
translations,
|
|
104
|
-
},
|
|
109
|
+
decorators: [withTheme, withLayout({ tooltips: true })],
|
|
110
|
+
parameters: { translations, layout: 'fullscreen' },
|
|
105
111
|
};
|
|
106
112
|
|
|
107
113
|
export default meta;
|
|
108
|
-
|
|
109
|
-
export const Default = {
|
|
110
|
-
args: {
|
|
111
|
-
content,
|
|
112
|
-
},
|
|
113
|
-
};
|
package/src/components/index.ts
CHANGED