@dxos/plugin-markdown 0.8.4-main.dedc0f3 → 0.8.4-main.ead640a

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 (137) hide show
  1. package/dist/lib/browser/{MarkdownCard-JLUQITYK.mjs → MarkdownCard-AGWOTODZ.mjs} +20 -17
  2. package/dist/lib/browser/MarkdownCard-AGWOTODZ.mjs.map +7 -0
  3. package/dist/lib/browser/{MarkdownContainer-JW7TRDSA.mjs → MarkdownContainer-MV2UNAUV.mjs} +54 -58
  4. package/dist/lib/browser/MarkdownContainer-MV2UNAUV.mjs.map +7 -0
  5. package/dist/lib/browser/{anchor-sort-E33BSTYF.mjs → anchor-sort-YWJI3BKT.mjs} +4 -4
  6. package/dist/lib/browser/{anchor-sort-E33BSTYF.mjs.map → anchor-sort-YWJI3BKT.mjs.map} +1 -1
  7. package/dist/lib/browser/{app-graph-serializer-OX62DNPT.mjs → app-graph-serializer-KYDFCUOW.mjs} +7 -7
  8. package/dist/lib/browser/app-graph-serializer-KYDFCUOW.mjs.map +7 -0
  9. package/dist/lib/browser/{blueprint-definition-5YKFUHRU.mjs → blueprint-definition-BHRMFZAC.mjs} +3 -3
  10. package/dist/lib/browser/{chunk-LAVZ2W6X.mjs → chunk-6KU5DKP7.mjs} +6 -5
  11. package/dist/lib/browser/chunk-6KU5DKP7.mjs.map +7 -0
  12. package/dist/lib/browser/{chunk-F6JJLKLN.mjs → chunk-HBBEHOP3.mjs} +12 -8
  13. package/dist/lib/browser/chunk-HBBEHOP3.mjs.map +7 -0
  14. package/dist/lib/browser/{chunk-Z7P6JGGW.mjs → chunk-O6XUPW6S.mjs} +2 -2
  15. package/dist/lib/browser/{chunk-BEE7VQPU.mjs → chunk-XMT6PMU5.mjs} +6 -5
  16. package/dist/lib/browser/chunk-XMT6PMU5.mjs.map +7 -0
  17. package/dist/lib/browser/chunk-Z5PDJNBV.mjs +22 -0
  18. package/dist/lib/browser/index.mjs +9 -8
  19. package/dist/lib/browser/index.mjs.map +3 -3
  20. package/dist/lib/browser/{intent-resolver-WDDH56JC.mjs → intent-resolver-XHVCZZHU.mjs} +5 -5
  21. package/dist/lib/browser/intent-resolver-XHVCZZHU.mjs.map +7 -0
  22. package/dist/lib/browser/meta.json +1 -1
  23. package/dist/lib/browser/{react-surface-L3NTMD4D.mjs → react-surface-3A2GO3BN.mjs} +7 -7
  24. package/dist/lib/browser/{react-surface-L3NTMD4D.mjs.map → react-surface-3A2GO3BN.mjs.map} +1 -1
  25. package/dist/lib/browser/{settings-AABBTB4Q.mjs → settings-XY265Y2Q.mjs} +4 -4
  26. package/dist/lib/browser/{settings-AABBTB4Q.mjs.map → settings-XY265Y2Q.mjs.map} +1 -1
  27. package/dist/lib/browser/{state-FTHQQX7V.mjs → state-6QODXCSZ.mjs} +3 -3
  28. package/dist/lib/browser/{state-FTHQQX7V.mjs.map → state-6QODXCSZ.mjs.map} +1 -1
  29. package/dist/lib/browser/{toolkit-2AJTHG74.mjs → toolkit-YA65QX2S.mjs} +15 -13
  30. package/dist/lib/browser/toolkit-YA65QX2S.mjs.map +7 -0
  31. package/dist/lib/browser/types/index.mjs +1 -1
  32. package/dist/lib/node-esm/{MarkdownCard-XL5EVSJ7.mjs → MarkdownCard-B2IWTFOC.mjs} +20 -17
  33. package/dist/lib/node-esm/MarkdownCard-B2IWTFOC.mjs.map +7 -0
  34. package/dist/lib/node-esm/{MarkdownContainer-HRGQXIXP.mjs → MarkdownContainer-J2R3DLCQ.mjs} +54 -58
  35. package/dist/lib/node-esm/MarkdownContainer-J2R3DLCQ.mjs.map +7 -0
  36. package/dist/lib/node-esm/{anchor-sort-ALP2NH24.mjs → anchor-sort-FCRYL2FX.mjs} +4 -4
  37. package/dist/lib/node-esm/{anchor-sort-ALP2NH24.mjs.map → anchor-sort-FCRYL2FX.mjs.map} +1 -1
  38. package/dist/lib/node-esm/{app-graph-serializer-56TD3BMX.mjs → app-graph-serializer-FAUQM3BH.mjs} +7 -7
  39. package/dist/lib/node-esm/app-graph-serializer-FAUQM3BH.mjs.map +7 -0
  40. package/dist/lib/node-esm/{blueprint-definition-GVW67KGV.mjs → blueprint-definition-XYFKMIDR.mjs} +3 -3
  41. package/dist/lib/node-esm/chunk-7RDNIMTF.mjs +24 -0
  42. package/dist/lib/node-esm/{chunk-DVK63TD3.mjs → chunk-FVI7LPC3.mjs} +12 -8
  43. package/dist/lib/node-esm/chunk-FVI7LPC3.mjs.map +7 -0
  44. package/dist/lib/node-esm/{chunk-FXILAQ5F.mjs → chunk-FWZKC6X5.mjs} +6 -5
  45. package/dist/lib/node-esm/chunk-FWZKC6X5.mjs.map +7 -0
  46. package/dist/lib/node-esm/{chunk-J7A6TUB2.mjs → chunk-XO3IEQJE.mjs} +2 -2
  47. package/dist/lib/node-esm/{chunk-O6EXWGGS.mjs → chunk-ZBXV4ON7.mjs} +6 -5
  48. package/dist/lib/node-esm/chunk-ZBXV4ON7.mjs.map +7 -0
  49. package/dist/lib/node-esm/index.mjs +9 -8
  50. package/dist/lib/node-esm/index.mjs.map +3 -3
  51. package/dist/lib/node-esm/{intent-resolver-2I5HKCUU.mjs → intent-resolver-7A2EXGZQ.mjs} +5 -5
  52. package/dist/lib/node-esm/intent-resolver-7A2EXGZQ.mjs.map +7 -0
  53. package/dist/lib/node-esm/meta.json +1 -1
  54. package/dist/lib/node-esm/{react-surface-YZSZFR5D.mjs → react-surface-RCLL5WVQ.mjs} +7 -7
  55. package/dist/lib/node-esm/{react-surface-YZSZFR5D.mjs.map → react-surface-RCLL5WVQ.mjs.map} +1 -1
  56. package/dist/lib/node-esm/{settings-CXGR6DH4.mjs → settings-H3UDD3KO.mjs} +4 -4
  57. package/dist/lib/node-esm/{settings-CXGR6DH4.mjs.map → settings-H3UDD3KO.mjs.map} +1 -1
  58. package/dist/lib/node-esm/{state-NWMQ3XAI.mjs → state-W3PECOJX.mjs} +3 -3
  59. package/dist/lib/node-esm/{state-NWMQ3XAI.mjs.map → state-W3PECOJX.mjs.map} +1 -1
  60. package/dist/lib/node-esm/{toolkit-RC44I2MI.mjs → toolkit-HSIKUGNK.mjs} +15 -13
  61. package/dist/lib/node-esm/toolkit-HSIKUGNK.mjs.map +7 -0
  62. package/dist/lib/node-esm/types/index.mjs +1 -1
  63. package/dist/types/src/MarkdownPlugin.d.ts +1 -1
  64. package/dist/types/src/MarkdownPlugin.d.ts.map +1 -1
  65. package/dist/types/src/capabilities/artifact-definition.d.ts.map +1 -1
  66. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
  67. package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
  68. package/dist/types/src/components/MarkdownCard/MarkdownCard.d.ts.map +1 -1
  69. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts +0 -1
  70. package/dist/types/src/components/MarkdownCard/MarkdownCard.stories.d.ts.map +1 -1
  71. package/dist/types/src/components/MarkdownContainer.d.ts.map +1 -1
  72. package/dist/types/src/components/MarkdownContainer.stories.d.ts +4 -4
  73. package/dist/types/src/components/MarkdownContainer.stories.d.ts.map +1 -1
  74. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts +4 -4
  75. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.d.ts.map +1 -1
  76. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts +1 -1
  77. package/dist/types/src/components/MarkdownEditor/MarkdownEditor.stories.d.ts.map +1 -1
  78. package/dist/types/src/components/Suggestions.stories.d.ts +1 -2
  79. package/dist/types/src/components/Suggestions.stories.d.ts.map +1 -1
  80. package/dist/types/src/components/Toolbar.stories.d.ts +1 -1
  81. package/dist/types/src/components/Toolbar.stories.d.ts.map +1 -1
  82. package/dist/types/src/functions/diff.d.ts.map +1 -1
  83. package/dist/types/src/functions/open.d.ts.map +1 -1
  84. package/dist/types/src/hooks/useSelectCurrentThread.d.ts +1 -1
  85. package/dist/types/src/hooks/useSelectCurrentThread.d.ts.map +1 -1
  86. package/dist/types/src/types/Markdown.d.ts +5 -3
  87. package/dist/types/src/types/Markdown.d.ts.map +1 -1
  88. package/dist/types/src/types/MarkdownAction.d.ts +2 -1
  89. package/dist/types/src/types/MarkdownAction.d.ts.map +1 -1
  90. package/dist/types/src/util.d.ts +1 -1
  91. package/dist/types/src/util.d.ts.map +1 -1
  92. package/dist/types/tsconfig.tsbuildinfo +1 -1
  93. package/package.json +54 -54
  94. package/src/MarkdownPlugin.tsx +98 -98
  95. package/src/capabilities/app-graph-serializer.ts +2 -2
  96. package/src/capabilities/artifact-definition.ts +3 -2
  97. package/src/capabilities/intent-resolver.ts +2 -1
  98. package/src/capabilities/toolkit.ts +9 -7
  99. package/src/components/MarkdownCard/MarkdownCard.stories.tsx +3 -6
  100. package/src/components/MarkdownCard/MarkdownCard.tsx +17 -16
  101. package/src/components/MarkdownContainer.stories.tsx +42 -33
  102. package/src/components/MarkdownContainer.tsx +16 -14
  103. package/src/components/MarkdownEditor/MarkdownEditor.stories.tsx +11 -10
  104. package/src/components/MarkdownEditor/MarkdownEditor.tsx +35 -35
  105. package/src/components/Suggestions.stories.tsx +28 -27
  106. package/src/components/Toolbar.stories.tsx +5 -5
  107. package/src/extensions.tsx +3 -3
  108. package/src/functions/diff.ts +4 -2
  109. package/src/functions/open.ts +4 -2
  110. package/src/hooks/useSelectCurrentThread.tsx +2 -2
  111. package/src/types/Markdown.ts +4 -2
  112. package/src/types/MarkdownAction.ts +1 -1
  113. package/src/util.tsx +8 -2
  114. package/dist/lib/browser/MarkdownCard-JLUQITYK.mjs.map +0 -7
  115. package/dist/lib/browser/MarkdownContainer-JW7TRDSA.mjs.map +0 -7
  116. package/dist/lib/browser/app-graph-serializer-OX62DNPT.mjs.map +0 -7
  117. package/dist/lib/browser/chunk-BEE7VQPU.mjs.map +0 -7
  118. package/dist/lib/browser/chunk-F6JJLKLN.mjs.map +0 -7
  119. package/dist/lib/browser/chunk-LAVZ2W6X.mjs.map +0 -7
  120. package/dist/lib/browser/chunk-SUOK6YMI.mjs +0 -22
  121. package/dist/lib/browser/intent-resolver-WDDH56JC.mjs.map +0 -7
  122. package/dist/lib/browser/toolkit-2AJTHG74.mjs.map +0 -7
  123. package/dist/lib/node-esm/MarkdownCard-XL5EVSJ7.mjs.map +0 -7
  124. package/dist/lib/node-esm/MarkdownContainer-HRGQXIXP.mjs.map +0 -7
  125. package/dist/lib/node-esm/app-graph-serializer-56TD3BMX.mjs.map +0 -7
  126. package/dist/lib/node-esm/chunk-DVK63TD3.mjs.map +0 -7
  127. package/dist/lib/node-esm/chunk-FXILAQ5F.mjs.map +0 -7
  128. package/dist/lib/node-esm/chunk-JC2YWB5D.mjs +0 -24
  129. package/dist/lib/node-esm/chunk-O6EXWGGS.mjs.map +0 -7
  130. package/dist/lib/node-esm/intent-resolver-2I5HKCUU.mjs.map +0 -7
  131. package/dist/lib/node-esm/toolkit-RC44I2MI.mjs.map +0 -7
  132. /package/dist/lib/browser/{blueprint-definition-5YKFUHRU.mjs.map → blueprint-definition-BHRMFZAC.mjs.map} +0 -0
  133. /package/dist/lib/browser/{chunk-Z7P6JGGW.mjs.map → chunk-O6XUPW6S.mjs.map} +0 -0
  134. /package/dist/lib/browser/{chunk-SUOK6YMI.mjs.map → chunk-Z5PDJNBV.mjs.map} +0 -0
  135. /package/dist/lib/node-esm/{blueprint-definition-GVW67KGV.mjs.map → blueprint-definition-XYFKMIDR.mjs.map} +0 -0
  136. /package/dist/lib/node-esm/{chunk-JC2YWB5D.mjs.map → chunk-7RDNIMTF.mjs.map} +0 -0
  137. /package/dist/lib/node-esm/{chunk-J7A6TUB2.mjs.map → chunk-XO3IEQJE.mjs.map} +0 -0
