@dxos/plugin-deck 0.8.4-main.21d9917 → 0.8.4-main.2244d791bb

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 (158) hide show
  1. package/dist/lib/browser/{app-graph-builder-DTVCULQ4.mjs → app-graph-builder-X7LCO5KE.mjs} +13 -12
  2. package/dist/lib/browser/app-graph-builder-X7LCO5KE.mjs.map +7 -0
  3. package/dist/lib/browser/{check-app-scheme-JSRXXIYF.mjs → check-app-scheme-PGISDJX7.mjs} +8 -8
  4. package/dist/lib/browser/check-app-scheme-PGISDJX7.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-ATFPDN6J.mjs → chunk-DONG2FYU.mjs} +12 -9
  6. package/dist/lib/browser/chunk-DONG2FYU.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-EREEXCHO.mjs → chunk-JGC4ZLG3.mjs} +102 -81
  8. package/dist/lib/browser/chunk-JGC4ZLG3.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-UNG4CLLP.mjs → chunk-YT3AJVUU.mjs} +8 -8
  10. package/dist/lib/browser/chunk-YT3AJVUU.mjs.map +7 -0
  11. package/dist/lib/browser/index.mjs +36 -34
  12. package/dist/lib/browser/index.mjs.map +3 -3
  13. package/dist/lib/browser/meta.json +1 -1
  14. package/dist/lib/browser/{operation-resolver-CDYBLZJ4.mjs → operation-resolver-XJFR3PNQ.mjs} +86 -84
  15. package/dist/lib/browser/operation-resolver-XJFR3PNQ.mjs.map +7 -0
  16. package/dist/lib/browser/{react-root-LYNEKGHM.mjs → react-root-AJFHKHRL.mjs} +6 -6
  17. package/dist/lib/browser/react-root-AJFHKHRL.mjs.map +7 -0
  18. package/dist/lib/browser/{react-surface-RPKD7XUR.mjs → react-surface-KBRBGEXY.mjs} +11 -10
  19. package/dist/lib/browser/react-surface-KBRBGEXY.mjs.map +7 -0
  20. package/dist/lib/browser/{settings-OMHVGZ6V.mjs → settings-ES42FGLG.mjs} +5 -4
  21. package/dist/lib/browser/settings-ES42FGLG.mjs.map +7 -0
  22. package/dist/lib/browser/{state-OC3BSB6E.mjs → state-YMI6IDEL.mjs} +7 -6
  23. package/dist/lib/browser/state-YMI6IDEL.mjs.map +7 -0
  24. package/dist/lib/browser/{toolkit-R53LD3EA.mjs → toolkit-VRD54KY3.mjs} +8 -7
  25. package/dist/lib/browser/toolkit-VRD54KY3.mjs.map +7 -0
  26. package/dist/lib/browser/types/index.mjs +1 -1
  27. package/dist/lib/browser/{url-handler-53TE6JZO.mjs → url-handler-37UPOB3U.mjs} +11 -10
  28. package/dist/lib/browser/url-handler-37UPOB3U.mjs.map +7 -0
  29. package/dist/lib/node-esm/{app-graph-builder-473BNZDJ.mjs → app-graph-builder-US54I64T.mjs} +13 -12
  30. package/dist/lib/node-esm/app-graph-builder-US54I64T.mjs.map +7 -0
  31. package/dist/lib/node-esm/{check-app-scheme-IVYRHKRH.mjs → check-app-scheme-CK6EVG5D.mjs} +8 -8
  32. package/dist/lib/node-esm/check-app-scheme-CK6EVG5D.mjs.map +7 -0
  33. package/dist/lib/node-esm/{chunk-V6VEXRD4.mjs → chunk-7NPS347C.mjs} +102 -81
  34. package/dist/lib/node-esm/chunk-7NPS347C.mjs.map +7 -0
  35. package/dist/lib/node-esm/{chunk-XAKTY3EB.mjs → chunk-CVYHPJIN.mjs} +12 -9
  36. package/dist/lib/node-esm/chunk-CVYHPJIN.mjs.map +7 -0
  37. package/dist/lib/node-esm/{chunk-SKEVPQ7E.mjs → chunk-ZMJPCZ3V.mjs} +8 -8
  38. package/dist/lib/node-esm/chunk-ZMJPCZ3V.mjs.map +7 -0
  39. package/dist/lib/node-esm/index.mjs +36 -34
  40. package/dist/lib/node-esm/index.mjs.map +3 -3
  41. package/dist/lib/node-esm/meta.json +1 -1
  42. package/dist/lib/node-esm/{operation-resolver-WUOE33ID.mjs → operation-resolver-ZQGNATPX.mjs} +86 -84
  43. package/dist/lib/node-esm/operation-resolver-ZQGNATPX.mjs.map +7 -0
  44. package/dist/lib/node-esm/{react-root-L7H43AS3.mjs → react-root-2S77ABBS.mjs} +6 -6
  45. package/dist/lib/node-esm/react-root-2S77ABBS.mjs.map +7 -0
  46. package/dist/lib/node-esm/{react-surface-77DKVMDV.mjs → react-surface-FIHMAFXH.mjs} +11 -10
  47. package/dist/lib/node-esm/react-surface-FIHMAFXH.mjs.map +7 -0
  48. package/dist/lib/node-esm/{settings-2HB6FKIK.mjs → settings-E3TH3FAW.mjs} +5 -4
  49. package/dist/lib/node-esm/settings-E3TH3FAW.mjs.map +7 -0
  50. package/dist/lib/node-esm/{state-JRQ45ACJ.mjs → state-WQEFBQMD.mjs} +7 -6
  51. package/dist/lib/node-esm/state-WQEFBQMD.mjs.map +7 -0
  52. package/dist/lib/node-esm/{toolkit-JLPZNNKB.mjs → toolkit-ME546G5T.mjs} +8 -7
  53. package/dist/lib/node-esm/toolkit-ME546G5T.mjs.map +7 -0
  54. package/dist/lib/node-esm/types/index.mjs +1 -1
  55. package/dist/lib/node-esm/{url-handler-QGF2R24T.mjs → url-handler-2KYHXINK.mjs} +11 -10
  56. package/dist/lib/node-esm/url-handler-2KYHXINK.mjs.map +7 -0
  57. package/dist/types/src/DeckPlugin.d.ts.map +1 -1
  58. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -1
  59. package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts.map +1 -1
  60. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +2 -2
  61. package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -1
  62. package/dist/types/src/capabilities/react-root/react-root.d.ts.map +1 -1
  63. package/dist/types/src/capabilities/react-surface/index.d.ts +1 -1
  64. package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -1
  65. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +2 -2
  66. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -1
  67. package/dist/types/src/capabilities/settings/index.d.ts +1 -1
  68. package/dist/types/src/capabilities/settings/index.d.ts.map +1 -1
  69. package/dist/types/src/capabilities/settings/settings.d.ts +3 -2
  70. package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -1
  71. package/dist/types/src/capabilities/state/index.d.ts +2 -0
  72. package/dist/types/src/capabilities/state/index.d.ts.map +1 -1
  73. package/dist/types/src/capabilities/state/state.d.ts +2 -0
  74. package/dist/types/src/capabilities/state/state.d.ts.map +1 -1
  75. package/dist/types/src/capabilities/toolkit/index.d.ts +1 -1
  76. package/dist/types/src/capabilities/toolkit/index.d.ts.map +1 -1
  77. package/dist/types/src/capabilities/toolkit/toolkit.d.ts +3 -2
  78. package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +1 -1
  79. package/dist/types/src/capabilities/url-handler/url-handler.d.ts.map +1 -1
  80. package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +1 -1
  81. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +1 -0
  82. package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +1 -1
  83. package/dist/types/src/components/DeckLayout/Dialog.d.ts.map +1 -1
  84. package/dist/types/src/components/DeckLayout/Popover.d.ts.map +1 -1
  85. package/dist/types/src/components/DeckLayout/Toast.d.ts +3 -3
  86. package/dist/types/src/components/DeckLayout/Toast.d.ts.map +1 -1
  87. package/dist/types/src/components/Plank/Plank.d.ts.map +1 -1
  88. package/dist/types/src/components/Plank/Plank.stories.d.ts +1 -0
  89. package/dist/types/src/components/Plank/Plank.stories.d.ts.map +1 -1
  90. package/dist/types/src/components/Plank/PlankHeading.d.ts.map +1 -1
  91. package/dist/types/src/translations.d.ts +1 -0
  92. package/dist/types/src/translations.d.ts.map +1 -1
  93. package/dist/types/src/types/capabilities.d.ts +2 -0
  94. package/dist/types/src/types/capabilities.d.ts.map +1 -1
  95. package/dist/types/src/types/events.d.ts.map +1 -1
  96. package/dist/types/src/types/schema.d.ts +2 -0
  97. package/dist/types/src/types/schema.d.ts.map +1 -1
  98. package/dist/types/tsconfig.tsbuildinfo +1 -1
  99. package/package.json +43 -42
  100. package/src/DeckPlugin.ts +12 -11
  101. package/src/capabilities/app-graph-builder/app-graph-builder.ts +11 -10
  102. package/src/capabilities/check-app-scheme/check-app-scheme.ts +12 -8
  103. package/src/capabilities/operation-resolver/operation-resolver.ts +95 -80
  104. package/src/capabilities/react-root/react-root.tsx +2 -2
  105. package/src/capabilities/react-surface/react-surface.tsx +8 -7
  106. package/src/capabilities/settings/settings.ts +3 -2
  107. package/src/capabilities/state/state.ts +5 -4
  108. package/src/capabilities/toolkit/toolkit.ts +6 -5
  109. package/src/capabilities/url-handler/url-handler.ts +8 -7
  110. package/src/components/DeckLayout/ActiveNode.tsx +3 -2
  111. package/src/components/DeckLayout/Banner.tsx +4 -4
  112. package/src/components/DeckLayout/ContentEmpty.tsx +2 -2
  113. package/src/components/DeckLayout/DeckLayout.stories.tsx +5 -4
  114. package/src/components/DeckLayout/DeckMain.tsx +7 -7
  115. package/src/components/DeckLayout/Dialog.tsx +9 -3
  116. package/src/components/DeckLayout/Popover.tsx +21 -5
  117. package/src/components/DeckLayout/StatusBar.tsx +3 -3
  118. package/src/components/DeckLayout/Toast.tsx +3 -3
  119. package/src/components/DeckSettings/DeckSettings.tsx +21 -21
  120. package/src/components/Plank/Plank.stories.tsx +4 -3
  121. package/src/components/Plank/Plank.tsx +5 -4
  122. package/src/components/Plank/PlankControls.tsx +1 -1
  123. package/src/components/Plank/PlankHeading.tsx +7 -6
  124. package/src/components/Sidebar/ComplementarySidebar.tsx +19 -15
  125. package/src/components/Sidebar/Sidebar.tsx +2 -2
  126. package/src/components/Sidebar/SidebarButton.tsx +9 -9
  127. package/src/hooks/useCompanions.ts +1 -1
  128. package/src/hooks/useDeckCompanions.ts +1 -1
  129. package/src/hooks/useDeckState.ts +3 -3
  130. package/src/hooks/useHoistStatusbar.ts +1 -1
  131. package/src/translations.ts +1 -0
  132. package/src/types/capabilities.ts +2 -2
  133. package/src/types/events.ts +4 -3
  134. package/src/types/schema.ts +7 -3
  135. package/dist/lib/browser/app-graph-builder-DTVCULQ4.mjs.map +0 -7
  136. package/dist/lib/browser/check-app-scheme-JSRXXIYF.mjs.map +0 -7
  137. package/dist/lib/browser/chunk-ATFPDN6J.mjs.map +0 -7
  138. package/dist/lib/browser/chunk-EREEXCHO.mjs.map +0 -7
  139. package/dist/lib/browser/chunk-UNG4CLLP.mjs.map +0 -7
  140. package/dist/lib/browser/operation-resolver-CDYBLZJ4.mjs.map +0 -7
  141. package/dist/lib/browser/react-root-LYNEKGHM.mjs.map +0 -7
  142. package/dist/lib/browser/react-surface-RPKD7XUR.mjs.map +0 -7
  143. package/dist/lib/browser/settings-OMHVGZ6V.mjs.map +0 -7
  144. package/dist/lib/browser/state-OC3BSB6E.mjs.map +0 -7
  145. package/dist/lib/browser/toolkit-R53LD3EA.mjs.map +0 -7
  146. package/dist/lib/browser/url-handler-53TE6JZO.mjs.map +0 -7
  147. package/dist/lib/node-esm/app-graph-builder-473BNZDJ.mjs.map +0 -7
  148. package/dist/lib/node-esm/check-app-scheme-IVYRHKRH.mjs.map +0 -7
  149. package/dist/lib/node-esm/chunk-SKEVPQ7E.mjs.map +0 -7
  150. package/dist/lib/node-esm/chunk-V6VEXRD4.mjs.map +0 -7
  151. package/dist/lib/node-esm/chunk-XAKTY3EB.mjs.map +0 -7
  152. package/dist/lib/node-esm/operation-resolver-WUOE33ID.mjs.map +0 -7
  153. package/dist/lib/node-esm/react-root-L7H43AS3.mjs.map +0 -7
  154. package/dist/lib/node-esm/react-surface-77DKVMDV.mjs.map +0 -7
  155. package/dist/lib/node-esm/settings-2HB6FKIK.mjs.map +0 -7
  156. package/dist/lib/node-esm/state-JRQ45ACJ.mjs.map +0 -7
  157. package/dist/lib/node-esm/toolkit-JLPZNNKB.mjs.map +0 -7
  158. package/dist/lib/node-esm/url-handler-QGF2R24T.mjs.map +0 -7
