@dxos/plugin-markdown 0.6.12-main.5cc132e → 0.6.12-main.89e9959
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/MarkdownContainer-OWVU5WMN.mjs +467 -0
- package/dist/lib/browser/MarkdownContainer-OWVU5WMN.mjs.map +7 -0
- package/dist/lib/{node-esm/chunk-4GGD6YJO.mjs → browser/chunk-2SJN46PA.mjs} +2 -5
- package/dist/lib/browser/chunk-2SJN46PA.mjs.map +7 -0
- package/dist/lib/browser/chunk-7WORDTCY.mjs +50 -0
- package/dist/lib/browser/chunk-7WORDTCY.mjs.map +7 -0
- package/dist/lib/browser/{chunk-7W37KPH3.mjs → chunk-OUZCML5B.mjs} +4 -2
- package/dist/lib/browser/chunk-OUZCML5B.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +68 -114
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/meta.mjs +1 -1
- package/dist/lib/browser/types/index.mjs +6 -4
- package/dist/lib/node/MarkdownContainer-IWMLWI6Z.cjs +482 -0
- package/dist/lib/node/MarkdownContainer-IWMLWI6Z.cjs.map +7 -0
- package/dist/lib/node/{chunk-EZTJSCMZ.cjs → chunk-HVDIBL5H.cjs} +11 -8
- package/dist/lib/node/chunk-HVDIBL5H.cjs.map +7 -0
- package/dist/lib/node/chunk-L2FIDO4L.cjs +72 -0
- package/dist/lib/node/chunk-L2FIDO4L.cjs.map +7 -0
- package/dist/lib/node/{MarkdownEditor-IUHHJ532.cjs → chunk-LPD4NOTH.cjs} +17 -9
- package/dist/lib/node/chunk-LPD4NOTH.cjs.map +7 -0
- package/dist/lib/node/index.cjs +103 -145
- package/dist/lib/node/index.cjs.map +4 -4
- 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 +8 -6
- package/dist/lib/node/types/index.cjs.map +2 -2
- package/dist/lib/node-esm/MarkdownContainer-MLTDWWGB.mjs +468 -0
- package/dist/lib/node-esm/MarkdownContainer-MLTDWWGB.mjs.map +7 -0
- package/dist/lib/{browser/chunk-4GGD6YJO.mjs → node-esm/chunk-2BGTVWHN.mjs} +4 -5
- package/dist/lib/node-esm/chunk-2BGTVWHN.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-7W37KPH3.mjs → chunk-4AGP7IJE.mjs} +5 -2
- package/dist/lib/node-esm/chunk-4AGP7IJE.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-YOIARYUO.mjs +51 -0
- package/dist/lib/node-esm/chunk-YOIARYUO.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +69 -114
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/meta.mjs +2 -1
- package/dist/lib/node-esm/types/index.mjs +7 -4
- package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownContainer.d.ts +15 -0
- package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -0
- package/dist/types/src/components/MarkdownEditor.d.ts +8 -3
- package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownEditor.stories.d.ts +3 -3
- package/dist/types/src/components/MarkdownEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +2 -11
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/extensions.d.ts +11 -15
- package/dist/types/src/extensions.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +1 -4
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/types/document.d.ts +10 -1
- package/dist/types/src/types/document.d.ts.map +1 -1
- package/dist/types/src/types/types.d.ts +7 -8
- package/dist/types/src/types/types.d.ts.map +1 -1
- package/package.json +34 -33
- package/src/MarkdownPlugin.tsx +40 -94
- package/src/components/MarkdownContainer.tsx +108 -0
- package/src/components/MarkdownEditor.stories.tsx +11 -5
- package/src/components/MarkdownEditor.tsx +33 -39
- package/src/components/index.ts +2 -14
- package/src/extensions.tsx +124 -67
- package/src/meta.tsx +1 -5
- package/src/types/document.ts +12 -0
- package/src/types/types.ts +9 -6
- package/dist/lib/browser/DocumentCard-2P4EICBA.mjs +0 -11
- package/dist/lib/browser/DocumentCard-2P4EICBA.mjs.map +0 -7
- package/dist/lib/browser/DocumentEditor-PXYEHGQA.mjs +0 -11
- package/dist/lib/browser/DocumentEditor-PXYEHGQA.mjs.map +0 -7
- package/dist/lib/browser/MarkdownEditor-IE2ISQQF.mjs +0 -10
- package/dist/lib/browser/MarkdownEditor-IE2ISQQF.mjs.map +0 -7
- package/dist/lib/browser/chunk-354DCID5.mjs +0 -117
- package/dist/lib/browser/chunk-354DCID5.mjs.map +0 -7
- package/dist/lib/browser/chunk-4GGD6YJO.mjs.map +0 -7
- package/dist/lib/browser/chunk-5FP6MXCU.mjs +0 -164
- package/dist/lib/browser/chunk-5FP6MXCU.mjs.map +0 -7
- package/dist/lib/browser/chunk-7W37KPH3.mjs.map +0 -7
- package/dist/lib/browser/chunk-RL7QY322.mjs +0 -86
- package/dist/lib/browser/chunk-RL7QY322.mjs.map +0 -7
- package/dist/lib/browser/chunk-RQLDAFNM.mjs +0 -216
- package/dist/lib/browser/chunk-RQLDAFNM.mjs.map +0 -7
- package/dist/lib/node/DocumentCard-EHJDDSRY.cjs +0 -32
- package/dist/lib/node/DocumentCard-EHJDDSRY.cjs.map +0 -7
- package/dist/lib/node/DocumentEditor-DZOOGCBM.cjs +0 -29
- package/dist/lib/node/DocumentEditor-DZOOGCBM.cjs.map +0 -7
- package/dist/lib/node/MarkdownEditor-IUHHJ532.cjs.map +0 -7
- package/dist/lib/node/chunk-DFWSVQEA.cjs +0 -189
- package/dist/lib/node/chunk-DFWSVQEA.cjs.map +0 -7
- package/dist/lib/node/chunk-EZTJSCMZ.cjs.map +0 -7
- package/dist/lib/node/chunk-GRU6YP3J.cjs +0 -242
- package/dist/lib/node/chunk-GRU6YP3J.cjs.map +0 -7
- package/dist/lib/node/chunk-KTYIOXL5.cjs +0 -149
- package/dist/lib/node/chunk-KTYIOXL5.cjs.map +0 -7
- package/dist/lib/node/chunk-Q4ZSCBQE.cjs +0 -114
- package/dist/lib/node/chunk-Q4ZSCBQE.cjs.map +0 -7
- package/dist/lib/node/chunk-TGMR2CKU.cjs +0 -52
- package/dist/lib/node/chunk-TGMR2CKU.cjs.map +0 -7
- package/dist/lib/node-esm/DocumentCard-2P4EICBA.mjs +0 -11
- package/dist/lib/node-esm/DocumentCard-2P4EICBA.mjs.map +0 -7
- package/dist/lib/node-esm/DocumentEditor-PXYEHGQA.mjs +0 -11
- package/dist/lib/node-esm/DocumentEditor-PXYEHGQA.mjs.map +0 -7
- package/dist/lib/node-esm/MarkdownEditor-IE2ISQQF.mjs +0 -10
- package/dist/lib/node-esm/MarkdownEditor-IE2ISQQF.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-354DCID5.mjs +0 -117
- package/dist/lib/node-esm/chunk-354DCID5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-4GGD6YJO.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-5FP6MXCU.mjs +0 -164
- package/dist/lib/node-esm/chunk-5FP6MXCU.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-7W37KPH3.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-RL7QY322.mjs +0 -86
- package/dist/lib/node-esm/chunk-RL7QY322.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-RQLDAFNM.mjs +0 -216
- package/dist/lib/node-esm/chunk-RQLDAFNM.mjs.map +0 -7
- package/dist/types/src/components/DocumentCard.d.ts +0 -16
- package/dist/types/src/components/DocumentCard.d.ts.map +0 -1
- package/dist/types/src/components/DocumentEditor.d.ts +0 -14
- package/dist/types/src/components/DocumentEditor.d.ts.map +0 -1
- package/dist/types/src/components/HeadingMenu.d.ts +0 -13
- package/dist/types/src/components/HeadingMenu.d.ts.map +0 -1
- package/dist/types/src/components/Layout.d.ts +0 -6
- package/dist/types/src/components/Layout.d.ts.map +0 -1
- package/src/components/DocumentCard.tsx +0 -107
- package/src/components/DocumentEditor.tsx +0 -137
- package/src/components/HeadingMenu.tsx +0 -46
- package/src/components/Layout.tsx +0 -27
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
|
+
import {
|
|
3
|
+
DocumentType,
|
|
4
|
+
TextType
|
|
5
|
+
} from "./chunk-4AGP7IJE.mjs";
|
|
6
|
+
|
|
7
|
+
// packages/plugins/plugin-markdown/src/util.tsx
|
|
8
|
+
import { debounce } from "@dxos/async";
|
|
9
|
+
import { create, createEchoObject, isEchoObject, loadObjectReferences } from "@dxos/react-client/echo";
|
|
10
|
+
var isMarkdownProperties = (data) => isEchoObject(data) ? true : data && typeof data === "object" ? "title" in data && typeof data.title === "string" : false;
|
|
11
|
+
var markdownExtensionPlugins = (plugins) => {
|
|
12
|
+
return plugins.filter((plugin) => Boolean(plugin.provides?.markdown));
|
|
13
|
+
};
|
|
14
|
+
var nonTitleChars = /[^\w ]/g;
|
|
15
|
+
var getFallbackName = (content) => {
|
|
16
|
+
return content.substring(0, 31).split("\n")[0].replaceAll(nonTitleChars, "").trim();
|
|
17
|
+
};
|
|
18
|
+
var setFallbackName = debounce((doc, content) => {
|
|
19
|
+
const name = getFallbackName(content);
|
|
20
|
+
if (doc.fallbackName !== name) {
|
|
21
|
+
doc.fallbackName = name;
|
|
22
|
+
}
|
|
23
|
+
}, 200);
|
|
24
|
+
var serializer = {
|
|
25
|
+
serialize: async ({ object }) => {
|
|
26
|
+
const content = await loadObjectReferences(object, (doc) => doc.content);
|
|
27
|
+
return JSON.stringify({
|
|
28
|
+
name: object.name,
|
|
29
|
+
content: content.content
|
|
30
|
+
});
|
|
31
|
+
},
|
|
32
|
+
deserialize: async ({ content: serialized }) => {
|
|
33
|
+
const { name, content } = JSON.parse(serialized);
|
|
34
|
+
return createEchoObject(create(DocumentType, {
|
|
35
|
+
name,
|
|
36
|
+
content: create(TextType, {
|
|
37
|
+
content
|
|
38
|
+
}),
|
|
39
|
+
threads: []
|
|
40
|
+
}));
|
|
41
|
+
}
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
export {
|
|
45
|
+
isMarkdownProperties,
|
|
46
|
+
markdownExtensionPlugins,
|
|
47
|
+
getFallbackName,
|
|
48
|
+
setFallbackName,
|
|
49
|
+
serializer
|
|
50
|
+
};
|
|
51
|
+
//# sourceMappingURL=chunk-YOIARYUO.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/util.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Plugin } from '@dxos/app-framework';\nimport { debounce } from '@dxos/async';\nimport { type TypedObjectSerializer } from '@dxos/plugin-space/types';\nimport { create, createEchoObject, isEchoObject, loadObjectReferences } from '@dxos/react-client/echo';\n\nimport { DocumentType, type MarkdownProperties, type MarkdownExtensionProvides, TextType } from './types';\n\nexport const isMarkdownProperties = (data: unknown): data is MarkdownProperties =>\n isEchoObject(data)\n ? true\n : data && typeof data === 'object'\n ? 'title' in data && typeof data.title === 'string'\n : false;\n\ntype MarkdownExtensionPlugin = Plugin<MarkdownExtensionProvides>;\n\nexport const markdownExtensionPlugins = (plugins: Plugin[]): MarkdownExtensionPlugin[] => {\n return (plugins as MarkdownExtensionPlugin[]).filter((plugin) => Boolean(plugin.provides?.markdown));\n};\n\nconst nonTitleChars = /[^\\w ]/g;\n\nexport const getFallbackName = (content: string) => {\n return content.substring(0, 31).split('\\n')[0].replaceAll(nonTitleChars, '').trim();\n};\n\nexport const setFallbackName = debounce((doc: DocumentType, content: string) => {\n const name = getFallbackName(content);\n if (doc.fallbackName !== name) {\n doc.fallbackName = name;\n }\n}, 200);\n\nexport const serializer: TypedObjectSerializer<DocumentType> = {\n serialize: async ({ object }): Promise<string> => {\n const content = await loadObjectReferences(object, (doc) => doc.content);\n return JSON.stringify({ name: object.name, content: content.content });\n },\n\n deserialize: async ({ content: serialized }) => {\n const { name, content } = JSON.parse(serialized);\n return createEchoObject(create(DocumentType, { name, content: create(TextType, { content }), threads: [] }));\n },\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;;AAKA,SAASA,gBAAgB;AAEzB,SAASC,QAAQC,kBAAkBC,cAAcC,4BAA4B;AAItE,IAAMC,uBAAuB,CAACC,SACnCC,aAAaD,IAAAA,IACT,OACAA,QAAQ,OAAOA,SAAS,WACtB,WAAWA,QAAQ,OAAOA,KAAKE,UAAU,WACzC;AAID,IAAMC,2BAA2B,CAACC,YAAAA;AACvC,SAAQA,QAAsCC,OAAO,CAACC,WAAWC,QAAQD,OAAOE,UAAUC,QAAAA,CAAAA;AAC5F;AAEA,IAAMC,gBAAgB;AAEf,IAAMC,kBAAkB,CAACC,YAAAA;AAC9B,SAAOA,QAAQC,UAAU,GAAG,EAAA,EAAIC,MAAM,IAAA,EAAM,CAAA,EAAGC,WAAWL,eAAe,EAAA,EAAIM,KAAI;AACnF;AAEO,IAAMC,kBAAkBC,SAAS,CAACC,KAAmBP,YAAAA;AAC1D,QAAMQ,OAAOT,gBAAgBC,OAAAA;AAC7B,MAAIO,IAAIE,iBAAiBD,MAAM;AAC7BD,QAAIE,eAAeD;EACrB;AACF,GAAG,GAAA;AAEI,IAAME,aAAkD;EAC7DC,WAAW,OAAO,EAAEC,OAAM,MAAE;AAC1B,UAAMZ,UAAU,MAAMa,qBAAqBD,QAAQ,CAACL,QAAQA,IAAIP,OAAO;AACvE,WAAOc,KAAKC,UAAU;MAAEP,MAAMI,OAAOJ;MAAMR,SAASA,QAAQA;IAAQ,CAAA;EACtE;EAEAgB,aAAa,OAAO,EAAEhB,SAASiB,WAAU,MAAE;AACzC,UAAM,EAAET,MAAMR,QAAO,IAAKc,KAAKI,MAAMD,UAAAA;AACrC,WAAOE,iBAAiBC,OAAOC,cAAc;MAAEb;MAAMR,SAASoB,OAAOE,UAAU;QAAEtB;MAAQ,CAAA;MAAIuB,SAAS,CAAA;IAAG,CAAA,CAAA;EAC3G;AACF;",
|
|
6
|
+
"names": ["debounce", "create", "createEchoObject", "isEchoObject", "loadObjectReferences", "isMarkdownProperties", "data", "isEchoObject", "title", "markdownExtensionPlugins", "plugins", "filter", "plugin", "Boolean", "provides", "markdown", "nonTitleChars", "getFallbackName", "content", "substring", "split", "replaceAll", "trim", "setFallbackName", "debounce", "doc", "name", "fallbackName", "serializer", "serialize", "object", "loadObjectReferences", "JSON", "stringify", "deserialize", "serialized", "parse", "createEchoObject", "create", "DocumentType", "TextType", "threads"]
|
|
7
|
+
}
|
|
@@ -1,123 +1,105 @@
|
|
|
1
|
-
import
|
|
1
|
+
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
3
|
getFallbackName,
|
|
4
4
|
isMarkdownProperties,
|
|
5
5
|
markdownExtensionPlugins,
|
|
6
6
|
serializer,
|
|
7
7
|
setFallbackName
|
|
8
|
-
} from "./chunk-
|
|
8
|
+
} from "./chunk-YOIARYUO.mjs";
|
|
9
9
|
import {
|
|
10
10
|
DocumentType,
|
|
11
11
|
MarkdownAction,
|
|
12
|
-
TextType
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
import "./chunk-RQLDAFNM.mjs";
|
|
12
|
+
TextType,
|
|
13
|
+
isEditorModel
|
|
14
|
+
} from "./chunk-4AGP7IJE.mjs";
|
|
16
15
|
import {
|
|
17
16
|
MARKDOWN_PLUGIN,
|
|
18
17
|
meta_default
|
|
19
|
-
} from "./chunk-
|
|
18
|
+
} from "./chunk-2BGTVWHN.mjs";
|
|
20
19
|
|
|
21
20
|
// packages/plugins/plugin-markdown/src/MarkdownPlugin.tsx
|
|
22
21
|
import { TextAa } from "@phosphor-icons/react";
|
|
23
|
-
import
|
|
24
|
-
import {
|
|
22
|
+
import React3 from "react";
|
|
23
|
+
import { parseIntentPlugin, resolvePlugin, LayoutAction, NavigationAction } from "@dxos/app-framework";
|
|
25
24
|
import { create } from "@dxos/echo-schema";
|
|
26
25
|
import { LocalStorageStore } from "@dxos/local-storage";
|
|
27
|
-
import { log } from "@dxos/log";
|
|
28
26
|
import { parseClientPlugin } from "@dxos/plugin-client";
|
|
29
27
|
import { createExtension, isActionGroup } from "@dxos/plugin-graph";
|
|
30
28
|
import { SpaceAction } from "@dxos/plugin-space";
|
|
31
29
|
import { CollectionType } from "@dxos/plugin-space/types";
|
|
32
30
|
import { createDocAccessor, fullyQualifiedId, getRangeFromCursor, isSpace, loadObjectReferences } from "@dxos/react-client/echo";
|
|
33
31
|
import { EditorViewModes as EditorViewModes2, translations as editorTranslations } from "@dxos/react-ui-editor";
|
|
34
|
-
import { isTileComponentProps } from "@dxos/react-ui-mosaic";
|
|
35
32
|
|
|
36
33
|
// 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
34
|
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
35
|
|
|
52
36
|
// packages/plugins/plugin-markdown/src/components/MarkdownSettings.tsx
|
|
53
|
-
import
|
|
37
|
+
import React from "react";
|
|
54
38
|
import { SettingsValue } from "@dxos/plugin-settings";
|
|
55
39
|
import { Input, Select, useTranslation } from "@dxos/react-ui";
|
|
56
40
|
import { EditorInputModes, EditorViewModes } from "@dxos/react-ui-editor";
|
|
57
41
|
var MarkdownSettings = ({ settings }) => {
|
|
58
42
|
const { t } = useTranslation(MARKDOWN_PLUGIN);
|
|
59
|
-
return /* @__PURE__ */
|
|
43
|
+
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
60
44
|
label: t("default view mode label")
|
|
61
|
-
}, /* @__PURE__ */
|
|
45
|
+
}, /* @__PURE__ */ React.createElement(Select.Root, {
|
|
62
46
|
value: settings.defaultViewMode,
|
|
63
47
|
onValueChange: (value) => {
|
|
64
48
|
settings.defaultViewMode = value;
|
|
65
49
|
}
|
|
66
|
-
}, /* @__PURE__ */
|
|
50
|
+
}, /* @__PURE__ */ React.createElement(Select.TriggerButton, null), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, EditorViewModes.map((mode) => /* @__PURE__ */ React.createElement(Select.Option, {
|
|
67
51
|
key: mode,
|
|
68
52
|
value: mode
|
|
69
53
|
}, t(`${mode} mode label`, {
|
|
70
54
|
ns: "react-ui-editor"
|
|
71
|
-
})))))))), /* @__PURE__ */
|
|
55
|
+
})))))))), /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
72
56
|
label: t("editor input mode label")
|
|
73
|
-
}, /* @__PURE__ */
|
|
57
|
+
}, /* @__PURE__ */ React.createElement(Select.Root, {
|
|
74
58
|
value: settings.editorInputMode ?? "default",
|
|
75
59
|
onValueChange: (value) => {
|
|
76
60
|
settings.editorInputMode = value;
|
|
77
61
|
}
|
|
78
|
-
}, /* @__PURE__ */
|
|
62
|
+
}, /* @__PURE__ */ React.createElement(Select.TriggerButton, {
|
|
79
63
|
placeholder: t("select editor input mode placeholder")
|
|
80
|
-
}), /* @__PURE__ */
|
|
64
|
+
}), /* @__PURE__ */ React.createElement(Select.Portal, null, /* @__PURE__ */ React.createElement(Select.Content, null, /* @__PURE__ */ React.createElement(Select.Viewport, null, EditorInputModes.map((mode) => /* @__PURE__ */ React.createElement(Select.Option, {
|
|
81
65
|
key: mode,
|
|
82
66
|
value: mode
|
|
83
|
-
}, t(`settings editor input mode ${mode} label`)))))))), /* @__PURE__ */
|
|
67
|
+
}, t(`settings editor input mode ${mode} label`)))))))), /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
84
68
|
label: t("settings toolbar label")
|
|
85
|
-
}, /* @__PURE__ */
|
|
69
|
+
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
86
70
|
checked: settings.toolbar,
|
|
87
71
|
onCheckedChange: (checked) => settings.toolbar = !!checked
|
|
88
|
-
})), /* @__PURE__ */
|
|
72
|
+
})), /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
89
73
|
label: t("settings numbered headings label")
|
|
90
|
-
}, /* @__PURE__ */
|
|
74
|
+
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
91
75
|
checked: settings.numberedHeadings,
|
|
92
76
|
onCheckedChange: (checked) => settings.numberedHeadings = !!checked
|
|
93
|
-
})), /* @__PURE__ */
|
|
77
|
+
})), /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
94
78
|
label: t("settings folding label")
|
|
95
|
-
}, /* @__PURE__ */
|
|
79
|
+
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
96
80
|
checked: settings.folding,
|
|
97
81
|
onCheckedChange: (checked) => settings.folding = !!checked
|
|
98
|
-
})), /* @__PURE__ */
|
|
82
|
+
})), /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
99
83
|
label: t("settings experimental label")
|
|
100
|
-
}, /* @__PURE__ */
|
|
84
|
+
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
101
85
|
checked: settings.experimental,
|
|
102
86
|
onCheckedChange: (checked) => settings.experimental = !!checked
|
|
103
|
-
})), /* @__PURE__ */
|
|
87
|
+
})), /* @__PURE__ */ React.createElement(SettingsValue, {
|
|
104
88
|
label: t("settings debug label"),
|
|
105
|
-
secondary: settings.debug ? /* @__PURE__ */
|
|
89
|
+
secondary: settings.debug ? /* @__PURE__ */ React.createElement(Input.Root, null, /* @__PURE__ */ React.createElement(Input.TextArea, {
|
|
106
90
|
rows: 5,
|
|
107
91
|
value: settings.typewriter,
|
|
108
92
|
onChange: ({ target: { value } }) => settings.typewriter = value,
|
|
109
93
|
placeholder: t("settings debug placeholder")
|
|
110
94
|
})) : void 0
|
|
111
|
-
}, /* @__PURE__ */
|
|
95
|
+
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
112
96
|
checked: settings.debug,
|
|
113
97
|
onCheckedChange: (checked) => settings.debug = !!checked
|
|
114
98
|
})));
|
|
115
99
|
};
|
|
116
100
|
|
|
117
101
|
// packages/plugins/plugin-markdown/src/components/index.ts
|
|
118
|
-
var
|
|
119
|
-
var DocumentEditor = React4.lazy(() => import("./DocumentEditor-PXYEHGQA.mjs"));
|
|
120
|
-
var MarkdownEditor = React4.lazy(() => import("./MarkdownEditor-IE2ISQQF.mjs"));
|
|
102
|
+
var MarkdownContainer = React2.lazy(() => import("./MarkdownContainer-MLTDWWGB.mjs"));
|
|
121
103
|
|
|
122
104
|
// packages/plugins/plugin-markdown/src/translations.ts
|
|
123
105
|
var translations_default = [
|
|
@@ -152,10 +134,7 @@ var translations_default = [
|
|
|
152
134
|
];
|
|
153
135
|
|
|
154
136
|
// packages/plugins/plugin-markdown/src/MarkdownPlugin.tsx
|
|
155
|
-
var
|
|
156
|
-
var isEditorModel = (data) => {
|
|
157
|
-
return data && typeof data === "object" && "id" in data && typeof data.id === "string" && "text" in data && typeof data.text === "string";
|
|
158
|
-
};
|
|
137
|
+
var getDoc = (object) => object instanceof DocumentType ? object : void 0;
|
|
159
138
|
var MarkdownPlugin = () => {
|
|
160
139
|
const settings = new LocalStorageStore(MARKDOWN_PLUGIN, {
|
|
161
140
|
defaultViewMode: "preview",
|
|
@@ -167,12 +146,8 @@ var MarkdownPlugin = () => {
|
|
|
167
146
|
extensionProviders: [],
|
|
168
147
|
viewMode: {}
|
|
169
148
|
});
|
|
170
|
-
const getViewMode = (id) =>
|
|
171
|
-
|
|
172
|
-
};
|
|
173
|
-
const setViewMode = (id, nextViewMode) => {
|
|
174
|
-
state.values.viewMode[id] = nextViewMode;
|
|
175
|
-
};
|
|
149
|
+
const getViewMode = (id) => id && state.values.viewMode[id] || settings.values.defaultViewMode;
|
|
150
|
+
const setViewMode = (id, viewMode) => state.values.viewMode[id] = viewMode;
|
|
176
151
|
return {
|
|
177
152
|
meta: meta_default,
|
|
178
153
|
ready: async (plugins) => {
|
|
@@ -224,7 +199,7 @@ var MarkdownPlugin = () => {
|
|
|
224
199
|
});
|
|
225
200
|
markdownExtensionPlugins(plugins).forEach((plugin) => {
|
|
226
201
|
const { extensions } = plugin.provides.markdown;
|
|
227
|
-
state.values.extensionProviders
|
|
202
|
+
state.values.extensionProviders?.push(extensions);
|
|
228
203
|
});
|
|
229
204
|
},
|
|
230
205
|
provides: {
|
|
@@ -239,8 +214,7 @@ var MarkdownPlugin = () => {
|
|
|
239
214
|
ns: MARKDOWN_PLUGIN
|
|
240
215
|
}
|
|
241
216
|
],
|
|
242
|
-
icon:
|
|
243
|
-
iconSymbol: "ph--text-aa--regular",
|
|
217
|
+
icon: "ph--text-aa--regular",
|
|
244
218
|
graphProps: {
|
|
245
219
|
managesAutofocus: true
|
|
246
220
|
},
|
|
@@ -263,6 +237,17 @@ var MarkdownPlugin = () => {
|
|
|
263
237
|
TextType
|
|
264
238
|
]
|
|
265
239
|
},
|
|
240
|
+
space: {
|
|
241
|
+
onSpaceCreate: {
|
|
242
|
+
label: [
|
|
243
|
+
"create document label",
|
|
244
|
+
{
|
|
245
|
+
ns: MARKDOWN_PLUGIN
|
|
246
|
+
}
|
|
247
|
+
],
|
|
248
|
+
action: MarkdownAction.CREATE
|
|
249
|
+
}
|
|
250
|
+
},
|
|
266
251
|
graph: {
|
|
267
252
|
builder: (plugins) => {
|
|
268
253
|
const client = resolvePlugin(plugins, parseClientPlugin)?.provides.client;
|
|
@@ -309,8 +294,7 @@ var MarkdownPlugin = () => {
|
|
|
309
294
|
ns: MARKDOWN_PLUGIN
|
|
310
295
|
}
|
|
311
296
|
],
|
|
312
|
-
icon:
|
|
313
|
-
iconSymbol: "ph--text-aa--regular",
|
|
297
|
+
icon: "ph--text-aa--regular",
|
|
314
298
|
testId: "markdownPlugin.createObject"
|
|
315
299
|
}
|
|
316
300
|
}
|
|
@@ -382,7 +366,7 @@ var MarkdownPlugin = () => {
|
|
|
382
366
|
ns: MARKDOWN_PLUGIN
|
|
383
367
|
}
|
|
384
368
|
],
|
|
385
|
-
icon: (props) => /* @__PURE__ */
|
|
369
|
+
icon: (props) => /* @__PURE__ */ React3.createElement(TextAa, props),
|
|
386
370
|
intent: {
|
|
387
371
|
plugin: MARKDOWN_PLUGIN,
|
|
388
372
|
action: MarkdownAction.CREATE
|
|
@@ -397,12 +381,6 @@ var MarkdownPlugin = () => {
|
|
|
397
381
|
"content"
|
|
398
382
|
]) : void 0;
|
|
399
383
|
if (!accessor) {
|
|
400
|
-
log.warn("No accessor found for document content.", void 0, {
|
|
401
|
-
F: __dxlog_file,
|
|
402
|
-
L: 249,
|
|
403
|
-
S: void 0,
|
|
404
|
-
C: (f, a) => f(...a)
|
|
405
|
-
});
|
|
406
384
|
return (_) => 0;
|
|
407
385
|
}
|
|
408
386
|
const getStartPosition = (cursor) => {
|
|
@@ -420,58 +398,34 @@ var MarkdownPlugin = () => {
|
|
|
420
398
|
}
|
|
421
399
|
},
|
|
422
400
|
surface: {
|
|
423
|
-
component: ({ data, role
|
|
424
|
-
const doc = data.active instanceof DocumentType ? data.active : data.object instanceof DocumentType ? data.object : void 0;
|
|
401
|
+
component: ({ data, role }) => {
|
|
425
402
|
switch (role) {
|
|
426
403
|
case "section":
|
|
427
404
|
case "article": {
|
|
428
|
-
|
|
429
|
-
|
|
430
|
-
|
|
431
|
-
|
|
432
|
-
|
|
433
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
});
|
|
439
|
-
} else if (isEditorModel(data.object)) {
|
|
440
|
-
return /* @__PURE__ */ React5.createElement(MarkdownEditor, {
|
|
441
|
-
id: data.object.id,
|
|
442
|
-
role,
|
|
443
|
-
coordinate: data.coordinate,
|
|
444
|
-
initialValue: data.object.text,
|
|
445
|
-
extensionProviders: state.values.extensionProviders,
|
|
446
|
-
inputMode: settings.values.editorInputMode,
|
|
447
|
-
toolbar: settings.values.toolbar,
|
|
448
|
-
scrollPastEnd: true,
|
|
449
|
-
viewMode: getViewMode(data.object.id),
|
|
450
|
-
onViewModeChange: setViewMode
|
|
451
|
-
});
|
|
452
|
-
}
|
|
453
|
-
break;
|
|
454
|
-
}
|
|
455
|
-
case "card": {
|
|
456
|
-
if (isObject(data.content) && typeof data.content.id === "string" && data.content.object instanceof DocumentType) {
|
|
457
|
-
const cardProps = {
|
|
458
|
-
...props,
|
|
459
|
-
item: {
|
|
460
|
-
id: data.content.id,
|
|
461
|
-
object: data.content.object,
|
|
462
|
-
color: typeof data.content.color === "string" ? data.content.color : void 0
|
|
463
|
-
}
|
|
464
|
-
};
|
|
465
|
-
return isTileComponentProps(cardProps) ? /* @__PURE__ */ React5.createElement(DocumentCard, {
|
|
466
|
-
...cardProps,
|
|
467
|
-
settings: settings.values,
|
|
468
|
-
ref: forwardedRef
|
|
469
|
-
}) : null;
|
|
405
|
+
const doc = getDoc(data.active) ?? getDoc(data.object);
|
|
406
|
+
const { id, object } = isEditorModel(data.object) ? {
|
|
407
|
+
id: data.object.id,
|
|
408
|
+
object: data.object
|
|
409
|
+
} : doc ? {
|
|
410
|
+
id: fullyQualifiedId(doc),
|
|
411
|
+
object: doc
|
|
412
|
+
} : {};
|
|
413
|
+
if (!id || !object) {
|
|
414
|
+
return null;
|
|
470
415
|
}
|
|
471
|
-
|
|
416
|
+
return /* @__PURE__ */ React3.createElement(MarkdownContainer, {
|
|
417
|
+
id,
|
|
418
|
+
object,
|
|
419
|
+
role,
|
|
420
|
+
coordinate: data.coordinate,
|
|
421
|
+
settings: settings.values,
|
|
422
|
+
extensionProviders: state.values.extensionProviders,
|
|
423
|
+
viewMode: getViewMode(id),
|
|
424
|
+
onViewModeChange: setViewMode
|
|
425
|
+
});
|
|
472
426
|
}
|
|
473
427
|
case "settings": {
|
|
474
|
-
return data.plugin === meta_default.id ? /* @__PURE__ */
|
|
428
|
+
return data.plugin === meta_default.id ? /* @__PURE__ */ React3.createElement(MarkdownSettings, {
|
|
475
429
|
settings: settings.values
|
|
476
430
|
}) : null;
|
|
477
431
|
}
|
|
@@ -530,6 +484,7 @@ export {
|
|
|
530
484
|
TextType,
|
|
531
485
|
src_default as default,
|
|
532
486
|
getFallbackName,
|
|
487
|
+
isEditorModel,
|
|
533
488
|
isMarkdownProperties,
|
|
534
489
|
markdownExtensionPlugins,
|
|
535
490
|
serializer,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../../../src/MarkdownPlugin.tsx", "../../../src/components/index.ts", "../../../src/components/
|
|
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 { log } from '@dxos/log';\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 {\n createDocAccessor,\n fullyQualifiedId,\n getRangeFromCursor,\n isSpace,\n loadObjectReferences,\n} 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 folding: false,\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 thread: {\n predicate: (obj) => obj instanceof DocumentType,\n createSort: (doc: DocumentType) => {\n const accessor = doc.content ? createDocAccessor(doc.content, ['content']) : undefined;\n\n if (!accessor) {\n log.warn('No accessor found for document content.');\n return (_) => 0;\n }\n\n const getStartPosition = (cursor: string | undefined) => {\n const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;\n return range?.start ?? Number.MAX_SAFE_INTEGER;\n };\n\n return (anchorA: string | undefined, anchorB: string | undefined): number => {\n if (anchorA === undefined || anchorB === undefined) {\n return 0;\n }\n const posA = getStartPosition(anchorA);\n const posB = getStartPosition(anchorB);\n return posA - posB;\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 scrollPastEnd\n viewMode={getViewMode(fullyQualifiedId(doc))}\n onViewModeChange={setViewMode}\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 scrollPastEnd\n viewMode={getViewMode(data.object.id)}\n onViewModeChange={setViewMode}\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": "
|
|
6
|
-
"names": ["TextAa", "React", "
|
|
3
|
+
"sources": ["../../../src/MarkdownPlugin.tsx", "../../../src/components/index.ts", "../../../src/components/MarkdownSettings.tsx", "../../../src/translations.ts", "../../../src/index.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { TextAa } from '@phosphor-icons/react';\nimport React from 'react';\n\nimport {\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 {\n createDocAccessor,\n fullyQualifiedId,\n getRangeFromCursor,\n isSpace,\n loadObjectReferences,\n} from '@dxos/react-client/echo';\nimport {\n type EditorInputMode,\n type EditorViewMode,\n EditorViewModes,\n translations as editorTranslations,\n} from '@dxos/react-ui-editor';\n\nimport { MarkdownContainer, MarkdownSettings } from './components';\nimport meta, { MARKDOWN_PLUGIN } from './meta';\nimport translations from './translations';\nimport { DocumentType, isEditorModel, 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// TODO(burdon): Normalize active/object.\nconst getDoc = (object: any) => (object instanceof DocumentType ? object : undefined);\n\nexport const MarkdownPlugin = (): PluginDefinition<MarkdownPluginProvides> => {\n const settings = new LocalStorageStore<MarkdownSettingsProps>(MARKDOWN_PLUGIN, {\n defaultViewMode: 'preview',\n toolbar: true,\n folding: false,\n experimental: false,\n });\n\n const state = new LocalStorageStore<MarkdownPluginState>(MARKDOWN_PLUGIN, { extensionProviders: [], viewMode: {} });\n\n const getViewMode = (id: string) => (id && state.values.viewMode[id]) || settings.values.defaultViewMode;\n const setViewMode = (id: string, viewMode: EditorViewMode) => (state.values.viewMode[id] = viewMode);\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: '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 space: {\n onSpaceCreate: {\n label: ['create document label', { ns: MARKDOWN_PLUGIN }],\n action: MarkdownAction.CREATE,\n },\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: '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 thread: {\n predicate: (obj) => obj instanceof DocumentType,\n createSort: (doc: DocumentType) => {\n const accessor = doc.content ? createDocAccessor(doc.content, ['content']) : undefined;\n if (!accessor) {\n return (_) => 0;\n }\n\n const getStartPosition = (cursor: string | undefined) => {\n const range = cursor ? getRangeFromCursor(accessor, cursor) : undefined;\n return range?.start ?? Number.MAX_SAFE_INTEGER;\n };\n\n return (anchorA: string | undefined, anchorB: string | undefined): number => {\n if (anchorA === undefined || anchorB === undefined) {\n return 0;\n }\n const posA = getStartPosition(anchorA);\n const posB = getStartPosition(anchorB);\n return posA - posB;\n };\n },\n },\n surface: {\n component: ({ data, role }) => {\n switch (role) {\n case 'section':\n case 'article': {\n // TODO(burdon): Normalize types (from FilesPlugin).\n const doc = getDoc(data.active) ?? getDoc(data.object);\n const { id, object } = isEditorModel(data.object)\n ? { id: data.object.id, object: data.object }\n : doc\n ? { id: fullyQualifiedId(doc), object: doc }\n : {};\n\n if (!id || !object) {\n return null;\n }\n\n return (\n <MarkdownContainer\n id={id}\n object={object}\n role={role}\n coordinate={data.coordinate as LayoutCoordinate}\n settings={settings.values}\n extensionProviders={state.values.extensionProviders}\n viewMode={getViewMode(id)}\n onViewModeChange={setViewMode}\n />\n );\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 from 'react';\n\nexport * from './MarkdownSettings';\n\nexport const MarkdownContainer = React.lazy(() => import('./MarkdownContainer'));\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
|
+
"names": ["TextAa", "React", "parseIntentPlugin", "resolvePlugin", "LayoutAction", "NavigationAction", "create", "LocalStorageStore", "parseClientPlugin", "createExtension", "isActionGroup", "SpaceAction", "CollectionType", "createDocAccessor", "fullyQualifiedId", "getRangeFromCursor", "isSpace", "loadObjectReferences", "EditorViewModes", "translations", "editorTranslations", "React", "React", "SettingsValue", "Input", "Select", "useTranslation", "EditorInputModes", "EditorViewModes", "MarkdownSettings", "settings", "t", "useTranslation", "MARKDOWN_PLUGIN", "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", "MarkdownContainer", "React", "lazy", "MARKDOWN_PLUGIN", "getDoc", "object", "DocumentType", "undefined", "MarkdownPlugin", "settings", "LocalStorageStore", "MARKDOWN_PLUGIN", "defaultViewMode", "toolbar", "folding", "experimental", "state", "extensionProviders", "viewMode", "getViewMode", "id", "values", "setViewMode", "meta", "ready", "plugins", "prop", "key", "storageKey", "type", "enum", "allowUndefined", "bool", "string", "json", "markdownExtensionPlugins", "forEach", "plugin", "extensions", "provides", "markdown", "push", "metadata", "records", "typename", "label", "name", "fallbackName", "placeholder", "ns", "icon", "graphProps", "managesAutofocus", "loadReferences", "doc", "loadObjectReferences", "content", "threads", "serializer", "translations", "editorTranslations", "echo", "schema", "TextType", "space", "onSpaceCreate", "action", "MarkdownAction", "CREATE", "graph", "builder", "client", "resolvePlugin", "parseClientPlugin", "dispatch", "parseIntentPlugin", "intent", "createExtension", "filter", "node", "isActionGroup", "startsWith", "SpaceAction", "ADD_OBJECT", "actions", "split", "at", "spaceId", "objectId", "spaces", "get", "find", "db", "getObjectById", "target", "data", "NavigationAction", "OPEN", "properties", "testId", "inputType", "outputType", "serialize", "deserialize", "ancestors", "isSpace", "findLast", "ancestor", "CollectionType", "result", "stack", "creators", "props", "React", "TextAa", "thread", "predicate", "obj", "createSort", "accessor", "createDocAccessor", "_", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "anchorA", "anchorB", "posA", "posB", "surface", "component", "role", "active", "isEditorModel", "fullyQualifiedId", "MarkdownContainer", "coordinate", "onViewModeChange", "MarkdownSettings", "resolver", "create", "intents", "LayoutAction", "SCROLL_INTO_VIEW", "SET_VIEW_MODE", "EditorViewModes", "includes", "MarkdownPlugin"]
|
|
7
7
|
}
|