@dxos/plugin-presenter 0.8.4-main.7ace549 → 0.8.4-main.9735255
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/CollectionPresenterContainer-IHDZWP3U.mjs +176 -0
- package/dist/lib/browser/CollectionPresenterContainer-IHDZWP3U.mjs.map +7 -0
- package/dist/lib/browser/DocumentPresenterContainer-74M6XAAI.mjs +173 -0
- package/dist/lib/browser/DocumentPresenterContainer-74M6XAAI.mjs.map +7 -0
- package/dist/lib/browser/{MarkdownSlide-MEXR54L5.mjs → MarkdownSlide-GIYJABHE.mjs} +54 -77
- package/dist/lib/browser/MarkdownSlide-GIYJABHE.mjs.map +7 -0
- package/dist/lib/browser/app-graph-builder-2QAQR34J.mjs +112 -0
- package/dist/lib/browser/app-graph-builder-2QAQR34J.mjs.map +7 -0
- package/dist/lib/browser/chunk-4PZXJXBO.mjs +50 -0
- package/dist/lib/browser/chunk-4PZXJXBO.mjs.map +7 -0
- package/dist/lib/browser/chunk-5MC4V23G.mjs +38 -0
- package/dist/lib/browser/chunk-5MC4V23G.mjs.map +7 -0
- package/dist/lib/browser/chunk-GM4KOXJY.mjs +41 -0
- package/dist/lib/browser/chunk-GM4KOXJY.mjs.map +7 -0
- package/dist/lib/browser/{chunk-TMTUZQCK.mjs → chunk-VQVZVXPJ.mjs} +1 -1
- package/dist/lib/browser/chunk-VQVZVXPJ.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +23 -30
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{react-surface-S4T6X72R.mjs → react-surface-2VP2M4Z7.mjs} +24 -18
- package/dist/lib/browser/react-surface-2VP2M4Z7.mjs.map +7 -0
- package/dist/lib/browser/settings-RDHXCCT4.mjs +31 -0
- package/dist/lib/browser/settings-RDHXCCT4.mjs.map +7 -0
- package/dist/types/src/PresenterPlugin.d.ts +2 -1
- package/dist/types/src/PresenterPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +6 -0
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts +3 -0
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +3 -3
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts +3 -0
- package/dist/types/src/capabilities/react-surface/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts +5 -0
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings/index.d.ts +7 -0
- package/dist/types/src/capabilities/settings/index.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings/settings.d.ts +9 -0
- package/dist/types/src/capabilities/settings/settings.d.ts.map +1 -0
- package/dist/types/src/components/CollectionPresenterContainer.d.ts +4 -4
- package/dist/types/src/components/CollectionPresenterContainer.d.ts.map +1 -1
- package/dist/types/src/components/MarkdownSlide.d.ts +4 -3
- package/dist/types/src/components/MarkdownSlide.d.ts.map +1 -1
- package/dist/types/src/components/Presenter/Pager.d.ts +1 -1
- package/dist/types/src/components/Presenter/Pager.d.ts.map +1 -1
- package/dist/types/src/components/PresenterSettings.d.ts +4 -2
- package/dist/types/src/components/PresenterSettings.d.ts.map +1 -1
- package/dist/types/src/components/RevealPlayer/RevealPlayer.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +18 -17
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +2 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +35 -23
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/src/useExitPresenter.d.ts +2 -3
- package/dist/types/src/useExitPresenter.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +45 -40
- package/src/PresenterPlugin.tsx +8 -23
- package/src/capabilities/app-graph-builder/app-graph-builder.ts +105 -0
- package/src/capabilities/app-graph-builder/index.ts +7 -0
- package/src/capabilities/index.ts +3 -5
- package/src/capabilities/react-surface/index.ts +7 -0
- package/src/capabilities/react-surface/react-surface.tsx +70 -0
- package/src/capabilities/settings/index.ts +7 -0
- package/src/capabilities/settings/settings.ts +30 -0
- package/src/components/CollectionPresenterContainer.tsx +12 -13
- package/src/components/DocumentPresenterContainer.tsx +3 -3
- package/src/components/Markdown/Container.tsx +1 -1
- package/src/components/MarkdownSlide.tsx +6 -2
- package/src/components/Presenter/Layout.tsx +1 -1
- package/src/components/Presenter/Pager.tsx +2 -2
- package/src/components/PresenterSettings.tsx +7 -2
- package/src/components/RevealPlayer/RevealPlayer.tsx +4 -1
- package/src/meta.ts +2 -2
- package/src/types.ts +14 -6
- package/src/useExitPresenter.ts +22 -24
- package/dist/lib/browser/CollectionPresenterContainer-4JFW3EKV.mjs +0 -199
- package/dist/lib/browser/CollectionPresenterContainer-4JFW3EKV.mjs.map +0 -7
- package/dist/lib/browser/DocumentPresenterContainer-SX32NAEH.mjs +0 -183
- package/dist/lib/browser/DocumentPresenterContainer-SX32NAEH.mjs.map +0 -7
- package/dist/lib/browser/MarkdownSlide-MEXR54L5.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-UJEKUKAP.mjs +0 -106
- package/dist/lib/browser/app-graph-builder-UJEKUKAP.mjs.map +0 -7
- package/dist/lib/browser/chunk-BJWK5GQV.mjs +0 -38
- package/dist/lib/browser/chunk-BJWK5GQV.mjs.map +0 -7
- package/dist/lib/browser/chunk-Q3H4KEFB.mjs +0 -41
- package/dist/lib/browser/chunk-Q3H4KEFB.mjs.map +0 -7
- package/dist/lib/browser/chunk-TMTUZQCK.mjs.map +0 -7
- package/dist/lib/browser/chunk-VRRPVTKA.mjs +0 -39
- package/dist/lib/browser/chunk-VRRPVTKA.mjs.map +0 -7
- package/dist/lib/browser/react-surface-S4T6X72R.mjs.map +0 -7
- package/dist/lib/browser/settings-57TUVRW3.mjs +0 -22
- package/dist/lib/browser/settings-57TUVRW3.mjs.map +0 -7
- package/dist/types/src/capabilities/app-graph-builder.d.ts +0 -4
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-surface.d.ts +0 -4
- package/dist/types/src/capabilities/react-surface.d.ts.map +0 -1
- package/dist/types/src/capabilities/settings.d.ts +0 -4
- package/dist/types/src/capabilities/settings.d.ts.map +0 -1
- package/src/capabilities/app-graph-builder.ts +0 -117
- package/src/capabilities/react-surface.tsx +0 -63
- package/src/capabilities/settings.ts +0 -19
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/app-graph-builder.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Atom } from '@effect-atom/atom-react';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\n\nimport { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { ATTENDABLE_PATH_SEPARATOR, DeckAction } from '@dxos/plugin-deck/types';\nimport { atomFromSignal, createExtension } from '@dxos/plugin-graph';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { getSpace } from '@dxos/react-client/echo';\nimport { Collection } from '@dxos/schema';\n\nimport { meta } from '../meta';\nimport { PresenterAction, type PresenterSettingsProps } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(\n Capabilities.AppGraphBuilder,\n createExtension({\n id: `${meta.id}/root`,\n // TODO(wittjosiah): This is a hack to work around presenter previously relying on \"variant\". Remove.\n connector: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => {\n const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));\n const settings = get(\n atomFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value),\n );\n const isPresentable = settings?.presentCollections\n ? Obj.instanceOf(Collection.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)\n : Obj.instanceOf(Markdown.Document, node.data);\n return isPresentable ? Option.some(node.data) : Option.none();\n }),\n Option.map((object) => {\n const id = Obj.getDXN(object).toString();\n return [\n {\n id: [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR),\n data: { type: meta.id, object },\n type: meta.id,\n properties: {\n label: 'Presenter',\n icon: 'ph--presentation--regular',\n disposition: 'hidden',\n },\n },\n ];\n }),\n Option.getOrElse(() => []),\n ),\n ),\n actions: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => {\n const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));\n const settings = get(\n atomFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value),\n );\n const isPresentable = settings?.presentCollections\n ? Obj.instanceOf(Collection.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)\n : Obj.instanceOf(Markdown.Document, node.data);\n return isPresentable ? Option.some(node.data) : Option.none();\n }),\n Option.map((object) => {\n const id = Obj.getDXN(object).toString();\n const spaceId = getSpace(object)?.id;\n return [\n {\n id: `${PresenterAction.TogglePresentation._tag}/${id}`,\n // TODO(burdon): Allow function so can generate state when activated.\n // So can set explicit fullscreen state coordinated with current presenter state.\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const layout = context.getCapability(DeckCapabilities.MutableDeckState);\n const presenterId = [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR);\n if (!layout.deck.fullscreen) {\n void dispatch(\n createIntent(DeckAction.Adjust, {\n type: 'solo--fullscreen',\n id: presenterId,\n }),\n );\n }\n await dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [presenterId],\n options: { workspace: spaceId },\n }),\n );\n },\n properties: {\n label: ['toggle presentation label', { ns: meta.id }],\n icon: 'ph--presentation--regular',\n disposition: 'list-item',\n keyBinding: {\n macos: 'shift+meta+p',\n windows: 'shift+alt+p',\n },\n },\n },\n ];\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n );\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["Atom", "Function", "Option", "Capabilities", "LayoutAction", "contributes", "createIntent", "Obj", "DeckCapabilities", "ATTENDABLE_PATH_SEPARATOR", "DeckAction", "atomFromSignal", "createExtension", "Markdown", "getSpace", "Collection", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "connector", "node", "Atom", "make", "get", "pipe", "flatMap", "settingsStore", "capabilities", "SettingsStore", "settings", "atomFromSignal", "getStore", "value", "isPresentable", "presentCollections", "Obj", "instanceOf", "Collection", "data", "Markdown", "Document", "some", "none", "map", "object", "getDXN", "toString", "join", "ATTENDABLE_PATH_SEPARATOR", "type", "properties", "label", "icon", "disposition", "getOrElse", "actions", "spaceId", "getSpace", "PresenterAction", "TogglePresentation", "_tag", "dispatchPromise", "dispatch", "getCapability", "IntentDispatcher", "layout", "DeckCapabilities", "MutableDeckState", "presenterId", "deck", "fullscreen", "createIntent", "DeckAction", "Adjust", "LayoutAction", "Open", "part", "subject", "options", "workspace", "ns", "keyBinding", "macos", "windows"]
|
|
7
|
-
}
|
|
@@ -1,38 +0,0 @@
|
|
|
1
|
-
// src/useExitPresenter.ts
|
|
2
|
-
import { useCallback } from "react";
|
|
3
|
-
import { LayoutAction, createIntent } from "@dxos/app-framework";
|
|
4
|
-
import { useCapability, useIntentDispatcher } from "@dxos/app-framework/react";
|
|
5
|
-
import { Obj } from "@dxos/echo";
|
|
6
|
-
import { DeckCapabilities } from "@dxos/plugin-deck";
|
|
7
|
-
import { DeckAction } from "@dxos/plugin-deck/types";
|
|
8
|
-
import { getSpace } from "@dxos/react-client/echo";
|
|
9
|
-
var useExitPresenter = (object) => {
|
|
10
|
-
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
11
|
-
const layout = useCapability(DeckCapabilities.MutableDeckState);
|
|
12
|
-
return useCallback(() => {
|
|
13
|
-
const objectId = Obj.getDXN(object).toString();
|
|
14
|
-
if (layout.deck.fullscreen) {
|
|
15
|
-
void dispatch(createIntent(DeckAction.Adjust, {
|
|
16
|
-
type: "solo--fullscreen",
|
|
17
|
-
id: objectId
|
|
18
|
-
}));
|
|
19
|
-
}
|
|
20
|
-
return dispatch(createIntent(LayoutAction.Open, {
|
|
21
|
-
part: "main",
|
|
22
|
-
subject: [
|
|
23
|
-
objectId
|
|
24
|
-
],
|
|
25
|
-
options: {
|
|
26
|
-
workspace: getSpace(document)?.id
|
|
27
|
-
}
|
|
28
|
-
}));
|
|
29
|
-
}, [
|
|
30
|
-
dispatch,
|
|
31
|
-
object
|
|
32
|
-
]);
|
|
33
|
-
};
|
|
34
|
-
|
|
35
|
-
export {
|
|
36
|
-
useExitPresenter
|
|
37
|
-
};
|
|
38
|
-
//# sourceMappingURL=chunk-BJWK5GQV.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/useExitPresenter.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useCallback } from 'react';\n\nimport { LayoutAction, createIntent } from '@dxos/app-framework';\nimport { useCapability, useIntentDispatcher } from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { type Live } from '@dxos/live-object';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { DeckAction } from '@dxos/plugin-deck/types';\nimport { getSpace } from '@dxos/react-client/echo';\n\nexport const useExitPresenter = (object: Live<any>) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const layout = useCapability(DeckCapabilities.MutableDeckState);\n\n return useCallback(() => {\n const objectId = Obj.getDXN(object).toString();\n if (layout.deck.fullscreen) {\n void dispatch(\n createIntent(DeckAction.Adjust, {\n type: 'solo--fullscreen',\n id: objectId,\n }),\n );\n }\n return dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [objectId],\n options: { workspace: getSpace(document)?.id },\n }),\n );\n }, [dispatch, object]);\n};\n"],
|
|
5
|
-
"mappings": ";AAIA,SAASA,mBAAmB;AAE5B,SAASC,cAAcC,oBAAoB;AAC3C,SAASC,eAAeC,2BAA2B;AACnD,SAASC,WAAW;AAEpB,SAASC,wBAAwB;AACjC,SAASC,kBAAkB;AAC3B,SAASC,gBAAgB;AAElB,IAAMC,mBAAmB,CAACC,WAAAA;AAC/B,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,QAAMC,SAASC,cAAcC,iBAAiBC,gBAAgB;AAE9D,SAAOC,YAAY,MAAA;AACjB,UAAMC,WAAWC,IAAIC,OAAOX,MAAAA,EAAQY,SAAQ;AAC5C,QAAIR,OAAOS,KAAKC,YAAY;AAC1B,WAAKZ,SACHa,aAAaC,WAAWC,QAAQ;QAC9BC,MAAM;QACNC,IAAIV;MACN,CAAA,CAAA;IAEJ;AACA,WAAOP,SACLa,aAAaK,aAAaC,MAAM;MAC9BC,MAAM;MACNC,SAAS;QAACd;;MACVe,SAAS;QAAEC,WAAWC,SAASC,QAAAA,GAAWR;MAAG;IAC/C,CAAA,CAAA;EAEJ,GAAG;IAACjB;IAAUF;GAAO;AACvB;",
|
|
6
|
-
"names": ["useCallback", "LayoutAction", "createIntent", "useCapability", "useIntentDispatcher", "Obj", "DeckCapabilities", "DeckAction", "getSpace", "useExitPresenter", "object", "dispatchPromise", "dispatch", "useIntentDispatcher", "layout", "useCapability", "DeckCapabilities", "MutableDeckState", "useCallback", "objectId", "Obj", "getDXN", "toString", "deck", "fullscreen", "createIntent", "DeckAction", "Adjust", "type", "id", "LayoutAction", "Open", "part", "subject", "options", "workspace", "getSpace", "document"]
|
|
7
|
-
}
|
|
@@ -1,41 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
meta
|
|
3
|
-
} from "./chunk-TMTUZQCK.mjs";
|
|
4
|
-
|
|
5
|
-
// src/components/PresenterSettings.tsx
|
|
6
|
-
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
7
|
-
import React from "react";
|
|
8
|
-
import { Input, useTranslation } from "@dxos/react-ui";
|
|
9
|
-
import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from "@dxos/react-ui-form";
|
|
10
|
-
var PresenterSettings = ({ settings }) => {
|
|
11
|
-
var _effect = _useSignals();
|
|
12
|
-
try {
|
|
13
|
-
const { t } = useTranslation(meta.id);
|
|
14
|
-
return /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
|
|
15
|
-
title: t("settings title", {
|
|
16
|
-
ns: meta.id
|
|
17
|
-
})
|
|
18
|
-
}, /* @__PURE__ */ React.createElement(ControlGroup, null, /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
19
|
-
title: t("present collections label")
|
|
20
|
-
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
21
|
-
checked: settings.presentCollections,
|
|
22
|
-
onCheckedChange: (checked) => settings.presentCollections = !!checked
|
|
23
|
-
})))));
|
|
24
|
-
} finally {
|
|
25
|
-
_effect.f();
|
|
26
|
-
}
|
|
27
|
-
};
|
|
28
|
-
|
|
29
|
-
// src/components/index.ts
|
|
30
|
-
import { lazy } from "react";
|
|
31
|
-
var MarkdownSlide = lazy(() => import("./MarkdownSlide-MEXR54L5.mjs"));
|
|
32
|
-
var DocumentPresenterContainer = lazy(() => import("./DocumentPresenterContainer-SX32NAEH.mjs"));
|
|
33
|
-
var CollectionPresenterContainer = lazy(() => import("./CollectionPresenterContainer-4JFW3EKV.mjs"));
|
|
34
|
-
|
|
35
|
-
export {
|
|
36
|
-
PresenterSettings,
|
|
37
|
-
MarkdownSlide,
|
|
38
|
-
DocumentPresenterContainer,
|
|
39
|
-
CollectionPresenterContainer
|
|
40
|
-
};
|
|
41
|
-
//# sourceMappingURL=chunk-Q3H4KEFB.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/components/PresenterSettings.tsx", "../../../src/components/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, useTranslation } from '@dxos/react-ui';\nimport { ControlGroup, ControlItemInput, ControlPage, ControlSection } from '@dxos/react-ui-form';\n\nimport { meta } from '../meta';\nimport { type PresenterSettingsProps } from '../types';\n\nexport const PresenterSettings = ({ settings }: { settings: PresenterSettingsProps }) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <ControlPage>\n <ControlSection title={t('settings title', { ns: meta.id })}>\n <ControlGroup>\n <ControlItemInput title={t('present collections label')}>\n <Input.Switch\n checked={settings.presentCollections}\n onCheckedChange={(checked) => (settings.presentCollections = !!checked)}\n />\n </ControlItemInput>\n </ControlGroup>\n </ControlSection>\n </ControlPage>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './PresenterSettings';\n\nexport const MarkdownSlide = lazy(() => import('./MarkdownSlide'));\nexport const DocumentPresenterContainer = lazy(() => import('./DocumentPresenterContainer'));\nexport const CollectionPresenterContainer = lazy(() => import('./CollectionPresenterContainer'));\n"],
|
|
5
|
-
"mappings": ";;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,OAAOC,sBAAsB;AACtC,SAASC,cAAcC,kBAAkBC,aAAaC,sBAAsB;AAKrE,IAAMC,oBAAoB,CAAC,EAAEC,SAAQ,MAAwC;;;AAClF,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,WACE,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;MAAeC,OAAON,EAAE,kBAAkB;QAAEO,IAAIL,KAAKC;MAAG,CAAA;OACvD,sBAAA,cAACK,cAAAA,MACC,sBAAA,cAACC,kBAAAA;MAAiBH,OAAON,EAAE,2BAAA;OACzB,sBAAA,cAACU,MAAMC,QAAM;MACXC,SAASb,SAASc;MAClBC,iBAAiB,CAACF,YAAab,SAASc,qBAAqB,CAAC,CAACD;;;;;AAO7E;;;ACzBA,SAASG,YAAY;AAId,IAAMC,gBAAgBC,KAAK,MAAM,OAAO,8BAAA,CAAA;AACxC,IAAMC,6BAA6BD,KAAK,MAAM,OAAO,2CAAA,CAAA;AACrD,IAAME,+BAA+BF,KAAK,MAAM,OAAO,6CAAA,CAAA;",
|
|
6
|
-
"names": ["React", "Input", "useTranslation", "ControlGroup", "ControlItemInput", "ControlPage", "ControlSection", "PresenterSettings", "settings", "t", "useTranslation", "meta", "id", "ControlPage", "ControlSection", "title", "ns", "ControlGroup", "ControlItemInput", "Input", "Switch", "checked", "presentCollections", "onCheckedChange", "lazy", "MarkdownSlide", "lazy", "DocumentPresenterContainer", "CollectionPresenterContainer"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/meta.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/presenter',\n name: 'Presenter',\n description: trim`\n Transform markdown documents into interactive presentation slideshows.\n Navigate between slides with keyboard controls and present content in full-screen mode.\n `,\n icon: 'ph--presentation--regular',\n iconHue: 'indigo',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-presenter',\n};\n"],
|
|
5
|
-
"mappings": ";AAKA,SAASA,YAAY;AAEd,IAAMC,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aAAaC;;;;EAIbC,MAAM;EACNC,SAAS;EACTC,QAAQ;AACV;",
|
|
6
|
-
"names": ["trim", "meta", "id", "name", "description", "trim", "icon", "iconHue", "source"]
|
|
7
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
meta
|
|
3
|
-
} from "./chunk-TMTUZQCK.mjs";
|
|
4
|
-
|
|
5
|
-
// src/types.ts
|
|
6
|
-
import * as Schema from "effect/Schema";
|
|
7
|
-
import { createContext } from "react";
|
|
8
|
-
import { Markdown } from "@dxos/plugin-markdown/types";
|
|
9
|
-
import { Collection } from "@dxos/schema";
|
|
10
|
-
(function(PresenterAction2) {
|
|
11
|
-
const PRESENTER_ACTION = `${meta.id}/action`;
|
|
12
|
-
class TogglePresentation extends Schema.TaggedClass()(`${PRESENTER_ACTION}/toggle-presentation`, {
|
|
13
|
-
input: Schema.Struct({
|
|
14
|
-
object: Schema.Union(Markdown.Document, Collection.Collection),
|
|
15
|
-
state: Schema.optional(Schema.Boolean)
|
|
16
|
-
}),
|
|
17
|
-
output: Schema.Void
|
|
18
|
-
}) {
|
|
19
|
-
}
|
|
20
|
-
PresenterAction2.TogglePresentation = TogglePresentation;
|
|
21
|
-
})(PresenterAction || (PresenterAction = {}));
|
|
22
|
-
var PresenterContext = createContext({
|
|
23
|
-
running: false,
|
|
24
|
-
start: () => {
|
|
25
|
-
},
|
|
26
|
-
stop: () => {
|
|
27
|
-
}
|
|
28
|
-
});
|
|
29
|
-
var PresenterSettingsSchema = Schema.mutable(Schema.Struct({
|
|
30
|
-
presentCollections: Schema.optional(Schema.Boolean)
|
|
31
|
-
}));
|
|
32
|
-
var PresenterAction;
|
|
33
|
-
|
|
34
|
-
export {
|
|
35
|
-
PresenterContext,
|
|
36
|
-
PresenterSettingsSchema,
|
|
37
|
-
PresenterAction
|
|
38
|
-
};
|
|
39
|
-
//# sourceMappingURL=chunk-VRRPVTKA.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/types.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\nimport { type Context, createContext } from 'react';\n\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { Collection } from '@dxos/schema';\n\nimport { meta } from './meta';\n\nexport namespace PresenterAction {\n const PRESENTER_ACTION = `${meta.id}/action`;\n\n export class TogglePresentation extends Schema.TaggedClass<TogglePresentation>()(\n `${PRESENTER_ACTION}/toggle-presentation`,\n {\n input: Schema.Struct({\n object: Schema.Union(Markdown.Document, Collection.Collection),\n state: Schema.optional(Schema.Boolean),\n }),\n output: Schema.Void,\n },\n ) {}\n}\n\nexport type PresenterContextType = {\n running: boolean;\n start: () => void;\n stop: () => void;\n};\n\nexport const PresenterContext: Context<PresenterContextType> = createContext<PresenterContextType>({\n running: false,\n start: () => {},\n stop: () => {},\n});\n\nexport const PresenterSettingsSchema = Schema.mutable(\n Schema.Struct({\n presentCollections: Schema.optional(Schema.Boolean),\n }),\n);\n\nexport type PresenterSettingsProps = Schema.Schema.Type<typeof PresenterSettingsSchema>;\n"],
|
|
5
|
-
"mappings": ";;;;;AAIA,YAAYA,YAAY;AACxB,SAAuBC,qBAAqB;AAE5C,SAASC,gBAAgB;AACzB,SAASC,kBAAkB;UAIVC,kBAAAA;AACf,QAAMC,mBAAmB,GAAGC,KAAKC,EAAE;EAE5B,MAAMC,2BAAkCC,mBAAW,EACxD,GAAGJ,gBAAAA,wBACH;IACEK,OAAcC,cAAO;MACnBC,QAAeC,aAAMC,SAASC,UAAUC,WAAWA,UAAU;MAC7DC,OAAcC,gBAAgBC,cAAO;IACvC,CAAA;IACAC,QAAeC;EACjB,CAAA,EAAA;EACC;mBATUb,qBAAAA;AAUf,GAbiBJ,oBAAAA,kBAAAA,CAAAA,EAAAA;AAqBV,IAAMkB,mBAAkDC,cAAoC;EACjGC,SAAS;EACTC,OAAO,MAAA;EAAO;EACdC,MAAM,MAAA;EAAO;AACf,CAAA;AAEO,IAAMC,0BAAiCC,eACrCjB,cAAO;EACZkB,oBAA2BX,gBAAgBC,cAAO;AACpD,CAAA,CAAA;;",
|
|
6
|
-
"names": ["Schema", "createContext", "Markdown", "Collection", "PresenterAction", "PRESENTER_ACTION", "meta", "id", "TogglePresentation", "TaggedClass", "input", "Struct", "object", "Union", "Markdown", "Document", "Collection", "state", "optional", "Boolean", "output", "Void", "PresenterContext", "createContext", "running", "start", "stop", "PresenterSettingsSchema", "mutable", "presentCollections"]
|
|
7
|
-
}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/react-surface.tsx"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Capabilities, contributes, createSurface } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { SettingsStore } from '@dxos/local-storage';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { Collection } from '@dxos/schema';\n\nimport {\n CollectionPresenterContainer,\n DocumentPresenterContainer,\n MarkdownSlide,\n PresenterSettings,\n} from '../components';\nimport { meta } from '../meta';\nimport { type PresenterSettingsProps } from '../types';\n\nexport default () =>\n contributes(Capabilities.ReactSurface, [\n createSurface({\n id: `${meta.id}/document`,\n role: 'article',\n position: 'hoist',\n filter: (data): data is { subject: { type: typeof meta.id; object: Markdown.Document } } =>\n !!data.subject &&\n typeof data.subject === 'object' &&\n 'type' in data.subject &&\n 'object' in data.subject &&\n data.subject.type === meta.id &&\n Obj.instanceOf(Markdown.Document, data.subject.object),\n component: ({ data }) => <DocumentPresenterContainer document={data.subject.object} />,\n }),\n createSurface({\n id: `${meta.id}/collection`,\n role: 'article',\n position: 'hoist',\n filter: (data): data is { subject: { type: typeof meta.id; object: Collection.Collection } } =>\n !!data.subject &&\n typeof data.subject === 'object' &&\n 'type' in data.subject &&\n 'object' in data.subject &&\n data.subject.type === meta.id &&\n Obj.instanceOf(Collection.Collection, data.subject.object),\n component: ({ data }) => <CollectionPresenterContainer collection={data.subject.object} />,\n }),\n createSurface({\n id: `${meta.id}/slide`,\n role: 'slide',\n filter: (data): data is { subject: Markdown.Document } => Obj.instanceOf(Markdown.Document, data.subject),\n component: ({ data }) => <MarkdownSlide document={data.subject} />,\n }),\n createSurface({\n id: `${meta.id}/plugin-settings`,\n role: 'article',\n filter: (data): data is { subject: SettingsStore<PresenterSettingsProps> } =>\n data.subject instanceof SettingsStore && data.subject.prefix === meta.id,\n component: ({ data: { subject } }) => <PresenterSettings settings={subject.value} />,\n }),\n ]);\n"],
|
|
5
|
-
"mappings": ";;;;;;;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,cAAcC,aAAaC,qBAAqB;AACzD,SAASC,WAAW;AACpB,SAASC,qBAAqB;AAC9B,SAASC,gBAAgB;AACzB,SAASC,kBAAkB;AAW3B,IAAA,yBAAe,MACbC,YAAYC,aAAaC,cAAc;EACrCC,cAAc;IACZC,IAAI,GAAGC,KAAKD,EAAE;IACdE,MAAM;IACNC,UAAU;IACVC,QAAQ,CAACC,SACP,CAAC,CAACA,KAAKC,WACP,OAAOD,KAAKC,YAAY,YACxB,UAAUD,KAAKC,WACf,YAAYD,KAAKC,WACjBD,KAAKC,QAAQC,SAASN,KAAKD,MAC3BQ,IAAIC,WAAWC,SAASC,UAAUN,KAAKC,QAAQM,MAAM;IACvDC,WAAW,CAAC,EAAER,KAAI,MAAO,sBAAA,cAACS,4BAAAA;MAA2BC,UAAUV,KAAKC,QAAQM;;EAC9E,CAAA;EACAb,cAAc;IACZC,IAAI,GAAGC,KAAKD,EAAE;IACdE,MAAM;IACNC,UAAU;IACVC,QAAQ,CAACC,SACP,CAAC,CAACA,KAAKC,WACP,OAAOD,KAAKC,YAAY,YACxB,UAAUD,KAAKC,WACf,YAAYD,KAAKC,WACjBD,KAAKC,QAAQC,SAASN,KAAKD,MAC3BQ,IAAIC,WAAWO,WAAWA,YAAYX,KAAKC,QAAQM,MAAM;IAC3DC,WAAW,CAAC,EAAER,KAAI,MAAO,sBAAA,cAACY,8BAAAA;MAA6BC,YAAYb,KAAKC,QAAQM;;EAClF,CAAA;EACAb,cAAc;IACZC,IAAI,GAAGC,KAAKD,EAAE;IACdE,MAAM;IACNE,QAAQ,CAACC,SAAiDG,IAAIC,WAAWC,SAASC,UAAUN,KAAKC,OAAO;IACxGO,WAAW,CAAC,EAAER,KAAI,MAAO,sBAAA,cAACc,eAAAA;MAAcJ,UAAUV,KAAKC;;EACzD,CAAA;EACAP,cAAc;IACZC,IAAI,GAAGC,KAAKD,EAAE;IACdE,MAAM;IACNE,QAAQ,CAACC,SACPA,KAAKC,mBAAmBc,iBAAiBf,KAAKC,QAAQe,WAAWpB,KAAKD;IACxEa,WAAW,CAAC,EAAER,MAAM,EAAEC,QAAO,EAAE,MAAO,sBAAA,cAACgB,mBAAAA;MAAkBC,UAAUjB,QAAQkB;;EAC7E,CAAA;CACD;",
|
|
6
|
-
"names": ["React", "Capabilities", "contributes", "createSurface", "Obj", "SettingsStore", "Markdown", "Collection", "contributes", "Capabilities", "ReactSurface", "createSurface", "id", "meta", "role", "position", "filter", "data", "subject", "type", "Obj", "instanceOf", "Markdown", "Document", "object", "component", "DocumentPresenterContainer", "document", "Collection", "CollectionPresenterContainer", "collection", "MarkdownSlide", "SettingsStore", "prefix", "PresenterSettings", "settings", "value"]
|
|
7
|
-
}
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
PresenterSettingsSchema
|
|
3
|
-
} from "./chunk-VRRPVTKA.mjs";
|
|
4
|
-
import {
|
|
5
|
-
meta
|
|
6
|
-
} from "./chunk-TMTUZQCK.mjs";
|
|
7
|
-
|
|
8
|
-
// src/capabilities/settings.ts
|
|
9
|
-
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
10
|
-
import { live } from "@dxos/live-object";
|
|
11
|
-
var settings_default = (() => {
|
|
12
|
-
const settings = live({});
|
|
13
|
-
return contributes(Capabilities.Settings, {
|
|
14
|
-
prefix: meta.id,
|
|
15
|
-
schema: PresenterSettingsSchema,
|
|
16
|
-
value: settings
|
|
17
|
-
});
|
|
18
|
-
});
|
|
19
|
-
export {
|
|
20
|
-
settings_default as default
|
|
21
|
-
};
|
|
22
|
-
//# sourceMappingURL=settings-57TUVRW3.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/capabilities/settings.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, contributes } from '@dxos/app-framework';\nimport { live } from '@dxos/live-object';\n\nimport { meta } from '../meta';\nimport { type PresenterSettingsProps, PresenterSettingsSchema } from '../types';\n\nexport default () => {\n const settings = live<PresenterSettingsProps>({});\n\n return contributes(Capabilities.Settings, {\n prefix: meta.id,\n schema: PresenterSettingsSchema,\n value: settings,\n });\n};\n"],
|
|
5
|
-
"mappings": ";;;;;;;;AAIA,SAASA,cAAcC,mBAAmB;AAC1C,SAASC,YAAY;AAKrB,IAAA,oBAAe,MAAA;AACb,QAAMC,WAAWC,KAA6B,CAAC,CAAA;AAE/C,SAAOC,YAAYC,aAAaC,UAAU;IACxCC,QAAQC,KAAKC;IACbC,QAAQC;IACRC,OAAOV;EACT,CAAA;AACF;",
|
|
6
|
-
"names": ["Capabilities", "contributes", "live", "settings", "live", "contributes", "Capabilities", "Settings", "prefix", "meta", "id", "schema", "PresenterSettingsSchema", "value"]
|
|
7
|
-
}
|
|
@@ -1,4 +0,0 @@
|
|
|
1
|
-
import { type PluginContext } from '@dxos/app-framework';
|
|
2
|
-
declare const _default: (context: PluginContext) => import("@dxos/app-framework").Capability<import("@dxos/app-framework").InterfaceDef<import("@dxos/app-graph").BuilderExtensions>>;
|
|
3
|
-
export default _default;
|
|
4
|
-
//# sourceMappingURL=app-graph-builder.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"app-graph-builder.d.ts","sourceRoot":"","sources":["../../../../src/capabilities/app-graph-builder.ts"],"names":[],"mappings":"AAQA,OAAO,EAA8B,KAAK,aAAa,EAA6B,MAAM,qBAAqB,CAAC;yBAYhG,SAAS,aAAa;AAAtC,wBAgGI"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"react-surface.d.ts","sourceRoot":"","sources":["../../../../src/capabilities/react-surface.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAE,YAAY,EAA8B,MAAM,qBAAqB,CAAC;;AAe/E,wBAyCK"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"settings.d.ts","sourceRoot":"","sources":["../../../../src/capabilities/settings.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,YAAY,EAAe,MAAM,qBAAqB,CAAC;;AAMhE,wBAQE"}
|
|
@@ -1,117 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { Atom } from '@effect-atom/atom-react';
|
|
6
|
-
import * as Function from 'effect/Function';
|
|
7
|
-
import * as Option from 'effect/Option';
|
|
8
|
-
|
|
9
|
-
import { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';
|
|
10
|
-
import { Obj } from '@dxos/echo';
|
|
11
|
-
import { DeckCapabilities } from '@dxos/plugin-deck';
|
|
12
|
-
import { ATTENDABLE_PATH_SEPARATOR, DeckAction } from '@dxos/plugin-deck/types';
|
|
13
|
-
import { atomFromSignal, createExtension } from '@dxos/plugin-graph';
|
|
14
|
-
import { Markdown } from '@dxos/plugin-markdown/types';
|
|
15
|
-
import { getSpace } from '@dxos/react-client/echo';
|
|
16
|
-
import { Collection } from '@dxos/schema';
|
|
17
|
-
|
|
18
|
-
import { meta } from '../meta';
|
|
19
|
-
import { PresenterAction, type PresenterSettingsProps } from '../types';
|
|
20
|
-
|
|
21
|
-
export default (context: PluginContext) =>
|
|
22
|
-
contributes(
|
|
23
|
-
Capabilities.AppGraphBuilder,
|
|
24
|
-
createExtension({
|
|
25
|
-
id: `${meta.id}/root`,
|
|
26
|
-
// TODO(wittjosiah): This is a hack to work around presenter previously relying on "variant". Remove.
|
|
27
|
-
connector: (node) =>
|
|
28
|
-
Atom.make((get) =>
|
|
29
|
-
Function.pipe(
|
|
30
|
-
get(node),
|
|
31
|
-
Option.flatMap((node) => {
|
|
32
|
-
const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
|
|
33
|
-
const settings = get(
|
|
34
|
-
atomFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value),
|
|
35
|
-
);
|
|
36
|
-
const isPresentable = settings?.presentCollections
|
|
37
|
-
? Obj.instanceOf(Collection.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)
|
|
38
|
-
: Obj.instanceOf(Markdown.Document, node.data);
|
|
39
|
-
return isPresentable ? Option.some(node.data) : Option.none();
|
|
40
|
-
}),
|
|
41
|
-
Option.map((object) => {
|
|
42
|
-
const id = Obj.getDXN(object).toString();
|
|
43
|
-
return [
|
|
44
|
-
{
|
|
45
|
-
id: [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR),
|
|
46
|
-
data: { type: meta.id, object },
|
|
47
|
-
type: meta.id,
|
|
48
|
-
properties: {
|
|
49
|
-
label: 'Presenter',
|
|
50
|
-
icon: 'ph--presentation--regular',
|
|
51
|
-
disposition: 'hidden',
|
|
52
|
-
},
|
|
53
|
-
},
|
|
54
|
-
];
|
|
55
|
-
}),
|
|
56
|
-
Option.getOrElse(() => []),
|
|
57
|
-
),
|
|
58
|
-
),
|
|
59
|
-
actions: (node) =>
|
|
60
|
-
Atom.make((get) =>
|
|
61
|
-
Function.pipe(
|
|
62
|
-
get(node),
|
|
63
|
-
Option.flatMap((node) => {
|
|
64
|
-
const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
|
|
65
|
-
const settings = get(
|
|
66
|
-
atomFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value),
|
|
67
|
-
);
|
|
68
|
-
const isPresentable = settings?.presentCollections
|
|
69
|
-
? Obj.instanceOf(Collection.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)
|
|
70
|
-
: Obj.instanceOf(Markdown.Document, node.data);
|
|
71
|
-
return isPresentable ? Option.some(node.data) : Option.none();
|
|
72
|
-
}),
|
|
73
|
-
Option.map((object) => {
|
|
74
|
-
const id = Obj.getDXN(object).toString();
|
|
75
|
-
const spaceId = getSpace(object)?.id;
|
|
76
|
-
return [
|
|
77
|
-
{
|
|
78
|
-
id: `${PresenterAction.TogglePresentation._tag}/${id}`,
|
|
79
|
-
// TODO(burdon): Allow function so can generate state when activated.
|
|
80
|
-
// So can set explicit fullscreen state coordinated with current presenter state.
|
|
81
|
-
data: async () => {
|
|
82
|
-
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
83
|
-
const layout = context.getCapability(DeckCapabilities.MutableDeckState);
|
|
84
|
-
const presenterId = [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR);
|
|
85
|
-
if (!layout.deck.fullscreen) {
|
|
86
|
-
void dispatch(
|
|
87
|
-
createIntent(DeckAction.Adjust, {
|
|
88
|
-
type: 'solo--fullscreen',
|
|
89
|
-
id: presenterId,
|
|
90
|
-
}),
|
|
91
|
-
);
|
|
92
|
-
}
|
|
93
|
-
await dispatch(
|
|
94
|
-
createIntent(LayoutAction.Open, {
|
|
95
|
-
part: 'main',
|
|
96
|
-
subject: [presenterId],
|
|
97
|
-
options: { workspace: spaceId },
|
|
98
|
-
}),
|
|
99
|
-
);
|
|
100
|
-
},
|
|
101
|
-
properties: {
|
|
102
|
-
label: ['toggle presentation label', { ns: meta.id }],
|
|
103
|
-
icon: 'ph--presentation--regular',
|
|
104
|
-
disposition: 'list-item',
|
|
105
|
-
keyBinding: {
|
|
106
|
-
macos: 'shift+meta+p',
|
|
107
|
-
windows: 'shift+alt+p',
|
|
108
|
-
},
|
|
109
|
-
},
|
|
110
|
-
},
|
|
111
|
-
];
|
|
112
|
-
}),
|
|
113
|
-
Option.getOrElse(() => []),
|
|
114
|
-
),
|
|
115
|
-
),
|
|
116
|
-
}),
|
|
117
|
-
);
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import React from 'react';
|
|
6
|
-
|
|
7
|
-
import { Capabilities, contributes, createSurface } from '@dxos/app-framework';
|
|
8
|
-
import { Obj } from '@dxos/echo';
|
|
9
|
-
import { SettingsStore } from '@dxos/local-storage';
|
|
10
|
-
import { Markdown } from '@dxos/plugin-markdown/types';
|
|
11
|
-
import { Collection } from '@dxos/schema';
|
|
12
|
-
|
|
13
|
-
import {
|
|
14
|
-
CollectionPresenterContainer,
|
|
15
|
-
DocumentPresenterContainer,
|
|
16
|
-
MarkdownSlide,
|
|
17
|
-
PresenterSettings,
|
|
18
|
-
} from '../components';
|
|
19
|
-
import { meta } from '../meta';
|
|
20
|
-
import { type PresenterSettingsProps } from '../types';
|
|
21
|
-
|
|
22
|
-
export default () =>
|
|
23
|
-
contributes(Capabilities.ReactSurface, [
|
|
24
|
-
createSurface({
|
|
25
|
-
id: `${meta.id}/document`,
|
|
26
|
-
role: 'article',
|
|
27
|
-
position: 'hoist',
|
|
28
|
-
filter: (data): data is { subject: { type: typeof meta.id; object: Markdown.Document } } =>
|
|
29
|
-
!!data.subject &&
|
|
30
|
-
typeof data.subject === 'object' &&
|
|
31
|
-
'type' in data.subject &&
|
|
32
|
-
'object' in data.subject &&
|
|
33
|
-
data.subject.type === meta.id &&
|
|
34
|
-
Obj.instanceOf(Markdown.Document, data.subject.object),
|
|
35
|
-
component: ({ data }) => <DocumentPresenterContainer document={data.subject.object} />,
|
|
36
|
-
}),
|
|
37
|
-
createSurface({
|
|
38
|
-
id: `${meta.id}/collection`,
|
|
39
|
-
role: 'article',
|
|
40
|
-
position: 'hoist',
|
|
41
|
-
filter: (data): data is { subject: { type: typeof meta.id; object: Collection.Collection } } =>
|
|
42
|
-
!!data.subject &&
|
|
43
|
-
typeof data.subject === 'object' &&
|
|
44
|
-
'type' in data.subject &&
|
|
45
|
-
'object' in data.subject &&
|
|
46
|
-
data.subject.type === meta.id &&
|
|
47
|
-
Obj.instanceOf(Collection.Collection, data.subject.object),
|
|
48
|
-
component: ({ data }) => <CollectionPresenterContainer collection={data.subject.object} />,
|
|
49
|
-
}),
|
|
50
|
-
createSurface({
|
|
51
|
-
id: `${meta.id}/slide`,
|
|
52
|
-
role: 'slide',
|
|
53
|
-
filter: (data): data is { subject: Markdown.Document } => Obj.instanceOf(Markdown.Document, data.subject),
|
|
54
|
-
component: ({ data }) => <MarkdownSlide document={data.subject} />,
|
|
55
|
-
}),
|
|
56
|
-
createSurface({
|
|
57
|
-
id: `${meta.id}/plugin-settings`,
|
|
58
|
-
role: 'article',
|
|
59
|
-
filter: (data): data is { subject: SettingsStore<PresenterSettingsProps> } =>
|
|
60
|
-
data.subject instanceof SettingsStore && data.subject.prefix === meta.id,
|
|
61
|
-
component: ({ data: { subject } }) => <PresenterSettings settings={subject.value} />,
|
|
62
|
-
}),
|
|
63
|
-
]);
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { Capabilities, contributes } from '@dxos/app-framework';
|
|
6
|
-
import { live } from '@dxos/live-object';
|
|
7
|
-
|
|
8
|
-
import { meta } from '../meta';
|
|
9
|
-
import { type PresenterSettingsProps, PresenterSettingsSchema } from '../types';
|
|
10
|
-
|
|
11
|
-
export default () => {
|
|
12
|
-
const settings = live<PresenterSettingsProps>({});
|
|
13
|
-
|
|
14
|
-
return contributes(Capabilities.Settings, {
|
|
15
|
-
prefix: meta.id,
|
|
16
|
-
schema: PresenterSettingsSchema,
|
|
17
|
-
value: settings,
|
|
18
|
-
});
|
|
19
|
-
};
|