@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.
Files changed (102) hide show
  1. package/dist/lib/browser/{DocumentCard-RKENHCNE.mjs → DocumentCard-2P4EICBA.mjs} +3 -3
  2. package/dist/lib/browser/DocumentEditor-GPWV3VN3.mjs +11 -0
  3. package/dist/lib/browser/{MarkdownEditor-5EUT7P66.mjs → MarkdownEditor-EKJJQEFL.mjs} +3 -3
  4. package/dist/lib/browser/{chunk-2SJN46PA.mjs → chunk-4GGD6YJO.mjs} +5 -2
  5. package/dist/lib/browser/chunk-4GGD6YJO.mjs.map +7 -0
  6. package/dist/lib/browser/{chunk-QIO7ZONH.mjs → chunk-7AF2JLK4.mjs} +18 -18
  7. package/dist/lib/browser/chunk-7AF2JLK4.mjs.map +7 -0
  8. package/dist/lib/browser/{chunk-N7FS4CK2.mjs → chunk-CQJL4G4X.mjs} +2 -2
  9. package/dist/lib/browser/chunk-CQJL4G4X.mjs.map +7 -0
  10. package/dist/lib/browser/{chunk-AFWT6Z7B.mjs → chunk-RL7QY322.mjs} +2 -2
  11. package/dist/lib/browser/{chunk-AVGUYNPR.mjs → chunk-VUN4QKTT.mjs} +53 -65
  12. package/dist/lib/browser/chunk-VUN4QKTT.mjs.map +7 -0
  13. package/dist/lib/browser/index.mjs +22 -29
  14. package/dist/lib/browser/index.mjs.map +3 -3
  15. package/dist/lib/browser/meta.json +1 -1
  16. package/dist/lib/browser/meta.mjs +1 -1
  17. package/dist/lib/browser/types/index.mjs +2 -2
  18. package/dist/lib/node/{DocumentCard-ECPKHJT7.cjs → DocumentCard-EHJDDSRY.cjs} +8 -8
  19. package/dist/lib/node/{DocumentCard-ECPKHJT7.cjs.map → DocumentCard-EHJDDSRY.cjs.map} +2 -2
  20. package/dist/lib/node/{DocumentEditor-QPH26VQZ.cjs → DocumentEditor-I5GCRBKU.cjs} +9 -9
  21. package/dist/lib/node/DocumentEditor-I5GCRBKU.cjs.map +7 -0
  22. package/dist/lib/node/{MarkdownEditor-ZD4W4UJ6.cjs → MarkdownEditor-UE23H75V.cjs} +8 -8
  23. package/dist/lib/node/MarkdownEditor-UE23H75V.cjs.map +7 -0
  24. package/dist/lib/node/{chunk-2T7LIVPT.cjs → chunk-7XIBNEI7.cjs} +51 -59
  25. package/dist/lib/node/chunk-7XIBNEI7.cjs.map +7 -0
  26. package/dist/lib/node/{chunk-5ZWOR7JF.cjs → chunk-Q4ZSCBQE.cjs} +6 -6
  27. package/dist/lib/node/{chunk-KDXONMFH.cjs → chunk-RVGN72IX.cjs} +24 -24
  28. package/dist/lib/node/chunk-RVGN72IX.cjs.map +7 -0
  29. package/dist/lib/node/{chunk-LPD4NOTH.cjs → chunk-TGMR2CKU.cjs} +18 -5
  30. package/dist/lib/node/chunk-TGMR2CKU.cjs.map +7 -0
  31. package/dist/lib/node/{chunk-RVNU7MRZ.cjs → chunk-VWQH4WC2.cjs} +6 -6
  32. package/dist/lib/node/chunk-VWQH4WC2.cjs.map +7 -0
  33. package/dist/lib/node/index.cjs +63 -70
  34. package/dist/lib/node/index.cjs.map +3 -3
  35. package/dist/lib/node/meta.cjs +3 -3
  36. package/dist/lib/node/meta.cjs.map +1 -1
  37. package/dist/lib/node/meta.json +1 -1
  38. package/dist/lib/node/types/index.cjs +5 -5
  39. package/dist/lib/node/types/index.cjs.map +1 -1
  40. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  41. package/dist/types/src/components/DocumentEditor.d.ts.map +1 -1
  42. package/dist/types/src/components/MarkdownEditor.d.ts +1 -1
  43. package/dist/types/src/components/MarkdownEditor.d.ts.map +1 -1
  44. package/dist/types/src/meta.d.ts +4 -1
  45. package/dist/types/src/meta.d.ts.map +1 -1
  46. package/dist/types/src/types/document.d.ts +0 -2
  47. package/dist/types/src/types/document.d.ts.map +1 -1
  48. package/dist/types/src/types/types.d.ts +9 -8
  49. package/dist/types/src/types/types.d.ts.map +1 -1
  50. package/package.json +34 -38
  51. package/src/MarkdownPlugin.tsx +10 -17
  52. package/src/components/DocumentEditor.tsx +18 -23
  53. package/src/components/MarkdownEditor.tsx +43 -15
  54. package/src/meta.tsx +5 -1
  55. package/src/types/types.ts +7 -9
  56. package/dist/lib/browser/DocumentEditor-JZI4663Q.mjs +0 -11
  57. package/dist/lib/browser/chunk-2SJN46PA.mjs.map +0 -7
  58. package/dist/lib/browser/chunk-AVGUYNPR.mjs.map +0 -7
  59. package/dist/lib/browser/chunk-N7FS4CK2.mjs.map +0 -7
  60. package/dist/lib/browser/chunk-QIO7ZONH.mjs.map +0 -7
  61. package/dist/lib/node/DocumentEditor-QPH26VQZ.cjs.map +0 -7
  62. package/dist/lib/node/MarkdownEditor-ZD4W4UJ6.cjs.map +0 -7
  63. package/dist/lib/node/chunk-2T7LIVPT.cjs.map +0 -7
  64. package/dist/lib/node/chunk-KDXONMFH.cjs.map +0 -7
  65. package/dist/lib/node/chunk-LPD4NOTH.cjs.map +0 -7
  66. package/dist/lib/node/chunk-RVNU7MRZ.cjs.map +0 -7
  67. package/dist/lib/node-esm/DocumentCard-RHVY4Z6L.mjs +0 -12
  68. package/dist/lib/node-esm/DocumentCard-RHVY4Z6L.mjs.map +0 -7
  69. package/dist/lib/node-esm/DocumentEditor-6F5ONTIO.mjs +0 -12
  70. package/dist/lib/node-esm/DocumentEditor-6F5ONTIO.mjs.map +0 -7
  71. package/dist/lib/node-esm/MarkdownEditor-OS7YG6MA.mjs +0 -11
  72. package/dist/lib/node-esm/MarkdownEditor-OS7YG6MA.mjs.map +0 -7
  73. package/dist/lib/node-esm/chunk-2BGTVWHN.mjs +0 -18
  74. package/dist/lib/node-esm/chunk-2BGTVWHN.mjs.map +0 -7
  75. package/dist/lib/node-esm/chunk-3CHPA7Y7.mjs +0 -40
  76. package/dist/lib/node-esm/chunk-3CHPA7Y7.mjs.map +0 -7
  77. package/dist/lib/node-esm/chunk-NZ4H6J5H.mjs +0 -165
  78. package/dist/lib/node-esm/chunk-NZ4H6J5H.mjs.map +0 -7
  79. package/dist/lib/node-esm/chunk-OE3CMI5X.mjs +0 -87
  80. package/dist/lib/node-esm/chunk-OE3CMI5X.mjs.map +0 -7
  81. package/dist/lib/node-esm/chunk-QARGBUBS.mjs +0 -221
  82. package/dist/lib/node-esm/chunk-QARGBUBS.mjs.map +0 -7
  83. package/dist/lib/node-esm/chunk-RO5FEVW6.mjs +0 -119
  84. package/dist/lib/node-esm/chunk-RO5FEVW6.mjs.map +0 -7
  85. package/dist/lib/node-esm/index.mjs +0 -540
  86. package/dist/lib/node-esm/index.mjs.map +0 -7
  87. package/dist/lib/node-esm/meta.json +0 -1
  88. package/dist/lib/node-esm/meta.mjs +0 -10
  89. package/dist/lib/node-esm/meta.mjs.map +0 -7
  90. package/dist/lib/node-esm/types/index.mjs +0 -13
  91. package/dist/lib/node-esm/types/index.mjs.map +0 -7
  92. package/dist/types/src/hooks/index.d.ts +0 -2
  93. package/dist/types/src/hooks/index.d.ts.map +0 -1
  94. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +0 -6
  95. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +0 -1
  96. package/src/hooks/index.ts +0 -5
  97. package/src/hooks/useSelectCurrentThread.tsx +0 -46
  98. /package/dist/lib/browser/{DocumentCard-RKENHCNE.mjs.map → DocumentCard-2P4EICBA.mjs.map} +0 -0
  99. /package/dist/lib/browser/{DocumentEditor-JZI4663Q.mjs.map → DocumentEditor-GPWV3VN3.mjs.map} +0 -0
  100. /package/dist/lib/browser/{MarkdownEditor-5EUT7P66.mjs.map → MarkdownEditor-EKJJQEFL.mjs.map} +0 -0
  101. /package/dist/lib/browser/{chunk-AFWT6Z7B.mjs.map → chunk-RL7QY322.mjs.map} +0 -0
  102. /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