@dxos/plugin-markdown 0.6.8-staging.77f93a3 → 0.6.8-staging.dec6b33
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/{DocumentEditor-DJ4K24MQ.mjs → DocumentEditor-NTERM6NF.mjs} +3 -3
- package/dist/lib/browser/{MarkdownEditor-KQWSKW2I.mjs → MarkdownEditor-5M5II34Y.mjs} +2 -2
- package/dist/lib/browser/{chunk-4UK23TZF.mjs → chunk-52M37CDH.mjs} +2 -2
- package/dist/lib/browser/{chunk-E5LKC775.mjs → chunk-IWA4H2T7.mjs} +14 -16
- package/dist/lib/browser/{chunk-E5LKC775.mjs.map → chunk-IWA4H2T7.mjs.map} +3 -3
- package/dist/lib/browser/index.mjs +4 -4
- package/dist/lib/browser/index.mjs.map +2 -2
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node/{DocumentEditor-2YZ2DBYL.cjs → DocumentEditor-UMWEXCDU.cjs} +7 -7
- package/dist/lib/node/{DocumentEditor-2YZ2DBYL.cjs.map → DocumentEditor-UMWEXCDU.cjs.map} +2 -2
- package/dist/lib/node/{MarkdownEditor-O4FJQIFS.cjs → MarkdownEditor-SJAWKOPB.cjs} +7 -7
- package/dist/lib/node/{MarkdownEditor-O4FJQIFS.cjs.map → MarkdownEditor-SJAWKOPB.cjs.map} +2 -2
- package/dist/lib/node/{chunk-DJ352NAA.cjs → chunk-7EEMD6CH.cjs} +6 -6
- package/dist/lib/node/{chunk-JSS2PWPA.cjs → chunk-OIOOPQLA.cjs} +17 -19
- package/dist/lib/node/{chunk-JSS2PWPA.cjs.map → chunk-OIOOPQLA.cjs.map} +3 -3
- package/dist/lib/node/index.cjs +11 -11
- package/dist/lib/node/index.cjs.map +2 -2
- package/dist/lib/node/meta.json +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
- package/package.json +28 -28
- package/src/MarkdownPlugin.tsx +1 -4
- package/src/components/MarkdownEditor.tsx +16 -12
- /package/dist/lib/browser/{DocumentEditor-DJ4K24MQ.mjs.map → DocumentEditor-NTERM6NF.mjs.map} +0 -0
- /package/dist/lib/browser/{MarkdownEditor-KQWSKW2I.mjs.map → MarkdownEditor-5M5II34Y.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-4UK23TZF.mjs.map → chunk-52M37CDH.mjs.map} +0 -0
- /package/dist/lib/node/{chunk-DJ352NAA.cjs.map → chunk-7EEMD6CH.cjs.map} +0 -0
|
@@ -16,14 +16,14 @@ 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(
|
|
21
|
-
default: () =>
|
|
19
|
+
var DocumentEditor_UMWEXCDU_exports = {};
|
|
20
|
+
__export(DocumentEditor_UMWEXCDU_exports, {
|
|
21
|
+
default: () => import_chunk_7EEMD6CH.DocumentEditor_default
|
|
22
22
|
});
|
|
23
|
-
module.exports = __toCommonJS(
|
|
24
|
-
var
|
|
23
|
+
module.exports = __toCommonJS(DocumentEditor_UMWEXCDU_exports);
|
|
24
|
+
var import_chunk_7EEMD6CH = require("./chunk-7EEMD6CH.cjs");
|
|
25
25
|
var import_chunk_VYLYUDDI = require("./chunk-VYLYUDDI.cjs");
|
|
26
26
|
var import_chunk_TZDYK4MV = require("./chunk-TZDYK4MV.cjs");
|
|
27
|
-
var
|
|
27
|
+
var import_chunk_OIOOPQLA = require("./chunk-OIOOPQLA.cjs");
|
|
28
28
|
var import_chunk_TGMR2CKU = require("./chunk-TGMR2CKU.cjs");
|
|
29
|
-
//# sourceMappingURL=DocumentEditor-
|
|
29
|
+
//# sourceMappingURL=DocumentEditor-UMWEXCDU.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["DocumentEditor-
|
|
4
|
-
"sourcesContent": ["import {\n DocumentEditor_default\n} from \"./chunk-
|
|
3
|
+
"sources": ["DocumentEditor-UMWEXCDU.cjs"],
|
|
4
|
+
"sourcesContent": ["import {\n DocumentEditor_default\n} from \"./chunk-7EEMD6CH.cjs\";\nimport \"./chunk-VYLYUDDI.cjs\";\nimport \"./chunk-TZDYK4MV.cjs\";\nimport \"./chunk-OIOOPQLA.cjs\";\nimport \"./chunk-TGMR2CKU.cjs\";\nexport {\n DocumentEditor_default as default\n};\n//# sourceMappingURL=DocumentEditor-UMWEXCDU.cjs.map\n"],
|
|
5
5
|
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAEO;AACP,4BAAO;AACP,4BAAO;AACP,4BAAO;AACP,4BAAO;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -16,16 +16,16 @@ 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(
|
|
21
|
-
MarkdownEditor: () =>
|
|
22
|
-
default: () =>
|
|
19
|
+
var MarkdownEditor_SJAWKOPB_exports = {};
|
|
20
|
+
__export(MarkdownEditor_SJAWKOPB_exports, {
|
|
21
|
+
MarkdownEditor: () => import_chunk_OIOOPQLA.MarkdownEditor,
|
|
22
|
+
default: () => import_chunk_OIOOPQLA.MarkdownEditor_default
|
|
23
23
|
});
|
|
24
|
-
module.exports = __toCommonJS(
|
|
25
|
-
var
|
|
24
|
+
module.exports = __toCommonJS(MarkdownEditor_SJAWKOPB_exports);
|
|
25
|
+
var import_chunk_OIOOPQLA = require("./chunk-OIOOPQLA.cjs");
|
|
26
26
|
var import_chunk_TGMR2CKU = require("./chunk-TGMR2CKU.cjs");
|
|
27
27
|
// Annotate the CommonJS export names for ESM import in node:
|
|
28
28
|
0 && (module.exports = {
|
|
29
29
|
MarkdownEditor
|
|
30
30
|
});
|
|
31
|
-
//# sourceMappingURL=MarkdownEditor-
|
|
31
|
+
//# sourceMappingURL=MarkdownEditor-SJAWKOPB.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["MarkdownEditor-
|
|
4
|
-
"sourcesContent": ["import {\n MarkdownEditor,\n MarkdownEditor_default\n} from \"./chunk-
|
|
3
|
+
"sources": ["MarkdownEditor-SJAWKOPB.cjs"],
|
|
4
|
+
"sourcesContent": ["import {\n MarkdownEditor,\n MarkdownEditor_default\n} from \"./chunk-OIOOPQLA.cjs\";\nimport \"./chunk-TGMR2CKU.cjs\";\nexport {\n MarkdownEditor,\n MarkdownEditor_default as default\n};\n//# sourceMappingURL=MarkdownEditor-SJAWKOPB.cjs.map\n"],
|
|
5
5
|
"mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAGO;AACP,4BAAO;",
|
|
6
6
|
"names": []
|
|
7
7
|
}
|
|
@@ -26,8 +26,8 @@ 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 chunk_7EEMD6CH_exports = {};
|
|
30
|
+
__export(chunk_7EEMD6CH_exports, {
|
|
31
31
|
DocumentEditor_default: () => DocumentEditor_default,
|
|
32
32
|
getFallbackName: () => getFallbackName,
|
|
33
33
|
isMarkdownProperties: () => isMarkdownProperties,
|
|
@@ -35,10 +35,10 @@ __export(chunk_DJ352NAA_exports, {
|
|
|
35
35
|
serializer: () => serializer,
|
|
36
36
|
setFallbackName: () => setFallbackName
|
|
37
37
|
});
|
|
38
|
-
module.exports = __toCommonJS(
|
|
38
|
+
module.exports = __toCommonJS(chunk_7EEMD6CH_exports);
|
|
39
39
|
var import_chunk_VYLYUDDI = require("./chunk-VYLYUDDI.cjs");
|
|
40
40
|
var import_chunk_TZDYK4MV = require("./chunk-TZDYK4MV.cjs");
|
|
41
|
-
var
|
|
41
|
+
var import_chunk_OIOOPQLA = require("./chunk-OIOOPQLA.cjs");
|
|
42
42
|
var import_react = __toESM(require("react"));
|
|
43
43
|
var import_app_framework = require("@dxos/app-framework");
|
|
44
44
|
var import_echo = require("@dxos/react-client/echo");
|
|
@@ -163,7 +163,7 @@ var DocumentEditor = ({ document: doc, extensionProviders = [], viewMode, settin
|
|
|
163
163
|
fileManagerPlugin,
|
|
164
164
|
space
|
|
165
165
|
]);
|
|
166
|
-
return /* @__PURE__ */ import_react.default.createElement(
|
|
166
|
+
return /* @__PURE__ */ import_react.default.createElement(import_chunk_OIOOPQLA.MarkdownEditor_default, {
|
|
167
167
|
id,
|
|
168
168
|
initialValue,
|
|
169
169
|
extensions,
|
|
@@ -186,4 +186,4 @@ var DocumentEditor_default = DocumentEditor;
|
|
|
186
186
|
serializer,
|
|
187
187
|
setFallbackName
|
|
188
188
|
});
|
|
189
|
-
//# sourceMappingURL=chunk-
|
|
189
|
+
//# sourceMappingURL=chunk-7EEMD6CH.cjs.map
|
|
@@ -26,12 +26,12 @@ 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 chunk_OIOOPQLA_exports = {};
|
|
30
|
+
__export(chunk_OIOOPQLA_exports, {
|
|
31
31
|
MarkdownEditor: () => MarkdownEditor,
|
|
32
32
|
MarkdownEditor_default: () => MarkdownEditor_default
|
|
33
33
|
});
|
|
34
|
-
module.exports = __toCommonJS(
|
|
34
|
+
module.exports = __toCommonJS(chunk_OIOOPQLA_exports);
|
|
35
35
|
var import_chunk_TGMR2CKU = require("./chunk-TGMR2CKU.cjs");
|
|
36
36
|
var import_view = require("@codemirror/view");
|
|
37
37
|
var import_react = __toESM(require("react"));
|
|
@@ -102,6 +102,16 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
102
102
|
}
|
|
103
103
|
}
|
|
104
104
|
});
|
|
105
|
+
const handleDrop = async (view, { files }) => {
|
|
106
|
+
const file = files[0];
|
|
107
|
+
const info = file && onFileUpload ? await onFileUpload(file) : void 0;
|
|
108
|
+
if (info) {
|
|
109
|
+
(0, import_react_ui_editor.processAction)(view, {
|
|
110
|
+
type: "image",
|
|
111
|
+
data: info.url
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
};
|
|
105
115
|
const { parentRef, view: editorView, focusAttributes } = (0, import_react_ui_editor.useTextEditor)(() => ({
|
|
106
116
|
initialValue,
|
|
107
117
|
extensions: [
|
|
@@ -156,16 +166,6 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
156
166
|
}
|
|
157
167
|
handleToolbarAction?.(action);
|
|
158
168
|
};
|
|
159
|
-
const handleDrop = async (view, { files }) => {
|
|
160
|
-
const file = files[0];
|
|
161
|
-
const info = file && onFileUpload ? await onFileUpload(file) : void 0;
|
|
162
|
-
if (info) {
|
|
163
|
-
(0, import_react_ui_editor.processAction)(view, {
|
|
164
|
-
type: "image",
|
|
165
|
-
data: info.url
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
};
|
|
169
169
|
return /* @__PURE__ */ import_react.default.createElement("div", {
|
|
170
170
|
role: "none",
|
|
171
171
|
...role === "section" ? {
|
|
@@ -181,8 +181,9 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
181
181
|
className: (0, import_react_ui_theme.mx)("flex shrink-0 justify-center overflow-x-auto", attentionFragment)
|
|
182
182
|
}, /* @__PURE__ */ import_react.default.createElement(import_react_ui_editor.Toolbar.Root, {
|
|
183
183
|
classNames: role === "section" ? [
|
|
184
|
+
import_react_ui_theme.textBlockWidth,
|
|
184
185
|
"z-[2] group-focus-within/section:visible",
|
|
185
|
-
!
|
|
186
|
+
!isDirectlyAttended && "invisible",
|
|
186
187
|
import_react_ui_stack.sectionToolbarLayout
|
|
187
188
|
] : [
|
|
188
189
|
import_react_ui_theme.textBlockWidth,
|
|
@@ -202,10 +203,7 @@ var MarkdownEditor = ({ id, role = "article", initialValue, extensions, extensio
|
|
|
202
203
|
ref: parentRef,
|
|
203
204
|
"data-testid": "composer.markdownRoot",
|
|
204
205
|
"data-toolbar": toolbar ? "enabled" : "disabled",
|
|
205
|
-
className: (
|
|
206
|
-
// TODO(burdon): Factor out margin for focus.
|
|
207
|
-
role === "section" ? (0, import_react_ui_theme.mx)("flex flex-col flex-1 min-bs-[12rem] mt-[2px]", import_react_ui_theme.focusRing) : (0, import_react_ui_theme.mx)("flex is-full bs-full overflow-hidden", import_react_ui_theme.focusRing, attentionFragment, "focus-visible:ring-inset", "data-[toolbar=disabled]:pbs-2 data-[toolbar=disabled]:row-span-2")
|
|
208
|
-
),
|
|
206
|
+
className: role === "section" ? (0, import_react_ui_theme.mx)("flex flex-col flex-1 min-bs-[12rem]", import_react_ui_theme.focusRing) : (0, import_react_ui_theme.mx)("flex is-full bs-full overflow-hidden", import_react_ui_theme.focusRing, attentionFragment, "focus-visible:ring-inset", "data-[toolbar=disabled]:pbs-2 data-[toolbar=disabled]:row-span-2"),
|
|
209
207
|
...focusAttributes
|
|
210
208
|
}));
|
|
211
209
|
};
|
|
@@ -225,4 +223,4 @@ var MarkdownEditor_default = MarkdownEditor;
|
|
|
225
223
|
MarkdownEditor,
|
|
226
224
|
MarkdownEditor_default
|
|
227
225
|
});
|
|
228
|
-
//# sourceMappingURL=chunk-
|
|
226
|
+
//# sourceMappingURL=chunk-OIOOPQLA.cjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/components/MarkdownEditor.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport React, { useMemo, useEffect, useCallback } from 'react';\n\nimport {\n type FileInfo,\n LayoutAction,\n type LayoutCoordinate,\n useResolvePlugin,\n useIntentResolver,\n parseLayoutPlugin,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { parseAttentionPlugin } from '@dxos/plugin-attention';\nimport { useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type Action,\n type DNDOptions,\n type EditorViewMode,\n type EditorInputMode,\n type UseTextEditorProps,\n Toolbar,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n processAction,\n useActionHandler,\n useCommentState,\n useCommentClickListener,\n useFormattingState,\n useTextEditor,\n editorContent,\n editorGutter,\n Cursor,\n setSelection,\n} from '@dxos/react-ui-editor';\nimport { sectionToolbarLayout } from '@dxos/react-ui-stack';\nimport { textBlockWidth, focusRing, mx } from '@dxos/react-ui-theme';\nimport { nonNullable } from '@dxos/util';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport type { MarkdownPluginState } from '../types';\n\nconst attentionFragment = mx(\n 'group-focus-within/editor:attention-surface group-[[aria-current]]/editor:attention-surface',\n 'group-focus-within/editor:separator-separator',\n);\n\nconst DEFAULT_VIEW_MODE: EditorViewMode = 'preview';\n\nexport type MarkdownEditorProps = {\n id: string;\n coordinate?: LayoutCoordinate;\n inputMode?: EditorInputMode;\n role?: string;\n scrollPastEnd?: boolean;\n toolbar?: boolean;\n viewMode?: EditorViewMode;\n onViewModeChange?: (id: string, mode: EditorViewMode) => void;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n} & Pick<UseTextEditorProps, 'initialValue' | 'scrollTo' | 'selection' | 'extensions'> &\n Partial<Pick<MarkdownPluginState, 'extensionProviders'>>;\n\nexport const MarkdownEditor = ({\n id,\n role = 'article',\n initialValue,\n extensions,\n extensionProviders,\n scrollPastEnd,\n scrollTo,\n selection,\n toolbar,\n viewMode,\n onFileUpload,\n onViewModeChange,\n}: MarkdownEditorProps) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n const { themeMode } = useThemeContext();\n const dispatch = useIntentDispatcher();\n const attentionPlugin = useResolvePlugin(parseAttentionPlugin);\n const layoutPlugin = useResolvePlugin(parseLayoutPlugin);\n const attended = Array.from(attentionPlugin?.provides.attention?.attended ?? []);\n const isDirectlyAttended = attended.length === 1 && attended[0] === id;\n const [formattingState, formattingObserver] = useFormattingState();\n\n // Extensions from other plugins.\n const providerExtensions = useMemo(() => extensionProviders?.map((provider) => provider({})), [extensionProviders]);\n\n // TODO(Zan): Move these into thread plugin as well?\n const [commentsState, commentObserver] = useCommentState();\n const onCommentClick = useCallback(() => {\n void dispatch({ action: LayoutAction.SET_LAYOUT, data: { element: 'complementary', state: true } });\n }, [dispatch]);\n const commentClickObserver = useCommentClickListener(onCommentClick);\n\n // Focus the space that references the comment.\n useIntentResolver(MARKDOWN_PLUGIN, ({ action, data }) => {\n switch (action) {\n // TODO(burdon): Use fully qualified ids everywhere.\n case LayoutAction.SCROLL_INTO_VIEW: {\n if (editorView && data?.id === id && data?.cursor) {\n // TODO(burdon): We need typed intents.\n const range = Cursor.getRangeFromCursor(editorView.state, data.cursor);\n if (range?.from) {\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: id }));\n }\n\n editorView.dispatch({\n effects,\n selection: selection ? { anchor: range.from } : undefined,\n });\n }\n }\n break;\n }\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({ themeMode, slots: { content: { className: editorContent } } }),\n editorGutter,\n role !== 'section' && onFileUpload ? dropFile({ onDrop: handleDrop }) : [],\n providerExtensions,\n extensions,\n ].filter(nonNullable),\n ...(role !== 'section' && {\n id,\n scrollTo,\n selection,\n // TODO(wittjosiah): Autofocus based on layout is racey.\n autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,\n moveToEndOfLine: true,\n }),\n }),\n [id, initialValue, formattingObserver, viewMode, themeMode, extensions, providerExtensions],\n );\n\n useTest(editorView);\n\n // Toolbar handler.\n const handleToolbarAction = useActionHandler(editorView);\n const handleAction = (action: Action) => {\n if (action.type === 'view-mode') {\n onViewModeChange?.(id, action.data);\n }\n\n handleToolbarAction?.(action);\n };\n\n
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,kBAA2B;AAC3B,mBAAuD;AAEvD,2BAQO;AACP,8BAAqC;AACrC,sBAAgD;AAChD,6BAqBO;AACP,4BAAqC;AACrC,4BAA8C;AAC9C,kBAA4B;AAK5B,IAAMA,wBAAoBC,0BACxB,+FACA,+CAAA;AAGF,IAAMC,oBAAoC;AAenC,IAAMC,iBAAiB,CAAC,EAC7BC,IACAC,OAAO,WACPC,cACAC,YACAC,oBACAC,eACAC,UACAC,WACAC,SACAC,UACAC,cACAC,iBAAgB,MACI;AACpB,QAAM,EAAEC,EAAC,QAAKC,gCAAeC,qCAAAA;AAC7B,QAAM,EAAEC,UAAS,QAAKC,iCAAAA;AACtB,QAAMC,eAAWC,0CAAAA;AACjB,QAAMC,sBAAkBC,uCAAiBC,4CAAAA;AACzC,QAAMC,mBAAeF,uCAAiBG,sCAAAA;AACtC,QAAMC,WAAWC,MAAMC,KAAKP,iBAAiBQ,SAASC,WAAWJ,YAAY,CAAA,CAAE;AAC/E,QAAMK,qBAAqBL,SAASM,WAAW,KAAKN,SAAS,CAAA,MAAOxB;AACpE,QAAM,CAAC+B,iBAAiBC,kBAAAA,QAAsBC,2CAAAA;AAG9C,QAAMC,yBAAqBC,sBAAQ,MAAM/B,oBAAoBgC,IAAI,CAACC,aAAaA,SAAS,CAAC,CAAA,CAAA,GAAK;IAACjC;GAAmB;AAGlH,QAAM,CAACkC,eAAeC,eAAAA,QAAmBC,wCAAAA;AACzC,QAAMC,qBAAiBC,0BAAY,MAAA;AACjC,SAAKzB,SAAS;MAAE0B,QAAQC,kCAAaC;MAAYC,MAAM;QAAEC,SAAS;QAAiBC,OAAO;MAAK;IAAE,CAAA;EACnG,GAAG;IAAC/B;GAAS;AACb,QAAMgC,2BAAuBC,gDAAwBT,cAAAA;AAGrDU,8CAAkBrC,uCAAiB,CAAC,EAAE6B,QAAQG,KAAI,MAAE;AAClD,YAAQH,QAAAA;MAEN,KAAKC,kCAAaQ,kBAAkB;AAClC,YAAIC,cAAcP,MAAM9C,OAAOA,MAAM8C,MAAMQ,QAAQ;AAEjD,gBAAMC,QAAQC,8BAAOC,mBAAmBJ,WAAWL,OAAOF,KAAKQ,MAAM;AACrE,cAAIC,OAAO7B,MAAM;AACf,kBAAMnB,aAAY8C,WAAWL,MAAMzC,UAAUmD,KAAKhC,SAAS6B,MAAM7B,OAAO;cAAEiC,QAAQJ,MAAM7B;YAAK,IAAIkC;AACjG,kBAAMC,UAAU;;cAEdC,uBAAWC,eAAeR,MAAM7B,MAAM;gBAAEsC,GAAG;gBAASC,SAAS;cAAG,CAAA;;AAElE,gBAAI1D,YAAW;AAEbsD,sBAAQK,KAAKC,oCAAaC,GAAG;gBAAEC,SAASrE;cAAG,CAAA,CAAA;YAC7C;AAEAqD,uBAAWpC,SAAS;cAClB4C;cACAtD,WAAWA,aAAY;gBAAEoD,QAAQJ,MAAM7B;cAAK,IAAIkC;YAClD,CAAA;UACF;QACF;AACA;MACF;IACF;EACF,CAAA;AAEA,QAAM,
|
|
6
|
-
"names": ["attentionFragment", "mx", "DEFAULT_VIEW_MODE", "MarkdownEditor", "id", "role", "initialValue", "extensions", "extensionProviders", "scrollPastEnd", "scrollTo", "selection", "toolbar", "viewMode", "onFileUpload", "onViewModeChange", "t", "useTranslation", "MARKDOWN_PLUGIN", "themeMode", "useThemeContext", "dispatch", "useIntentDispatcher", "attentionPlugin", "useResolvePlugin", "parseAttentionPlugin", "layoutPlugin", "parseLayoutPlugin", "attended", "Array", "from", "provides", "attention", "isDirectlyAttended", "length", "formattingState", "formattingObserver", "useFormattingState", "providerExtensions", "useMemo", "map", "provider", "commentsState", "commentObserver", "useCommentState", "onCommentClick", "useCallback", "action", "LayoutAction", "SET_LAYOUT", "data", "element", "state", "commentClickObserver", "useCommentClickListener", "useIntentResolver", "SCROLL_INTO_VIEW", "editorView", "cursor", "range", "Cursor", "getRangeFromCursor", "main", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport React, { useMemo, useEffect, useCallback } from 'react';\n\nimport {\n type FileInfo,\n LayoutAction,\n type LayoutCoordinate,\n useResolvePlugin,\n useIntentResolver,\n parseLayoutPlugin,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { parseAttentionPlugin } from '@dxos/plugin-attention';\nimport { useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type Action,\n type DNDOptions,\n type EditorViewMode,\n type EditorInputMode,\n type UseTextEditorProps,\n Toolbar,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n processAction,\n useActionHandler,\n useCommentState,\n useCommentClickListener,\n useFormattingState,\n useTextEditor,\n editorContent,\n editorGutter,\n Cursor,\n setSelection,\n} from '@dxos/react-ui-editor';\nimport { sectionToolbarLayout } from '@dxos/react-ui-stack';\nimport { textBlockWidth, focusRing, mx } from '@dxos/react-ui-theme';\nimport { nonNullable } from '@dxos/util';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport type { MarkdownPluginState } from '../types';\n\nconst attentionFragment = mx(\n 'group-focus-within/editor:attention-surface group-[[aria-current]]/editor:attention-surface',\n 'group-focus-within/editor:separator-separator',\n);\n\nconst DEFAULT_VIEW_MODE: EditorViewMode = 'preview';\n\nexport type MarkdownEditorProps = {\n id: string;\n coordinate?: LayoutCoordinate;\n inputMode?: EditorInputMode;\n role?: string;\n scrollPastEnd?: boolean;\n toolbar?: boolean;\n viewMode?: EditorViewMode;\n onViewModeChange?: (id: string, mode: EditorViewMode) => void;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n} & Pick<UseTextEditorProps, 'initialValue' | 'scrollTo' | 'selection' | 'extensions'> &\n Partial<Pick<MarkdownPluginState, 'extensionProviders'>>;\n\nexport const MarkdownEditor = ({\n id,\n role = 'article',\n initialValue,\n extensions,\n extensionProviders,\n scrollPastEnd,\n scrollTo,\n selection,\n toolbar,\n viewMode,\n onFileUpload,\n onViewModeChange,\n}: MarkdownEditorProps) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n const { themeMode } = useThemeContext();\n const dispatch = useIntentDispatcher();\n const attentionPlugin = useResolvePlugin(parseAttentionPlugin);\n const layoutPlugin = useResolvePlugin(parseLayoutPlugin);\n const attended = Array.from(attentionPlugin?.provides.attention?.attended ?? []);\n const isDirectlyAttended = attended.length === 1 && attended[0] === id;\n const [formattingState, formattingObserver] = useFormattingState();\n\n // Extensions from other plugins.\n const providerExtensions = useMemo(() => extensionProviders?.map((provider) => provider({})), [extensionProviders]);\n\n // TODO(Zan): Move these into thread plugin as well?\n const [commentsState, commentObserver] = useCommentState();\n const onCommentClick = useCallback(() => {\n void dispatch({ action: LayoutAction.SET_LAYOUT, data: { element: 'complementary', state: true } });\n }, [dispatch]);\n const commentClickObserver = useCommentClickListener(onCommentClick);\n\n // Focus the space that references the comment.\n useIntentResolver(MARKDOWN_PLUGIN, ({ action, data }) => {\n switch (action) {\n // TODO(burdon): Use fully qualified ids everywhere.\n case LayoutAction.SCROLL_INTO_VIEW: {\n if (editorView && data?.id === id && data?.cursor) {\n // TODO(burdon): We need typed intents.\n const range = Cursor.getRangeFromCursor(editorView.state, data.cursor);\n if (range?.from) {\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: id }));\n }\n\n editorView.dispatch({\n effects,\n selection: selection ? { anchor: range.from } : undefined,\n });\n }\n }\n break;\n }\n }\n });\n\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 processAction(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({ themeMode, slots: { content: { className: editorContent } } }),\n editorGutter,\n role !== 'section' && onFileUpload ? dropFile({ onDrop: handleDrop }) : [],\n providerExtensions,\n extensions,\n ].filter(nonNullable),\n ...(role !== 'section' && {\n id,\n scrollTo,\n selection,\n // TODO(wittjosiah): Autofocus based on layout is racey.\n autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,\n moveToEndOfLine: true,\n }),\n }),\n [id, initialValue, formattingObserver, viewMode, themeMode, extensions, providerExtensions],\n );\n\n useTest(editorView);\n\n // Toolbar handler.\n const handleToolbarAction = useActionHandler(editorView);\n const handleAction = (action: Action) => {\n if (action.type === 'view-mode') {\n onViewModeChange?.(id, action.data);\n }\n\n handleToolbarAction?.(action);\n };\n\n return (\n <div\n role='none'\n // TODO(burdon): Move role logic out of here (see sheet, table, sketch, etc.)\n {...(role === 'section'\n ? { className: 'flex flex-col' }\n : {\n className: 'contents group/editor',\n ...(isDirectlyAttended && { 'aria-current': 'location' }),\n })}\n >\n {toolbar && (\n <div role='none' className={mx('flex shrink-0 justify-center overflow-x-auto', attentionFragment)}>\n <Toolbar.Root\n classNames={\n role === 'section'\n ? [\n textBlockWidth,\n 'z-[2] group-focus-within/section:visible',\n !isDirectlyAttended && 'invisible',\n sectionToolbarLayout,\n ]\n : [\n textBlockWidth,\n 'group-focus-within/editor:separator-separator group-[[aria-current]]/editor:separator-separator',\n ]\n }\n state={formattingState && { ...formattingState, ...commentsState }}\n onAction={handleAction}\n >\n <Toolbar.Markdown />\n {onFileUpload && <Toolbar.Custom onUpload={onFileUpload} />}\n <Toolbar.Separator />\n <Toolbar.View mode={viewMode ?? DEFAULT_VIEW_MODE} />\n <Toolbar.Actions />\n </Toolbar.Root>\n </div>\n )}\n <div\n role='none'\n ref={parentRef}\n data-testid='composer.markdownRoot'\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n className={\n role === 'section'\n ? mx('flex flex-col flex-1 min-bs-[12rem]', focusRing)\n : mx(\n 'flex is-full bs-full overflow-hidden',\n focusRing,\n attentionFragment,\n 'focus-visible:ring-inset',\n 'data-[toolbar=disabled]:pbs-2 data-[toolbar=disabled]:row-span-2',\n )\n }\n {...focusAttributes}\n />\n </div>\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 default MarkdownEditor;\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,kBAA2B;AAC3B,mBAAuD;AAEvD,2BAQO;AACP,8BAAqC;AACrC,sBAAgD;AAChD,6BAqBO;AACP,4BAAqC;AACrC,4BAA8C;AAC9C,kBAA4B;AAK5B,IAAMA,wBAAoBC,0BACxB,+FACA,+CAAA;AAGF,IAAMC,oBAAoC;AAenC,IAAMC,iBAAiB,CAAC,EAC7BC,IACAC,OAAO,WACPC,cACAC,YACAC,oBACAC,eACAC,UACAC,WACAC,SACAC,UACAC,cACAC,iBAAgB,MACI;AACpB,QAAM,EAAEC,EAAC,QAAKC,gCAAeC,qCAAAA;AAC7B,QAAM,EAAEC,UAAS,QAAKC,iCAAAA;AACtB,QAAMC,eAAWC,0CAAAA;AACjB,QAAMC,sBAAkBC,uCAAiBC,4CAAAA;AACzC,QAAMC,mBAAeF,uCAAiBG,sCAAAA;AACtC,QAAMC,WAAWC,MAAMC,KAAKP,iBAAiBQ,SAASC,WAAWJ,YAAY,CAAA,CAAE;AAC/E,QAAMK,qBAAqBL,SAASM,WAAW,KAAKN,SAAS,CAAA,MAAOxB;AACpE,QAAM,CAAC+B,iBAAiBC,kBAAAA,QAAsBC,2CAAAA;AAG9C,QAAMC,yBAAqBC,sBAAQ,MAAM/B,oBAAoBgC,IAAI,CAACC,aAAaA,SAAS,CAAC,CAAA,CAAA,GAAK;IAACjC;GAAmB;AAGlH,QAAM,CAACkC,eAAeC,eAAAA,QAAmBC,wCAAAA;AACzC,QAAMC,qBAAiBC,0BAAY,MAAA;AACjC,SAAKzB,SAAS;MAAE0B,QAAQC,kCAAaC;MAAYC,MAAM;QAAEC,SAAS;QAAiBC,OAAO;MAAK;IAAE,CAAA;EACnG,GAAG;IAAC/B;GAAS;AACb,QAAMgC,2BAAuBC,gDAAwBT,cAAAA;AAGrDU,8CAAkBrC,uCAAiB,CAAC,EAAE6B,QAAQG,KAAI,MAAE;AAClD,YAAQH,QAAAA;MAEN,KAAKC,kCAAaQ,kBAAkB;AAClC,YAAIC,cAAcP,MAAM9C,OAAOA,MAAM8C,MAAMQ,QAAQ;AAEjD,gBAAMC,QAAQC,8BAAOC,mBAAmBJ,WAAWL,OAAOF,KAAKQ,MAAM;AACrE,cAAIC,OAAO7B,MAAM;AACf,kBAAMnB,aAAY8C,WAAWL,MAAMzC,UAAUmD,KAAKhC,SAAS6B,MAAM7B,OAAO;cAAEiC,QAAQJ,MAAM7B;YAAK,IAAIkC;AACjG,kBAAMC,UAAU;;cAEdC,uBAAWC,eAAeR,MAAM7B,MAAM;gBAAEsC,GAAG;gBAASC,SAAS;cAAG,CAAA;;AAElE,gBAAI1D,YAAW;AAEbsD,sBAAQK,KAAKC,oCAAaC,GAAG;gBAAEC,SAASrE;cAAG,CAAA,CAAA;YAC7C;AAEAqD,uBAAWpC,SAAS;cAClB4C;cACAtD,WAAWA,aAAY;gBAAEoD,QAAQJ,MAAM7B;cAAK,IAAIkC;YAClD,CAAA;UACF;QACF;AACA;MACF;IACF;EACF,CAAA;AAGA,QAAMU,aAAmC,OAAOC,MAAM,EAAEC,MAAK,MAAE;AAC7D,UAAMC,OAAOD,MAAM,CAAA;AACnB,UAAME,OAAOD,QAAQ/D,eAAe,MAAMA,aAAa+D,IAAAA,IAAQb;AAC/D,QAAIc,MAAM;AACRC,gDAAcJ,MAAM;QAAEK,MAAM;QAAS9B,MAAM4B,KAAKG;MAAI,CAAA;IACtD;EACF;AAEA,QAAM,EACJC,WACAP,MAAMlB,YACN0B,gBAAe,QACbC,sCACF,OAAO;IACL9E;IACAC,YAAY;MACV6B;MACAO;MACAU;UACAgC,8CAAsB;QACpBC,UAAUzE,aAAa;QACvB0E,aAAavE,EAAE,oBAAA;QACfP,eAAeJ,SAAS,YAAY,QAAQI;MAC9C,CAAA;UACA+E,iDAAyB;QAAErE;MAAU,CAAA;UACrCsE,8CAAsB;QAAEtE;QAAWuE,OAAO;UAAEC,SAAS;YAAEC,WAAWC;UAAc;QAAE;MAAE,CAAA;MACpFC;MACAzF,SAAS,aAAaS,mBAAeiF,iCAAS;QAAEC,QAAQtB;MAAW,CAAA,IAAK,CAAA;MACxEpC;MACA/B;MACA0F,OAAOC,uBAAAA;IACT,GAAI7F,SAAS,aAAa;MACxBD;MACAM;MACAC;;MAEAwF,WAAWzE,cAAcK,SAASqE,SAAS1E,cAAcK,SAASqE,OAAOjC,mBAAmB/D,KAAK;MACjGiG,iBAAiB;IACnB;EACF,IACA;IAACjG;IAAIE;IAAc8B;IAAoBvB;IAAUM;IAAWZ;IAAY+B;GAAmB;AAG7FgE,UAAQ7C,UAAAA;AAGR,QAAM8C,0BAAsBC,yCAAiB/C,UAAAA;AAC7C,QAAMgD,eAAe,CAAC1D,WAAAA;AACpB,QAAIA,OAAOiC,SAAS,aAAa;AAC/BjE,yBAAmBX,IAAI2C,OAAOG,IAAI;IACpC;AAEAqD,0BAAsBxD,MAAAA;EACxB;AAEA,SACE,6BAAA2D,QAAA,cAACC,OAAAA;IACCtG,MAAK;IAEJ,GAAIA,SAAS,YACV;MAAEuF,WAAW;IAAgB,IAC7B;MACEA,WAAW;MACX,GAAI3D,sBAAsB;QAAE,gBAAgB;MAAW;IACzD;KAEHrB,WACC,6BAAA8F,QAAA,cAACC,OAAAA;IAAItG,MAAK;IAAOuF,eAAW3F,0BAAG,gDAAgDD,iBAAAA;KAC7E,6BAAA0G,QAAA,cAACE,+BAAQC,MAAI;IACXC,YACEzG,SAAS,YACL;MACE0G;MACA;MACA,CAAC9E,sBAAsB;MACvB+E;QAEF;MACED;MACA;;IAGR3D,OAAOjB,mBAAmB;MAAE,GAAGA;MAAiB,GAAGO;IAAc;IACjEuE,UAAUR;KAEV,6BAAAC,QAAA,cAACE,+BAAQM,UAAQ,IAAA,GAChBpG,gBAAgB,6BAAA4F,QAAA,cAACE,+BAAQO,QAAM;IAACC,UAAUtG;MAC3C,6BAAA4F,QAAA,cAACE,+BAAQS,WAAS,IAAA,GAClB,6BAAAX,QAAA,cAACE,+BAAQU,MAAI;IAACC,MAAM1G,YAAYX;MAChC,6BAAAwG,QAAA,cAACE,+BAAQY,SAAO,IAAA,CAAA,CAAA,GAItB,6BAAAd,QAAA,cAACC,OAAAA;IACCtG,MAAK;IACLoH,KAAKvC;IACLwC,eAAY;IACZC,gBAAc/G,UAAU,YAAY;IACpCgF,WACEvF,SAAS,gBACLJ,0BAAG,uCAAuC2H,+BAAAA,QAC1C3H,0BACE,wCACA2H,iCACA5H,mBACA,4BACA,kEAAA;IAGP,GAAGmF;;AAIZ;AAIA,IAAMmB,UAAU,CAAC3B,SAAAA;AACfkD,8BAAU,MAAA;AACR,UAAMC,WAAYC,OAAeD;AACjC,QAAIA,UAAU;AACZA,eAASrE,aAAakB;IACxB;EACF,GAAG;IAACA;GAAK;AACX;AAEA,IAAA,yBAAexE;",
|
|
6
|
+
"names": ["attentionFragment", "mx", "DEFAULT_VIEW_MODE", "MarkdownEditor", "id", "role", "initialValue", "extensions", "extensionProviders", "scrollPastEnd", "scrollTo", "selection", "toolbar", "viewMode", "onFileUpload", "onViewModeChange", "t", "useTranslation", "MARKDOWN_PLUGIN", "themeMode", "useThemeContext", "dispatch", "useIntentDispatcher", "attentionPlugin", "useResolvePlugin", "parseAttentionPlugin", "layoutPlugin", "parseLayoutPlugin", "attended", "Array", "from", "provides", "attention", "isDirectlyAttended", "length", "formattingState", "formattingObserver", "useFormattingState", "providerExtensions", "useMemo", "map", "provider", "commentsState", "commentObserver", "useCommentState", "onCommentClick", "useCallback", "action", "LayoutAction", "SET_LAYOUT", "data", "element", "state", "commentClickObserver", "useCommentClickListener", "useIntentResolver", "SCROLL_INTO_VIEW", "editorView", "cursor", "range", "Cursor", "getRangeFromCursor", "main", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "handleDrop", "view", "files", "file", "info", "processAction", "type", "url", "parentRef", "focusAttributes", "useTextEditor", "createBasicExtensions", "readonly", "placeholder", "createMarkdownExtensions", "createThemeExtensions", "slots", "content", "className", "editorContent", "editorGutter", "dropFile", "onDrop", "filter", "nonNullable", "autoFocus", "layout", "moveToEndOfLine", "useTest", "handleToolbarAction", "useActionHandler", "handleAction", "React", "div", "Toolbar", "Root", "classNames", "textBlockWidth", "sectionToolbarLayout", "onAction", "Markdown", "Custom", "onUpload", "Separator", "View", "mode", "Actions", "ref", "data-testid", "data-toolbar", "focusRing", "useEffect", "composer", "window"]
|
|
7
7
|
}
|
package/dist/lib/node/index.cjs
CHANGED
|
@@ -33,18 +33,18 @@ __export(node_exports, {
|
|
|
33
33
|
MarkdownPlugin: () => MarkdownPlugin,
|
|
34
34
|
TextType: () => import_chunk_VYLYUDDI.TextType,
|
|
35
35
|
default: () => src_default,
|
|
36
|
-
getFallbackName: () =>
|
|
37
|
-
isMarkdownProperties: () =>
|
|
38
|
-
markdownExtensionPlugins: () =>
|
|
39
|
-
serializer: () =>
|
|
40
|
-
setFallbackName: () =>
|
|
36
|
+
getFallbackName: () => import_chunk_7EEMD6CH.getFallbackName,
|
|
37
|
+
isMarkdownProperties: () => import_chunk_7EEMD6CH.isMarkdownProperties,
|
|
38
|
+
markdownExtensionPlugins: () => import_chunk_7EEMD6CH.markdownExtensionPlugins,
|
|
39
|
+
serializer: () => import_chunk_7EEMD6CH.serializer,
|
|
40
|
+
setFallbackName: () => import_chunk_7EEMD6CH.setFallbackName
|
|
41
41
|
});
|
|
42
42
|
module.exports = __toCommonJS(node_exports);
|
|
43
43
|
var import_chunk_FW5O2I25 = require("./chunk-FW5O2I25.cjs");
|
|
44
|
-
var
|
|
44
|
+
var import_chunk_7EEMD6CH = require("./chunk-7EEMD6CH.cjs");
|
|
45
45
|
var import_chunk_VYLYUDDI = require("./chunk-VYLYUDDI.cjs");
|
|
46
46
|
var import_chunk_TZDYK4MV = require("./chunk-TZDYK4MV.cjs");
|
|
47
|
-
var
|
|
47
|
+
var import_chunk_OIOOPQLA = require("./chunk-OIOOPQLA.cjs");
|
|
48
48
|
var import_chunk_TGMR2CKU = require("./chunk-TGMR2CKU.cjs");
|
|
49
49
|
var import_react = require("@phosphor-icons/react");
|
|
50
50
|
var import_react2 = __toESM(require("react"));
|
|
@@ -132,8 +132,8 @@ var MarkdownSettings = ({ settings }) => {
|
|
|
132
132
|
})));
|
|
133
133
|
};
|
|
134
134
|
var DocumentCard = import_react3.default.lazy(() => import("./DocumentCard-SOTFILJY.cjs"));
|
|
135
|
-
var DocumentEditor = import_react3.default.lazy(() => import("./DocumentEditor-
|
|
136
|
-
var MarkdownEditor = import_react3.default.lazy(() => import("./MarkdownEditor-
|
|
135
|
+
var DocumentEditor = import_react3.default.lazy(() => import("./DocumentEditor-UMWEXCDU.cjs"));
|
|
136
|
+
var MarkdownEditor = import_react3.default.lazy(() => import("./MarkdownEditor-SJAWKOPB.cjs"));
|
|
137
137
|
var translations_default = [
|
|
138
138
|
{
|
|
139
139
|
"en-US": {
|
|
@@ -232,7 +232,7 @@ var MarkdownPlugin = () => {
|
|
|
232
232
|
storageKey: "view-mode",
|
|
233
233
|
type: import_local_storage.LocalStorageStore.json()
|
|
234
234
|
});
|
|
235
|
-
(0,
|
|
235
|
+
(0, import_chunk_7EEMD6CH.markdownExtensionPlugins)(plugins).forEach((plugin) => {
|
|
236
236
|
const { extensions } = plugin.provides.markdown;
|
|
237
237
|
state.values.extensionProviders.push(extensions);
|
|
238
238
|
});
|
|
@@ -259,7 +259,7 @@ var MarkdownPlugin = () => {
|
|
|
259
259
|
doc2.content,
|
|
260
260
|
...doc2.threads
|
|
261
261
|
]),
|
|
262
|
-
serializer:
|
|
262
|
+
serializer: import_chunk_7EEMD6CH.serializer
|
|
263
263
|
}
|
|
264
264
|
}
|
|
265
265
|
},
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/MarkdownPlugin.tsx", "../../../src/components/index.ts", "../../../src/components/HeadingMenu.tsx", "../../../src/components/Layout.tsx", "../../../src/components/MarkdownSettings.tsx", "../../../src/translations.ts", "../../../src/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type IconProps, TextAa } from '@phosphor-icons/react';\nimport React, { type Ref } from 'react';\n\nimport {\n isObject,\n parseIntentPlugin,\n resolvePlugin,\n LayoutAction,\n type LayoutCoordinate,\n NavigationAction,\n type PluginDefinition,\n} from '@dxos/app-framework';\nimport { create } from '@dxos/echo-schema';\nimport { LocalStorageStore } from '@dxos/local-storage';\nimport { parseClientPlugin } from '@dxos/plugin-client';\nimport { type ActionGroup, createExtension, isActionGroup } from '@dxos/plugin-graph';\nimport { SpaceAction } from '@dxos/plugin-space';\nimport { CollectionType } from '@dxos/plugin-space/types';\nimport { fullyQualifiedId, isSpace, loadObjectReferences } from '@dxos/react-client/echo';\nimport {\n type EditorInputMode,\n type EditorViewMode,\n EditorViewModes,\n translations as editorTranslations,\n} from '@dxos/react-ui-editor';\nimport { isTileComponentProps } from '@dxos/react-ui-mosaic';\n\nimport { type DocumentItemProps, DocumentCard, DocumentEditor, MarkdownEditor, MarkdownSettings } from './components';\nimport meta, { MARKDOWN_PLUGIN } from './meta';\nimport translations from './translations';\nimport { DocumentType, TextType } from './types';\nimport {\n type MarkdownPluginProvides,\n type MarkdownSettingsProps,\n MarkdownAction,\n type MarkdownPluginState,\n} from './types';\nimport { markdownExtensionPlugins, serializer } from './util';\n\n/**\n * Checks if an object conforms to the interface needed to render an editor.\n */\nconst isEditorModel = (data: any): data is { id: string; text: string } => {\n return (\n data &&\n typeof data === 'object' &&\n 'id' in data &&\n typeof data.id === 'string' &&\n 'text' in data &&\n typeof data.text === 'string'\n );\n};\n\nexport const MarkdownPlugin = (): PluginDefinition<MarkdownPluginProvides> => {\n const settings = new LocalStorageStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN, {\n defaultViewMode: 'preview',\n toolbar: true,\n experimental: false,\n });\n\n const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });\n\n const getViewMode = (id?: string) => {\n return (id && state.values.viewMode[id]) || settings.values.defaultViewMode;\n };\n\n const setViewMode = (id: string, nextViewMode: EditorViewMode) => {\n state.values.viewMode[id] = nextViewMode;\n };\n\n return {\n meta,\n ready: async (plugins) => {\n settings\n .prop({\n key: 'defaultViewMode',\n storageKey: 'default-view-mode',\n type: LocalStorageStore.enum<EditorViewMode>(),\n })\n .prop({\n key: 'editorInputMode',\n storageKey: 'editor-mode',\n type: LocalStorageStore.enum<EditorInputMode>({ allowUndefined: true }),\n })\n .prop({ key: 'toolbar', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'experimental', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'debug', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'typewriter', type: LocalStorageStore.string({ allowUndefined: true }) })\n .prop({ key: 'numberedHeadings', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'folding', type: LocalStorageStore.bool({ allowUndefined: true }) });\n\n state.prop({\n key: 'viewMode',\n storageKey: 'view-mode',\n type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>(),\n });\n\n markdownExtensionPlugins(plugins).forEach((plugin) => {\n const { extensions } = plugin.provides.markdown;\n state.values.extensionProviders.push(extensions);\n });\n },\n provides: {\n settings: settings.values,\n metadata: {\n records: {\n [DocumentType.typename]: {\n label: (object: any) => (object instanceof DocumentType ? object.name ?? object.fallbackName : undefined),\n placeholder: ['document title placeholder', { ns: MARKDOWN_PLUGIN }],\n icon: (props: IconProps) => <TextAa {...props} />,\n iconSymbol: 'ph--text-aa--regular',\n graphProps: {\n managesAutofocus: true,\n },\n // TODO(wittjosiah): Move out of metadata.\n loadReferences: (doc: DocumentType) => loadObjectReferences(doc, (doc) => [doc.content, ...doc.threads]),\n serializer,\n },\n },\n },\n translations: [...translations, ...editorTranslations],\n echo: {\n schema: [DocumentType, TextType],\n },\n graph: {\n builder: (plugins) => {\n const client = resolvePlugin(plugins, parseClientPlugin)?.provides.client;\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;\n if (!client || !dispatch) {\n return [];\n }\n\n return createExtension({\n id: MarkdownAction.CREATE,\n filter: (node): node is ActionGroup => isActionGroup(node) && node.id.startsWith(SpaceAction.ADD_OBJECT),\n actions: ({ node }) => {\n const id = node.id.split('/').at(-1);\n const [spaceId, objectId] = id?.split(':') ?? [];\n const space = client.spaces.get().find((space) => space.id === spaceId);\n const object = objectId && space?.db.getObjectById(objectId);\n const target = objectId ? object : space;\n if (!target) {\n return;\n }\n\n return [\n {\n id: `${MARKDOWN_PLUGIN}/create/${node.id}`,\n data: async () => {\n await dispatch([\n { plugin: MARKDOWN_PLUGIN, action: MarkdownAction.CREATE },\n { action: SpaceAction.ADD_OBJECT, data: { target } },\n { action: NavigationAction.OPEN },\n ]);\n },\n properties: {\n label: ['create document label', { ns: MARKDOWN_PLUGIN }],\n icon: (props: IconProps) => <TextAa {...props} />,\n iconSymbol: 'ph--text-aa--regular',\n testId: 'markdownPlugin.createObject',\n },\n },\n ];\n },\n });\n },\n serializer: (plugins) => {\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;\n if (!dispatch) {\n return [];\n }\n return [\n {\n inputType: DocumentType.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await loadObjectReferences(doc, (doc) => doc.content);\n return {\n name:\n doc.name ||\n doc.fallbackName ||\n translations[0]['en-US'][MARKDOWN_PLUGIN]['document title placeholder'],\n data: content.content,\n type: 'text/markdown',\n };\n },\n deserialize: async (data, ancestors) => {\n const space = ancestors.find(isSpace);\n const target =\n ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ??\n space?.properties[CollectionType.typename];\n if (!space || !target) {\n return;\n }\n\n const result = await dispatch([\n {\n plugin: MARKDOWN_PLUGIN,\n action: MarkdownAction.CREATE,\n data: { name: data.name, content: data.data },\n },\n {\n action: SpaceAction.ADD_OBJECT,\n data: { target },\n },\n ]);\n\n return result?.data.object;\n },\n },\n ];\n },\n },\n stack: {\n creators: [\n {\n id: 'create-stack-section-doc',\n testId: 'markdownPlugin.createSection',\n type: ['plugin name', { ns: MARKDOWN_PLUGIN }],\n label: ['create stack section label', { ns: MARKDOWN_PLUGIN }],\n icon: (props: any) => <TextAa {...props} />,\n intent: {\n plugin: MARKDOWN_PLUGIN,\n action: MarkdownAction.CREATE,\n },\n },\n ],\n },\n surface: {\n component: ({ data, role, ...props }, forwardedRef) => {\n const doc =\n data.active instanceof DocumentType\n ? data.active\n : data.object instanceof DocumentType\n ? data.object\n : undefined;\n\n switch (role) {\n case 'section':\n case 'article': {\n if (doc && doc.content) {\n return (\n <DocumentEditor\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n document={doc}\n extensionProviders={state.values.extensionProviders}\n settings={settings.values}\n viewMode={getViewMode(fullyQualifiedId(doc))}\n onViewModeChange={setViewMode}\n scrollPastEnd\n />\n );\n } else if (isEditorModel(data.object)) {\n return (\n <MarkdownEditor\n id={data.object.id}\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n initialValue={data.object.text}\n extensionProviders={state.values.extensionProviders}\n inputMode={settings.values.editorInputMode}\n toolbar={settings.values.toolbar}\n viewMode={getViewMode(data.object.id)}\n onViewModeChange={setViewMode}\n scrollPastEnd\n />\n );\n }\n break;\n }\n\n case 'card': {\n if (\n isObject(data.content) &&\n typeof data.content.id === 'string' &&\n data.content.object instanceof DocumentType\n ) {\n // isTileComponentProps is a type guard for these props.\n // `props` will not pass this guard without transforming `data` into `item`.\n const cardProps = {\n ...props,\n item: {\n id: data.content.id,\n object: data.content.object,\n color: typeof data.content.color === 'string' ? data.content.color : undefined,\n } as DocumentItemProps,\n };\n\n return isTileComponentProps(cardProps) ? (\n <DocumentCard {...cardProps} settings={settings.values} ref={forwardedRef as Ref<HTMLDivElement>} />\n ) : null;\n }\n break;\n }\n\n case 'settings': {\n return data.plugin === meta.id ? <MarkdownSettings settings={settings.values} /> : null;\n }\n }\n\n return null;\n },\n },\n intent: {\n resolver: ({ action, data }) => {\n switch (action) {\n case MarkdownAction.CREATE: {\n const doc = create(DocumentType, {\n name: data?.name,\n content: create(TextType, { content: data?.content ?? '' }),\n threads: [],\n });\n\n return {\n data: doc,\n intents: [[{ action: LayoutAction.SCROLL_INTO_VIEW, data: { id: fullyQualifiedId(doc) } }]],\n };\n }\n\n case MarkdownAction.SET_VIEW_MODE: {\n const { id, viewMode } = data ?? {};\n if (typeof id === 'string' && EditorViewModes.includes(viewMode)) {\n state.values.viewMode[id] = viewMode;\n return { data: true };\n }\n\n break;\n }\n }\n },\n },\n },\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type LazyExoticComponent } from 'react';\n\nimport { type DocumentEditor as DocumentEditorType } from './DocumentEditor';\n\nexport { type DocumentCardProps, type DocumentItemProps } from './DocumentCard';\n\nexport * from './DocumentCard';\nexport * from './DocumentEditor';\nexport * from './MarkdownEditor';\nexport * from './HeadingMenu';\nexport * from './Layout';\nexport * from './MarkdownSettings';\n\n// Lazily load components for content surfaces.\nexport const DocumentCard = React.lazy(() => import('./DocumentCard'));\nexport const DocumentEditor: LazyExoticComponent<DocumentEditorType> = React.lazy(() => import('./DocumentEditor'));\nexport const MarkdownEditor = React.lazy(() => import('./MarkdownEditor'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { DotsThreeVertical } from '@phosphor-icons/react';\nimport React, { type PropsWithChildren, type FC } from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { Button, DropdownMenu } from '@dxos/react-ui';\nimport { fineButtonDimensions, getSize } from '@dxos/react-ui-theme';\n\nimport { type DocumentType, type MarkdownProperties } from '../types';\n\n// TODO(thure): This needs to be refactored into a graph node action.\nexport const DocumentHeadingMenu: FC<{ document: DocumentType }> = ({ document }) => {\n return <HeadingMenu properties={document} content={document.content?.content} />;\n};\n\n/**\n * Menu for the layout heading.\n */\nexport const HeadingMenu = ({\n content,\n properties,\n}: PropsWithChildren<{\n content: string | undefined;\n properties: MarkdownProperties;\n}>) => {\n return (\n <DropdownMenu.Root modal={false}>\n <DropdownMenu.Trigger asChild>\n <Button variant='ghost' classNames={fineButtonDimensions}>\n <DotsThreeVertical className={getSize(4)} />\n </Button>\n </DropdownMenu.Trigger>\n <DropdownMenu.Portal>\n <DropdownMenu.Content sideOffset={8} classNames='z-10'>\n <DropdownMenu.Viewport>\n <Surface data={{ content, properties }} role='menuitem' />\n </DropdownMenu.Viewport>\n <DropdownMenu.Arrow />\n </DropdownMenu.Content>\n </DropdownMenu.Portal>\n </DropdownMenu.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\n\nimport { Main } from '@dxos/react-ui';\nimport { editorWithToolbarLayout } from '@dxos/react-ui-editor';\nimport { topbarBlockPaddingStart } from '@dxos/react-ui-theme';\n\nexport const MainLayout = ({ children, toolbar }: PropsWithChildren<{ toolbar?: boolean }>) => {\n return (\n <Main.Content\n bounce\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n classNames={[topbarBlockPaddingStart, editorWithToolbarLayout]}\n >\n {children}\n </Main.Content>\n );\n};\n\n// Used when the editor is embedded in another context (e.g., iframe) and has no topbar/sidebar/etc.\n// TODO(wittjosiah): What's the difference between this and Section/Card?\nexport const EmbeddedLayout = ({ children }: PropsWithChildren) => {\n return <Main.Content classNames='min-bs-[100dvh] grid p-0.5'>{children}</Main.Content>;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { SettingsValue } from '@dxos/plugin-settings';\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { type MarkdownSettingsProps } from '../types';\n\nexport const MarkdownSettings = ({ settings }: { settings: MarkdownSettingsProps }) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <>\n <SettingsValue label={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n settings.defaultViewMode = value as EditorViewMode;\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: 'react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </SettingsValue>\n\n <SettingsValue label={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n settings.editorInputMode = value as EditorInputMode;\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </SettingsValue>\n\n <SettingsValue label={t('settings toolbar label')}>\n <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />\n </SettingsValue>\n\n <SettingsValue label={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}\n />\n </SettingsValue>\n\n <SettingsValue label={t('settings folding label')}>\n <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />\n </SettingsValue>\n\n <SettingsValue label={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => (settings.experimental = !!checked)}\n />\n </SettingsValue>\n\n <SettingsValue\n label={t('settings debug label')}\n secondary={\n settings.debug ? (\n <Input.Root>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => (settings.typewriter = value)}\n placeholder={t('settings debug placeholder')}\n />\n </Input.Root>\n ) : undefined\n }\n >\n <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />\n </SettingsValue>\n </>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MARKDOWN_PLUGIN } from './meta';\n\nexport default [\n {\n 'en-US': {\n [MARKDOWN_PLUGIN]: {\n 'plugin name': 'Editor',\n 'create stack section label': 'Create document',\n 'document title placeholder': 'New document',\n 'choose markdown from space dialog title': 'Choose one or more documents to add',\n // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)\n 'empty choose markdown from space message': 'None available; try creating a new one instead?',\n 'chooser done label': 'Add selected',\n 'create document label': 'Create document',\n 'editor placeholder': 'New document',\n 'editor input mode label': 'Editor input mode',\n 'select editor input mode placeholder': 'Select editor input mode…',\n 'settings editor input mode default label': 'Default',\n 'settings editor input mode vim label': 'Vim',\n 'settings editor input mode vscode label': 'VS Code',\n 'settings toolbar label': 'Show toolbar',\n 'settings numbered headings label': 'Numbered headings',\n 'settings folding label': 'Folding',\n 'settings experimental label': 'Enable experimental features',\n 'settings debug label': 'Enable debugging features',\n 'settings debug placeholder': 'Typewriter script...',\n 'toggle view mode label': 'Toggle read-only',\n 'default view mode label': 'Default view mode',\n },\n },\n },\n];\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MarkdownPlugin } from './MarkdownPlugin';\n\nexport default MarkdownPlugin;\n\nexport * from './MarkdownPlugin';\nexport * from './types';\nexport * from './util';\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,mBAAuC;AACvC,IAAAA,gBAAgC;AAEhC,2BAQO;AACP,yBAAuB;AACvB,2BAAkC;AAClC,2BAAkC;AAClC,0BAAiE;AACjE,0BAA4B;AAC5B,mBAA+B;AAC/B,kBAAgE;AAChE,6BAKO;AACP,6BAAqC;ACzBrC,IAAAA,gBAAgD;ACAhD,IAAAA,gBAAkC;AAClC,IAAAA,gBAAuD;AAEvD,IAAAC,wBAAwB;AACxB,sBAAqC;AACrC,4BAA8C;ACL9C,IAAAD,gBAA8C;AAE9C,IAAAE,mBAAqB;AACrB,IAAAC,0BAAwC;AACxC,IAAAC,yBAAwC;ACJxC,IAAAJ,gBAAkB;AAElB,6BAA8B;AAC9B,IAAAE,mBAA8C;AAC9C,IAAAC,0BAA6F;AAKtF,IAAME,mBAAmB,CAAC,EAAEC,SAAQ,MAAuC;AAChF,QAAM,EAAEC,EAAC,QAAKC,iCAAeC,qCAAAA;AAG7B,SACEC,8BAAAA,QAAA,cAAAA,cAAAA,QAAA,UAAA,MACEA,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,yBAAA;KACtBG,8BAAAA,QAAA,cAACG,wBAAOC,MAAI;IACVC,OAAOT,SAASU;IAChBC,eAAe,CAACF,UAAAA;AACdT,eAASU,kBAAkBD;IAC7B;KAEAL,8BAAAA,QAAA,cAACG,wBAAOK,eAAa,IAAA,GACrBR,8BAAAA,QAAA,cAACG,wBAAOM,QAAM,MACZT,8BAAAA,QAAA,cAACG,wBAAOO,SAAO,MACbV,8BAAAA,QAAA,cAACG,wBAAOQ,UAAQ,MACbC,wCAAgBC,IAAI,CAACC,SACpBd,8BAAAA,QAAA,cAACG,wBAAOY,QAAM;IAACC,KAAKF;IAAMT,OAAOS;KAC9BjB,EAAE,GAAGiB,IAAAA,eAAmB;IAAEG,IAAI;EAAkB,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAS/DjB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,yBAAA;KACtBG,8BAAAA,QAAA,cAACG,wBAAOC,MAAI;IACVC,OAAOT,SAASsB,mBAAmB;IACnCX,eAAe,CAACF,UAAAA;AACdT,eAASsB,kBAAkBb;IAC7B;KAEAL,8BAAAA,QAAA,cAACG,wBAAOK,eAAa;IAACW,aAAatB,EAAE,sCAAA;MACrCG,8BAAAA,QAAA,cAACG,wBAAOM,QAAM,MACZT,8BAAAA,QAAA,cAACG,wBAAOO,SAAO,MACbV,8BAAAA,QAAA,cAACG,wBAAOQ,UAAQ,MACbS,yCAAiBP,IAAI,CAACC,SACrBd,8BAAAA,QAAA,cAACG,wBAAOY,QAAM;IAACC,KAAKF;IAAMT,OAAOS;KAC9BjB,EAAE,8BAA8BiB,IAAAA,QAAY,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,CAAA,GAS3Dd,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,wBAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IAACC,SAAS3B,SAAS4B;IAASC,iBAAiB,CAACF,YAAa3B,SAAS4B,UAAU,CAAC,CAACD;OAG/FvB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,kCAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IACXC,SAAS3B,SAAS8B;IAClBD,iBAAiB,CAACF,YAAa3B,SAAS8B,mBAAmB,CAAC,CAACH;OAIjEvB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,wBAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IAACC,SAAS3B,SAAS+B;IAASF,iBAAiB,CAACF,YAAa3B,SAAS+B,UAAU,CAAC,CAACJ;OAG/FvB,8BAAAA,QAAA,cAACC,sCAAAA;IAAcC,OAAOL,EAAE,6BAAA;KACtBG,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IACXC,SAAS3B,SAASgC;IAClBH,iBAAiB,CAACF,YAAa3B,SAASgC,eAAe,CAAC,CAACL;OAI7DvB,8BAAAA,QAAA,cAACC,sCAAAA;IACCC,OAAOL,EAAE,sBAAA;IACTgC,WACEjC,SAASkC,QACP9B,8BAAAA,QAAA,cAACqB,uBAAMjB,MAAI,MACTJ,8BAAAA,QAAA,cAACqB,uBAAMU,UAAQ;MACbC,MAAM;MACN3B,OAAOT,SAASqC;MAChBC,UAAU,CAAC,EAAEC,QAAQ,EAAE9B,MAAK,EAAE,MAAQT,SAASqC,aAAa5B;MAC5Dc,aAAatB,EAAE,4BAAA;UAGjBuC;KAGNpC,8BAAAA,QAAA,cAACqB,uBAAMC,QAAM;IAACC,SAAS3B,SAASkC;IAAOL,iBAAiB,CAACF,YAAa3B,SAASkC,QAAQ,CAAC,CAACP;;AAIjG;AHtFO,IAAMc,eAAerC,cAAAA,QAAMsC,KAAK,MAAM,OAAO,6BAAA,CAAA;AAC7C,IAAMC,iBAA0DvC,cAAAA,QAAMsC,KAAK,MAAM,OAAO,+BAAA,CAAA;AACxF,IAAME,iBAAiBxC,cAAAA,QAAMsC,KAAK,MAAM,OAAO,+BAAA,CAAA;AIdtD,IAAA,uBAAe;EACb;IACE,SAAS;MACP,CAACvC,qCAAAA,GAAkB;QACjB,eAAe;QACf,8BAA8B;QAC9B,8BAA8B;QAC9B,2CAA2C;;QAE3C,4CAA4C;QAC5C,sBAAsB;QACtB,yBAAyB;QACzB,sBAAsB;QACtB,2BAA2B;QAC3B,wCAAwC;QACxC,4CAA4C;QAC5C,wCAAwC;QACxC,2CAA2C;QAC3C,0BAA0B;QAC1B,oCAAoC;QACpC,0BAA0B;QAC1B,+BAA+B;QAC/B,wBAAwB;QACxB,8BAA8B;QAC9B,0BAA0B;QAC1B,2BAA2B;MAC7B;IACF;EACF;;ALYF,IAAM0C,gBAAgB,CAACC,SAAAA;AACrB,SACEA,QACA,OAAOA,SAAS,YAChB,QAAQA,QACR,OAAOA,KAAKC,OAAO,YACnB,UAAUD,QACV,OAAOA,KAAKE,SAAS;AAEzB;AAEO,IAAMC,iBAAiB,MAAA;AAC5B,QAAMjD,WAAW,IAAIkD,uCAAyC/C,uCAAiB;IAC7EO,iBAAiB;IACjBkB,SAAS;IACTI,cAAc;EAChB,CAAA;AAEA,QAAMmB,QAAQ,IAAID,uCAAuC/C,uCAAiB;IAAEiD,oBAAoB,CAAA;IAAIC,UAAU,CAAC;EAAE,CAAA;AAEjH,QAAMC,cAAc,CAACP,OAAAA;AACnB,WAAQA,MAAMI,MAAMI,OAAOF,SAASN,EAAAA,KAAQ/C,SAASuD,OAAO7C;EAC9D;AAEA,QAAM8C,cAAc,CAACT,IAAYU,iBAAAA;AAC/BN,UAAMI,OAAOF,SAASN,EAAAA,IAAMU;EAC9B;AAEA,SAAO;IACLC,MAAAA;IACAC,OAAO,OAAOC,YAAAA;AACZ5D,eACG6D,KAAK;QACJzC,KAAK;QACL0C,YAAY;QACZC,MAAMb,uCAAkBc,KAAI;MAC9B,CAAA,EACCH,KAAK;QACJzC,KAAK;QACL0C,YAAY;QACZC,MAAMb,uCAAkBc,KAAsB;UAAEC,gBAAgB;QAAK,CAAA;MACvE,CAAA,EACCJ,KAAK;QAAEzC,KAAK;QAAW2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EAC9EJ,KAAK;QAAEzC,KAAK;QAAgB2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EACnFJ,KAAK;QAAEzC,KAAK;QAAS2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EAC5EJ,KAAK;QAAEzC,KAAK;QAAc2C,MAAMb,uCAAkBiB,OAAO;UAAEF,gBAAgB;QAAK,CAAA;MAAG,CAAA,EACnFJ,KAAK;QAAEzC,KAAK;QAAoB2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA,EACvFJ,KAAK;QAAEzC,KAAK;QAAW2C,MAAMb,uCAAkBgB,KAAK;UAAED,gBAAgB;QAAK,CAAA;MAAG,CAAA;AAEjFd,YAAMU,KAAK;QACTzC,KAAK;QACL0C,YAAY;QACZC,MAAMb,uCAAkBkB,KAAI;MAC9B,CAAA;AAEAC,0DAAyBT,OAAAA,EAASU,QAAQ,CAACC,WAAAA;AACzC,cAAM,EAAEC,WAAU,IAAKD,OAAOE,SAASC;AACvCvB,cAAMI,OAAOH,mBAAmBuB,KAAKH,UAAAA;MACvC,CAAA;IACF;IACAC,UAAU;MACRzE,UAAUA,SAASuD;MACnBqB,UAAU;QACRC,SAAS;UACP,CAACC,mCAAaC,QAAQ,GAAG;YACvBzE,OAAO,CAAC0E,WAAiBA,kBAAkBF,qCAAeE,OAAOC,QAAQD,OAAOE,eAAe1C;YAC/FjB,aAAa;cAAC;cAA8B;gBAAEF,IAAIlB;cAAgB;;YAClEgF,MAAM,CAACC,UAAqBhF,8BAAAA,QAAA,cAACiF,qBAAWD,KAAAA;YACxCE,YAAY;YACZC,YAAY;cACVC,kBAAkB;YACpB;;YAEAC,gBAAgB,CAACC,YAAsBC,kCAAqBD,KAAK,CAACA,SAAQ;cAACA,KAAIE;iBAAYF,KAAIG;aAAQ;YACvGC;UACF;QACF;MACF;MACAC,cAAc;WAAIA;WAAiBC,uBAAAA;;MACnCC,MAAM;QACJC,QAAQ;UAACpB;UAAcqB;;MACzB;MACAC,OAAO;QACLC,SAAS,CAACzC,YAAAA;AACR,gBAAM0C,aAASC,oCAAc3C,SAAS4C,sCAAAA,GAAoB/B,SAAS6B;AACnE,gBAAMG,eAAWF,oCAAc3C,SAAS8C,sCAAAA,GAAoBjC,SAASkC,OAAOF;AAC5E,cAAI,CAACH,UAAU,CAACG,UAAU;AACxB,mBAAO,CAAA;UACT;AAEA,qBAAOG,qCAAgB;YACrB7D,IAAI8D,qCAAeC;YACnBC,QAAQ,CAACC,aAA8BC,mCAAcD,IAAAA,KAASA,KAAKjE,GAAGmE,WAAWC,gCAAYC,UAAU;YACvGC,SAAS,CAAC,EAAEL,KAAI,MAAE;AAChB,oBAAMjE,KAAKiE,KAAKjE,GAAGuE,MAAM,GAAA,EAAKC,GAAG,EAAC;AAClC,oBAAM,CAACC,SAASC,QAAAA,IAAY1E,IAAIuE,MAAM,GAAA,KAAQ,CAAA;AAC9C,oBAAMI,QAAQpB,OAAOqB,OAAOC,IAAG,EAAGC,KAAK,CAACH,WAAUA,OAAM3E,OAAOyE,OAAAA;AAC/D,oBAAMxC,SAASyC,YAAYC,OAAOI,GAAGC,cAAcN,QAAAA;AACnD,oBAAMlF,SAASkF,WAAWzC,SAAS0C;AACnC,kBAAI,CAACnF,QAAQ;AACX;cACF;AAEA,qBAAO;gBACL;kBACEQ,IAAI,GAAG5C,qCAAAA,WAA0B6G,KAAKjE,EAAE;kBACxCD,MAAM,YAAA;AACJ,0BAAM2D,SAAS;sBACb;wBAAElC,QAAQpE;wBAAiB6H,QAAQnB,qCAAeC;sBAAO;sBACzD;wBAAEkB,QAAQb,gCAAYC;wBAAYtE,MAAM;0BAAEP;wBAAO;sBAAE;sBACnD;wBAAEyF,QAAQC,sCAAiBC;sBAAK;qBACjC;kBACH;kBACAC,YAAY;oBACV7H,OAAO;sBAAC;sBAAyB;wBAAEe,IAAIlB;sBAAgB;;oBACvDgF,MAAM,CAACC,UAAqBhF,8BAAAA,QAAA,cAACiF,qBAAWD,KAAAA;oBACxCE,YAAY;oBACZ8C,QAAQ;kBACV;gBACF;;YAEJ;UACF,CAAA;QACF;QACAtC,YAAY,CAAClC,YAAAA;AACX,gBAAM6C,eAAWF,oCAAc3C,SAAS8C,sCAAAA,GAAoBjC,SAASkC,OAAOF;AAC5E,cAAI,CAACA,UAAU;AACb,mBAAO,CAAA;UACT;AACA,iBAAO;YACL;cACE4B,WAAWvD,mCAAaC;cACxBuD,YAAY;;cAEZC,WAAW,OAAOvB,SAAAA;AAChB,sBAAMtB,MAAMsB,KAAKlE;AACjB,sBAAM8C,UAAU,UAAMD,kCAAqBD,KAAK,CAACA,SAAQA,KAAIE,OAAO;AACpE,uBAAO;kBACLX,MACES,IAAIT,QACJS,IAAIR,gBACJa,qBAAa,CAAA,EAAG,OAAA,EAAS5F,qCAAAA,EAAiB,4BAAA;kBAC5C2C,MAAM8C,QAAQA;kBACd7B,MAAM;gBACR;cACF;cACAyE,aAAa,OAAO1F,MAAM2F,cAAAA;AACxB,sBAAMf,QAAQe,UAAUZ,KAAKa,mBAAAA;AAC7B,sBAAMnG,SACJkG,UAAUE,SAAS,CAACC,aAAaA,oBAAoBC,2BAAAA,KACrDnB,OAAOS,WAAWU,4BAAe9D,QAAQ;AAC3C,oBAAI,CAAC2C,SAAS,CAACnF,QAAQ;AACrB;gBACF;AAEA,sBAAMuG,SAAS,MAAMrC,SAAS;kBAC5B;oBACElC,QAAQpE;oBACR6H,QAAQnB,qCAAeC;oBACvBhE,MAAM;sBAAEmC,MAAMnC,KAAKmC;sBAAMW,SAAS9C,KAAKA;oBAAK;kBAC9C;kBACA;oBACEkF,QAAQb,gCAAYC;oBACpBtE,MAAM;sBAAEP;oBAAO;kBACjB;iBACD;AAED,uBAAOuG,QAAQhG,KAAKkC;cACtB;YACF;;QAEJ;MACF;MACA+D,OAAO;QACLC,UAAU;UACR;YACEjG,IAAI;YACJqF,QAAQ;YACRrE,MAAM;cAAC;cAAe;gBAAE1C,IAAIlB;cAAgB;;YAC5CG,OAAO;cAAC;cAA8B;gBAAEe,IAAIlB;cAAgB;;YAC5DgF,MAAM,CAACC,UAAehF,8BAAAA,QAAA,cAACiF,qBAAWD,KAAAA;YAClCuB,QAAQ;
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type IconProps, TextAa } from '@phosphor-icons/react';\nimport React, { type Ref } from 'react';\n\nimport {\n isObject,\n parseIntentPlugin,\n resolvePlugin,\n LayoutAction,\n type LayoutCoordinate,\n NavigationAction,\n type PluginDefinition,\n} from '@dxos/app-framework';\nimport { create } from '@dxos/echo-schema';\nimport { LocalStorageStore } from '@dxos/local-storage';\nimport { parseClientPlugin } from '@dxos/plugin-client';\nimport { type ActionGroup, createExtension, isActionGroup } from '@dxos/plugin-graph';\nimport { SpaceAction } from '@dxos/plugin-space';\nimport { CollectionType } from '@dxos/plugin-space/types';\nimport { fullyQualifiedId, isSpace, loadObjectReferences } from '@dxos/react-client/echo';\nimport {\n type EditorInputMode,\n type EditorViewMode,\n EditorViewModes,\n translations as editorTranslations,\n} from '@dxos/react-ui-editor';\nimport { isTileComponentProps } from '@dxos/react-ui-mosaic';\n\nimport { type DocumentItemProps, DocumentCard, DocumentEditor, MarkdownEditor, MarkdownSettings } from './components';\nimport meta, { MARKDOWN_PLUGIN } from './meta';\nimport translations from './translations';\nimport { DocumentType, TextType } from './types';\nimport {\n type MarkdownPluginProvides,\n type MarkdownSettingsProps,\n MarkdownAction,\n type MarkdownPluginState,\n} from './types';\nimport { markdownExtensionPlugins, serializer } from './util';\n\n/**\n * Checks if an object conforms to the interface needed to render an editor.\n */\nconst isEditorModel = (data: any): data is { id: string; text: string } => {\n return (\n data &&\n typeof data === 'object' &&\n 'id' in data &&\n typeof data.id === 'string' &&\n 'text' in data &&\n typeof data.text === 'string'\n );\n};\n\nexport const MarkdownPlugin = (): PluginDefinition<MarkdownPluginProvides> => {\n const settings = new LocalStorageStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN, {\n defaultViewMode: 'preview',\n toolbar: true,\n experimental: false,\n });\n\n const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });\n\n const getViewMode = (id?: string) => {\n return (id && state.values.viewMode[id]) || settings.values.defaultViewMode;\n };\n\n const setViewMode = (id: string, nextViewMode: EditorViewMode) => {\n state.values.viewMode[id] = nextViewMode;\n };\n\n return {\n meta,\n ready: async (plugins) => {\n settings\n .prop({\n key: 'defaultViewMode',\n storageKey: 'default-view-mode',\n type: LocalStorageStore.enum<EditorViewMode>(),\n })\n .prop({\n key: 'editorInputMode',\n storageKey: 'editor-mode',\n type: LocalStorageStore.enum<EditorInputMode>({ allowUndefined: true }),\n })\n .prop({ key: 'toolbar', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'experimental', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'debug', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'typewriter', type: LocalStorageStore.string({ allowUndefined: true }) })\n .prop({ key: 'numberedHeadings', type: LocalStorageStore.bool({ allowUndefined: true }) })\n .prop({ key: 'folding', type: LocalStorageStore.bool({ allowUndefined: true }) });\n\n state.prop({\n key: 'viewMode',\n storageKey: 'view-mode',\n type: LocalStorageStore.json<{ [key: string]: EditorViewMode }>(),\n });\n\n markdownExtensionPlugins(plugins).forEach((plugin) => {\n const { extensions } = plugin.provides.markdown;\n state.values.extensionProviders.push(extensions);\n });\n },\n provides: {\n settings: settings.values,\n metadata: {\n records: {\n [DocumentType.typename]: {\n label: (object: any) => (object instanceof DocumentType ? object.name ?? object.fallbackName : undefined),\n placeholder: ['document title placeholder', { ns: MARKDOWN_PLUGIN }],\n icon: (props: IconProps) => <TextAa {...props} />,\n iconSymbol: 'ph--text-aa--regular',\n graphProps: {\n managesAutofocus: true,\n },\n // TODO(wittjosiah): Move out of metadata.\n loadReferences: (doc: DocumentType) => loadObjectReferences(doc, (doc) => [doc.content, ...doc.threads]),\n serializer,\n },\n },\n },\n translations: [...translations, ...editorTranslations],\n echo: {\n schema: [DocumentType, TextType],\n },\n graph: {\n builder: (plugins) => {\n const client = resolvePlugin(plugins, parseClientPlugin)?.provides.client;\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;\n if (!client || !dispatch) {\n return [];\n }\n\n return createExtension({\n id: MarkdownAction.CREATE,\n filter: (node): node is ActionGroup => isActionGroup(node) && node.id.startsWith(SpaceAction.ADD_OBJECT),\n actions: ({ node }) => {\n const id = node.id.split('/').at(-1);\n const [spaceId, objectId] = id?.split(':') ?? [];\n const space = client.spaces.get().find((space) => space.id === spaceId);\n const object = objectId && space?.db.getObjectById(objectId);\n const target = objectId ? object : space;\n if (!target) {\n return;\n }\n\n return [\n {\n id: `${MARKDOWN_PLUGIN}/create/${node.id}`,\n data: async () => {\n await dispatch([\n { plugin: MARKDOWN_PLUGIN, action: MarkdownAction.CREATE },\n { action: SpaceAction.ADD_OBJECT, data: { target } },\n { action: NavigationAction.OPEN },\n ]);\n },\n properties: {\n label: ['create document label', { ns: MARKDOWN_PLUGIN }],\n icon: (props: IconProps) => <TextAa {...props} />,\n iconSymbol: 'ph--text-aa--regular',\n testId: 'markdownPlugin.createObject',\n },\n },\n ];\n },\n });\n },\n serializer: (plugins) => {\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;\n if (!dispatch) {\n return [];\n }\n return [\n {\n inputType: DocumentType.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await loadObjectReferences(doc, (doc) => doc.content);\n return {\n name:\n doc.name ||\n doc.fallbackName ||\n translations[0]['en-US'][MARKDOWN_PLUGIN]['document title placeholder'],\n data: content.content,\n type: 'text/markdown',\n };\n },\n deserialize: async (data, ancestors) => {\n const space = ancestors.find(isSpace);\n const target =\n ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ??\n space?.properties[CollectionType.typename];\n if (!space || !target) {\n return;\n }\n\n const result = await dispatch([\n {\n plugin: MARKDOWN_PLUGIN,\n action: MarkdownAction.CREATE,\n data: { name: data.name, content: data.data },\n },\n {\n action: SpaceAction.ADD_OBJECT,\n data: { target },\n },\n ]);\n\n return result?.data.object;\n },\n },\n ];\n },\n },\n stack: {\n creators: [\n {\n id: 'create-stack-section-doc',\n testId: 'markdownPlugin.createSection',\n type: ['plugin name', { ns: MARKDOWN_PLUGIN }],\n label: ['create stack section label', { ns: MARKDOWN_PLUGIN }],\n icon: (props: any) => <TextAa {...props} />,\n intent: { plugin: MARKDOWN_PLUGIN, action: MarkdownAction.CREATE },\n },\n ],\n },\n surface: {\n component: ({ data, role, ...props }, forwardedRef) => {\n const doc =\n data.active instanceof DocumentType\n ? data.active\n : data.object instanceof DocumentType\n ? data.object\n : undefined;\n\n switch (role) {\n case 'section':\n case 'article': {\n if (doc && doc.content) {\n return (\n <DocumentEditor\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n document={doc}\n extensionProviders={state.values.extensionProviders}\n settings={settings.values}\n viewMode={getViewMode(fullyQualifiedId(doc))}\n onViewModeChange={setViewMode}\n scrollPastEnd\n />\n );\n } else if (isEditorModel(data.object)) {\n return (\n <MarkdownEditor\n id={data.object.id}\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n initialValue={data.object.text}\n extensionProviders={state.values.extensionProviders}\n inputMode={settings.values.editorInputMode}\n toolbar={settings.values.toolbar}\n viewMode={getViewMode(data.object.id)}\n onViewModeChange={setViewMode}\n scrollPastEnd\n />\n );\n }\n break;\n }\n\n case 'card': {\n if (\n isObject(data.content) &&\n typeof data.content.id === 'string' &&\n data.content.object instanceof DocumentType\n ) {\n // isTileComponentProps is a type guard for these props.\n // `props` will not pass this guard without transforming `data` into `item`.\n const cardProps = {\n ...props,\n item: {\n id: data.content.id,\n object: data.content.object,\n color: typeof data.content.color === 'string' ? data.content.color : undefined,\n } as DocumentItemProps,\n };\n\n return isTileComponentProps(cardProps) ? (\n <DocumentCard {...cardProps} settings={settings.values} ref={forwardedRef as Ref<HTMLDivElement>} />\n ) : null;\n }\n break;\n }\n\n case 'settings': {\n return data.plugin === meta.id ? <MarkdownSettings settings={settings.values} /> : null;\n }\n }\n\n return null;\n },\n },\n intent: {\n resolver: ({ action, data }) => {\n switch (action) {\n case MarkdownAction.CREATE: {\n const doc = create(DocumentType, {\n name: data?.name,\n content: create(TextType, { content: data?.content ?? '' }),\n threads: [],\n });\n\n return {\n data: doc,\n intents: [[{ action: LayoutAction.SCROLL_INTO_VIEW, data: { id: fullyQualifiedId(doc) } }]],\n };\n }\n\n case MarkdownAction.SET_VIEW_MODE: {\n const { id, viewMode } = data ?? {};\n if (typeof id === 'string' && EditorViewModes.includes(viewMode)) {\n state.values.viewMode[id] = viewMode;\n return { data: true };\n }\n\n break;\n }\n }\n },\n },\n },\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type LazyExoticComponent } from 'react';\n\nimport { type DocumentEditor as DocumentEditorType } from './DocumentEditor';\n\nexport { type DocumentCardProps, type DocumentItemProps } from './DocumentCard';\n\nexport * from './DocumentCard';\nexport * from './DocumentEditor';\nexport * from './MarkdownEditor';\nexport * from './HeadingMenu';\nexport * from './Layout';\nexport * from './MarkdownSettings';\n\n// Lazily load components for content surfaces.\nexport const DocumentCard = React.lazy(() => import('./DocumentCard'));\nexport const DocumentEditor: LazyExoticComponent<DocumentEditorType> = React.lazy(() => import('./DocumentEditor'));\nexport const MarkdownEditor = React.lazy(() => import('./MarkdownEditor'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { DotsThreeVertical } from '@phosphor-icons/react';\nimport React, { type PropsWithChildren, type FC } from 'react';\n\nimport { Surface } from '@dxos/app-framework';\nimport { Button, DropdownMenu } from '@dxos/react-ui';\nimport { fineButtonDimensions, getSize } from '@dxos/react-ui-theme';\n\nimport { type DocumentType, type MarkdownProperties } from '../types';\n\n// TODO(thure): This needs to be refactored into a graph node action.\nexport const DocumentHeadingMenu: FC<{ document: DocumentType }> = ({ document }) => {\n return <HeadingMenu properties={document} content={document.content?.content} />;\n};\n\n/**\n * Menu for the layout heading.\n */\nexport const HeadingMenu = ({\n content,\n properties,\n}: PropsWithChildren<{\n content: string | undefined;\n properties: MarkdownProperties;\n}>) => {\n return (\n <DropdownMenu.Root modal={false}>\n <DropdownMenu.Trigger asChild>\n <Button variant='ghost' classNames={fineButtonDimensions}>\n <DotsThreeVertical className={getSize(4)} />\n </Button>\n </DropdownMenu.Trigger>\n <DropdownMenu.Portal>\n <DropdownMenu.Content sideOffset={8} classNames='z-10'>\n <DropdownMenu.Viewport>\n <Surface data={{ content, properties }} role='menuitem' />\n </DropdownMenu.Viewport>\n <DropdownMenu.Arrow />\n </DropdownMenu.Content>\n </DropdownMenu.Portal>\n </DropdownMenu.Root>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\n\nimport { Main } from '@dxos/react-ui';\nimport { editorWithToolbarLayout } from '@dxos/react-ui-editor';\nimport { topbarBlockPaddingStart } from '@dxos/react-ui-theme';\n\nexport const MainLayout = ({ children, toolbar }: PropsWithChildren<{ toolbar?: boolean }>) => {\n return (\n <Main.Content\n bounce\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n classNames={[topbarBlockPaddingStart, editorWithToolbarLayout]}\n >\n {children}\n </Main.Content>\n );\n};\n\n// Used when the editor is embedded in another context (e.g., iframe) and has no topbar/sidebar/etc.\n// TODO(wittjosiah): What's the difference between this and Section/Card?\nexport const EmbeddedLayout = ({ children }: PropsWithChildren) => {\n return <Main.Content classNames='min-bs-[100dvh] grid p-0.5'>{children}</Main.Content>;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { SettingsValue } from '@dxos/plugin-settings';\nimport { Input, Select, useTranslation } from '@dxos/react-ui';\nimport { type EditorInputMode, EditorInputModes, type EditorViewMode, EditorViewModes } from '@dxos/react-ui-editor';\n\nimport { MARKDOWN_PLUGIN } from '../meta';\nimport { type MarkdownSettingsProps } from '../types';\n\nexport const MarkdownSettings = ({ settings }: { settings: MarkdownSettingsProps }) => {\n const { t } = useTranslation(MARKDOWN_PLUGIN);\n\n // TODO(wittjosiah): Add skill test confirmation for entering vim mode.\n return (\n <>\n <SettingsValue label={t('default view mode label')}>\n <Select.Root\n value={settings.defaultViewMode}\n onValueChange={(value) => {\n settings.defaultViewMode = value as EditorViewMode;\n }}\n >\n <Select.TriggerButton />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorViewModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`${mode} mode label`, { ns: 'react-ui-editor' })}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </SettingsValue>\n\n <SettingsValue label={t('editor input mode label')}>\n <Select.Root\n value={settings.editorInputMode ?? 'default'}\n onValueChange={(value) => {\n settings.editorInputMode = value as EditorInputMode;\n }}\n >\n <Select.TriggerButton placeholder={t('select editor input mode placeholder')} />\n <Select.Portal>\n <Select.Content>\n <Select.Viewport>\n {EditorInputModes.map((mode) => (\n <Select.Option key={mode} value={mode}>\n {t(`settings editor input mode ${mode} label`)}\n </Select.Option>\n ))}\n </Select.Viewport>\n </Select.Content>\n </Select.Portal>\n </Select.Root>\n </SettingsValue>\n\n <SettingsValue label={t('settings toolbar label')}>\n <Input.Switch checked={settings.toolbar} onCheckedChange={(checked) => (settings.toolbar = !!checked)} />\n </SettingsValue>\n\n <SettingsValue label={t('settings numbered headings label')}>\n <Input.Switch\n checked={settings.numberedHeadings}\n onCheckedChange={(checked) => (settings.numberedHeadings = !!checked)}\n />\n </SettingsValue>\n\n <SettingsValue label={t('settings folding label')}>\n <Input.Switch checked={settings.folding} onCheckedChange={(checked) => (settings.folding = !!checked)} />\n </SettingsValue>\n\n <SettingsValue label={t('settings experimental label')}>\n <Input.Switch\n checked={settings.experimental}\n onCheckedChange={(checked) => (settings.experimental = !!checked)}\n />\n </SettingsValue>\n\n <SettingsValue\n label={t('settings debug label')}\n secondary={\n settings.debug ? (\n <Input.Root>\n <Input.TextArea\n rows={5}\n value={settings.typewriter}\n onChange={({ target: { value } }) => (settings.typewriter = value)}\n placeholder={t('settings debug placeholder')}\n />\n </Input.Root>\n ) : undefined\n }\n >\n <Input.Switch checked={settings.debug} onCheckedChange={(checked) => (settings.debug = !!checked)} />\n </SettingsValue>\n </>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MARKDOWN_PLUGIN } from './meta';\n\nexport default [\n {\n 'en-US': {\n [MARKDOWN_PLUGIN]: {\n 'plugin name': 'Editor',\n 'create stack section label': 'Create document',\n 'document title placeholder': 'New document',\n 'choose markdown from space dialog title': 'Choose one or more documents to add',\n // TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)\n 'empty choose markdown from space message': 'None available; try creating a new one instead?',\n 'chooser done label': 'Add selected',\n 'create document label': 'Create document',\n 'editor placeholder': 'New document',\n 'editor input mode label': 'Editor input mode',\n 'select editor input mode placeholder': 'Select editor input mode…',\n 'settings editor input mode default label': 'Default',\n 'settings editor input mode vim label': 'Vim',\n 'settings editor input mode vscode label': 'VS Code',\n 'settings toolbar label': 'Show toolbar',\n 'settings numbered headings label': 'Numbered headings',\n 'settings folding label': 'Folding',\n 'settings experimental label': 'Enable experimental features',\n 'settings debug label': 'Enable debugging features',\n 'settings debug placeholder': 'Typewriter script...',\n 'toggle view mode label': 'Toggle read-only',\n 'default view mode label': 'Default view mode',\n },\n },\n },\n];\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { MarkdownPlugin } from './MarkdownPlugin';\n\nexport default MarkdownPlugin;\n\nexport * from './MarkdownPlugin';\nexport * from './types';\nexport * from './util';\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
6
|
"names": ["import_react", "import_app_framework", "import_react_ui", "import_react_ui_editor", "import_react_ui_theme", "MarkdownSettings", "settings", "t", "useTranslation", "MARKDOWN_PLUGIN", "React", "SettingsValue", "label", "Select", "Root", "value", "defaultViewMode", "onValueChange", "TriggerButton", "Portal", "Content", "Viewport", "EditorViewModes", "map", "mode", "Option", "key", "ns", "editorInputMode", "placeholder", "EditorInputModes", "Input", "Switch", "checked", "toolbar", "onCheckedChange", "numberedHeadings", "folding", "experimental", "secondary", "debug", "TextArea", "rows", "typewriter", "onChange", "target", "undefined", "DocumentCard", "lazy", "DocumentEditor", "MarkdownEditor", "isEditorModel", "data", "id", "text", "MarkdownPlugin", "LocalStorageStore", "state", "extensionProviders", "viewMode", "getViewMode", "values", "setViewMode", "nextViewMode", "meta", "ready", "plugins", "prop", "storageKey", "type", "enum", "allowUndefined", "bool", "string", "json", "markdownExtensionPlugins", "forEach", "plugin", "extensions", "provides", "markdown", "push", "metadata", "records", "DocumentType", "typename", "object", "name", "fallbackName", "icon", "props", "TextAa", "iconSymbol", "graphProps", "managesAutofocus", "loadReferences", "doc", "loadObjectReferences", "content", "threads", "serializer", "translations", "editorTranslations", "echo", "schema", "TextType", "graph", "builder", "client", "resolvePlugin", "parseClientPlugin", "dispatch", "parseIntentPlugin", "intent", "createExtension", "MarkdownAction", "CREATE", "filter", "node", "isActionGroup", "startsWith", "SpaceAction", "ADD_OBJECT", "actions", "split", "at", "spaceId", "objectId", "space", "spaces", "get", "find", "db", "getObjectById", "action", "NavigationAction", "OPEN", "properties", "testId", "inputType", "outputType", "serialize", "deserialize", "ancestors", "isSpace", "findLast", "ancestor", "CollectionType", "result", "stack", "creators", "surface", "component", "role", "forwardedRef", "active", "coordinate", "document", "fullyQualifiedId", "onViewModeChange", "scrollPastEnd", "initialValue", "inputMode", "isObject", "cardProps", "item", "color", "isTileComponentProps", "ref", "resolver", "create", "intents", "LayoutAction", "SCROLL_INTO_VIEW", "SET_VIEW_MODE", "includes"]
|
|
7
7
|
}
|