@dxos/plugin-markdown 0.6.8-main.046e6cf

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 (107) hide show
  1. package/LICENSE +8 -0
  2. package/README.md +15 -0
  3. package/dist/lib/browser/DocumentCard-CDWDPILF.mjs +11 -0
  4. package/dist/lib/browser/DocumentCard-CDWDPILF.mjs.map +7 -0
  5. package/dist/lib/browser/DocumentEditor-VMHFHWOQ.mjs +11 -0
  6. package/dist/lib/browser/DocumentEditor-VMHFHWOQ.mjs.map +7 -0
  7. package/dist/lib/browser/MarkdownEditor-KYUQ45PC.mjs +10 -0
  8. package/dist/lib/browser/MarkdownEditor-KYUQ45PC.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-4GGD6YJO.mjs +19 -0
  10. package/dist/lib/browser/chunk-4GGD6YJO.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-6ZL2GJCQ.mjs +177 -0
  12. package/dist/lib/browser/chunk-6ZL2GJCQ.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-DX3K37SM.mjs +86 -0
  14. package/dist/lib/browser/chunk-DX3K37SM.mjs.map +7 -0
  15. package/dist/lib/browser/chunk-MDX3MAMP.mjs +119 -0
  16. package/dist/lib/browser/chunk-MDX3MAMP.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-PZDW7KVZ.mjs +172 -0
  18. package/dist/lib/browser/chunk-PZDW7KVZ.mjs.map +7 -0
  19. package/dist/lib/browser/chunk-RETREORA.mjs +39 -0
  20. package/dist/lib/browser/chunk-RETREORA.mjs.map +7 -0
  21. package/dist/lib/browser/index.mjs +506 -0
  22. package/dist/lib/browser/index.mjs.map +7 -0
  23. package/dist/lib/browser/meta.json +1 -0
  24. package/dist/lib/browser/meta.mjs +9 -0
  25. package/dist/lib/browser/meta.mjs.map +7 -0
  26. package/dist/lib/browser/types/index.mjs +12 -0
  27. package/dist/lib/browser/types/index.mjs.map +7 -0
  28. package/dist/lib/node/DocumentCard-SOTFILJY.cjs +32 -0
  29. package/dist/lib/node/DocumentCard-SOTFILJY.cjs.map +7 -0
  30. package/dist/lib/node/DocumentEditor-CUKHGS5R.cjs +29 -0
  31. package/dist/lib/node/DocumentEditor-CUKHGS5R.cjs.map +7 -0
  32. package/dist/lib/node/MarkdownEditor-GGFCD26C.cjs +31 -0
  33. package/dist/lib/node/MarkdownEditor-GGFCD26C.cjs.map +7 -0
  34. package/dist/lib/node/chunk-FW5O2I25.cjs +114 -0
  35. package/dist/lib/node/chunk-FW5O2I25.cjs.map +7 -0
  36. package/dist/lib/node/chunk-IUQ2SKGY.cjs +202 -0
  37. package/dist/lib/node/chunk-IUQ2SKGY.cjs.map +7 -0
  38. package/dist/lib/node/chunk-TGMR2CKU.cjs +52 -0
  39. package/dist/lib/node/chunk-TGMR2CKU.cjs.map +7 -0
  40. package/dist/lib/node/chunk-TO3FCKT7.cjs +202 -0
  41. package/dist/lib/node/chunk-TO3FCKT7.cjs.map +7 -0
  42. package/dist/lib/node/chunk-TZDYK4MV.cjs +151 -0
  43. package/dist/lib/node/chunk-TZDYK4MV.cjs.map +7 -0
  44. package/dist/lib/node/chunk-VYLYUDDI.cjs +58 -0
  45. package/dist/lib/node/chunk-VYLYUDDI.cjs.map +7 -0
  46. package/dist/lib/node/index.cjs +517 -0
  47. package/dist/lib/node/index.cjs.map +7 -0
  48. package/dist/lib/node/meta.cjs +30 -0
  49. package/dist/lib/node/meta.cjs.map +7 -0
  50. package/dist/lib/node/meta.json +1 -0
  51. package/dist/lib/node/types/index.cjs +34 -0
  52. package/dist/lib/node/types/index.cjs.map +7 -0
  53. package/dist/types/src/MarkdownPlugin.d.ts +4 -0
  54. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -0
  55. package/dist/types/src/components/DocumentCard.d.ts +16 -0
  56. package/dist/types/src/components/DocumentCard.d.ts.map +1 -0
  57. package/dist/types/src/components/DocumentEditor.d.ts +14 -0
  58. package/dist/types/src/components/DocumentEditor.d.ts.map +1 -0
  59. package/dist/types/src/components/HeadingMenu.d.ts +13 -0
  60. package/dist/types/src/components/HeadingMenu.d.ts.map +1 -0
  61. package/dist/types/src/components/Layout.d.ts +6 -0
  62. package/dist/types/src/components/Layout.d.ts.map +1 -0
  63. package/dist/types/src/components/MarkdownEditor.d.ts +19 -0
  64. package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -0
  65. package/dist/types/src/components/MarkdownEditor.stories.d.ts +27 -0
  66. package/dist/types/src/components/MarkdownEditor.stories.d.ts.map +1 -0
  67. package/dist/types/src/components/MarkdownSettings.d.ts +6 -0
  68. package/dist/types/src/components/MarkdownSettings.d.ts.map +1 -0
  69. package/dist/types/src/components/Toolbar.stories.d.ts +9 -0
  70. package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -0
  71. package/dist/types/src/components/index.d.ts +13 -0
  72. package/dist/types/src/components/index.d.ts.map +1 -0
  73. package/dist/types/src/extensions.d.ts +20 -0
  74. package/dist/types/src/extensions.d.ts.map +1 -0
  75. package/dist/types/src/index.d.ts +6 -0
  76. package/dist/types/src/index.d.ts.map +1 -0
  77. package/dist/types/src/meta.d.ts +15 -0
  78. package/dist/types/src/meta.d.ts.map +1 -0
  79. package/dist/types/src/translations.d.ts +29 -0
  80. package/dist/types/src/translations.d.ts.map +1 -0
  81. package/dist/types/src/types/document.d.ts +97 -0
  82. package/dist/types/src/types/document.d.ts.map +1 -0
  83. package/dist/types/src/types/index.d.ts +3 -0
  84. package/dist/types/src/types/index.d.ts.map +1 -0
  85. package/dist/types/src/types/types.d.ts +42 -0
  86. package/dist/types/src/types/types.d.ts.map +1 -0
  87. package/dist/types/src/util.d.ts +11 -0
  88. package/dist/types/src/util.d.ts.map +1 -0
  89. package/package.json +94 -0
  90. package/src/MarkdownPlugin.tsx +341 -0
  91. package/src/components/DocumentCard.tsx +107 -0
  92. package/src/components/DocumentEditor.tsx +140 -0
  93. package/src/components/HeadingMenu.tsx +46 -0
  94. package/src/components/Layout.tsx +27 -0
  95. package/src/components/MarkdownEditor.stories.tsx +55 -0
  96. package/src/components/MarkdownEditor.tsx +241 -0
  97. package/src/components/MarkdownSettings.tsx +105 -0
  98. package/src/components/Toolbar.stories.tsx +118 -0
  99. package/src/components/index.ts +21 -0
  100. package/src/extensions.tsx +175 -0
  101. package/src/index.ts +11 -0
  102. package/src/meta.tsx +19 -0
  103. package/src/translations.ts +36 -0
  104. package/src/types/document.ts +17 -0
  105. package/src/types/index.ts +6 -0
  106. package/src/types/types.ts +75 -0
  107. package/src/util.tsx +48 -0
