@dxos/plugin-markdown 0.6.12-main.f9d0246 → 0.6.12-staging.0b4bb48
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/{DocumentCard-RKENHCNE.mjs → DocumentCard-2P4EICBA.mjs} +3 -3
- package/dist/lib/browser/DocumentEditor-GPWV3VN3.mjs +11 -0
- package/dist/lib/browser/{MarkdownEditor-5EUT7P66.mjs → MarkdownEditor-EKJJQEFL.mjs} +3 -3
- package/dist/lib/browser/{chunk-2SJN46PA.mjs → chunk-4GGD6YJO.mjs} +5 -2
- package/dist/lib/browser/chunk-4GGD6YJO.mjs.map +7 -0
- package/dist/lib/browser/{chunk-QIO7ZONH.mjs → chunk-7AF2JLK4.mjs} +18 -18
- package/dist/lib/browser/chunk-7AF2JLK4.mjs.map +7 -0
- package/dist/lib/browser/{chunk-N7FS4CK2.mjs → chunk-CQJL4G4X.mjs} +2 -2
- package/dist/lib/browser/chunk-CQJL4G4X.mjs.map +7 -0
- package/dist/lib/browser/{chunk-AFWT6Z7B.mjs → chunk-RL7QY322.mjs} +2 -2
- package/dist/lib/browser/{chunk-AVGUYNPR.mjs → chunk-VUN4QKTT.mjs} +53 -65
- package/dist/lib/browser/chunk-VUN4QKTT.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +22 -29
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/meta.mjs +1 -1
- package/dist/lib/browser/types/index.mjs +2 -2
- package/dist/lib/node/{DocumentCard-ECPKHJT7.cjs → DocumentCard-EHJDDSRY.cjs} +8 -8
- package/dist/lib/node/{DocumentCard-ECPKHJT7.cjs.map → DocumentCard-EHJDDSRY.cjs.map} +2 -2
- package/dist/lib/node/{DocumentEditor-QPH26VQZ.cjs → DocumentEditor-I5GCRBKU.cjs} +9 -9
- package/dist/lib/node/DocumentEditor-I5GCRBKU.cjs.map +7 -0
- package/dist/lib/node/{MarkdownEditor-ZD4W4UJ6.cjs → MarkdownEditor-UE23H75V.cjs} +8 -8
- package/dist/lib/node/MarkdownEditor-UE23H75V.cjs.map +7 -0
- package/dist/lib/node/{chunk-2T7LIVPT.cjs → chunk-7XIBNEI7.cjs} +51 -59
- package/dist/lib/node/chunk-7XIBNEI7.cjs.map +7 -0
- package/dist/lib/node/{chunk-5ZWOR7JF.cjs → chunk-Q4ZSCBQE.cjs} +6 -6
- package/dist/lib/node/{chunk-KDXONMFH.cjs → chunk-RVGN72IX.cjs} +24 -24
- package/dist/lib/node/chunk-RVGN72IX.cjs.map +7 -0
- package/dist/lib/node/{chunk-LPD4NOTH.cjs → chunk-TGMR2CKU.cjs} +18 -5
- package/dist/lib/node/chunk-TGMR2CKU.cjs.map +7 -0
- package/dist/lib/node/{chunk-RVNU7MRZ.cjs → chunk-VWQH4WC2.cjs} +6 -6
- package/dist/lib/node/chunk-VWQH4WC2.cjs.map +7 -0
- package/dist/lib/node/index.cjs +63 -70
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/meta.cjs +3 -3
- package/dist/lib/node/meta.cjs.map +1 -1
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/types/index.cjs +5 -5
- package/dist/lib/node/types/index.cjs.map +1 -1
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/components/DocumentEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor.d.ts +1 -1
- package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +4 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/types/document.d.ts +0 -2
- package/dist/types/src/types/document.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +9 -8
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/package.json +34 -38
- package/src/MarkdownPlugin.tsx +10 -17
- package/src/components/DocumentEditor.tsx +18 -23
- package/src/components/MarkdownEditor.tsx +43 -15
- package/src/meta.tsx +5 -1
- package/src/types/types.ts +7 -9
- package/dist/lib/browser/DocumentEditor-JZI4663Q.mjs +0 -11
- package/dist/lib/browser/chunk-2SJN46PA.mjs.map +0 -7
- package/dist/lib/browser/chunk-AVGUYNPR.mjs.map +0 -7
- package/dist/lib/browser/chunk-N7FS4CK2.mjs.map +0 -7
- package/dist/lib/browser/chunk-QIO7ZONH.mjs.map +0 -7
- package/dist/lib/node/DocumentEditor-QPH26VQZ.cjs.map +0 -7
- package/dist/lib/node/MarkdownEditor-ZD4W4UJ6.cjs.map +0 -7
- package/dist/lib/node/chunk-2T7LIVPT.cjs.map +0 -7
- package/dist/lib/node/chunk-KDXONMFH.cjs.map +0 -7
- package/dist/lib/node/chunk-LPD4NOTH.cjs.map +0 -7
- package/dist/lib/node/chunk-RVNU7MRZ.cjs.map +0 -7
- package/dist/lib/node-esm/DocumentCard-RHVY4Z6L.mjs +0 -12
- package/dist/lib/node-esm/DocumentCard-RHVY4Z6L.mjs.map +0 -7
- package/dist/lib/node-esm/DocumentEditor-6F5ONTIO.mjs +0 -12
- package/dist/lib/node-esm/DocumentEditor-6F5ONTIO.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownEditor-OS7YG6MA.mjs +0 -11
- package/dist/lib/node-esm/MarkdownEditor-OS7YG6MA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-2BGTVWHN.mjs +0 -18
- package/dist/lib/node-esm/chunk-2BGTVWHN.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-3CHPA7Y7.mjs +0 -40
- package/dist/lib/node-esm/chunk-3CHPA7Y7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NZ4H6J5H.mjs +0 -165
- package/dist/lib/node-esm/chunk-NZ4H6J5H.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-OE3CMI5X.mjs +0 -87
- package/dist/lib/node-esm/chunk-OE3CMI5X.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-QARGBUBS.mjs +0 -221
- package/dist/lib/node-esm/chunk-QARGBUBS.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-RO5FEVW6.mjs +0 -119
- package/dist/lib/node-esm/chunk-RO5FEVW6.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -540
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/meta.mjs +0 -10
- package/dist/lib/node-esm/meta.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -13
- package/dist/lib/node-esm/types/index.mjs.map +0 -7
- package/dist/types/src/hooks/index.d.ts +0 -2
- package/dist/types/src/hooks/index.d.ts.map +0 -1
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
- package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
- package/src/hooks/index.ts +0 -5
- package/src/hooks/useSelectCurrentThread.tsx +0 -46
- /package/dist/lib/browser/{DocumentCard-RKENHCNE.mjs.map → DocumentCard-2P4EICBA.mjs.map} +0 -0
- /package/dist/lib/browser/{DocumentEditor-JZI4663Q.mjs.map → DocumentEditor-GPWV3VN3.mjs.map} +0 -0
- /package/dist/lib/browser/{MarkdownEditor-5EUT7P66.mjs.map → MarkdownEditor-EKJJQEFL.mjs.map} +0 -0
- /package/dist/lib/browser/{chunk-AFWT6Z7B.mjs.map → chunk-RL7QY322.mjs.map} +0 -0
- /package/dist/lib/node/{chunk-5ZWOR7JF.cjs.map → chunk-Q4ZSCBQE.cjs.map} +0 -0
|
@@ -1,119 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
|
|
3
|
-
// packages/plugins/plugin-markdown/src/extensions.tsx
|
|
4
|
-
import { ArrowSquareDown, ArrowSquareOut } from "@phosphor-icons/react";
|
|
5
|
-
import React, { StrictMode } from "react";
|
|
6
|
-
import { createRoot } from "react-dom/client";
|
|
7
|
-
import { NavigationAction } from "@dxos/app-framework";
|
|
8
|
-
import { invariant } from "@dxos/invariant";
|
|
9
|
-
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
10
|
-
import { autocomplete, decorateMarkdown, linkTooltip, typewriter, formattingKeymap, InputModeExtensions, folding } from "@dxos/react-ui-editor";
|
|
11
|
-
import { getSize, mx } from "@dxos/react-ui-theme";
|
|
12
|
-
import { isNotFalsy, nonNullable } from "@dxos/util";
|
|
13
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
|
|
14
|
-
var createBaseExtensions = ({ viewMode, settings, document, query, dispatch }) => {
|
|
15
|
-
const extensions = [];
|
|
16
|
-
if (settings?.editorInputMode) {
|
|
17
|
-
const extension = InputModeExtensions[settings.editorInputMode];
|
|
18
|
-
if (extension) {
|
|
19
|
-
extensions.push(extension);
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
if (viewMode !== "source") {
|
|
23
|
-
extensions.push(...[
|
|
24
|
-
formattingKeymap(),
|
|
25
|
-
decorateMarkdown({
|
|
26
|
-
selectionChangeDelay: 100,
|
|
27
|
-
numberedHeadings: settings?.numberedHeadings ? {
|
|
28
|
-
from: 2
|
|
29
|
-
} : void 0,
|
|
30
|
-
// TODO(wittjosiah): For internal links, consider ignoring the link text and rendering the label of the object being linked to.
|
|
31
|
-
renderLinkButton: dispatch && document ? onRenderLink((id) => {
|
|
32
|
-
void dispatch({
|
|
33
|
-
action: NavigationAction.ADD_TO_ACTIVE,
|
|
34
|
-
data: {
|
|
35
|
-
id,
|
|
36
|
-
part: "main",
|
|
37
|
-
pivotId: fullyQualifiedId(document),
|
|
38
|
-
scrollIntoView: true
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
}) : void 0
|
|
42
|
-
}),
|
|
43
|
-
linkTooltip(renderLinkTooltip)
|
|
44
|
-
]);
|
|
45
|
-
}
|
|
46
|
-
if (query) {
|
|
47
|
-
extensions.push(autocomplete({
|
|
48
|
-
onSearch: (text) => {
|
|
49
|
-
return query.objects.map((object) => object.name?.length && object.id !== document?.id ? {
|
|
50
|
-
label: object.name,
|
|
51
|
-
// TODO(burdon): Factor out URL builder.
|
|
52
|
-
apply: `[${object.name}](/${fullyQualifiedId(object)})`
|
|
53
|
-
} : void 0).filter(nonNullable);
|
|
54
|
-
}
|
|
55
|
-
}));
|
|
56
|
-
}
|
|
57
|
-
extensions.push(...[
|
|
58
|
-
//
|
|
59
|
-
settings?.folding && folding()
|
|
60
|
-
].filter(isNotFalsy));
|
|
61
|
-
if (settings?.debug) {
|
|
62
|
-
const items = settings.typewriter ?? "";
|
|
63
|
-
extensions.push(...[
|
|
64
|
-
items ? typewriter({
|
|
65
|
-
items: items.split(/[,\n]/)
|
|
66
|
-
}) : void 0
|
|
67
|
-
].filter(nonNullable));
|
|
68
|
-
}
|
|
69
|
-
return extensions;
|
|
70
|
-
};
|
|
71
|
-
var hover = "rounded-sm text-primary-600 hover:text-primary-500 dark:text-primary-300 hover:dark:text-primary-200";
|
|
72
|
-
var onRenderLink = (onSelectObject) => (el, url) => {
|
|
73
|
-
const isInternal = url.startsWith("/") || // TODO(wittjosiah): This should probably be parsed out on paste?
|
|
74
|
-
url.startsWith(window.location.origin);
|
|
75
|
-
const options = isInternal ? {
|
|
76
|
-
onClick: () => {
|
|
77
|
-
const qualifiedId = url.split("/").at(-1);
|
|
78
|
-
invariant(qualifiedId, "Invalid link format.", {
|
|
79
|
-
F: __dxlog_file,
|
|
80
|
-
L: 148,
|
|
81
|
-
S: void 0,
|
|
82
|
-
A: [
|
|
83
|
-
"qualifiedId",
|
|
84
|
-
"'Invalid link format.'"
|
|
85
|
-
]
|
|
86
|
-
});
|
|
87
|
-
onSelectObject(qualifiedId);
|
|
88
|
-
}
|
|
89
|
-
} : {
|
|
90
|
-
href: url,
|
|
91
|
-
rel: "noreferrer",
|
|
92
|
-
target: "_blank"
|
|
93
|
-
};
|
|
94
|
-
const LinkIcon = isInternal ? ArrowSquareDown : ArrowSquareOut;
|
|
95
|
-
createRoot(el).render(/* @__PURE__ */ React.createElement(StrictMode, null, /* @__PURE__ */ React.createElement("a", {
|
|
96
|
-
...options,
|
|
97
|
-
className: hover
|
|
98
|
-
}, /* @__PURE__ */ React.createElement(LinkIcon, {
|
|
99
|
-
weight: "bold",
|
|
100
|
-
className: mx(getSize(4), "inline-block leading-none mis-1 cursor-pointer")
|
|
101
|
-
}))));
|
|
102
|
-
};
|
|
103
|
-
var renderLinkTooltip = (el, url) => {
|
|
104
|
-
const web = new URL(url);
|
|
105
|
-
createRoot(el).render(/* @__PURE__ */ React.createElement(StrictMode, null, /* @__PURE__ */ React.createElement("a", {
|
|
106
|
-
href: url,
|
|
107
|
-
target: "_blank",
|
|
108
|
-
rel: "noreferrer",
|
|
109
|
-
className: hover
|
|
110
|
-
}, web.origin, /* @__PURE__ */ React.createElement(ArrowSquareOut, {
|
|
111
|
-
weight: "bold",
|
|
112
|
-
className: mx(getSize(4), "inline-block leading-none mis-1 cursor-pointer")
|
|
113
|
-
}))));
|
|
114
|
-
};
|
|
115
|
-
|
|
116
|
-
export {
|
|
117
|
-
createBaseExtensions
|
|
118
|
-
};
|
|
119
|
-
//# sourceMappingURL=chunk-RO5FEVW6.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/extensions.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { ArrowSquareDown, ArrowSquareOut, type Icon } from '@phosphor-icons/react';\nimport React, { type AnchorHTMLAttributes, StrictMode } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport { type IntentDispatcher, NavigationAction } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { fullyQualifiedId, type Query } from '@dxos/react-client/echo';\nimport {\n type AutocompleteResult,\n type Extension,\n type EditorViewMode,\n autocomplete,\n decorateMarkdown,\n linkTooltip,\n typewriter,\n formattingKeymap,\n InputModeExtensions,\n folding,\n} from '@dxos/react-ui-editor';\nimport { getSize, mx } from '@dxos/react-ui-theme';\nimport { isNotFalsy, nonNullable } from '@dxos/util';\n\nimport { type DocumentType, type MarkdownSettingsProps } from './types';\n\nexport type ExtensionsOptions = {\n viewMode?: EditorViewMode;\n settings?: MarkdownSettingsProps;\n document?: DocumentType;\n debug?: boolean;\n experimental?: boolean;\n numberedHeadings?: boolean;\n folding?: boolean;\n query?: Query<DocumentType>;\n dispatch?: IntentDispatcher;\n};\n\n/**\n * Create extension instances for editor.\n */\nexport const createBaseExtensions = ({\n viewMode,\n settings,\n document,\n query,\n dispatch,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [];\n\n //\n // Editor mode.\n //\n if (settings?.editorInputMode) {\n const extension = InputModeExtensions[settings.editorInputMode];\n if (extension) {\n extensions.push(extension);\n }\n }\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 action: NavigationAction.ADD_TO_ACTIVE,\n data: {\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 query\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(nonNullable);\n },\n }),\n );\n }\n\n extensions.push(\n ...[\n //\n settings?.folding && folding(),\n ].filter(isNotFalsy),\n );\n\n if (settings?.debug) {\n const items = settings.typewriter ?? '';\n extensions.push(...[items ? typewriter({ items: items.split(/[,\\n]/) }) : undefined].filter(nonNullable));\n }\n\n return extensions;\n};\n\n// TODO(burdon): Factor out style.\nconst hover = 'rounded-sm text-primary-600 hover:text-primary-500 dark:text-primary-300 hover:dark:text-primary-200';\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 const LinkIcon: Icon = isInternal ? ArrowSquareDown : ArrowSquareOut;\n\n createRoot(el).render(\n <StrictMode>\n <a {...options} className={hover}>\n <LinkIcon weight='bold' className={mx(getSize(4), 'inline-block leading-none mis-1 cursor-pointer')} />\n </a>\n </StrictMode>,\n );\n};\n\nconst renderLinkTooltip = (el: Element, url: string) => {\n const web = new URL(url);\n createRoot(el).render(\n <StrictMode>\n <a href={url} target='_blank' rel='noreferrer' className={hover}>\n {web.origin}\n <ArrowSquareOut weight='bold' className={mx(getSize(4), 'inline-block leading-none mis-1 cursor-pointer')} />\n </a>\n </StrictMode>,\n );\n};\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["ArrowSquareDown", "ArrowSquareOut", "React", "StrictMode", "createRoot", "NavigationAction", "invariant", "fullyQualifiedId", "autocomplete", "decorateMarkdown", "linkTooltip", "typewriter", "formattingKeymap", "InputModeExtensions", "folding", "getSize", "mx", "isNotFalsy", "nonNullable", "createBaseExtensions", "viewMode", "settings", "document", "query", "dispatch", "extensions", "editorInputMode", "extension", "push", "selectionChangeDelay", "numberedHeadings", "from", "undefined", "renderLinkButton", "onRenderLink", "id", "action", "ADD_TO_ACTIVE", "data", "part", "pivotId", "scrollIntoView", "renderLinkTooltip", "onSearch", "text", "objects", "map", "object", "name", "length", "label", "apply", "filter", "debug", "items", "split", "hover", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "options", "onClick", "qualifiedId", "at", "href", "rel", "target", "LinkIcon", "render", "a", "className", "weight", "web", "URL"]
|
|
7
|
-
}
|
|
@@ -1,540 +0,0 @@
|
|
|
1
|
-
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
-
import "./chunk-OE3CMI5X.mjs";
|
|
3
|
-
import {
|
|
4
|
-
getFallbackName,
|
|
5
|
-
isMarkdownProperties,
|
|
6
|
-
markdownExtensionPlugins,
|
|
7
|
-
serializer,
|
|
8
|
-
setFallbackName
|
|
9
|
-
} from "./chunk-NZ4H6J5H.mjs";
|
|
10
|
-
import {
|
|
11
|
-
DocumentType,
|
|
12
|
-
MarkdownAction,
|
|
13
|
-
TextType
|
|
14
|
-
} from "./chunk-3CHPA7Y7.mjs";
|
|
15
|
-
import "./chunk-RO5FEVW6.mjs";
|
|
16
|
-
import "./chunk-QARGBUBS.mjs";
|
|
17
|
-
import {
|
|
18
|
-
MARKDOWN_PLUGIN,
|
|
19
|
-
meta_default
|
|
20
|
-
} from "./chunk-2BGTVWHN.mjs";
|
|
21
|
-
|
|
22
|
-
// packages/plugins/plugin-markdown/src/MarkdownPlugin.tsx
|
|
23
|
-
import { TextAa } from "@phosphor-icons/react";
|
|
24
|
-
import React5 from "react";
|
|
25
|
-
import { isObject, parseIntentPlugin, resolvePlugin, LayoutAction, NavigationAction } from "@dxos/app-framework";
|
|
26
|
-
import { create } from "@dxos/echo-schema";
|
|
27
|
-
import { LocalStorageStore } from "@dxos/local-storage";
|
|
28
|
-
import { parseClientPlugin } from "@dxos/plugin-client";
|
|
29
|
-
import { createExtension, isActionGroup } from "@dxos/plugin-graph";
|
|
30
|
-
import { SpaceAction } from "@dxos/plugin-space";
|
|
31
|
-
import { CollectionType } from "@dxos/plugin-space/types";
|
|
32
|
-
import { createDocAccessor, fullyQualifiedId, getRangeFromCursor, isSpace, loadObjectReferences } from "@dxos/react-client/echo";
|
|
33
|
-
import { EditorViewModes as EditorViewModes2, translations as editorTranslations } from "@dxos/react-ui-editor";
|
|
34
|
-
import { isTileComponentProps } from "@dxos/react-ui-mosaic";
|
|
35
|
-
|
|
36
|
-
// packages/plugins/plugin-markdown/src/components/index.ts
|
|
37
|
-
import React4 from "react";
|
|
38
|
-
|
|
39
|
-
// packages/plugins/plugin-markdown/src/components/HeadingMenu.tsx
|
|
40
|
-
import { DotsThreeVertical } from "@phosphor-icons/react";
|
|
41
|
-
import React from "react";
|
|
42
|
-
import { Surface } from "@dxos/app-framework";
|
|
43
|
-
import { Button, DropdownMenu } from "@dxos/react-ui";
|
|
44
|
-
import { fineButtonDimensions, getSize } from "@dxos/react-ui-theme";
|
|
45
|
-
|
|
46
|
-
// packages/plugins/plugin-markdown/src/components/Layout.tsx
|
|
47
|
-
import React2 from "react";
|
|
48
|
-
import { Main } from "@dxos/react-ui";
|
|
49
|
-
import { editorWithToolbarLayout } from "@dxos/react-ui-editor";
|
|
50
|
-
import { topbarBlockPaddingStart } from "@dxos/react-ui-theme";
|
|
51
|
-
|
|
52
|
-
// packages/plugins/plugin-markdown/src/components/MarkdownSettings.tsx
|
|
53
|
-
import React3 from "react";
|
|
54
|
-
import { SettingsValue } from "@dxos/plugin-settings";
|
|
55
|
-
import { Input, Select, useTranslation } from "@dxos/react-ui";
|
|
56
|
-
import { EditorInputModes, EditorViewModes } from "@dxos/react-ui-editor";
|
|
57
|
-
var MarkdownSettings = ({ settings }) => {
|
|
58
|
-
const { t } = useTranslation(MARKDOWN_PLUGIN);
|
|
59
|
-
return /* @__PURE__ */ React3.createElement(React3.Fragment, null, /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
60
|
-
label: t("default view mode label")
|
|
61
|
-
}, /* @__PURE__ */ React3.createElement(Select.Root, {
|
|
62
|
-
value: settings.defaultViewMode,
|
|
63
|
-
onValueChange: (value) => {
|
|
64
|
-
settings.defaultViewMode = value;
|
|
65
|
-
}
|
|
66
|
-
}, /* @__PURE__ */ React3.createElement(Select.TriggerButton, null), /* @__PURE__ */ React3.createElement(Select.Portal, null, /* @__PURE__ */ React3.createElement(Select.Content, null, /* @__PURE__ */ React3.createElement(Select.Viewport, null, EditorViewModes.map((mode) => /* @__PURE__ */ React3.createElement(Select.Option, {
|
|
67
|
-
key: mode,
|
|
68
|
-
value: mode
|
|
69
|
-
}, t(`${mode} mode label`, {
|
|
70
|
-
ns: "react-ui-editor"
|
|
71
|
-
})))))))), /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
72
|
-
label: t("editor input mode label")
|
|
73
|
-
}, /* @__PURE__ */ React3.createElement(Select.Root, {
|
|
74
|
-
value: settings.editorInputMode ?? "default",
|
|
75
|
-
onValueChange: (value) => {
|
|
76
|
-
settings.editorInputMode = value;
|
|
77
|
-
}
|
|
78
|
-
}, /* @__PURE__ */ React3.createElement(Select.TriggerButton, {
|
|
79
|
-
placeholder: t("select editor input mode placeholder")
|
|
80
|
-
}), /* @__PURE__ */ React3.createElement(Select.Portal, null, /* @__PURE__ */ React3.createElement(Select.Content, null, /* @__PURE__ */ React3.createElement(Select.Viewport, null, EditorInputModes.map((mode) => /* @__PURE__ */ React3.createElement(Select.Option, {
|
|
81
|
-
key: mode,
|
|
82
|
-
value: mode
|
|
83
|
-
}, t(`settings editor input mode ${mode} label`)))))))), /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
84
|
-
label: t("settings toolbar label")
|
|
85
|
-
}, /* @__PURE__ */ React3.createElement(Input.Switch, {
|
|
86
|
-
checked: settings.toolbar,
|
|
87
|
-
onCheckedChange: (checked) => settings.toolbar = !!checked
|
|
88
|
-
})), /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
89
|
-
label: t("settings numbered headings label")
|
|
90
|
-
}, /* @__PURE__ */ React3.createElement(Input.Switch, {
|
|
91
|
-
checked: settings.numberedHeadings,
|
|
92
|
-
onCheckedChange: (checked) => settings.numberedHeadings = !!checked
|
|
93
|
-
})), /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
94
|
-
label: t("settings folding label")
|
|
95
|
-
}, /* @__PURE__ */ React3.createElement(Input.Switch, {
|
|
96
|
-
checked: settings.folding,
|
|
97
|
-
onCheckedChange: (checked) => settings.folding = !!checked
|
|
98
|
-
})), /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
99
|
-
label: t("settings experimental label")
|
|
100
|
-
}, /* @__PURE__ */ React3.createElement(Input.Switch, {
|
|
101
|
-
checked: settings.experimental,
|
|
102
|
-
onCheckedChange: (checked) => settings.experimental = !!checked
|
|
103
|
-
})), /* @__PURE__ */ React3.createElement(SettingsValue, {
|
|
104
|
-
label: t("settings debug label"),
|
|
105
|
-
secondary: settings.debug ? /* @__PURE__ */ React3.createElement(Input.Root, null, /* @__PURE__ */ React3.createElement(Input.TextArea, {
|
|
106
|
-
rows: 5,
|
|
107
|
-
value: settings.typewriter,
|
|
108
|
-
onChange: ({ target: { value } }) => settings.typewriter = value,
|
|
109
|
-
placeholder: t("settings debug placeholder")
|
|
110
|
-
})) : void 0
|
|
111
|
-
}, /* @__PURE__ */ React3.createElement(Input.Switch, {
|
|
112
|
-
checked: settings.debug,
|
|
113
|
-
onCheckedChange: (checked) => settings.debug = !!checked
|
|
114
|
-
})));
|
|
115
|
-
};
|
|
116
|
-
|
|
117
|
-
// packages/plugins/plugin-markdown/src/components/index.ts
|
|
118
|
-
var DocumentCard = React4.lazy(() => import("./DocumentCard-RHVY4Z6L.mjs"));
|
|
119
|
-
var DocumentEditor = React4.lazy(() => import("./DocumentEditor-6F5ONTIO.mjs"));
|
|
120
|
-
var MarkdownEditor = React4.lazy(() => import("./MarkdownEditor-OS7YG6MA.mjs"));
|
|
121
|
-
|
|
122
|
-
// packages/plugins/plugin-markdown/src/translations.ts
|
|
123
|
-
var translations_default = [
|
|
124
|
-
{
|
|
125
|
-
"en-US": {
|
|
126
|
-
[MARKDOWN_PLUGIN]: {
|
|
127
|
-
"plugin name": "Editor",
|
|
128
|
-
"create stack section label": "Create document",
|
|
129
|
-
"document title placeholder": "New document",
|
|
130
|
-
"choose markdown from space dialog title": "Choose one or more documents to add",
|
|
131
|
-
// TODO(burdon): Style-guide for user-facing text (e.g., hints, questions, capitalization, etc.)
|
|
132
|
-
"empty choose markdown from space message": "None available; try creating a new one instead?",
|
|
133
|
-
"chooser done label": "Add selected",
|
|
134
|
-
"create document label": "Create document",
|
|
135
|
-
"editor placeholder": "New document",
|
|
136
|
-
"editor input mode label": "Editor input mode",
|
|
137
|
-
"select editor input mode placeholder": "Select editor input mode\u2026",
|
|
138
|
-
"settings editor input mode default label": "Default",
|
|
139
|
-
"settings editor input mode vim label": "Vim",
|
|
140
|
-
"settings editor input mode vscode label": "VS Code",
|
|
141
|
-
"settings toolbar label": "Show toolbar",
|
|
142
|
-
"settings numbered headings label": "Numbered headings",
|
|
143
|
-
"settings folding label": "Folding",
|
|
144
|
-
"settings experimental label": "Enable experimental features",
|
|
145
|
-
"settings debug label": "Enable debugging features",
|
|
146
|
-
"settings debug placeholder": "Typewriter script...",
|
|
147
|
-
"toggle view mode label": "Toggle read-only",
|
|
148
|
-
"default view mode label": "Default view mode"
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
}
|
|
152
|
-
];
|
|
153
|
-
|
|
154
|
-
// packages/plugins/plugin-markdown/src/MarkdownPlugin.tsx
|
|
155
|
-
var isEditorModel = (data) => {
|
|
156
|
-
return data && typeof data === "object" && "id" in data && typeof data.id === "string" && "text" in data && typeof data.text === "string";
|
|
157
|
-
};
|
|
158
|
-
var MarkdownPlugin = () => {
|
|
159
|
-
const settings = new LocalStorageStore(MARKDOWN_PLUGIN, {
|
|
160
|
-
defaultViewMode: "preview",
|
|
161
|
-
toolbar: true,
|
|
162
|
-
folding: false,
|
|
163
|
-
experimental: false
|
|
164
|
-
});
|
|
165
|
-
const state = new LocalStorageStore(MARKDOWN_PLUGIN, {
|
|
166
|
-
extensionProviders: [],
|
|
167
|
-
viewMode: {}
|
|
168
|
-
});
|
|
169
|
-
const getViewMode = (id) => {
|
|
170
|
-
return id && state.values.viewMode[id] || settings.values.defaultViewMode;
|
|
171
|
-
};
|
|
172
|
-
const setViewMode = (id, nextViewMode) => {
|
|
173
|
-
state.values.viewMode[id] = nextViewMode;
|
|
174
|
-
};
|
|
175
|
-
return {
|
|
176
|
-
meta: meta_default,
|
|
177
|
-
ready: async (plugins) => {
|
|
178
|
-
settings.prop({
|
|
179
|
-
key: "defaultViewMode",
|
|
180
|
-
storageKey: "default-view-mode",
|
|
181
|
-
type: LocalStorageStore.enum()
|
|
182
|
-
}).prop({
|
|
183
|
-
key: "editorInputMode",
|
|
184
|
-
storageKey: "editor-mode",
|
|
185
|
-
type: LocalStorageStore.enum({
|
|
186
|
-
allowUndefined: true
|
|
187
|
-
})
|
|
188
|
-
}).prop({
|
|
189
|
-
key: "toolbar",
|
|
190
|
-
type: LocalStorageStore.bool({
|
|
191
|
-
allowUndefined: true
|
|
192
|
-
})
|
|
193
|
-
}).prop({
|
|
194
|
-
key: "experimental",
|
|
195
|
-
type: LocalStorageStore.bool({
|
|
196
|
-
allowUndefined: true
|
|
197
|
-
})
|
|
198
|
-
}).prop({
|
|
199
|
-
key: "debug",
|
|
200
|
-
type: LocalStorageStore.bool({
|
|
201
|
-
allowUndefined: true
|
|
202
|
-
})
|
|
203
|
-
}).prop({
|
|
204
|
-
key: "typewriter",
|
|
205
|
-
type: LocalStorageStore.string({
|
|
206
|
-
allowUndefined: true
|
|
207
|
-
})
|
|
208
|
-
}).prop({
|
|
209
|
-
key: "numberedHeadings",
|
|
210
|
-
type: LocalStorageStore.bool({
|
|
211
|
-
allowUndefined: true
|
|
212
|
-
})
|
|
213
|
-
}).prop({
|
|
214
|
-
key: "folding",
|
|
215
|
-
type: LocalStorageStore.bool({
|
|
216
|
-
allowUndefined: true
|
|
217
|
-
})
|
|
218
|
-
});
|
|
219
|
-
state.prop({
|
|
220
|
-
key: "viewMode",
|
|
221
|
-
storageKey: "view-mode",
|
|
222
|
-
type: LocalStorageStore.json()
|
|
223
|
-
});
|
|
224
|
-
markdownExtensionPlugins(plugins).forEach((plugin) => {
|
|
225
|
-
const { extensions } = plugin.provides.markdown;
|
|
226
|
-
state.values.extensionProviders.push(extensions);
|
|
227
|
-
});
|
|
228
|
-
},
|
|
229
|
-
provides: {
|
|
230
|
-
settings: settings.values,
|
|
231
|
-
metadata: {
|
|
232
|
-
records: {
|
|
233
|
-
[DocumentType.typename]: {
|
|
234
|
-
label: (object) => object instanceof DocumentType ? object.name ?? object.fallbackName : void 0,
|
|
235
|
-
placeholder: [
|
|
236
|
-
"document title placeholder",
|
|
237
|
-
{
|
|
238
|
-
ns: MARKDOWN_PLUGIN
|
|
239
|
-
}
|
|
240
|
-
],
|
|
241
|
-
icon: "ph--text-aa--regular",
|
|
242
|
-
graphProps: {
|
|
243
|
-
managesAutofocus: true
|
|
244
|
-
},
|
|
245
|
-
// TODO(wittjosiah): Move out of metadata.
|
|
246
|
-
loadReferences: (doc) => loadObjectReferences(doc, (doc2) => [
|
|
247
|
-
doc2.content,
|
|
248
|
-
...doc2.threads
|
|
249
|
-
]),
|
|
250
|
-
serializer
|
|
251
|
-
}
|
|
252
|
-
}
|
|
253
|
-
},
|
|
254
|
-
translations: [
|
|
255
|
-
...translations_default,
|
|
256
|
-
...editorTranslations
|
|
257
|
-
],
|
|
258
|
-
echo: {
|
|
259
|
-
schema: [
|
|
260
|
-
DocumentType,
|
|
261
|
-
TextType
|
|
262
|
-
]
|
|
263
|
-
},
|
|
264
|
-
space: {
|
|
265
|
-
onSpaceCreate: {
|
|
266
|
-
label: [
|
|
267
|
-
"create document label",
|
|
268
|
-
{
|
|
269
|
-
ns: MARKDOWN_PLUGIN
|
|
270
|
-
}
|
|
271
|
-
],
|
|
272
|
-
action: MarkdownAction.CREATE
|
|
273
|
-
}
|
|
274
|
-
},
|
|
275
|
-
graph: {
|
|
276
|
-
builder: (plugins) => {
|
|
277
|
-
const client = resolvePlugin(plugins, parseClientPlugin)?.provides.client;
|
|
278
|
-
const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;
|
|
279
|
-
if (!client || !dispatch) {
|
|
280
|
-
return [];
|
|
281
|
-
}
|
|
282
|
-
return createExtension({
|
|
283
|
-
id: MarkdownAction.CREATE,
|
|
284
|
-
filter: (node) => isActionGroup(node) && node.id.startsWith(SpaceAction.ADD_OBJECT),
|
|
285
|
-
actions: ({ node }) => {
|
|
286
|
-
const id = node.id.split("/").at(-1);
|
|
287
|
-
const [spaceId, objectId] = id?.split(":") ?? [];
|
|
288
|
-
const space = client.spaces.get().find((space2) => space2.id === spaceId);
|
|
289
|
-
const object = objectId && space?.db.getObjectById(objectId);
|
|
290
|
-
const target = objectId ? object : space;
|
|
291
|
-
if (!target) {
|
|
292
|
-
return;
|
|
293
|
-
}
|
|
294
|
-
return [
|
|
295
|
-
{
|
|
296
|
-
id: `${MARKDOWN_PLUGIN}/create/${node.id}`,
|
|
297
|
-
data: async () => {
|
|
298
|
-
await dispatch([
|
|
299
|
-
{
|
|
300
|
-
plugin: MARKDOWN_PLUGIN,
|
|
301
|
-
action: MarkdownAction.CREATE
|
|
302
|
-
},
|
|
303
|
-
{
|
|
304
|
-
action: SpaceAction.ADD_OBJECT,
|
|
305
|
-
data: {
|
|
306
|
-
target
|
|
307
|
-
}
|
|
308
|
-
},
|
|
309
|
-
{
|
|
310
|
-
action: NavigationAction.OPEN
|
|
311
|
-
}
|
|
312
|
-
]);
|
|
313
|
-
},
|
|
314
|
-
properties: {
|
|
315
|
-
label: [
|
|
316
|
-
"create document label",
|
|
317
|
-
{
|
|
318
|
-
ns: MARKDOWN_PLUGIN
|
|
319
|
-
}
|
|
320
|
-
],
|
|
321
|
-
icon: "ph--text-aa--regular",
|
|
322
|
-
testId: "markdownPlugin.createObject"
|
|
323
|
-
}
|
|
324
|
-
}
|
|
325
|
-
];
|
|
326
|
-
}
|
|
327
|
-
});
|
|
328
|
-
},
|
|
329
|
-
serializer: (plugins) => {
|
|
330
|
-
const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatch;
|
|
331
|
-
if (!dispatch) {
|
|
332
|
-
return [];
|
|
333
|
-
}
|
|
334
|
-
return [
|
|
335
|
-
{
|
|
336
|
-
inputType: DocumentType.typename,
|
|
337
|
-
outputType: "text/markdown",
|
|
338
|
-
// Reconcile with metadata serializers.
|
|
339
|
-
serialize: async (node) => {
|
|
340
|
-
const doc = node.data;
|
|
341
|
-
const content = await loadObjectReferences(doc, (doc2) => doc2.content);
|
|
342
|
-
return {
|
|
343
|
-
name: doc.name || doc.fallbackName || translations_default[0]["en-US"][MARKDOWN_PLUGIN]["document title placeholder"],
|
|
344
|
-
data: content.content,
|
|
345
|
-
type: "text/markdown"
|
|
346
|
-
};
|
|
347
|
-
},
|
|
348
|
-
deserialize: async (data, ancestors) => {
|
|
349
|
-
const space = ancestors.find(isSpace);
|
|
350
|
-
const target = ancestors.findLast((ancestor) => ancestor instanceof CollectionType) ?? space?.properties[CollectionType.typename];
|
|
351
|
-
if (!space || !target) {
|
|
352
|
-
return;
|
|
353
|
-
}
|
|
354
|
-
const result = await dispatch([
|
|
355
|
-
{
|
|
356
|
-
plugin: MARKDOWN_PLUGIN,
|
|
357
|
-
action: MarkdownAction.CREATE,
|
|
358
|
-
data: {
|
|
359
|
-
name: data.name,
|
|
360
|
-
content: data.data
|
|
361
|
-
}
|
|
362
|
-
},
|
|
363
|
-
{
|
|
364
|
-
action: SpaceAction.ADD_OBJECT,
|
|
365
|
-
data: {
|
|
366
|
-
target
|
|
367
|
-
}
|
|
368
|
-
}
|
|
369
|
-
]);
|
|
370
|
-
return result?.data.object;
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
];
|
|
374
|
-
}
|
|
375
|
-
},
|
|
376
|
-
stack: {
|
|
377
|
-
creators: [
|
|
378
|
-
{
|
|
379
|
-
id: "create-stack-section-doc",
|
|
380
|
-
testId: "markdownPlugin.createSection",
|
|
381
|
-
type: [
|
|
382
|
-
"plugin name",
|
|
383
|
-
{
|
|
384
|
-
ns: MARKDOWN_PLUGIN
|
|
385
|
-
}
|
|
386
|
-
],
|
|
387
|
-
label: [
|
|
388
|
-
"create stack section label",
|
|
389
|
-
{
|
|
390
|
-
ns: MARKDOWN_PLUGIN
|
|
391
|
-
}
|
|
392
|
-
],
|
|
393
|
-
icon: (props) => /* @__PURE__ */ React5.createElement(TextAa, props),
|
|
394
|
-
intent: {
|
|
395
|
-
plugin: MARKDOWN_PLUGIN,
|
|
396
|
-
action: MarkdownAction.CREATE
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
]
|
|
400
|
-
},
|
|
401
|
-
thread: {
|
|
402
|
-
predicate: (obj) => obj instanceof DocumentType,
|
|
403
|
-
createSort: (doc) => {
|
|
404
|
-
const accessor = doc.content ? createDocAccessor(doc.content, [
|
|
405
|
-
"content"
|
|
406
|
-
]) : void 0;
|
|
407
|
-
if (!accessor) {
|
|
408
|
-
return (_) => 0;
|
|
409
|
-
}
|
|
410
|
-
const getStartPosition = (cursor) => {
|
|
411
|
-
const range = cursor ? getRangeFromCursor(accessor, cursor) : void 0;
|
|
412
|
-
return range?.start ?? Number.MAX_SAFE_INTEGER;
|
|
413
|
-
};
|
|
414
|
-
return (anchorA, anchorB) => {
|
|
415
|
-
if (anchorA === void 0 || anchorB === void 0) {
|
|
416
|
-
return 0;
|
|
417
|
-
}
|
|
418
|
-
const posA = getStartPosition(anchorA);
|
|
419
|
-
const posB = getStartPosition(anchorB);
|
|
420
|
-
return posA - posB;
|
|
421
|
-
};
|
|
422
|
-
}
|
|
423
|
-
},
|
|
424
|
-
surface: {
|
|
425
|
-
component: ({ data, role, ...props }, forwardedRef) => {
|
|
426
|
-
const doc = data.active instanceof DocumentType ? data.active : data.object instanceof DocumentType ? data.object : void 0;
|
|
427
|
-
switch (role) {
|
|
428
|
-
case "section":
|
|
429
|
-
case "article": {
|
|
430
|
-
if (doc && doc.content) {
|
|
431
|
-
return /* @__PURE__ */ React5.createElement(DocumentEditor, {
|
|
432
|
-
role,
|
|
433
|
-
coordinate: data.coordinate,
|
|
434
|
-
document: doc,
|
|
435
|
-
extensionProviders: state.values.extensionProviders,
|
|
436
|
-
settings: settings.values,
|
|
437
|
-
scrollPastEnd: true,
|
|
438
|
-
viewMode: getViewMode(fullyQualifiedId(doc)),
|
|
439
|
-
onViewModeChange: setViewMode
|
|
440
|
-
});
|
|
441
|
-
} else if (isEditorModel(data.object)) {
|
|
442
|
-
return /* @__PURE__ */ React5.createElement(MarkdownEditor, {
|
|
443
|
-
id: data.object.id,
|
|
444
|
-
role,
|
|
445
|
-
coordinate: data.coordinate,
|
|
446
|
-
initialValue: data.object.text,
|
|
447
|
-
extensionProviders: state.values.extensionProviders,
|
|
448
|
-
inputMode: settings.values.editorInputMode,
|
|
449
|
-
toolbar: settings.values.toolbar,
|
|
450
|
-
scrollPastEnd: true,
|
|
451
|
-
viewMode: getViewMode(data.object.id),
|
|
452
|
-
onViewModeChange: setViewMode
|
|
453
|
-
});
|
|
454
|
-
}
|
|
455
|
-
break;
|
|
456
|
-
}
|
|
457
|
-
case "card": {
|
|
458
|
-
if (isObject(data.content) && typeof data.content.id === "string" && data.content.object instanceof DocumentType) {
|
|
459
|
-
const cardProps = {
|
|
460
|
-
...props,
|
|
461
|
-
item: {
|
|
462
|
-
id: data.content.id,
|
|
463
|
-
object: data.content.object,
|
|
464
|
-
color: typeof data.content.color === "string" ? data.content.color : void 0
|
|
465
|
-
}
|
|
466
|
-
};
|
|
467
|
-
return isTileComponentProps(cardProps) ? /* @__PURE__ */ React5.createElement(DocumentCard, {
|
|
468
|
-
...cardProps,
|
|
469
|
-
settings: settings.values,
|
|
470
|
-
ref: forwardedRef
|
|
471
|
-
}) : null;
|
|
472
|
-
}
|
|
473
|
-
break;
|
|
474
|
-
}
|
|
475
|
-
case "settings": {
|
|
476
|
-
return data.plugin === meta_default.id ? /* @__PURE__ */ React5.createElement(MarkdownSettings, {
|
|
477
|
-
settings: settings.values
|
|
478
|
-
}) : null;
|
|
479
|
-
}
|
|
480
|
-
}
|
|
481
|
-
return null;
|
|
482
|
-
}
|
|
483
|
-
},
|
|
484
|
-
intent: {
|
|
485
|
-
resolver: ({ action, data }) => {
|
|
486
|
-
switch (action) {
|
|
487
|
-
case MarkdownAction.CREATE: {
|
|
488
|
-
const doc = create(DocumentType, {
|
|
489
|
-
name: data?.name,
|
|
490
|
-
content: create(TextType, {
|
|
491
|
-
content: data?.content ?? ""
|
|
492
|
-
}),
|
|
493
|
-
threads: []
|
|
494
|
-
});
|
|
495
|
-
return {
|
|
496
|
-
data: doc,
|
|
497
|
-
intents: [
|
|
498
|
-
[
|
|
499
|
-
{
|
|
500
|
-
action: LayoutAction.SCROLL_INTO_VIEW,
|
|
501
|
-
data: {
|
|
502
|
-
id: fullyQualifiedId(doc)
|
|
503
|
-
}
|
|
504
|
-
}
|
|
505
|
-
]
|
|
506
|
-
]
|
|
507
|
-
};
|
|
508
|
-
}
|
|
509
|
-
case MarkdownAction.SET_VIEW_MODE: {
|
|
510
|
-
const { id, viewMode } = data ?? {};
|
|
511
|
-
if (typeof id === "string" && EditorViewModes2.includes(viewMode)) {
|
|
512
|
-
state.values.viewMode[id] = viewMode;
|
|
513
|
-
return {
|
|
514
|
-
data: true
|
|
515
|
-
};
|
|
516
|
-
}
|
|
517
|
-
break;
|
|
518
|
-
}
|
|
519
|
-
}
|
|
520
|
-
}
|
|
521
|
-
}
|
|
522
|
-
}
|
|
523
|
-
};
|
|
524
|
-
};
|
|
525
|
-
|
|
526
|
-
// packages/plugins/plugin-markdown/src/index.ts
|
|
527
|
-
var src_default = MarkdownPlugin;
|
|
528
|
-
export {
|
|
529
|
-
DocumentType,
|
|
530
|
-
MarkdownAction,
|
|
531
|
-
MarkdownPlugin,
|
|
532
|
-
TextType,
|
|
533
|
-
src_default as default,
|
|
534
|
-
getFallbackName,
|
|
535
|
-
isMarkdownProperties,
|
|
536
|
-
markdownExtensionPlugins,
|
|
537
|
-
serializer,
|
|
538
|
-
setFallbackName
|
|
539
|
-
};
|
|
540
|
-
//# sourceMappingURL=index.mjs.map
|