@dxos/plugin-markdown 0.7.5-main.9cb18ac → 0.7.5-main.9d2a38b

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 (165) hide show
  1. package/dist/lib/browser/{MarkdownContainer-XY6NEUOA.mjs → MarkdownContainer-ARRY4I6S.mjs} +95 -46
  2. package/dist/lib/browser/MarkdownContainer-ARRY4I6S.mjs.map +7 -0
  3. package/dist/lib/browser/app-graph-serializer-HHWSLYIW.mjs +51 -0
  4. package/dist/lib/browser/app-graph-serializer-HHWSLYIW.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-R4MG2DP2.mjs → chunk-ADAYSA5G.mjs} +20 -9
  6. package/dist/lib/browser/chunk-ADAYSA5G.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-6FIHBJRV.mjs → chunk-EMIIXXVX.mjs} +17 -12
  8. package/dist/lib/browser/chunk-EMIIXXVX.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-FSAYVXSE.mjs +16 -0
  10. package/dist/lib/browser/chunk-FSAYVXSE.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-4X6YX3KU.mjs → chunk-YB2TJFNH.mjs} +3 -3
  12. package/dist/lib/browser/chunk-YB2TJFNH.mjs.map +7 -0
  13. package/dist/lib/browser/chunk-YPDWX3WI.mjs +47 -0
  14. package/dist/lib/browser/chunk-YPDWX3WI.mjs.map +7 -0
  15. package/dist/lib/browser/index.mjs +100 -367
  16. package/dist/lib/browser/index.mjs.map +4 -4
  17. package/dist/lib/browser/intent-resolver-4KWMUMND.mjs +37 -0
  18. package/dist/lib/browser/intent-resolver-4KWMUMND.mjs.map +7 -0
  19. package/dist/lib/browser/meta.json +1 -1
  20. package/dist/lib/browser/react-surface-RL4CISJZ.mjs +152 -0
  21. package/dist/lib/browser/react-surface-RL4CISJZ.mjs.map +7 -0
  22. package/dist/lib/browser/settings-PTF73JDL.mjs +28 -0
  23. package/dist/lib/browser/settings-PTF73JDL.mjs.map +7 -0
  24. package/dist/lib/browser/state-DOVZP7XJ.mjs +37 -0
  25. package/dist/lib/browser/state-DOVZP7XJ.mjs.map +7 -0
  26. package/dist/lib/browser/thread-G4RS7NBZ.mjs +36 -0
  27. package/dist/lib/browser/thread-G4RS7NBZ.mjs.map +7 -0
  28. package/dist/lib/browser/types/index.mjs +4 -4
  29. package/dist/lib/node/{MarkdownContainer-EX6YDF6J.cjs → MarkdownContainer-TV6W64EN.cjs} +100 -53
  30. package/dist/lib/node/MarkdownContainer-TV6W64EN.cjs.map +7 -0
  31. package/dist/lib/node/app-graph-serializer-PJRST43Q.cjs +62 -0
  32. package/dist/lib/node/app-graph-serializer-PJRST43Q.cjs.map +7 -0
  33. package/dist/lib/node/{chunk-CQMXZ54Z.cjs → chunk-34WFGSZU.cjs} +21 -16
  34. package/dist/lib/node/chunk-34WFGSZU.cjs.map +7 -0
  35. package/dist/lib/node/chunk-7WZANRNS.cjs +64 -0
  36. package/dist/lib/node/chunk-7WZANRNS.cjs.map +7 -0
  37. package/dist/lib/node/{meta.cjs → chunk-G7WKHUGU.cjs} +13 -8
  38. package/dist/lib/node/chunk-G7WKHUGU.cjs.map +7 -0
  39. package/dist/lib/node/{chunk-PHHIPRJC.cjs → chunk-HTWAAR54.cjs} +7 -7
  40. package/dist/lib/node/chunk-HTWAAR54.cjs.map +7 -0
  41. package/dist/lib/node/{chunk-SXQAPZZU.cjs → chunk-UFFFUC6W.cjs} +37 -12
  42. package/dist/lib/node/chunk-UFFFUC6W.cjs.map +7 -0
  43. package/dist/lib/node/index.cjs +92 -366
  44. package/dist/lib/node/index.cjs.map +4 -4
  45. package/dist/lib/node/intent-resolver-QN25AFOP.cjs +50 -0
  46. package/dist/lib/node/intent-resolver-QN25AFOP.cjs.map +7 -0
  47. package/dist/lib/node/meta.json +1 -1
  48. package/dist/lib/node/react-surface-RZ2XV56V.cjs +165 -0
  49. package/dist/lib/node/react-surface-RZ2XV56V.cjs.map +7 -0
  50. package/dist/lib/node/settings-BO5P5R4I.cjs +42 -0
  51. package/dist/lib/node/settings-BO5P5R4I.cjs.map +7 -0
  52. package/dist/lib/node/state-F26NQP7F.cjs +51 -0
  53. package/dist/lib/node/state-F26NQP7F.cjs.map +7 -0
  54. package/dist/lib/node/thread-THWQ67WS.cjs +52 -0
  55. package/dist/lib/node/thread-THWQ67WS.cjs.map +7 -0
  56. package/dist/lib/node/types/index.cjs +7 -7
  57. package/dist/lib/node/types/index.cjs.map +1 -1
  58. package/dist/lib/node-esm/{MarkdownContainer-E7W623A7.mjs → MarkdownContainer-3ZHQTTMQ.mjs} +95 -46
  59. package/dist/lib/node-esm/MarkdownContainer-3ZHQTTMQ.mjs.map +7 -0
  60. package/dist/lib/node-esm/app-graph-serializer-JTHJUUS2.mjs +52 -0
  61. package/dist/lib/node-esm/app-graph-serializer-JTHJUUS2.mjs.map +7 -0
  62. package/dist/lib/node-esm/chunk-2GHK262V.mjs +17 -0
  63. package/dist/lib/node-esm/chunk-2GHK262V.mjs.map +7 -0
  64. package/dist/lib/node-esm/{chunk-BABK7FMW.mjs → chunk-AOKWCL3O.mjs} +3 -3
  65. package/dist/lib/node-esm/chunk-AOKWCL3O.mjs.map +7 -0
  66. package/dist/lib/node-esm/{chunk-ZVFBKBSA.mjs → chunk-CDFNMFGT.mjs} +17 -12
  67. package/dist/lib/node-esm/chunk-CDFNMFGT.mjs.map +7 -0
  68. package/dist/lib/node-esm/chunk-HLP536EW.mjs +48 -0
  69. package/dist/lib/node-esm/chunk-HLP536EW.mjs.map +7 -0
  70. package/dist/lib/node-esm/{chunk-Y76MM22C.mjs → chunk-Y5RSQVGH.mjs} +20 -9
  71. package/dist/lib/node-esm/chunk-Y5RSQVGH.mjs.map +7 -0
  72. package/dist/lib/node-esm/index.mjs +100 -367
  73. package/dist/lib/node-esm/index.mjs.map +4 -4
  74. package/dist/lib/node-esm/intent-resolver-F7MQOTG7.mjs +38 -0
  75. package/dist/lib/node-esm/intent-resolver-F7MQOTG7.mjs.map +7 -0
  76. package/dist/lib/node-esm/meta.json +1 -1
  77. package/dist/lib/node-esm/react-surface-RRXHEW4R.mjs +153 -0
  78. package/dist/lib/node-esm/react-surface-RRXHEW4R.mjs.map +7 -0
  79. package/dist/lib/node-esm/settings-E7P5FQ3F.mjs +29 -0
  80. package/dist/lib/node-esm/settings-E7P5FQ3F.mjs.map +7 -0
  81. package/dist/lib/node-esm/state-HXSOQNOV.mjs +38 -0
  82. package/dist/lib/node-esm/state-HXSOQNOV.mjs.map +7 -0
  83. package/dist/lib/node-esm/thread-CYEXBXTW.mjs +37 -0
  84. package/dist/lib/node-esm/thread-CYEXBXTW.mjs.map +7 -0
  85. package/dist/lib/node-esm/types/index.mjs +4 -4
  86. package/dist/types/src/MarkdownPlugin.d.ts +1 -3
  87. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  88. package/dist/types/src/capabilities/app-graph-serializer.d.ts +4 -0
  89. package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
  90. package/dist/types/src/capabilities/capabilities.d.ts +12 -0
  91. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
  92. package/dist/types/src/capabilities/index.d.ts +16 -0
  93. package/dist/types/src/capabilities/index.d.ts.map +1 -0
  94. package/dist/types/src/capabilities/intent-resolver.d.ts +4 -0
  95. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
  96. package/dist/types/src/capabilities/react-surface.d.ts +4 -0
  97. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  98. package/dist/types/src/capabilities/settings.d.ts +4 -0
  99. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  100. package/dist/types/src/capabilities/state.d.ts +11 -0
  101. package/dist/types/src/capabilities/state.d.ts.map +1 -0
  102. package/dist/types/src/capabilities/thread.d.ts +6 -0
  103. package/dist/types/src/capabilities/thread.d.ts.map +1 -0
  104. package/dist/types/src/components/MarkdownContainer.d.ts +1 -1
  105. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  106. package/dist/types/src/components/MarkdownEditor.d.ts +15 -0
  107. package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
  108. package/dist/types/src/components/MarkdownEditor.stories.d.ts.map +1 -1
  109. package/dist/types/src/components/Toolbar.stories.d.ts +2 -2
  110. package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
  111. package/dist/types/src/components/index.d.ts +1 -1
  112. package/dist/types/src/components/index.d.ts.map +1 -1
  113. package/dist/types/src/extensions.d.ts +2 -2
  114. package/dist/types/src/extensions.d.ts.map +1 -1
  115. package/dist/types/src/index.d.ts +2 -3
  116. package/dist/types/src/index.d.ts.map +1 -1
  117. package/dist/types/src/meta.d.ts +1 -2
  118. package/dist/types/src/meta.d.ts.map +1 -1
  119. package/dist/types/src/translations.d.ts +3 -0
  120. package/dist/types/src/translations.d.ts.map +1 -1
  121. package/dist/types/src/types/schema.d.ts +0 -7
  122. package/dist/types/src/types/schema.d.ts.map +1 -1
  123. package/dist/types/src/types/types.d.ts +12 -26
  124. package/dist/types/src/types/types.d.ts.map +1 -1
  125. package/dist/types/src/util.d.ts +1 -5
  126. package/dist/types/src/util.d.ts.map +1 -1
  127. package/dist/types/tsconfig.tsbuildinfo +1 -1
  128. package/package.json +32 -37
  129. package/src/MarkdownPlugin.tsx +79 -213
  130. package/src/capabilities/app-graph-serializer.ts +50 -0
  131. package/src/capabilities/capabilities.ts +20 -0
  132. package/src/capabilities/index.ts +14 -0
  133. package/src/capabilities/intent-resolver.ts +27 -0
  134. package/src/capabilities/react-surface.tsx +73 -0
  135. package/src/capabilities/settings.ts +25 -0
  136. package/src/capabilities/state.ts +31 -0
  137. package/src/capabilities/thread.ts +34 -0
  138. package/src/components/MarkdownContainer.tsx +6 -7
  139. package/src/components/MarkdownEditor.stories.tsx +16 -5
  140. package/src/components/MarkdownEditor.tsx +82 -48
  141. package/src/components/Toolbar.stories.tsx +16 -22
  142. package/src/extensions.tsx +13 -10
  143. package/src/index.ts +2 -5
  144. package/src/meta.ts +1 -1
  145. package/src/translations.ts +1 -0
  146. package/src/types/schema.ts +1 -5
  147. package/src/types/types.ts +16 -44
  148. package/src/util.tsx +2 -8
  149. package/dist/lib/browser/MarkdownContainer-XY6NEUOA.mjs.map +0 -7
  150. package/dist/lib/browser/chunk-4X6YX3KU.mjs.map +0 -7
  151. package/dist/lib/browser/chunk-6FIHBJRV.mjs.map +0 -7
  152. package/dist/lib/browser/chunk-R4MG2DP2.mjs.map +0 -7
  153. package/dist/lib/browser/meta.mjs +0 -9
  154. package/dist/lib/browser/meta.mjs.map +0 -7
  155. package/dist/lib/node/MarkdownContainer-EX6YDF6J.cjs.map +0 -7
  156. package/dist/lib/node/chunk-CQMXZ54Z.cjs.map +0 -7
  157. package/dist/lib/node/chunk-PHHIPRJC.cjs.map +0 -7
  158. package/dist/lib/node/chunk-SXQAPZZU.cjs.map +0 -7
  159. package/dist/lib/node/meta.cjs.map +0 -7
  160. package/dist/lib/node-esm/MarkdownContainer-E7W623A7.mjs.map +0 -7
  161. package/dist/lib/node-esm/chunk-BABK7FMW.mjs.map +0 -7
  162. package/dist/lib/node-esm/chunk-Y76MM22C.mjs.map +0 -7
  163. package/dist/lib/node-esm/chunk-ZVFBKBSA.mjs.map +0 -7
  164. package/dist/lib/node-esm/meta.mjs +0 -10
  165. package/dist/lib/node-esm/meta.mjs.map +0 -7