@@ -0,0 +1,517 @@
1
+ "use strict";
2
+ var __create = Object.create;
3
+ var __defProp = Object.defineProperty;
4
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
+ var __getOwnPropNames = Object.getOwnPropertyNames;
6
+ var __getProtoOf = Object.getPrototypeOf;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __export = (target, all) => {
9
+ for (var name in all)
10
+ __defProp(target, name, { get: all[name], enumerable: true });
11
+ };
12
+ var __copyProps = (to, from, except, desc) => {
13
+ if (from && typeof from === "object" || typeof from === "function") {
14
+ for (let key of __getOwnPropNames(from))
15
+ if (!__hasOwnProp.call(to, key) && key !== except)
16
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
17
+ }
18
+ return to;
19
+ };
20
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
21
+ // If the importer is in node compatibility mode or this is not an ESM
22
+ // file that has been converted to a CommonJS file using a Babel-
23
+ // compatible transform (i.e. "__esModule" has not been set), then set
24
+ // "default" to the CommonJS "module.exports" for node compatibility.
25
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
26
+ mod
27
+ ));
28
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
+ var node_exports = {};
30
+ __export(node_exports, {
31
+ DocumentType: () => import_chunk_VYLYUDDI.DocumentType,
32
+ MarkdownAction: () => import_chunk_VYLYUDDI.MarkdownAction,
33
+ MarkdownPlugin: () => MarkdownPlugin,
34
+ TextType: () => import_chunk_VYLYUDDI.TextType,
35
+ default: () => src_default,
36
+ getFallbackName: () => import_chunk_IUQ2SKGY.getFallbackName,
37
+ isMarkdownProperties: () => import_chunk_IUQ2SKGY.isMarkdownProperties,
38
+ markdownExtensionPlugins: () => import_chunk_IUQ2SKGY.markdownExtensionPlugins,
39
+ serializer: () => import_chunk_IUQ2SKGY.serializer,
40
+ setFallbackName: () => import_chunk_IUQ2SKGY.setFallbackName
41
+ });
42
+ module.exports = __toCommonJS(node_exports);
43
+ var import_chunk_FW5O2I25 = require("./chunk-FW5O2I25.cjs");
44
+ var import_chunk_IUQ2SKGY = require("./chunk-IUQ2SKGY.cjs");
45
+ var import_chunk_VYLYUDDI = require("./chunk-VYLYUDDI.cjs");
46
+ var import_chunk_TZDYK4MV = require("./chunk-TZDYK4MV.cjs");
47
+ var import_chunk_TO3FCKT7 = require("./chunk-TO3FCKT7.cjs");
48
+ var import_chunk_TGMR2CKU = require("./chunk-TGMR2CKU.cjs");
49
+ var import_react = require("@phosphor-icons/react");
50
+ var import_react2 = __toESM(require("react"));
51
+ var import_app_framework = require("@dxos/app-framework");
52
+ var import_echo_schema = require("@dxos/echo-schema");
53
+ var import_local_storage = require("@dxos/local-storage");
54
+ var import_plugin_client = require("@dxos/plugin-client");
55
+ var import_plugin_graph = require("@dxos/plugin-graph");
56
+ var import_plugin_space = require("@dxos/plugin-space");
57
+ var import_types = require("@dxos/plugin-space/types");
58
+ var import_echo = require("@dxos/react-client/echo");
59
+ var import_react_ui_editor = require("@dxos/react-ui-editor");
60
+ var import_react_ui_mosaic = require("@dxos/react-ui-mosaic");
61
+ var import_react3 = __toESM(require("react"));
62
+ var import_react4 = require("@phosphor-icons/react");
63
+ var import_react5 = __toESM(require("react"));
64
+ var import_app_framework2 = require("@dxos/app-framework");
65
+ var import_react_ui = require("@dxos/react-ui");
66
+ var import_react_ui_theme = require("@dxos/react-ui-theme");
67
+ var import_react6 = __toESM(require("react"));
68
+ var import_react_ui2 = require("@dxos/react-ui");
69
+ var import_react_ui_editor2 = require("@dxos/react-ui-editor");
70
+ var import_react_ui_theme2 = require("@dxos/react-ui-theme");
71
+ var import_react7 = __toESM(require("react"));
72
+ var import_plugin_settings = require("@dxos/plugin-settings");
73
+ var import_react_ui3 = require("@dxos/react-ui");
74
+ var import_react_ui_editor3 = require("@dxos/react-ui-editor");
75
+ var MarkdownSettings = ({ settings }) => {
76
+ const { t } = (0, import_react_ui3.useTranslation)(import_chunk_TGMR2CKU.MARKDOWN_PLUGIN);
77
+ return /* @__PURE__ */ import_react7.default.createElement(import_react7.default.Fragment, null, /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
78
+ label: t("default view mode label")
79
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Root, {
80
+ value: settings.defaultViewMode,
81
+ onValueChange: (value) => {
82
+ settings.defaultViewMode = value;
83
+ }
84
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.TriggerButton, null), /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Portal, null, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Content, null, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Viewport, null, import_react_ui_editor3.EditorViewModes.map((mode) => /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Option, {
85
+ key: mode,
86
+ value: mode
87
+ }, t(`${mode} mode label`, {
88
+ ns: "react-ui-editor"
89
+ })))))))), /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
90
+ label: t("editor input mode label")
91
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Root, {
92
+ value: settings.editorInputMode ?? "default",
93
+ onValueChange: (value) => {
94
+ settings.editorInputMode = value;
95
+ }
96
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.TriggerButton, {
97
+ placeholder: t("select editor input mode placeholder")
98
+ }), /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Portal, null, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Content, null, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Viewport, null, import_react_ui_editor3.EditorInputModes.map((mode) => /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Select.Option, {
99
+ key: mode,
100
+ value: mode
101
+ }, t(`settings editor input mode ${mode} label`)))))))), /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
102
+ label: t("settings toolbar label")
103
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.Switch, {
104
+ checked: settings.toolbar,
105
+ onCheckedChange: (checked) => settings.toolbar = !!checked
106
+ })), /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
107
+ label: t("settings numbered headings label")
108
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.Switch, {
109
+ checked: settings.numberedHeadings,
110
+ onCheckedChange: (checked) => settings.numberedHeadings = !!checked
111
+ })), /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
112
+ label: t("settings folding label")
113
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.Switch, {
114
+ checked: settings.folding,
115
+ onCheckedChange: (checked) => settings.folding = !!checked
116
+ })), /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
117
+ label: t("settings experimental label")
118
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.Switch, {
119
+ checked: settings.experimental,
120
+ onCheckedChange: (checked) => settings.experimental = !!checked
121
+ })), /* @__PURE__ */ import_react7.default.createElement(import_plugin_settings.SettingsValue, {
122
+ label: t("settings debug label"),
123
+ secondary: settings.debug ? /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.Root, null, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.TextArea, {
124
+ rows: 5,
125
+ value: settings.typewriter,
126
+ onChange: ({ target: { value } }) => settings.typewriter = value,
127
+ placeholder: t("settings debug placeholder")
128
+ })) : void 0
129
+ }, /* @__PURE__ */ import_react7.default.createElement(import_react_ui3.Input.Switch, {
130
+ checked: settings.debug,
131
+ onCheckedChange: (checked) => settings.debug = !!checked
132
+ })));
133
+ };
134
+ var DocumentCard = import_react3.default.lazy(() => import("./DocumentCard-SOTFILJY.cjs"));
135
+ var DocumentEditor = import_react3.default.lazy(() => import("./DocumentEditor-CUKHGS5R.cjs"));
136
+ var MarkdownEditor = import_react3.default.lazy(() => import("./MarkdownEditor-GGFCD26C.cjs"));
137
+ var translations_default = [
138
+ {
139
+ "en-US": {
140
+ [import_chunk_TGMR2CKU.MARKDOWN_PLUGIN]: {
141
+ "plugin name": "Editor",
142
+ "create stack section label": "Create document",
143
+ "document title placeholder": "New document",
144
+ "choose markdown from space dialog title": "Choose one or more documents to add",
145
+ // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)
146
+ "empty choose markdown from space message": "None available; try creating a new one instead?",
147
+ "chooser done label": "Add selected",
148
+ "create document label": "Create document",
149
+ "editor placeholder": "New document",
150
+ "editor input mode label": "Editor input mode",
151
+ "select editor input mode placeholder": "Select editor input mode\u2026",
152
+ "settings editor input mode default label": "Default",
153
+ "settings editor input mode vim label": "Vim",
154
+ "settings editor input mode vscode label": "VS Code",
155
+ "settings toolbar label": "Show toolbar",
156
+ "settings numbered headings label": "Numbered headings",
157
+ "settings folding label": "Folding",
158
+ "settings experimental label": "Enable experimental features",
159
+ "settings debug label": "Enable debugging features",
160
+ "settings debug placeholder": "Typewriter script...",
161
+ "toggle view mode label": "Toggle read-only",
162
+ "default view mode label": "Default view mode"
163
+ }
164
+ }
165
+ }
166
+ ];
167
+ var isEditorModel = (data) => {
168
+ return data && typeof data === "object" && "id" in data && typeof data.id === "string" && "text" in data && typeof data.text === "string";
169
+ };
170
+ var MarkdownPlugin = () => {
171
+ const settings = new import_local_storage.LocalStorageStore(import_chunk_TGMR2CKU.MARKDOWN_PLUGIN, {
172
+ defaultViewMode: "preview",
173
+ toolbar: true,
174
+ experimental: false
175
+ });
176
+ const state = new import_local_storage.LocalStorageStore(import_chunk_TGMR2CKU.MARKDOWN_PLUGIN, {
177
+ extensionProviders: [],
178
+ viewMode: {}
179
+ });
180
+ const getViewMode = (id) => {
181
+ return id && state.values.viewMode[id] || settings.values.defaultViewMode;
182
+ };
183
+ const setViewMode = (id, nextViewMode) => {
184
+ state.values.viewMode[id] = nextViewMode;
185
+ };
186
+ return {
187
+ meta: import_chunk_TGMR2CKU.meta_default,
188
+ ready: async (plugins) => {
189
+ settings.prop({
190
+ key: "defaultViewMode",
191
+ storageKey: "default-view-mode",
192
+ type: import_local_storage.LocalStorageStore.enum()
193
+ }).prop({
194
+ key: "editorInputMode",
195
+ storageKey: "editor-mode",
196
+ type: import_local_storage.LocalStorageStore.enum({
197
+ allowUndefined: true
198
+ })
199
+ }).prop({
200
+ key: "toolbar",
201
+ type: import_local_storage.LocalStorageStore.bool({
202
+ allowUndefined: true
203
+ })
204
+ }).prop({
205
+ key: "experimental",
206
+ type: import_local_storage.LocalStorageStore.bool({
207
+ allowUndefined: true
208
+ })
209
+ }).prop({
210
+ key: "debug",
211
+ type: import_local_storage.LocalStorageStore.bool({
212
+ allowUndefined: true
213
+ })
214
+ }).prop({
215
+ key: "typewriter",
216
+ type: import_local_storage.LocalStorageStore.string({
217
+ allowUndefined: true
218
+ })
219
+ }).prop({
220
+ key: "numberedHeadings",
221
+ type: import_local_storage.LocalStorageStore.bool({
222
+ allowUndefined: true
223
+ })
224
+ }).prop({
225
+ key: "folding",
226
+ type: import_local_storage.LocalStorageStore.bool({
227
+ allowUndefined: true
228
+ })
229
+ });
230
+ state.prop({
231
+ key: "viewMode",
232
+ storageKey: "view-mode",
233
+ type: import_local_storage.LocalStorageStore.json()
234
+ });
235
+ (0, import_chunk_IUQ2SKGY.markdownExtensionPlugins)(plugins).forEach((plugin) => {
236
+ const { extensions } = plugin.provides.markdown;
237
+ state.values.extensionProviders.push(extensions);
238
+ });
239
+ },
240
+ provides: {
241
+ settings: settings.values,
242
+ metadata: {
243
+ records: {
244
+ [import_chunk_VYLYUDDI.DocumentType.typename]: {
245
+ label: (object) => object instanceof import_chunk_VYLYUDDI.DocumentType ? object.name ?? object.fallbackName : void 0,
246
+ placeholder: [
247
+ "document title placeholder",
248
+ {
249
+ ns: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN
250
+ }
251
+ ],
252
+ icon: (props) => /* @__PURE__ */ import_react2.default.createElement(import_react.TextAa, props),
253
+ iconSymbol: "ph--text-aa--regular",
254
+ graphProps: {
255
+ managesAutofocus: true
256
+ },
257
+ // TODO(wittjosiah): Move out of metadata.
258
+ loadReferences: (doc) => (0, import_echo.loadObjectReferences)(doc, (doc2) => [
259
+ doc2.content,
260
+ ...doc2.threads
261
+ ]),
262
+ serializer: import_chunk_IUQ2SKGY.serializer
263
+ }
264
+ }
265
+ },
266
+ translations: [
267
+ ...translations_default,
268
+ ...import_react_ui_editor.translations
269
+ ],
270
+ echo: {
271
+ schema: [
272
+ import_chunk_VYLYUDDI.DocumentType,
273
+ import_chunk_VYLYUDDI.TextType
274
+ ]
275
+ },
276
+ graph: {
277
+ builder: (plugins) => {
278
+ const client = (0, import_app_framework.resolvePlugin)(plugins, import_plugin_client.parseClientPlugin)?.provides.client;
279
+ const dispatch = (0, import_app_framework.resolvePlugin)(plugins, import_app_framework.parseIntentPlugin)?.provides.intent.dispatch;
280
+ if (!client || !dispatch) {
281
+ return [];
282
+ }
283
+ return (0, import_plugin_graph.createExtension)({
284
+ id: import_chunk_VYLYUDDI.MarkdownAction.CREATE,
285
+ filter: (node) => (0, import_plugin_graph.isActionGroup)(node) && node.id.startsWith(import_plugin_space.SpaceAction.ADD_OBJECT),
286
+ actions: ({ node }) => {
287
+ const id = node.id.split("/").at(-1);
288
+ const [spaceId, objectId] = id?.split(":") ?? [];
289
+ const space = client.spaces.get().find((space2) => space2.id === spaceId);
290
+ const object = objectId && space?.db.getObjectById(objectId);
291
+ const target = objectId ? object : space;
292
+ if (!target) {
293
+ return;
294
+ }
295
+ return [
296
+ {
297
+ id: `${import_chunk_TGMR2CKU.MARKDOWN_PLUGIN}/create/${node.id}`,
298
+ data: async () => {
299
+ await dispatch([
300
+ {
301
+ plugin: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN,
302
+ action: import_chunk_VYLYUDDI.MarkdownAction.CREATE
303
+ },
304
+ {
305
+ action: import_plugin_space.SpaceAction.ADD_OBJECT,
306
+ data: {
307
+ target
308
+ }
309
+ },
310
+ {
311
+ action: import_app_framework.NavigationAction.OPEN
312
+ }
313
+ ]);
314
+ },
315
+ properties: {
316
+ label: [
317
+ "create document label",
318
+ {
319
+ ns: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN
320
+ }
321
+ ],
322
+ icon: (props) => /* @__PURE__ */ import_react2.default.createElement(import_react.TextAa, props),
323
+ iconSymbol: "ph--text-aa--regular",
324
+ testId: "markdownPlugin.createObject"
325
+ }
326
+ }
327
+ ];
328
+ }
329
+ });
330
+ },
331
+ serializer: (plugins) => {
332
+ const dispatch = (0, import_app_framework.resolvePlugin)(plugins, import_app_framework.parseIntentPlugin)?.provides.intent.dispatch;
333
+ if (!dispatch) {
334
+ return [];
335
+ }
336
+ return [
337
+ {
338
+ inputType: import_chunk_VYLYUDDI.DocumentType.typename,
339
+ outputType: "text/markdown",
340
+ // Reconcile with metadata serializers.
341
+ serialize: async (node) => {
342
+ const doc = node.data;
343
+ const content = await (0, import_echo.loadObjectReferences)(doc, (doc2) => doc2.content);
344
+ return {
345
+ name: doc.name || doc.fallbackName || translations_default[0]["en-US"][import_chunk_TGMR2CKU.MARKDOWN_PLUGIN]["document title placeholder"],
346
+ data: content.content,
347
+ type: "text/markdown"
348
+ };
349
+ },
350
+ deserialize: async (data, ancestors) => {
351
+ const space = ancestors.find(import_echo.isSpace);
352
+ const target = ancestors.findLast((ancestor) => ancestor instanceof import_types.CollectionType) ?? space?.properties[import_types.CollectionType.typename];
353
+ if (!space || !target) {
354
+ return;
355
+ }
356
+ const result = await dispatch([
357
+ {
358
+ plugin: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN,
359
+ action: import_chunk_VYLYUDDI.MarkdownAction.CREATE,
360
+ data: {
361
+ name: data.name,
362
+ content: data.data
363
+ }
364
+ },
365
+ {
366
+ action: import_plugin_space.SpaceAction.ADD_OBJECT,
367
+ data: {
368
+ target
369
+ }
370
+ }
371
+ ]);
372
+ return result?.data.object;
373
+ }
374
+ }
375
+ ];
376
+ }
377
+ },
378
+ stack: {
379
+ creators: [
380
+ {
381
+ id: "create-stack-section-doc",
382
+ testId: "markdownPlugin.createSection",
383
+ type: [
384
+ "plugin name",
385
+ {
386
+ ns: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN
387
+ }
388
+ ],
389
+ label: [
390
+ "create stack section label",
391
+ {
392
+ ns: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN
393
+ }
394
+ ],
395
+ icon: (props) => /* @__PURE__ */ import_react2.default.createElement(import_react.TextAa, props),
396
+ intent: {
397
+ plugin: import_chunk_TGMR2CKU.MARKDOWN_PLUGIN,
398
+ action: import_chunk_VYLYUDDI.MarkdownAction.CREATE
399
+ }
400
+ }
401
+ ]
402
+ },
403
+ surface: {
404
+ component: ({ data, role, ...props }, forwardedRef) => {
405
+ const doc = data.active instanceof import_chunk_VYLYUDDI.DocumentType ? data.active : data.object instanceof import_chunk_VYLYUDDI.DocumentType ? data.object : void 0;
406
+ switch (role) {
407
+ case "section":
408
+ case "article": {
409
+ if (doc && doc.content) {
410
+ return /* @__PURE__ */ import_react2.default.createElement(DocumentEditor, {
411
+ role,
412
+ coordinate: data.coordinate,
413
+ document: doc,
414
+ extensionProviders: state.values.extensionProviders,
415
+ settings: settings.values,
416
+ viewMode: getViewMode((0, import_echo.fullyQualifiedId)(doc)),
417
+ onViewModeChange: setViewMode,
418
+ scrollPastEnd: true
419
+ });
420
+ } else if (isEditorModel(data.object)) {
421
+ return /* @__PURE__ */ import_react2.default.createElement(MarkdownEditor, {
422
+ id: data.object.id,
423
+ role,
424
+ coordinate: data.coordinate,
425
+ initialValue: data.object.text,
426
+ extensionProviders: state.values.extensionProviders,
427
+ inputMode: settings.values.editorInputMode,
428
+ toolbar: settings.values.toolbar,
429
+ viewMode: getViewMode(data.object.id),
430
+ onViewModeChange: setViewMode,
431
+ scrollPastEnd: true
432
+ });
433
+ }
434
+ break;
435
+ }
436
+ case "card": {
437
+ if ((0, import_app_framework.isObject)(data.content) && typeof data.content.id === "string" && data.content.object instanceof import_chunk_VYLYUDDI.DocumentType) {
438
+ const cardProps = {
439
+ ...props,
440
+ item: {
441
+ id: data.content.id,
442
+ object: data.content.object,
443
+ color: typeof data.content.color === "string" ? data.content.color : void 0
444
+ }
445
+ };
446
+ return (0, import_react_ui_mosaic.isTileComponentProps)(cardProps) ? /* @__PURE__ */ import_react2.default.createElement(DocumentCard, {
447
+ ...cardProps,
448
+ settings: settings.values,
449
+ ref: forwardedRef
450
+ }) : null;
451
+ }
452
+ break;
453
+ }
454
+ case "settings": {
455
+ return data.plugin === import_chunk_TGMR2CKU.meta_default.id ? /* @__PURE__ */ import_react2.default.createElement(MarkdownSettings, {
456
+ settings: settings.values
457
+ }) : null;
458
+ }
459
+ }
460
+ return null;
461
+ }
462
+ },
463
+ intent: {
464
+ resolver: ({ action, data }) => {
465
+ switch (action) {
466
+ case import_chunk_VYLYUDDI.MarkdownAction.CREATE: {
467
+ const doc = (0, import_echo_schema.create)(import_chunk_VYLYUDDI.DocumentType, {
468
+ name: data?.name,
469
+ content: (0, import_echo_schema.create)(import_chunk_VYLYUDDI.TextType, {
470
+ content: data?.content ?? ""
471
+ }),
472
+ threads: []
473
+ });
474
+ return {
475
+ data: doc,
476
+ intents: [
477
+ [
478
+ {
479
+ action: import_app_framework.LayoutAction.SCROLL_INTO_VIEW,
480
+ data: {
481
+ id: doc.id
482
+ }
483
+ }
484
+ ]
485
+ ]
486
+ };
487
+ }
488
+ case import_chunk_VYLYUDDI.MarkdownAction.SET_VIEW_MODE: {
489
+ const { id, viewMode } = data ?? {};
490
+ if (typeof id === "string" && import_react_ui_editor.EditorViewModes.includes(viewMode)) {
491
+ state.values.viewMode[id] = viewMode;
492
+ return {
493
+ data: true
494
+ };
495
+ }
496
+ break;
497
+ }
498
+ }
499
+ }
500
+ }
501
+ }
502
+ };
503
+ };
504
+ var src_default = MarkdownPlugin;
505
+ // Annotate the CommonJS export names for ESM import in node:
506
+ 0 && (module.exports = {
507
+ DocumentType,
508
+ MarkdownAction,
509
+ MarkdownPlugin,
510
+ TextType,
511
+ getFallbackName,
512
+ isMarkdownProperties,
513
+ markdownExtensionPlugins,
514
+ serializer,
515
+ setFallbackName
516
+ });
517
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/MarkdownPlugin.tsx", "../../../src/components/index.ts", "../../../src/components/HeadingMenu.tsx", "../../../src/components/Layout.tsx", "../../../src/components/MarkdownSettings.tsx", "../../../src/translations.ts", "../../../src/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type IconProps, TextAa } from '@phosphor-icons/react';\nimport React, { type Ref } from 'react';\n\nimport {\n isObject,\n parseIntentPlugin,\n resolvePlugin,\n LayoutAction,\n type LayoutCoordinate,\n NavigationAction,\n type PluginDefinition,\n} from '@dxos/app-framework';\nimport { create } from '@dxos/echo-schema';\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 { fullyQualifiedId, isSpace, loadObjectReferences } from '@dxos/react-client/echo';\nimport {\n type EditorInputMode,\n type EditorViewMode,\n EditorViewModes,\n translations as editorTranslations,\n} from '@dxos/react-ui-editor';\nimport { isTileComponentProps } from '@dxos/react-ui-mosaic';\n\nimport { type DocumentItemProps, DocumentCard, DocumentEditor, MarkdownEditor, MarkdownSettings } from './components';\nimport meta, { MARKDOWN_PLUGIN } from './meta';\nimport translations from './translations';\nimport { DocumentType, 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/**\n * Checks if an object conforms to the interface needed to render an editor.\n */\nconst isEditorModel = (data: any): data is { id: string; text: string } => {\n return (\n data &&\n typeof data === 'object' &&\n 'id' in data &&\n typeof data.id === 'string' &&\n 'text' in data &&\n typeof data.text === 'string'\n );\n};\n\nexport const MarkdownPlugin = (): PluginDefinition<MarkdownPluginProvides> => {\n const settings = new LocalStorageStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN, {\n defaultViewMode: 'preview',\n toolbar: true,\n experimental: false,\n });\n\n const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });\n\n const getViewMode = (id?: string) => {\n return (id && state.values.viewMode[id]) || settings.values.defaultViewMode;\n };\n\n const setViewMode = (id: string, nextViewMode: EditorViewMode) => {\n state.values.viewMode[id] = nextViewMode;\n };\n\n return {\n meta,\n ready: async (plugins) => {\n settings\n .prop({\n key: 'defaultViewMode',\n storageKey: 'default-view-mode',\n type: LocalStorageStore.enum<EditorViewMode>(),\n })\n .prop({\n key: 'editorInputMode',\n storageKey: 'editor-mode',\n type: LocalStorageStore.enum<EditorInputMode>({ allowUndefined: true }),\n })\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({\n key: 'viewMode',\n storageKey: 'view-mode',\n type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>(),\n });\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 label: (object: any) => (object instanceof DocumentType ? object.name ?? object.fallbackName : undefined),\n placeholder: ['document title placeholder', { ns: MARKDOWN_PLUGIN }],\n icon: (props: IconProps) => <TextAa {...props} />,\n iconSymbol: '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, 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: (props: IconProps) => <TextAa {...props} />,\n iconSymbol: '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 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 surface: {\n component: ({ data, role, ...props }, forwardedRef) => {\n const doc =\n data.active instanceof DocumentType\n ? data.active\n : data.object instanceof DocumentType\n ? data.object\n : undefined;\n\n switch (role) {\n case 'section':\n case 'article': {\n if (doc && doc.content) {\n return (\n <DocumentEditor\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n document={doc}\n extensionProviders={state.values.extensionProviders}\n settings={settings.values}\n viewMode={getViewMode(fullyQualifiedId(doc))}\n onViewModeChange={setViewMode}\n scrollPastEnd\n />\n );\n } else if (isEditorModel(data.object)) {\n return (\n <MarkdownEditor\n id={data.object.id}\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n initialValue={data.object.text}\n extensionProviders={state.values.extensionProviders}\n inputMode={settings.values.editorInputMode}\n toolbar={settings.values.toolbar}\n viewMode={getViewMode(data.object.id)}\n onViewModeChange={setViewMode}\n scrollPastEnd\n />\n );\n }\n break;\n }\n\n case 'card': {\n if (\n isObject(data.content) &&\n typeof data.content.id === 'string' &&\n data.content.object instanceof DocumentType\n ) {\n // isTileComponentProps is a type guard for these props.\n // `props` will not pass this guard without transforming `data` into `item`.\n const cardProps = {\n ...props,\n item: {\n id: data.content.id,\n object: data.content.object,\n color: typeof data.content.color === 'string' ? data.content.color : undefined,\n } as DocumentItemProps,\n };\n\n return isTileComponentProps(cardProps) ? (\n <DocumentCard {...cardProps} settings={settings.values} ref={forwardedRef as Ref<HTMLDivElement>} />\n ) : null;\n }\n break;\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 {\n data: doc,\n intents: [[{ action: LayoutAction.SCROLL_INTO_VIEW, data: { id: doc.id } }]],\n };\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 React, { type LazyExoticComponent } from 'react';\n\nimport { type DocumentEditor as DocumentEditorType } from './DocumentEditor';\n\nexport { type DocumentCardProps, type DocumentItemProps } from './DocumentCard';\n\nexport * from './DocumentCard';\nexport * from './DocumentEditor';\nexport * from './MarkdownEditor';\nexport * from './HeadingMenu';\nexport * from './Layout';\nexport * from './MarkdownSettings';\n\n// Lazily load components for content surfaces.\nexport const DocumentCard = React.lazy(() => import('./DocumentCard'));\nexport const DocumentEditor: LazyExoticComponent<DocumentEditorType> = React.lazy(() => import('./DocumentEditor'));\nexport const MarkdownEditor = React.lazy(() => import('./MarkdownEditor'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { DotsThreeVertical } from '@phosphor-icons/react';\nimport React, { type PropsWithChildren, type FC } from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { Button, DropdownMenu } from '@dxos/react-ui';\nimport { fineButtonDimensions, getSize } from '@dxos/react-ui-theme';\n\nimport { type DocumentType, type MarkdownProperties } from '../types';\n\n// TODO(thure): This needs to be refactored into a graph node action.\nexport const DocumentHeadingMenu: FC<{ document: DocumentType }> = ({ document }) => {\n return <HeadingMenu properties={document} content={document.content?.content} />;\n};\n\n/**\n * Menu for the layout heading.\n */\nexport const HeadingMenu = ({\n content,\n properties,\n}: PropsWithChildren<{\n content: string | undefined;\n properties: MarkdownProperties;\n}>) => {\n return (\n <DropdownMenu.Root modal={false}>\n <DropdownMenu.Trigger asChild>\n <Button variant='ghost' classNames={fineButtonDimensions}>\n <DotsThreeVertical className={getSize(4)} />\n </Button>\n </DropdownMenu.Trigger>\n <DropdownMenu.Portal>\n <DropdownMenu.Content sideOffset={8} classNames='z-10'>\n <DropdownMenu.Viewport>\n <Surface data={{ content, properties }} role='menuitem' />\n </DropdownMenu.Viewport>\n <DropdownMenu.Arrow />\n </DropdownMenu.Content>\n </DropdownMenu.Portal>\n </DropdownMenu.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\n\nimport { Main } from '@dxos/react-ui';\nimport { editorWithToolbarLayout } from '@dxos/react-ui-editor';\nimport { topbarBlockPaddingStart } from '@dxos/react-ui-theme';\n\nexport const MainLayout = ({ children, toolbar }: PropsWithChildren<{ toolbar?: boolean }>) => {\n return (\n <Main.Content\n bounce\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n classNames={[topbarBlockPaddingStart, editorWithToolbarLayout]}\n >\n {children}\n </Main.Content>\n );\n};\n\n// Used when the editor is embedded in another context (e.g., iframe) and has no topbar/sidebar/etc.\n// TODO(wittjosiah): What's the difference between this and Section/Card?\nexport const EmbeddedLayout = ({ children }: PropsWithChildren) => {\n return <Main.Content classNames='min-bs-[100dvh] grid p-0.5'>{children}</Main.Content>;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { SettingsValue } from '@dxos/plugin-settings';\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';\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 <SettingsValue 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 </SettingsValue>\n\n <SettingsValue 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 </SettingsValue>\n\n <SettingsValue label={t('settings toolbar label')}>\n <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />\n </SettingsValue>\n\n <SettingsValue label={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}\n />\n </SettingsValue>\n\n <SettingsValue label={t('settings folding label')}>\n <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />\n </SettingsValue>\n\n <SettingsValue label={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => (settings.experimental = !!checked)}\n />\n </SettingsValue>\n\n <SettingsValue\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 </SettingsValue>\n </>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MARKDOWN_PLUGIN } from './meta';\n\nexport default [\n {\n 'en-US': {\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': 'New document',\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,mBAAuC;AACvC,IAAAA,gBAAgC;AAEhC,2BAQO;AACP,yBAAuB;AACvB,2BAAkC;AAClC,2BAAkC;AAClC,0BAAiE;AACjE,0BAA4B;AAC5B,mBAA+B;AAC/B,kBAAgE;AAChE,6BAKO;AACP,6BAAqC;ACzBrC,IAAAA,gBAAgD;ACAhD,IAAAA,gBAAkC;AAClC,IAAAA,gBAAuD;AAEvD,IAAAC,wBAAwB;AACxB,sBAAqC;AACrC,4BAA8C;ACL9C,IAAAD,gBAA8C;AAE9C,IAAAE,mBAAqB;AACrB,IAAAC,0BAAwC;AACxC,IAAAC,yBAAwC;ACJxC,IAAAJ,gBAAkB;AAElB,6BAA8B;AAC9B,IAAAE,mBAA8C;AAC9C,IAAAC,0BAA6F;AAKtF,IAAME,mBAAmB,CAAC,EAAEC,SAAQ,MAAuC;AAChF,QAAM,EAAEC,EAAC,QAAKC,iCAAeC,qCAAAA;AAG7B,SACEC,8BAAAA,QAAA,cAAAA,cAAAA,QAAA,UAAA,MACEA,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,yBAAA;KACtBG,8BAAAA,QAAA,cAACG,wBAAOC,MAAI;IACVC,OAAOT,SAASU;IAChBC,eAAe,CAACF,UAAAA;AACdT,eAASU,kBAAkBD;IAC7B;KAEAL,8BAAAA,QAAA,cAACG,wBAAOK,eAAa,IAAA,GACrBR,8BAAAA,QAAA,cAACG,wBAAOM,QAAM,MACZT,8BAAAA,QAAA,cAACG,wBAAOO,SAAO,MACbV,8BAAAA,QAAA,cAACG,wBAAOQ,UAAQ,MACbC,wCAAgBC,IAAI,CAACC,SACpBd,8BAAAA,QAAA,cAACG,wBAAOY,QAAM;IAACC,KAAKF;IAAMT,OAAOS;KAC9BjB,EAAE,GAAGiB,IAAAA,eAAmB;IAAEG,IAAI;EAAkB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAS/DjB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,yBAAA;KACtBG,8BAAAA,QAAA,cAACG,wBAAOC,MAAI;IACVC,OAAOT,SAASsB,mBAAmB;IACnCX,eAAe,CAACF,UAAAA;AACdT,eAASsB,kBAAkBb;IAC7B;KAEAL,8BAAAA,QAAA,cAACG,wBAAOK,eAAa;IAACW,aAAatB,EAAE,sCAAA;MACrCG,8BAAAA,QAAA,cAACG,wBAAOM,QAAM,MACZT,8BAAAA,QAAA,cAACG,wBAAOO,SAAO,MACbV,8BAAAA,QAAA,cAACG,wBAAOQ,UAAQ,MACbS,yCAAiBP,IAAI,CAACC,SACrBd,8BAAAA,QAAA,cAACG,wBAAOY,QAAM;IAACC,KAAKF;IAAMT,OAAOS;KAC9BjB,EAAE,8BAA8BiB,IAAAA,QAAY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAS3Dd,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,wBAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IAACC,SAAS3B,SAAS4B;IAASC,iBAAiB,CAACF,YAAa3B,SAAS4B,UAAU,CAAC,CAACD;OAG/FvB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,kCAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IACXC,SAAS3B,SAAS8B;IAClBD,iBAAiB,CAACF,YAAa3B,SAAS8B,mBAAmB,CAAC,CAACH;OAIjEvB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,wBAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IAACC,SAAS3B,SAAS+B;IAASF,iBAAiB,CAACF,YAAa3B,SAAS+B,UAAU,CAAC,CAACJ;OAG/FvB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,6BAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IACXC,SAAS3B,SAASgC;IAClBH,iBAAiB,CAACF,YAAa3B,SAASgC,eAAe,CAAC,CAACL;OAI7DvB,8BAAAA,QAAA,cAACC,sCAAAA;IACCC,OAAOL,EAAE,sBAAA;IACTgC,WACEjC,SAASkC,QACP9B,8BAAAA,QAAA,cAACqB,uBAAMjB,MAAI,MACTJ,8BAAAA,QAAA,cAACqB,uBAAMU,UAAQ;MACbC,MAAM;MACN3B,OAAOT,SAASqC;MAChBC,UAAU,CAAC,EAAEC,QAAQ,EAAE9B,MAAK,EAAE,MAAQT,SAASqC,aAAa5B;MAC5Dc,aAAatB,EAAE,4BAAA;UAGjBuC;KAGNpC,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IAACC,SAAS3B,SAASkC;IAAOL,iBAAiB,CAACF,YAAa3B,SAASkC,QAAQ,CAAC,CAACP;;AAIjG;AHtFO,IAAMc,eAAerC,cAAAA,QAAMsC,KAAK,MAAM,OAAO,6BAAA,CAAA;AAC7C,IAAMC,iBAA0DvC,cAAAA,QAAMsC,KAAK,MAAM,OAAO,+BAAA,CAAA;AACxF,IAAME,iBAAiBxC,cAAAA,QAAMsC,KAAK,MAAM,OAAO,+BAAA,CAAA;AIdtD,IAAA,uBAAe;EACb;IACE,SAAS;MACP,CAACvC,qCAAAA,GAAkB;QACjB,eAAe;QACf,8BAA8B;QAC9B,8BAA8B;QAC9B,2CAA2C;;QAE3C,4CAA4C;QAC5C,sBAAsB;QACtB,yBAAyB;QACzB,sBAAsB;QACtB,2BAA2B;QAC3B,wCAAwC;QACxC,4CAA4C;QAC5C,wCAAwC;QACxC,2CAA2C;QAC3C,0BAA0B;QAC1B,oCAAoC;QACpC,0BAA0B;QAC1B,+BAA+B;QAC/B,wBAAwB;QACxB,8BAA8B;QAC9B,0BAA0B;QAC1B,2BAA2B;MAC7B;IACF;EACF;;ALYF,IAAM0C,gBAAgB,CAACC,SAAAA;AACrB,SACEA,QACA,OAAOA,SAAS,YAChB,QAAQA,QACR,OAAOA,KAAKC,OAAO,YACnB,UAAUD,QACV,OAAOA,KAAKE,SAAS;AAEzB;AAEO,IAAMC,iBAAiB,MAAA;AAC5B,QAAMjD,WAAW,IAAIkD,uCAAyC/C,uCAAiB;IAC7EO,iBAAiB;IACjBkB,SAAS;IACTI,cAAc;EAChB,CAAA;AAEA,QAAMmB,QAAQ,IAAID,uCAAuC/C,uCAAiB;IAAEiD,oBAAoB,CAAA;IAAIC,UAAU,CAAC;EAAE,CAAA;AAEjH,QAAMC,cAAc,CAACP,OAAAA;AACnB,WAAQA,MAAMI,MAAMI,OAAOF,SAASN,EAAAA,KAAQ/C,SAASuD,OAAO7C;EAC9D;AAEA,QAAM8C,cAAc,CAACT,IAAYU,iBAAAA;AAC/BN,UAAMI,OAAOF,SAASN,EAAAA,IAAMU;EAC9B;AAEA,SAAO;IACLC,MAAAA;IACAC,OAAO,OAAOC,YAAAA;AACZ5D,eACG6D,KAAK;QACJzC,KAAK;QACL0C,YAAY;QACZC,MAAMb,uCAAkBc,KAAI;MAC9B,CAAA,EACCH,KAAK;QACJzC,KAAK;QACL0C,YAAY;QACZC,MAAMb,uCAAkBc,KAAsB;UAAEC,gBAAgB;QAAK,CAAA;MACvE,CAAA,EACCJ,KAAK;QAAEzC,KAAK;QAAW2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EAC9EJ,KAAK;QAAEzC,KAAK;QAAgB2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EACnFJ,KAAK;QAAEzC,KAAK;QAAS2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EAC5EJ,KAAK;QAAEzC,KAAK;QAAc2C,MAAMb,uCAAkBiB,OAAO;UAAEF,gBAAgB;QAAK,CAAA;MAAG,CAAA,EACnFJ,KAAK;QAAEzC,KAAK;QAAoB2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EACvFJ,KAAK;QAAEzC,KAAK;QAAW2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA;AAEjFd,YAAMU,KAAK;QACTzC,KAAK;QACL0C,YAAY;QACZC,MAAMb,uCAAkBkB,KAAI;MAC9B,CAAA;AAEAC,0DAAyBT,OAAAA,EAASU,QAAQ,CAACC,WAAAA;AACzC,cAAM,EAAEC,WAAU,IAAKD,OAAOE,SAASC;AACvCvB,cAAMI,OAAOH,mBAAmBuB,KAAKH,UAAAA;MACvC,CAAA;IACF;IACAC,UAAU;MACRzE,UAAUA,SAASuD;MACnBqB,UAAU;QACRC,SAAS;UACP,CAACC,mCAAaC,QAAQ,GAAG;YACvBzE,OAAO,CAAC0E,WAAiBA,kBAAkBF,qCAAeE,OAAOC,QAAQD,OAAOE,eAAe1C;YAC/FjB,aAAa;cAAC;cAA8B;gBAAEF,IAAIlB;cAAgB;;YAClEgF,MAAM,CAACC,UAAqBhF,8BAAAA,QAAA,cAACiF,qBAAWD,KAAAA;YACxCE,YAAY;YACZC,YAAY;cACVC,kBAAkB;YACpB;;YAEAC,gBAAgB,CAACC,YAAsBC,kCAAqBD,KAAK,CAACA,SAAQ;cAACA,KAAIE;iBAAYF,KAAIG;aAAQ;YACvGC;UACF;QACF;MACF;MACAC,cAAc;WAAIA;WAAiBC,uBAAAA;;MACnCC,MAAM;QACJC,QAAQ;UAACpB;UAAcqB;;MACzB;MACAC,OAAO;QACLC,SAAS,CAACzC,YAAAA;AACR,gBAAM0C,aAASC,oCAAc3C,SAAS4C,sCAAAA,GAAoB/B,SAAS6B;AACnE,gBAAMG,eAAWF,oCAAc3C,SAAS8C,sCAAAA,GAAoBjC,SAASkC,OAAOF;AAC5E,cAAI,CAACH,UAAU,CAACG,UAAU;AACxB,mBAAO,CAAA;UACT;AAEA,qBAAOG,qCAAgB;YACrB7D,IAAI8D,qCAAeC;YACnBC,QAAQ,CAACC,aAA8BC,mCAAcD,IAAAA,KAASA,KAAKjE,GAAGmE,WAAWC,gCAAYC,UAAU;YACvGC,SAAS,CAAC,EAAEL,KAAI,MAAE;AAChB,oBAAMjE,KAAKiE,KAAKjE,GAAGuE,MAAM,GAAA,EAAKC,GAAG,EAAC;AAClC,oBAAM,CAACC,SAASC,QAAAA,IAAY1E,IAAIuE,MAAM,GAAA,KAAQ,CAAA;AAC9C,oBAAMI,QAAQpB,OAAOqB,OAAOC,IAAG,EAAGC,KAAK,CAACH,WAAUA,OAAM3E,OAAOyE,OAAAA;AAC/D,oBAAMxC,SAASyC,YAAYC,OAAOI,GAAGC,cAAcN,QAAAA;AACnD,oBAAMlF,SAASkF,WAAWzC,SAAS0C;AACnC,kBAAI,CAACnF,QAAQ;AACX;cACF;AAEA,qBAAO;gBACL;kBACEQ,IAAI,GAAG5C,qCAAAA,WAA0B6G,KAAKjE,EAAE;kBACxCD,MAAM,YAAA;AACJ,0BAAM2D,SAAS;sBACb;wBAAElC,QAAQpE;wBAAiB6H,QAAQnB,qCAAeC;sBAAO;sBACzD;wBAAEkB,QAAQb,gCAAYC;wBAAYtE,MAAM;0BAAEP;wBAAO;sBAAE;sBACnD;wBAAEyF,QAAQC,sCAAiBC;sBAAK;qBACjC;kBACH;kBACAC,YAAY;oBACV7H,OAAO;sBAAC;sBAAyB;wBAAEe,IAAIlB;sBAAgB;;oBACvDgF,MAAM,CAACC,UAAqBhF,8BAAAA,QAAA,cAACiF,qBAAWD,KAAAA;oBACxCE,YAAY;oBACZ8C,QAAQ;kBACV;gBACF;;YAEJ;UACF,CAAA;QACF;QACAtC,YAAY,CAAClC,YAAAA;AACX,gBAAM6C,eAAWF,oCAAc3C,SAAS8C,sCAAAA,GAAoBjC,SAASkC,OAAOF;AAC5E,cAAI,CAACA,UAAU;AACb,mBAAO,CAAA;UACT;AACA,iBAAO;YACL;cACE4B,WAAWvD,mCAAaC;cACxBuD,YAAY;;cAEZC,WAAW,OAAOvB,SAAAA;AAChB,sBAAMtB,MAAMsB,KAAKlE;AACjB,sBAAM8C,UAAU,UAAMD,kCAAqBD,KAAK,CAACA,SAAQA,KAAIE,OAAO;AACpE,uBAAO;kBACLX,MACES,IAAIT,QACJS,IAAIR,gBACJa,qBAAa,CAAA,EAAG,OAAA,EAAS5F,qCAAAA,EAAiB,4BAAA;kBAC5C2C,MAAM8C,QAAQA;kBACd7B,MAAM;gBACR;cACF;cACAyE,aAAa,OAAO1F,MAAM2F,cAAAA;AACxB,sBAAMf,QAAQe,UAAUZ,KAAKa,mBAAAA;AAC7B,sBAAMnG,SACJkG,UAAUE,SAAS,CAACC,aAAaA,oBAAoBC,2BAAAA,KACrDnB,OAAOS,WAAWU,4BAAe9D,QAAQ;AAC3C,oBAAI,CAAC2C,SAAS,CAACnF,QAAQ;AACrB;gBACF;AAEA,sBAAMuG,SAAS,MAAMrC,SAAS;kBAC5B;oBACElC,QAAQpE;oBACR6H,QAAQnB,qCAAeC;oBACvBhE,MAAM;sBAAEmC,MAAMnC,KAAKmC;sBAAMW,SAAS9C,KAAKA;oBAAK;kBAC9C;kBACA;oBACEkF,QAAQb,gCAAYC;oBACpBtE,MAAM;sBAAEP;oBAAO;kBACjB;iBACD;AAED,uBAAOuG,QAAQhG,KAAKkC;cACtB;YACF;;QAEJ;MACF;MACA+D,OAAO;QACLC,UAAU;UACR;YACEjG,IAAI;YACJqF,QAAQ;YACRrE,MAAM;cAAC;cAAe;gBAAE1C,IAAIlB;cAAgB;;YAC5CG,OAAO;cAAC;cAA8B;gBAAEe,IAAIlB;cAAgB;;YAC5DgF,MAAM,CAACC,UAAehF,8BAAAA,QAAA,cAACiF,qBAAWD,KAAAA;YAClCuB,QAAQ;cACNpC,QAAQpE;cACR6H,QAAQnB,qCAAeC;YACzB;UACF;;MAEJ;MACAmC,SAAS;QACPC,WAAW,CAAC,EAAEpG,MAAMqG,MAAM,GAAG/D,MAAAA,GAASgE,iBAAAA;AACpC,gBAAM1D,MACJ5C,KAAKuG,kBAAkBvE,qCACnBhC,KAAKuG,SACLvG,KAAKkC,kBAAkBF,qCACrBhC,KAAKkC,SACLxC;AAER,kBAAQ2G,MAAAA;YACN,KAAK;YACL,KAAK,WAAW;AACd,kBAAIzD,OAAOA,IAAIE,SAAS;AACtB,uBACExF,8BAAAA,QAAA,cAACuC,gBAAAA;kBACCwG;kBACAG,YAAYxG,KAAKwG;kBACjBC,UAAU7D;kBACVtC,oBAAoBD,MAAMI,OAAOH;kBACjCpD,UAAUA,SAASuD;kBACnBF,UAAUC,gBAAYkG,8BAAiB9D,GAAAA,CAAAA;kBACvC+D,kBAAkBjG;kBAClBkG,eAAAA;;cAGN,WAAW7G,cAAcC,KAAKkC,MAAM,GAAG;AACrC,uBACE5E,8BAAAA,QAAA,cAACwC,gBAAAA;kBACCG,IAAID,KAAKkC,OAAOjC;kBAChBoG;kBACAG,YAAYxG,KAAKwG;kBACjBK,cAAc7G,KAAKkC,OAAOhC;kBAC1BI,oBAAoBD,MAAMI,OAAOH;kBACjCwG,WAAW5J,SAASuD,OAAOjC;kBAC3BM,SAAS5B,SAASuD,OAAO3B;kBACzByB,UAAUC,YAAYR,KAAKkC,OAAOjC,EAAE;kBACpC0G,kBAAkBjG;kBAClBkG,eAAAA;;cAGN;AACA;YACF;YAEA,KAAK,QAAQ;AACX,sBACEG,+BAAS/G,KAAK8C,OAAO,KACrB,OAAO9C,KAAK8C,QAAQ7C,OAAO,YAC3BD,KAAK8C,QAAQZ,kBAAkBF,oCAC/B;AAGA,sBAAMgF,YAAY;kBAChB,GAAG1E;kBACH2E,MAAM;oBACJhH,IAAID,KAAK8C,QAAQ7C;oBACjBiC,QAAQlC,KAAK8C,QAAQZ;oBACrBgF,OAAO,OAAOlH,KAAK8C,QAAQoE,UAAU,WAAWlH,KAAK8C,QAAQoE,QAAQxH;kBACvE;gBACF;AAEA,2BAAOyH,6CAAqBH,SAAAA,IAC1B1J,8BAAAA,QAAA,cAACqC,cAAAA;kBAAc,GAAGqH;kBAAW9J,UAAUA,SAASuD;kBAAQ2G,KAAKd;qBAC3D;cACN;AACA;YACF;YAEA,KAAK,YAAY;AACf,qBAAOtG,KAAKyB,WAAWb,mCAAKX,KAAK3C,8BAAAA,QAAA,cAACL,kBAAAA;gBAAiBC,UAAUA,SAASuD;mBAAa;YACrF;UACF;AAEA,iBAAO;QACT;MACF;MACAoD,QAAQ;QACNwD,UAAU,CAAC,EAAEnC,QAAQlF,KAAI,MAAE;AACzB,kBAAQkF,QAAAA;YACN,KAAKnB,qCAAeC,QAAQ;AAC1B,oBAAMpB,UAAM0E,2BAAOtF,oCAAc;gBAC/BG,MAAMnC,MAAMmC;gBACZW,aAASwE,2BAAOjE,gCAAU;kBAAEP,SAAS9C,MAAM8C,WAAW;gBAAG,CAAA;gBACzDC,SAAS,CAAA;cACX,CAAA;AAEA,qBAAO;gBACL/C,MAAM4C;gBACN2E,SAAS;kBAAC;oBAAC;sBAAErC,QAAQsC,kCAAaC;sBAAkBzH,MAAM;wBAAEC,IAAI2C,IAAI3C;sBAAG;oBAAE;;;cAC3E;YACF;YAEA,KAAK8D,qCAAe2D,eAAe;AACjC,oBAAM,EAAEzH,IAAIM,SAAQ,IAAKP,QAAQ,CAAC;AAClC,kBAAI,OAAOC,OAAO,YAAY/B,uBAAAA,gBAAgByJ,SAASpH,QAAAA,GAAW;AAChEF,sBAAMI,OAAOF,SAASN,EAAAA,IAAMM;AAC5B,uBAAO;kBAAEP,MAAM;gBAAK;cACtB;AAEA;YACF;UACF;QACF;MACF;IACF;EACF;AACF;AM9UA,IAAA,cAAeG;",
6
+ "names": ["import_react", "import_app_framework", "import_react_ui", "import_react_ui_editor", "import_react_ui_theme", "MarkdownSettings", "settings", "t", "useTranslation", "MARKDOWN_PLUGIN", "React", "SettingsValue", "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", "DocumentCard", "lazy", "DocumentEditor", "MarkdownEditor", "isEditorModel", "data", "id", "text", "MarkdownPlugin", "LocalStorageStore", "state", "extensionProviders", "viewMode", "getViewMode", "values", "setViewMode", "nextViewMode", "meta", "ready", "plugins", "prop", "storageKey", "type", "enum", "allowUndefined", "bool", "string", "json", "markdownExtensionPlugins", "forEach", "plugin", "extensions", "provides", "markdown", "push", "metadata", "records", "DocumentType", "typename", "object", "name", "fallbackName", "icon", "props", "TextAa", "iconSymbol", "graphProps", "managesAutofocus", "loadReferences", "doc", "loadObjectReferences", "content", "threads", "serializer", "translations", "editorTranslations", "echo", "schema", "TextType", "graph", "builder", "client", "resolvePlugin", "parseClientPlugin", "dispatch", "parseIntentPlugin", "intent", "createExtension", "MarkdownAction", "CREATE", "filter", "node", "isActionGroup", "startsWith", "SpaceAction", "ADD_OBJECT", "actions", "split", "at", "spaceId", "objectId", "space", "spaces", "get", "find", "db", "getObjectById", "action", "NavigationAction", "OPEN", "properties", "testId", "inputType", "outputType", "serialize", "deserialize", "ancestors", "isSpace", "findLast", "ancestor", "CollectionType", "result", "stack", "creators", "surface", "component", "role", "forwardedRef", "active", "coordinate", "document", "fullyQualifiedId", "onViewModeChange", "scrollPastEnd", "initialValue", "inputMode", "isObject", "cardProps", "item", "color", "isTileComponentProps", "ref", "resolver", "create", "intents", "LayoutAction", "SCROLL_INTO_VIEW", "SET_VIEW_MODE", "includes"]
7
+ }
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var meta_exports = {};
20
+ __export(meta_exports, {
21
+ MARKDOWN_PLUGIN: () => import_chunk_TGMR2CKU.MARKDOWN_PLUGIN,
22
+ default: () => import_chunk_TGMR2CKU.meta_default
23
+ });
24
+ module.exports = __toCommonJS(meta_exports);
25
+ var import_chunk_TGMR2CKU = require("./chunk-TGMR2CKU.cjs");
26
+ // Annotate the CommonJS export names for ESM import in node:
27
+ 0 && (module.exports = {
28
+ MARKDOWN_PLUGIN
29
+ });
30
+ //# sourceMappingURL=meta.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["meta.cjs"],
4
+ "sourcesContent": ["import {\n MARKDOWN_PLUGIN,\n meta_default\n} from \"./chunk-TGMR2CKU.cjs\";\nexport {\n MARKDOWN_PLUGIN,\n meta_default as default\n};\n//# sourceMappingURL=meta.cjs.map\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAGO;",
6
+ "names": []
7
+ }