@dxos/plugin-markdown 0.7.4-staging.f7e8224 → 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.
Files changed (65) hide show
  1. package/dist/lib/browser/{MarkdownContainer-6OPC5MKP.mjs → MarkdownContainer-XY6NEUOA.mjs} +86 -86
  2. package/dist/lib/browser/MarkdownContainer-XY6NEUOA.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-CMSUKMPM.mjs → chunk-6FIHBJRV.mjs} +27 -7
  4. package/dist/lib/browser/chunk-6FIHBJRV.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-TZN5FGB2.mjs → chunk-R4MG2DP2.mjs} +6 -6
  6. package/dist/lib/browser/chunk-R4MG2DP2.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +88 -174
  8. package/dist/lib/browser/index.mjs.map +3 -3
  9. package/dist/lib/browser/meta.json +1 -1
  10. package/dist/lib/browser/types/index.mjs +1 -1
  11. package/dist/lib/node/{MarkdownContainer-6OKJOHTZ.cjs → MarkdownContainer-EX6YDF6J.cjs} +78 -78
  12. package/dist/lib/node/MarkdownContainer-EX6YDF6J.cjs.map +7 -0
  13. package/dist/lib/node/{chunk-YGMWZIIJ.cjs → chunk-CQMXZ54Z.cjs} +28 -8
  14. package/dist/lib/node/chunk-CQMXZ54Z.cjs.map +7 -0
  15. package/dist/lib/node/{chunk-KEPAM4JP.cjs → chunk-SXQAPZZU.cjs} +9 -9
  16. package/dist/lib/node/chunk-SXQAPZZU.cjs.map +7 -0
  17. package/dist/lib/node/index.cjs +123 -209
  18. package/dist/lib/node/index.cjs.map +3 -3
  19. package/dist/lib/node/meta.json +1 -1
  20. package/dist/lib/node/types/index.cjs +5 -5
  21. package/dist/lib/node/types/index.cjs.map +1 -1
  22. package/dist/lib/node-esm/{MarkdownContainer-GBNSGROQ.mjs → MarkdownContainer-E7W623A7.mjs} +86 -86
  23. package/dist/lib/node-esm/MarkdownContainer-E7W623A7.mjs.map +7 -0
  24. package/dist/lib/node-esm/{chunk-NUMUUCYF.mjs → chunk-Y76MM22C.mjs} +6 -6
  25. package/dist/lib/node-esm/chunk-Y76MM22C.mjs.map +7 -0
  26. package/dist/lib/node-esm/{chunk-ERJ52KN2.mjs → chunk-ZVFBKBSA.mjs} +27 -7
  27. package/dist/lib/node-esm/chunk-ZVFBKBSA.mjs.map +7 -0
  28. package/dist/lib/node-esm/index.mjs +88 -174
  29. package/dist/lib/node-esm/index.mjs.map +3 -3
  30. package/dist/lib/node-esm/meta.json +1 -1
  31. package/dist/lib/node-esm/types/index.mjs +1 -1
  32. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  33. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  34. package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
  35. package/dist/types/src/extensions.d.ts +2 -2
  36. package/dist/types/src/extensions.d.ts.map +1 -1
  37. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  38. package/dist/types/src/types/index.d.ts +1 -1
  39. package/dist/types/src/types/index.d.ts.map +1 -1
  40. package/dist/types/src/types/schema.d.ts +82 -0
  41. package/dist/types/src/types/schema.d.ts.map +1 -0
  42. package/dist/types/src/types/types.d.ts +31 -12
  43. package/dist/types/src/types/types.d.ts.map +1 -1
  44. package/dist/types/tsconfig.tsbuildinfo +1 -0
  45. package/package.json +30 -29
  46. package/src/MarkdownPlugin.tsx +84 -149
  47. package/src/components/MarkdownContainer.tsx +8 -3
  48. package/src/components/MarkdownEditor.tsx +5 -13
  49. package/src/extensions.tsx +9 -10
  50. package/src/hooks/useSelectCurrentThread.tsx +17 -14
  51. package/src/types/index.ts +1 -1
  52. package/src/types/{document.ts → schema.ts} +4 -3
  53. package/src/types/types.ts +21 -15
  54. package/src/util.tsx +3 -3
  55. package/dist/lib/browser/MarkdownContainer-6OPC5MKP.mjs.map +0 -7
  56. package/dist/lib/browser/chunk-CMSUKMPM.mjs.map +0 -7
  57. package/dist/lib/browser/chunk-TZN5FGB2.mjs.map +0 -7
  58. package/dist/lib/node/MarkdownContainer-6OKJOHTZ.cjs.map +0 -7
  59. package/dist/lib/node/chunk-KEPAM4JP.cjs.map +0 -7
  60. package/dist/lib/node/chunk-YGMWZIIJ.cjs.map +0 -7
  61. package/dist/lib/node-esm/MarkdownContainer-GBNSGROQ.mjs.map +0 -7
  62. package/dist/lib/node-esm/chunk-ERJ52KN2.mjs.map +0 -7
  63. package/dist/lib/node-esm/chunk-NUMUUCYF.mjs.map +0 -7
  64. package/dist/types/src/types/document.d.ts +0 -106
  65. 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-TZN5FGB2.mjs";
