@dxos/plugin-presenter 0.8.4-main.67995b8 → 0.8.4-main.69d29f4
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-GIYJABHE.mjs +200 -0
- 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-VQVZVXPJ.mjs +18 -0
- package/dist/lib/browser/chunk-VQVZVXPJ.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +24 -32
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react-surface-2VP2M4Z7.mjs +63 -0
- 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 +5 -5
- package/dist/types/src/components/CollectionPresenterContainer.d.ts.map +1 -1
- package/dist/types/src/components/DocumentPresenterContainer.d.ts.map +1 -1
- package/dist/types/src/components/Markdown/Container.stories.d.ts +14 -22
- package/dist/types/src/components/Markdown/Container.stories.d.ts.map +1 -1
- package/dist/types/src/components/Markdown/Slide.d.ts +1 -3
- package/dist/types/src/components/Markdown/Slide.d.ts.map +1 -1
- package/dist/types/src/components/Markdown/Slide.stories.d.ts +11 -12
- package/dist/types/src/components/Markdown/Slide.stories.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/Presenter/Pager.stories.d.ts +12 -4
- package/dist/types/src/components/Presenter/Pager.stories.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/RevealPlayer/RevealPlayer.stories.d.ts +18 -2
- package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +25 -7
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +2 -3
- package/dist/types/src/meta.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.d.ts +36 -26
- 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 +47 -41
- package/src/PresenterPlugin.tsx +8 -24
- 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 +14 -14
- package/src/components/DocumentPresenterContainer.tsx +5 -4
- package/src/components/Markdown/Container.stories.tsx +21 -20
- package/src/components/Markdown/Container.tsx +2 -2
- package/src/components/Markdown/Slide.stories.tsx +11 -7
- package/src/components/Markdown/Slide.tsx +12 -128
- package/src/components/Markdown/styles.css +104 -0
- package/src/components/Markdown/theme.ts +2 -2
- package/src/components/Markdown/typings.d.ts +8 -0
- package/src/components/MarkdownSlide.tsx +6 -2
- package/src/components/Presenter/Layout.tsx +1 -1
- package/src/components/Presenter/Pager.stories.tsx +8 -8
- package/src/components/Presenter/Pager.tsx +53 -18
- package/src/components/PresenterSettings.tsx +21 -12
- package/src/components/RevealPlayer/RevealPlayer.stories.tsx +7 -5
- package/src/components/RevealPlayer/RevealPlayer.tsx +65 -58
- package/src/meta.ts +9 -6
- package/src/translations.ts +1 -0
- package/src/types.ts +18 -10
- package/src/useExitPresenter.ts +24 -24
- package/dist/lib/browser/CollectionPresenterContainer-IPDW4HZR.mjs +0 -191
- package/dist/lib/browser/CollectionPresenterContainer-IPDW4HZR.mjs.map +0 -7
- package/dist/lib/browser/DocumentPresenterContainer-LJBJM5UB.mjs +0 -185
- package/dist/lib/browser/DocumentPresenterContainer-LJBJM5UB.mjs.map +0 -7
- package/dist/lib/browser/MarkdownSlide-KG7ESCSU.mjs +0 -336
- package/dist/lib/browser/MarkdownSlide-KG7ESCSU.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-LURIPUEV.mjs +0 -77
- package/dist/lib/browser/app-graph-builder-LURIPUEV.mjs.map +0 -7
- package/dist/lib/browser/chunk-QWJM3ADC.mjs +0 -37
- package/dist/lib/browser/chunk-QWJM3ADC.mjs.map +0 -7
- package/dist/lib/browser/chunk-TANLITL2.mjs +0 -36
- package/dist/lib/browser/chunk-TANLITL2.mjs.map +0 -7
- package/dist/lib/browser/chunk-VSD5LSE5.mjs +0 -15
- package/dist/lib/browser/chunk-VSD5LSE5.mjs.map +0 -7
- package/dist/lib/browser/chunk-W4IR3DJE.mjs +0 -39
- package/dist/lib/browser/chunk-W4IR3DJE.mjs.map +0 -7
- package/dist/lib/browser/react-surface-3SPF2ANF.mjs +0 -57
- package/dist/lib/browser/react-surface-3SPF2ANF.mjs.map +0 -7
- package/dist/lib/browser/settings-VBRYUIWN.mjs +0 -22
- package/dist/lib/browser/settings-VBRYUIWN.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 -82
- package/src/capabilities/react-surface.tsx +0 -53
- package/src/capabilities/settings.ts +0 -19
|
@@ -0,0 +1,112 @@
|
|
|
1
|
+
import {
|
|
2
|
+
PresenterCapabilities,
|
|
3
|
+
PresenterOperation
|
|
4
|
+
} from "./chunk-4PZXJXBO.mjs";
|
|
5
|
+
import {
|
|
6
|
+
meta
|
|
7
|
+
} from "./chunk-VQVZVXPJ.mjs";
|
|
8
|
+
|
|
9
|
+
// src/capabilities/app-graph-builder/app-graph-builder.ts
|
|
10
|
+
import * as Effect from "effect/Effect";
|
|
11
|
+
import * as Option from "effect/Option";
|
|
12
|
+
import { Capability, Common } from "@dxos/app-framework";
|
|
13
|
+
import { Obj } from "@dxos/echo";
|
|
14
|
+
import { Operation } from "@dxos/operation";
|
|
15
|
+
import { DeckCapabilities } from "@dxos/plugin-deck";
|
|
16
|
+
import { ATTENDABLE_PATH_SEPARATOR, DeckOperation } from "@dxos/plugin-deck/types";
|
|
17
|
+
import { GraphBuilder, NodeMatcher } from "@dxos/plugin-graph";
|
|
18
|
+
import { Markdown } from "@dxos/plugin-markdown/types";
|
|
19
|
+
import { Collection } from "@dxos/schema";
|
|
20
|
+
var whenPresentable = (node) => Option.orElse(NodeMatcher.whenEchoType(Collection.Collection)(node), () => NodeMatcher.whenEchoType(Markdown.Document)(node));
|
|
21
|
+
var app_graph_builder_default = Capability.makeModule(Effect.fnUntraced(function* () {
|
|
22
|
+
const capabilities = yield* Capability.Service;
|
|
23
|
+
const extensions = yield* GraphBuilder.createExtension({
|
|
24
|
+
id: `${meta.id}/root`,
|
|
25
|
+
// TODO(wittjosiah): This is a hack to work around presenter previously relying on "variant". Remove.
|
|
26
|
+
match: whenPresentable,
|
|
27
|
+
connector: (object, get) => {
|
|
28
|
+
const settingsAtom = capabilities.get(PresenterCapabilities.Settings);
|
|
29
|
+
const settings = get(settingsAtom);
|
|
30
|
+
const isPresentable = settings?.presentCollections ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object) : Obj.instanceOf(Markdown.Document, object);
|
|
31
|
+
if (!isPresentable) {
|
|
32
|
+
return Effect.succeed([]);
|
|
33
|
+
}
|
|
34
|
+
const id = Obj.getDXN(object).toString();
|
|
35
|
+
return Effect.succeed([
|
|
36
|
+
{
|
|
37
|
+
id: [
|
|
38
|
+
id,
|
|
39
|
+
"presenter"
|
|
40
|
+
].join(ATTENDABLE_PATH_SEPARATOR),
|
|
41
|
+
data: {
|
|
42
|
+
type: meta.id,
|
|
43
|
+
object
|
|
44
|
+
},
|
|
45
|
+
type: meta.id,
|
|
46
|
+
properties: {
|
|
47
|
+
label: "Presenter",
|
|
48
|
+
icon: "ph--presentation--regular",
|
|
49
|
+
disposition: "hidden"
|
|
50
|
+
}
|
|
51
|
+
}
|
|
52
|
+
]);
|
|
53
|
+
},
|
|
54
|
+
actions: (object, get) => {
|
|
55
|
+
const settingsAtom = capabilities.get(PresenterCapabilities.Settings);
|
|
56
|
+
const settings = get(settingsAtom);
|
|
57
|
+
const isPresentable = settings?.presentCollections ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object) : Obj.instanceOf(Markdown.Document, object);
|
|
58
|
+
if (!isPresentable) {
|
|
59
|
+
return Effect.succeed([]);
|
|
60
|
+
}
|
|
61
|
+
const dxn = Obj.getDXN(object);
|
|
62
|
+
const id = dxn.toString();
|
|
63
|
+
const { spaceId } = dxn.asEchoDXN();
|
|
64
|
+
return Effect.succeed([
|
|
65
|
+
{
|
|
66
|
+
id: `${PresenterOperation.TogglePresentation.meta.key}/${id}`,
|
|
67
|
+
// TODO(burdon): Allow function so can generate state when activated.
|
|
68
|
+
// So can set explicit fullscreen state coordinated with current presenter state.
|
|
69
|
+
data: Effect.fnUntraced(function* () {
|
|
70
|
+
const deckState = yield* Common.Capability.getAtomValue(DeckCapabilities.State);
|
|
71
|
+
const deck = deckState.decks[deckState.activeDeck];
|
|
72
|
+
const presenterId = [
|
|
73
|
+
id,
|
|
74
|
+
"presenter"
|
|
75
|
+
].join(ATTENDABLE_PATH_SEPARATOR);
|
|
76
|
+
if (!deck?.fullscreen) {
|
|
77
|
+
yield* Operation.invoke(DeckOperation.Adjust, {
|
|
78
|
+
type: "solo--fullscreen",
|
|
79
|
+
id: presenterId
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
yield* Operation.invoke(Common.LayoutOperation.Open, {
|
|
83
|
+
subject: [
|
|
84
|
+
presenterId
|
|
85
|
+
],
|
|
86
|
+
workspace: spaceId
|
|
87
|
+
});
|
|
88
|
+
}),
|
|
89
|
+
properties: {
|
|
90
|
+
label: [
|
|
91
|
+
"toggle presentation label",
|
|
92
|
+
{
|
|
93
|
+
ns: meta.id
|
|
94
|
+
}
|
|
95
|
+
],
|
|
96
|
+
icon: "ph--presentation--regular",
|
|
97
|
+
disposition: "list-item",
|
|
98
|
+
keyBinding: {
|
|
99
|
+
macos: "shift+meta+p",
|
|
100
|
+
windows: "shift+alt+p"
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
]);
|
|
105
|
+
}
|
|
106
|
+
});
|
|
107
|
+
return Capability.contributes(Common.Capability.AppGraphBuilder, extensions);
|
|
108
|
+
}));
|
|
109
|
+
export {
|
|
110
|
+
app_graph_builder_default as default
|
|
111
|
+
};
|
|
112
|
+
//# sourceMappingURL=app-graph-builder-2QAQR34J.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';\nimport * as Option from 'effect/Option';\n\nimport { Capability, Common } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { Operation } from '@dxos/operation';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { ATTENDABLE_PATH_SEPARATOR, DeckOperation } from '@dxos/plugin-deck/types';\nimport { GraphBuilder, type Node, NodeMatcher } from '@dxos/plugin-graph';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { Collection } from '@dxos/schema';\n\nimport { meta } from '../../meta';\nimport { PresenterCapabilities, PresenterOperation } from '../../types';\n\n/** Match nodes that can be presented (Collection or Document). */\nconst whenPresentable = (node: Node.Node) =>\n Option.orElse(NodeMatcher.whenEchoType(Collection.Collection)(node), () =>\n NodeMatcher.whenEchoType(Markdown.Document)(node),\n );\n\nexport default Capability.makeModule(\n Effect.fnUntraced(function* () {\n const capabilities = yield* Capability.Service;\n\n const extensions = yield* GraphBuilder.createExtension({\n id: `${meta.id}/root`,\n // TODO(wittjosiah): This is a hack to work around presenter previously relying on \"variant\". Remove.\n match: whenPresentable,\n connector: (object, get) => {\n const settingsAtom = capabilities.get(PresenterCapabilities.Settings);\n const settings = get(settingsAtom);\n const isPresentable = settings?.presentCollections\n ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object)\n : Obj.instanceOf(Markdown.Document, object);\n if (!isPresentable) {\n return Effect.succeed([]);\n }\n const id = Obj.getDXN(object).toString();\n return Effect.succeed([\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 actions: (object, get) => {\n const settingsAtom = capabilities.get(PresenterCapabilities.Settings);\n const settings = get(settingsAtom);\n const isPresentable = settings?.presentCollections\n ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object)\n : Obj.instanceOf(Markdown.Document, object);\n if (!isPresentable) {\n return Effect.succeed([]);\n }\n const dxn = Obj.getDXN(object);\n const id = dxn.toString();\n const { spaceId } = dxn.asEchoDXN()!;\n return Effect.succeed([\n {\n id: `${PresenterOperation.TogglePresentation.meta.key}/${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: Effect.fnUntraced(function* () {\n const deckState = yield* Common.Capability.getAtomValue(DeckCapabilities.State);\n const deck = deckState.decks[deckState.activeDeck];\n const presenterId = [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR);\n if (!deck?.fullscreen) {\n yield* Operation.invoke(DeckOperation.Adjust, {\n type: 'solo--fullscreen' as const,\n id: presenterId,\n });\n }\n yield* Operation.invoke(Common.LayoutOperation.Open, {\n subject: [presenterId],\n workspace: spaceId,\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 });\n\n return Capability.contributes(Common.Capability.AppGraphBuilder, extensions);\n }),\n);\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Effect", "Option", "Capability", "Common", "Obj", "Operation", "DeckCapabilities", "ATTENDABLE_PATH_SEPARATOR", "DeckOperation", "GraphBuilder", "NodeMatcher", "Markdown", "Collection", "whenPresentable", "node", "orElse", "NodeMatcher", "whenEchoType", "Collection", "Markdown", "Document", "Capability", "makeModule", "fnUntraced", "capabilities", "Service", "extensions", "GraphBuilder", "createExtension", "id", "meta", "match", "connector", "object", "get", "settingsAtom", "PresenterCapabilities", "Settings", "settings", "isPresentable", "presentCollections", "Obj", "instanceOf", "succeed", "getDXN", "toString", "join", "ATTENDABLE_PATH_SEPARATOR", "data", "type", "properties", "label", "icon", "disposition", "actions", "dxn", "spaceId", "asEchoDXN", "PresenterOperation", "TogglePresentation", "key", "deckState", "Common", "getAtomValue", "DeckCapabilities", "State", "deck", "decks", "activeDeck", "presenterId", "fullscreen", "Operation", "invoke", "DeckOperation", "Adjust", "LayoutOperation", "Open", "subject", "workspace", "ns", "keyBinding", "macos", "windows", "contributes", "AppGraphBuilder"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import {
|
|
2
|
+
meta
|
|
3
|
+
} from "./chunk-VQVZVXPJ.mjs";
|
|
4
|
+
|
|
5
|
+
// src/types.ts
|
|
6
|
+
import * as Schema from "effect/Schema";
|
|
7
|
+
import { createContext } from "react";
|
|
8
|
+
import { Capability } from "@dxos/app-framework";
|
|
9
|
+
import { Operation } from "@dxos/operation";
|
|
10
|
+
import { Markdown } from "@dxos/plugin-markdown/types";
|
|
11
|
+
import { Collection } from "@dxos/schema";
|
|
12
|
+
var PRESENTER_OPERATION = `${meta.id}/operation`;
|
|
13
|
+
(function(PresenterOperation2) {
|
|
14
|
+
PresenterOperation2.TogglePresentation = Operation.make({
|
|
15
|
+
meta: {
|
|
16
|
+
key: `${PRESENTER_OPERATION}/toggle-presentation`,
|
|
17
|
+
name: "Toggle Presentation"
|
|
18
|
+
},
|
|
19
|
+
schema: {
|
|
20
|
+
input: Schema.Struct({
|
|
21
|
+
object: Schema.Union(Markdown.Document, Collection.Collection),
|
|
22
|
+
state: Schema.optional(Schema.Boolean)
|
|
23
|
+
}),
|
|
24
|
+
output: Schema.Void
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
})(PresenterOperation || (PresenterOperation = {}));
|
|
28
|
+
var PresenterContext = createContext({
|
|
29
|
+
running: false,
|
|
30
|
+
start: () => {
|
|
31
|
+
},
|
|
32
|
+
stop: () => {
|
|
33
|
+
}
|
|
34
|
+
});
|
|
35
|
+
var PresenterSettingsSchema = Schema.mutable(Schema.Struct({
|
|
36
|
+
presentCollections: Schema.optional(Schema.Boolean)
|
|
37
|
+
}));
|
|
38
|
+
(function(PresenterCapabilities2) {
|
|
39
|
+
PresenterCapabilities2.Settings = Capability.make(`${meta.id}/capability/settings`);
|
|
40
|
+
})(PresenterCapabilities || (PresenterCapabilities = {}));
|
|
41
|
+
var PresenterOperation;
|
|
42
|
+
var PresenterCapabilities;
|
|
43
|
+
|
|
44
|
+
export {
|
|
45
|
+
PresenterContext,
|
|
46
|
+
PresenterSettingsSchema,
|
|
47
|
+
PresenterOperation,
|
|
48
|
+
PresenterCapabilities
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=chunk-4PZXJXBO.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/types.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Atom } from '@effect-atom/atom-react';\nimport * as Schema from 'effect/Schema';\nimport { type Context, createContext } from 'react';\n\nimport { Capability } from '@dxos/app-framework';\nimport { Operation } from '@dxos/operation';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { Collection } from '@dxos/schema';\n\nimport { meta } from './meta';\n\nconst PRESENTER_OPERATION = `${meta.id}/operation`;\n\n// TODO(wittjosiah): This appears to be unused.\nexport namespace PresenterOperation {\n export const TogglePresentation = Operation.make({\n meta: { key: `${PRESENTER_OPERATION}/toggle-presentation`, name: 'Toggle Presentation' },\n schema: {\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\nexport namespace PresenterCapabilities {\n export const Settings = Capability.make<Atom.Writable<PresenterSettingsProps>>(`${meta.id}/capability/settings`);\n}\n"],
|
|
5
|
+
"mappings": ";;;;;AAKA,YAAYA,YAAY;AACxB,SAAuBC,qBAAqB;AAE5C,SAASC,kBAAkB;AAC3B,SAASC,iBAAiB;AAC1B,SAASC,gBAAgB;AACzB,SAASC,kBAAkB;AAI3B,IAAMC,sBAAsB,GAAGC,KAAKC,EAAE;UAGrBC,qBAAAA;sBACFC,qBAAqBC,UAAUC,KAAK;IAC/CL,MAAM;MAAEM,KAAK,GAAGP,mBAAAA;MAA2CQ,MAAM;IAAsB;IACvFC,QAAQ;MACNC,OAAcC,cAAO;QACnBC,QAAeC,aAAMC,SAASC,UAAUC,WAAWA,UAAU;QAC7DC,OAAcC,gBAAgBC,cAAO;MACvC,CAAA;MACAC,QAAeC;IACjB;EACF,CAAA;AACF,GAXiBlB,uBAAAA,qBAAAA,CAAAA,EAAAA;AAmBV,IAAMmB,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;UAKeW,wBAAAA;yBACFC,WAAWC,WAAW1B,KAA4C,GAAGL,KAAKC,EAAE,sBAAsB;AACjH,GAFiB4B,0BAAAA,wBAAAA,CAAAA,EAAAA;;;",
|
|
6
|
+
"names": ["Schema", "createContext", "Capability", "Operation", "Markdown", "Collection", "PRESENTER_OPERATION", "meta", "id", "PresenterOperation", "TogglePresentation", "Operation", "make", "key", "name", "schema", "input", "Struct", "object", "Union", "Markdown", "Document", "Collection", "state", "optional", "Boolean", "output", "Void", "PresenterContext", "createContext", "running", "start", "stop", "PresenterSettingsSchema", "mutable", "presentCollections", "PresenterCapabilities", "Settings", "Capability"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import {
|
|
2
|
+
meta
|
|
3
|
+
} from "./chunk-VQVZVXPJ.mjs";
|
|
4
|
+
|
|
5
|
+
// src/components/PresenterSettings.tsx
|
|
6
|
+
import React from "react";
|
|
7
|
+
import { Input, useTranslation } from "@dxos/react-ui";
|
|
8
|
+
import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from "@dxos/react-ui-form";
|
|
9
|
+
var PresenterSettings = ({ settings, onSettingsChange }) => {
|
|
10
|
+
const { t } = useTranslation(meta.id);
|
|
11
|
+
return /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
|
|
12
|
+
title: t("settings title", {
|
|
13
|
+
ns: meta.id
|
|
14
|
+
})
|
|
15
|
+
}, /* @__PURE__ */ React.createElement(ControlGroup, null, /* @__PURE__ */ React.createElement(ControlItemInput, {
|
|
16
|
+
title: t("present collections label")
|
|
17
|
+
}, /* @__PURE__ */ React.createElement(Input.Switch, {
|
|
18
|
+
checked: settings.presentCollections,
|
|
19
|
+
onCheckedChange: (checked) => onSettingsChange((s) => ({
|
|
20
|
+
...s,
|
|
21
|
+
presentCollections: !!checked
|
|
22
|
+
}))
|
|
23
|
+
})))));
|
|
24
|
+
};
|
|
25
|
+
|
|
26
|
+
// src/components/index.ts
|
|
27
|
+
import { lazy } from "react";
|
|
28
|
+
var MarkdownSlide = lazy(() => import("./MarkdownSlide-GIYJABHE.mjs"));
|
|
29
|
+
var DocumentPresenterContainer = lazy(() => import("./DocumentPresenterContainer-74M6XAAI.mjs"));
|
|
30
|
+
var CollectionPresenterContainer = lazy(() => import("./CollectionPresenterContainer-IHDZWP3U.mjs"));
|
|
31
|
+
|
|
32
|
+
export {
|
|
33
|
+
PresenterSettings,
|
|
34
|
+
MarkdownSlide,
|
|
35
|
+
DocumentPresenterContainer,
|
|
36
|
+
CollectionPresenterContainer
|
|
37
|
+
};
|
|
38
|
+
//# sourceMappingURL=chunk-5MC4V23G.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
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 type PresenterSettingsComponentProps = {\n settings: PresenterSettingsProps;\n onSettingsChange: (fn: (current: PresenterSettingsProps) => PresenterSettingsProps) => void;\n};\n\nexport const PresenterSettings = ({ settings, onSettingsChange }: PresenterSettingsComponentProps) => {\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) => onSettingsChange((s) => ({ ...s, 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;AAUrE,IAAMC,oBAAoB,CAAC,EAAEC,UAAUC,iBAAgB,MAAmC;AAC/F,QAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,SACE,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;IAAeC,OAAON,EAAE,kBAAkB;MAAEO,IAAIL,KAAKC;IAAG,CAAA;KACvD,sBAAA,cAACK,cAAAA,MACC,sBAAA,cAACC,kBAAAA;IAAiBH,OAAON,EAAE,2BAAA;KACzB,sBAAA,cAACU,MAAMC,QAAM;IACXC,SAASd,SAASe;IAClBC,iBAAiB,CAACF,YAAYb,iBAAiB,CAACgB,OAAO;MAAE,GAAGA;MAAGF,oBAAoB,CAAC,CAACD;IAAQ,EAAA;;AAO3G;;;AC9BA,SAASI,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", "onSettingsChange", "t", "useTranslation", "meta", "id", "ControlPage", "ControlSection", "title", "ns", "ControlGroup", "ControlItemInput", "Input", "Switch", "checked", "presentCollections", "onCheckedChange", "s", "lazy", "MarkdownSlide", "lazy", "DocumentPresenterContainer", "CollectionPresenterContainer"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
// src/useExitPresenter.ts
|
|
2
|
+
import { useAtomValue } from "@effect-atom/atom-react";
|
|
3
|
+
import { useCallback, useMemo } from "react";
|
|
4
|
+
import { Common } from "@dxos/app-framework";
|
|
5
|
+
import { useCapability, useOperationInvoker } from "@dxos/app-framework/react";
|
|
6
|
+
import { Obj } from "@dxos/echo";
|
|
7
|
+
import { DeckCapabilities } from "@dxos/plugin-deck";
|
|
8
|
+
import { DeckOperation } from "@dxos/plugin-deck/types";
|
|
9
|
+
var useExitPresenter = (object) => {
|
|
10
|
+
const { invokePromise } = useOperationInvoker();
|
|
11
|
+
const stateAtom = useCapability(DeckCapabilities.State);
|
|
12
|
+
const state = useAtomValue(stateAtom);
|
|
13
|
+
const deck = useMemo(() => state.decks[state.activeDeck], [
|
|
14
|
+
state.decks,
|
|
15
|
+
state.activeDeck
|
|
16
|
+
]);
|
|
17
|
+
return useCallback(() => {
|
|
18
|
+
const objectId = Obj.getDXN(object).toString();
|
|
19
|
+
if (deck?.fullscreen) {
|
|
20
|
+
void invokePromise(DeckOperation.Adjust, {
|
|
21
|
+
type: "solo--fullscreen",
|
|
22
|
+
id: objectId
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
return invokePromise(Common.LayoutOperation.Open, {
|
|
26
|
+
subject: [
|
|
27
|
+
objectId
|
|
28
|
+
],
|
|
29
|
+
workspace: Obj.getDatabase(object)?.spaceId
|
|
30
|
+
});
|
|
31
|
+
}, [
|
|
32
|
+
invokePromise,
|
|
33
|
+
object,
|
|
34
|
+
deck
|
|
35
|
+
]);
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
export {
|
|
39
|
+
useExitPresenter
|
|
40
|
+
};
|
|
41
|
+
//# sourceMappingURL=chunk-GM4KOXJY.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/useExitPresenter.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useAtomValue } from '@effect-atom/atom-react';\nimport { useCallback, useMemo } from 'react';\n\nimport { Common } from '@dxos/app-framework';\nimport { useCapability, useOperationInvoker } from '@dxos/app-framework/react';\nimport { Obj } from '@dxos/echo';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { DeckOperation } from '@dxos/plugin-deck/types';\n\nexport const useExitPresenter = (object: any) => {\n const { invokePromise } = useOperationInvoker();\n const stateAtom = useCapability(DeckCapabilities.State);\n const state = useAtomValue(stateAtom);\n\n // Compute deck from decks[activeDeck] since the getter doesn't survive spread operations.\n const deck = useMemo(() => state.decks[state.activeDeck], [state.decks, state.activeDeck]);\n\n return useCallback(() => {\n const objectId = Obj.getDXN(object).toString();\n if (deck?.fullscreen) {\n void invokePromise(DeckOperation.Adjust, {\n type: 'solo--fullscreen',\n id: objectId,\n });\n }\n return invokePromise(Common.LayoutOperation.Open, {\n subject: [objectId],\n workspace: Obj.getDatabase(object)?.spaceId,\n });\n }, [invokePromise, object, deck]);\n};\n"],
|
|
5
|
+
"mappings": ";AAIA,SAASA,oBAAoB;AAC7B,SAASC,aAAaC,eAAe;AAErC,SAASC,cAAc;AACvB,SAASC,eAAeC,2BAA2B;AACnD,SAASC,WAAW;AACpB,SAASC,wBAAwB;AACjC,SAASC,qBAAqB;AAEvB,IAAMC,mBAAmB,CAACC,WAAAA;AAC/B,QAAM,EAAEC,cAAa,IAAKC,oBAAAA;AAC1B,QAAMC,YAAYC,cAAcC,iBAAiBC,KAAK;AACtD,QAAMC,QAAQC,aAAaL,SAAAA;AAG3B,QAAMM,OAAOC,QAAQ,MAAMH,MAAMI,MAAMJ,MAAMK,UAAU,GAAG;IAACL,MAAMI;IAAOJ,MAAMK;GAAW;AAEzF,SAAOC,YAAY,MAAA;AACjB,UAAMC,WAAWC,IAAIC,OAAOhB,MAAAA,EAAQiB,SAAQ;AAC5C,QAAIR,MAAMS,YAAY;AACpB,WAAKjB,cAAckB,cAAcC,QAAQ;QACvCC,MAAM;QACNC,IAAIR;MACN,CAAA;IACF;AACA,WAAOb,cAAcsB,OAAOC,gBAAgBC,MAAM;MAChDC,SAAS;QAACZ;;MACVa,WAAWZ,IAAIa,YAAY5B,MAAAA,GAAS6B;IACtC,CAAA;EACF,GAAG;IAAC5B;IAAeD;IAAQS;GAAK;AAClC;",
|
|
6
|
+
"names": ["useAtomValue", "useCallback", "useMemo", "Common", "useCapability", "useOperationInvoker", "Obj", "DeckCapabilities", "DeckOperation", "useExitPresenter", "object", "invokePromise", "useOperationInvoker", "stateAtom", "useCapability", "DeckCapabilities", "State", "state", "useAtomValue", "deck", "useMemo", "decks", "activeDeck", "useCallback", "objectId", "Obj", "getDXN", "toString", "fullscreen", "DeckOperation", "Adjust", "type", "id", "Common", "LayoutOperation", "Open", "subject", "workspace", "getDatabase", "spaceId"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
// src/meta.ts
|
|
2
|
+
import { trim } from "@dxos/util";
|
|
3
|
+
var meta = {
|
|
4
|
+
id: "dxos.org/plugin/presenter",
|
|
5
|
+
name: "Presenter",
|
|
6
|
+
description: trim`
|
|
7
|
+
Transform markdown documents into interactive presentation slideshows.
|
|
8
|
+
Navigate between slides with keyboard controls and present content in full-screen mode.
|
|
9
|
+
`,
|
|
10
|
+
icon: "ph--presentation--regular",
|
|
11
|
+
iconHue: "indigo",
|
|
12
|
+
source: "https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-presenter"
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export {
|
|
16
|
+
meta
|
|
17
|
+
};
|
|
18
|
+
//# sourceMappingURL=chunk-VQVZVXPJ.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/meta.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Plugin } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: Plugin.Meta = {\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,OAAoB;EAC/BC,IAAI;EACJC,MAAM;EACNC,aAAaC;;;;EAIbC,MAAM;EACNC,SAAS;EACTC,QAAQ;AACV;",
|
|
6
|
+
"names": ["trim", "meta", "id", "name", "description", "trim", "icon", "iconHue", "source"]
|
|
7
|
+
}
|
|
@@ -3,20 +3,25 @@ import {
|
|
|
3
3
|
DocumentPresenterContainer,
|
|
4
4
|
MarkdownSlide,
|
|
5
5
|
PresenterSettings
|
|
6
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-5MC4V23G.mjs";
|
|
7
7
|
import {
|
|
8
|
-
PRESENTER_PLUGIN,
|
|
9
8
|
meta
|
|
10
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-VQVZVXPJ.mjs";
|
|
11
10
|
|
|
12
11
|
// src/PresenterPlugin.tsx
|
|
13
|
-
import {
|
|
12
|
+
import { Common, Plugin } from "@dxos/app-framework";
|
|
14
13
|
|
|
15
|
-
// src/capabilities/index.ts
|
|
16
|
-
import {
|
|
17
|
-
var AppGraphBuilder = lazy(() => import("./app-graph-builder-
|
|
18
|
-
|
|
19
|
-
|
|
14
|
+
// src/capabilities/app-graph-builder/index.ts
|
|
15
|
+
import { Capability } from "@dxos/app-framework";
|
|
16
|
+
var AppGraphBuilder = Capability.lazy("AppGraphBuilder", () => import("./app-graph-builder-2QAQR34J.mjs"));
|
|
17
|
+
|
|
18
|
+
// src/capabilities/react-surface/index.ts
|
|
19
|
+
import { Capability as Capability2 } from "@dxos/app-framework";
|
|
20
|
+
var ReactSurface = Capability2.lazy("ReactSurface", () => import("./react-surface-2VP2M4Z7.mjs"));
|
|
21
|
+
|
|
22
|
+
// src/capabilities/settings/index.ts
|
|
23
|
+
import { Capability as Capability3 } from "@dxos/app-framework";
|
|
24
|
+
var PresenterSettings2 = Capability3.lazy("PresenterSettings", () => import("./settings-RDHXCCT4.mjs"));
|
|
20
25
|
|
|
21
26
|
// src/translations.ts
|
|
22
27
|
var translations = [
|
|
@@ -24,6 +29,7 @@ var translations = [
|
|
|
24
29
|
"en-US": {
|
|
25
30
|
[meta.id]: {
|
|
26
31
|
"plugin name": "Presenter",
|
|
32
|
+
"settings title": "Presenter settings",
|
|
27
33
|
"toggle presentation label": "Present",
|
|
28
34
|
"present collections label": "Present collections (experimental)"
|
|
29
35
|
}
|
|
@@ -32,33 +38,19 @@ var translations = [
|
|
|
32
38
|
];
|
|
33
39
|
|
|
34
40
|
// src/PresenterPlugin.tsx
|
|
35
|
-
var PresenterPlugin = ()
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
activate: () => contributes(Capabilities.Translations, translations)
|
|
45
|
-
}),
|
|
46
|
-
defineModule({
|
|
47
|
-
id: `${meta.id}/module/react-surface`,
|
|
48
|
-
activatesOn: Events.SetupReactSurface,
|
|
49
|
-
activate: ReactSurface
|
|
50
|
-
}),
|
|
51
|
-
defineModule({
|
|
52
|
-
id: `${meta.id}/module/app-graph-builder`,
|
|
53
|
-
activatesOn: Events.SetupAppGraph,
|
|
54
|
-
activate: AppGraphBuilder
|
|
55
|
-
})
|
|
56
|
-
]);
|
|
41
|
+
var PresenterPlugin = Plugin.define(meta).pipe(Common.Plugin.addSettingsModule({
|
|
42
|
+
activate: PresenterSettings2
|
|
43
|
+
}), Common.Plugin.addTranslationsModule({
|
|
44
|
+
translations
|
|
45
|
+
}), Common.Plugin.addSurfaceModule({
|
|
46
|
+
activate: ReactSurface
|
|
47
|
+
}), Common.Plugin.addAppGraphModule({
|
|
48
|
+
activate: AppGraphBuilder
|
|
49
|
+
}), Plugin.make);
|
|
57
50
|
export {
|
|
58
51
|
CollectionPresenterContainer,
|
|
59
52
|
DocumentPresenterContainer,
|
|
60
53
|
MarkdownSlide,
|
|
61
|
-
PRESENTER_PLUGIN,
|
|
62
54
|
PresenterPlugin,
|
|
63
55
|
PresenterSettings,
|
|
64
56
|
meta
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../../../src/PresenterPlugin.tsx", "../../../src/capabilities/index.ts", "../../../src/translations.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport {
|
|
5
|
-
"mappings": "
|
|
6
|
-
"names": ["
|
|
3
|
+
"sources": ["../../../src/PresenterPlugin.tsx", "../../../src/capabilities/app-graph-builder/index.ts", "../../../src/capabilities/react-surface/index.ts", "../../../src/capabilities/settings/index.ts", "../../../src/translations.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Common, Plugin } from '@dxos/app-framework';\n\nimport { AppGraphBuilder, PresenterSettings, ReactSurface } from './capabilities';\nimport { meta } from './meta';\nimport { translations } from './translations';\n\n// TODO(burdon): Only scale markdown content.\n// TODO(burdon): Map stack content; Slide content type (e.g., markdown, sketch, IPFS image, table, etc.)\n\nexport const PresenterPlugin = Plugin.define(meta).pipe(\n Common.Plugin.addSettingsModule({ activate: PresenterSettings }),\n Common.Plugin.addTranslationsModule({ translations }),\n Common.Plugin.addSurfaceModule({ activate: ReactSurface }),\n Common.Plugin.addAppGraphModule({ activate: AppGraphBuilder }),\n Plugin.make,\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capability } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = Capability.lazy('AppGraphBuilder', () => import('./app-graph-builder'));\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capability } from '@dxos/app-framework';\n\nexport const ReactSurface = Capability.lazy('ReactSurface', () => import('./react-surface'));\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capability } from '@dxos/app-framework';\n\nexport const PresenterSettings = Capability.lazy('PresenterSettings', () => import('./settings'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nimport { meta } from './meta';\n\nexport const translations = [\n {\n 'en-US': {\n [meta.id]: {\n 'plugin name': 'Presenter',\n 'settings title': 'Presenter settings',\n 'toggle presentation label': 'Present',\n 'present collections label': 'Present collections (experimental)',\n },\n },\n },\n] as const satisfies Resource[];\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;AAIA,SAASA,QAAQC,cAAc;;;ACA/B,SAASC,kBAAkB;AAEpB,IAAMC,kBAAkBC,WAAWC,KAAK,mBAAmB,MAAM,OAAO,kCAAA,CAAA;;;ACF/E,SAASC,cAAAA,mBAAkB;AAEpB,IAAMC,eAAeC,YAAWC,KAAK,gBAAgB,MAAM,OAAO,8BAAA,CAAA;;;ACFzE,SAASC,cAAAA,mBAAkB;AAEpB,IAAMC,qBAAoBC,YAAWC,KAAK,qBAAqB,MAAM,OAAO,yBAAA,CAAA;;;ACE5E,IAAMC,eAAe;EAC1B;IACE,SAAS;MACP,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;QACf,kBAAkB;QAClB,6BAA6B;QAC7B,6BAA6B;MAC/B;IACF;EACF;;;;AJLK,IAAMC,kBAAkBC,OAAOC,OAAOC,IAAAA,EAAMC,KACjDC,OAAOJ,OAAOK,kBAAkB;EAAEC,UAAUC;AAAkB,CAAA,GAC9DH,OAAOJ,OAAOQ,sBAAsB;EAAEC;AAAa,CAAA,GACnDL,OAAOJ,OAAOU,iBAAiB;EAAEJ,UAAUK;AAAa,CAAA,GACxDP,OAAOJ,OAAOY,kBAAkB;EAAEN,UAAUO;AAAgB,CAAA,GAC5Db,OAAOc,IAAI;",
|
|
6
|
+
"names": ["Common", "Plugin", "Capability", "AppGraphBuilder", "Capability", "lazy", "Capability", "ReactSurface", "Capability", "lazy", "Capability", "PresenterSettings", "Capability", "lazy", "translations", "meta", "id", "PresenterPlugin", "Plugin", "define", "meta", "pipe", "Common", "addSettingsModule", "activate", "PresenterSettings", "addTranslationsModule", "translations", "addSurfaceModule", "ReactSurface", "addAppGraphModule", "AppGraphBuilder", "make"]
|
|
7
7
|
}
|