@@ -26,26 +26,26 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
26
26
  mod
27
27
  ));
28
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
- var MarkdownContainer_EX6YDF6J_exports = {};
30
- __export(MarkdownContainer_EX6YDF6J_exports, {
29
+ var MarkdownContainer_TV6W64EN_exports = {};
30
+ __export(MarkdownContainer_TV6W64EN_exports, {
31
31
  DocumentEditor: () => DocumentEditor,
32
32
  default: () => MarkdownContainer_default
33
33
  });
34
- module.exports = __toCommonJS(MarkdownContainer_EX6YDF6J_exports);
35
- var import_chunk_SXQAPZZU = require("./chunk-SXQAPZZU.cjs");
36
- var import_chunk_CQMXZ54Z = require("./chunk-CQMXZ54Z.cjs");
37
- var import_chunk_PHHIPRJC = require("./chunk-PHHIPRJC.cjs");
34
+ module.exports = __toCommonJS(MarkdownContainer_TV6W64EN_exports);
35
+ var import_chunk_UFFFUC6W = require("./chunk-UFFFUC6W.cjs");
36
+ var import_chunk_34WFGSZU = require("./chunk-34WFGSZU.cjs");
37
+ var import_chunk_G7WKHUGU = require("./chunk-G7WKHUGU.cjs");
38
+ var import_chunk_HTWAAR54 = require("./chunk-HTWAAR54.cjs");
38
39
  var import_react = __toESM(require("react"));
39
40
  var import_app_framework = require("@dxos/app-framework");
40
41
  var import_echo = require("@dxos/react-client/echo");
41
42
  var import_search = require("@codemirror/search");
42
43
  var import_react2 = __toESM(require("react"));
44
+ var import_react_dropzone = require("react-dropzone");
43
45
  var import_app_framework2 = require("@dxos/app-framework");
44
46
  var import_react_ui = require("@dxos/react-ui");
45
- var import_react_ui_attention = require("@dxos/react-ui-attention");
46
47
  var import_react_ui_editor = require("@dxos/react-ui-editor");
47
48
  var import_react_ui_stack = require("@dxos/react-ui-stack");
48
- var import_react_ui_theme = require("@dxos/react-ui-theme");
49
49
  var import_util = require("@dxos/util");
50
50
  var import_view = require("@codemirror/view");
51
51
  var import_react3 = require("react");
@@ -60,7 +60,7 @@ var import_echo2 = require("@dxos/react-client/echo");
60
60
  var import_halo = require("@dxos/react-client/halo");
61
61
  var import_react_ui2 = require("@dxos/react-ui");
62
62
  var import_react_ui_editor3 = require("@dxos/react-ui-editor");
63
- var import_react_ui_theme2 = require("@dxos/react-ui-theme");
63
+ var import_react_ui_theme = require("@dxos/react-ui-theme");
64
64
  var import_util2 = require("@dxos/util");
65
65
  var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-markdown/src/hooks/useSelectCurrentThread.tsx";
66
66
  var useSelectCurrentThread = (editorView, documentId) => {
@@ -105,22 +105,23 @@ var useSelectCurrentThread = (editorView, documentId) => {
105
105
  documentId,
106
106
  editorView
107
107
  ]);
108
- (0, import_app_framework3.useIntentResolver)(import_chunk_PHHIPRJC.MARKDOWN_PLUGIN, scrollIntoViewResolver);
108
+ (0, import_app_framework3.useIntentResolver)(import_chunk_HTWAAR54.MARKDOWN_PLUGIN, scrollIntoViewResolver);
109
109
  };
110
- var DEFAULT_VIEW_MODE = "preview";
111
110
  var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensionProviders, scrollPastEnd, toolbar, viewMode, editorStateStore, onFileUpload, onViewModeChange }) => {
112
- const { t } = (0, import_react_ui.useTranslation)(import_chunk_PHHIPRJC.MARKDOWN_PLUGIN);
111
+ const { t } = (0, import_react_ui.useTranslation)(import_chunk_HTWAAR54.MARKDOWN_PLUGIN);
113
112
  const { themeMode } = (0, import_react_ui.useThemeContext)();
114
113
  const { dispatchPromise: dispatch } = (0, import_app_framework2.useIntentDispatcher)();
115
- const [formattingState, formattingObserver] = (0, import_react_ui_editor.useFormattingState)();
116
- const { hasAttention } = (0, import_react_ui_attention.useAttention)(id);
114
+ const toolbarState = (0, import_react_ui_editor.useEditorToolbarState)({
115
+ viewMode
116
+ });
117
+ const formattingObserver = (0, import_react_ui_editor.useFormattingState)(toolbarState);
117
118
  const { scrollTo, selection } = (0, import_react2.useMemo)(() => editorStateStore?.getState(id) ?? {}, [
118
119
  id
119
120
  ]);
120
121
  const providerExtensions = (0, import_react2.useMemo)(() => extensionProviders?.flatMap((provider) => provider({})).filter(import_util.nonNullable), [
121
122
  extensionProviders
122
123
  ]);
123
- const [commentsState, commentObserver] = (0, import_react_ui_editor.useCommentState)();
124
+ const commentObserver = (0, import_react_ui_editor.useCommentState)(toolbarState);
124
125
  const onCommentClick = (0, import_react2.useCallback)(async () => {
125
126
  await dispatch((0, import_app_framework2.createIntent)(import_app_framework2.NavigationAction.Open, {
126
127
  activeParts: {
@@ -139,7 +140,7 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
139
140
  const file = files[0];
140
141
  const info = file && onFileUpload ? await onFileUpload(file) : void 0;
141
142
  if (info) {
142
- (0, import_react_ui_editor.processAction)(view, {
143
+ (0, import_react_ui_editor.processEditorPayload)(view, {
143
144
  type: "image",
144
145
  data: info.url
145
146
  });
@@ -193,9 +194,44 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
193
194
  ]);
194
195
  useTest(editorView);
195
196
  useSelectCurrentThread(editorView, id);
197
+ const { acceptedFiles, getInputProps, open } = (0, import_react_dropzone.useDropzone)({
198
+ multiple: false,
199
+ noDrag: true,
200
+ accept: {
201
+ "image/*": [
202
+ ".jpg",
203
+ ".jpeg",
204
+ ".png",
205
+ ".gif"
206
+ ]
207
+ }
208
+ });
209
+ (0, import_react2.useEffect)(() => {
210
+ if (editorView && onFileUpload && acceptedFiles.length) {
211
+ requestAnimationFrame(async () => {
212
+ const f = acceptedFiles[0];
213
+ const file = new File([
214
+ f
215
+ ], f.name, {
216
+ type: f.type,
217
+ lastModified: f.lastModified
218
+ });
219
+ const info = await onFileUpload(file);
220
+ if (info) {
221
+ (0, import_react_ui_editor.processEditorPayload)(editorView, {
222
+ type: "image",
223
+ data: info.url
224
+ });
225
+ }
226
+ });
227
+ }
228
+ }, [
229
+ acceptedFiles,
230
+ editorView
231
+ ]);
196
232
  const handleToolbarAction = (0, import_react_ui_editor.useActionHandler)(editorView);
197
- const handleAction = (action) => {
198
- switch (action.type) {
233
+ const handleAction = (0, import_react2.useCallback)((action) => {
234
+ switch (action.properties.type) {
199
235
  case "search": {
200
236
  if (editorView) {
201
237
  (0, import_search.openSearchPanel)(editorView);
@@ -203,37 +239,34 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
203
239
  return;
204
240
  }
205
241
  case "view-mode": {
206
- onViewModeChange?.(id, action.data);
242
+ onViewModeChange?.(id, action.properties.data);
243
+ return;
244
+ }
245
+ case "image": {
246
+ open();
207
247
  return;
208
248
  }
209
249
  }
210
250
  handleToolbarAction?.(action);
211
- };
251
+ }, [
252
+ editorView,
253
+ onViewModeChange,
254
+ open
255
+ ]);
212
256
  return /* @__PURE__ */ import_react2.default.createElement(import_react_ui_stack.StackItem.Content, {
213
- toolbar
214
- }, toolbar && /* @__PURE__ */ import_react2.default.createElement("div", {
215
- role: "none",
216
- className: (0, import_react_ui_theme.mx)("attention-surface is-full border-be !border-separator", role === "section" && "sticky block-start-0 z-[1] -mbe-px min-is-0")
217
- }, /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.Toolbar.Root, {
218
- classNames: [
219
- import_react_ui_theme.textBlockWidth,
220
- !hasAttention && "opacity-20"
221
- ],
222
- state: formattingState && {
223
- ...formattingState,
224
- ...commentsState
225
- },
257
+ toolbar: !!toolbar
258
+ }, toolbar && /* @__PURE__ */ import_react2.default.createElement(import_react2.default.Fragment, null, /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.EditorToolbar, {
259
+ attendableId: id,
260
+ role,
261
+ state: toolbarState,
262
+ customActions: onFileUpload ? createUploadAction : void 0,
226
263
  onAction: handleAction
227
- }, /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.Toolbar.Markdown, null), onFileUpload && /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.Toolbar.Custom, {
228
- onUpload: onFileUpload
229
- }), /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.Toolbar.Separator, null), /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.Toolbar.View, {
230
- mode: viewMode ?? DEFAULT_VIEW_MODE
231
- }), /* @__PURE__ */ import_react2.default.createElement(import_react_ui_editor.Toolbar.Actions, null))), /* @__PURE__ */ import_react2.default.createElement("div", {
264
+ }), /* @__PURE__ */ import_react2.default.createElement("input", getInputProps())), /* @__PURE__ */ import_react2.default.createElement("div", {
232
265
  role: "none",
233
266
  ref: parentRef,
234
267
  "data-testid": "composer.markdownRoot",
235
268
  "data-toolbar": toolbar ? "enabled" : "disabled",
236
- className: (0, import_react_ui_theme.mx)("ch-focus-ring-inset data-[toolbar=disabled]:pbs-2 attention-surface", role === "article" ? "min-bs-0" : "[&_.cm-scroller]:overflow-hidden [&_.cm-scroller]:min-bs-24"),
269
+ className: (0, import_react_ui_editor.stackItemContentEditorClassNames)(role),
237
270
  ...focusAttributes
238
271
  }));
239
272
  };
@@ -247,8 +280,22 @@ var useTest = (view) => {
247
280
  view
248
281
  ]);
249
282
  };
283
+ var createUploadAction = () => ({
284
+ nodes: [
285
+ (0, import_react_ui_editor.createEditorAction)({
286
+ type: "image",
287
+ testId: "editor.toolbar.image"
288
+ }, "ph--image-square--regular", "upload image label")
289
+ ],
290
+ edges: [
291
+ {
292
+ source: "root",
293
+ target: "image"
294
+ }
295
+ ]
296
+ });
250
297
  var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
251
- var useExtensions = ({ document, settings, viewMode, editorStateStore, extensionProviders }) => {
298
+ var useExtensions = ({ document, settings, viewMode, editorStateStore }) => {
252
299
  const { dispatchPromise: dispatch } = (0, import_app_framework4.useIntentDispatcher)();
253
300
  const identity = (0, import_halo.useIdentity)();
254
301
  const space = (0, import_echo2.getSpace)(document);
@@ -268,7 +315,8 @@ var useExtensions = ({ document, settings, viewMode, editorStateStore, extension
268
315
  settings.debug,
269
316
  settings.typewriter
270
317
  ]);
271
- const pluginExtensions = (0, import_react4.useMemo)(() => extensionProviders?.reduce((acc, provider) => {
318
+ const extensionProviders = (0, import_app_framework4.useCapabilities)(import_chunk_G7WKHUGU.MarkdownCapabilities.Extensions);
319
+ const pluginExtensions = (0, import_react4.useMemo)(() => extensionProviders.flat().reduce((acc, provider) => {
272
320
  const extension = typeof provider === "function" ? provider({
273
321
  document
274
322
  }) : provider;
@@ -292,7 +340,7 @@ var useExtensions = ({ document, settings, viewMode, editorStateStore, extension
292
340
  }),
293
341
  (0, import_react_ui_editor3.selectionState)(editorStateStore),
294
342
  document && (0, import_react_ui_editor3.listener)({
295
- onChange: (text) => (0, import_chunk_SXQAPZZU.setFallbackName)(document, text)
343
+ onChange: (text) => (0, import_chunk_UFFFUC6W.setFallbackName)(document, text)
296
344
  }),
297
345
  baseExtensions,
298
346
  pluginExtensions
@@ -364,7 +412,7 @@ var onRenderLink = (onSelectObject) => (el, url) => {
364
412
  const qualifiedId = url.split("/").at(-1);
365
413
  (0, import_invariant2.invariant)(qualifiedId, "Invalid link format.", {
366
414
  F: __dxlog_file2,
367
- L: 214,
415
+ L: 217,
368
416
  S: void 0,
369
417
  A: [
370
418
  "qualifiedId",
@@ -402,15 +450,14 @@ var renderLinkTooltip = (el, url) => {
402
450
  };
403
451
  var renderRoot = (root, node) => {
404
452
  (0, import_client.createRoot)(root).render(/* @__PURE__ */ import_react4.default.createElement(import_react_ui2.ThemeProvider, {
405
- tx: import_react_ui_theme2.defaultTx
453
+ tx: import_react_ui_theme.defaultTx
406
454
  }, node));
407
455
  return root;
408
456
  };
409
- var MarkdownContainer = ({ id, role, object, extensionProviders, settings, viewMode, editorStateStore, onViewModeChange }) => {
457
+ var MarkdownContainer = ({ id, role, object, settings, viewMode, editorStateStore, onViewModeChange }) => {
410
458
  const scrollPastEnd = role === "article";
411
- const doc = object instanceof import_chunk_CQMXZ54Z.DocumentType ? object : void 0;
459
+ const doc = object instanceof import_chunk_34WFGSZU.DocumentType ? object : void 0;
412
460
  const extensions = useExtensions({
413
- extensionProviders,
414
461
  document: doc,
415
462
  settings,
416
463
  viewMode,
@@ -447,7 +494,7 @@ var DocumentEditor = ({ id, document: doc, settings, viewMode, ...props }) => {
447
494
  if (typeof doc.fallbackName === "string") {
448
495
  return;
449
496
  }
450
- const fallbackName = doc.content?.target?.content ? (0, import_chunk_SXQAPZZU.getFallbackName)(doc.content.target.content) : void 0;
497
+ const fallbackName = doc.content?.target?.content ? (0, import_chunk_UFFFUC6W.getFallbackName)(doc.content.target.content) : void 0;
451
498
  if (fallbackName) {
452
499
  doc.fallbackName = fallbackName;
453
500
  }
@@ -455,15 +502,15 @@ var DocumentEditor = ({ id, document: doc, settings, viewMode, ...props }) => {
455
502
  doc,
456
503
  doc.content
457
504
  ]);
458
- const fileManagerPlugin = (0, import_app_framework.useResolvePlugin)(import_app_framework.parseFileManagerPlugin);
505
+ const [upload] = (0, import_app_framework.useCapabilities)(import_app_framework.Capabilities.FileUploader);
459
506
  const handleFileUpload = (0, import_react.useMemo)(() => {
460
- if (space === void 0 || fileManagerPlugin?.provides.file.upload === void 0) {
507
+ if (space === void 0 || upload === void 0) {
461
508
  return void 0;
462
509
  }
463
- return async (file) => fileManagerPlugin?.provides?.file?.upload?.(file, space);
510
+ return async (file) => upload(file, space);
464
511
  }, [
465
512
  space,
466
- fileManagerPlugin
513
+ upload
467
514
  ]);
468
515
  return /* @__PURE__ */ import_react.default.createElement(MarkdownEditor, {
469
516
  id,
@@ -480,4 +527,4 @@ var MarkdownContainer_default = MarkdownContainer;
480
527
  0 && (module.exports = {
481
528
  DocumentEditor
482
529
  });
483
- //# sourceMappingURL=MarkdownContainer-EX6YDF6J.cjs.map
530
+ //# sourceMappingURL=MarkdownContainer-TV6W64EN.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/MarkdownContainer.tsx", "../../../src/components/MarkdownEditor.tsx", "../../../src/hooks/useSelectCurrentThread.tsx", "../../../src/extensions.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useEffect, useMemo } from 'react';\n\nimport { Capabilities, useCapabilities } from '@dxos/app-framework';\nimport { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\n\nimport { MarkdownEditor, type MarkdownEditorProps } from './MarkdownEditor';\nimport { useExtensions } from '../extensions';\nimport { DocumentType, type MarkdownSettingsProps } from '../types';\nimport { getFallbackName } from '../util';\n\nexport type MarkdownContainerProps = Pick<\n MarkdownEditorProps,\n 'role' | 'extensionProviders' | 'viewMode' | 'editorStateStore' | 'onViewModeChange'\n> & {\n id: string;\n object: DocumentType | any;\n settings: MarkdownSettingsProps;\n};\n\n// TODO(burdon): Move toolbar here.\n// TODO(burdon): Factor out difference for ECHO and non-ECHO objects; i.e., single component.\nconst MarkdownContainer = ({\n id,\n role,\n object,\n settings,\n viewMode,\n editorStateStore,\n onViewModeChange,\n}: MarkdownContainerProps) => {\n const scrollPastEnd = role === 'article';\n const doc = object instanceof DocumentType ? object : undefined;\n const extensions = useExtensions({ document: doc, settings, viewMode, editorStateStore });\n\n if (doc) {\n return (\n <DocumentEditor\n id={fullyQualifiedId(object)}\n role={role}\n document={doc}\n extensions={extensions}\n viewMode={viewMode}\n settings={settings}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n />\n );\n } else {\n return (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={object.text}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n />\n );\n }\n};\n\ntype DocumentEditorProps = Omit<MarkdownContainerProps, 'object' | 'extensionProviders' | 'editorStateStore'> &\n Pick<MarkdownEditorProps, 'id' | 'scrollPastEnd' | 'extensions'> & {\n document: DocumentType;\n };\n\nexport const DocumentEditor = ({ id, document: doc, settings, viewMode, ...props }: DocumentEditorProps) => {\n const space = getSpace(doc);\n\n // Migrate gradually to `fallbackName`.\n useEffect(() => {\n if (typeof doc.fallbackName === 'string') {\n return;\n }\n\n const fallbackName = doc.content?.target?.content ? getFallbackName(doc.content.target.content) : undefined;\n if (fallbackName) {\n doc.fallbackName = fallbackName;\n }\n }, [doc, doc.content]);\n\n // File dragging.\n const [upload] = useCapabilities(Capabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (space === undefined || upload === undefined) {\n return undefined;\n }\n\n // TODO(burdon): Re-order props: space, file.\n return async (file: File) => upload!(file, space);\n }, [space, upload]);\n\n return (\n <MarkdownEditor\n id={id}\n initialValue={doc.content?.target?.content}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n onFileUpload={handleFileUpload}\n {...props}\n />\n );\n};\n\nexport default MarkdownContainer;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { openSearchPanel } from '@codemirror/search';\nimport { type EditorView } from '@codemirror/view';\nimport React, { useMemo, useEffect, useCallback } from 'react';\nimport { useDropzone } from 'react-dropzone';\n\nimport { createIntent, type FileInfo, LayoutAction, NavigationAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type EditorAction,\n type DNDOptions,\n type EditorViewMode,\n type EditorInputMode,\n type EditorSelectionState,\n type EditorStateStore,\n EditorToolbar,\n type UseTextEditorProps,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorContent,\n editorGutter,\n processEditorPayload,\n useActionHandler,\n useCommentState,\n useCommentClickListener,\n useFormattingState,\n useTextEditor,\n stackItemContentEditorClassNames,\n useEditorToolbarState,\n createEditorAction,\n} from '@dxos/react-ui-editor';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { isNotFalsy, nonNullable } from '@dxos/util';\n\nimport { useSelectCurrentThread } from '../hooks';\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { type MarkdownPluginState } from '../types';\n\nexport type MarkdownEditorProps = {\n id: string;\n role?: string;\n inputMode?: EditorInputMode;\n scrollPastEnd?: boolean;\n toolbar?: boolean;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n onViewModeChange?: (id: string, mode: EditorViewMode) => void;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n} & Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &\n Partial<Pick<MarkdownPluginState, 'extensionProviders'>>;\n\n/**\n * Base markdown editor component.\n *\n * This component provides all the features of the markdown editor that do no depend on ECHO.\n * This allows it to be used as a common editor for markdown content on arbitrary backends (e.g. files).\n */\nexport const MarkdownEditor = ({\n id,\n role = 'article',\n initialValue,\n extensions,\n extensionProviders,\n scrollPastEnd,\n toolbar,\n viewMode,\n editorStateStore,\n onFileUpload,\n onViewModeChange,\n}: MarkdownEditorProps) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n const { themeMode } = useThemeContext();\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const toolbarState = useEditorToolbarState({ viewMode });\n const formattingObserver = useFormattingState(toolbarState);\n\n // Restore last selection and scroll point.\n const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);\n\n // Extensions from other plugins.\n // TODO(burdon): Reconcile with DocumentEditor.useExtensions.\n const providerExtensions = useMemo(\n () => extensionProviders?.flatMap((provider) => provider({})).filter(nonNullable),\n [extensionProviders],\n );\n\n // TODO(Zan): Factor out to thread plugin.\n const commentObserver = useCommentState(toolbarState);\n const onCommentClick = useCallback(async () => {\n await dispatch(createIntent(NavigationAction.Open, { activeParts: { complementary: 'comments' } }));\n await dispatch(createIntent(LayoutAction.SetLayout, { element: 'complementary', state: true }));\n }, [dispatch]);\n const commentClickObserver = useCommentClickListener(onCommentClick);\n\n // TODO(wittjosiah): Factor out to file uploader plugin.\n // Drag files.\n const handleDrop: DNDOptions['onDrop'] = async (view, { files }) => {\n const file = files[0];\n const info = file && onFileUpload ? await onFileUpload(file) : undefined;\n if (info) {\n processEditorPayload(view, { type: 'image', data: info.url });\n }\n };\n\n const {\n parentRef,\n view: editorView,\n focusAttributes,\n } = useTextEditor(\n () => ({\n initialValue,\n extensions: [\n formattingObserver,\n commentObserver,\n commentClickObserver,\n createBasicExtensions({\n readonly: viewMode === 'readonly',\n placeholder: t('editor placeholder'),\n scrollPastEnd: role === 'section' ? false : scrollPastEnd,\n }),\n createMarkdownExtensions({ themeMode }),\n createThemeExtensions({\n themeMode,\n syntaxHighlighting: true,\n slots: { content: { className: editorContent } },\n }),\n editorGutter,\n role !== 'section' && onFileUpload && dropFile({ onDrop: handleDrop }),\n providerExtensions,\n extensions,\n ].filter(isNotFalsy),\n ...(role !== 'section' && {\n id,\n scrollTo,\n selection,\n // TODO(wittjosiah): Autofocus based on layout is racy.\n // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,\n moveToEndOfLine: true,\n }),\n }),\n [id, formattingObserver, viewMode, themeMode, extensions, providerExtensions],\n );\n\n useTest(editorView);\n useSelectCurrentThread(editorView, id);\n\n // https://react-dropzone.js.org/#src\n const { acceptedFiles, getInputProps, open } = useDropzone({\n multiple: false,\n noDrag: true,\n accept: {\n 'image/*': ['.jpg', '.jpeg', '.png', '.gif'],\n },\n });\n\n useEffect(() => {\n if (editorView && onFileUpload && acceptedFiles.length) {\n requestAnimationFrame(async () => {\n // NOTE: Clone file since react-dropzone patches in a non-standard `path` property, which confuses IPFS.\n const f = acceptedFiles[0];\n const file = new File([f], f.name, {\n type: f.type,\n lastModified: f.lastModified,\n });\n\n const info = await onFileUpload(file);\n if (info) {\n processEditorPayload(editorView, { type: 'image', data: info.url });\n }\n });\n }\n }, [acceptedFiles, editorView]);\n\n // Toolbar handler.\n const handleToolbarAction = useActionHandler(editorView);\n const handleAction = useCallback(\n (action: EditorAction) => {\n switch (action.properties.type) {\n case 'search': {\n if (editorView) {\n openSearchPanel(editorView);\n }\n return;\n }\n case 'view-mode': {\n onViewModeChange?.(id, action.properties.data);\n return;\n }\n case 'image': {\n open();\n return;\n }\n }\n\n handleToolbarAction?.(action);\n },\n [editorView, onViewModeChange, open],\n );\n\n return (\n <StackItem.Content toolbar={!!toolbar}>\n {toolbar && (\n <>\n <EditorToolbar\n attendableId={id}\n role={role}\n state={toolbarState}\n customActions={onFileUpload ? createUploadAction : undefined}\n onAction={handleAction}\n />\n <input {...getInputProps()} />\n </>\n )}\n <div\n role='none'\n ref={parentRef}\n data-testid='composer.markdownRoot'\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n className={stackItemContentEditorClassNames(role)}\n {...focusAttributes}\n />\n </StackItem.Content>\n );\n};\n\n// Expose editor view for playwright tests.\n// TODO(wittjosiah): Find a better way to expose this or find a way to limit it to test runs.\nconst useTest = (view?: EditorView) => {\n useEffect(() => {\n const composer = (window as any).composer;\n if (composer) {\n composer.editorView = view;\n }\n }, [view]);\n};\n\nexport const createUploadAction = () => ({\n nodes: [\n createEditorAction(\n { type: 'image', testId: 'editor.toolbar.image' },\n 'ph--image-square--regular',\n 'upload image label',\n ),\n ],\n edges: [{ source: 'root', target: 'image' }],\n});\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport { useMemo } from 'react';\n\nimport { createResolver, LayoutAction, useIntentResolver } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { Cursor, setSelection } from '@dxos/react-ui-editor';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\n\n/**\n * Handle scrolling and selection of the current thread in a markdown editor.\n */\nexport const useSelectCurrentThread = (editorView: EditorView | undefined, documentId: string) => {\n const scrollIntoViewResolver = useMemo(\n () =>\n createResolver(\n LayoutAction.ScrollIntoView,\n ({ cursor }) => {\n invariant(editorView, 'Editor view is not defined.');\n const range = Cursor.getRangeFromCursor(editorView.state, cursor!);\n if (range) {\n const selection = editorView.state.selection.main.from !== range.from ? { anchor: range.from } : undefined;\n const effects = [\n // NOTE: This does not use the DOM scrollIntoView function.\n EditorView.scrollIntoView(range.from, { y: 'start', yMargin: 96 }),\n ];\n if (selection) {\n // Update the editor selection to get bi-directional highlighting.\n effects.push(setSelection.of({ current: documentId }));\n }\n\n editorView.dispatch({\n effects,\n selection: selection ? { anchor: range.from } : undefined,\n });\n }\n },\n {\n disposition: 'hoist',\n filter: (data) => !!editorView && data.id === documentId && !!data.cursor,\n },\n ),\n [documentId, editorView],\n );\n\n useIntentResolver(MARKDOWN_PLUGIN, scrollIntoViewResolver);\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport {\n createIntent,\n NavigationAction,\n type PromiseIntentDispatcher,\n useCapabilities,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { createDocAccessor, fullyQualifiedId, getSpace, type Query } from '@dxos/react-client/echo';\nimport { useIdentity } from '@dxos/react-client/halo';\nimport { Icon, ThemeProvider } from '@dxos/react-ui';\nimport {\n type AutocompleteResult,\n type EditorStateStore,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n createDataExtensions,\n autocomplete,\n decorateMarkdown,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n selectionState,\n typewriter,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { isNotFalsy } from '@dxos/util';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { type DocumentType, type MarkdownSettingsProps } from './types';\nimport { setFallbackName } from './util';\n\ntype ExtensionsOptions = {\n document?: DocumentType;\n dispatch?: PromiseIntentDispatcher;\n query?: Query<DocumentType>;\n settings: MarkdownSettingsProps;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({ document, settings, viewMode, editorStateStore }: ExtensionsOptions): Extension[] => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const identity = useIdentity();\n const space = getSpace(document);\n\n // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.\n // TODO(burdon): Unsubscribe.\n // const query = space?.db.query(Filter.schema(DocumentType));\n // query?.subscribe();\n const baseExtensions = useMemo(\n () =>\n createBaseExtensions({\n document,\n settings,\n viewMode,\n dispatch,\n // query,\n }),\n [\n document,\n viewMode,\n dispatch,\n settings,\n settings.editorInputMode,\n settings.folding,\n settings.numberedHeadings,\n settings.debug,\n settings.typewriter,\n ],\n );\n\n const extensionProviders = useCapabilities(MarkdownCapabilities.Extensions);\n\n //\n // External extensions from other plugins.\n //\n const pluginExtensions = useMemo<Extension[] | undefined>(\n () =>\n extensionProviders.flat().reduce((acc: Extension[], provider) => {\n const extension = typeof provider === 'function' ? provider({ document }) : provider;\n if (extension) {\n acc.push(extension);\n }\n\n return acc;\n }, []),\n [extensionProviders, document],\n );\n\n //\n // Basic plugins.\n //\n return useMemo<Extension[]>(\n () =>\n [\n // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.\n document &&\n createDataExtensions({\n id: document.id,\n text: document.content.target && createDocAccessor(document.content.target, ['content']),\n space,\n identity,\n }),\n selectionState(editorStateStore),\n document &&\n listener({\n onChange: (text) => setFallbackName(document, text),\n }),\n baseExtensions,\n pluginExtensions,\n ].filter(isNotFalsy),\n [baseExtensions, pluginExtensions, document, document?.content?.target, space, identity],\n );\n};\n\n/**\n * Create extension instances for editor.\n */\nconst createBaseExtensions = ({ document, dispatch, settings, query, viewMode }: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n settings.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings.folding && folding(),\n ].filter(isNotFalsy);\n\n //\n // Markdown\n //\n if (viewMode !== 'source') {\n extensions.push(\n ...[\n formattingKeymap(),\n decorateMarkdown({\n selectionChangeDelay: 100,\n numberedHeadings: settings.numberedHeadings ? { from: 2 } : undefined,\n // TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.\n renderLinkButton:\n dispatch && document\n ? onRenderLink((id: string) => {\n void dispatch(\n createIntent(NavigationAction.AddToActive, {\n id,\n part: 'main',\n pivotId: fullyQualifiedId(document),\n scrollIntoView: true,\n }),\n );\n })\n : undefined,\n }),\n linkTooltip(renderLinkTooltip),\n ],\n );\n }\n\n //\n // Autocomplete object links.\n //\n if (query) {\n extensions.push(\n autocomplete({\n onSearch: (text: string) => {\n // TODO(burdon): Specify filter (e.g., stack).\n return query.objects\n .map<AutocompleteResult | undefined>((object) =>\n object.name?.length && object.id !== document?.id\n ? {\n label: object.name,\n // TODO(burdon): Factor out URL builder.\n apply: `[${object.name}](/${fullyQualifiedId(object)})`,\n }\n : undefined,\n )\n .filter(isNotFalsy);\n },\n }),\n );\n }\n\n if (settings.debug) {\n const items = settings.typewriter?.split(/[,\\n]/) ?? '';\n if (items) {\n extensions.push(typewriter({ items }));\n }\n }\n\n return extensions;\n};\n\n// TODO(burdon): Factor out styles.\nconst style = {\n hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',\n icon: 'inline-block leading-none mis-1 cursor-pointer',\n};\n\nconst onRenderLink = (onSelectObject: (id: string) => void) => (el: Element, url: string) => {\n // TODO(burdon): Formalize/document internal link format.\n const isInternal =\n url.startsWith('/') ||\n // TODO(wittjosiah): This should probably be parsed out on paste?\n url.startsWith(window.location.origin);\n\n const options: AnchorHTMLAttributes<any> = isInternal\n ? {\n onClick: () => {\n const qualifiedId = url.split('/').at(-1);\n invariant(qualifiedId, 'Invalid link format.');\n onSelectObject(qualifiedId);\n },\n }\n : {\n href: url,\n rel: 'noreferrer',\n target: '_blank',\n };\n\n renderRoot(\n el,\n <a {...options} className={style.hover}>\n <Icon\n icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}\n size={4}\n classNames={style.icon}\n />\n </a>,\n );\n};\n\nconst renderLinkTooltip = (el: Element, url: string) => {\n const web = new URL(url);\n renderRoot(\n el,\n <a href={url} rel='noreferrer' target='_blank' className={style.hover}>\n {web.origin}\n <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />\n </a>,\n );\n};\n\n// TODO(burdon): Remove react rendering; use DOM directly.\nexport const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {\n createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);\n return root;\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["import_react", "import_app_framework", "import_react_ui_editor", "import_invariant", "import_echo", "import_react_ui", "import_util", "useSelectCurrentThread", "editorView", "documentId", "scrollIntoViewResolver", "useMemo", "createResolver", "LayoutAction", "ScrollIntoView", "cursor", "invariant", "range", "Cursor", "getRangeFromCursor", "state", "selection", "main", "from", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "dispatch", "disposition", "filter", "data", "id", "useIntentResolver", "MARKDOWN_PLUGIN", "MarkdownEditor", "role", "initialValue", "extensions", "extensionProviders", "scrollPastEnd", "toolbar", "viewMode", "editorStateStore", "onFileUpload", "onViewModeChange", "t", "useTranslation", "themeMode", "useThemeContext", "dispatchPromise", "useIntentDispatcher", "toolbarState", "useEditorToolbarState", "formattingObserver", "useFormattingState", "scrollTo", "getState", "providerExtensions", "flatMap", "provider", "nonNullable", "commentObserver", "useCommentState", "onCommentClick", "useCallback", "createIntent", "NavigationAction", "Open", "activeParts", "complementary", "SetLayout", "element", "commentClickObserver", "useCommentClickListener", "handleDrop", "view", "files", "file", "info", "processEditorPayload", "type", "url", "parentRef", "focusAttributes", "useTextEditor", "createBasicExtensions", "readonly", "placeholder", "createMarkdownExtensions", "createThemeExtensions", "syntaxHighlighting", "slots", "content", "className", "editorContent", "editorGutter", "dropFile", "onDrop", "isNotFalsy", "moveToEndOfLine", "useTest", "acceptedFiles", "getInputProps", "open", "useDropzone", "multiple", "noDrag", "accept", "useEffect", "length", "requestAnimationFrame", "f", "File", "name", "lastModified", "handleToolbarAction", "useActionHandler", "handleAction", "action", "properties", "openSearchPanel", "React", "StackItem", "Content", "EditorToolbar", "attendableId", "customActions", "createUploadAction", "onAction", "input", "div", "ref", "data-testid", "data-toolbar", "stackItemContentEditorClassNames", "composer", "window", "nodes", "createEditorAction", "testId", "edges", "source", "target", "useExtensions", "document", "settings", "identity", "useIdentity", "space", "getSpace", "baseExtensions", "createBaseExtensions", "editorInputMode", "folding", "numberedHeadings", "debug", "typewriter", "useCapabilities", "MarkdownCapabilities", "Extensions", "pluginExtensions", "flat", "reduce", "acc", "extension", "createDataExtensions", "text", "createDocAccessor", "selectionState", "listener", "onChange", "setFallbackName", "query", "InputModeExtensions", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "renderLinkButton", "onRenderLink", "AddToActive", "part", "pivotId", "fullyQualifiedId", "linkTooltip", "renderLinkTooltip", "autocomplete", "onSearch", "objects", "map", "object", "label", "apply", "items", "split", "style", "hover", "icon", "onSelectObject", "el", "isInternal", "startsWith", "location", "origin", "options", "onClick", "qualifiedId", "at", "href", "rel", "renderRoot", "a", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "MarkdownContainer", "doc", "DocumentType", "DocumentEditor", "inputMode", "props", "fallbackName", "getFallbackName", "upload", "Capabilities", "FileUploader", "handleFileUpload"]
7
+ }
@@ -0,0 +1,62 @@
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 app_graph_serializer_PJRST43Q_exports = {};
20
+ __export(app_graph_serializer_PJRST43Q_exports, {
21
+ default: () => app_graph_serializer_default
22
+ });
23
+ module.exports = __toCommonJS(app_graph_serializer_PJRST43Q_exports);
24
+ var import_chunk_7WZANRNS = require("./chunk-7WZANRNS.cjs");
25
+ var import_chunk_34WFGSZU = require("./chunk-34WFGSZU.cjs");
26
+ var import_chunk_HTWAAR54 = require("./chunk-HTWAAR54.cjs");
27
+ var import_effect = require("effect");
28
+ var import_app_framework = require("@dxos/app-framework");
29
+ var import_types = require("@dxos/plugin-space/types");
30
+ var import_echo = require("@dxos/react-client/echo");
31
+ var app_graph_serializer_default = (context) => (0, import_app_framework.contributes)(import_app_framework.Capabilities.AppGraphSerializer, [
32
+ {
33
+ inputType: import_chunk_34WFGSZU.DocumentType.typename,
34
+ outputType: "text/markdown",
35
+ // Reconcile with metadata serializers.
36
+ serialize: async (node) => {
37
+ const doc = node.data;
38
+ const content = await doc.content.load();
39
+ return {
40
+ name: doc.name || doc.fallbackName || import_chunk_7WZANRNS.translations_default[0]["en-US"][import_chunk_HTWAAR54.MARKDOWN_PLUGIN]["document title placeholder"],
41
+ data: content.content,
42
+ type: "text/markdown"
43
+ };
44
+ },
45
+ deserialize: async (data, ancestors) => {
46
+ const space = ancestors.find(import_echo.isSpace);
47
+ const target = ancestors.findLast((ancestor) => ancestor instanceof import_types.CollectionType) ?? space?.properties[import_types.CollectionType.typename]?.target;
48
+ if (!space || !target) {
49
+ return;
50
+ }
51
+ const { dispatchPromise: dispatch } = context.requestCapability(import_app_framework.Capabilities.IntentDispatcher);
52
+ const result = await dispatch((0, import_effect.pipe)((0, import_app_framework.createIntent)(import_chunk_34WFGSZU.MarkdownAction.Create, {
53
+ name: data.name,
54
+ content: data.data
55
+ }), (0, import_app_framework.chain)(import_types.SpaceAction.AddObject, {
56
+ target
57
+ })));
58
+ return result.data?.object;
59
+ }
60
+ }
61
+ ]);
62
+ //# sourceMappingURL=app-graph-serializer-PJRST43Q.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-serializer.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe } from 'effect';\n\nimport { contributes, Capabilities, type PluginsContext, chain, createIntent } from '@dxos/app-framework';\nimport { SpaceAction, CollectionType } from '@dxos/plugin-space/types';\nimport { isSpace } from '@dxos/react-client/echo';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport translations from '../translations';\nimport { MarkdownAction, DocumentType } from '../types';\n\nexport default (context: PluginsContext) =>\n contributes(Capabilities.AppGraphSerializer, [\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: doc.name || doc.fallbackName || 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 { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);\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"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,oBAAqB;AAErB,2BAAoF;AACpF,mBAA4C;AAC5C,kBAAwB;AAMxB,IAAA,+BAAe,CAACA,gBACdC,kCAAYC,kCAAaC,oBAAoB;EAC3C;IACEC,WAAWC,mCAAaC;IACxBC,YAAY;;IAEZC,WAAW,OAAOC,SAAAA;AAChB,YAAMC,MAAMD,KAAKE;AACjB,YAAMC,UAAU,MAAMF,IAAIE,QAAQC,KAAI;AACtC,aAAO;QACLC,MAAMJ,IAAII,QAAQJ,IAAIK,gBAAgBC,2CAAa,CAAA,EAAG,OAAA,EAASC,qCAAAA,EAAiB,4BAAA;QAChFN,MAAMC,QAAQA;QACdM,MAAM;MACR;IACF;IACAC,aAAa,OAAOR,MAAMS,cAAAA;AACxB,YAAMC,QAAQD,UAAUE,KAAKC,mBAAAA;AAC7B,YAAMC,SACJJ,UAAUK,SAAS,CAACC,aAAaA,oBAAoBC,2BAAAA,KACrDN,OAAOO,WAAWD,4BAAerB,QAAQ,GAAGkB;AAC9C,UAAI,CAACH,SAAS,CAACG,QAAQ;AACrB;MACF;AAEA,YAAM,EAAEK,iBAAiBC,SAAQ,IAAK9B,QAAQ+B,kBAAkB7B,kCAAa8B,gBAAgB;AAC7F,YAAMC,SAAS,MAAMH,aACnBI,wBACEC,mCAAaC,qCAAeC,QAAQ;QAAEvB,MAAMH,KAAKG;QAAMF,SAASD,KAAKA;MAAK,CAAA,OAC1E2B,4BAAMC,yBAAYC,WAAW;QAAEhB;MAAO,CAAA,CAAA,CAAA;AAI1C,aAAOS,OAAOtB,MAAM8B;IACtB;EACF;CACD;",
6
+ "names": ["context", "contributes", "Capabilities", "AppGraphSerializer", "inputType", "DocumentType", "typename", "outputType", "serialize", "node", "doc", "data", "content", "load", "name", "fallbackName", "translations", "MARKDOWN_PLUGIN", "type", "deserialize", "ancestors", "space", "find", "isSpace", "target", "findLast", "ancestor", "CollectionType", "properties", "dispatchPromise", "dispatch", "requestCapability", "IntentDispatcher", "result", "pipe", "createIntent", "MarkdownAction", "Create", "chain", "SpaceAction", "AddObject", "object"]
7
+ }
@@ -16,38 +16,32 @@ var __copyProps = (to, from, except, desc) => {
16
16
  return to;
17
17
  };
18
18
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var chunk_CQMXZ54Z_exports = {};
20
- __export(chunk_CQMXZ54Z_exports, {
19
+ var chunk_34WFGSZU_exports = {};
20
+ __export(chunk_34WFGSZU_exports, {
21
21
  DocumentType: () => DocumentType,
22
22
  MarkdownAction: () => MarkdownAction,
23
- TextType: () => TextType,
23
+ MarkdownSettingsSchema: () => MarkdownSettingsSchema,
24
24
  isEditorModel: () => isEditorModel
25
25
  });
26
- module.exports = __toCommonJS(chunk_CQMXZ54Z_exports);
27
- var import_chunk_PHHIPRJC = require("./chunk-PHHIPRJC.cjs");
26
+ module.exports = __toCommonJS(chunk_34WFGSZU_exports);
27
+ var import_chunk_HTWAAR54 = require("./chunk-HTWAAR54.cjs");
28
28
  var import_echo_schema = require("@dxos/echo-schema");
29
29
  var import_types = require("@dxos/plugin-space/types");
30
+ var import_schema = require("@dxos/schema");
30
31
  var import_echo_schema2 = require("@dxos/echo-schema");
31
32
  var import_react_ui_editor = require("@dxos/react-ui-editor");
32
- var TextType = class extends (0, import_echo_schema.TypedObject)({
33
- typename: "dxos.org/type/Text",
34
- version: "0.1.0"
35
- })({
36
- content: import_echo_schema.S.String
37
- }) {
38
- };
39
33
  var DocumentType = class extends (0, import_echo_schema.TypedObject)({
40
34
  typename: "dxos.org/type/Document",
41
35
  version: "0.1.0"
42
36
  })({
43
37
  name: import_echo_schema.S.optional(import_echo_schema.S.String),
44
38
  fallbackName: import_echo_schema.S.optional(import_echo_schema.S.String),
45
- content: (0, import_echo_schema.Ref)(TextType),
39
+ content: (0, import_echo_schema.Ref)(import_schema.TextType),
46
40
  threads: import_echo_schema.S.mutable(import_echo_schema.S.Array((0, import_echo_schema.Ref)(import_types.ThreadType)))
47
41
  }) {
48
42
  };
49
43
  var isEditorModel = (data) => data && typeof data === "object" && "id" in data && typeof data.id === "string" && "text" in data && typeof data.text === "string";
50
- var MARKDOWN_ACTION = `${import_chunk_PHHIPRJC.MARKDOWN_PLUGIN}/action`;
44
+ var MARKDOWN_ACTION = `${import_chunk_HTWAAR54.MARKDOWN_PLUGIN}/action`;
51
45
  var MarkdownAction;
52
46
  (function(MarkdownAction2) {
53
47
  class Create extends import_echo_schema2.S.TaggedClass()(MARKDOWN_ACTION, {
@@ -71,11 +65,22 @@ var MarkdownAction;
71
65
  }
72
66
  MarkdownAction2.SetViewMode = SetViewMode;
73
67
  })(MarkdownAction || (MarkdownAction = {}));
68
+ var MarkdownSettingsSchema = import_echo_schema2.S.mutable(import_echo_schema2.S.Struct({
69
+ defaultViewMode: import_react_ui_editor.EditorViewMode,
70
+ editorInputMode: import_echo_schema2.S.optional(import_react_ui_editor.EditorInputMode),
71
+ experimental: import_echo_schema2.S.optional(import_echo_schema2.S.Boolean),
72
+ debug: import_echo_schema2.S.optional(import_echo_schema2.S.Boolean),
73
+ toolbar: import_echo_schema2.S.optional(import_echo_schema2.S.Boolean),
74
+ typewriter: import_echo_schema2.S.optional(import_echo_schema2.S.String),
75
+ // TODO(burdon): Per document settings.
76
+ numberedHeadings: import_echo_schema2.S.optional(import_echo_schema2.S.Boolean),
77
+ folding: import_echo_schema2.S.optional(import_echo_schema2.S.Boolean)
78
+ }));
74
79
  // Annotate the CommonJS export names for ESM import in node:
75
80
  0 && (module.exports = {
76
81
  DocumentType,
77
82
  MarkdownAction,
78
- TextType,
83
+ MarkdownSettingsSchema,
79
84
  isEditorModel
80
85
  });
81
- //# sourceMappingURL=chunk-CQMXZ54Z.cjs.map
86
+ //# sourceMappingURL=chunk-34WFGSZU.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/types/schema.ts", "../../../src/types/types.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Ref, S, TypedObject } from '@dxos/echo-schema';\nimport { ThreadType } from '@dxos/plugin-space/types';\nimport { TextType } from '@dxos/schema';\n\nexport class DocumentType extends TypedObject({ typename: 'dxos.org/type/Document', version: '0.1.0' })({\n name: S.optional(S.String),\n fallbackName: S.optional(S.String),\n content: Ref(TextType),\n threads: S.mutable(S.Array(Ref(ThreadType))),\n}) {}\n\n/**\n * Checks if an object conforms to the interface needed to render an editor.\n */\n// TODO(burdon): Normalize types (from FilesPlugin).\nexport const isEditorModel = (data: any): data is { id: string; text: string } =>\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// Copyright 2023 DXOS.org\n//\n\nimport { S } from '@dxos/echo-schema';\n// TODO(wittjosiah): This pulls in UI code into the types entrypoint.\nimport { type Extension, EditorInputMode, EditorViewMode } from '@dxos/react-ui-editor';\n\nimport { DocumentType } from './schema';\nimport { MARKDOWN_PLUGIN } from '../meta';\n\nconst MARKDOWN_ACTION = `${MARKDOWN_PLUGIN}/action`;\n\nexport namespace MarkdownAction {\n export class Create extends S.TaggedClass<Create>()(MARKDOWN_ACTION, {\n input: S.Struct({\n name: S.optional(S.String),\n content: S.optional(S.String),\n }),\n output: S.Struct({\n object: DocumentType,\n }),\n }) {}\n\n export class SetViewMode extends S.TaggedClass<SetViewMode>()(`${MARKDOWN_ACTION}/set-view-mode`, {\n input: S.Struct({\n id: S.String,\n viewMode: EditorViewMode,\n }),\n output: S.Void,\n }) {}\n}\n\nexport type MarkdownProperties = Record<string, any>;\n\n// TODO(burdon): Async.\nexport type MarkdownExtensionProvider = (props: { document?: DocumentType }) => Extension | undefined;\n\nexport type OnChange = (text: string) => void;\n\nexport type MarkdownPluginState = {\n // Codemirror extensions provided by other plugins.\n extensionProviders?: MarkdownExtensionProvider[];\n\n // TODO(burdon): Extend view mode per document to include scroll position, etc.\n // View mode per document.\n viewMode: Record<string, EditorViewMode>;\n};\n\nexport const MarkdownSettingsSchema = S.mutable(\n S.Struct({\n defaultViewMode: EditorViewMode,\n editorInputMode: S.optional(EditorInputMode),\n experimental: S.optional(S.Boolean),\n debug: S.optional(S.Boolean),\n toolbar: S.optional(S.Boolean),\n typewriter: S.optional(S.String),\n // TODO(burdon): Per document settings.\n numberedHeadings: S.optional(S.Boolean),\n folding: S.optional(S.Boolean),\n }),\n);\n\nexport type MarkdownSettingsProps = S.Schema.Type<typeof MarkdownSettingsSchema>;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,yBAAoC;AACpC,mBAA2B;AAC3B,oBAAyB;ACFzB,IAAAA,sBAAkB;AAElB,6BAAgE;ADEzD,IAAMC,eAAN,kBAA2BC,gCAAY;EAAEC,UAAU;EAA0BC,SAAS;AAAQ,CAAA,EAAG;EACtGC,MAAMC,qBAAEC,SAASD,qBAAEE,MAAM;EACzBC,cAAcH,qBAAEC,SAASD,qBAAEE,MAAM;EACjCE,aAASC,wBAAIC,sBAAAA;EACbC,SAASP,qBAAEQ,QAAQR,qBAAES,UAAMJ,wBAAIK,uBAAAA,CAAAA,CAAAA;AACjC,CAAA,EAAA;AAAI;AAMG,IAAMC,gBAAgB,CAACC,SAC5BA,QACA,OAAOA,SAAS,YAChB,QAAQA,QACR,OAAOA,KAAKC,OAAO,YACnB,UAAUD,QACV,OAAOA,KAAKE,SAAS;ACdvB,IAAMC,kBAAkB,GAAGC,qCAAAA;;UAEVC,iBAAAA;EACR,MAAMC,eAAelB,oBAAAA,EAAEmB,YAAW,EAAWJ,iBAAiB;IACnEK,OAAOpB,oBAAAA,EAAEqB,OAAO;MACdtB,MAAMC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEE,MAAM;MACzBE,SAASJ,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEE,MAAM;IAC9B,CAAA;IACAoB,QAAQtB,oBAAAA,EAAEqB,OAAO;MACfE,QAAQ5B;IACV,CAAA;EACF,CAAA,EAAA;EAAI;kBARSuB,SAAAA;EAUN,MAAMM,oBAAoBxB,oBAAAA,EAAEmB,YAAW,EAAgB,GAAGJ,eAAAA,kBAAiC;IAChGK,OAAOpB,oBAAAA,EAAEqB,OAAO;MACdR,IAAIb,oBAAAA,EAAEE;MACNuB,UAAUC;IACZ,CAAA;IACAJ,QAAQtB,oBAAAA,EAAE2B;EACZ,CAAA,EAAA;EAAI;kBANSH,cAAAA;AAOf,GAlBiBP,mBAAAA,iBAAAA,CAAAA,EAAAA;AAoCV,IAAMW,yBAAyB5B,oBAAAA,EAAEQ,QACtCR,oBAAAA,EAAEqB,OAAO;EACPQ,iBAAiBH;EACjBI,iBAAiB9B,oBAAAA,EAAEC,SAAS8B,sCAAAA;EAC5BC,cAAchC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEiC,OAAO;EAClCC,OAAOlC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEiC,OAAO;EAC3BE,SAASnC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEiC,OAAO;EAC7BG,YAAYpC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEE,MAAM;;EAE/BmC,kBAAkBrC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEiC,OAAO;EACtCK,SAAStC,oBAAAA,EAAEC,SAASD,oBAAAA,EAAEiC,OAAO;AAC/B,CAAA,CAAA;",
6
+ "names": ["import_echo_schema", "DocumentType", "TypedObject", "typename", "version", "name", "S", "optional", "String", "fallbackName", "content", "Ref", "TextType", "threads", "mutable", "Array", "ThreadType", "isEditorModel", "data", "id", "text", "MARKDOWN_ACTION", "MARKDOWN_PLUGIN", "MarkdownAction", "Create", "TaggedClass", "input", "Struct", "output", "object", "SetViewMode", "viewMode", "EditorViewMode", "Void", "MarkdownSettingsSchema", "defaultViewMode", "editorInputMode", "EditorInputMode", "experimental", "Boolean", "debug", "toolbar", "typewriter", "numberedHeadings", "folding"]
7
+ }
@@ -0,0 +1,64 @@
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 chunk_7WZANRNS_exports = {};
20
+ __export(chunk_7WZANRNS_exports, {
21
+ translations_default: () => translations_default
22
+ });
23
+ module.exports = __toCommonJS(chunk_7WZANRNS_exports);
24
+ var import_chunk_34WFGSZU = require("./chunk-34WFGSZU.cjs");
25
+ var import_chunk_HTWAAR54 = require("./chunk-HTWAAR54.cjs");
26
+ var translations_default = [
27
+ {
28
+ "en-US": {
29
+ [import_chunk_34WFGSZU.DocumentType.typename]: {
30
+ "typename label": "Document"
31
+ },
32
+ [import_chunk_HTWAAR54.MARKDOWN_PLUGIN]: {
33
+ "plugin name": "Editor",
34
+ "create stack section label": "Create document",
35
+ "document title placeholder": "New document",
36
+ "choose markdown from space dialog title": "Choose one or more documents to add",
37
+ // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)
38
+ "empty choose markdown from space message": "None available; try creating a new one instead?",
39
+ "chooser done label": "Add selected",
40
+ "create document label": "Create document",
41
+ "editor placeholder": "",
42
+ "editor input mode label": "Editor input mode",
43
+ "select editor input mode placeholder": "Select editor input mode\u2026",
44
+ "settings editor input mode default label": "Default",
45
+ "settings editor input mode vim label": "Vim",
46
+ "settings editor input mode vscode label": "VS Code",
47
+ "settings toolbar label": "Show toolbar",
48
+ "settings numbered headings label": "Numbered headings",
49
+ "settings folding label": "Folding",
50
+ "settings experimental label": "Enable experimental features",
51
+ "settings debug label": "Enable debugging features",
52
+ "settings debug placeholder": "Typewriter script...",
53
+ "toggle view mode label": "Toggle read-only",
54
+ "default view mode label": "Default view mode",
55
+ "upload image label": "Upload Image"
56
+ }
57
+ }
58
+ }
59
+ ];
60
+ // Annotate the CommonJS export names for ESM import in node:
61
+ 0 && (module.exports = {
62
+ translations_default
63
+ });
64
+ //# sourceMappingURL=chunk-7WZANRNS.cjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/translations.ts"],
4
+ "sourcesContent": ["//\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 'upload image label': 'Upload Image',\n },\n },\n },\n];\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;AAOA,IAAA,uBAAe;EACb;IACE,SAAS;MACP,CAACA,mCAAaC,QAAQ,GAAG;QACvB,kBAAkB;MACpB;MACA,CAACC,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;QAC3B,sBAAsB;MACxB;IACF;EACF;;",
6
+ "names": ["DocumentType", "typename", "MARKDOWN_PLUGIN"]
7
+ }