@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,22 +1,22 @@
1
1
  import {
2
- getAbstract,
2
+ getContentSnippet,
3
3
  getFallbackName
4
- } from "./chunk-LAVZ2W6X.mjs";
4
+ } from "./chunk-6KU5DKP7.mjs";
5
5
  import {
6
6
  Markdown_exports
7
- } from "./chunk-BEE7VQPU.mjs";
7
+ } from "./chunk-XMT6PMU5.mjs";
8
8
  import {
9
9
  meta
10
10
  } from "./chunk-ODB2PTBP.mjs";
11
11
 
12
12
  // src/components/MarkdownCard/MarkdownCard.tsx
13
13
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
14
- import { pipe } from "effect";
14
+ import * as Function from "effect/Function";
15
15
  import React, { useCallback } from "react";
16
16
  import { LayoutAction, chain, createIntent, useIntentDispatcher } from "@dxos/app-framework";
17
17
  import { Obj } from "@dxos/echo";
18
18
  import { fullyQualifiedId } from "@dxos/react-client/echo";
19
- import { Button, Icon, useTranslation } from "@dxos/react-ui";
19
+ import { IconButton, useTranslation } from "@dxos/react-ui";
20
20
  import { Card } from "@dxos/react-ui-stack";
21
21
  import { DataType } from "@dxos/schema";