@@ -1,23 +1,23 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
- getAbstract,
3
+ getContentSnippet,
4
4
  getFallbackName
5
- } from "./chunk-O6EXWGGS.mjs";
5
+ } from "./chunk-ZBXV4ON7.mjs";
6
6
  import {
7
7
  Markdown_exports
8
- } from "./chunk-FXILAQ5F.mjs";
8
+ } from "./chunk-FWZKC6X5.mjs";
9
9
  import {
10
10
  meta
11
11
  } from "./chunk-VCG2U522.mjs";
12
12
 
13
13
  // src/components/MarkdownCard/MarkdownCard.tsx
14
14
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
15
- import { pipe } from "effect";
15
+ import * as Function from "effect/Function";
16
16
  import React, { useCallback } from "react";
17
17
  import { LayoutAction, chain, createIntent, useIntentDispatcher } from "@dxos/app-framework";
18
18
  import { Obj } from "@dxos/echo";
19
19
  import { fullyQualifiedId } from "@dxos/react-client/echo";
20
- import { Button, Icon, useTranslation } from "@dxos/react-ui";
20
+ import { IconButton, useTranslation } from "@dxos/react-ui";
21
21
  import { Card } from "@dxos/react-ui-stack";
22
22
  import { DataType } from "@dxos/schema";
