@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.
- package/dist/lib/browser/{MarkdownContainer-XY6NEUOA.mjs → MarkdownContainer-ARRY4I6S.mjs} +95 -46
- package/dist/lib/browser/MarkdownContainer-ARRY4I6S.mjs.map +7 -0
- package/dist/lib/browser/app-graph-serializer-HHWSLYIW.mjs +51 -0
- package/dist/lib/browser/app-graph-serializer-HHWSLYIW.mjs.map +7 -0
- package/dist/lib/browser/{chunk-R4MG2DP2.mjs → chunk-ADAYSA5G.mjs} +20 -9
- package/dist/lib/browser/chunk-ADAYSA5G.mjs.map +7 -0
- package/dist/lib/browser/{chunk-6FIHBJRV.mjs → chunk-EMIIXXVX.mjs} +17 -12
- package/dist/lib/browser/chunk-EMIIXXVX.mjs.map +7 -0
- package/dist/lib/browser/chunk-FSAYVXSE.mjs +16 -0
- package/dist/lib/browser/chunk-FSAYVXSE.mjs.map +7 -0
- package/dist/lib/browser/{chunk-4X6YX3KU.mjs → chunk-YB2TJFNH.mjs} +3 -3
- package/dist/lib/browser/chunk-YB2TJFNH.mjs.map +7 -0
- package/dist/lib/browser/chunk-YPDWX3WI.mjs +47 -0
- package/dist/lib/browser/chunk-YPDWX3WI.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +100 -367
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/intent-resolver-4KWMUMND.mjs +37 -0
- package/dist/lib/browser/intent-resolver-4KWMUMND.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-RL4CISJZ.mjs +152 -0
- package/dist/lib/browser/react-surface-RL4CISJZ.mjs.map +7 -0
- package/dist/lib/browser/settings-PTF73JDL.mjs +28 -0
- package/dist/lib/browser/settings-PTF73JDL.mjs.map +7 -0
- package/dist/lib/browser/state-DOVZP7XJ.mjs +37 -0
- package/dist/lib/browser/state-DOVZP7XJ.mjs.map +7 -0
- package/dist/lib/browser/thread-G4RS7NBZ.mjs +36 -0
- package/dist/lib/browser/thread-G4RS7NBZ.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +4 -4
- package/dist/lib/node/{MarkdownContainer-EX6YDF6J.cjs → MarkdownContainer-TV6W64EN.cjs} +100 -53
- package/dist/lib/node/MarkdownContainer-TV6W64EN.cjs.map +7 -0
- package/dist/lib/node/app-graph-serializer-PJRST43Q.cjs +62 -0
- package/dist/lib/node/app-graph-serializer-PJRST43Q.cjs.map +7 -0
- package/dist/lib/node/{chunk-CQMXZ54Z.cjs → chunk-34WFGSZU.cjs} +21 -16
- package/dist/lib/node/chunk-34WFGSZU.cjs.map +7 -0
- package/dist/lib/node/chunk-7WZANRNS.cjs +64 -0
- package/dist/lib/node/chunk-7WZANRNS.cjs.map +7 -0
- package/dist/lib/node/{meta.cjs → chunk-G7WKHUGU.cjs} +13 -8
- package/dist/lib/node/chunk-G7WKHUGU.cjs.map +7 -0
- package/dist/lib/node/{chunk-PHHIPRJC.cjs → chunk-HTWAAR54.cjs} +7 -7
- package/dist/lib/node/chunk-HTWAAR54.cjs.map +7 -0
- package/dist/lib/node/{chunk-SXQAPZZU.cjs → chunk-UFFFUC6W.cjs} +37 -12
- package/dist/lib/node/chunk-UFFFUC6W.cjs.map +7 -0
- package/dist/lib/node/index.cjs +92 -366
- package/dist/lib/node/index.cjs.map +4 -4
- package/dist/lib/node/intent-resolver-QN25AFOP.cjs +50 -0
- package/dist/lib/node/intent-resolver-QN25AFOP.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/react-surface-RZ2XV56V.cjs +165 -0
- package/dist/lib/node/react-surface-RZ2XV56V.cjs.map +7 -0
- package/dist/lib/node/settings-BO5P5R4I.cjs +42 -0
- package/dist/lib/node/settings-BO5P5R4I.cjs.map +7 -0
- package/dist/lib/node/state-F26NQP7F.cjs +51 -0
- package/dist/lib/node/state-F26NQP7F.cjs.map +7 -0
- package/dist/lib/node/thread-THWQ67WS.cjs +52 -0
- package/dist/lib/node/thread-THWQ67WS.cjs.map +7 -0
- package/dist/lib/node/types/index.cjs +7 -7
- package/dist/lib/node/types/index.cjs.map +1 -1
- package/dist/lib/node-esm/{MarkdownContainer-E7W623A7.mjs → MarkdownContainer-3ZHQTTMQ.mjs} +95 -46
- package/dist/lib/node-esm/MarkdownContainer-3ZHQTTMQ.mjs.map +7 -0
- package/dist/lib/node-esm/app-graph-serializer-JTHJUUS2.mjs +52 -0
- package/dist/lib/node-esm/app-graph-serializer-JTHJUUS2.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-2GHK262V.mjs +17 -0
- package/dist/lib/node-esm/chunk-2GHK262V.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-BABK7FMW.mjs → chunk-AOKWCL3O.mjs} +3 -3
- package/dist/lib/node-esm/chunk-AOKWCL3O.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-ZVFBKBSA.mjs → chunk-CDFNMFGT.mjs} +17 -12
- package/dist/lib/node-esm/chunk-CDFNMFGT.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HLP536EW.mjs +48 -0
- package/dist/lib/node-esm/chunk-HLP536EW.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-Y76MM22C.mjs → chunk-Y5RSQVGH.mjs} +20 -9
- package/dist/lib/node-esm/chunk-Y5RSQVGH.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +100 -367
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/intent-resolver-F7MQOTG7.mjs +38 -0
- package/dist/lib/node-esm/intent-resolver-F7MQOTG7.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react-surface-RRXHEW4R.mjs +153 -0
- package/dist/lib/node-esm/react-surface-RRXHEW4R.mjs.map +7 -0
- package/dist/lib/node-esm/settings-E7P5FQ3F.mjs +29 -0
- package/dist/lib/node-esm/settings-E7P5FQ3F.mjs.map +7 -0
- package/dist/lib/node-esm/state-HXSOQNOV.mjs +38 -0
- package/dist/lib/node-esm/state-HXSOQNOV.mjs.map +7 -0
- package/dist/lib/node-esm/thread-CYEXBXTW.mjs +37 -0
- package/dist/lib/node-esm/thread-CYEXBXTW.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +4 -4
- package/dist/types/src/MarkdownPlugin.d.ts +1 -3
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-serializer.d.ts +4 -0
- package/dist/types/src/capabilities/app-graph-serializer.d.ts.map +1 -0
- package/dist/types/src/capabilities/capabilities.d.ts +12 -0
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +16 -0
- package/dist/types/src/capabilities/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/intent-resolver.d.ts +4 -0
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface.d.ts +4 -0
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings.d.ts +4 -0
- package/dist/types/src/capabilities/settings.d.ts.map +1 -0
- package/dist/types/src/capabilities/state.d.ts +11 -0
- package/dist/types/src/capabilities/state.d.ts.map +1 -0
- package/dist/types/src/capabilities/thread.d.ts +6 -0
- package/dist/types/src/capabilities/thread.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownContainer.d.ts +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor.d.ts +15 -0
- package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/Toolbar.stories.d.ts +2 -2
- package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -1
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts +2 -2
- package/dist/types/src/extensions.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +1 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +3 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +0 -7
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +12 -26
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/dist/types/src/util.d.ts +1 -5
- package/dist/types/src/util.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +32 -37
- package/src/MarkdownPlugin.tsx +79 -213
- package/src/capabilities/app-graph-serializer.ts +50 -0
- package/src/capabilities/capabilities.ts +20 -0
- package/src/capabilities/index.ts +14 -0
- package/src/capabilities/intent-resolver.ts +27 -0
- package/src/capabilities/react-surface.tsx +73 -0
- package/src/capabilities/settings.ts +25 -0
- package/src/capabilities/state.ts +31 -0
- package/src/capabilities/thread.ts +34 -0
- package/src/components/MarkdownContainer.tsx +6 -7
- package/src/components/MarkdownEditor.stories.tsx +16 -5
- package/src/components/MarkdownEditor.tsx +82 -48
- package/src/components/Toolbar.stories.tsx +16 -22
- package/src/extensions.tsx +13 -10
- package/src/index.ts +2 -5
- package/src/meta.ts +1 -1
- package/src/translations.ts +1 -0
- package/src/types/schema.ts +1 -5
- package/src/types/types.ts +16 -44
- package/src/util.tsx +2 -8
- package/dist/lib/browser/MarkdownContainer-XY6NEUOA.mjs.map +0 -7
- package/dist/lib/browser/chunk-4X6YX3KU.mjs.map +0 -7
- package/dist/lib/browser/chunk-6FIHBJRV.mjs.map +0 -7
- package/dist/lib/browser/chunk-R4MG2DP2.mjs.map +0 -7
- package/dist/lib/browser/meta.mjs +0 -9
- package/dist/lib/browser/meta.mjs.map +0 -7
- package/dist/lib/node/MarkdownContainer-EX6YDF6J.cjs.map +0 -7
- package/dist/lib/node/chunk-CQMXZ54Z.cjs.map +0 -7
- package/dist/lib/node/chunk-PHHIPRJC.cjs.map +0 -7
- package/dist/lib/node/chunk-SXQAPZZU.cjs.map +0 -7
- package/dist/lib/node/meta.cjs.map +0 -7
- package/dist/lib/node-esm/MarkdownContainer-E7W623A7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-BABK7FMW.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-Y76MM22C.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZVFBKBSA.mjs.map +0 -7
- package/dist/lib/node-esm/meta.mjs +0 -10
- 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
|
|
30
|
-
__export(
|
|
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(
|
|
35
|
-
var
|
|
36
|
-
var
|
|
37
|
-
var
|
|
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
|
|
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)(
|
|
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)(
|
|
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
|
|
116
|
-
|
|
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
|
|
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.
|
|
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(
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
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(
|
|
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,
|
|
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
|
|
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
|
|
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,
|
|
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:
|
|
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:
|
|
453
|
+
tx: import_react_ui_theme.defaultTx
|
|
406
454
|
}, node));
|
|
407
455
|
return root;
|
|
408
456
|
};
|
|
409
|
-
var MarkdownContainer = ({ id, role, object,
|
|
457
|
+
var MarkdownContainer = ({ id, role, object, settings, viewMode, editorStateStore, onViewModeChange }) => {
|
|
410
458
|
const scrollPastEnd = role === "article";
|
|
411
|
-
const doc = object instanceof
|
|
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,
|
|
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
|
|
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 ||
|
|
507
|
+
if (space === void 0 || upload === void 0) {
|
|
461
508
|
return void 0;
|
|
462
509
|
}
|
|
463
|
-
return async (file) =>
|
|
510
|
+
return async (file) => upload(file, space);
|
|
464
511
|
}, [
|
|
465
512
|
space,
|
|
466
|
-
|
|
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-
|
|
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": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAA0C;AAE1C,2BAA8C;AAC9C,kBAA2C;ACH3C,oBAAgC;AAEhC,IAAAA,gBAAuD;AACvD,4BAA4B;AAE5B,IAAAC,wBAAiG;AACjG,sBAAgD;AAChD,6BAwBO;AACP,4BAA0B;AAC1B,kBAAwC;ACjCxC,kBAA2B;AAC3B,IAAAD,gBAAwB;AAExB,IAAAC,wBAAgE;AAChE,uBAA0B;AAC1B,IAAAC,0BAAqC;ACLrC,IAAAF,gBAA0E;AAC1E,oBAA2B;AAE3B,IAAAC,wBAMO;AACP,IAAAE,oBAA0B;AAC1B,IAAAC,eAA0E;AAC1E,kBAA4B;AAC5B,IAAAC,mBAAoC;AACpC,IAAAH,0BAeO;AACP,4BAA0B;AAC1B,IAAAI,eAA2B;;ADnBpB,IAAMC,yBAAyB,CAACC,YAAoCC,eAAAA;AACzE,QAAMC,6BAAyBC,uBAC7B,UACEC,sCACEC,mCAAaC,gBACb,CAAC,EAAEC,OAAM,MAAE;AACTC,oCAAUR,YAAY,+BAAA;;;;;;;;;AACtB,UAAMS,QAAQC,+BAAOC,mBAAmBX,WAAWY,OAAOL,MAAAA;AAC1D,QAAIE,OAAO;AACT,YAAMI,YAAYb,WAAWY,MAAMC,UAAUC,KAAKC,SAASN,MAAMM,OAAO;QAAEC,QAAQP,MAAMM;MAAK,IAAIE;AACjG,YAAMC,UAAU;;QAEdC,uBAAWC,eAAeX,MAAMM,MAAM;UAAEM,GAAG;UAASC,SAAS;QAAG,CAAA;;AAElE,UAAIT,WAAW;AAEbK,gBAAQK,KAAKC,qCAAaC,GAAG;UAAEC,SAASzB;QAAW,CAAA,CAAA;MACrD;AAEAD,iBAAW2B,SAAS;QAClBT;QACAL,WAAWA,YAAY;UAAEG,QAAQP,MAAMM;QAAK,IAAIE;MAClD,CAAA;IACF;EACF,GACA;IACEW,aAAa;IACbC,QAAQ,CAACC,SAAS,CAAC,CAAC9B,cAAc8B,KAAKC,OAAO9B,cAAc,CAAC,CAAC6B,KAAKvB;EACrE,CAAA,GAEJ;IAACN;IAAYD;GAAW;AAG1BgC,+CAAkBC,uCAAiB/B,sBAAAA;AACrC;ADYO,IAAMgC,iBAAiB,CAAC,EAC7BH,IACAI,OAAO,WACPC,cACAC,YACAC,oBACAC,eACAC,SACAC,UACAC,kBACAC,cACAC,iBAAgB,MACI;AACpB,QAAM,EAAEC,EAAC,QAAKC,gCAAeb,qCAAAA;AAC7B,QAAM,EAAEc,UAAS,QAAKC,iCAAAA;AACtB,QAAM,EAAEC,iBAAiBtB,SAAQ,QAAKuB,2CAAAA;AACtC,QAAMC,mBAAeC,8CAAsB;IAAEX;EAAS,CAAA;AACtD,QAAMY,yBAAqBC,2CAAmBH,YAAAA;AAG9C,QAAM,EAAEI,UAAU1C,UAAS,QAAKV,cAAAA,SAA8B,MAAMuC,kBAAkBc,SAASzB,EAAAA,KAAO,CAAC,GAAG;IAACA;GAAG;AAI9G,QAAM0B,yBAAqBtD,cAAAA,SACzB,MAAMmC,oBAAoBoB,QAAQ,CAACC,aAAaA,SAAS,CAAC,CAAA,CAAA,EAAI9B,OAAO+B,uBAAAA,GACrE;IAACtB;GAAmB;AAItB,QAAMuB,sBAAkBC,wCAAgBX,YAAAA;AACxC,QAAMY,qBAAiBC,2BAAY,YAAA;AACjC,UAAMrC,aAASsC,oCAAaC,uCAAiBC,MAAM;MAAEC,aAAa;QAAEC,eAAe;MAAW;IAAE,CAAA,CAAA;AAChG,UAAM1C,aAASsC,oCAAa5D,sBAAAA,aAAaiE,WAAW;MAAEC,SAAS;MAAiB3D,OAAO;IAAK,CAAA,CAAA;EAC9F,GAAG;IAACe;GAAS;AACb,QAAM6C,2BAAuBC,gDAAwBV,cAAAA;AAIrD,QAAMW,aAAmC,OAAOC,MAAM,EAAEC,MAAK,MAAE;AAC7D,UAAMC,OAAOD,MAAM,CAAA;AACnB,UAAME,OAAOD,QAAQlC,eAAe,MAAMA,aAAakC,IAAAA,IAAQ5D;AAC/D,QAAI6D,MAAM;AACRC,uDAAqBJ,MAAM;QAAEK,MAAM;QAASlD,MAAMgD,KAAKG;MAAI,CAAA;IAC7D;EACF;AAEA,QAAM,EACJC,WACAP,MAAM3E,YACNmF,gBAAe,QACbC,sCACF,OAAO;IACLhD;IACAC,YAAY;MACVgB;MACAQ;MACAW;UACAa,8CAAsB;QACpBC,UAAU7C,aAAa;QACvB8C,aAAa1C,EAAE,oBAAA;QACfN,eAAeJ,SAAS,YAAY,QAAQI;MAC9C,CAAA;UACAiD,iDAAyB;QAAEzC;MAAU,CAAA;UACrC0C,8CAAsB;QACpB1C;QACA2C,oBAAoB;QACpBC,OAAO;UAAEC,SAAS;YAAEC,WAAWC;UAAc;QAAE;MACjD,CAAA;MACAC;MACA5D,SAAS,aAAaQ,oBAAgBqD,iCAAS;QAAEC,QAAQvB;MAAW,CAAA;MACpEjB;MACApB;MACAR,OAAOqE,sBAAAA;IACT,GAAI/D,SAAS,aAAa;MACxBJ;MACAwB;MACA1C;;;MAGAsF,iBAAiB;IACnB;EACF,IACA;IAACpE;IAAIsB;IAAoBZ;IAAUM;IAAWV;IAAYoB;GAAmB;AAG/E2C,UAAQpG,UAAAA;AACRD,yBAAuBC,YAAY+B,EAAAA;AAGnC,QAAM,EAAEsE,eAAeC,eAAeC,KAAI,QAAKC,mCAAY;IACzDC,UAAU;IACVC,QAAQ;IACRC,QAAQ;MACN,WAAW;QAAC;QAAQ;QAAS;QAAQ;;IACvC;EACF,CAAA;AAEAC,+BAAU,MAAA;AACR,QAAI5G,cAAc2C,gBAAgB0D,cAAcQ,QAAQ;AACtDC,4BAAsB,YAAA;AAEpB,cAAMC,IAAIV,cAAc,CAAA;AACxB,cAAMxB,OAAO,IAAImC,KAAK;UAACD;WAAIA,EAAEE,MAAM;UACjCjC,MAAM+B,EAAE/B;UACRkC,cAAcH,EAAEG;QAClB,CAAA;AAEA,cAAMpC,OAAO,MAAMnC,aAAakC,IAAAA;AAChC,YAAIC,MAAM;AACRC,2DAAqB/E,YAAY;YAAEgF,MAAM;YAASlD,MAAMgD,KAAKG;UAAI,CAAA;QACnE;MACF,CAAA;IACF;EACF,GAAG;IAACoB;IAAerG;GAAW;AAG9B,QAAMmH,0BAAsBC,yCAAiBpH,UAAAA;AAC7C,QAAMqH,mBAAerD,2BACnB,CAACsD,WAAAA;AACC,YAAQA,OAAOC,WAAWvC,MAAI;MAC5B,KAAK,UAAU;AACb,YAAIhF,YAAY;AACdwH,6CAAgBxH,UAAAA;QAClB;AACA;MACF;MACA,KAAK,aAAa;AAChB4C,2BAAmBb,IAAIuF,OAAOC,WAAWzF,IAAI;AAC7C;MACF;MACA,KAAK,SAAS;AACZyE,aAAAA;AACA;MACF;IACF;AAEAY,0BAAsBG,MAAAA;EACxB,GACA;IAACtH;IAAY4C;IAAkB2D;GAAK;AAGtC,SACE,8BAAAkB,QAAA,cAACC,gCAAUC,SAAO;IAACnF,SAAS,CAAC,CAACA;KAC3BA,WACC,8BAAAiF,QAAA,cAAA,cAAAA,QAAA,UAAA,MACE,8BAAAA,QAAA,cAACG,sCAAAA;IACCC,cAAc9F;IACdI;IACAvB,OAAOuC;IACP2E,eAAenF,eAAeoF,qBAAqB9G;IACnD+G,UAAUX;MAEZ,8BAAAI,QAAA,cAACQ,SAAU3B,cAAAA,CAAAA,CAAAA,GAGf,8BAAAmB,QAAA,cAACS,OAAAA;IACC/F,MAAK;IACLgG,KAAKjD;IACLkD,eAAY;IACZC,gBAAc7F,UAAU,YAAY;IACpCqD,eAAWyC,yDAAiCnG,IAAAA;IAC3C,GAAGgD;;AAIZ;AAIA,IAAMiB,UAAU,CAACzB,SAAAA;AACfiC,+BAAU,MAAA;AACR,UAAM2B,WAAYC,OAAeD;AACjC,QAAIA,UAAU;AACZA,eAASvI,aAAa2E;IACxB;EACF,GAAG;IAACA;GAAK;AACX;AAEO,IAAMoD,qBAAqB,OAAO;EACvCU,OAAO;QACLC,2CACE;MAAE1D,MAAM;MAAS2D,QAAQ;IAAuB,GAChD,6BACA,oBAAA;;EAGJC,OAAO;IAAC;MAAEC,QAAQ;MAAQC,QAAQ;IAAQ;;AAC5C;;AEvMO,IAAMC,gBAAgB,CAAC,EAAEC,UAAUC,UAAUxG,UAAUC,iBAAgB,MAAqB;AACjG,QAAM,EAAEO,iBAAiBtB,SAAQ,QAAKuB,sBAAAA,qBAAAA;AACtC,QAAMgG,eAAWC,yBAAAA;AACjB,QAAMC,YAAQC,uBAASL,QAAAA;AAMvB,QAAMM,qBAAiBnJ,cAAAA,SACrB,MACEoJ,qBAAqB;IACnBP;IACAC;IACAxG;IACAd;EAEF,CAAA,GACF;IACEqH;IACAvG;IACAd;IACAsH;IACAA,SAASO;IACTP,SAASQ;IACTR,SAASS;IACTT,SAASU;IACTV,SAASW;GACV;AAGH,QAAMtH,yBAAqBuH,uCAAgBC,2CAAqBC,UAAU;AAK1E,QAAMC,uBAAmB7J,cAAAA,SACvB,MACEmC,mBAAmB2H,KAAI,EAAGC,OAAO,CAACC,KAAkBxG,aAAAA;AAClD,UAAMyG,YAAY,OAAOzG,aAAa,aAAaA,SAAS;MAAEqF;IAAS,CAAA,IAAKrF;AAC5E,QAAIyG,WAAW;AACbD,UAAI5I,KAAK6I,SAAAA;IACX;AAEA,WAAOD;EACT,GAAG,CAAA,CAAE,GACP;IAAC7H;IAAoB0G;GAAS;AAMhC,aAAO7I,cAAAA,SACL,MACE;;IAEE6I,gBACEqB,8CAAqB;MACnBtI,IAAIiH,SAASjH;MACbuI,MAAMtB,SAASpD,QAAQkD,cAAUyB,gCAAkBvB,SAASpD,QAAQkD,QAAQ;QAAC;OAAU;MACvFM;MACAF;IACF,CAAA;QACFsB,wCAAe9H,gBAAAA;IACfsG,gBACEyB,kCAAS;MACPC,UAAU,CAACJ,aAASK,uCAAgB3B,UAAUsB,IAAAA;IAChD,CAAA;IACFhB;IACAU;IACAnI,OAAOqE,aAAAA,UAAAA,GACX;IAACoD;IAAgBU;IAAkBhB;IAAUA,UAAUpD,SAASkD;IAAQM;IAAOF;GAAS;AAE5F;AAKA,IAAMK,uBAAuB,CAAC,EAAEP,UAAUrH,UAAUsH,UAAU2B,OAAOnI,SAAQ,MAAqB;AAChG,QAAMJ,aAA0B;IAC9B4G,SAASO,mBAAmBqB,4CAAoB5B,SAASO,eAAe;IACxEP,SAASQ,eAAWA,iCAAAA;IACpB5H,OAAOqE,aAAAA,UAAAA;AAKT,MAAIzD,aAAa,UAAU;AACzBJ,eAAWd,KAAI,GACV;UACDuJ,0CAAAA;UACAC,0CAAiB;QACfC,sBAAsB;QACtBtB,kBAAkBT,SAASS,mBAAmB;UAAE3I,MAAM;QAAE,IAAIE;;QAE5DgK,kBACEtJ,YAAYqH,WACRkC,aAAa,CAACnJ,OAAAA;AACZ,eAAKJ,aACHsC,sBAAAA,cAAaC,sBAAAA,iBAAiBiH,aAAa;YACzCpJ;YACAqJ,MAAM;YACNC,aAASC,+BAAiBtC,QAAAA;YAC1B5H,gBAAgB;UAClB,CAAA,CAAA;QAEJ,CAAA,IACAH;MACR,CAAA;UACAsK,qCAAYC,iBAAAA;KACb;EAEL;AAKA,MAAIZ,OAAO;AACTvI,eAAWd,SACTkK,sCAAa;MACXC,UAAU,CAACpB,SAAAA;AAET,eAAOM,MAAMe,QACVC,IAAoC,CAACC,WACpCA,OAAO5E,MAAMJ,UAAUgF,OAAO9J,OAAOiH,UAAUjH,KAC3C;UACE+J,OAAOD,OAAO5E;;UAEd8E,OAAO,IAAIF,OAAO5E,IAAI,UAAMqE,+BAAiBO,MAAAA,CAAAA;QAC/C,IACA5K,MAAAA,EAELY,OAAOqE,aAAAA,UAAAA;MACZ;IACF,CAAA,CAAA;EAEJ;AAEA,MAAI+C,SAASU,OAAO;AAClB,UAAMqC,QAAQ/C,SAASW,YAAYqC,MAAM,OAAA,KAAY;AACrD,QAAID,OAAO;AACT3J,iBAAWd,SAAKqI,oCAAW;QAAEoC;MAAM,CAAA,CAAA;IACrC;EACF;AAEA,SAAO3J;AACT;AAGA,IAAM6J,QAAQ;EACZC,OAAO;EACPC,MAAM;AACR;AAEA,IAAMlB,eAAe,CAACmB,mBAAyC,CAACC,IAAarH,QAAAA;AAE3E,QAAMsH,aACJtH,IAAIuH,WAAW,GAAA;EAEfvH,IAAIuH,WAAWhE,OAAOiE,SAASC,MAAM;AAEvC,QAAMC,UAAqCJ,aACvC;IACEK,SAAS,MAAA;AACP,YAAMC,cAAc5H,IAAIgH,MAAM,GAAA,EAAKa,GAAG,EAAC;AACvCtM,4BAAAA,WAAUqM,aAAa,wBAAA;;;;;;;;;AACvBR,qBAAeQ,WAAAA;IACjB;EACF,IACA;IACEE,MAAM9H;IACN+H,KAAK;IACLlE,QAAQ;EACV;AAEJmE,aACEX,IACA7E,8BAAAA,QAAA,cAACyF,KAAAA;IAAG,GAAGP;IAAS9G,WAAWqG,MAAMC;KAC/B1E,8BAAAA,QAAA,cAAC0F,uBAAAA;IACCf,MAAMG,aAAa,gCAAgC;IACnDa,MAAM;IACNC,YAAYnB,MAAME;;AAI1B;AAEA,IAAMZ,oBAAoB,CAACc,IAAarH,QAAAA;AACtC,QAAMqI,MAAM,IAAIC,IAAItI,GAAAA;AACpBgI,aACEX,IACA7E,8BAAAA,QAAA,cAACyF,KAAAA;IAAEH,MAAM9H;IAAK+H,KAAI;IAAalE,QAAO;IAASjD,WAAWqG,MAAMC;KAC7DmB,IAAIZ,QACLjF,8BAAAA,QAAA,cAAC0F,uBAAAA;IAAKf,MAAK;IAA6BgB,MAAM;IAAGC,YAAYnB,MAAME;;AAGzE;AAGO,IAAMa,aAAa,CAAoBO,MAASC,SAAAA;AACrDC,gCAAWF,IAAAA,EAAMG,OAAOlG,8BAAAA,QAAA,cAACmG,gCAAAA;IAAcC,IAAIC;KAAYL,IAAAA,CAAAA;AACvD,SAAOD;AACT;AHpOA,IAAMO,oBAAoB,CAAC,EACzBhM,IACAI,MACA0J,QACA5C,UACAxG,UACAC,kBACAE,iBAAgB,MACO;AACvB,QAAML,gBAAgBJ,SAAS;AAC/B,QAAM6L,MAAMnC,kBAAkBoC,qCAAepC,SAAS5K;AACtD,QAAMoB,aAAa0G,cAAc;IAAEC,UAAUgF;IAAK/E;IAAUxG;IAAUC;EAAiB,CAAA;AAEvF,MAAIsL,KAAK;AACP,WACEvG,6BAAAA,QAAA,cAACyG,gBAAAA;MACCnM,QAAIuJ,YAAAA,kBAAiBO,MAAAA;MACrB1J;MACA6G,UAAUgF;MACV3L;MACAI;MACAwG;MACA1G;MACAK;;EAGN,OAAO;AACL,WACE6E,6BAAAA,QAAA,cAACvF,gBAAAA;MACCH;MACAI;MACAC,cAAcyJ,OAAOvB;MACrBjI;MACAI;MACAD,SAASyG,SAASzG;MAClB2L,WAAWlF,SAASO;MACpBjH;MACAK;;EAGN;AACF;AAOO,IAAMsL,iBAAiB,CAAC,EAAEnM,IAAIiH,UAAUgF,KAAK/E,UAAUxG,UAAU,GAAG2L,MAAAA,MAA4B;AACrG,QAAMhF,YAAQC,YAAAA,UAAS2E,GAAAA;AAGvBpH,mBAAAA,WAAU,MAAA;AACR,QAAI,OAAOoH,IAAIK,iBAAiB,UAAU;AACxC;IACF;AAEA,UAAMA,eAAeL,IAAIpI,SAASkD,QAAQlD,cAAU0I,uCAAgBN,IAAIpI,QAAQkD,OAAOlD,OAAO,IAAI3E;AAClG,QAAIoN,cAAc;AAChBL,UAAIK,eAAeA;IACrB;EACF,GAAG;IAACL;IAAKA,IAAIpI;GAAQ;AAGrB,QAAM,CAAC2I,MAAAA,QAAU1E,qBAAAA,iBAAgB2E,kCAAaC,YAAY;AAC1D,QAAMC,uBAAmBvO,aAAAA,SAAQ,MAAA;AAC/B,QAAIiJ,UAAUnI,UAAasN,WAAWtN,QAAW;AAC/C,aAAOA;IACT;AAGA,WAAO,OAAO4D,SAAe0J,OAAQ1J,MAAMuE,KAAAA;EAC7C,GAAG;IAACA;IAAOmF;GAAO;AAElB,SACE9G,6BAAAA,QAAA,cAACvF,gBAAAA;IACCH;IACAK,cAAc4L,IAAIpI,SAASkD,QAAQlD;IACnCnD;IACAD,SAASyG,SAASzG;IAClB2L,WAAWlF,SAASO;IACpB7G,cAAc+L;IACb,GAAGN;;AAGV;AAEA,IAAA,4BAAeL;",
|
|
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
|
|
20
|
-
__export(
|
|
19
|
+
var chunk_34WFGSZU_exports = {};
|
|
20
|
+
__export(chunk_34WFGSZU_exports, {
|
|
21
21
|
DocumentType: () => DocumentType,
|
|
22
22
|
MarkdownAction: () => MarkdownAction,
|
|
23
|
-
|
|
23
|
+
MarkdownSettingsSchema: () => MarkdownSettingsSchema,
|
|
24
24
|
isEditorModel: () => isEditorModel
|
|
25
25
|
});
|
|
26
|
-
module.exports = __toCommonJS(
|
|
27
|
-
var
|
|
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 = `${
|
|
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
|
-
|
|
83
|
+
MarkdownSettingsSchema,
|
|
79
84
|
isEditorModel
|
|
80
85
|
});
|
|
81
|
-
//# sourceMappingURL=chunk-
|
|
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
|
+
}
|