22
22
  var getTitle = (subject, fallback) => {
@@ -28,9 +28,9 @@ var getTitle = (subject, fallback) => {
28
28
  };
29
29
  var getSnippet = (subject, fallback) => {
30
30
  if (Obj.instanceOf(Markdown_exports.Document, subject)) {
31
- return getAbstract(subject.content?.target?.content ?? fallback);
31
+ return Obj.getDescription(subject) || getContentSnippet(subject.content?.target?.content ?? fallback);
32
32
  } else if (Obj.instanceOf(DataType.Text, subject)) {
33
- return getAbstract(subject.content);
33
+ return getContentSnippet(subject.content ?? fallback);
34
34
  }
35
35
  };
36
36
  var MarkdownCard = ({ subject, role }) => {
@@ -39,7 +39,7 @@ var MarkdownCard = ({ subject, role }) => {
39
39
  const { dispatchPromise: dispatch } = useIntentDispatcher();
40
40
  const { t } = useTranslation(meta.id);
41
41
  const snippet = getSnippet(subject, t("fallback abstract"));
42
- const handleNavigate = useCallback(() => dispatch(pipe(createIntent(LayoutAction.UpdatePopover, {
42
+ const handleNavigate = useCallback(() => dispatch(Function.pipe(createIntent(LayoutAction.UpdatePopover, {
43
43
  part: "popover",
44
44
  subject: null,
45
45
  options: {
@@ -57,15 +57,18 @@ var MarkdownCard = ({ subject, role }) => {
57
57
  ]);
58
58
  return /* @__PURE__ */ React.createElement(Card.SurfaceRoot, {
59
59
  role
60
- }, /* @__PURE__ */ React.createElement(Card.Heading, null, getTitle(subject, t("fallback title"))), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
61
- classNames: "line-clamp-3 break-words col-span-2"
62
- }, snippet), role === "card--popover" && /* @__PURE__ */ React.createElement(Card.Chrome, null, /* @__PURE__ */ React.createElement(Button, {
63
- onClick: handleNavigate
64
- }, /* @__PURE__ */ React.createElement("span", {
60
+ }, /* @__PURE__ */ React.createElement(Card.Heading, {
61
+ classNames: "flex items-center"
62
+ }, getTitle(subject, t("fallback title")), /* @__PURE__ */ React.createElement("span", {
65
63
  className: "grow"
66
- }, t("navigate to document label")), /* @__PURE__ */ React.createElement(Icon, {
67
- icon: "ph--arrow-right--regular"
68
- }))));
64
+ }), /* @__PURE__ */ React.createElement(IconButton, {
65
+ iconOnly: true,
66
+ icon: "ph--arrow-right--regular",
67
+ label: t("navigate to document label"),
68
+ onClick: handleNavigate
69
+ })), snippet && /* @__PURE__ */ React.createElement(Card.Text, {
70
+ classNames: "line-clamp-3 text-sm text-description"
71
+ }, snippet));
69
72
  } finally {
70
73
  _effect.f();
71
74
  }
@@ -77,4 +80,4 @@ export {
77
80
  MarkdownCard,
78
81
  MarkdownCard_default as default
79
82
  };
80
- //# sourceMappingURL=MarkdownCard-JLUQITYK.mjs.map
83
+ //# sourceMappingURL=MarkdownCard-AGWOTODZ.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,15 +1,15 @@
1
- import "./chunk-SUOK6YMI.mjs";
2
- import "./chunk-F6JJLKLN.mjs";
1
+ import "./chunk-Z5PDJNBV.mjs";
2
+ import "./chunk-HBBEHOP3.mjs";
3
3
  import {
4
4
  MarkdownCapabilities
5
5
  } from "./chunk-OY6CGPOO.mjs";
6
6
  import {
7
7
  getFallbackName,
8
8
  setFallbackName
9
- } from "./chunk-LAVZ2W6X.mjs";
9
+ } from "./chunk-6KU5DKP7.mjs";
10
10
  import {
11
11
  Markdown_exports
12
- } from "./chunk-BEE7VQPU.mjs";
12
+ } from "./chunk-XMT6PMU5.mjs";
13
13
  import {
14
14
  meta
15
15
  } from "./chunk-ODB2PTBP.mjs";
@@ -23,7 +23,8 @@ import { Capabilities, Surface, useAppGraph, useCapabilities as useCapabilities2
23
23
  import { DXN, Filter, Obj, Query, Type } from "@dxos/echo";
24
24
  import { ClientCapabilities } from "@dxos/plugin-client";
25
25
  import { SpaceCapabilities } from "@dxos/plugin-space";
26
- import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2, useQuery, useSpace } from "@dxos/react-client/echo";
26
+ import { useClient } from "@dxos/react-client";
27
+ import { fullyQualifiedId as fullyQualifiedId2, getSpace as getSpace2 } from "@dxos/react-client/echo";
27
28
  import { toLocalizedString as toLocalizedString2, useTranslation as useTranslation2 } from "@dxos/react-ui";
28
29
  import { insertAtCursor, insertAtLineStart } from "@dxos/react-ui-editor";
29
30
  import { DataType } from "@dxos/schema";
@@ -39,7 +40,7 @@ import { useIdentity } from "@dxos/react-client/halo";
39
40
  import { Icon, ThemeProvider } from "@dxos/react-ui";
40
41
  import { Cursor, EditorView, InputModeExtensions, createDataExtensions, decorateMarkdown, documentId, folding, formattingKeymap, linkTooltip, listener, preview, selectionState, typewriter } from "@dxos/react-ui-editor";
41
42
  import { defaultTx } from "@dxos/react-ui-theme";
42
- import { isNotFalsy } from "@dxos/util";
43
+ import { isTruthy } from "@dxos/util";
43
44
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-markdown/src/extensions.tsx";
44
45
  var useExtensions = ({ document, id, text, settings, selectionManager, viewMode, editorStateStore, previewOptions }) => {
45
46
  const { dispatchPromise: dispatch } = useIntentDispatcher();
@@ -111,7 +112,7 @@ var useExtensions = ({ document, id, text, settings, selectionManager, viewMode,
111
112
  }),
112
113
  baseExtensions,
113
114
  pluginExtensions
114
- ].filter(isNotFalsy), [
115
+ ].filter(isTruthy), [
115
116
  baseExtensions,
116
117
  pluginExtensions,
117
118
  document,
@@ -127,7 +128,7 @@ var createBaseExtensions = ({ document, id, dispatch, settings, selectionManager
127
128
  selectionManager && selectionChange(selectionManager),
128
129
  settings.editorInputMode && InputModeExtensions[settings.editorInputMode],
129
130
  settings.folding && folding()
130
- ].filter(isNotFalsy);
131
+ ].filter(isTruthy);
131
132
  if (viewMode !== "source") {
132
133
  extensions.push(...[
133
134
  formattingKeymap(),
@@ -237,14 +238,14 @@ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
237
238
  import React2, { forwardRef, useCallback, useEffect, useImperativeHandle, useMemo as useMemo3, useRef } from "react";
238
239
  import { useDropzone } from "react-dropzone";
239
240
  import { invariant as invariant3 } from "@dxos/invariant";
240
- import { toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
241
- 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";
241
+ import { Domino, toLocalizedString, useThemeContext, useTranslation } from "@dxos/react-ui";
242
+ import { EditorToolbar, PopoverMenuProvider, addLink, createBasicExtensions, createMarkdownExtensions, createThemeExtensions, dropFile, editorGutter, editorSlots, filterMenuGroups, formattingCommands, linkSlashCommands, processEditorPayload, stackItemContentEditorClassNames, useEditorToolbarState, useFormattingState, usePopoverMenu, useTextEditor } from "@dxos/react-ui-editor";
242
243
  import { StackItem } from "@dxos/react-ui-stack";
243
- import { isNonNullable, isNotFalsy as isNotFalsy2 } from "@dxos/util";
244
+ import { isNonNullable, isTruthy as isTruthy2 } from "@dxos/util";
244
245
 
245
246
  // src/hooks/useSelectCurrentThread.tsx
246
247
  import { EditorView as EditorView2 } from "@codemirror/view";
247
- import { Schema } from "effect";
248
+ import * as Schema from "effect/Schema";
248
249
  import { useMemo as useMemo2 } from "react";
249
250
  import { LayoutAction as LayoutAction2, createResolver, useIntentResolver } from "@dxos/app-framework";
250
251
  import { invariant as invariant2 } from "@dxos/invariant";
@@ -308,18 +309,20 @@ var MarkdownEditor = ({ extensions: extensionsParam, slashCommandGroups, onLinkQ
308
309
  var _effect = _useSignals();
309
310
  try {
310
311
  const { t } = useTranslation();
311
- const viewRef = useRef();
312
- const getMenu = useCallback((trigger, query) => {
312
+ const viewRef = useRef(null);
313
+ const getMenu = useCallback(({ text, trigger }) => {
313
314
  switch (trigger) {
314
- case "@":
315
- return onLinkQuery?.(query) ?? [];
315
+ case "@": {
316
+ return onLinkQuery?.(text) ?? [];
317
+ }
316
318
  case "/":
317
- default:
318
- return filterItems([
319
- coreSlashCommands,
319
+ default: {
320
+ return filterMenuGroups([
321
+ formattingCommands,
320
322
  linkSlashCommands,
321
323
  ...slashCommandGroups ?? []
322
- ], (item) => query ? toLocalizedString(item.label, t).toLowerCase().includes(query.toLowerCase()) : true);
324
+ ], (item) => text ? toLocalizedString(item.label, t).toLowerCase().includes(text.toLowerCase()) : true);
325
+ }
323
326
  }
324
327
  }, [
325
328
  onLinkQuery,
@@ -337,32 +340,30 @@ var MarkdownEditor = ({ extensions: extensionsParam, slashCommandGroups, onLinkQ
337
340
  trigger,
338
341
  placeholder: {
339
342
  delay: 3e3,
340
- 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()
343
+ 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()
341
344
  },
342
345
  getMenu
343
346
  };
344
347
  }, [
348
+ onLinkQuery,
345
349
  getMenu
346
350
  ]);
347
- const { commandMenu, groupsRef, currentItem, onSelect, ...refPopoverProps } = useCommandMenu(options);
351
+ const { groupsRef, extension, ...commandMenuProps } = usePopoverMenu(options);
348
352
  const extensions = useMemo3(() => [
349
353
  extensionsParam,
350
- commandMenu
351
- ].filter(isNotFalsy2), [
354
+ extension
355
+ ].filter(isTruthy2), [
352
356
  extensionsParam,
353
- commandMenu
357
+ extension
354
358
  ]);
355
- return /* @__PURE__ */ React2.createElement(RefPopover, {
356
- modal: false,
357
- ...refPopoverProps
359
+ return /* @__PURE__ */ React2.createElement(PopoverMenuProvider, {
360
+ view: viewRef.current,
361
+ groups: groupsRef.current,
362
+ ...commandMenuProps
358
363
  }, /* @__PURE__ */ React2.createElement(MarkdownEditorImpl, {
359
364
  ref: viewRef,
360
365
  ...props,
361
366
  extensions
362
- }), /* @__PURE__ */ React2.createElement(CommandMenu, {
363
- groups: groupsRef.current,
364
- currentItem,
365
- onSelect
366
367
  }));
367
368
  } finally {
368
369
  _effect.f();
@@ -415,7 +416,7 @@ var MarkdownEditorImpl = /* @__PURE__ */ forwardRef(({ id, role = "article", ini
415
416
  }),
416
417
  providerExtensions,
417
418
  extensions
418
- ].filter(isNotFalsy2),
419
+ ].filter(isTruthy2),
419
420
  ...role !== "section" && {
420
421
  id,
421
422
  scrollTo,
@@ -576,7 +577,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
576
577
  objectForms,
577
578
  schemaWhiteList
578
579
  ]);
579
- const onLinkQuery = useCallback2(async (query) => {
580
+ const handleLinkQuery = useCallback2(async (query) => {
580
581
  const name = query?.startsWith("@") ? query.slice(1).toLowerCase() : query?.toLowerCase() ?? "";
581
582
  const results = await space?.db.query(Query.select(filter)).run();
582
583
  const getLabel = (object2) => {
@@ -602,7 +603,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
602
603
  label,
603
604
  icon: metadata.icon,
604
605
  onSelect: (view, head) => {
605
- const link = `[${label}][${Obj.getDXN(object2)}]`;
606
+ const link = `[${label}](${Obj.getDXN(object2)})`;
606
607
  if (query?.startsWith("@")) {
607
608
  insertAtLineStart(view, head, `!${link}
608
609
  `);
@@ -632,7 +633,7 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
632
633
  settings,
633
634
  scrollPastEnd,
634
635
  onViewModeChange,
635
- onLinkQuery: space ? onLinkQuery : void 0
636
+ onLinkQuery: space ? handleLinkQuery : void 0
636
637
  }) : text ? /* @__PURE__ */ React3.createElement(MarkdownEditor, {
637
638
  id,
638
639
  role,
@@ -643,22 +644,19 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
643
644
  inputMode: settings.editorInputMode,
644
645
  scrollPastEnd,
645
646
  onViewModeChange,
646
- onLinkQuery: space ? onLinkQuery : void 0
647
- }) : (
648
- // TODO(burdon): Normalize with above.
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 ? onLinkQuery : void 0
660
- })
661
- );
647
+ onLinkQuery: space ? handleLinkQuery : void 0
648
+ }) : /* @__PURE__ */ React3.createElement(MarkdownEditor, {
649
+ id,
650
+ role,
651
+ initialValue: object.text,
652
+ extensions,
653
+ viewMode,
654
+ toolbar: settings.toolbar,
655
+ inputMode: settings.editorInputMode,
656
+ scrollPastEnd,
657
+ onViewModeChange,
658
+ onLinkQuery: space ? handleLinkQuery : void 0
659
+ });
662
660
  return /* @__PURE__ */ React3.createElement(React3.Fragment, null, editor, previewBlocks.map(({ link, el }) => /* @__PURE__ */ React3.createElement(PreviewBlock, {
663
661
  key: link.ref,
664
662
  link,
@@ -671,11 +669,9 @@ var MarkdownContainer = ({ id, role, object, settings, selectionManager, viewMod
671
669
  var PreviewBlock = ({ link, el }) => {
672
670
  var _effect = _useSignals2();
673
671
  try {
674
- const echoDXN = useMemo4(() => DXN.parse(link.ref).asEchoDXN(), [
675
- link.ref
676
- ]);
677
- const space = useSpace(echoDXN?.spaceId);
678
- const [subject] = useQuery(space, Query.select(Filter.ids(echoDXN?.echoId ?? "")));
672
+ const client = useClient();
673
+ const dxn = DXN.parse(link.ref);
674
+ const subject = client.graph.ref(dxn).target;
679
675
  const data = useMemo4(() => ({
680
676
  subject
681
677
  }), [
@@ -752,4 +748,4 @@ export {
752
748
  MarkdownContainer,
753
749
  MarkdownContainer_default as default
754
750
  };
755
- //# sourceMappingURL=MarkdownContainer-JW7TRDSA.mjs.map
751
+ //# sourceMappingURL=MarkdownContainer-MV2UNAUV.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,13 +1,13 @@
1
1
  import {
2
2
  Markdown_exports
3
- } from "./chunk-BEE7VQPU.mjs";
3
+ } from "./chunk-XMT6PMU5.mjs";
4
4
  import "./chunk-ODB2PTBP.mjs";
5
5
 
6
6
  // src/capabilities/anchor-sort.ts
7
7
  import { Capabilities, contributes } from "@dxos/app-framework";
8
8
  import { Type } from "@dxos/echo";
9
9
  import { createDocAccessor, getRangeFromCursor, getTarget } from "@dxos/react-client/echo";
10
- var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
10
+ var anchor_sort_default = (() => contributes(Capabilities.AnchorSort, {
11
11
  key: Type.getTypename(Markdown_exports.Document),
12
12
  sort: (anchorA, anchorB) => {
13
13
  const doc = getTarget(anchorA);
@@ -25,8 +25,8 @@ var anchor_sort_default = () => contributes(Capabilities.AnchorSort, {
25
25
  const posB = getStartPosition(anchorB.anchor);
26
26
  return posA - posB;
27
27
  }
28
- });
28
+ }));
29
29
  export {
30
30
  anchor_sort_default as default
31
31
  };
32
- //# sourceMappingURL=anchor-sort-E33BSTYF.mjs.map
32
+ //# sourceMappingURL=anchor-sort-YWJI3BKT.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,20 +1,20 @@
1
1
  import {
2
2
  translations
3
- } from "./chunk-Z7P6JGGW.mjs";
3
+ } from "./chunk-O6XUPW6S.mjs";
4
4
  import {
5
5
  MarkdownAction_exports,
6
6
  Markdown_exports
7
- } from "./chunk-BEE7VQPU.mjs";
7
+ } from "./chunk-XMT6PMU5.mjs";
8
8
  import "./chunk-ODB2PTBP.mjs";
9
9
 
10
10
  // src/capabilities/app-graph-serializer.ts
11
- import { pipe } from "effect";
11
+ import * as Function from "effect/Function";
12
12
  import { Capabilities, chain, contributes, createIntent } from "@dxos/app-framework";
13
13
  import { Obj } from "@dxos/echo";
14
14
  import { SpaceAction } from "@dxos/plugin-space/types";
15
15
  import { isSpace } from "@dxos/react-client/echo";
16
16
  import { DataType } from "@dxos/schema";
17
- var app_graph_serializer_default = (context) => contributes(Capabilities.AppGraphSerializer, [
17
+ var app_graph_serializer_default = ((context) => contributes(Capabilities.AppGraphSerializer, [
18
18
  {
19
19
  inputType: Markdown_exports.Document.typename,
20
20
  outputType: "text/markdown",
@@ -35,7 +35,7 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
35
35
  return;
36
36
  }
37
37
  const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
38
- const result = await dispatch(pipe(createIntent(MarkdownAction_exports.Create, {
38
+ const result = await dispatch(Function.pipe(createIntent(MarkdownAction_exports.Create, {
39
39
  name: data.name,
40
40
  content: data.data
41
41
  }), chain(SpaceAction.AddObject, {
@@ -44,8 +44,8 @@ var app_graph_serializer_default = (context) => contributes(Capabilities.AppGrap
44
44
  return result.data?.object;
45
45
  }
46
46
  }
47
- ]);
47
+ ]));
48
48
  export {
49
49
  app_graph_serializer_default as default
50
50
  };
51
- //# sourceMappingURL=app-graph-serializer-OX62DNPT.mjs.map
51
+ //# sourceMappingURL=app-graph-serializer-KYDFCUOW.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
+ }
@@ -1,11 +1,11 @@
1
1
  import {
2
2
  BLUEPRINT_KEY,
3
3
  blueprint_definition_default
4
- } from "./chunk-F6JJLKLN.mjs";
5
- import "./chunk-BEE7VQPU.mjs";
4
+ } from "./chunk-HBBEHOP3.mjs";
5
+ import "./chunk-XMT6PMU5.mjs";
6
6
  import "./chunk-ODB2PTBP.mjs";
7
7
  export {
8
8
  BLUEPRINT_KEY,
9
9
  blueprint_definition_default as default
10
10
  };
11
- //# sourceMappingURL=blueprint-definition-5YKFUHRU.mjs.map
11
+ //# sourceMappingURL=blueprint-definition-BHRMFZAC.mjs.map
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  Markdown_exports
3
- } from "./chunk-BEE7VQPU.mjs";
3
+ } from "./chunk-XMT6PMU5.mjs";
4
4
 
5
5
  // src/util.tsx
6
6
  import { debounce } from "@dxos/async";
@@ -11,8 +11,9 @@ var nonTitleChars = /[^\w ]/g;
11
11
  var getFallbackName = (content) => {
12
12
  return content.substring(0, 31).split("\n")[0].replaceAll(nonTitleChars, "").trim();
13
13
  };
14
- var getAbstract = (content) => {
15
- return content.substring(0, 128).split("\n")[0].replaceAll(nonTitleChars, "").trim();
14
+ var getContentSnippet = (content) => {
15
+ const abstract = content.split("\n").filter((line) => !line.startsWith("#")).filter((line) => line.trim() !== "")[0].replaceAll(nonTitleChars, "").trim();
16
+ return abstract;
16
17
  };
17
18
  var setFallbackName = debounce((doc, content) => {
18
19
  const name = getFallbackName(content);
@@ -43,8 +44,8 @@ export {
43
44
  isEditorModel,
44
45
  isMarkdownProperties,
45
46
  getFallbackName,
46
- getAbstract,
47
+ getContentSnippet,
47
48
  setFallbackName,
48
49
  serializer
49
50
  };
50
- //# sourceMappingURL=chunk-LAVZ2W6X.mjs.map
51
+ //# sourceMappingURL=chunk-6KU5DKP7.mjs.map