23
23
  var getTitle = (subject, fallback) => {
@@ -29,9 +29,9 @@ var getTitle = (subject, fallback) => {
29
29
  };
30
30
  var getSnippet = (subject, fallback) => {
31
31
  if (Obj.instanceOf(Markdown_exports.Document, subject)) {
32
- return getAbstract(subject.content?.target?.content ?? fallback);
32
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
33
33
  } else if (Obj.instanceOf(DataType.Text, subject)) {
34
- return getAbstract(subject.content);
34
+ return getContentSnippet(subject.content ?? fallback);
35
35
  }
36
36
  };
37
37
  var MarkdownCard = ({ subject, role }) => {
@@ -40,7 +40,7 @@ var MarkdownCard = ({ subject, role }) => {
40
40
  const { dispatchPromise: dispatch } = useIntentDispatcher();
41
41
  const { t } = useTranslation(meta.id);
42
42
  const snippet = getSnippet(subject, t("fallback abstract"));
43
- const handleNavigate = useCallback(() => dispatch(pipe(createIntent(LayoutAction.UpdatePopover, {
43
+ const handleNavigate = useCallback(() => dispatch(Function.pipe(createIntent(LayoutAction.UpdatePopover, {
44
44
  part: "popover",
45
45
  subject: null,
46
46
  options: {
@@ -58,15 +58,18 @@ var MarkdownCard = ({ subject, role }) => {
58
58
  ]);
59
59
  return /* @__PURE__ */ React.createElement(Card.SurfaceRoot, {
60
60
  role
61
- }, /* @__PURE__ */ React.createElement(Card.Heading, null, getTitle(subject, t("fallback title"))), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
62
- classNames: "line-clamp-3 break-words col-span-2"
63
- }, snippet), role === "card--popover" && /* @__PURE__ */ React.createElement(Card.Chrome, null, /* @__PURE__ */ React.createElement(Button, {
64
- onClick: handleNavigate
65
- }, /* @__PURE__ */ React.createElement("span", {
61
+ }, /* @__PURE__ */ React.createElement(Card.Heading, {
62
+ classNames: "flex items-center"
63
+ }, getTitle(subject, t("fallback title")), /* @__PURE__ */ React.createElement("span", {
66
64
  className: "grow"
67
- }, t("navigate to document label")), /* @__PURE__ */ React.createElement(Icon, {
68
- icon: "ph--arrow-right--regular"
69
- }))));
65
+ }), /* @__PURE__ */ React.createElement(IconButton, {
66
+ iconOnly: true,
67
+ icon: "ph--arrow-right--regular",
68
+ label: t("navigate to document label"),
69
+ onClick: handleNavigate
70
+ })), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
71
+ classNames: "line-clamp-3 text-sm text-description"
72
+ }, snippet));
70
73
  } finally {
71
74
  _effect.f();
72
75
  }
@@ -78,4 +81,4 @@ export {
78
81
  MarkdownCard,
79
82
  MarkdownCard_default as default
80
83
  };
81
- //# sourceMappingURL=MarkdownCard-XL5EVSJ7.mjs.map
84
+ //# sourceMappingURL=MarkdownCard-B2IWTFOC.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/MarkdownCard/MarkdownCard.tsx", "../../../src/components/MarkdownCard/index.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Function from 'effect/Function';\nimport React, { useCallback } from 'react';\n\nimport { LayoutAction, chain, createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { type PreviewProps } from '@dxos/plugin-preview';\nimport { fullyQualifiedId } from '@dxos/react-client/echo';\nimport { IconButton, useTranslation } from '@dxos/react-ui';\nimport { Card } from '@dxos/react-ui-stack';\nimport { DataType } from '@dxos/schema';\n\nimport { meta } from '../../meta';\nimport { Markdown } from '../../types';\nimport { getContentSnippet, getFallbackName } from '../../util';\n\n// TODO(burdon): Factor out.\nconst getTitle = (subject: Markdown.Document | DataType.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n return subject.name ?? subject.fallbackName ?? getFallbackName(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(DataType.Text, subject)) {\n return getFallbackName(subject.content);\n }\n};\n\n// TODO(burdon): Factor out.\nconst getSnippet = (subject: Markdown.Document | DataType.Text, fallback: string) => {\n if (Obj.instanceOf(Markdown.Document, subject)) {\n return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);\n } else if (Obj.instanceOf(DataType.Text, subject)) {\n return getContentSnippet(subject.content ?? fallback);\n }\n};\n\nexport type MarkdownCardProps = PreviewProps<Markdown.Document | DataType.Text>;\n\nexport const MarkdownCard = ({ subject, role }: MarkdownCardProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const { t } = useTranslation(meta.id);\n const snippet = getSnippet(subject, t('fallback abstract'));\n\n // TODO(wittjosiah): Factor out so this component isn't dependent on the app framework.\n const handleNavigate = useCallback(\n () =>\n dispatch(\n Function.pipe(\n createIntent(LayoutAction.UpdatePopover, {\n part: 'popover',\n subject: null,\n options: { state: false, anchorId: '' },\n }),\n chain(LayoutAction.Open, { part: 'main', subject: [fullyQualifiedId(subject)] }),\n ),\n ),\n [dispatch, subject],\n );\n\n return (\n <Card.SurfaceRoot role={role}>\n <Card.Heading classNames='flex items-center'>\n {getTitle(subject, t('fallback title'))}\n <span className='grow' />\n <IconButton\n iconOnly\n icon='ph--arrow-right--regular'\n label={t('navigate to document label')}\n onClick={handleNavigate}\n />\n </Card.Heading>\n {snippet && <Card.Text classNames='line-clamp-3 text-sm text-description'>{snippet}</Card.Text>}\n </Card.SurfaceRoot>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { MarkdownCard } from './MarkdownCard';\n\nexport * from './MarkdownCard';\n\nexport default MarkdownCard;\n"],
5
+ "mappings": ";;;;;;;;;;;;;;AAIA,YAAYA,cAAc;AAC1B,OAAOC,SAASC,mBAAmB;AAEnC,SAASC,cAAcC,OAAOC,cAAcC,2BAA2B;AACvE,SAASC,WAAW;AAEpB,SAASC,wBAAwB;AACjC,SAASC,YAAYC,sBAAsB;AAC3C,SAASC,YAAY;AACrB,SAASC,gBAAgB;AAOzB,IAAMC,WAAW,CAACC,SAA4CC,aAAAA;AAC5D,MAAIC,IAAIC,WAAWC,iBAASC,UAAUL,OAAAA,GAAU;AAC9C,WAAOA,QAAQM,QAAQN,QAAQO,gBAAgBC,gBAAgBR,QAAQS,SAASC,QAAQD,WAAWR,QAAAA;EACrG,WAAWC,IAAIC,WAAWQ,SAASC,MAAMZ,OAAAA,GAAU;AACjD,WAAOQ,gBAAgBR,QAAQS,OAAO;EACxC;AACF;AAGA,IAAMI,aAAa,CAACb,SAA4CC,aAAAA;AAC9D,MAAIC,IAAIC,WAAWC,iBAASC,UAAUL,OAAAA,GAAU;AAC9C,WAAOE,IAAIY,eAAed,OAAAA,KAAYe,kBAAkBf,QAAQS,SAASC,QAAQD,WAAWR,QAAAA;EAC9F,WAAWC,IAAIC,WAAWQ,SAASC,MAAMZ,OAAAA,GAAU;AACjD,WAAOe,kBAAkBf,QAAQS,WAAWR,QAAAA;EAC9C;AACF;AAIO,IAAMe,eAAe,CAAC,EAAEhB,SAASiB,KAAI,MAAqB;;;AAC/D,UAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AACpC,UAAMC,UAAUZ,WAAWb,SAASqB,EAAE,mBAAA,CAAA;AAGtC,UAAMK,iBAAiBC,YACrB,MACER,SACWS,cACPC,aAAaC,aAAaC,eAAe;MACvCC,MAAM;MACNhC,SAAS;MACTiC,SAAS;QAAEC,OAAO;QAAOC,UAAU;MAAG;IACxC,CAAA,GACAC,MAAMN,aAAaO,MAAM;MAAEL,MAAM;MAAQhC,SAAS;QAACsC,iBAAiBtC,OAAAA;;IAAU,CAAA,CAAA,CAAA,GAGpF;MAACmB;MAAUnB;KAAQ;AAGrB,WACE,sBAAA,cAACuC,KAAKC,aAAW;MAACvB;OAChB,sBAAA,cAACsB,KAAKE,SAAO;MAACC,YAAW;OACtB3C,SAASC,SAASqB,EAAE,gBAAA,CAAA,GACrB,sBAAA,cAACsB,QAAAA;MAAKC,WAAU;QAChB,sBAAA,cAACC,YAAAA;MACCC,UAAAA;MACAC,MAAK;MACLC,OAAO3B,EAAE,4BAAA;MACT4B,SAASvB;SAGZD,WAAW,sBAAA,cAACc,KAAK3B,MAAI;MAAC8B,YAAW;OAAyCjB,OAAAA,CAAAA;;;;AAGjF;;;ACnEA,IAAA,uBAAeyB;",
6
+ "names": ["Function", "React", "useCallback", "LayoutAction", "chain", "createIntent", "useIntentDispatcher", "Obj", "fullyQualifiedId", "IconButton", "useTranslation", "Card", "DataType", "getTitle", "subject", "fallback", "Obj", "instanceOf", "Markdown", "Document", "name", "fallbackName", "getFallbackName", "content", "target", "DataType", "Text", "getSnippet", "getDescription", "getContentSnippet", "MarkdownCard", "role", "dispatchPromise", "dispatch", "useIntentDispatcher", "t", "useTranslation", "meta", "id", "snippet", "handleNavigate", "useCallback", "pipe", "createIntent", "LayoutAction", "UpdatePopover", "part", "options", "state", "anchorId", "chain", "Open", "fullyQualifiedId", "Card", "SurfaceRoot", "Heading", "classNames", "span", "className", "IconButton", "iconOnly", "icon", "label", "onClick", "MarkdownCard"]
7
+ }
@@ -1,16 +1,16 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import "./chunk-JC2YWB5D.mjs";
3
- import "./chunk-DVK63TD3.mjs";
2
+ import "./chunk-7RDNIMTF.mjs";
3
+ import "./chunk-FVI7LPC3.mjs";
4
4
  import {
5
5
  MarkdownCapabilities
6
6
  } from "./chunk-CB2R4YIY.mjs";
7
7
  import {
8
8
  getFallbackName,
9
9
  setFallbackName
10
- } from "./chunk-O6EXWGGS.mjs";
10
+ } from "./chunk-ZBXV4ON7.mjs";
11
11
  import {
12
12
  Markdown_exports
13
- } from "./chunk-FXILAQ5F.mjs";
13
+ } from "./chunk-FWZKC6X5.mjs";
14
14
  import {
15
15
  meta
16
16
  } from "./chunk-VCG2U522.mjs";
@@ -24,7 +24,8 @@ import { Capabilities, Surface, useAppGraph, useCapabilities as useCapabilities2
24
24
  import { DXN, Filter, Obj, Query, Type } from "@dxos/echo";
25
25
  import { ClientCapabilities } from "@dxos/plugin-client";
26
26
  import { SpaceCapabilities } from "@dxos/plugin-space";
27
- import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2, useQuery, useSpace } from "@dxos/react-client/echo";
27
+ import { useClient } from "@dxos/react-client";
28
+ import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2 } from "@dxos/react-client/echo";
28
29
  import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
29
30
  import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
30
31
  import { DataType } from "@dxos/schema";
@@ -40,7 +41,7 @@ import { useIdentity } from "@dxos/react-client/halo";
40
41
  import { Icon, ThemeProvider } from "@dxos/react-ui";
41
42
  import { Cursor, EditorView, InputModeExtensions, createDataExtensions, decorateMarkdown, documentId, folding, formattingKeymap, linkTooltip, listener, preview, selectionState, typewriter } from "@dxos/react-ui-editor";
42
43
  import { defaultTx } from "@dxos/react-ui-theme";
43
- import { isNotFalsy } from "@dxos/util";
44
+ import { isTruthy } from "@dxos/util";
44
45
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
45
46
  var useExtensions = ({ document, id, text, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
46
47
  const { dispatchPromise: dispatch } = useIntentDispatcher();
@@ -112,7 +113,7 @@ var useExtensions = ({ document, id, text, settings, selectionManager, viewMode,
112
113
  }),
113
114
  baseExtensions,
114
115
  pluginExtensions
115
- ].filter(isNotFalsy), [
116
+ ].filter(isTruthy), [
116
117
  baseExtensions,
117
118
  pluginExtensions,
118
119
  document,
@@ -128,7 +129,7 @@ var createBaseExtensions = ({ document, id, dispatch, settings, selectionManager
128
129
  selectionManager && selectionChange(selectionManager),
129
130
  settings.editorInputMode && InputModeExtensions[settings.editorInputMode],
130
131
  settings.folding && folding()
131
- ].filter(isNotFalsy);
132
+ ].filter(isTruthy);
132
133
  if (viewMode !== "source") {
133
134
  extensions.push(...[
134
135
  formattingKeymap(),
@@ -238,14 +239,14 @@ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
238
239
  import React2, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo as useMemo3, useRef } from "react";
239
240
  import { useDropzone } from "react-dropzone";
240
241
  import { invariant as invariant3 } from "@dxos/invariant";
241
- import { toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
242
- import { CommandMenu, Domino, EditorToolbar, RefPopover, addLink, coreSlashCommands, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorGutter, editorSlots, filterItems, linkSlashCommands, processEditorPayload, stackItemContentEditorClassNames, useCommandMenu, useEditorToolbarState, useFormattingState, useTextEditor } from "@dxos/react-ui-editor";
242
+ import { Domino, toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
243
+ import { EditorToolbar, PopoverMenuProvider, addLink, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorGutter, editorSlots, filterMenuGroups, formattingCommands, linkSlashCommands, processEditorPayload, stackItemContentEditorClassNames, useEditorToolbarState, useFormattingState, usePopoverMenu, useTextEditor } from "@dxos/react-ui-editor";
243
244
  import { StackItem } from "@dxos/react-ui-stack";
244
- import { isNonNullable, isNotFalsy as isNotFalsy2 } from "@dxos/util";
245
+ import { isNonNullable, isTruthy as isTruthy2 } from "@dxos/util";
245
246
 
246
247
  // src/hooks/useSelectCurrentThread.tsx
247
248
  import { EditorView as EditorView2 } from "@codemirror/view";
248
- import { Schema } from "effect";
249
+ import * as Schema from "effect/Schema";
249
250
  import { useMemo as useMemo2 } from "react";
250
251
  import { LayoutAction as LayoutAction2, createResolver, useIntentResolver } from "@dxos/app-framework";
251
252
  import { invariant as invariant2 } from "@dxos/invariant";
@@ -309,18 +310,20 @@ var MarkdownEditor = ({ extensions: extensionsParam, slashCommandGroups, onLinkQ
309
310
  var _effect = _useSignals();
310
311
  try {
311
312
  const { t } = useTranslation();
312
- const viewRef = useRef();
313
- const getMenu = useCallback((trigger, query) => {
313
+ const viewRef = useRef(null);
314
+ const getMenu = useCallback(({ text, trigger }) => {
314
315
  switch (trigger) {
315
- case "@":
316
- return onLinkQuery?.(query) ?? [];
316
+ case "@": {
317
+ return onLinkQuery?.(text) ?? [];
318
+ }
317
319
  case "/":
318
- default:
319
- return filterItems([
320
- coreSlashCommands,
320
+ default: {
321
+ return filterMenuGroups([
322
+ formattingCommands,
321
323
  linkSlashCommands,
322
324
  ...slashCommandGroups ?? []
323
- ], (item) => query ? toLocalizedString(item.label, t).toLowerCase().includes(query.toLowerCase()) : true);
325
+ ], (item) => text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true);
326
+ }
324
327
  }
325
328
  }, [
326
329
  onLinkQuery,
@@ -338,32 +341,30 @@ var MarkdownEditor = ({ extensions: extensionsParam, slashCommandGroups, onLinkQ
338
341
  trigger,
339
342
  placeholder: {
340
343
  delay: 3e3,
341
- content: () => Domino.of("div").child(Domino.of("span").text("Press"), ...trigger.map((text) => Domino.of("span").classNames("border border-separator rounded-sm mx-1 px-1.5 pt-[1px] pb-[2px]").text(text)), Domino.of("span").text("for commands.")).build()
344
+ content: () => Domino.of("div").children(Domino.of("span").text("Press"), ...trigger.map((text) => Domino.of("span").classNames("mx-1 px-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm").text(text)), Domino.of("span").text("for commands.")).build()
342
345
  },
343
346
  getMenu
344
347
  };
345
348
  }, [
349
+ onLinkQuery,
346
350
  getMenu
347
351
  ]);
348
- const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu(options);
352
+ const { groupsRef, extension, ...commandMenuProps } = usePopoverMenu(options);
349
353
  const extensions = useMemo3(() => [
350
354
  extensionsParam,
351
- commandMenu
352
- ].filter(isNotFalsy2), [
355
+ extension
356
+ ].filter(isTruthy2), [
353
357
  extensionsParam,
354
- commandMenu
358
+ extension
355
359
  ]);
356
- return /* @__PURE__ */ React2.createElement(RefPopover, {
357
- modal: false,
358
- ...refPopoverProps
360
+ return /* @__PURE__ */ React2.createElement(PopoverMenuProvider, {
361
+ view: viewRef.current,
362
+ groups: groupsRef.current,
363
+ ...commandMenuProps
359
364
  }, /* @__PURE__ */ React2.createElement(MarkdownEditorImpl, {
360
365
  ref: viewRef,
361
366
  ...props,
362
367
  extensions
363
- }), /* @__PURE__ */ React2.createElement(CommandMenu, {
364
- groups: groupsRef.current,
365
- currentItem,
366
- onSelect
367
368
  }));
368
369
  } finally {
369
370
  _effect.f();
@@ -416,7 +417,7 @@ var MarkdownEditorImpl = /* @__PURE__ */ forwardRef(({ id, role = "article", ini
416
417
  }),
417
418
  providerExtensions,
418
419
  extensions
419
- ].filter(isNotFalsy2),
420
+ ].filter(isTruthy2),
420
421
  ...role !== "section" && {
421
422
  id,
422
423
  scrollTo,
@@ -577,7 +578,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
577
578
  objectForms,
578
579
  schemaWhiteList
579
580
  ]);
580
- const onLinkQuery = useCallback2(async (query) => {
581
+ const handleLinkQuery = useCallback2(async (query) => {
581
582
  const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
582
583
  const results = await space?.db.query(Query.select(filter)).run();
583
584
  const getLabel = (object2) => {
@@ -603,7 +604,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
603
604
  label,
604
605
  icon: metadata.icon,
605
606
  onSelect: (view, head) => {
606
- const link = `[${label}][${Obj.getDXN(object2)}]`;
607
+ const link = `[${label}](${Obj.getDXN(object2)})`;
607
608
  if (query?.startsWith("@")) {
608
609
  insertAtLineStart(view, head, `!${link}
609
610
  `);
@@ -633,7 +634,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
633
634
  settings,
634
635
  scrollPastEnd,
635
636
  onViewModeChange,
636
- onLinkQuery: space ? onLinkQuery : void 0
637
+ onLinkQuery: space ? handleLinkQuery : void 0
637
638
  }) : text ? /* @__PURE__ */ React3.createElement(MarkdownEditor, {
638
639
  id,
639
640
  role,
@@ -644,22 +645,19 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
644
645
  inputMode: settings.editorInputMode,
645
646
  scrollPastEnd,
646
647
  onViewModeChange,
647
- onLinkQuery: space ? onLinkQuery : void 0
648
- }) : (
649
- // TODO(burdon): Normalize with above.
650
- /* @__PURE__ */ React3.createElement(MarkdownEditor, {
651
- id,
652
- role,
653
- initialValue: object.text,
654
- extensions,
655
- viewMode,
656
- toolbar: settings.toolbar,
657
- inputMode: settings.editorInputMode,
658
- scrollPastEnd,
659
- onViewModeChange,
660
- onLinkQuery: space ? onLinkQuery : void 0
661
- })
662
- );
648
+ onLinkQuery: space ? handleLinkQuery : void 0
649
+ }) : /* @__PURE__ */ React3.createElement(MarkdownEditor, {
650
+ id,
651
+ role,
652
+ initialValue: object.text,
653
+ extensions,
654
+ viewMode,
655
+ toolbar: settings.toolbar,
656
+ inputMode: settings.editorInputMode,
657
+ scrollPastEnd,
658
+ onViewModeChange,
659
+ onLinkQuery: space ? handleLinkQuery : void 0
660
+ });
663
661
  return /* @__PURE__ */ React3.createElement(React3.Fragment, null, editor, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React3.createElement(PreviewBlock, {
664
662
  key: link.ref,
665
663
  link,
@@ -672,11 +670,9 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
672
670
  var PreviewBlock = ({ link, el }) => {
673
671
  var _effect = _useSignals2();
674
672
  try {
675
- const echoDXN = useMemo4(() => DXN.parse(link.ref).asEchoDXN(), [
676
- link.ref
677
- ]);
678
- const space = useSpace(echoDXN?.spaceId);
679
- const [subject] = useQuery(space, Query.select(Filter.ids(echoDXN?.echoId ?? "")));
673
+ const client = useClient();
674
+ const dxn = DXN.parse(link.ref);
675
+ const subject = client.graph.ref(dxn).target;
680
676
  const data = useMemo4(() => ({
681
677
  subject
682
678
  }), [
@@ -753,4 +749,4 @@ export {
753
749
  MarkdownContainer,
754
750
  MarkdownContainer_default as default
755
751
  };
756
- //# sourceMappingURL=MarkdownContainer-HRGQXIXP.mjs.map
752
+ //# sourceMappingURL=MarkdownContainer-J2R3DLCQ.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/MarkdownContainer.tsx", "../../../src/extensions.tsx", "../../../src/components/MarkdownEditor/MarkdownEditor.tsx", "../../../src/hooks/useSelectCurrentThread.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { Rx } from '@effect-rx/rx-react';\nimport React, { useCallback, useEffect, useMemo, useState } from 'react';\nimport { createPortal } from 'react-dom';\n\nimport { Capabilities, Surface, useAppGraph, useCapabilities, usePluginManager } from '@dxos/app-framework';\nimport { DXN, Filter, Obj, Query, Type } from '@dxos/echo';\nimport { ClientCapabilities } from '@dxos/plugin-client';\nimport { SpaceCapabilities } from '@dxos/plugin-space';\nimport { useClient } from '@dxos/react-client';\nimport { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { toLocalizedString, useTranslation } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n type PopoverMenuGroup,\n type PopoverMenuItem,\n type PreviewLinkRef,\n type PreviewOptions,\n insertAtCursor,\n insertAtLineStart,\n} from '@dxos/react-ui-editor';\nimport { DataType } from '@dxos/schema';\n\nimport { useExtensions } from '../extensions';\nimport { Markdown } from '../types';\nimport { getFallbackName } from '../util';\n\nimport { MarkdownEditor, type MarkdownEditorProps } from './MarkdownEditor';\n\nexport type MarkdownContainerProps = Pick<\n MarkdownEditorProps,\n 'role' | 'extensionProviders' | 'viewMode' | 'editorStateStore' | 'onViewModeChange'\n> & {\n id: string;\n object: Markdown.Document | DataType.Text | any;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n};\n\nexport const MarkdownContainer = ({\n id,\n role,\n object,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n onViewModeChange,\n}: MarkdownContainerProps) => {\n const { t } = useTranslation();\n const scrollPastEnd = role === 'article';\n const doc = Obj.instanceOf(Markdown.Document, object) ? object : undefined;\n const text = Obj.instanceOf(DataType.Text, object) ? object : undefined;\n const [previewBlocks, setPreviewBlocks] = useState<{ link: PreviewLinkRef; el: HTMLElement }[]>([]);\n const previewOptions = useMemo(\n (): PreviewOptions => ({\n addBlockContainer: (link, el) => {\n setPreviewBlocks((prev) => [...prev, { link, el }]);\n },\n removeBlockContainer: (link) => {\n setPreviewBlocks((prev) => prev.filter(({ link: prevLink }) => prevLink.ref !== link.ref));\n },\n }),\n [],\n );\n const extensions = useExtensions({\n document: doc,\n text,\n id,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n previewOptions,\n });\n\n // TODO(wittjosiah): Factor out.\n const manager = usePluginManager();\n const resolve = useCallback(\n (typename: string) =>\n manager.context.getCapabilities(Capabilities.Metadata).find(({ id }) => id === typename)?.metadata ?? {},\n [manager],\n );\n const space = getSpace(object);\n const objectForms = useCapabilities(SpaceCapabilities.ObjectForm);\n const schemaWhiteList = useCapabilities(ClientCapabilities.SchemaWhiteList);\n const filter = useMemo(\n () =>\n Filter.or(\n ...objectForms.map((form) => Filter.type(form.objectSchema)),\n ...schemaWhiteList.flat().map((schema) => Filter.typename(Type.getTypename(schema))),\n ),\n [objectForms, schemaWhiteList],\n );\n\n const handleLinkQuery = useCallback(\n async (query?: string): Promise<PopoverMenuGroup[]> => {\n const name = query?.startsWith('@') ? query.slice(1).toLowerCase() : (query?.toLowerCase() ?? '');\n const results = await space?.db.query(Query.select(filter)).run();\n // TODO(wittjosiah): Use `Obj.Any` type.\n const getLabel = (object: any) => {\n const label = Obj.getLabel(object);\n if (label) {\n return label;\n }\n\n // TODO(wittjosiah): Remove metadata labels.\n const type = Obj.getTypename(object)!;\n const metadata = resolve(type);\n return metadata.label?.(object) || ['object name placeholder', { ns: type, default: 'New object' }];\n };\n const items =\n results?.objects\n .filter((object) => toLocalizedString(getLabel(object), t).toLowerCase().includes(name))\n // TODO(wittjosiah): Remove `any` type.\n .map((object: any): PopoverMenuItem => {\n const metadata = resolve(Obj.getTypename(object)!);\n const label = toLocalizedString(getLabel(object), t);\n return {\n id: object.id,\n label,\n icon: metadata.icon,\n onSelect: (view, head) => {\n const link = `[${label}](${Obj.getDXN(object)})`;\n if (query?.startsWith('@')) {\n insertAtLineStart(view, head, `!${link}\\n`);\n } else {\n insertAtCursor(view, head, `${link} `);\n }\n },\n };\n }) ?? [];\n return [{ id: 'echo', items }];\n },\n [filter, resolve, space],\n );\n\n // TODO(burdon): Reconcile variants.\n const editor = doc ? (\n <DocumentEditor\n id={fullyQualifiedId(object)}\n role={role}\n document={doc}\n extensions={extensions}\n viewMode={viewMode}\n settings={settings}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n onLinkQuery={space ? handleLinkQuery : undefined}\n />\n ) : text ? (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={text.content}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n onLinkQuery={space ? handleLinkQuery : undefined}\n />\n ) : (\n <MarkdownEditor\n id={id}\n role={role}\n initialValue={object.text}\n extensions={extensions}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n inputMode={settings.editorInputMode}\n scrollPastEnd={scrollPastEnd}\n onViewModeChange={onViewModeChange}\n onLinkQuery={space ? handleLinkQuery : undefined}\n />\n );\n\n return (\n <>\n {editor}\n {previewBlocks.map(({ link, el }) => (\n <PreviewBlock key={link.ref} link={link} el={el} />\n ))}\n </>\n );\n};\n\n// TODO(wittjosiah): This shouldn't be \"card\" but \"block\".\n// It's not a preview card but an interactive embedded object.\nconst PreviewBlock = ({ link, el }: { link: PreviewLinkRef; el: HTMLElement }) => {\n const client = useClient();\n const dxn = DXN.parse(link.ref);\n const subject = client.graph.ref(dxn).target;\n const data = useMemo(() => ({ subject }), [subject]);\n\n return createPortal(<Surface role='card--transclusion' data={data} limit={1} />, el);\n};\n\ntype DocumentEditorProps = Omit<MarkdownContainerProps, 'object' | 'extensionProviders' | 'editorStateStore'> &\n Pick<MarkdownEditorProps, 'id' | 'scrollPastEnd' | 'extensions' | 'onLinkQuery'> & {\n document: Markdown.Document;\n };\n\nexport const DocumentEditor = ({ id, document: doc, settings, viewMode, ...props }: DocumentEditorProps) => {\n const space = getSpace(doc);\n\n // Migrate gradually to `fallbackName`.\n useEffect(() => {\n if (typeof doc.fallbackName === 'string') {\n return;\n }\n\n const fallbackName = doc.content?.target?.content ? getFallbackName(doc.content.target.content) : undefined;\n if (fallbackName) {\n doc.fallbackName = fallbackName;\n }\n }, [doc, doc.content]);\n\n // File dragging.\n const [upload] = useCapabilities(Capabilities.FileUploader);\n const handleFileUpload = useMemo(() => {\n if (space === undefined || upload === undefined) {\n return undefined;\n }\n\n // TODO(burdon): Re-order props: space, file.\n return async (file: File) => upload!(file, space);\n }, [space, upload]);\n\n const { graph } = useAppGraph();\n const customActions = useMemo(() => {\n return Rx.make((get) => {\n const actions = get(graph.actions(id));\n const nodes = actions.filter((action) => action.properties.disposition === 'toolbar');\n return { nodes, edges: nodes.map((node) => ({ source: 'root', target: node.id })) };\n });\n }, [graph]);\n\n return (\n <MarkdownEditor\n id={id}\n initialValue={doc.content?.target?.content}\n viewMode={viewMode}\n toolbar={settings.toolbar}\n customActions={customActions}\n inputMode={settings.editorInputMode}\n onFileUpload={handleFileUpload}\n {...props}\n />\n );\n};\n\nexport default MarkdownContainer;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type ViewUpdate } from '@codemirror/view';\nimport React, { type AnchorHTMLAttributes, type ReactNode, useMemo } from 'react';\nimport { createRoot } from 'react-dom/client';\n\nimport {\n LayoutAction,\n type PromiseIntentDispatcher,\n createIntent,\n useCapabilities,\n useIntentDispatcher,\n} from '@dxos/app-framework';\nimport { debounceAndThrottle } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\nimport { createDocAccessor, fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { useIdentity } from '@dxos/react-client/halo';\nimport { Icon, ThemeProvider } from '@dxos/react-ui';\nimport { type SelectionManager } from '@dxos/react-ui-attention';\nimport {\n Cursor,\n type EditorStateStore,\n EditorView,\n type EditorViewMode,\n type Extension,\n InputModeExtensions,\n type PreviewOptions,\n type RenderCallback,\n createDataExtensions,\n decorateMarkdown,\n documentId,\n folding,\n formattingKeymap,\n linkTooltip,\n listener,\n preview,\n selectionState,\n typewriter,\n} from '@dxos/react-ui-editor';\nimport { defaultTx } from '@dxos/react-ui-theme';\nimport { type DataType } from '@dxos/schema';\nimport { isTruthy } from '@dxos/util';\n\nimport { MarkdownCapabilities } from './capabilities';\nimport { type Markdown } from './types';\nimport { setFallbackName } from './util';\n\ntype ExtensionsOptions = {\n document?: Markdown.Document;\n id?: string;\n text?: DataType.Text;\n dispatch?: PromiseIntentDispatcher;\n settings: Markdown.Settings;\n selectionManager?: SelectionManager;\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n previewOptions?: PreviewOptions;\n};\n\n// TODO(burdon): Merge with createBaseExtensions below.\nexport const useExtensions = ({\n document,\n id,\n text,\n settings,\n selectionManager,\n viewMode,\n editorStateStore,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const identity = useIdentity();\n const space = getSpace(document) ?? getSpace(text);\n\n // TODO(wittjosiah): Autocomplete is not working and this query is causing performance issues.\n // TODO(burdon): Unsubscribe.\n // const query = space?.db.query(Filter.type(DocumentType));\n // query?.subscribe();\n const baseExtensions = useMemo(\n () =>\n createBaseExtensions({\n document,\n id,\n text,\n settings,\n selectionManager,\n viewMode,\n previewOptions,\n dispatch,\n // query,\n }),\n [\n document,\n id,\n text,\n viewMode,\n dispatch,\n previewOptions,\n settings,\n settings.editorInputMode,\n settings.folding,\n settings.numberedHeadings,\n settings.debug,\n settings.typewriter,\n selectionManager,\n ],\n );\n\n const extensionProviders = useCapabilities(MarkdownCapabilities.Extensions);\n\n //\n // External extensions from other plugins.\n //\n const pluginExtensions = useMemo<Extension[]>(() => {\n if (!document) {\n return [];\n }\n\n return extensionProviders.flat().reduce((acc: Extension[], provider) => {\n const extension = typeof provider === 'function' ? provider({ document }) : provider;\n if (extension) {\n acc.push(extension);\n }\n\n return acc;\n }, []);\n }, [extensionProviders, document]);\n\n //\n // Basic plugins.\n //\n return useMemo<Extension[]>(\n () =>\n [\n // NOTE: Data extensions must be first so that automerge is updated before other extensions compute their state.\n document &&\n createDataExtensions({\n id: document.id,\n text: document.content.target && createDocAccessor(document.content.target, ['content']),\n space,\n identity,\n }),\n text &&\n id &&\n createDataExtensions({\n id,\n text: createDocAccessor(text, ['content']),\n space,\n identity,\n }),\n selectionState(editorStateStore),\n document &&\n listener({\n onChange: (text) => setFallbackName(document, text),\n }),\n baseExtensions,\n pluginExtensions,\n ].filter(isTruthy),\n [baseExtensions, pluginExtensions, document, document?.content?.target, text, id, space, identity],\n );\n};\n\n/**\n * Create extension instances for editor.\n */\nconst createBaseExtensions = ({\n document,\n id,\n dispatch,\n settings,\n selectionManager,\n viewMode,\n previewOptions,\n}: ExtensionsOptions): Extension[] => {\n const extensions: Extension[] = [\n selectionManager && selectionChange(selectionManager),\n settings.editorInputMode && InputModeExtensions[settings.editorInputMode],\n settings.folding && folding(),\n ].filter(isTruthy);\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 || id)\n ? createLinkRenderer((id: string) => {\n void dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [id],\n options: {\n pivotId: document ? fullyQualifiedId(document) : id,\n },\n }),\n );\n })\n : undefined,\n }),\n linkTooltip(renderLinkTooltip),\n preview(previewOptions),\n ],\n );\n }\n\n if (settings.debug) {\n const items = settings.typewriter?.split(/[,\\n]/) ?? '';\n if (items) {\n extensions.push(typewriter({ items }));\n }\n }\n\n return extensions;\n};\n\nexport const selectionChange = (selectionManager: SelectionManager) => {\n return EditorView.updateListener.of(\n debounceAndThrottle((update: ViewUpdate) => {\n if (update.selectionSet) {\n const id = update.state.facet(documentId);\n const cursorConverter = update.state.facet(Cursor.converter);\n const selection = update.state.selection;\n const ranges = selection.ranges\n .map((range) => ({\n from: cursorConverter.toCursor(range.from),\n to: cursorConverter.toCursor(range.to),\n }))\n .filter(({ from, to }) => to > from);\n selectionManager.updateMultiRange(id, ranges);\n }\n }, 100),\n );\n};\n\n// TODO(burdon): Factor out styles.\nconst style = {\n hover: 'rounded-sm text-primary-500 hover:text-primary-600 dark:text-primary-500 hover:dark:text-primary-400',\n icon: 'inline-block leading-none mis-1 cursor-pointer',\n};\n\nconst createLinkRenderer =\n (onSelectObject: (id: string) => void): RenderCallback<{ url: string }> =>\n (el, { url }) => {\n // TODO(burdon): Formalize/document internal link format.\n const isInternal =\n url.startsWith('/') ||\n // TODO(wittjosiah): This should probably be parsed out on paste?\n url.startsWith(window.location.origin);\n\n const options: AnchorHTMLAttributes<any> = isInternal\n ? {\n onClick: () => {\n const qualifiedId = url.split('/').at(-1);\n invariant(qualifiedId, 'Invalid link format.');\n onSelectObject(qualifiedId);\n },\n }\n : {\n href: url,\n rel: 'noreferrer',\n target: '_blank',\n };\n\n renderRoot(\n el,\n <a {...options} className={style.hover}>\n <Icon\n icon={isInternal ? 'ph--arrow-square-down--bold' : 'ph--arrow-square-out--bold'}\n size={4}\n classNames={style.icon}\n />\n </a>,\n );\n };\n\nconst renderLinkTooltip: RenderCallback<{ url: string }> = (el, { url }) => {\n const web = new URL(url);\n renderRoot(\n el,\n <a href={url} rel='noreferrer' target='_blank' className={style.hover}>\n {web.origin}\n <Icon icon='ph--arrow-square-out--bold' size={4} classNames={style.icon} />\n </a>,\n );\n};\n\n// TODO(burdon): Remove react rendering; use DOM directly.\nexport const renderRoot = <T extends Element>(root: T, node: ReactNode): T => {\n createRoot(root).render(<ThemeProvider tx={defaultTx}>{node}</ThemeProvider>);\n return root;\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type EditorView } from '@codemirror/view';\nimport React, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo, useRef } from 'react';\nimport { useDropzone } from 'react-dropzone';\n\nimport { type FileInfo } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { Domino, toLocalizedString, useThemeContext, useTranslation } from '@dxos/react-ui';\nimport {\n type DNDOptions,\n type EditorInputMode,\n type EditorSelectionState,\n type EditorStateStore,\n EditorToolbar,\n type EditorToolbarActionGraphProps,\n type EditorViewMode,\n type PopoverMenuGroup,\n PopoverMenuProvider,\n type UsePopoverMenuProps,\n type UseTextEditorProps,\n addLink,\n createBasicExtensions,\n createMarkdownExtensions,\n createThemeExtensions,\n dropFile,\n editorGutter,\n editorSlots,\n filterMenuGroups,\n formattingCommands,\n linkSlashCommands,\n processEditorPayload,\n stackItemContentEditorClassNames,\n useEditorToolbarState,\n useFormattingState,\n usePopoverMenu,\n useTextEditor,\n} from '@dxos/react-ui-editor';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { isNonNullable, isTruthy } from '@dxos/util';\n\nimport { useSelectCurrentThread } from '../../hooks';\nimport { meta } from '../../meta';\nimport { type MarkdownPluginState } from '../../types';\n\nexport type MarkdownEditorProps = {\n id: string;\n role?: string;\n toolbar?: boolean;\n inputMode?: EditorInputMode;\n scrollPastEnd?: boolean;\n slashCommandGroups?: PopoverMenuGroup[];\n customActions?: EditorToolbarActionGraphProps['customActions'];\n // TODO(wittjosiah): Generalize custom toolbar actions (e.g. comment, upload, etc.)\n viewMode?: EditorViewMode;\n editorStateStore?: EditorStateStore;\n onViewModeChange?: (id: string, mode: EditorViewMode) => void;\n onLinkQuery?: (query?: string) => Promise<PopoverMenuGroup[]>;\n onFileUpload?: (file: File) => Promise<FileInfo | undefined>;\n} & (Pick<UseTextEditorProps, 'initialValue' | 'extensions'> &\n Partial<Pick<MarkdownPluginState, 'extensionProviders'>>);\n\n/**\n * Base markdown editor component.\n * This component provides all the features of the markdown editor that do no depend on ECHO.\n * This allows it to be used as a common editor for markdown content on arbitrary backends (e.g. files).\n */\nexport const MarkdownEditor = ({\n extensions: extensionsParam,\n slashCommandGroups,\n onLinkQuery,\n ...props\n}: MarkdownEditorProps) => {\n const { t } = useTranslation();\n const viewRef = useRef<EditorView>(null);\n\n const getMenu = useCallback<NonNullable<UsePopoverMenuProps['getMenu']>>(\n ({ text, trigger }) => {\n switch (trigger) {\n case '@': {\n return onLinkQuery?.(text) ?? [];\n }\n\n case '/':\n default: {\n return filterMenuGroups([formattingCommands, linkSlashCommands, ...(slashCommandGroups ?? [])], (item) =>\n text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true,\n );\n }\n }\n },\n [onLinkQuery, slashCommandGroups],\n );\n\n const options = useMemo<UsePopoverMenuProps>(() => {\n const trigger = onLinkQuery ? ['/', '@'] : ['/'];\n return {\n viewRef,\n trigger,\n placeholder: {\n delay: 3_000,\n content: () =>\n Domino.of('div')\n .children(\n Domino.of('span').text('Press'),\n ...trigger.map((text) =>\n Domino.of('span')\n .classNames('mx-1 px-1.5 pt-[1px] pb-[2px] border border-separator rounded-sm')\n .text(text),\n ),\n Domino.of('span').text('for commands.'),\n )\n .build(),\n },\n getMenu,\n };\n }, [onLinkQuery, getMenu]);\n\n const { groupsRef, extension, ...commandMenuProps } = usePopoverMenu(options);\n const extensions = useMemo(() => [extensionsParam, extension].filter(isTruthy), [extensionsParam, extension]);\n\n return (\n <PopoverMenuProvider view={viewRef.current} groups={groupsRef.current} {...commandMenuProps}>\n <MarkdownEditorImpl ref={viewRef} {...props} extensions={extensions} />\n </PopoverMenuProvider>\n );\n};\n\nconst MarkdownEditorImpl = forwardRef<EditorView | null, MarkdownEditorProps>(\n (\n {\n id,\n role = 'article',\n initialValue,\n customActions,\n editorStateStore,\n extensions,\n extensionProviders,\n scrollPastEnd,\n toolbar,\n viewMode,\n onFileUpload,\n onViewModeChange,\n },\n forwardedRef,\n ) => {\n const { t } = useTranslation(meta.id);\n const { themeMode } = useThemeContext();\n const toolbarState = useEditorToolbarState({ viewMode });\n const formattingObserver = useFormattingState(toolbarState);\n\n // Restore last selection and scroll point.\n const { scrollTo, selection } = useMemo<EditorSelectionState>(() => editorStateStore?.getState(id) ?? {}, [id]);\n\n // Extensions from other plugins.\n // TODO(burdon): Reconcile with DocumentEditor.useExtensions.\n const providerExtensions = useMemo(\n () => extensionProviders?.flatMap((provider) => provider({})).filter(isNonNullable),\n [extensionProviders],\n );\n\n // TODO(wittjosiah): Factor out to file uploader plugin.\n // Drag files.\n const handleDrop: DNDOptions['onDrop'] = async (view, { files }) => {\n const file = files[0];\n const info = file && onFileUpload ? await onFileUpload(file) : undefined;\n if (info) {\n processEditorPayload(view, { type: 'image', data: info.url });\n }\n };\n\n const {\n parentRef,\n view: editorView,\n focusAttributes,\n } = useTextEditor(\n () => ({\n initialValue,\n extensions: [\n formattingObserver,\n createBasicExtensions({\n readOnly: viewMode === 'readonly',\n placeholder: t('editor placeholder'),\n scrollPastEnd: role === 'section' ? false : scrollPastEnd,\n search: true,\n }),\n createMarkdownExtensions(),\n createThemeExtensions({ themeMode, syntaxHighlighting: true, slots: editorSlots }),\n editorGutter,\n role !== 'section' && onFileUpload && dropFile({ onDrop: handleDrop }),\n providerExtensions,\n extensions,\n ].filter(isTruthy),\n ...(role !== 'section' && {\n id,\n scrollTo,\n selection,\n // TODO(wittjosiah): Autofocus based on layout is racy.\n // autoFocus: layoutPlugin?.provides.layout ? layoutPlugin?.provides.layout.scrollIntoView === id : true,\n moveToEndOfLine: true,\n }),\n }),\n [id, formattingObserver, viewMode, themeMode, extensions, providerExtensions],\n );\n\n useImperativeHandle<EditorView | null, EditorView | null>(forwardedRef, () => editorView, [editorView]);\n useTest(editorView);\n useSelectCurrentThread(editorView, id);\n\n // https://react-dropzone.js.org/#src\n const { acceptedFiles, getInputProps, open } = useDropzone({\n multiple: false,\n noDrag: true,\n accept: {\n 'image/*': ['.jpg', '.jpeg', '.png', '.gif'],\n },\n });\n\n useEffect(() => {\n if (editorView && onFileUpload && acceptedFiles.length) {\n requestAnimationFrame(async () => {\n // NOTE: Clone file since react-dropzone patches in a non-standard `path` property, which confuses IPFS.\n const f = acceptedFiles[0];\n const file = new File([f], f.name, {\n type: f.type,\n lastModified: f.lastModified,\n });\n\n const info = await onFileUpload(file);\n if (info) {\n addLink({ url: info.url, image: true })(editorView);\n }\n });\n }\n }, [acceptedFiles, editorView, onFileUpload]);\n\n const getView = useCallback(() => {\n invariant(editorView);\n return editorView;\n }, [editorView]);\n\n const handleViewModeChange = useCallback(\n (mode: EditorViewMode) => onViewModeChange?.(id, mode),\n [id, onViewModeChange],\n );\n\n const handleImageUpload = useCallback(() => {\n if (onFileUpload) {\n open();\n }\n }, [onFileUpload]);\n\n return (\n <StackItem.Content toolbar={!!toolbar}>\n {toolbar && (\n <>\n <EditorToolbar\n attendableId={id}\n role={role}\n state={toolbarState}\n customActions={customActions}\n getView={getView}\n image={handleImageUpload}\n viewMode={handleViewModeChange}\n />\n <input {...getInputProps()} />\n </>\n )}\n <div\n role='none'\n ref={parentRef}\n data-testid='composer.markdownRoot'\n data-toolbar={toolbar ? 'enabled' : 'disabled'}\n className={stackItemContentEditorClassNames(role)}\n data-popover-collision-boundary={true}\n {...focusAttributes}\n />\n </StackItem.Content>\n );\n },\n);\n\n// Expose editor view for playwright tests.\n// TODO(wittjosiah): Find a better way to expose this or find a way to limit it to test runs.\nconst useTest = (view: EditorView | null) => {\n useEffect(() => {\n const composer = (window as any).composer;\n if (composer) {\n composer.editorView = view;\n }\n }, [view]);\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { EditorView } from '@codemirror/view';\nimport * as Schema from 'effect/Schema';\nimport { useMemo } from 'react';\n\nimport { LayoutAction, createResolver, useIntentResolver } from '@dxos/app-framework';\nimport { invariant } from '@dxos/invariant';\nimport { Cursor, setSelection } from '@dxos/react-ui-editor';\n\nimport { meta } from '../meta';\n\n/**\n * Handle scrolling and selection of the current thread in a markdown editor.\n */\nexport const useSelectCurrentThread = (editorView: EditorView | null, documentId: string) => {\n const scrollIntoViewResolver = useMemo(\n () =>\n createResolver({\n intent: LayoutAction.UpdateLayout,\n position: 'hoist',\n filter: (data): data is { part: 'current'; subject: string; options: { cursor: string } } => {\n if (!Schema.is(LayoutAction.ScrollIntoView.fields.input)(data)) {\n return false;\n }\n\n return !!editorView && data.subject === documentId && !!data.options?.cursor;\n },\n resolve: ({ options: { cursor } }) => {\n invariant(editorView, 'Editor view is not defined.');\n const range = Cursor.getRangeFromCursor(editorView.state, cursor!);\n if (range) {\n const selection = editorView.state.selection.main.from !== range.from ? { anchor: range.from } : undefined;\n const effects = [\n // NOTE: This does not use the DOM scrollIntoView function.\n EditorView.scrollIntoView(range.from, { y: 'start', yMargin: 96 }),\n ];\n if (selection) {\n // Update the editor selection to get bi-directional highlighting.\n effects.push(setSelection.of({ current: documentId }));\n }\n\n editorView.dispatch({\n effects,\n selection: selection ? { anchor: range.from } : undefined,\n });\n }\n },\n }),\n [documentId, editorView],\n );\n\n useIntentResolver(meta.id, scrollIntoViewResolver);\n};\n"],
5
+ "mappings": "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",
6
+ "names": ["Rx", "React", "useCallback", "useEffect", "useMemo", "useState", "createPortal", "Capabilities", "Surface", "useAppGraph", "useCapabilities", "usePluginManager", "DXN", "Filter", "Obj", "Query", "Type", "ClientCapabilities", "SpaceCapabilities", "useClient", "fullyQualifiedId", "getSpace", "toLocalizedString", "useTranslation", "insertAtCursor", "insertAtLineStart", "DataType", "React", "useMemo", "createRoot", "LayoutAction", "createIntent", "useCapabilities", "useIntentDispatcher", "debounceAndThrottle", "invariant", "createDocAccessor", "fullyQualifiedId", "getSpace", "useIdentity", "Icon", "ThemeProvider", "Cursor", "EditorView", "InputModeExtensions", "createDataExtensions", "decorateMarkdown", "documentId", "folding", "formattingKeymap", "linkTooltip", "listener", "preview", "selectionState", "typewriter", "defaultTx", "isTruthy", "useExtensions", "document", "id", "text", "settings", "selectionManager", "viewMode", "editorStateStore", "previewOptions", "dispatchPromise", "dispatch", "useIntentDispatcher", "identity", "useIdentity", "space", "getSpace", "baseExtensions", "useMemo", "createBaseExtensions", "editorInputMode", "folding", "numberedHeadings", "debug", "typewriter", "extensionProviders", "useCapabilities", "MarkdownCapabilities", "Extensions", "pluginExtensions", "flat", "reduce", "acc", "provider", "extension", "push", "createDataExtensions", "content", "target", "createDocAccessor", "selectionState", "listener", "onChange", "setFallbackName", "filter", "isTruthy", "extensions", "selectionChange", "InputModeExtensions", "formattingKeymap", "decorateMarkdown", "selectionChangeDelay", "from", "undefined", "renderLinkButton", "createLinkRenderer", "createIntent", "LayoutAction", "Open", "part", "subject", "options", "pivotId", "fullyQualifiedId", "linkTooltip", "renderLinkTooltip", "preview", "items", "split", "EditorView", "updateListener", "of", "debounceAndThrottle", "update", "selectionSet", "state", "facet", "documentId", "cursorConverter", "Cursor", "converter", "selection", "ranges", "map", "range", "toCursor", "to", "updateMultiRange", "style", "hover", "icon", "onSelectObject", "el", "url", "isInternal", "startsWith", "window", "location", "origin", "onClick", "qualifiedId", "at", "invariant", "href", "rel", "renderRoot", "a", "className", "Icon", "size", "classNames", "web", "URL", "root", "node", "createRoot", "render", "ThemeProvider", "tx", "defaultTx", "React", "forwardRef", "useCallback", "useEffect", "useImperativeHandle", "useMemo", "useRef", "useDropzone", "invariant", "Domino", "toLocalizedString", "useThemeContext", "useTranslation", "EditorToolbar", "PopoverMenuProvider", "addLink", "createBasicExtensions", "createMarkdownExtensions", "createThemeExtensions", "dropFile", "editorGutter", "editorSlots", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "processEditorPayload", "stackItemContentEditorClassNames", "useEditorToolbarState", "useFormattingState", "usePopoverMenu", "useTextEditor", "StackItem", "isNonNullable", "isTruthy", "EditorView", "Schema", "useMemo", "LayoutAction", "createResolver", "useIntentResolver", "invariant", "Cursor", "setSelection", "useSelectCurrentThread", "editorView", "documentId", "scrollIntoViewResolver", "useMemo", "createResolver", "intent", "LayoutAction", "UpdateLayout", "position", "filter", "data", "is", "ScrollIntoView", "fields", "input", "subject", "options", "cursor", "resolve", "invariant", "range", "Cursor", "getRangeFromCursor", "state", "selection", "main", "from", "anchor", "undefined", "effects", "EditorView", "scrollIntoView", "y", "yMargin", "push", "setSelection", "of", "current", "dispatch", "useIntentResolver", "meta", "id", "MarkdownEditor", "extensions", "extensionsParam", "slashCommandGroups", "onLinkQuery", "props", "t", "useTranslation", "viewRef", "useRef", "getMenu", "useCallback", "text", "trigger", "filterMenuGroups", "formattingCommands", "linkSlashCommands", "item", "toLocalizedString", "label", "toLowerCase", "includes", "options", "useMemo", "placeholder", "delay", "content", "Domino", "of", "children", "map", "classNames", "build", "groupsRef", "extension", "commandMenuProps", "usePopoverMenu", "filter", "isTruthy", "React", "PopoverMenuProvider", "view", "current", "groups", "MarkdownEditorImpl", "ref", "forwardRef", "id", "role", "initialValue", "customActions", "editorStateStore", "extensionProviders", "scrollPastEnd", "toolbar", "viewMode", "onFileUpload", "onViewModeChange", "forwardedRef", "meta", "themeMode", "useThemeContext", "toolbarState", "useEditorToolbarState", "formattingObserver", "useFormattingState", "scrollTo", "selection", "getState", "providerExtensions", "flatMap", "provider", "isNonNullable", "handleDrop", "files", "file", "info", "undefined", "processEditorPayload", "type", "data", "url", "parentRef", "editorView", "focusAttributes", "useTextEditor", "createBasicExtensions", "readOnly", "search", "createMarkdownExtensions", "createThemeExtensions", "syntaxHighlighting", "slots", "editorSlots", "editorGutter", "dropFile", "onDrop", "moveToEndOfLine", "useImperativeHandle", "useTest", "useSelectCurrentThread", "acceptedFiles", "getInputProps", "open", "useDropzone", "multiple", "noDrag", "accept", "useEffect", "length", "requestAnimationFrame", "f", "File", "name", "lastModified", "addLink", "image", "getView", "invariant", "handleViewModeChange", "mode", "handleImageUpload", "StackItem", "Content", "EditorToolbar", "attendableId", "state", "input", "div", "data-testid", "data-toolbar", "className", "stackItemContentEditorClassNames", "data-popover-collision-boundary", "composer", "window", "MarkdownContainer", "id", "role", "object", "settings", "selectionManager", "viewMode", "editorStateStore", "onViewModeChange", "t", "useTranslation", "scrollPastEnd", "doc", "Obj", "instanceOf", "Markdown", "Document", "undefined", "text", "DataType", "Text", "previewBlocks", "setPreviewBlocks", "useState", "previewOptions", "useMemo", "addBlockContainer", "link", "el", "prev", "removeBlockContainer", "filter", "prevLink", "ref", "extensions", "useExtensions", "document", "manager", "usePluginManager", "resolve", "useCallback", "typename", "context", "getCapabilities", "Capabilities", "Metadata", "find", "metadata", "space", "getSpace", "objectForms", "useCapabilities", "SpaceCapabilities", "ObjectForm", "schemaWhiteList", "ClientCapabilities", "SchemaWhiteList", "Filter", "or", "map", "form", "type", "objectSchema", "flat", "schema", "Type", "getTypename", "handleLinkQuery", "query", "name", "startsWith", "slice", "toLowerCase", "results", "db", "Query", "select", "run", "getLabel", "label", "ns", "default", "items", "objects", "toLocalizedString", "includes", "icon", "onSelect", "view", "head", "getDXN", "insertAtLineStart", "insertAtCursor", "editor", "React", "DocumentEditor", "fullyQualifiedId", "onLinkQuery", "MarkdownEditor", "initialValue", "content", "toolbar", "inputMode", "editorInputMode", "PreviewBlock", "key", "client", "useClient", "dxn", "DXN", "parse", "subject", "graph", "target", "data", "createPortal", "Surface", "limit", "props", "useEffect", "fallbackName", "getFallbackName", "upload", "FileUploader", "handleFileUpload", "file", "useAppGraph", "customActions", "Rx", "make", "get", "actions", "nodes", "action", "properties", "disposition", "edges", "node", "source", "onFileUpload"]
7
+ }
@@ -1,14 +1,14 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  Markdown_exports
4
- } from "./chunk-FXILAQ5F.mjs";
4
+ } from "./chunk-FWZKC6X5.mjs";
5
5
  import "./chunk-VCG2U522.mjs";
6
6
 
7
7
  // src/capabilities/anchor-sort.ts
8
8
  import { Capabilities, contributes } from "@dxos/app-framework";
9
9
  import { Type } from "@dxos/echo";
10
10
  import { createDocAccessor, getRangeFromCursor, getTarget } from "@dxos/react-client/echo";
11
- var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
11
+ var anchor_sort_default = (() => contributes(Capabilities.AnchorSort, {
12
12
  key: Type.getTypename(Markdown_exports.Document),
13
13
  sort: (anchorA, anchorB) => {
14
14
  const doc = getTarget(anchorA);
@@ -26,8 +26,8 @@ var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
26
26
  const posB = getStartPosition(anchorB.anchor);
27
27
  return posA - posB;
28
28
  }
29
- });
29
+ }));
30
30
  export {
31
31
  anchor_sort_default as default
32
32
  };
33
- //# sourceMappingURL=anchor-sort-ALP2NH24.mjs.map
33
+ //# sourceMappingURL=anchor-sort-FCRYL2FX.mjs.map
@@ -2,6 +2,6 @@
2
2
  "version": 3,
3
3
  "sources": ["../../../src/capabilities/anchor-sort.ts"],
4
4
  "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes } from '@dxos/app-framework';\nimport { Type } from '@dxos/echo';\nimport { createDocAccessor, getRangeFromCursor, getTarget } from '@dxos/react-client/echo';\n\nimport { Markdown } from '../types';\n\nexport default () =>\n contributes(Capabilities.AnchorSort, {\n key: Type.getTypename(Markdown.Document)!,\n sort: (anchorA, anchorB) => {\n const doc = getTarget(anchorA) as Markdown.Document;\n const accessor = doc.content.target ? createDocAccessor(doc.content.target, ['content']) : undefined;\n if (doc !== getTarget(anchorB) || !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 const posA = getStartPosition(anchorA.anchor);\n const posB = getStartPosition(anchorB.anchor);\n return posA - posB;\n },\n });\n"],
5
- "mappings": ";;;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,YAAY;AACrB,SAASC,mBAAmBC,oBAAoBC,iBAAiB;AAIjE,IAAA,sBAAe,MACbC,YAAYC,aAAaC,YAAY;EACnCC,KAAKC,KAAKC,YAAYC,iBAASC,QAAQ;EACvCC,MAAM,CAACC,SAASC,YAAAA;AACd,UAAMC,MAAMC,UAAUH,OAAAA;AACtB,UAAMI,WAAWF,IAAIG,QAAQC,SAASC,kBAAkBL,IAAIG,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIN,QAAQC,UAAUF,OAAAA,KAAY,CAACG,UAAU;AAC3C,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBT,QAAQiB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBR,QAAQgB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA;",
5
+ "mappings": ";;;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,YAAY;AACrB,SAASC,mBAAmBC,oBAAoBC,iBAAiB;AAIjE,IAAA,uBAAe,MACbC,YAAYC,aAAaC,YAAY;EACnCC,KAAKC,KAAKC,YAAYC,iBAASC,QAAQ;EACvCC,MAAM,CAACC,SAASC,YAAAA;AACd,UAAMC,MAAMC,UAAUH,OAAAA;AACtB,UAAMI,WAAWF,IAAIG,QAAQC,SAASC,kBAAkBL,IAAIG,QAAQC,QAAQ;MAAC;KAAU,IAAIE;AAC3F,QAAIN,QAAQC,UAAUF,OAAAA,KAAY,CAACG,UAAU;AAC3C,aAAO;IACT;AAEA,UAAMK,mBAAmB,CAACC,WAAAA;AACxB,YAAMC,QAAQD,SAASE,mBAAmBR,UAAUM,MAAAA,IAAUF;AAC9D,aAAOG,OAAOE,SAASC,OAAOC;IAChC;AAEA,UAAMC,OAAOP,iBAAiBT,QAAQiB,MAAM;AAC5C,UAAMC,OAAOT,iBAAiBR,QAAQgB,MAAM;AAC5C,WAAOD,OAAOE;EAChB;AACF,CAAA;",
6
6
  "names": ["Capabilities", "contributes", "Type", "createDocAccessor", "getRangeFromCursor", "getTarget", "contributes", "Capabilities", "AnchorSort", "key", "Type", "getTypename", "Markdown", "Document", "sort", "anchorA", "anchorB", "doc", "getTarget", "accessor", "content", "target", "createDocAccessor", "undefined", "getStartPosition", "cursor", "range", "getRangeFromCursor", "start", "Number", "MAX_SAFE_INTEGER", "posA", "anchor", "posB"]
7
7
  }
@@ -1,21 +1,21 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  translations
4
- } from "./chunk-J7A6TUB2.mjs";
4
+ } from "./chunk-XO3IEQJE.mjs";
5
5
  import {
6
6
  MarkdownAction_exports,
7
7
  Markdown_exports
8
- } from "./chunk-FXILAQ5F.mjs";
8
+ } from "./chunk-FWZKC6X5.mjs";
9
9
  import "./chunk-VCG2U522.mjs";
10
10
 
11
11
  // src/capabilities/app-graph-serializer.ts
12
- import { pipe } from "effect";
12
+ import * as Function from "effect/Function";
13
13
  import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
14
14
  import { Obj } from "@dxos/echo";
15
15
  import { SpaceAction } from "@dxos/plugin-space/types";
16
16
  import { isSpace } from "@dxos/react-client/echo";
17
17
  import { DataType } from "@dxos/schema";
18
- var app_graph_serializer_default = (context) => contributes(Capabilities.AppGraphSerializer, [
18
+ var app_graph_serializer_default = ((context) => contributes(Capabilities.AppGraphSerializer, [
19
19
  {
20
20
  inputType: Markdown_exports.Document.typename,
21
21
  outputType: "text/markdown",
@@ -36,7 +36,7 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
36
36
  return;
37
37
  }
38
38
  const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
39
- const result = await dispatch(pipe(createIntent(MarkdownAction_exports.Create, {
39
+ const result = await dispatch(Function.pipe(createIntent(MarkdownAction_exports.Create, {
40
40
  name: data.name,
41
41
  content: data.data
42
42
  }), chain(SpaceAction.AddObject, {
@@ -45,8 +45,8 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
45
45
  return result.data?.object;
46
46
  }
47
47
  }
48
- ]);
48
+ ]));
49
49
  export {
50
50
  app_graph_serializer_default as default
51
51
  };
52
- //# sourceMappingURL=app-graph-serializer-56TD3BMX.mjs.map
52
+ //# sourceMappingURL=app-graph-serializer-FAUQM3BH.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-serializer.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Function from 'effect/Function';\n\nimport { Capabilities, type PluginContext, chain, contributes, createIntent } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { SpaceAction } from '@dxos/plugin-space/types';\nimport { isSpace } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { translations } from '../translations';\nimport { Markdown, MarkdownAction } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.AppGraphSerializer, [\n {\n inputType: Markdown.Document.typename,\n outputType: 'text/markdown',\n // Reconcile with metadata serializers.\n serialize: async (node) => {\n const doc = node.data;\n const content = await doc.content.load();\n return {\n name:\n doc.name ||\n doc.fallbackName ||\n translations[0]['en-US'][Markdown.Document.typename]['object name 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) => Obj.instanceOf(DataType.Collection, ancestor)) ??\n space?.properties[DataType.Collection.typename]?.target;\n if (!space || !target) {\n return;\n }\n\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const result = await dispatch(\n Function.pipe(\n createIntent(MarkdownAction.Create, { name: data.name, content: data.data }),\n chain(SpaceAction.AddObject, { target }),\n ),\n );\n\n return result.data?.object;\n },\n },\n ]);\n"],
5
+ "mappings": ";;;;;;;;;;;AAIA,YAAYA,cAAc;AAE1B,SAASC,cAAkCC,OAAOC,aAAaC,oBAAoB;AACnF,SAASC,WAAW;AACpB,SAASC,mBAAmB;AAC5B,SAASC,eAAe;AACxB,SAASC,gBAAgB;AAKzB,IAAA,gCAAe,CAACC,YACdC,YAAYC,aAAaC,oBAAoB;EAC3C;IACEC,WAAWC,iBAASC,SAASC;IAC7BC,YAAY;;IAEZC,WAAW,OAAOC,SAAAA;AAChB,YAAMC,MAAMD,KAAKE;AACjB,YAAMC,UAAU,MAAMF,IAAIE,QAAQC,KAAI;AACtC,aAAO;QACLC,MACEJ,IAAII,QACJJ,IAAIK,gBACJC,aAAa,CAAA,EAAG,OAAA,EAASZ,iBAASC,SAASC,QAAQ,EAAE,yBAAA;QACvDK,MAAMC,QAAQA;QACdK,MAAM;MACR;IACF;IACAC,aAAa,OAAOP,MAAMQ,cAAAA;AACxB,YAAMC,QAAQD,UAAUE,KAAKC,OAAAA;AAC7B,YAAMC,SACJJ,UAAUK,SAAS,CAACC,aAAaC,IAAIC,WAAWC,SAASC,YAAYJ,QAAAA,CAAAA,KACrEL,OAAOU,WAAWF,SAASC,WAAWvB,QAAQ,GAAGiB;AACnD,UAAI,CAACH,SAAS,CAACG,QAAQ;AACrB;MACF;AAEA,YAAM,EAAEQ,iBAAiBC,SAAQ,IAAKjC,QAAQkC,cAAchC,aAAaiC,gBAAgB;AACzF,YAAMC,SAAS,MAAMH,SACVI,cACPC,aAAaC,uBAAeC,QAAQ;QAAEzB,MAAMH,KAAKG;QAAMF,SAASD,KAAKA;MAAK,CAAA,GAC1E6B,MAAMC,YAAYC,WAAW;QAAEnB;MAAO,CAAA,CAAA,CAAA;AAI1C,aAAOY,OAAOxB,MAAMgC;IACtB;EACF;CACD;",
6
+ "names": ["Function", "Capabilities", "chain", "contributes", "createIntent", "Obj", "SpaceAction", "isSpace", "DataType", "context", "contributes", "Capabilities", "AppGraphSerializer", "inputType", "Markdown", "Document", "typename", "outputType", "serialize", "node", "doc", "data", "content", "load", "name", "fallbackName", "translations", "type", "deserialize", "ancestors", "space", "find", "isSpace", "target", "findLast", "ancestor", "Obj", "instanceOf", "DataType", "Collection", "properties", "dispatchPromise", "dispatch", "getCapability", "IntentDispatcher", "result", "pipe", "createIntent", "MarkdownAction", "Create", "chain", "SpaceAction", "AddObject", "object"]
7
+ }
@@ -2,11 +2,11 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  BLUEPRINT_KEY,
4
4
  blueprint_definition_default
5
- } from "./chunk-DVK63TD3.mjs";
6
- import "./chunk-FXILAQ5F.mjs";
5
+ } from "./chunk-FVI7LPC3.mjs";
6
+ import "./chunk-FWZKC6X5.mjs";
7
7
  import "./chunk-VCG2U522.mjs";
8
8
  export {
9
9
  BLUEPRINT_KEY,
10
10
  blueprint_definition_default as default
11
11
  };
12
- //# sourceMappingURL=blueprint-definition-GVW67KGV.mjs.map
12
+ //# sourceMappingURL=blueprint-definition-XYFKMIDR.mjs.map
@@ -0,0 +1,24 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // src/capabilities/index.ts
4
+ import { lazy } from "@dxos/app-framework";
5
+ var AnchorSort = lazy(() => import("./anchor-sort-FCRYL2FX.mjs"));
6
+ var AppGraphSerializer = lazy(() => import("./app-graph-serializer-FAUQM3BH.mjs"));
7
+ var BlueprintDefinition = lazy(() => import("./blueprint-definition-XYFKMIDR.mjs"));
8
+ var IntentResolver = lazy(() => import("./intent-resolver-7A2EXGZQ.mjs"));
9
+ var ReactSurface = lazy(() => import("./react-surface-RCLL5WVQ.mjs"));
10
+ var MarkdownSettings = lazy(() => import("./settings-H3UDD3KO.mjs"));
11
+ var MarkdownState = lazy(() => import("./state-W3PECOJX.mjs"));
12
+ var Toolkit = lazy(() => import("./toolkit-HSIKUGNK.mjs"));
13
+
14
+ export {
15
+ AnchorSort,
16
+ AppGraphSerializer,
17
+ BlueprintDefinition,
18
+ IntentResolver,
19
+ ReactSurface,
20
+ MarkdownSettings,
21
+ MarkdownState,
22
+ Toolkit
23
+ };
24
+ //# sourceMappingURL=chunk-7RDNIMTF.mjs.map