@dxos/plugin-markdown 0.7.4 → 0.7.5-main.499c70c
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-6OPC5MKP.mjs → MarkdownContainer-XY6NEUOA.mjs} +86 -86
- package/dist/lib/browser/MarkdownContainer-XY6NEUOA.mjs.map +7 -0
- package/dist/lib/browser/{chunk-CMSUKMPM.mjs → chunk-6FIHBJRV.mjs} +27 -7
- package/dist/lib/browser/chunk-6FIHBJRV.mjs.map +7 -0
- package/dist/lib/browser/{chunk-TZN5FGB2.mjs → chunk-R4MG2DP2.mjs} +6 -6
- package/dist/lib/browser/chunk-R4MG2DP2.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +88 -174
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/types/index.mjs +1 -1
- package/dist/lib/node/{MarkdownContainer-6OKJOHTZ.cjs → MarkdownContainer-EX6YDF6J.cjs} +78 -78
- package/dist/lib/node/MarkdownContainer-EX6YDF6J.cjs.map +7 -0
- package/dist/lib/node/{chunk-YGMWZIIJ.cjs → chunk-CQMXZ54Z.cjs} +28 -8
- package/dist/lib/node/chunk-CQMXZ54Z.cjs.map +7 -0
- package/dist/lib/node/{chunk-KEPAM4JP.cjs → chunk-SXQAPZZU.cjs} +9 -9
- package/dist/lib/node/chunk-SXQAPZZU.cjs.map +7 -0
- package/dist/lib/node/index.cjs +123 -209
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/types/index.cjs +5 -5
- package/dist/lib/node/types/index.cjs.map +1 -1
- package/dist/lib/node-esm/{MarkdownContainer-GBNSGROQ.mjs → MarkdownContainer-E7W623A7.mjs} +86 -86
- package/dist/lib/node-esm/MarkdownContainer-E7W623A7.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-NUMUUCYF.mjs → chunk-Y76MM22C.mjs} +6 -6
- package/dist/lib/node-esm/chunk-Y76MM22C.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ERJ52KN2.mjs → chunk-ZVFBKBSA.mjs} +27 -7
- package/dist/lib/node-esm/chunk-ZVFBKBSA.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +88 -174
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/types/index.mjs +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts +2 -2
- 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/types/index.d.ts +1 -1
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +82 -0
- package/dist/types/src/types/schema.d.ts.map +1 -0
- package/dist/types/src/types/types.d.ts +31 -12
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -0
- package/package.json +30 -29
- package/src/MarkdownPlugin.tsx +84 -149
- package/src/components/MarkdownContainer.tsx +8 -3
- package/src/components/MarkdownEditor.tsx +5 -13
- package/src/extensions.tsx +9 -10
- package/src/hooks/useSelectCurrentThread.tsx +17 -14
- package/src/types/index.ts +1 -1
- package/src/types/{document.ts → schema.ts} +4 -3
- package/src/types/types.ts +21 -15
- package/src/util.tsx +3 -3
- package/dist/lib/browser/MarkdownContainer-6OPC5MKP.mjs.map +0 -7
- package/dist/lib/browser/chunk-CMSUKMPM.mjs.map +0 -7
- package/dist/lib/browser/chunk-TZN5FGB2.mjs.map +0 -7
- package/dist/lib/node/MarkdownContainer-6OKJOHTZ.cjs.map +0 -7
- package/dist/lib/node/chunk-KEPAM4JP.cjs.map +0 -7
- package/dist/lib/node/chunk-YGMWZIIJ.cjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-GBNSGROQ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ERJ52KN2.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NUMUUCYF.mjs.map +0 -7
- package/dist/types/src/types/document.d.ts +0 -106
- package/dist/types/src/types/document.d.ts.map +0 -1
|
@@ -4,30 +4,28 @@ import {
|
|
|
4
4
|
markdownExtensionPlugins,
|
|
5
5
|
serializer,
|
|
6
6
|
setFallbackName
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-R4MG2DP2.mjs";
|
|
8
8
|
import {
|
|
9
9
|
DocumentType,
|
|
10
10
|
MarkdownAction,
|
|
11
11
|
TextType,
|
|
12
12
|
isEditorModel
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-6FIHBJRV.mjs";
|
|
14
14
|
import {
|
|
15
15
|
MARKDOWN_PLUGIN,
|
|
16
16
|
meta_default
|
|
17
17
|
} from "./chunk-4X6YX3KU.mjs";
|
|
18
18
|
|
|
19
19
|
// packages/plugins/plugin-markdown/src/MarkdownPlugin.tsx
|
|
20
|
-
import {
|
|
20
|
+
import { pipe } from "effect";
|
|
21
21
|
import React2 from "react";
|
|
22
|
-
import { parseIntentPlugin, resolvePlugin,
|
|
23
|
-
import { create } from "@dxos/live-object";
|
|
22
|
+
import { parseIntentPlugin, resolvePlugin, createSurface, createResolver, createIntent, chain } from "@dxos/app-framework";
|
|
23
|
+
import { create, makeRef, RefArray } from "@dxos/live-object";
|
|
24
24
|
import { LocalStorageStore } from "@dxos/local-storage";
|
|
25
|
-
import { parseClientPlugin } from "@dxos/plugin-client";
|
|
26
|
-
import { createExtension, isActionGroup } from "@dxos/plugin-graph";
|
|
27
25
|
import { SpaceAction } from "@dxos/plugin-space";
|
|
28
26
|
import { CollectionType } from "@dxos/plugin-space/types";
|
|
29
|
-
import { createDocAccessor, fullyQualifiedId, getRangeFromCursor, isSpace
|
|
30
|
-
import {
|
|
27
|
+
import { createDocAccessor, fullyQualifiedId, getRangeFromCursor, isSpace } from "@dxos/react-client/echo";
|
|
28
|
+
import { translations as editorTranslations, createEditorStateStore } from "@dxos/react-ui-editor";
|
|
31
29
|
|
|
32
30
|
// packages/plugins/plugin-markdown/src/components/index.ts
|
|
33
31
|
import { lazy } from "react";
|
|
@@ -98,7 +96,7 @@ var MarkdownSettings = ({ settings }) => {
|
|
|
98
96
|
};
|
|
99
97
|
|
|
100
98
|
// packages/plugins/plugin-markdown/src/components/index.ts
|
|
101
|
-
var MarkdownContainer = lazy(() => import("./MarkdownContainer-
|
|
99
|
+
var MarkdownContainer = lazy(() => import("./MarkdownContainer-XY6NEUOA.mjs"));
|
|
102
100
|
|
|
103
101
|
// packages/plugins/plugin-markdown/src/translations.ts
|
|
104
102
|
var translations_default = [
|
|
@@ -136,7 +134,6 @@ var translations_default = [
|
|
|
136
134
|
];
|
|
137
135
|
|
|
138
136
|
// packages/plugins/plugin-markdown/src/MarkdownPlugin.tsx
|
|
139
|
-
var getDoc = (object) => object instanceof DocumentType ? object : void 0;
|
|
140
137
|
var MarkdownPlugin = () => {
|
|
141
138
|
const settings = new LocalStorageStore(MARKDOWN_PLUGIN, {
|
|
142
139
|
defaultViewMode: "preview",
|
|
@@ -154,7 +151,7 @@ var MarkdownPlugin = () => {
|
|
|
154
151
|
const setViewMode = (id, viewMode) => state.values.viewMode[id] = viewMode;
|
|
155
152
|
return {
|
|
156
153
|
meta: meta_default,
|
|
157
|
-
ready: async (plugins) => {
|
|
154
|
+
ready: async ({ plugins }) => {
|
|
158
155
|
settings.prop({
|
|
159
156
|
key: "defaultViewMode",
|
|
160
157
|
type: LocalStorageStore.enum()
|
|
@@ -208,7 +205,7 @@ var MarkdownPlugin = () => {
|
|
|
208
205
|
metadata: {
|
|
209
206
|
records: {
|
|
210
207
|
[DocumentType.typename]: {
|
|
211
|
-
createObject: MarkdownAction.
|
|
208
|
+
createObject: (props) => createIntent(MarkdownAction.Create, props),
|
|
212
209
|
label: (object) => object instanceof DocumentType ? object.name || object.fallbackName : void 0,
|
|
213
210
|
placeholder: [
|
|
214
211
|
"document title placeholder",
|
|
@@ -221,9 +218,9 @@ var MarkdownPlugin = () => {
|
|
|
221
218
|
managesAutofocus: true
|
|
222
219
|
},
|
|
223
220
|
// TODO(wittjosiah): Move out of metadata.
|
|
224
|
-
loadReferences: (doc) =>
|
|
225
|
-
|
|
226
|
-
...
|
|
221
|
+
loadReferences: async (doc) => await RefArray.loadAll([
|
|
222
|
+
doc.content,
|
|
223
|
+
...doc.threads
|
|
227
224
|
]),
|
|
228
225
|
serializer
|
|
229
226
|
}
|
|
@@ -242,61 +239,8 @@ var MarkdownPlugin = () => {
|
|
|
242
239
|
]
|
|
243
240
|
},
|
|
244
241
|
graph: {
|
|
245
|
-
builder: (plugins) => {
|
|
246
|
-
const client = resolvePlugin(plugins, parseClientPlugin)?.provides.client;
|
|
247
|
-
const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;
|
|
248
|
-
if (!client || !dispatch) {
|
|
249
|
-
return [];
|
|
250
|
-
}
|
|
251
|
-
return createExtension({
|
|
252
|
-
id: MarkdownAction.CREATE,
|
|
253
|
-
filter: (node) => isActionGroup(node) && node.id.startsWith(SpaceAction.ADD_OBJECT),
|
|
254
|
-
actions: ({ node }) => {
|
|
255
|
-
const id = node.id.split("/").at(-1);
|
|
256
|
-
const [spaceId, objectId] = id?.split(":") ?? [];
|
|
257
|
-
const space = client.spaces.get().find((space2) => space2.id === spaceId);
|
|
258
|
-
const object = objectId && space?.db.getObjectById(objectId);
|
|
259
|
-
const target = objectId ? object : space;
|
|
260
|
-
if (!target) {
|
|
261
|
-
return;
|
|
262
|
-
}
|
|
263
|
-
return [
|
|
264
|
-
{
|
|
265
|
-
id: `${MARKDOWN_PLUGIN}/create/${node.id}`,
|
|
266
|
-
data: async () => {
|
|
267
|
-
await dispatch([
|
|
268
|
-
{
|
|
269
|
-
plugin: MARKDOWN_PLUGIN,
|
|
270
|
-
action: MarkdownAction.CREATE
|
|
271
|
-
},
|
|
272
|
-
{
|
|
273
|
-
action: SpaceAction.ADD_OBJECT,
|
|
274
|
-
data: {
|
|
275
|
-
target
|
|
276
|
-
}
|
|
277
|
-
},
|
|
278
|
-
{
|
|
279
|
-
action: NavigationAction.OPEN
|
|
280
|
-
}
|
|
281
|
-
]);
|
|
282
|
-
},
|
|
283
|
-
properties: {
|
|
284
|
-
label: [
|
|
285
|
-
"create document label",
|
|
286
|
-
{
|
|
287
|
-
ns: MARKDOWN_PLUGIN
|
|
288
|
-
}
|
|
289
|
-
],
|
|
290
|
-
icon: "ph--text-aa--regular",
|
|
291
|
-
testId: "markdownPlugin.createObject"
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
];
|
|
295
|
-
}
|
|
296
|
-
});
|
|
297
|
-
},
|
|
298
242
|
serializer: (plugins) => {
|
|
299
|
-
const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.
|
|
243
|
+
const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatchPromise;
|
|
300
244
|
if (!dispatch) {
|
|
301
245
|
return [];
|
|
302
246
|
}
|
|
@@ -307,7 +251,7 @@ var MarkdownPlugin = () => {
|
|
|
307
251
|
// Reconcile with metadata serializers.
|
|
308
252
|
serialize: async (node) => {
|
|
309
253
|
const doc = node.data;
|
|
310
|
-
const content = await
|
|
254
|
+
const content = await doc.content.load();
|
|
311
255
|
return {
|
|
312
256
|
name: doc.name || doc.fallbackName || translations_default[0]["en-US"][MARKDOWN_PLUGIN]["document title placeholder"],
|
|
313
257
|
data: content.content,
|
|
@@ -316,61 +260,26 @@ var MarkdownPlugin = () => {
|
|
|
316
260
|
},
|
|
317
261
|
deserialize: async (data, ancestors) => {
|
|
318
262
|
const space = ancestors.find(isSpace);
|
|
319
|
-
const target = ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ?? space?.properties[CollectionType.typename];
|
|
263
|
+
const target = ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ?? space?.properties[CollectionType.typename]?.target;
|
|
320
264
|
if (!space || !target) {
|
|
321
265
|
return;
|
|
322
266
|
}
|
|
323
|
-
const result = await dispatch(
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
}
|
|
331
|
-
},
|
|
332
|
-
{
|
|
333
|
-
action: SpaceAction.ADD_OBJECT,
|
|
334
|
-
data: {
|
|
335
|
-
target
|
|
336
|
-
}
|
|
337
|
-
}
|
|
338
|
-
]);
|
|
339
|
-
return result?.data.object;
|
|
267
|
+
const result = await dispatch(pipe(createIntent(MarkdownAction.Create, {
|
|
268
|
+
name: data.name,
|
|
269
|
+
content: data.data
|
|
270
|
+
}), chain(SpaceAction.AddObject, {
|
|
271
|
+
target
|
|
272
|
+
})));
|
|
273
|
+
return result.data?.object;
|
|
340
274
|
}
|
|
341
275
|
}
|
|
342
276
|
];
|
|
343
277
|
}
|
|
344
278
|
},
|
|
345
|
-
stack: {
|
|
346
|
-
creators: [
|
|
347
|
-
{
|
|
348
|
-
id: "create-stack-section-doc",
|
|
349
|
-
testId: "markdownPlugin.createSection",
|
|
350
|
-
type: [
|
|
351
|
-
"plugin name",
|
|
352
|
-
{
|
|
353
|
-
ns: MARKDOWN_PLUGIN
|
|
354
|
-
}
|
|
355
|
-
],
|
|
356
|
-
label: [
|
|
357
|
-
"create stack section label",
|
|
358
|
-
{
|
|
359
|
-
ns: MARKDOWN_PLUGIN
|
|
360
|
-
}
|
|
361
|
-
],
|
|
362
|
-
icon: (props) => /* @__PURE__ */ React2.createElement(TextAa, props),
|
|
363
|
-
intent: {
|
|
364
|
-
plugin: MARKDOWN_PLUGIN,
|
|
365
|
-
action: MarkdownAction.CREATE
|
|
366
|
-
}
|
|
367
|
-
}
|
|
368
|
-
]
|
|
369
|
-
},
|
|
370
279
|
thread: {
|
|
371
280
|
predicate: (obj) => obj instanceof DocumentType,
|
|
372
281
|
createSort: (doc) => {
|
|
373
|
-
const accessor = doc.content ? createDocAccessor(doc.content, [
|
|
282
|
+
const accessor = doc.content.target ? createDocAccessor(doc.content.target, [
|
|
374
283
|
"content"
|
|
375
284
|
]) : void 0;
|
|
376
285
|
if (!accessor) {
|
|
@@ -391,68 +300,73 @@ var MarkdownPlugin = () => {
|
|
|
391
300
|
}
|
|
392
301
|
},
|
|
393
302
|
surface: {
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
399
|
-
|
|
400
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
408
|
-
|
|
409
|
-
|
|
410
|
-
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
303
|
+
definitions: () => [
|
|
304
|
+
createSurface({
|
|
305
|
+
id: `${MARKDOWN_PLUGIN}/document`,
|
|
306
|
+
role: [
|
|
307
|
+
"article",
|
|
308
|
+
"section"
|
|
309
|
+
],
|
|
310
|
+
filter: (data) => data.subject instanceof DocumentType,
|
|
311
|
+
component: ({ data, role }) => /* @__PURE__ */ React2.createElement(MarkdownContainer, {
|
|
312
|
+
id: fullyQualifiedId(data.subject),
|
|
313
|
+
object: data.subject,
|
|
314
|
+
role,
|
|
315
|
+
settings: settings.values,
|
|
316
|
+
extensionProviders: state.values.extensionProviders,
|
|
317
|
+
viewMode: getViewMode(fullyQualifiedId(data.subject)),
|
|
318
|
+
editorStateStore,
|
|
319
|
+
onViewModeChange: setViewMode
|
|
320
|
+
})
|
|
321
|
+
}),
|
|
322
|
+
createSurface({
|
|
323
|
+
id: `${MARKDOWN_PLUGIN}/editor`,
|
|
324
|
+
role: [
|
|
325
|
+
"article",
|
|
326
|
+
"section"
|
|
327
|
+
],
|
|
328
|
+
filter: (data) => isEditorModel(data.subject),
|
|
329
|
+
component: ({ data, role }) => /* @__PURE__ */ React2.createElement(MarkdownContainer, {
|
|
330
|
+
id: data.subject.id,
|
|
331
|
+
object: data.subject,
|
|
332
|
+
role,
|
|
333
|
+
settings: settings.values,
|
|
334
|
+
extensionProviders: state.values.extensionProviders,
|
|
335
|
+
viewMode: getViewMode(data.subject.id),
|
|
336
|
+
editorStateStore,
|
|
337
|
+
onViewModeChange: setViewMode
|
|
338
|
+
})
|
|
339
|
+
}),
|
|
340
|
+
createSurface({
|
|
341
|
+
id: `${MARKDOWN_PLUGIN}/settings`,
|
|
342
|
+
role: "settings",
|
|
343
|
+
filter: (data) => data.subject === MARKDOWN_PLUGIN,
|
|
344
|
+
component: () => /* @__PURE__ */ React2.createElement(MarkdownSettings, {
|
|
345
|
+
settings: settings.values
|
|
346
|
+
})
|
|
347
|
+
})
|
|
348
|
+
]
|
|
428
349
|
},
|
|
429
350
|
intent: {
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
content:
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
442
|
-
};
|
|
443
|
-
}
|
|
444
|
-
case MarkdownAction.SET_VIEW_MODE: {
|
|
445
|
-
const { id, viewMode } = data ?? {};
|
|
446
|
-
if (typeof id === "string" && EditorViewModes2.includes(viewMode)) {
|
|
447
|
-
state.values.viewMode[id] = viewMode;
|
|
448
|
-
return {
|
|
449
|
-
data: true
|
|
450
|
-
};
|
|
351
|
+
resolvers: () => [
|
|
352
|
+
createResolver(MarkdownAction.Create, ({ name, content }) => {
|
|
353
|
+
const doc = create(DocumentType, {
|
|
354
|
+
name,
|
|
355
|
+
content: makeRef(create(TextType, {
|
|
356
|
+
content: content ?? ""
|
|
357
|
+
})),
|
|
358
|
+
threads: []
|
|
359
|
+
});
|
|
360
|
+
return {
|
|
361
|
+
data: {
|
|
362
|
+
object: doc
|
|
451
363
|
}
|
|
452
|
-
|
|
453
|
-
|
|
454
|
-
}
|
|
455
|
-
|
|
364
|
+
};
|
|
365
|
+
}),
|
|
366
|
+
createResolver(MarkdownAction.SetViewMode, ({ id, viewMode }) => {
|
|
367
|
+
state.values.viewMode[id] = viewMode;
|
|
368
|
+
})
|
|
369
|
+
]
|
|
456
370
|
}
|
|
457
371
|
}
|
|
458
372
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/MarkdownPlugin.tsx", "../../../src/components/index.ts", "../../../src/components/MarkdownSettings.tsx", "../../../src/translations.ts", "../../../src/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { TextAa } from '@phosphor-icons/react';\nimport React from 'react';\n\nimport { parseIntentPlugin, resolvePlugin, NavigationAction, type PluginDefinition } from '@dxos/app-framework';\nimport { create } from '@dxos/live-object';\nimport { LocalStorageStore } from '@dxos/local-storage';\nimport { parseClientPlugin } from '@dxos/plugin-client';\nimport { type ActionGroup, createExtension, isActionGroup } from '@dxos/plugin-graph';\nimport { SpaceAction } from '@dxos/plugin-space';\nimport { CollectionType } from '@dxos/plugin-space/types';\nimport {\n createDocAccessor,\n fullyQualifiedId,\n getRangeFromCursor,\n isSpace,\n loadObjectReferences,\n} from '@dxos/react-client/echo';\nimport {\n type EditorInputMode,\n type EditorViewMode,\n EditorViewModes,\n translations as editorTranslations,\n createEditorStateStore,\n} from '@dxos/react-ui-editor';\n\nimport { MarkdownContainer, MarkdownSettings } from './components';\nimport meta, { MARKDOWN_PLUGIN } from './meta';\nimport translations from './translations';\nimport { DocumentType, isEditorModel, TextType } from './types';\nimport {\n type MarkdownPluginProvides,\n type MarkdownSettingsProps,\n MarkdownAction,\n type MarkdownPluginState,\n} from './types';\nimport { markdownExtensionPlugins, serializer } from './util';\n\n// TODO(burdon): Normalize active/object.\nconst getDoc = (object: any) => (object instanceof DocumentType ? object : undefined);\n\nexport const MarkdownPlugin = (): PluginDefinition<MarkdownPluginProvides> => {\n const settings = new LocalStorageStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN, {\n defaultViewMode: 'preview',\n toolbar: true,\n numberedHeadings: true,\n folding: true,\n experimental: false,\n });\n\n const editorStateStore = createEditorStateStore(`${MARKDOWN_PLUGIN}/editor`);\n\n const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });\n\n const getViewMode = (id: string) => (id && state.values.viewMode[id]) || settings.values.defaultViewMode;\n const setViewMode = (id: string, viewMode: EditorViewMode) => (state.values.viewMode[id] = viewMode);\n\n return {\n meta,\n ready: async (plugins) => {\n settings\n .prop({ key: 'defaultViewMode', type: LocalStorageStore.enum<EditorViewMode>() })\n .prop({ key: 'editorInputMode', type: LocalStorageStore.enum<EditorInputMode>({ allowUndefined: true }) })\n .prop({ key: 'toolbar', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'experimental', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'debug', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'typewriter', type: LocalStorageStore.string({ allowUndefined: true }) })\n .prop({ key: 'numberedHeadings', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'folding', type: LocalStorageStore.bool({ allowUndefined: true }) });\n\n state.prop({ key: 'viewMode', type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>() });\n\n markdownExtensionPlugins(plugins).forEach((plugin) => {\n const { extensions } = plugin.provides.markdown;\n state.values.extensionProviders?.push(extensions);\n });\n },\n provides: {\n settings: settings.values,\n metadata: {\n records: {\n [DocumentType.typename]: {\n createObject: MarkdownAction.CREATE,\n label: (object: any) => (object instanceof DocumentType ? object.name || object.fallbackName : undefined),\n placeholder: ['document title placeholder', { ns: MARKDOWN_PLUGIN }],\n icon: 'ph--text-aa--regular',\n graphProps: {\n managesAutofocus: true,\n },\n // TODO(wittjosiah): Move out of metadata.\n loadReferences: (doc: DocumentType) => loadObjectReferences(doc, (doc) => [doc.content, ...doc.threads]),\n serializer,\n },\n },\n },\n translations: [...translations, ...editorTranslations],\n echo: {\n schema: [DocumentType],\n system: [TextType],\n },\n graph: {\n builder: (plugins) => {\n const client = resolvePlugin(plugins, parseClientPlugin)?.provides.client;\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;\n if (!client || !dispatch) {\n return [];\n }\n\n return createExtension({\n id: MarkdownAction.CREATE,\n filter: (node): node is ActionGroup => isActionGroup(node) && node.id.startsWith(SpaceAction.ADD_OBJECT),\n actions: ({ node }) => {\n const id = node.id.split('/').at(-1);\n const [spaceId, objectId] = id?.split(':') ?? [];\n const space = client.spaces.get().find((space) => space.id === spaceId);\n const object = objectId && space?.db.getObjectById(objectId);\n const target = objectId ? object : space;\n if (!target) {\n return;\n }\n\n return [\n {\n id: `${MARKDOWN_PLUGIN}/create/${node.id}`,\n data: async () => {\n await dispatch([\n { plugin: MARKDOWN_PLUGIN, action: MarkdownAction.CREATE },\n { action: SpaceAction.ADD_OBJECT, data: { target } },\n { action: NavigationAction.OPEN },\n ]);\n },\n properties: {\n label: ['create document label', { ns: MARKDOWN_PLUGIN }],\n icon: 'ph--text-aa--regular',\n testId: 'markdownPlugin.createObject',\n },\n },\n ];\n },\n });\n },\n serializer: (plugins) => {\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;\n if (!dispatch) {\n return [];\n }\n\n return [\n {\n inputType: DocumentType.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await loadObjectReferences(doc, (doc) => doc.content);\n return {\n name:\n doc.name ||\n doc.fallbackName ||\n translations[0]['en-US'][MARKDOWN_PLUGIN]['document title placeholder'],\n data: content.content,\n type: 'text/markdown',\n };\n },\n deserialize: async (data, ancestors) => {\n const space = ancestors.find(isSpace);\n const target =\n ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ??\n space?.properties[CollectionType.typename];\n if (!space || !target) {\n return;\n }\n\n const result = await dispatch([\n {\n plugin: MARKDOWN_PLUGIN,\n action: MarkdownAction.CREATE,\n data: { name: data.name, content: data.data },\n },\n {\n action: SpaceAction.ADD_OBJECT,\n data: { target },\n },\n ]);\n\n return result?.data.object;\n },\n },\n ];\n },\n },\n stack: {\n creators: [\n {\n id: 'create-stack-section-doc',\n testId: 'markdownPlugin.createSection',\n type: ['plugin name', { ns: MARKDOWN_PLUGIN }],\n label: ['create stack section label', { ns: MARKDOWN_PLUGIN }],\n icon: (props: any) => <TextAa {...props} />,\n intent: {\n plugin: MARKDOWN_PLUGIN,\n action: MarkdownAction.CREATE,\n },\n },\n ],\n },\n thread: {\n predicate: (obj) => obj instanceof DocumentType,\n createSort: (doc: DocumentType) => {\n const accessor = doc.content ? createDocAccessor(doc.content, ['content']) : undefined;\n if (!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 return (anchorA: string | undefined, anchorB: string | undefined): number => {\n if (anchorA === undefined || anchorB === undefined) {\n return 0;\n }\n const posA = getStartPosition(anchorA);\n const posB = getStartPosition(anchorB);\n return posA - posB;\n };\n },\n },\n surface: {\n component: ({ data, role }) => {\n switch (role) {\n case 'section':\n case 'article': {\n const doc = getDoc(data.object);\n const { id, object } = isEditorModel(data.object)\n ? { id: data.object.id, object: data.object }\n : doc\n ? { id: fullyQualifiedId(doc), object: doc }\n : {};\n\n if (!id || !object) {\n return null;\n }\n\n return (\n <MarkdownContainer\n id={id}\n object={object}\n role={role}\n settings={settings.values}\n extensionProviders={state.values.extensionProviders}\n viewMode={getViewMode(id)}\n editorStateStore={editorStateStore}\n onViewModeChange={setViewMode}\n />\n );\n }\n\n case 'settings': {\n return data.plugin === meta.id ? <MarkdownSettings settings={settings.values} /> : null;\n }\n }\n\n return null;\n },\n },\n intent: {\n resolver: ({ action, data }) => {\n switch (action) {\n case MarkdownAction.CREATE: {\n const doc = create(DocumentType, {\n name: data?.name,\n content: create(TextType, { content: data?.content ?? '' }),\n threads: [],\n });\n\n return { data: doc };\n }\n\n case MarkdownAction.SET_VIEW_MODE: {\n const { id, viewMode } = data ?? {};\n if (typeof id === 'string' && EditorViewModes.includes(viewMode)) {\n state.values.viewMode[id] = viewMode;\n return { data: true };\n }\n\n break;\n }\n }\n },\n },\n },\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './MarkdownSettings';\n\nexport const MarkdownContainer = lazy(() => import('./MarkdownContainer'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';\nimport { DeprecatedFormInput } from '@dxos/react-ui-form';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { type MarkdownSettingsProps } from '../types';\n\nexport const MarkdownSettings = ({ settings }: { settings: MarkdownSettingsProps }) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <>\n <DeprecatedFormInput label={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n settings.defaultViewMode = value as EditorViewMode;\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: 'react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n settings.editorInputMode = value as EditorInputMode;\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings toolbar label')}>\n <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings folding label')}>\n <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => (settings.experimental = !!checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput\n label={t('settings debug label')}\n secondary={\n settings.debug ? (\n <Input.Root>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => (settings.typewriter = value)}\n placeholder={t('settings debug placeholder')}\n />\n </Input.Root>\n ) : undefined\n }\n >\n <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />\n </DeprecatedFormInput>\n </>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MARKDOWN_PLUGIN } from './meta';\nimport { DocumentType } from './types';\n\nexport default [\n {\n 'en-US': {\n [DocumentType.typename]: {\n 'typename label': 'Document',\n },\n [MARKDOWN_PLUGIN]: {\n 'plugin name': 'Editor',\n 'create stack section label': 'Create document',\n 'document title placeholder': 'New document',\n 'choose markdown from space dialog title': 'Choose one or more documents to add',\n // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)\n 'empty choose markdown from space message': 'None available; try creating a new one instead?',\n 'chooser done label': 'Add selected',\n 'create document label': 'Create document',\n 'editor placeholder': '',\n 'editor input mode label': 'Editor input mode',\n 'select editor input mode placeholder': 'Select editor input mode…',\n 'settings editor input mode default label': 'Default',\n 'settings editor input mode vim label': 'Vim',\n 'settings editor input mode vscode label': 'VS Code',\n 'settings toolbar label': 'Show toolbar',\n 'settings numbered headings label': 'Numbered headings',\n 'settings folding label': 'Folding',\n 'settings experimental label': 'Enable experimental features',\n 'settings debug label': 'Enable debugging features',\n 'settings debug placeholder': 'Typewriter script...',\n 'toggle view mode label': 'Toggle read-only',\n 'default view mode label': 'Default view mode',\n },\n },\n },\n];\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MarkdownPlugin } from './MarkdownPlugin';\n\nexport default MarkdownPlugin;\n\nexport * from './MarkdownPlugin';\nexport * from './types';\nexport * from './util';\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;AAIA,SAASA,
|
|
6
|
-
"names": ["
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { pipe } from 'effect';\nimport React from 'react';\n\nimport {\n parseIntentPlugin,\n resolvePlugin,\n type PluginDefinition,\n createSurface,\n createResolver,\n createIntent,\n chain,\n} from '@dxos/app-framework';\nimport type { BaseObject } from '@dxos/echo-schema';\nimport { create, makeRef, RefArray } from '@dxos/live-object';\nimport { LocalStorageStore } from '@dxos/local-storage';\nimport { SpaceAction } from '@dxos/plugin-space';\nimport { CollectionType } from '@dxos/plugin-space/types';\nimport { createDocAccessor, fullyQualifiedId, getRangeFromCursor, isSpace } from '@dxos/react-client/echo';\nimport {\n type EditorInputMode,\n type EditorViewMode,\n translations as editorTranslations,\n createEditorStateStore,\n} from '@dxos/react-ui-editor';\n\nimport { MarkdownContainer, MarkdownSettings } from './components';\nimport meta, { MARKDOWN_PLUGIN } from './meta';\nimport translations from './translations';\nimport { DocumentType, isEditorModel, TextType } from './types';\nimport {\n type MarkdownPluginProvides,\n type MarkdownSettingsProps,\n MarkdownAction,\n type MarkdownPluginState,\n} from './types';\nimport { markdownExtensionPlugins, serializer } from './util';\n\nexport const MarkdownPlugin = (): PluginDefinition<MarkdownPluginProvides> => {\n const settings = new LocalStorageStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN, {\n defaultViewMode: 'preview',\n toolbar: true,\n numberedHeadings: true,\n folding: true,\n experimental: false,\n });\n\n const editorStateStore = createEditorStateStore(`${MARKDOWN_PLUGIN}/editor`);\n\n const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });\n\n const getViewMode = (id: string) => (id && state.values.viewMode[id]) || settings.values.defaultViewMode;\n const setViewMode = (id: string, viewMode: EditorViewMode) => (state.values.viewMode[id] = viewMode);\n\n return {\n meta,\n ready: async ({ plugins }) => {\n settings\n .prop({ key: 'defaultViewMode', type: LocalStorageStore.enum<EditorViewMode>() })\n .prop({ key: 'editorInputMode', type: LocalStorageStore.enum<EditorInputMode>({ allowUndefined: true }) })\n .prop({ key: 'toolbar', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'experimental', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'debug', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'typewriter', type: LocalStorageStore.string({ allowUndefined: true }) })\n .prop({ key: 'numberedHeadings', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'folding', type: LocalStorageStore.bool({ allowUndefined: true }) });\n\n state.prop({ key: 'viewMode', type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>() });\n\n markdownExtensionPlugins(plugins).forEach((plugin) => {\n const { extensions } = plugin.provides.markdown;\n state.values.extensionProviders?.push(extensions);\n });\n },\n provides: {\n settings: settings.values,\n metadata: {\n records: {\n [DocumentType.typename]: {\n createObject: (props: { name?: string }) => createIntent(MarkdownAction.Create, props),\n label: (object: any) => (object instanceof DocumentType ? object.name || object.fallbackName : undefined),\n placeholder: ['document title placeholder', { ns: MARKDOWN_PLUGIN }],\n icon: 'ph--text-aa--regular',\n graphProps: {\n managesAutofocus: true,\n },\n // TODO(wittjosiah): Move out of metadata.\n loadReferences: async (doc: DocumentType) =>\n await RefArray.loadAll<BaseObject>([doc.content, ...doc.threads]),\n serializer,\n },\n },\n },\n translations: [...translations, ...editorTranslations],\n echo: {\n schema: [DocumentType],\n system: [TextType],\n },\n graph: {\n serializer: (plugins) => {\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatchPromise;\n if (!dispatch) {\n return [];\n }\n\n return [\n {\n inputType: DocumentType.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await doc.content.load();\n return {\n name:\n doc.name ||\n doc.fallbackName ||\n translations[0]['en-US'][MARKDOWN_PLUGIN]['document title placeholder'],\n data: content.content,\n type: 'text/markdown',\n };\n },\n deserialize: async (data, ancestors) => {\n const space = ancestors.find(isSpace);\n const target =\n ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ??\n space?.properties[CollectionType.typename]?.target;\n if (!space || !target) {\n return;\n }\n\n const result = await dispatch(\n pipe(\n createIntent(MarkdownAction.Create, { name: data.name, content: data.data }),\n chain(SpaceAction.AddObject, { target }),\n ),\n );\n\n return result.data?.object;\n },\n },\n ];\n },\n },\n thread: {\n predicate: (obj) => obj instanceof DocumentType,\n createSort: (doc: DocumentType) => {\n const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;\n if (!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 return (anchorA: string | undefined, anchorB: string | undefined): number => {\n if (anchorA === undefined || anchorB === undefined) {\n return 0;\n }\n const posA = getStartPosition(anchorA);\n const posB = getStartPosition(anchorB);\n return posA - posB;\n };\n },\n },\n surface: {\n definitions: () => [\n createSurface({\n id: `${MARKDOWN_PLUGIN}/document`,\n role: ['article', 'section'],\n filter: (data): data is { subject: DocumentType } => data.subject instanceof DocumentType,\n component: ({ data, role }) => (\n <MarkdownContainer\n id={fullyQualifiedId(data.subject)}\n object={data.subject}\n role={role}\n settings={settings.values}\n extensionProviders={state.values.extensionProviders}\n viewMode={getViewMode(fullyQualifiedId(data.subject))}\n editorStateStore={editorStateStore}\n onViewModeChange={setViewMode}\n />\n ),\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/editor`,\n role: ['article', 'section'],\n filter: (data): data is { subject: { id: string; text: string } } => isEditorModel(data.subject),\n component: ({ data, role }) => (\n <MarkdownContainer\n id={data.subject.id}\n object={data.subject}\n role={role}\n settings={settings.values}\n extensionProviders={state.values.extensionProviders}\n viewMode={getViewMode(data.subject.id)}\n editorStateStore={editorStateStore}\n onViewModeChange={setViewMode}\n />\n ),\n }),\n createSurface({\n id: `${MARKDOWN_PLUGIN}/settings`,\n role: 'settings',\n filter: (data): data is any => data.subject === MARKDOWN_PLUGIN,\n component: () => <MarkdownSettings settings={settings.values} />,\n }),\n ],\n },\n intent: {\n resolvers: () => [\n createResolver(MarkdownAction.Create, ({ name, content }) => {\n const doc = create(DocumentType, {\n name,\n content: makeRef(create(TextType, { content: content ?? '' })),\n threads: [],\n });\n\n return { data: { object: doc } };\n }),\n createResolver(MarkdownAction.SetViewMode, ({ id, viewMode }) => {\n state.values.viewMode[id] = viewMode;\n }),\n ],\n },\n },\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './MarkdownSettings';\n\nexport const MarkdownContainer = lazy(() => import('./MarkdownContainer'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';\nimport { DeprecatedFormInput } from '@dxos/react-ui-form';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { type MarkdownSettingsProps } from '../types';\n\nexport const MarkdownSettings = ({ settings }: { settings: MarkdownSettingsProps }) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <>\n <DeprecatedFormInput label={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n settings.defaultViewMode = value as EditorViewMode;\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: 'react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n settings.editorInputMode = value as EditorInputMode;\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings toolbar label')}>\n <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings folding label')}>\n <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput label={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => (settings.experimental = !!checked)}\n />\n </DeprecatedFormInput>\n\n <DeprecatedFormInput\n label={t('settings debug label')}\n secondary={\n settings.debug ? (\n <Input.Root>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => (settings.typewriter = value)}\n placeholder={t('settings debug placeholder')}\n />\n </Input.Root>\n ) : undefined\n }\n >\n <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />\n </DeprecatedFormInput>\n </>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MARKDOWN_PLUGIN } from './meta';\nimport { DocumentType } from './types';\n\nexport default [\n {\n 'en-US': {\n [DocumentType.typename]: {\n 'typename label': 'Document',\n },\n [MARKDOWN_PLUGIN]: {\n 'plugin name': 'Editor',\n 'create stack section label': 'Create document',\n 'document title placeholder': 'New document',\n 'choose markdown from space dialog title': 'Choose one or more documents to add',\n // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)\n 'empty choose markdown from space message': 'None available; try creating a new one instead?',\n 'chooser done label': 'Add selected',\n 'create document label': 'Create document',\n 'editor placeholder': '',\n 'editor input mode label': 'Editor input mode',\n 'select editor input mode placeholder': 'Select editor input mode…',\n 'settings editor input mode default label': 'Default',\n 'settings editor input mode vim label': 'Vim',\n 'settings editor input mode vscode label': 'VS Code',\n 'settings toolbar label': 'Show toolbar',\n 'settings numbered headings label': 'Numbered headings',\n 'settings folding label': 'Folding',\n 'settings experimental label': 'Enable experimental features',\n 'settings debug label': 'Enable debugging features',\n 'settings debug placeholder': 'Typewriter script...',\n 'toggle view mode label': 'Toggle read-only',\n 'default view mode label': 'Default view mode',\n },\n },\n },\n];\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MarkdownPlugin } from './MarkdownPlugin';\n\nexport default MarkdownPlugin;\n\nexport * from './MarkdownPlugin';\nexport * from './types';\nexport * from './util';\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["pipe", "React", "parseIntentPlugin", "resolvePlugin", "createSurface", "createResolver", "createIntent", "chain", "create", "makeRef", "RefArray", "LocalStorageStore", "SpaceAction", "CollectionType", "createDocAccessor", "fullyQualifiedId", "getRangeFromCursor", "isSpace", "translations", "editorTranslations", "createEditorStateStore", "lazy", "React", "Input", "Select", "useTranslation", "EditorInputModes", "EditorViewModes", "DeprecatedFormInput", "MarkdownSettings", "settings", "t", "useTranslation", "MARKDOWN_PLUGIN", "DeprecatedFormInput", "label", "Select", "Root", "value", "defaultViewMode", "onValueChange", "TriggerButton", "Portal", "Content", "Viewport", "EditorViewModes", "map", "mode", "Option", "key", "ns", "editorInputMode", "placeholder", "EditorInputModes", "Input", "Switch", "checked", "toolbar", "onCheckedChange", "numberedHeadings", "folding", "experimental", "secondary", "debug", "TextArea", "rows", "typewriter", "onChange", "target", "undefined", "MarkdownContainer", "lazy", "DocumentType", "typename", "MARKDOWN_PLUGIN", "MarkdownPlugin", "settings", "LocalStorageStore", "MARKDOWN_PLUGIN", "defaultViewMode", "toolbar", "numberedHeadings", "folding", "experimental", "editorStateStore", "createEditorStateStore", "state", "extensionProviders", "viewMode", "getViewMode", "id", "values", "setViewMode", "meta", "ready", "plugins", "prop", "key", "type", "enum", "allowUndefined", "bool", "string", "json", "markdownExtensionPlugins", "forEach", "plugin", "extensions", "provides", "markdown", "push", "metadata", "records", "DocumentType", "typename", "createObject", "props", "createIntent", "MarkdownAction", "Create", "label", "object", "name", "fallbackName", "undefined", "placeholder", "ns", "icon", "graphProps", "managesAutofocus", "loadReferences", "doc", "RefArray", "loadAll", "content", "threads", "serializer", "translations", "editorTranslations", "echo", "schema", "system", "TextType", "graph", "dispatch", "resolvePlugin", "parseIntentPlugin", "intent", "dispatchPromise", "inputType", "outputType", "serialize", "node", "data", "load", "deserialize", "ancestors", "space", "find", "isSpace", "target", "findLast", "ancestor", "CollectionType", "properties", "result", "pipe", "chain", "SpaceAction", "AddObject", "thread", "predicate", "obj", "createSort", "accessor", "createDocAccessor", "_", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "anchorA", "anchorB", "posA", "posB", "surface", "definitions", "createSurface", "role", "filter", "subject", "component", "React", "MarkdownContainer", "fullyQualifiedId", "onViewModeChange", "isEditorModel", "MarkdownSettings", "resolvers", "createResolver", "create", "makeRef", "SetViewMode", "MarkdownPlugin"]
|
|
7
7
|
}
|