@@ -1,23 +1,24 @@
1
1
  import {
2
2
  Banner,
3
3
  DeckSettings
4
- } from "./chunk-EREEXCHO.mjs";
5
- import "./chunk-UNG4CLLP.mjs";
4
+ } from "./chunk-JGC4ZLG3.mjs";
5
+ import "./chunk-YT3AJVUU.mjs";
6
6
  import "./chunk-NHABISX2.mjs";
7
7
  import {
8
8
  meta
9
- } from "./chunk-ATFPDN6J.mjs";
9
+ } from "./chunk-DONG2FYU.mjs";
10
10
 
11
11
  // src/capabilities/react-surface/react-surface.tsx
12
12
  import * as Effect from "effect/Effect";
13
13
  import React from "react";
14
- import { Capability, Common } from "@dxos/app-framework";
15
- import { useSettingsState } from "@dxos/app-framework/react";
16
- var react_surface_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(Common.Capability.ReactSurface, [
17
- Common.createSurface({
14
+ import { Capabilities, Capability } from "@dxos/app-framework";
15
+ import { Surface, useSettingsState } from "@dxos/app-framework/ui";
16
+ import { AppCapabilities } from "@dxos/app-toolkit";
17
+ var react_surface_default = Capability.makeModule(() => Effect.succeed(Capability.contributes(Capabilities.ReactSurface, [
18
+ Surface.create({
18
19
  id: `${meta.id}/plugin-settings`,
19
20
  role: "article",
20
- filter: (data) => Common.Capability.isSettings(data.subject) && data.subject.prefix === meta.id,
21
+ filter: (data) => AppCapabilities.isSettings(data.subject) && data.subject.prefix === meta.id,
21
22
  component: ({ data: { subject } }) => {
22
23
  const { settings, updateSettings } = useSettingsState(subject.atom);
23
24
  return /* @__PURE__ */ React.createElement(DeckSettings, {
@@ -26,7 +27,7 @@ var react_surface_default = Capability.makeModule(() => Effect.succeed(Capabilit
26
27
  });
27
28
  }
28
29
  }),
29
- Common.createSurface({
30
+ Surface.create({
30
31
  id: `${meta.id}/banner`,
31
32
  role: "banner",
32
33
  component: ({ data }) => {
@@ -39,4 +40,4 @@ var react_surface_default = Capability.makeModule(() => Effect.succeed(Capabilit
39
40
  export {
40
41
  react_surface_default as default
41
42
  };
42
- //# sourceMappingURL=react-surface-RPKD7XUR.mjs.map
43
+ //# sourceMappingURL=react-surface-KBRBGEXY.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/react-surface/react-surface.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\nimport React from 'react';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { Surface, useSettingsState } from '@dxos/app-framework/ui';\nimport { AppCapabilities } from '@dxos/app-toolkit';\n\nimport { Banner, DeckSettings } from '../../components';\nimport { meta } from '../../meta';\nimport { type DeckSettingsProps } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.succeed(\n Capability.contributes(Capabilities.ReactSurface, [\n Surface.create({\n id: `${meta.id}/plugin-settings`,\n role: 'article',\n filter: (data): data is { subject: AppCapabilities.Settings } =>\n AppCapabilities.isSettings(data.subject) && data.subject.prefix === meta.id,\n component: ({ data: { subject } }) => {\n const { settings, updateSettings } = useSettingsState<DeckSettingsProps>(subject.atom);\n return <DeckSettings settings={settings} onSettingsChange={updateSettings} />;\n },\n }),\n Surface.create({\n id: `${meta.id}/banner`,\n role: 'banner',\n component: ({ data }: { data: { variant?: 'topbar' | 'sidebar' } }) => {\n return <Banner variant={data.variant} />;\n },\n }),\n ]),\n ),\n);\n"],
5
+ "mappings": ";;;;;;;;;;;AAIA,YAAYA,YAAY;AACxB,OAAOC,WAAW;AAElB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,SAASC,wBAAwB;AAC1C,SAASC,uBAAuB;AAMhC,IAAA,wBAAeC,WAAWC,WAAW,MAC5BC,eACLF,WAAWG,YAAYC,aAAaC,cAAc;EAChDC,QAAQC,OAAO;IACbC,IAAI,GAAGC,KAAKD,EAAE;IACdE,MAAM;IACNC,QAAQ,CAACC,SACPC,gBAAgBC,WAAWF,KAAKG,OAAO,KAAKH,KAAKG,QAAQC,WAAWP,KAAKD;IAC3ES,WAAW,CAAC,EAAEL,MAAM,EAAEG,QAAO,EAAE,MAAE;AAC/B,YAAM,EAAEG,UAAUC,eAAc,IAAKC,iBAAoCL,QAAQM,IAAI;AACrF,aAAO,sBAAA,cAACC,cAAAA;QAAaJ;QAAoBK,kBAAkBJ;;IAC7D;EACF,CAAA;EACAb,QAAQC,OAAO;IACbC,IAAI,GAAGC,KAAKD,EAAE;IACdE,MAAM;IACNO,WAAW,CAAC,EAAEL,KAAI,MAAgD;AAChE,aAAO,sBAAA,cAACY,QAAAA;QAAOC,SAASb,KAAKa;;IAC/B;EACF,CAAA;CACD,CAAA,CAAA;",
6
+ "names": ["Effect", "React", "Capabilities", "Capability", "Surface", "useSettingsState", "AppCapabilities", "Capability", "makeModule", "succeed", "contributes", "Capabilities", "ReactSurface", "Surface", "create", "id", "meta", "role", "filter", "data", "AppCapabilities", "isSettings", "subject", "prefix", "component", "settings", "updateSettings", "useSettingsState", "atom", "DeckSettings", "onSettingsChange", "Banner", "variant"]
7
+ }
@@ -2,11 +2,12 @@ import {
2
2
  DeckCapabilities,
3
3
  DeckSettingsSchema,
4
4
  meta
5
- } from "./chunk-ATFPDN6J.mjs";
5
+ } from "./chunk-DONG2FYU.mjs";
6
6
 
7
7
  // src/capabilities/settings/settings.ts
8
8
  import * as Effect from "effect/Effect";
9
- import { Capability, Common } from "@dxos/app-framework";
9
+ import { Capability } from "@dxos/app-framework";
10
+ import { AppCapabilities } from "@dxos/app-toolkit";
10
11
  import { createKvsStore } from "@dxos/effect";
11
12
  var settings_default = Capability.makeModule(() => Effect.sync(() => {
12
13
  const settingsAtom = createKvsStore({
@@ -24,7 +25,7 @@ var settings_default = Capability.makeModule(() => Effect.sync(() => {
24
25
  });
25
26
  return [
26
27
  Capability.contributes(DeckCapabilities.Settings, settingsAtom),
27
- Capability.contributes(Common.Capability.Settings, {
28
+ Capability.contributes(AppCapabilities.Settings, {
28
29
  prefix: meta.id,
29
30
  schema: DeckSettingsSchema,
30
31
  atom: settingsAtom
@@ -34,4 +35,4 @@ var settings_default = Capability.makeModule(() => Effect.sync(() => {
34
35
  export {
35
36
  settings_default as default
36
37
  };
37
- //# sourceMappingURL=settings-OMHVGZ6V.mjs.map
38
+ //# sourceMappingURL=settings-ES42FGLG.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/settings/settings.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { createKvsStore } from '@dxos/effect';\n\nimport { meta } from '../../meta';\nimport { DeckCapabilities, DeckSettingsSchema } from '../../types';\n\nexport default Capability.makeModule(() =>\n Effect.sync(() => {\n const settingsAtom = createKvsStore({\n key: meta.id,\n schema: DeckSettingsSchema,\n defaultValue: () => ({\n showHints: false,\n enableDeck: false,\n enableStatusbar: false,\n enableNativeRedirect: false,\n newPlankPositioning: 'start' as const,\n overscroll: 'none' as const,\n encapsulatedPlanks: false,\n }),\n });\n\n return [\n Capability.contributes(DeckCapabilities.Settings, settingsAtom),\n Capability.contributes(AppCapabilities.Settings, {\n prefix: meta.id,\n schema: DeckSettingsSchema,\n atom: settingsAtom,\n }),\n ];\n }),\n);\n"],
5
+ "mappings": ";;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,kBAAkB;AAC3B,SAASC,uBAAuB;AAChC,SAASC,sBAAsB;AAK/B,IAAA,mBAAeC,WAAWC,WAAW,MAC5BC,YAAK,MAAA;AACV,QAAMC,eAAeC,eAAe;IAClCC,KAAKC,KAAKC;IACVC,QAAQC;IACRC,cAAc,OAAO;MACnBC,WAAW;MACXC,YAAY;MACZC,iBAAiB;MACjBC,sBAAsB;MACtBC,qBAAqB;MACrBC,YAAY;MACZC,oBAAoB;IACtB;EACF,CAAA;AAEA,SAAO;IACLjB,WAAWkB,YAAYC,iBAAiBC,UAAUjB,YAAAA;IAClDH,WAAWkB,YAAYG,gBAAgBD,UAAU;MAC/CE,QAAQhB,KAAKC;MACbC,QAAQC;MACRc,MAAMpB;IACR,CAAA;;AAEJ,CAAA,CAAA;",
6
+ "names": ["Effect", "Capability", "AppCapabilities", "createKvsStore", "Capability", "makeModule", "sync", "settingsAtom", "createKvsStore", "key", "meta", "id", "schema", "DeckSettingsSchema", "defaultValue", "showHints", "enableDeck", "enableStatusbar", "enableNativeRedirect", "newPlankPositioning", "overscroll", "encapsulatedPlanks", "contributes", "DeckCapabilities", "Settings", "AppCapabilities", "prefix", "atom"]
7
+ }
@@ -4,12 +4,13 @@ import {
4
4
  defaultDeck,
5
5
  getMode,
6
6
  meta
7
- } from "./chunk-ATFPDN6J.mjs";
7
+ } from "./chunk-DONG2FYU.mjs";
8
8
 
9
9
  // src/capabilities/state/state.ts
10
10
  import { Atom } from "@effect-atom/atom-react";
11
11
  import * as Effect from "effect/Effect";
12
- import { Capability, Common } from "@dxos/app-framework";
12
+ import { Capabilities, Capability } from "@dxos/app-framework";
13
+ import { AppCapabilities } from "@dxos/app-toolkit";
13
14
  import { createKvsStore } from "@dxos/effect";
14
15
  import { invariant } from "@dxos/invariant";
15
16
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-deck/src/capabilities/state/state.ts";
@@ -40,7 +41,7 @@ var defaultDeckEphemeralState = {
40
41
  scrollIntoView: void 0
41
42
  };
42
43
  var state_default = Capability.makeModule(Effect.fnUntraced(function* () {
43
- const registry = yield* Capability.get(Common.Capability.AtomRegistry);
44
+ const registry = yield* Capability.get(Capabilities.AtomRegistry);
44
45
  const stateAtom = createKvsStore({
45
46
  key: `${meta.id}/state`,
46
47
  schema: DeckStateSchema,
@@ -71,7 +72,7 @@ var state_default = Capability.makeModule(Effect.fnUntraced(function* () {
71
72
  const deck = state.decks[state.activeDeck];
72
73
  invariant(deck, `Deck not found: ${state.activeDeck}`, {
73
74
  F: __dxlog_file,
74
- L: 85,
75
+ L: 86,
75
76
  S: this,
76
77
  A: [
77
78
  "deck",
@@ -94,10 +95,10 @@ var state_default = Capability.makeModule(Effect.fnUntraced(function* () {
94
95
  return [
95
96
  Capability.contributes(DeckCapabilities.State, stateAtom),
96
97
  Capability.contributes(DeckCapabilities.EphemeralState, ephemeralAtom),
97
- Capability.contributes(Common.Capability.Layout, layoutAtom)
98
+ Capability.contributes(AppCapabilities.Layout, layoutAtom)
98
99
  ];
99
100
  }));
100
101
  export {
101
102
  state_default as default
102
103
  };
103
- //# sourceMappingURL=state-OC3BSB6E.mjs.map
104
+ //# sourceMappingURL=state-YMI6IDEL.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/state/state.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Atom } from '@effect-atom/atom-react';\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { AppCapabilities } from '@dxos/app-toolkit';\nimport { createKvsStore } from '@dxos/effect';\nimport { invariant } from '@dxos/invariant';\n\nimport { meta } from '../../meta';\nimport {\n DeckCapabilities,\n type DeckEphemeralStateProps,\n type DeckStateProps,\n DeckStateSchema,\n defaultDeck,\n getMode,\n} from '../../types';\n\n/** Default persisted state. */\nconst defaultDeckState: DeckStateProps = {\n sidebarState: 'expanded',\n complementarySidebarState: 'collapsed',\n complementarySidebarPanel: undefined,\n activeDeck: 'default',\n previousDeck: 'default',\n decks: {\n default: { ...defaultDeck },\n },\n previousMode: {},\n};\n\n/** Default ephemeral state. */\nconst defaultDeckEphemeralState: DeckEphemeralStateProps = {\n dialogContent: null,\n dialogOpen: false,\n dialogBlockAlign: undefined,\n dialogType: undefined,\n popoverContent: null,\n popoverAnchor: undefined,\n popoverAnchorId: undefined,\n popoverOpen: false,\n toasts: [],\n currentUndoId: undefined,\n scrollIntoView: undefined,\n};\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const registry = yield* Capability.get(Capabilities.AtomRegistry);\n\n // Persisted state using KVS store.\n const stateAtom = createKvsStore({\n key: `${meta.id}/state`,\n schema: DeckStateSchema,\n defaultValue: () => ({ ...defaultDeckState }),\n });\n\n // Ephemeral state (not persisted, but kept alive to prevent GC resets).\n const ephemeralAtom = Atom.make<DeckEphemeralStateProps>({ ...defaultDeckEphemeralState }).pipe(Atom.keepAlive);\n\n // Don't allow fullscreen mode to be persisted to prevent getting stuck in it.\n const currentState = registry.get(stateAtom);\n const currentDeck = currentState.decks[currentState.activeDeck];\n if (currentDeck?.fullscreen) {\n registry.set(stateAtom, {\n ...currentState,\n decks: {\n ...currentState.decks,\n [currentState.activeDeck]: {\n ...currentDeck,\n fullscreen: false,\n },\n },\n });\n }\n\n // Create derived layout atom (read-only) from both state atoms.\n const layoutAtom = Atom.make((get) => {\n const state = get(stateAtom);\n const ephemeral = get(ephemeralAtom);\n const deck = state.decks[state.activeDeck];\n invariant(deck, `Deck not found: ${state.activeDeck}`);\n return {\n mode: getMode(deck),\n dialogOpen: ephemeral.dialogOpen,\n sidebarOpen: state.sidebarState === 'expanded',\n complementarySidebarOpen: state.complementarySidebarState === 'expanded',\n workspace: state.activeDeck,\n active: deck.solo ? [deck.solo] : deck.active,\n inactive: deck.inactive,\n scrollIntoView: ephemeral.scrollIntoView,\n } satisfies AppCapabilities.Layout;\n }).pipe(Atom.keepAlive);\n\n return [\n Capability.contributes(DeckCapabilities.State, stateAtom),\n Capability.contributes(DeckCapabilities.EphemeralState, ephemeralAtom),\n Capability.contributes(AppCapabilities.Layout, layoutAtom),\n ];\n }),\n);\n"],
5
+ "mappings": ";;;;;;;;;AAIA,SAASA,YAAY;AACrB,YAAYC,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,uBAAuB;AAChC,SAASC,sBAAsB;AAC/B,SAASC,iBAAiB;;AAa1B,IAAMC,mBAAmC;EACvCC,cAAc;EACdC,2BAA2B;EAC3BC,2BAA2BC;EAC3BC,YAAY;EACZC,cAAc;EACdC,OAAO;IACLC,SAAS;MAAE,GAAGC;IAAY;EAC5B;EACAC,cAAc,CAAC;AACjB;AAGA,IAAMC,4BAAqD;EACzDC,eAAe;EACfC,YAAY;EACZC,kBAAkBV;EAClBW,YAAYX;EACZY,gBAAgB;EAChBC,eAAeb;EACfc,iBAAiBd;EACjBe,aAAa;EACbC,QAAQ,CAAA;EACRC,eAAejB;EACfkB,gBAAgBlB;AAClB;AAEA,IAAA,gBAAemB,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAMC,WAAW,OAAOH,WAAWI,IAAIC,aAAaC,YAAY;AAGhE,QAAMC,YAAYC,eAAe;IAC/BC,KAAK,GAAGC,KAAKC,EAAE;IACfC,QAAQC;IACRC,cAAc,OAAO;MAAE,GAAGrC;IAAiB;EAC7C,CAAA;AAGA,QAAMsC,gBAAgBC,KAAKC,KAA8B;IAAE,GAAG7B;EAA0B,CAAA,EAAG8B,KAAKF,KAAKG,SAAS;AAG9G,QAAMC,eAAejB,SAASC,IAAIG,SAAAA;AAClC,QAAMc,cAAcD,aAAapC,MAAMoC,aAAatC,UAAU;AAC9D,MAAIuC,aAAaC,YAAY;AAC3BnB,aAASoB,IAAIhB,WAAW;MACtB,GAAGa;MACHpC,OAAO;QACL,GAAGoC,aAAapC;QAChB,CAACoC,aAAatC,UAAU,GAAG;UACzB,GAAGuC;UACHC,YAAY;QACd;MACF;IACF,CAAA;EACF;AAGA,QAAME,aAAaR,KAAKC,KAAK,CAACb,QAAAA;AAC5B,UAAMqB,QAAQrB,IAAIG,SAAAA;AAClB,UAAMmB,YAAYtB,IAAIW,aAAAA;AACtB,UAAMY,OAAOF,MAAMzC,MAAMyC,MAAM3C,UAAU;AACzC8C,cAAUD,MAAM,mBAAmBF,MAAM3C,UAAU,IAAE;;;;;;;;;AACrD,WAAO;MACL+C,MAAMC,QAAQH,IAAAA;MACdrC,YAAYoC,UAAUpC;MACtByC,aAAaN,MAAM/C,iBAAiB;MACpCsD,0BAA0BP,MAAM9C,8BAA8B;MAC9DsD,WAAWR,MAAM3C;MACjBoD,QAAQP,KAAKQ,OAAO;QAACR,KAAKQ;UAAQR,KAAKO;MACvCE,UAAUT,KAAKS;MACfrC,gBAAgB2B,UAAU3B;IAC5B;EACF,CAAA,EAAGmB,KAAKF,KAAKG,SAAS;AAEtB,SAAO;IACLnB,WAAWqC,YAAYC,iBAAiBC,OAAOhC,SAAAA;IAC/CP,WAAWqC,YAAYC,iBAAiBE,gBAAgBzB,aAAAA;IACxDf,WAAWqC,YAAYI,gBAAgBC,QAAQlB,UAAAA;;AAEnD,CAAA,CAAA;",
6
+ "names": ["Atom", "Effect", "Capabilities", "Capability", "AppCapabilities", "createKvsStore", "invariant", "defaultDeckState", "sidebarState", "complementarySidebarState", "complementarySidebarPanel", "undefined", "activeDeck", "previousDeck", "decks", "default", "defaultDeck", "previousMode", "defaultDeckEphemeralState", "dialogContent", "dialogOpen", "dialogBlockAlign", "dialogType", "popoverContent", "popoverAnchor", "popoverAnchorId", "popoverOpen", "toasts", "currentUndoId", "scrollIntoView", "Capability", "makeModule", "fnUntraced", "registry", "get", "Capabilities", "AtomRegistry", "stateAtom", "createKvsStore", "key", "meta", "id", "schema", "DeckStateSchema", "defaultValue", "ephemeralAtom", "Atom", "make", "pipe", "keepAlive", "currentState", "currentDeck", "fullscreen", "set", "layoutAtom", "state", "ephemeral", "deck", "invariant", "mode", "getMode", "sidebarOpen", "complementarySidebarOpen", "workspace", "active", "solo", "inactive", "contributes", "DeckCapabilities", "State", "EphemeralState", "AppCapabilities", "Layout"]
7
+ }
@@ -1,13 +1,14 @@
1
1
  import {
2
2
  DeckCapabilities
3
- } from "./chunk-ATFPDN6J.mjs";
3
+ } from "./chunk-DONG2FYU.mjs";
4
4
 
5
5
  // src/capabilities/toolkit/toolkit.ts
6
6
  import * as Tool from "@effect/ai/Tool";
7
7
  import * as Toolkit from "@effect/ai/Toolkit";
8
8
  import * as Effect from "effect/Effect";
9
9
  import * as Schema from "effect/Schema";
10
- import { Capability, Common } from "@dxos/app-framework";
10
+ import { Capabilities, Capability } from "@dxos/app-framework";
11
+ import { AppCapabilities, LayoutOperation } from "@dxos/app-toolkit";
11
12
  import { GenericToolkit } from "@dxos/assistant";
12
13
  import { ArtifactId } from "@dxos/assistant";
13
14
  import { trim } from "@dxos/util";
@@ -25,15 +26,15 @@ var Toolkit$ = Toolkit.make(Tool.make("open-item", {
25
26
  DeckToolkit2.Toolkit = Toolkit$;
26
27
  DeckToolkit2.createLayer = (capabilityManager) => Toolkit$.toLayer({
27
28
  "open-item": ({ id }) => Effect.gen(function* () {
28
- const registry = capabilityManager.get(Common.Capability.AtomRegistry);
29
+ const registry = capabilityManager.get(Capabilities.AtomRegistry);
29
30
  const stateAtom = capabilityManager.get(DeckCapabilities.State);
30
31
  const state = registry.get(stateAtom);
31
32
  const dxn = ArtifactId.toDXN(id, state.activeDeck).asEchoDXN();
32
33
  if (!dxn) {
33
34
  throw new Error(`Invalid object ID: ${id}`);
34
35
  }
35
- const { invoke } = capabilityManager.get(Common.Capability.OperationInvoker);
36
- yield* invoke(Common.LayoutOperation.Open, {
36
+ const { invoke } = capabilityManager.get(Capabilities.OperationInvoker);
37
+ yield* invoke(LayoutOperation.Open, {
37
38
  subject: [
38
39
  `${dxn.spaceId}:${dxn.echoId}`
39
40
  ]
@@ -43,11 +44,11 @@ var Toolkit$ = Toolkit.make(Tool.make("open-item", {
43
44
  })(DeckToolkit || (DeckToolkit = {}));
44
45
  var toolkit_default = Capability.makeModule(Effect.fnUntraced(function* () {
45
46
  const capabilityManager = yield* Capability.Service;
46
- return Capability.contributes(Common.Capability.Toolkit, GenericToolkit.make(DeckToolkit.Toolkit, DeckToolkit.createLayer(capabilityManager)));
47
+ return Capability.contributes(AppCapabilities.Toolkit, GenericToolkit.make(DeckToolkit.Toolkit, DeckToolkit.createLayer(capabilityManager)));
47
48
  }));
48
49
  var DeckToolkit;
49
50
  export {
50
51
  DeckToolkit,
51
52
  toolkit_default as default
52
53
  };
53
- //# sourceMappingURL=toolkit-R53LD3EA.mjs.map
54
+ //# sourceMappingURL=toolkit-VRD54KY3.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/toolkit/toolkit.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Tool from '@effect/ai/Tool';\nimport * as Toolkit from '@effect/ai/Toolkit';\nimport * as Effect from 'effect/Effect';\nimport * as Schema from 'effect/Schema';\n\nimport { Capabilities, Capability, type CapabilityManager } from '@dxos/app-framework';\nimport { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';\nimport { GenericToolkit } from '@dxos/assistant';\nimport { ArtifactId } from '@dxos/assistant';\nimport { type SpaceId } from '@dxos/keys';\nimport { trim } from '@dxos/util';\n\nimport { DeckCapabilities } from '../../types';\n\nconst Toolkit$ = Toolkit.make(\n Tool.make('open-item', {\n description: trim`\n Opens an item in the application.\n `,\n parameters: {\n id: ArtifactId,\n },\n success: Schema.Any,\n failure: Schema.Never,\n }),\n);\n\nexport namespace DeckToolkit {\n export const Toolkit = Toolkit$;\n\n export const createLayer = (capabilityManager: CapabilityManager.CapabilityManager) =>\n Toolkit$.toLayer({\n 'open-item': ({ id }) =>\n Effect.gen(function* () {\n const registry = capabilityManager.get(Capabilities.AtomRegistry);\n const stateAtom = capabilityManager.get(DeckCapabilities.State);\n const state = registry.get(stateAtom);\n const dxn = ArtifactId.toDXN(id, state.activeDeck as SpaceId).asEchoDXN();\n if (!dxn) {\n // TODO(wittjosiah): Support other variants.\n throw new Error(`Invalid object ID: ${id}`);\n }\n\n // TODO(wittjosiah): Get capabilities via layers.\n const { invoke } = capabilityManager.get(Capabilities.OperationInvoker);\n yield* invoke(LayoutOperation.Open, { subject: [`${dxn.spaceId!}:${dxn.echoId}`] });\n }).pipe(Effect.orDie),\n });\n}\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const capabilityManager = yield* Capability.Service;\n\n return Capability.contributes(\n AppCapabilities.Toolkit,\n GenericToolkit.make(DeckToolkit.Toolkit, DeckToolkit.createLayer(capabilityManager)),\n );\n }),\n);\n"],
5
+ "mappings": ";;;;;AAIA,YAAYA,UAAU;AACtB,YAAYC,aAAa;AACzB,YAAYC,YAAY;AACxB,YAAYC,YAAY;AAExB,SAASC,cAAcC,kBAA0C;AACjE,SAASC,iBAAiBC,uBAAuB;AACjD,SAASC,sBAAsB;AAC/B,SAASC,kBAAkB;AAE3B,SAASC,YAAY;AAIrB,IAAMC,WAAmBC,aAClBA,UAAK,aAAa;EACrBC,aAAaC;;;EAGbC,YAAY;IACVC,IAAIC;EACN;EACAC,SAAgBC;EAChBC,SAAgBC;AAClB,CAAA,CAAA;UAGeC,cAAAA;eACFC,UAAUZ;eAEVa,cAAc,CAACC,sBAC1Bd,SAASe,QAAQ;IACf,aAAa,CAAC,EAAEV,GAAE,MACTW,WAAI,aAAA;AACT,YAAMC,WAAWH,kBAAkBI,IAAIC,aAAaC,YAAY;AAChE,YAAMC,YAAYP,kBAAkBI,IAAII,iBAAiBC,KAAK;AAC9D,YAAMC,QAAQP,SAASC,IAAIG,SAAAA;AAC3B,YAAMI,MAAMnB,WAAWoB,MAAMrB,IAAImB,MAAMG,UAAU,EAAaC,UAAS;AACvE,UAAI,CAACH,KAAK;AAER,cAAM,IAAII,MAAM,sBAAsBxB,EAAAA,EAAI;MAC5C;AAGA,YAAM,EAAEyB,OAAM,IAAKhB,kBAAkBI,IAAIC,aAAaY,gBAAgB;AACtE,aAAOD,OAAOE,gBAAgBC,MAAM;QAAEC,SAAS;UAAC,GAAGT,IAAIU,OAAO,IAAKV,IAAIW,MAAM;;MAAI,CAAA;IACnF,CAAA,EAAGC,KAAYC,YAAK;EACxB,CAAA;AACJ,GArBiB3B,gBAAAA,cAAAA,CAAAA,EAAAA;AAuBjB,IAAA,kBAAe4B,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAM3B,oBAAoB,OAAOyB,WAAWG;AAE5C,SAAOH,WAAWI,YAChBC,gBAAgBhC,SAChBiC,eAAe5C,KAAKU,YAAYC,SAASD,YAAYE,YAAYC,iBAAAA,CAAAA,CAAAA;AAErE,CAAA,CAAA;;",
6
+ "names": ["Tool", "Toolkit", "Effect", "Schema", "Capabilities", "Capability", "AppCapabilities", "LayoutOperation", "GenericToolkit", "ArtifactId", "trim", "Toolkit$", "make", "description", "trim", "parameters", "id", "ArtifactId", "success", "Any", "failure", "Never", "DeckToolkit", "Toolkit", "createLayer", "capabilityManager", "toLayer", "gen", "registry", "get", "Capabilities", "AtomRegistry", "stateAtom", "DeckCapabilities", "State", "state", "dxn", "toDXN", "activeDeck", "asEchoDXN", "Error", "invoke", "OperationInvoker", "LayoutOperation", "Open", "subject", "spaceId", "echoId", "pipe", "orDie", "Capability", "makeModule", "fnUntraced", "Service", "contributes", "AppCapabilities", "GenericToolkit"]
7
+ }
@@ -16,7 +16,7 @@ import {
16
16
  defaultDeck,
17
17
  getMode,
18
18
  isLayoutMode
19
- } from "../chunk-ATFPDN6J.mjs";
19
+ } from "../chunk-DONG2FYU.mjs";
20
20
  export {
21
21
  ATTENDABLE_PATH_SEPARATOR,
22
22
  DECK_COMPANION_TYPE,
@@ -1,16 +1,17 @@
1
1
  import {
2
2
  DeckCapabilities,
3
3
  defaultDeck
4
- } from "./chunk-ATFPDN6J.mjs";
4
+ } from "./chunk-DONG2FYU.mjs";
5
5
 
6
6
  // src/capabilities/url-handler/url-handler.ts
7
7
  import * as Effect from "effect/Effect";
8
- import { Capability, Common } from "@dxos/app-framework";
8
+ import { Capabilities, Capability } from "@dxos/app-framework";
9
+ import { LayoutOperation } from "@dxos/app-toolkit";
9
10
  import { invariant } from "@dxos/invariant";
10
11
  var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-deck/src/capabilities/url-handler/url-handler.ts";
11
12
  var url_handler_default = Capability.makeModule(Effect.fnUntraced(function* () {
12
- const { invokeSync } = yield* Capability.get(Common.Capability.OperationInvoker);
13
- const registry = yield* Capability.get(Common.Capability.AtomRegistry);
13
+ const { invokeSync } = yield* Capability.get(Capabilities.OperationInvoker);
14
+ const registry = yield* Capability.get(Capabilities.AtomRegistry);
14
15
  const stateAtom = yield* Capability.get(DeckCapabilities.State);
15
16
  const getState = () => registry.get(stateAtom);
16
17
  const getDeck = () => {
@@ -18,7 +19,7 @@ var url_handler_default = Capability.makeModule(Effect.fnUntraced(function* () {
18
19
  const deck = state.decks[state.activeDeck];
19
20
  invariant(deck, `Deck not found: ${state.activeDeck}`, {
20
21
  F: __dxlog_file,
21
- L: 26,
22
+ L: 27,
22
23
  S: this,
23
24
  A: [
24
25
  "deck",
@@ -48,18 +49,18 @@ var url_handler_default = Capability.makeModule(Effect.fnUntraced(function* () {
48
49
  }
49
50
  const [_, nextDeck, nextSolo] = pathname.split("/");
50
51
  if (nextDeck && nextDeck !== state.activeDeck) {
51
- invokeSync(Common.LayoutOperation.SwitchWorkspace, {
52
+ invokeSync(LayoutOperation.SwitchWorkspace, {
52
53
  subject: nextDeck
53
54
  });
54
55
  }
55
56
  const deck = getDeck();
56
57
  if (nextSolo && nextSolo !== deck.solo) {
57
- invokeSync(Common.LayoutOperation.SetLayoutMode, {
58
+ invokeSync(LayoutOperation.SetLayoutMode, {
58
59
  subject: nextSolo,
59
60
  mode: "solo"
60
61
  });
61
62
  } else if (!nextSolo && deck.solo) {
62
- invokeSync(Common.LayoutOperation.SetLayoutMode, {
63
+ invokeSync(LayoutOperation.SetLayoutMode, {
63
64
  mode: "deck"
64
65
  });
65
66
  }
@@ -82,7 +83,7 @@ var url_handler_default = Capability.makeModule(Effect.fnUntraced(function* () {
82
83
  }
83
84
  }
84
85
  });
85
- return Capability.contributes(Common.Capability.Null, null, () => Effect.sync(() => {
86
+ return Capability.contributes(Capabilities.Null, null, () => Effect.sync(() => {
86
87
  window.removeEventListener("popstate", handleNavigation);
87
88
  unsubscribe();
88
89
  }));
@@ -90,4 +91,4 @@ var url_handler_default = Capability.makeModule(Effect.fnUntraced(function* () {
90
91
  export {
91
92
  url_handler_default as default
92
93
  };
93
- //# sourceMappingURL=url-handler-53TE6JZO.mjs.map
94
+ //# sourceMappingURL=url-handler-37UPOB3U.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/url-handler/url-handler.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { LayoutOperation } from '@dxos/app-toolkit';\nimport { invariant } from '@dxos/invariant';\n\nimport { DeckCapabilities, type DeckStateProps, defaultDeck } from '../../types';\n\n// TODO(wittjosiah): Cleanup the url handling. May justify introducing routing capabilities.\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const { invokeSync } = yield* Capability.get(Capabilities.OperationInvoker);\n const registry = yield* Capability.get(Capabilities.AtomRegistry);\n const stateAtom = yield* Capability.get(DeckCapabilities.State);\n\n // Helper to get state.\n const getState = () => registry.get(stateAtom);\n\n // Helper to get computed deck from state.\n const getDeck = () => {\n const state = getState();\n const deck = state.decks[state.activeDeck];\n invariant(deck, `Deck not found: ${state.activeDeck}`);\n return deck;\n };\n\n // Helper to update state.\n const updateState = (fn: (current: DeckStateProps) => DeckStateProps) => {\n registry.set(stateAtom, fn(getState()));\n };\n\n const handleNavigation = () => {\n const pathname = window.location.pathname;\n const state = getState();\n if (pathname === '/reset') {\n updateState((s) => ({\n ...s,\n activeDeck: 'default',\n decks: {\n default: { ...defaultDeck },\n },\n }));\n window.location.pathname = '/';\n return;\n }\n\n const [_, nextDeck, nextSolo] = pathname.split('/');\n if (nextDeck && nextDeck !== state.activeDeck) {\n invokeSync(LayoutOperation.SwitchWorkspace, { subject: nextDeck });\n }\n\n const deck = getDeck();\n if (nextSolo && nextSolo !== deck.solo) {\n invokeSync(LayoutOperation.SetLayoutMode, { subject: nextSolo, mode: 'solo' });\n } else if (!nextSolo && deck.solo) {\n invokeSync(LayoutOperation.SetLayoutMode, { mode: 'deck' });\n }\n };\n\n yield* Effect.sync(() => handleNavigation());\n window.addEventListener('popstate', handleNavigation);\n\n // Subscribe to state changes to update the URL.\n let lastSolo: string | undefined;\n let lastActiveDeck: string | undefined;\n const unsubscribe = registry.subscribe(stateAtom, () => {\n const state = getState();\n const deck = getDeck();\n const solo = deck.solo;\n const activeDeck = state.activeDeck;\n\n // Only update URL if relevant state changed.\n if (solo !== lastSolo || activeDeck !== lastActiveDeck) {\n lastSolo = solo;\n lastActiveDeck = activeDeck;\n\n const path = solo ? `/${activeDeck}/${solo}` : `/${activeDeck}`;\n if (window.location.pathname !== path) {\n // TODO(thure): In some browsers, this only preserves the most recent state change, even though this is not `history.replace`…\n history.pushState(null, '', `${path}${window.location.search}`);\n }\n }\n });\n\n return Capability.contributes(Capabilities.Null, null, () =>\n Effect.sync(() => {\n window.removeEventListener('popstate', handleNavigation);\n unsubscribe();\n }),\n );\n }),\n);\n"],
5
+ "mappings": ";;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,uBAAuB;AAChC,SAASC,iBAAiB;;AAK1B,IAAA,sBAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAM,EAAEC,WAAU,IAAK,OAAOH,WAAWI,IAAIC,aAAaC,gBAAgB;AAC1E,QAAMC,WAAW,OAAOP,WAAWI,IAAIC,aAAaG,YAAY;AAChE,QAAMC,YAAY,OAAOT,WAAWI,IAAIM,iBAAiBC,KAAK;AAG9D,QAAMC,WAAW,MAAML,SAASH,IAAIK,SAAAA;AAGpC,QAAMI,UAAU,MAAA;AACd,UAAMC,QAAQF,SAAAA;AACd,UAAMG,OAAOD,MAAME,MAAMF,MAAMG,UAAU;AACzCC,cAAUH,MAAM,mBAAmBD,MAAMG,UAAU,IAAE;;;;;;;;;AACrD,WAAOF;EACT;AAGA,QAAMI,cAAc,CAACC,OAAAA;AACnBb,aAASc,IAAIZ,WAAWW,GAAGR,SAAAA,CAAAA,CAAAA;EAC7B;AAEA,QAAMU,mBAAmB,MAAA;AACvB,UAAMC,WAAWC,OAAOC,SAASF;AACjC,UAAMT,QAAQF,SAAAA;AACd,QAAIW,aAAa,UAAU;AACzBJ,kBAAY,CAACO,OAAO;QAClB,GAAGA;QACHT,YAAY;QACZD,OAAO;UACLW,SAAS;YAAE,GAAGC;UAAY;QAC5B;MACF,EAAA;AACAJ,aAAOC,SAASF,WAAW;AAC3B;IACF;AAEA,UAAM,CAACM,GAAGC,UAAUC,QAAAA,IAAYR,SAASS,MAAM,GAAA;AAC/C,QAAIF,YAAYA,aAAahB,MAAMG,YAAY;AAC7Cd,iBAAW8B,gBAAgBC,iBAAiB;QAAEC,SAASL;MAAS,CAAA;IAClE;AAEA,UAAMf,OAAOF,QAAAA;AACb,QAAIkB,YAAYA,aAAahB,KAAKqB,MAAM;AACtCjC,iBAAW8B,gBAAgBI,eAAe;QAAEF,SAASJ;QAAUO,MAAM;MAAO,CAAA;IAC9E,WAAW,CAACP,YAAYhB,KAAKqB,MAAM;AACjCjC,iBAAW8B,gBAAgBI,eAAe;QAAEC,MAAM;MAAO,CAAA;IAC3D;EACF;AAEA,SAAcC,YAAK,MAAMjB,iBAAAA,CAAAA;AACzBE,SAAOgB,iBAAiB,YAAYlB,gBAAAA;AAGpC,MAAImB;AACJ,MAAIC;AACJ,QAAMC,cAAcpC,SAASqC,UAAUnC,WAAW,MAAA;AAChD,UAAMK,QAAQF,SAAAA;AACd,UAAMG,OAAOF,QAAAA;AACb,UAAMuB,OAAOrB,KAAKqB;AAClB,UAAMnB,aAAaH,MAAMG;AAGzB,QAAImB,SAASK,YAAYxB,eAAeyB,gBAAgB;AACtDD,iBAAWL;AACXM,uBAAiBzB;AAEjB,YAAM4B,OAAOT,OAAO,IAAInB,UAAAA,IAAcmB,IAAAA,KAAS,IAAInB,UAAAA;AACnD,UAAIO,OAAOC,SAASF,aAAasB,MAAM;AAErCC,gBAAQC,UAAU,MAAM,IAAI,GAAGF,IAAAA,GAAOrB,OAAOC,SAASuB,MAAM,EAAE;MAChE;IACF;EACF,CAAA;AAEA,SAAOhD,WAAWiD,YAAY5C,aAAa6C,MAAM,MAAM,MAC9CX,YAAK,MAAA;AACVf,WAAO2B,oBAAoB,YAAY7B,gBAAAA;AACvCqB,gBAAAA;EACF,CAAA,CAAA;AAEJ,CAAA,CAAA;",
6
+ "names": ["Effect", "Capabilities", "Capability", "LayoutOperation", "invariant", "Capability", "makeModule", "fnUntraced", "invokeSync", "get", "Capabilities", "OperationInvoker", "registry", "AtomRegistry", "stateAtom", "DeckCapabilities", "State", "getState", "getDeck", "state", "deck", "decks", "activeDeck", "invariant", "updateState", "fn", "set", "handleNavigation", "pathname", "window", "location", "s", "default", "defaultDeck", "_", "nextDeck", "nextSolo", "split", "LayoutOperation", "SwitchWorkspace", "subject", "solo", "SetLayoutMode", "mode", "sync", "addEventListener", "lastSolo", "lastActiveDeck", "unsubscribe", "subscribe", "path", "history", "pushState", "search", "contributes", "Null", "removeEventListener"]
7
+ }
@@ -2,11 +2,12 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  DeckCapabilities,
4
4
  meta
5
- } from "./chunk-XAKTY3EB.mjs";
5
+ } from "./chunk-CVYHPJIN.mjs";
6
6
 
7
7
  // src/capabilities/app-graph-builder/app-graph-builder.ts
8
8
  import * as Effect from "effect/Effect";
9
- import { Capability, Common } from "@dxos/app-framework";
9
+ import { Capabilities, Capability } from "@dxos/app-framework";
10
+ import { AppCapabilities, LayoutOperation } from "@dxos/app-toolkit";
10
11
  import { Operation } from "@dxos/operation";
11
12
  import { AttentionCapabilities } from "@dxos/plugin-attention";
12
13
  import { GraphBuilder, NodeMatcher } from "@dxos/plugin-graph";
@@ -16,12 +17,12 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
16
17
  match: NodeMatcher.whenRoot,
17
18
  actions: (_node, get) => Effect.gen(function* () {
18
19
  const closeCurrent = {
19
- id: `${Common.LayoutOperation.Close.meta.key}/current`,
20
+ id: `${LayoutOperation.Close.meta.key}/current`,
20
21
  data: Effect.fnUntraced(function* () {
21
22
  const attention = yield* Capability.get(AttentionCapabilities.Attention);
22
23
  const attended = attention.getCurrent().at(-1);
23
24
  if (attended) {
24
- yield* Operation.invoke(Common.LayoutOperation.Close, {
25
+ yield* Operation.invoke(LayoutOperation.Close, {
25
26
  subject: [
26
27
  attended
27
28
  ]
@@ -39,13 +40,13 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
39
40
  }
40
41
  };
41
42
  const closeOthers = {
42
- id: `${Common.LayoutOperation.Close.meta.key}/others`,
43
+ id: `${LayoutOperation.Close.meta.key}/others`,
43
44
  data: Effect.fnUntraced(function* () {
44
45
  const attention = yield* Capability.get(AttentionCapabilities.Attention);
45
46
  const deck2 = yield* DeckCapabilities.getDeck();
46
47
  const attended = attention.getCurrent().at(-1);
47
48
  const ids = deck2.active.filter((id) => id !== attended) ?? [];
48
- yield* Operation.invoke(Common.LayoutOperation.Close, {
49
+ yield* Operation.invoke(LayoutOperation.Close, {
49
50
  subject: ids
50
51
  });
51
52
  }),
@@ -60,10 +61,10 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
60
61
  }
61
62
  };
62
63
  const closeAll = {
63
- id: `${Common.LayoutOperation.Close.meta.key}/all`,
64
+ id: `${LayoutOperation.Close.meta.key}/all`,
64
65
  data: Effect.fnUntraced(function* () {
65
66
  const deck2 = yield* DeckCapabilities.getDeck();
66
- yield* Operation.invoke(Common.LayoutOperation.Close, {
67
+ yield* Operation.invoke(LayoutOperation.Close, {
67
68
  subject: deck2.active
68
69
  });
69
70
  }),
@@ -80,9 +81,9 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
80
81
  const state = get(yield* Capability.get(DeckCapabilities.State));
81
82
  const deck = state.decks[state.activeDeck];
82
83
  const toggleSidebar = {
83
- id: `${Common.LayoutOperation.UpdateSidebar.meta.key}/nav`,
84
+ id: `${LayoutOperation.UpdateSidebar.meta.key}/nav`,
84
85
  data: Effect.fnUntraced(function* () {
85
- yield* Common.Capability.updateAtomValue(DeckCapabilities.State, (s) => ({
86
+ yield* Capabilities.updateAtomValue(DeckCapabilities.State, (s) => ({
86
87
  ...s,
87
88
  sidebarState: s.sidebarState === "expanded" ? "collapsed" : "expanded"
88
89
  }));
@@ -113,9 +114,9 @@ var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function
113
114
  ];
114
115
  })
115
116
  });
116
- return Capability.contributes(Common.Capability.AppGraphBuilder, extensions);
117
+ return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);
117
118
  }));
118
119
  export {
119
120
  app_graph_builder_default as default
120
121
  };
121
- //# sourceMappingURL=app-graph-builder-473BNZDJ.mjs.map
122
+ //# sourceMappingURL=app-graph-builder-US54I64T.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-builder/app-graph-builder.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';\nimport { Operation } from '@dxos/operation';\nimport { AttentionCapabilities } from '@dxos/plugin-attention';\nimport { GraphBuilder, NodeMatcher } from '@dxos/plugin-graph';\n\nimport { meta } from '../../meta';\nimport { DeckCapabilities } from '../../types';\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const extensions = yield* GraphBuilder.createExtension({\n id: meta.id,\n match: NodeMatcher.whenRoot,\n actions: (_node, get) =>\n Effect.gen(function* () {\n // NOTE(Zan): This is currently disabled.\n // TODO(Zan): Fullscreen needs to know the active node and provide that to the layout part.\n // const _fullscreen = {\n // id: `${LayoutAction.UpdateLayout._tag}/fullscreen`,\n // data: async () => {\n // const { dispatchPromise: dispatch } = context.get(Capabilities.IntentDispatcher);\n // await dispatch(\n // createIntent(LayoutAction.SetLayoutMode, { part: 'mode', options: { mode: 'fullscreen' } }),\n // );\n // },\n // properties: {\n // label: ['toggle fullscreen label', { ns: meta.id }],\n // icon: 'ph--arrows-out--regular',\n // keyBinding: {\n // macos: 'ctrl+meta+f',\n // windows: 'shift+ctrl+f',\n // },\n // },\n // };\n\n const closeCurrent = {\n id: `${LayoutOperation.Close.meta.key}/current`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const attended = attention.getCurrent().at(-1);\n if (attended) {\n yield* Operation.invoke(LayoutOperation.Close, { subject: [attended] });\n }\n }),\n properties: {\n label: ['close current label', { ns: meta.id }],\n icon: 'ph--x--regular',\n },\n };\n\n const closeOthers = {\n id: `${LayoutOperation.Close.meta.key}/others`,\n data: Effect.fnUntraced(function* () {\n const attention = yield* Capability.get(AttentionCapabilities.Attention);\n const deck = yield* DeckCapabilities.getDeck();\n const attended = attention.getCurrent().at(-1);\n const ids = deck.active.filter((id: string) => id !== attended) ?? [];\n yield* Operation.invoke(LayoutOperation.Close, { subject: ids });\n }),\n properties: {\n label: ['close others label', { ns: meta.id }],\n icon: 'ph--x-square--regular',\n },\n };\n\n const closeAll = {\n id: `${LayoutOperation.Close.meta.key}/all`,\n data: Effect.fnUntraced(function* () {\n const deck = yield* DeckCapabilities.getDeck();\n yield* Operation.invoke(LayoutOperation.Close, { subject: deck.active });\n }),\n properties: {\n label: ['close all label', { ns: meta.id }],\n icon: 'ph--x-circle--regular',\n },\n };\n\n const state = get(yield* Capability.get(DeckCapabilities.State));\n const deck = state.decks[state.activeDeck];\n\n const toggleSidebar = {\n id: `${LayoutOperation.UpdateSidebar.meta.key}/nav`,\n data: Effect.fnUntraced(function* () {\n yield* Capabilities.updateAtomValue(DeckCapabilities.State, (s) => ({\n ...s,\n sidebarState: s.sidebarState === 'expanded' ? ('collapsed' as const) : ('expanded' as const),\n }));\n }),\n properties: {\n label: [\n state.sidebarState === 'expanded'\n ? 'collapse navigation sidebar label'\n : 'open navigation sidebar label',\n { ns: meta.id },\n ],\n icon: 'ph--sidebar--regular',\n keyBinding: {\n macos: \"meta+'\",\n },\n disposition: 'pin-end',\n position: 'hoist',\n l0Breakpoint: 'lg',\n },\n };\n\n return !deck?.solo ? [closeCurrent, closeOthers, closeAll, toggleSidebar] : [toggleSidebar];\n }),\n });\n\n return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);\n }),\n);\n"],
5
+ "mappings": ";;;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,iBAAiBC,uBAAuB;AACjD,SAASC,iBAAiB;AAC1B,SAASC,6BAA6B;AACtC,SAASC,cAAcC,mBAAmB;AAK1C,IAAA,4BAAeC,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAMC,aAAa,OAAOC,aAAaC,gBAAgB;IACrDC,IAAIC,KAAKD;IACTE,OAAOC,YAAYC;IACnBC,SAAS,CAACC,OAAOC,QACRC,WAAI,aAAA;AAqBT,YAAMC,eAAe;QACnBT,IAAI,GAAGU,gBAAgBC,MAAMV,KAAKW,GAAG;QACrCC,MAAajB,kBAAW,aAAA;AACtB,gBAAMkB,YAAY,OAAOpB,WAAWa,IAAIQ,sBAAsBC,SAAS;AACvE,gBAAMC,WAAWH,UAAUI,WAAU,EAAGC,GAAG,EAAC;AAC5C,cAAIF,UAAU;AACZ,mBAAOG,UAAUC,OAAOX,gBAAgBC,OAAO;cAAEW,SAAS;gBAACL;;YAAU,CAAA;UACvE;QACF,CAAA;QACAM,YAAY;UACVC,OAAO;YAAC;YAAuB;cAAEC,IAAIxB,KAAKD;YAAG;;UAC7C0B,MAAM;QACR;MACF;AAEA,YAAMC,cAAc;QAClB3B,IAAI,GAAGU,gBAAgBC,MAAMV,KAAKW,GAAG;QACrCC,MAAajB,kBAAW,aAAA;AACtB,gBAAMkB,YAAY,OAAOpB,WAAWa,IAAIQ,sBAAsBC,SAAS;AACvE,gBAAMY,QAAO,OAAOC,iBAAiBC,QAAO;AAC5C,gBAAMb,WAAWH,UAAUI,WAAU,EAAGC,GAAG,EAAC;AAC5C,gBAAMY,MAAMH,MAAKI,OAAOC,OAAO,CAACjC,OAAeA,OAAOiB,QAAAA,KAAa,CAAA;AACnE,iBAAOG,UAAUC,OAAOX,gBAAgBC,OAAO;YAAEW,SAASS;UAAI,CAAA;QAChE,CAAA;QACAR,YAAY;UACVC,OAAO;YAAC;YAAsB;cAAEC,IAAIxB,KAAKD;YAAG;;UAC5C0B,MAAM;QACR;MACF;AAEA,YAAMQ,WAAW;QACflC,IAAI,GAAGU,gBAAgBC,MAAMV,KAAKW,GAAG;QACrCC,MAAajB,kBAAW,aAAA;AACtB,gBAAMgC,QAAO,OAAOC,iBAAiBC,QAAO;AAC5C,iBAAOV,UAAUC,OAAOX,gBAAgBC,OAAO;YAAEW,SAASM,MAAKI;UAAO,CAAA;QACxE,CAAA;QACAT,YAAY;UACVC,OAAO;YAAC;YAAmB;cAAEC,IAAIxB,KAAKD;YAAG;;UACzC0B,MAAM;QACR;MACF;AAEA,YAAMS,QAAQ5B,IAAI,OAAOb,WAAWa,IAAIsB,iBAAiBO,KAAK,CAAA;AAC9D,YAAMR,OAAOO,MAAME,MAAMF,MAAMG,UAAU;AAEzC,YAAMC,gBAAgB;QACpBvC,IAAI,GAAGU,gBAAgB8B,cAAcvC,KAAKW,GAAG;QAC7CC,MAAajB,kBAAW,aAAA;AACtB,iBAAO6C,aAAaC,gBAAgBb,iBAAiBO,OAAO,CAACO,OAAO;YAClE,GAAGA;YACHC,cAAcD,EAAEC,iBAAiB,aAAc,cAAyB;UAC1E,EAAA;QACF,CAAA;QACArB,YAAY;UACVC,OAAO;YACLW,MAAMS,iBAAiB,aACnB,sCACA;YACJ;cAAEnB,IAAIxB,KAAKD;YAAG;;UAEhB0B,MAAM;UACNmB,YAAY;YACVC,OAAO;UACT;UACAC,aAAa;UACbC,UAAU;UACVC,cAAc;QAChB;MACF;AAEA,aAAO,CAACrB,MAAMsB,OAAO;QAACzC;QAAckB;QAAaO;QAAUK;UAAiB;QAACA;;IAC/E,CAAA;EACJ,CAAA;AAEA,SAAO7C,WAAWyD,YAAYC,gBAAgBC,iBAAiBxD,UAAAA;AACjE,CAAA,CAAA;",
6
+ "names": ["Effect", "Capabilities", "Capability", "AppCapabilities", "LayoutOperation", "Operation", "AttentionCapabilities", "GraphBuilder", "NodeMatcher", "Capability", "makeModule", "fnUntraced", "extensions", "GraphBuilder", "createExtension", "id", "meta", "match", "NodeMatcher", "whenRoot", "actions", "_node", "get", "gen", "closeCurrent", "LayoutOperation", "Close", "key", "data", "attention", "AttentionCapabilities", "Attention", "attended", "getCurrent", "at", "Operation", "invoke", "subject", "properties", "label", "ns", "icon", "closeOthers", "deck", "DeckCapabilities", "getDeck", "ids", "active", "filter", "closeAll", "state", "State", "decks", "activeDeck", "toggleSidebar", "UpdateSidebar", "Capabilities", "updateAtomValue", "s", "sidebarState", "keyBinding", "macos", "disposition", "position", "l0Breakpoint", "solo", "contributes", "AppCapabilities", "AppGraphBuilder"]
7
+ }
@@ -1,13 +1,13 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
2
  import {
3
3
  DeckCapabilities
4
- } from "./chunk-XAKTY3EB.mjs";
4
+ } from "./chunk-CVYHPJIN.mjs";
5
5
 
6
6
  // src/capabilities/check-app-scheme/check-app-scheme.ts
7
7
  import * as Effect from "effect/Effect";
8
- import { Capability, Common } from "@dxos/app-framework";
9
- var isSocket = !!globalThis.__args;
10
- var appScheme = "composer://";
8
+ import { Capabilities, Capability } from "@dxos/app-framework";
9
+ import { isTauri } from "@dxos/util";
10
+ var APP_SCHEME = "composer://";
11
11
  var checkAppScheme = (url) => {
12
12
  const iframe = document.createElement("iframe");
13
13
  iframe.style.display = "none";
@@ -22,12 +22,12 @@ var checkAppScheme = (url) => {
22
22
  });
23
23
  };
24
24
  var check_app_scheme_default = Capability.makeModule(Effect.fnUntraced(function* () {
25
- const settings = yield* Common.Capability.getAtomValue(DeckCapabilities.Settings);
26
- if (!isSocket && settings?.enableNativeRedirect) {
27
- checkAppScheme(appScheme);
25
+ const settings = yield* Capabilities.getAtomValue(DeckCapabilities.Settings);
26
+ if (!isTauri() && settings?.enableNativeRedirect) {
27
+ checkAppScheme(APP_SCHEME);
28
28
  }
29
29
  }));
30
30
  export {
31
31
  check_app_scheme_default as default
32
32
  };
33
- //# sourceMappingURL=check-app-scheme-IVYRHKRH.mjs.map
33
+ //# sourceMappingURL=check-app-scheme-CK6EVG5D.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/check-app-scheme/check-app-scheme.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport * as Effect from 'effect/Effect';\n\nimport { Capabilities, Capability } from '@dxos/app-framework';\nimport { isTauri } from '@dxos/util';\n\nimport { DeckCapabilities } from '../../types';\n\nconst APP_SCHEME = 'composer://';\n\n/**\n * Attempts to redirect from the web app to the native desktop app using a custom URL scheme.\n * Creates a hidden iframe that navigates to the custom scheme URL (e.g., composer://workspace/123).\n * If the native app is installed and handles the scheme, the user will be redirected.\n * The iframe is automatically removed after 3 seconds or when the page is hidden.\n */\n// TODO(mjamesderocher): Factor out as part of NavigationPlugin.\nconst checkAppScheme = (url: string) => {\n const iframe = document.createElement('iframe');\n iframe.style.display = 'none';\n document.body.appendChild(iframe);\n\n iframe.src = url + window.location.pathname.replace(/^\\/+/, '') + window.location.search;\n\n const timer = setTimeout(() => {\n document.body.removeChild(iframe);\n }, 3000);\n\n window.addEventListener('pagehide', (event) => {\n clearTimeout(timer);\n document.body.removeChild(iframe);\n });\n};\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const settings = yield* Capabilities.getAtomValue(DeckCapabilities.Settings);\n if (!isTauri() && settings?.enableNativeRedirect) {\n checkAppScheme(APP_SCHEME);\n }\n }),\n);\n"],
5
+ "mappings": ";;;;;;AAIA,YAAYA,YAAY;AAExB,SAASC,cAAcC,kBAAkB;AACzC,SAASC,eAAe;AAIxB,IAAMC,aAAa;AASnB,IAAMC,iBAAiB,CAACC,QAAAA;AACtB,QAAMC,SAASC,SAASC,cAAc,QAAA;AACtCF,SAAOG,MAAMC,UAAU;AACvBH,WAASI,KAAKC,YAAYN,MAAAA;AAE1BA,SAAOO,MAAMR,MAAMS,OAAOC,SAASC,SAASC,QAAQ,QAAQ,EAAA,IAAMH,OAAOC,SAASG;AAElF,QAAMC,QAAQC,WAAW,MAAA;AACvBb,aAASI,KAAKU,YAAYf,MAAAA;EAC5B,GAAG,GAAA;AAEHQ,SAAOQ,iBAAiB,YAAY,CAACC,UAAAA;AACnCC,iBAAaL,KAAAA;AACbZ,aAASI,KAAKU,YAAYf,MAAAA;EAC5B,CAAA;AACF;AAEA,IAAA,2BAAemB,WAAWC,WACjBC,kBAAW,aAAA;AAChB,QAAMC,WAAW,OAAOC,aAAaC,aAAaC,iBAAiBC,QAAQ;AAC3E,MAAI,CAACC,QAAAA,KAAaL,UAAUM,sBAAsB;AAChD9B,mBAAeD,UAAAA;EACjB;AACF,CAAA,CAAA;",
6
+ "names": ["Effect", "Capabilities", "Capability", "isTauri", "APP_SCHEME", "checkAppScheme", "url", "iframe", "document", "createElement", "style", "display", "body", "appendChild", "src", "window", "location", "pathname", "replace", "search", "timer", "setTimeout", "removeChild", "addEventListener", "event", "clearTimeout", "Capability", "makeModule", "fnUntraced", "settings", "Capabilities", "getAtomValue", "DeckCapabilities", "Settings", "isTauri", "enableNativeRedirect"]
7
+ }