@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.
- package/dist/lib/browser/{app-graph-builder-DTVCULQ4.mjs → app-graph-builder-X7LCO5KE.mjs} +13 -12
- package/dist/lib/browser/app-graph-builder-X7LCO5KE.mjs.map +7 -0
- package/dist/lib/browser/{check-app-scheme-JSRXXIYF.mjs → check-app-scheme-PGISDJX7.mjs} +8 -8
- package/dist/lib/browser/check-app-scheme-PGISDJX7.mjs.map +7 -0
- package/dist/lib/browser/{chunk-ATFPDN6J.mjs → chunk-DONG2FYU.mjs} +12 -9
- package/dist/lib/browser/chunk-DONG2FYU.mjs.map +7 -0
- package/dist/lib/browser/{chunk-EREEXCHO.mjs → chunk-JGC4ZLG3.mjs} +102 -81
- package/dist/lib/browser/chunk-JGC4ZLG3.mjs.map +7 -0
- package/dist/lib/browser/{chunk-UNG4CLLP.mjs → chunk-YT3AJVUU.mjs} +8 -8
- package/dist/lib/browser/chunk-YT3AJVUU.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +36 -34
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{operation-resolver-CDYBLZJ4.mjs → operation-resolver-XJFR3PNQ.mjs} +86 -84
- package/dist/lib/browser/operation-resolver-XJFR3PNQ.mjs.map +7 -0
- package/dist/lib/browser/{react-root-LYNEKGHM.mjs → react-root-AJFHKHRL.mjs} +6 -6
- package/dist/lib/browser/react-root-AJFHKHRL.mjs.map +7 -0
- package/dist/lib/browser/{react-surface-RPKD7XUR.mjs → react-surface-KBRBGEXY.mjs} +11 -10
- package/dist/lib/browser/react-surface-KBRBGEXY.mjs.map +7 -0
- package/dist/lib/browser/{settings-OMHVGZ6V.mjs → settings-ES42FGLG.mjs} +5 -4
- package/dist/lib/browser/settings-ES42FGLG.mjs.map +7 -0
- package/dist/lib/browser/{state-OC3BSB6E.mjs → state-YMI6IDEL.mjs} +7 -6
- package/dist/lib/browser/state-YMI6IDEL.mjs.map +7 -0
- package/dist/lib/browser/{toolkit-R53LD3EA.mjs → toolkit-VRD54KY3.mjs} +8 -7
- package/dist/lib/browser/toolkit-VRD54KY3.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -1
- package/dist/lib/browser/{url-handler-53TE6JZO.mjs → url-handler-37UPOB3U.mjs} +11 -10
- package/dist/lib/browser/url-handler-37UPOB3U.mjs.map +7 -0
- package/dist/lib/node-esm/{app-graph-builder-473BNZDJ.mjs → app-graph-builder-US54I64T.mjs} +13 -12
- package/dist/lib/node-esm/app-graph-builder-US54I64T.mjs.map +7 -0
- package/dist/lib/node-esm/{check-app-scheme-IVYRHKRH.mjs → check-app-scheme-CK6EVG5D.mjs} +8 -8
- package/dist/lib/node-esm/check-app-scheme-CK6EVG5D.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-V6VEXRD4.mjs → chunk-7NPS347C.mjs} +102 -81
- package/dist/lib/node-esm/chunk-7NPS347C.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-XAKTY3EB.mjs → chunk-CVYHPJIN.mjs} +12 -9
- package/dist/lib/node-esm/chunk-CVYHPJIN.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-SKEVPQ7E.mjs → chunk-ZMJPCZ3V.mjs} +8 -8
- package/dist/lib/node-esm/chunk-ZMJPCZ3V.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +36 -34
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{operation-resolver-WUOE33ID.mjs → operation-resolver-ZQGNATPX.mjs} +86 -84
- package/dist/lib/node-esm/operation-resolver-ZQGNATPX.mjs.map +7 -0
- package/dist/lib/node-esm/{react-root-L7H43AS3.mjs → react-root-2S77ABBS.mjs} +6 -6
- package/dist/lib/node-esm/react-root-2S77ABBS.mjs.map +7 -0
- package/dist/lib/node-esm/{react-surface-77DKVMDV.mjs → react-surface-FIHMAFXH.mjs} +11 -10
- package/dist/lib/node-esm/react-surface-FIHMAFXH.mjs.map +7 -0
- package/dist/lib/node-esm/{settings-2HB6FKIK.mjs → settings-E3TH3FAW.mjs} +5 -4
- package/dist/lib/node-esm/settings-E3TH3FAW.mjs.map +7 -0
- package/dist/lib/node-esm/{state-JRQ45ACJ.mjs → state-WQEFBQMD.mjs} +7 -6
- package/dist/lib/node-esm/state-WQEFBQMD.mjs.map +7 -0
- package/dist/lib/node-esm/{toolkit-JLPZNNKB.mjs → toolkit-ME546G5T.mjs} +8 -7
- package/dist/lib/node-esm/toolkit-ME546G5T.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -1
- package/dist/lib/node-esm/{url-handler-QGF2R24T.mjs → url-handler-2KYHXINK.mjs} +11 -10
- package/dist/lib/node-esm/url-handler-2KYHXINK.mjs.map +7 -0
- package/dist/types/src/DeckPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/check-app-scheme/check-app-scheme.d.ts.map +1 -1
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +2 -2
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-root/react-root.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts +1 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts +2 -2
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings/index.d.ts +1 -1
- package/dist/types/src/capabilities/settings/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings/settings.d.ts +3 -2
- package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -1
- package/dist/types/src/capabilities/state/index.d.ts +2 -0
- package/dist/types/src/capabilities/state/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/state/state.d.ts +2 -0
- package/dist/types/src/capabilities/state/state.d.ts.map +1 -1
- package/dist/types/src/capabilities/toolkit/index.d.ts +1 -1
- package/dist/types/src/capabilities/toolkit/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/toolkit/toolkit.d.ts +3 -2
- package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +1 -1
- package/dist/types/src/capabilities/url-handler/url-handler.d.ts.map +1 -1
- package/dist/types/src/components/DeckLayout/ActiveNode.d.ts.map +1 -1
- package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts +1 -0
- package/dist/types/src/components/DeckLayout/DeckLayout.stories.d.ts.map +1 -1
- package/dist/types/src/components/DeckLayout/Dialog.d.ts.map +1 -1
- package/dist/types/src/components/DeckLayout/Popover.d.ts.map +1 -1
- package/dist/types/src/components/DeckLayout/Toast.d.ts +3 -3
- package/dist/types/src/components/DeckLayout/Toast.d.ts.map +1 -1
- package/dist/types/src/components/Plank/Plank.d.ts.map +1 -1
- package/dist/types/src/components/Plank/Plank.stories.d.ts +1 -0
- package/dist/types/src/components/Plank/Plank.stories.d.ts.map +1 -1
- package/dist/types/src/components/Plank/PlankHeading.d.ts.map +1 -1
- package/dist/types/src/translations.d.ts +1 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/capabilities.d.ts +2 -0
- package/dist/types/src/types/capabilities.d.ts.map +1 -1
- package/dist/types/src/types/events.d.ts.map +1 -1
- package/dist/types/src/types/schema.d.ts +2 -0
- package/dist/types/src/types/schema.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +43 -42
- package/src/DeckPlugin.ts +12 -11
- package/src/capabilities/app-graph-builder/app-graph-builder.ts +11 -10
- package/src/capabilities/check-app-scheme/check-app-scheme.ts +12 -8
- package/src/capabilities/operation-resolver/operation-resolver.ts +95 -80
- package/src/capabilities/react-root/react-root.tsx +2 -2
- package/src/capabilities/react-surface/react-surface.tsx +8 -7
- package/src/capabilities/settings/settings.ts +3 -2
- package/src/capabilities/state/state.ts +5 -4
- package/src/capabilities/toolkit/toolkit.ts +6 -5
- package/src/capabilities/url-handler/url-handler.ts +8 -7
- package/src/components/DeckLayout/ActiveNode.tsx +3 -2
- package/src/components/DeckLayout/Banner.tsx +4 -4
- package/src/components/DeckLayout/ContentEmpty.tsx +2 -2
- package/src/components/DeckLayout/DeckLayout.stories.tsx +5 -4
- package/src/components/DeckLayout/DeckMain.tsx +7 -7
- package/src/components/DeckLayout/Dialog.tsx +9 -3
- package/src/components/DeckLayout/Popover.tsx +21 -5
- package/src/components/DeckLayout/StatusBar.tsx +3 -3
- package/src/components/DeckLayout/Toast.tsx +3 -3
- package/src/components/DeckSettings/DeckSettings.tsx +21 -21
- package/src/components/Plank/Plank.stories.tsx +4 -3
- package/src/components/Plank/Plank.tsx +5 -4
- package/src/components/Plank/PlankControls.tsx +1 -1
- package/src/components/Plank/PlankHeading.tsx +7 -6
- package/src/components/Sidebar/ComplementarySidebar.tsx +19 -15
- package/src/components/Sidebar/Sidebar.tsx +2 -2
- package/src/components/Sidebar/SidebarButton.tsx +9 -9
- package/src/hooks/useCompanions.ts +1 -1
- package/src/hooks/useDeckCompanions.ts +1 -1
- package/src/hooks/useDeckState.ts +3 -3
- package/src/hooks/useHoistStatusbar.ts +1 -1
- package/src/translations.ts +1 -0
- package/src/types/capabilities.ts +2 -2
- package/src/types/events.ts +4 -3
- package/src/types/schema.ts +7 -3
- package/dist/lib/browser/app-graph-builder-DTVCULQ4.mjs.map +0 -7
- package/dist/lib/browser/check-app-scheme-JSRXXIYF.mjs.map +0 -7
- package/dist/lib/browser/chunk-ATFPDN6J.mjs.map +0 -7
- package/dist/lib/browser/chunk-EREEXCHO.mjs.map +0 -7
- package/dist/lib/browser/chunk-UNG4CLLP.mjs.map +0 -7
- package/dist/lib/browser/operation-resolver-CDYBLZJ4.mjs.map +0 -7
- package/dist/lib/browser/react-root-LYNEKGHM.mjs.map +0 -7
- package/dist/lib/browser/react-surface-RPKD7XUR.mjs.map +0 -7
- package/dist/lib/browser/settings-OMHVGZ6V.mjs.map +0 -7
- package/dist/lib/browser/state-OC3BSB6E.mjs.map +0 -7
- package/dist/lib/browser/toolkit-R53LD3EA.mjs.map +0 -7
- package/dist/lib/browser/url-handler-53TE6JZO.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-473BNZDJ.mjs.map +0 -7
- package/dist/lib/node-esm/check-app-scheme-IVYRHKRH.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-SKEVPQ7E.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-V6VEXRD4.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-XAKTY3EB.mjs.map +0 -7
- package/dist/lib/node-esm/operation-resolver-WUOE33ID.mjs.map +0 -7
- package/dist/lib/node-esm/react-root-L7H43AS3.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-77DKVMDV.mjs.map +0 -7
- package/dist/lib/node-esm/settings-2HB6FKIK.mjs.map +0 -7
- package/dist/lib/node-esm/state-JRQ45ACJ.mjs.map +0 -7
- package/dist/lib/node-esm/toolkit-JLPZNNKB.mjs.map +0 -7
- 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-
|
|
5
|
-
import "./chunk-
|
|
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-
|
|
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 {
|
|
15
|
-
import { useSettingsState } from "@dxos/app-framework/
|
|
16
|
-
|
|
17
|
-
|
|
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) =>
|
|
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
|
-
|
|
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-
|
|
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-
|
|
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
|
|
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(
|
|
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-
|
|
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-
|
|
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 {
|
|
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(
|
|
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:
|
|
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(
|
|
98
|
+
Capability.contributes(AppCapabilities.Layout, layoutAtom)
|
|
98
99
|
];
|
|
99
100
|
}));
|
|
100
101
|
export {
|
|
101
102
|
state_default as default
|
|
102
103
|
};
|
|
103
|
-
//# sourceMappingURL=state-
|
|
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-
|
|
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 {
|
|
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(
|
|
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(
|
|
36
|
-
yield* invoke(
|
|
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(
|
|
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-
|
|
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
|
+
}
|
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
import {
|
|
2
2
|
DeckCapabilities,
|
|
3
3
|
defaultDeck
|
|
4
|
-
} from "./chunk-
|
|
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 {
|
|
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(
|
|
13
|
-
const registry = yield* Capability.get(
|
|
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:
|
|
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(
|
|
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(
|
|
58
|
+
invokeSync(LayoutOperation.SetLayoutMode, {
|
|
58
59
|
subject: nextSolo,
|
|
59
60
|
mode: "solo"
|
|
60
61
|
});
|
|
61
62
|
} else if (!nextSolo && deck.solo) {
|
|
62
|
-
invokeSync(
|
|
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(
|
|
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-
|
|
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-
|
|
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 {
|
|
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: `${
|
|
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(
|
|
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: `${
|
|
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(
|
|
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: `${
|
|
64
|
+
id: `${LayoutOperation.Close.meta.key}/all`,
|
|
64
65
|
data: Effect.fnUntraced(function* () {
|
|
65
66
|
const deck2 = yield* DeckCapabilities.getDeck();
|
|
66
|
-
yield* Operation.invoke(
|
|
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: `${
|
|
84
|
+
id: `${LayoutOperation.UpdateSidebar.meta.key}/nav`,
|
|
84
85
|
data: Effect.fnUntraced(function* () {
|
|
85
|
-
yield*
|
|
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(
|
|
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-
|
|
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-
|
|
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 {
|
|
9
|
-
|
|
10
|
-
var
|
|
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*
|
|
26
|
-
if (!
|
|
27
|
-
checkAppScheme(
|
|
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-
|
|
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
|
+
}
|