7
+ } from "./chunk-R4MG2DP2.mjs";
8
8
  import {
9
9
  DocumentType,
10
10
  MarkdownAction,
11
11
  TextType,
12
12
  isEditorModel
13
- } from "./chunk-CMSUKMPM.mjs";
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 { TextAa } from "@phosphor-icons/react";
20
+ import { pipe } from "effect";
21
21
  import React2 from "react";
22
- import { parseIntentPlugin, resolvePlugin, NavigationAction } from "@dxos/app-framework";
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, loadObjectReferences } from "@dxos/react-client/echo";
30
- import { EditorViewModes as EditorViewModes2, translations as editorTranslations, createEditorStateStore } from "@dxos/react-ui-editor";
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-6OPC5MKP.mjs"));
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.CREATE,
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) => loadObjectReferences(doc, (doc2) => [
225
- doc2.content,
226
- ...doc2.threads
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.dispatch;
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 loadObjectReferences(doc, (doc2) => doc2.content);
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
- plugin: MARKDOWN_PLUGIN,
326
- action: MarkdownAction.CREATE,
327
- data: {
328
- name: data.name,
329
- content: data.data
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
- component: ({ data, role }) => {
395
- switch (role) {
396
- case "section":
397
- case "article": {
398
- const doc = getDoc(data.object);
399
- const { id, object } = isEditorModel(data.object) ? {
400
- id: data.object.id,
401
- object: data.object
402
- } : doc ? {
403
- id: fullyQualifiedId(doc),
404
- object: doc
405
- } : {};
406
- if (!id || !object) {
407
- return null;
408
- }
409
- return /* @__PURE__ */ React2.createElement(MarkdownContainer, {
410
- id,
411
- object,
412
- role,
413
- settings: settings.values,
414
- extensionProviders: state.values.extensionProviders,
415
- viewMode: getViewMode(id),
416
- editorStateStore,
417
- onViewModeChange: setViewMode
418
- });
419
- }
420
- case "settings": {
421
- return data.plugin === meta_default.id ? /* @__PURE__ */ React2.createElement(MarkdownSettings, {
422
- settings: settings.values
423
- }) : null;
424
- }
425
- }
426
- return null;
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
- resolver: ({ action, data }) => {
431
- switch (action) {
432
- case MarkdownAction.CREATE: {
433
- const doc = create(DocumentType, {
434
- name: data?.name,
435
- content: create(TextType, {
436
- content: data?.content ?? ""
437
- }),
438
- threads: []
439
- });
440
- return {
441
- data: doc
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
- break;
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": "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",
6
- "names": ["TextAa", "React", "parseIntentPlugin", "resolvePlugin", "NavigationAction", "create", "LocalStorageStore", "parseClientPlugin", "createExtension", "isActionGroup", "SpaceAction", "CollectionType", "createDocAccessor", "fullyQualifiedId", "getRangeFromCursor", "isSpace", "loadObjectReferences", "EditorViewModes", "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", "getDoc", "object", "DocumentType", "undefined", "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", "typename", "createObject", "MarkdownAction", "CREATE", "label", "name", "fallbackName", "placeholder", "ns", "icon", "graphProps", "managesAutofocus", "loadReferences", "doc", "loadObjectReferences", "content", "threads", "serializer", "translations", "editorTranslations", "echo", "schema", "system", "TextType", "graph", "builder", "client", "resolvePlugin", "parseClientPlugin", "dispatch", "parseIntentPlugin", "intent", "createExtension", "filter", "node", "isActionGroup", "startsWith", "SpaceAction", "ADD_OBJECT", "actions", "split", "at", "spaceId", "objectId", "space", "spaces", "get", "find", "db", "getObjectById", "target", "data", "action", "NavigationAction", "OPEN", "properties", "testId", "inputType", "outputType", "serialize", "deserialize", "ancestors", "isSpace", "findLast", "ancestor", "CollectionType", "result", "stack", "creators", "props", "React", "TextAa", "thread", "predicate", "obj", "createSort", "accessor", "createDocAccessor", "_", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "anchorA", "anchorB", "posA", "posB", "surface", "component", "role", "isEditorModel", "fullyQualifiedId", "MarkdownContainer", "onViewModeChange", "MarkdownSettings", "resolver", "create", "SET_VIEW_MODE", "EditorViewModes", "includes", "MarkdownPlugin"]
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
  }