@dxos/plugin-presenter 0.7.4 → 0.7.5-main.9d26e3a
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/{MarkdownSlide-4FZ3XIH5.mjs → MarkdownSlide-5NYXG5SC.mjs} +2 -2
- package/dist/lib/browser/MarkdownSlide-5NYXG5SC.mjs.map +7 -0
- package/dist/lib/browser/{PresenterMain-FUIXINMC.mjs → PresenterMain-TQE4OZK2.mjs} +12 -30
- package/dist/lib/browser/PresenterMain-TQE4OZK2.mjs.map +7 -0
- package/dist/lib/browser/{RevealMain-YOFOFZJE.mjs → RevealMain-JGKAQMQ4.mjs} +11 -27
- package/dist/lib/browser/RevealMain-JGKAQMQ4.mjs.map +7 -0
- package/dist/lib/browser/chunk-Z6QQB6KB.mjs +35 -0
- package/dist/lib/browser/chunk-Z6QQB6KB.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +76 -92
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/types/src/PresenterPlugin.d.ts.map +1 -1
- package/dist/types/src/components/PresenterMain.d.ts.map +1 -1
- package/dist/types/src/components/RevealMain.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +17 -1
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -0
- package/package.json +20 -20
- package/src/PresenterPlugin.tsx +54 -59
- package/src/components/MarkdownSlide.tsx +1 -1
- package/src/components/PresenterMain.tsx +5 -27
- package/src/components/RevealMain.tsx +5 -17
- package/src/types.ts +18 -2
- package/dist/lib/browser/MarkdownSlide-4FZ3XIH5.mjs.map +0 -7
- package/dist/lib/browser/PresenterMain-FUIXINMC.mjs.map +0 -7
- package/dist/lib/browser/RevealMain-YOFOFZJE.mjs.map +0 -7
- package/dist/lib/browser/chunk-RXCQGKK4.mjs +0 -20
- package/dist/lib/browser/chunk-RXCQGKK4.mjs.map +0 -7
|
@@ -298,7 +298,7 @@ var components = {
|
|
|
298
298
|
|
|
299
299
|
// packages/plugins/plugin-presenter/src/components/MarkdownSlide.tsx
|
|
300
300
|
var MarkdownSlide = ({ document }) => {
|
|
301
|
-
const content = document.content?.content;
|
|
301
|
+
const content = document.content.target?.content;
|
|
302
302
|
if (!content) {
|
|
303
303
|
return null;
|
|
304
304
|
}
|
|
@@ -310,4 +310,4 @@ var MarkdownSlide_default = MarkdownSlide;
|
|
|
310
310
|
export {
|
|
311
311
|
MarkdownSlide_default as default
|
|
312
312
|
};
|
|
313
|
-
//# sourceMappingURL=MarkdownSlide-
|
|
313
|
+
//# sourceMappingURL=MarkdownSlide-5NYXG5SC.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/MarkdownSlide.tsx", "../../../src/components/Markdown/Container.tsx", "../../../src/components/Markdown/Slide.tsx", "../../../src/components/Markdown/theme.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type FC } from 'react';\n\nimport { type DocumentType } from '@dxos/plugin-markdown/types';\n\nimport { Container, Slide } from './Markdown';\n\nconst MarkdownSlide: FC<{ document: DocumentType }> = ({ document }) => {\n const content = document.content.target?.content;\n if (!content) {\n return null;\n }\n\n return (\n <Container>\n <Slide content={content} />\n </Container>\n );\n};\n\nexport default MarkdownSlide;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type PropsWithChildren, useState } from 'react';\nimport { useResizeDetector } from 'react-resize-detector';\n\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { mx } from '@dxos/react-ui-theme';\n\nexport type ContainerProps = ThemedClassName<PropsWithChildren<{}>>;\n\n/**\n * Scaled markdown container.\n */\nexport const Container = ({ children, classNames }: ContainerProps) => {\n const [props, setProps] = useState({});\n const {\n ref: containerRef,\n width,\n height,\n } = useResizeDetector({\n refreshMode: 'debounce',\n refreshRate: 200,\n refreshOptions: {\n leading: true,\n },\n onResize: ({ width, height }) => {\n if (width && height) {\n setProps(createLayoutProps({ width, height }));\n }\n },\n });\n\n // TODO(burdon): Reconcile highlight colors with markdown editor.\n // https://www.npmjs.com/package/react-markdown\n return (\n <div ref={containerRef} className={mx('flex grow relative overflow-hidden bg-attention', classNames)}>\n <div className={mx('flex w-full h-full overflow-hidden absolute')} style={props}>\n {width && height && children}\n </div>\n </div>\n );\n};\n\n/**\n * Compute CSS properties to transform DIV to be full screen.\n *\n * Display resolutions:\n * window.screen.{availWidth, availHeight}\n * 5K Studio 16.2-inch Macbook Pro\n * Max 5120 x 2880 3456 x 2234\n * Default 2560 x 1440 1728 x 1117 (Actual height 1080 - 37 pixel notch)\n * Aspect 1.77 (16/9) 1.54\n */\nconst createLayoutProps = ({ width, height }: { width: number; height: number }) => {\n // Config.\n const aspectRatio = 16 / 9;\n const nominalWidth = 2560;\n const nominalHeight = nominalWidth / aspectRatio;\n\n // NOTE: Hack to detect full height on Macbook Pro due to notch.\n // const macIntelNotch = 1117 - 1080;\n // const fullscreen =\n // height === screen.availHeight ||\n // (window.navigator.platform === 'MacIntel' && height === screen.availHeight - macIntelNotch);\n\n // If not fullscreen then make scale slightly smaller so there's a natural border.\n // const scaleFactor = fullscreen ? 1 : 0.95;\n\n // Compute scaling factor required.\n const scale = Math.min(width / nominalWidth, height / nominalHeight);\n\n return {\n left: (width - nominalWidth) / 2,\n top: (height - nominalHeight) / 2,\n width: nominalWidth,\n height: nominalHeight,\n transform: `scale(${scale})`,\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { h } from 'hastscript';\nimport React from 'react';\nimport ReactMarkdown from 'react-markdown';\nimport addClasses from 'rehype-add-classes';\nimport highlight from 'rehype-highlight';\nimport remarkFrontmatter from 'remark-frontmatter';\nimport remarkParseFrontmatter from 'remark-parse-frontmatter';\n\nimport 'highlight.js/styles/github.css';\n\nimport { theme } from './theme';\n\nexport type SlideProps = {\n content?: string;\n classes?: { [selector: string]: string };\n};\n\nexport const Slide = ({ content = '', classes = theme.nodes }: SlideProps) => {\n // TODO(thure): `rehype-highlight` ends up using `github.css` from `highlight.js`, but this does not appear to be\n // configurable. Find a way to remove the literal stylesheet here.\n return (\n <>\n <style>{`\n.dark pre code.hljs {\n display: block;\n overflow-x: auto;\n padding: 1em\n}\n.dark code.hljs {\n padding: 3px 5px\n}\n/*!\n Theme: GitHub Dark\n Description: Dark theme as seen on github.com\n Author: github.com\n Maintainer: @Hirse\n Updated: 2021-05-15\n\n Outdated base version: https://github.com/primer/github-syntax-dark\n Current colors taken from GitHub's CSS\n*/\n.dark .hljs {\n color: #c9d1d9;\n background: #0d1117\n}\n.dark .hljs-doctag,\n.dark .hljs-keyword,\n.dark .hljs-meta .hljs-keyword,\n.dark .hljs-template-tag,\n.dark .hljs-template-variable,\n.dark .hljs-type,\n.dark .hljs-variable.language_ {\n /* prettylights-syntax-keyword */\n color: #ff7b72\n}\n.dark .hljs-title,\n.dark .hljs-title.class_,\n.dark .hljs-title.class_.inherited__,\n.dark .hljs-title.function_ {\n /* prettylights-syntax-entity */\n color: #d2a8ff\n}\n.dark .hljs-attr,\n.dark .hljs-attribute,\n.dark .hljs-literal,\n.dark .hljs-meta,\n.dark .hljs-number,\n.dark .hljs-operator,\n.dark .hljs-variable,\n.dark .hljs-selector-attr,\n.dark .hljs-selector-class,\n.dark .hljs-selector-id {\n /* prettylights-syntax-constant */\n color: #79c0ff\n}\n.dark .hljs-regexp,\n.dark .hljs-string,\n.dark .hljs-meta .hljs-string {\n /* prettylights-syntax-string */\n color: #a5d6ff\n}\n.dark .hljs-built_in,\n.dark .hljs-symbol {\n /* prettylights-syntax-variable */\n color: #ffa657\n}\n.dark .hljs-comment,\n.dark .hljs-code,\n.dark .hljs-formula {\n /* prettylights-syntax-comment */\n color: #8b949e\n}\n.dark .hljs-name,\n.dark .hljs-quote,\n.dark .hljs-selector-tag,\n.dark .hljs-selector-pseudo {\n /* prettylights-syntax-entity-tag */\n color: #7ee787\n}\n.dark .hljs-subst {\n /* prettylights-syntax-storage-modifier-import */\n color: #c9d1d9\n}\n.dark .hljs-section {\n /* prettylights-syntax-markup-heading */\n color: #1f6feb;\n font-weight: bold\n}\n.dark .hljs-bullet {\n /* prettylights-syntax-markup-list */\n color: #f2cc60\n}\n.dark .hljs-emphasis {\n /* prettylights-syntax-markup-italic */\n color: #c9d1d9;\n font-style: italic\n}\n.dark .hljs-strong {\n /* prettylights-syntax-markup-bold */\n color: #c9d1d9;\n font-weight: bold\n}\n.dark .hljs-addition {\n /* prettylights-syntax-markup-inserted */\n color: #aff5b4;\n background-color: #033a16\n}\n.dark .hljs-deletion {\n /* prettylights-syntax-markup-deleted */\n color: #ffdcd7;\n background-color: #67060c\n}\n.dark .hljs-char.escape_,\n.dark .hljs-link,\n.dark .hljs-params,\n.dark .hljs-property,\n.dark .hljs-punctuation,\n.dark .hljs-tag {\n /* purposely ignored */\n \n}\n `}</style>\n <ReactMarkdown\n components={components}\n // Markdown to HTML.\n remarkPlugins={[[remarkFrontmatter, 'yaml'], remarkParseFrontmatter as any]}\n // HTML processing.\n rehypePlugins={[highlight, [addClasses, classes], slideLayout]}\n >\n {content}\n </ReactMarkdown>\n </>\n );\n};\n\n/**\n * Rehype plugin to format DOM based on frontmatter.\n * https://github.com/unifiedjs/unified#plugin\n * TODO(burdon): See tools/presenter: remarkPluginLayout\n * E.g., layout image from front-matter.\n */\nconst slideLayout =\n (options = {}) =>\n (tree: any, file: any) => {\n const {\n data: { frontmatter = {} },\n } = file;\n\n let content = tree.children;\n const { layout, image } = frontmatter;\n if (image) {\n const img = h('div', {\n class: 'flex grow shrink-0 bg-cover bg-center bg-no-repeat',\n style: {\n backgroundImage: `url(${image})`,\n },\n });\n\n switch (layout) {\n case 'fullscreen': {\n content = img;\n break;\n }\n\n case 'columns': {\n content = h('div', { class: 'flex grow grid grid-cols-2' }, [\n h('div', { class: theme.padding }, [content]),\n img,\n ]);\n break;\n }\n\n case 'rows': {\n content = h('div', { class: 'flex grow flex-col' }, [\n h('div', { class: theme.padding }, [content]),\n h('div', { class: ['flex grow pt-0', theme.padding] }, [img]),\n ]);\n break;\n }\n }\n } else {\n content = h('div', { class: ['flex grow flex-col', theme.padding] }, [content]);\n }\n\n const root = h('div', { class: ['flex flex-col grow', theme.root] }, [content]);\n tree.children = [root];\n };\n\nconst ImageWrapper = ({ node, ...props }: { node: any }) => {\n const { alt = '', src } = props as { alt: string; src: string };\n return <img alt={alt} src={src} />;\n};\n\nconst components = { img: ImageWrapper };\n", "//\n// Copyright 2023 DXOS.org\n//\n\n// TODO(burdon): Create theme type and picker.\n\nexport const theme = {\n root: 'bg-attention leading-relaxed font-mono',\n\n padding: 'px-40 py-16 gap-8',\n\n nodes: {\n h1: 'text-[80px] text-accentText',\n h2: 'text-[60px] text-accentText',\n h3: 'text-[48px] text-accentText',\n\n p: 'text-[48px]',\n\n ul: 'my-[16px] ml-12 leading-relaxed list-disc',\n ol: 'my-[16px] ml-24 leading-relaxed list-decimal',\n li: 'pl-6 text-[48px]',\n\n pre: 'w-full mx-0 my-[32px] p-0 __border-l-[16px] bg-input p-4 __whitespace-pre-line',\n code: 'p-0 text-[40px]',\n },\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "React", "useState", "useResizeDetector", "mx", "Container", "children", "classNames", "props", "setProps", "useState", "ref", "containerRef", "width", "height", "useResizeDetector", "refreshMode", "refreshRate", "refreshOptions", "leading", "onResize", "createLayoutProps", "div", "className", "mx", "style", "aspectRatio", "nominalWidth", "nominalHeight", "scale", "Math", "min", "left", "top", "transform", "h", "React", "ReactMarkdown", "addClasses", "highlight", "remarkFrontmatter", "remarkParseFrontmatter", "theme", "root", "padding", "nodes", "h1", "h2", "h3", "p", "ul", "ol", "li", "pre", "code", "Slide", "content", "classes", "theme", "nodes", "React", "style", "ReactMarkdown", "components", "remarkPlugins", "remarkFrontmatter", "remarkParseFrontmatter", "rehypePlugins", "highlight", "addClasses", "slideLayout", "options", "tree", "file", "data", "frontmatter", "children", "layout", "image", "img", "h", "class", "backgroundImage", "padding", "root", "ImageWrapper", "node", "props", "alt", "src", "MarkdownSlide", "document", "content", "target", "React", "Container", "Slide"]
|
|
7
|
+
}
|
|
@@ -1,15 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
} from "./chunk-
|
|
5
|
-
import
|
|
6
|
-
PRESENTER_PLUGIN
|
|
7
|
-
} from "./chunk-67PDV7KN.mjs";
|
|
2
|
+
PresenterAction,
|
|
3
|
+
PresenterContext
|
|
4
|
+
} from "./chunk-Z6QQB6KB.mjs";
|
|
5
|
+
import "./chunk-67PDV7KN.mjs";
|
|
8
6
|
|
|
9
7
|
// packages/plugins/plugin-presenter/src/components/PresenterMain.tsx
|
|
10
8
|
import React3, { useContext, useState } from "react";
|
|
11
|
-
import { Surface, useIntentDispatcher, useResolvePlugin, parseLayoutPlugin,
|
|
12
|
-
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
9
|
+
import { Surface, useIntentDispatcher, useResolvePlugin, parseLayoutPlugin, createIntent } from "@dxos/app-framework";
|
|
13
10
|
import { Main } from "@dxos/react-ui";
|
|
14
11
|
import { baseSurface, topbarBlockPaddingStart, fixedInsetFlexLayout, bottombarBlockPaddingEnd } from "@dxos/react-ui-theme";
|
|
15
12
|
|
|
@@ -151,27 +148,12 @@ var PresenterMain = ({ collection }) => {
|
|
|
151
148
|
const layoutPlugin = useResolvePlugin(parseLayoutPlugin);
|
|
152
149
|
const fullscreen = layoutPlugin?.provides.layout.layoutMode === "fullscreen";
|
|
153
150
|
const { running } = useContext(PresenterContext);
|
|
154
|
-
const dispatch = useIntentDispatcher();
|
|
151
|
+
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
155
152
|
const handleSetRunning = (running2) => {
|
|
156
|
-
void dispatch(
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
data: {
|
|
161
|
-
state: running2
|
|
162
|
-
}
|
|
163
|
-
},
|
|
164
|
-
...!running2 ? [
|
|
165
|
-
{
|
|
166
|
-
action: NavigationAction.CLOSE,
|
|
167
|
-
data: {
|
|
168
|
-
activeParts: {
|
|
169
|
-
fullScreen: fullyQualifiedId(collection)
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
] : []
|
|
174
|
-
]);
|
|
153
|
+
void dispatch(createIntent(PresenterAction.TogglePresentation, {
|
|
154
|
+
object: collection,
|
|
155
|
+
state: running2
|
|
156
|
+
}));
|
|
175
157
|
};
|
|
176
158
|
return /* @__PURE__ */ React3.createElement(Main.Content, {
|
|
177
159
|
classNames: [
|
|
@@ -199,7 +181,7 @@ var PresenterMain = ({ collection }) => {
|
|
|
199
181
|
}, /* @__PURE__ */ React3.createElement(Surface, {
|
|
200
182
|
role: "slide",
|
|
201
183
|
data: {
|
|
202
|
-
|
|
184
|
+
subject: collection.objects[slide]
|
|
203
185
|
},
|
|
204
186
|
placeholder: /* @__PURE__ */ React3.createElement(React3.Fragment, null)
|
|
205
187
|
})));
|
|
@@ -208,4 +190,4 @@ var PresenterMain_default = PresenterMain;
|
|
|
208
190
|
export {
|
|
209
191
|
PresenterMain_default as default
|
|
210
192
|
};
|
|
211
|
-
//# sourceMappingURL=PresenterMain-
|
|
193
|
+
//# sourceMappingURL=PresenterMain-TQE4OZK2.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/PresenterMain.tsx", "../../../src/components/Presenter/Layout.tsx", "../../../src/components/Presenter/Pager.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type FC, useContext, useState } from 'react';\n\nimport { Surface, useIntentDispatcher, useResolvePlugin, parseLayoutPlugin, createIntent } from '@dxos/app-framework';\nimport { type CollectionType } from '@dxos/plugin-space/types';\nimport { Main } from '@dxos/react-ui';\nimport {\n baseSurface,\n topbarBlockPaddingStart,\n fixedInsetFlexLayout,\n bottombarBlockPaddingEnd,\n} from '@dxos/react-ui-theme';\n\nimport { Layout, PageNumber, Pager, StartButton } from './Presenter';\nimport { PresenterContext, PresenterAction } from '../types';\n\nconst PresenterMain: FC<{ collection: CollectionType }> = ({ collection }) => {\n const [slide, setSlide] = useState(0);\n\n // TODO(burdon): Should not depend on split screen.\n const layoutPlugin = useResolvePlugin(parseLayoutPlugin);\n const fullscreen = layoutPlugin?.provides.layout.layoutMode === 'fullscreen';\n const { running } = useContext(PresenterContext);\n\n // TODO(burdon): Currently conflates fullscreen and running.\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const handleSetRunning = (running: boolean) => {\n void dispatch(createIntent(PresenterAction.TogglePresentation, { object: collection, state: running }));\n };\n\n return (\n <Main.Content\n classNames={[\n baseSurface,\n fixedInsetFlexLayout,\n !fullscreen && topbarBlockPaddingStart,\n !fullscreen && bottombarBlockPaddingEnd,\n ]}\n >\n <Layout\n topRight={<StartButton running={running} onClick={(running) => handleSetRunning(running)} />}\n bottomRight={<PageNumber index={slide} count={collection.objects.length} />}\n bottomLeft={\n <Pager\n index={slide}\n count={collection.objects.length}\n keys={running}\n onChange={setSlide}\n onExit={() => handleSetRunning(false)}\n />\n }\n >\n {/* TODO(wittjosiah): Better slide placeholder. */}\n <Surface role='slide' data={{ subject: collection.objects[slide] }} placeholder={<></>} />\n </Layout>\n </Main.Content>\n );\n};\n\nexport default PresenterMain;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type PropsWithChildren, type ReactNode } from 'react';\n\nimport { type ThemedClassName } from '@dxos/react-ui';\nimport { mx } from '@dxos/react-ui-theme';\n\nexport type LayoutProps = ThemedClassName<\n PropsWithChildren<{\n className?: string;\n topLeft?: ReactNode;\n topRight?: ReactNode;\n bottomLeft?: ReactNode;\n bottomRight?: ReactNode;\n }>\n>;\n\nexport const Layout = ({ children, classNames, topLeft, topRight, bottomLeft, bottomRight }: LayoutProps) => {\n return (\n <div className={mx('flex grow relative overflow-hidden bg-attention', classNames)}>\n <div className={mx('flex flex-col grow overflow-hidden')}>{children}</div>\n\n <div className='z-[200]'>\n <div className='absolute top-4 left-4'>{topLeft}</div>\n <div className='absolute top-4 right-4'>{topRight}</div>\n <div className='absolute bottom-4 left-4'>{bottomLeft}</div>\n <div className='absolute bottom-4 right-4'>{bottomRight}</div>\n </div>\n </div>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { Play, X, CaretDoubleLeft, CaretDoubleRight, CaretLeft, CaretRight } from '@phosphor-icons/react';\nimport React, { type FC, useEffect } from 'react';\n\nimport { Button, useControlledValue } from '@dxos/react-ui';\nimport { getSize, mx } from '@dxos/react-ui-theme';\n\nexport type PagerProps = {\n index?: number;\n count?: number;\n keys?: boolean; // TODO(burdon): Rename.\n onChange?: (index: number) => void;\n onExit?: () => void;\n};\n\nexport const Pager = ({ index: controlledIndex = 0, count = 0, keys, onChange, onExit }: PagerProps) => {\n const [index, setIndex] = useControlledValue(controlledIndex);\n useEffect(() => {\n onChange?.(index);\n }, [index]);\n\n const handleChangeIndex = (dir: number) => {\n setIndex((index) => {\n const next = index + dir;\n return next >= 0 && next < count ? next : index;\n });\n };\n\n // TODO(burdon): Standardize via system key binding.\n useEffect(() => {\n if (!keys) {\n return;\n }\n\n const keydownHandler = (event: KeyboardEvent) => {\n switch (event.key) {\n case 'Escape': {\n onExit?.();\n break;\n }\n case 'ArrowLeft': {\n if (event.shiftKey) {\n onChange?.(0);\n } else {\n handleChangeIndex(-1);\n }\n break;\n }\n case 'ArrowRight': {\n if (event.shiftKey) {\n onChange?.(count - 1);\n } else {\n handleChangeIndex(1);\n }\n break;\n }\n case 'ArrowUp': {\n onChange?.(0);\n break;\n }\n case 'ArrowDown': {\n onChange?.(count - 1);\n break;\n }\n }\n };\n\n window.addEventListener('keydown', keydownHandler);\n return () => window.removeEventListener('keydown', keydownHandler);\n }, [keys, count]);\n\n if (index === undefined || !count) {\n return null;\n }\n\n return (\n <div className='flex items-center text-neutral-500'>\n <Button variant='ghost' classNames='p-0' onClick={() => onChange?.(0)}>\n <CaretDoubleLeft className={mx(getSize(6))} />\n </Button>\n <Button variant='ghost' classNames='p-0' onClick={() => handleChangeIndex(-1)}>\n <CaretLeft className={mx(getSize(6))} />\n </Button>\n <Button variant='ghost' classNames='p-0' onClick={() => handleChangeIndex(1)}>\n <CaretRight className={mx(getSize(6))} />\n </Button>\n <Button variant='ghost' classNames='p-0' onClick={() => onChange?.(count - 1)}>\n <CaretDoubleRight className={mx(getSize(6))} />\n </Button>\n </div>\n );\n};\n\nexport type PageNumberProps = {\n index?: number;\n count?: number;\n};\n\nexport const PageNumber = ({ index = 0, count = 1 }: PageNumberProps) => {\n if (index === undefined || !count) {\n return null;\n }\n\n return (\n <div className='flex items-center text-neutral-500 text-2xl'>\n <div>\n {index + 1} / {count}\n </div>\n </div>\n );\n};\n\nexport const StartButton: FC<{ running?: boolean; onClick?: (start: boolean) => void }> = ({ running, onClick }) => {\n return (\n <Button variant='ghost' classNames='p-0' onClick={() => onClick?.(!running)}>\n {(running && <X className={mx(getSize(6))} />) || <Play className={mx(getSize(6))} />}\n </Button>\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "useContext", "useState", "Surface", "useIntentDispatcher", "useResolvePlugin", "parseLayoutPlugin", "createIntent", "Main", "baseSurface", "topbarBlockPaddingStart", "fixedInsetFlexLayout", "bottombarBlockPaddingEnd", "React", "mx", "Layout", "children", "classNames", "topLeft", "topRight", "bottomLeft", "bottomRight", "div", "className", "mx", "Play", "X", "CaretDoubleLeft", "CaretDoubleRight", "CaretLeft", "CaretRight", "React", "useEffect", "Button", "useControlledValue", "getSize", "mx", "Pager", "index", "controlledIndex", "count", "keys", "onChange", "onExit", "setIndex", "useControlledValue", "useEffect", "handleChangeIndex", "dir", "next", "keydownHandler", "event", "key", "shiftKey", "window", "addEventListener", "removeEventListener", "undefined", "React", "div", "className", "Button", "variant", "classNames", "onClick", "CaretDoubleLeft", "mx", "getSize", "CaretLeft", "CaretRight", "CaretDoubleRight", "PageNumber", "StartButton", "running", "X", "Play", "PresenterMain", "collection", "slide", "setSlide", "useState", "layoutPlugin", "useResolvePlugin", "parseLayoutPlugin", "fullscreen", "provides", "layout", "layoutMode", "running", "useContext", "PresenterContext", "dispatchPromise", "dispatch", "useIntentDispatcher", "handleSetRunning", "createIntent", "PresenterAction", "TogglePresentation", "object", "state", "React", "Main", "Content", "classNames", "baseSurface", "fixedInsetFlexLayout", "topbarBlockPaddingStart", "bottombarBlockPaddingEnd", "Layout", "topRight", "StartButton", "onClick", "bottomRight", "PageNumber", "index", "count", "objects", "length", "bottomLeft", "Pager", "keys", "onChange", "onExit", "Surface", "role", "data", "subject", "placeholder"]
|
|
7
|
+
}
|
|
@@ -1,14 +1,11 @@
|
|
|
1
1
|
import {
|
|
2
|
-
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import
|
|
5
|
-
PRESENTER_PLUGIN
|
|
6
|
-
} from "./chunk-67PDV7KN.mjs";
|
|
2
|
+
PresenterAction
|
|
3
|
+
} from "./chunk-Z6QQB6KB.mjs";
|
|
4
|
+
import "./chunk-67PDV7KN.mjs";
|
|
7
5
|
|
|
8
6
|
// packages/plugins/plugin-presenter/src/components/RevealMain.tsx
|
|
9
7
|
import React2 from "react";
|
|
10
|
-
import {
|
|
11
|
-
import { fullyQualifiedId } from "@dxos/react-client/echo";
|
|
8
|
+
import { useIntentDispatcher, useResolvePlugin, parseLayoutPlugin, createIntent } from "@dxos/app-framework";
|
|
12
9
|
import { Main } from "@dxos/react-ui";
|
|
13
10
|
import { topbarBlockPaddingStart, fixedInsetFlexLayout, bottombarBlockPaddingEnd } from "@dxos/react-ui-theme";
|
|
14
11
|
|
|
@@ -133,7 +130,7 @@ var RevealPlayer = ({ content, slide, onExit }) => {
|
|
|
133
130
|
// packages/plugins/plugin-presenter/src/components/RevealMain.tsx
|
|
134
131
|
var PresenterMain = ({ document }) => {
|
|
135
132
|
const fullscreen = useResolvePlugin(parseLayoutPlugin)?.provides.layout.layoutMode === "fullscreen";
|
|
136
|
-
const dispatch = useIntentDispatcher();
|
|
133
|
+
const { dispatchPromise: dispatch } = useIntentDispatcher();
|
|
137
134
|
return /* @__PURE__ */ React2.createElement(Main.Content, {
|
|
138
135
|
classNames: [
|
|
139
136
|
fixedInsetFlexLayout,
|
|
@@ -141,25 +138,12 @@ var PresenterMain = ({ document }) => {
|
|
|
141
138
|
!fullscreen && bottombarBlockPaddingEnd
|
|
142
139
|
]
|
|
143
140
|
}, /* @__PURE__ */ React2.createElement(RevealPlayer, {
|
|
144
|
-
content: document.content?.content ?? "",
|
|
141
|
+
content: document.content.target?.content ?? "",
|
|
145
142
|
onExit: () => {
|
|
146
|
-
void dispatch(
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
data: {
|
|
151
|
-
state: false
|
|
152
|
-
}
|
|
153
|
-
},
|
|
154
|
-
{
|
|
155
|
-
action: NavigationAction.CLOSE,
|
|
156
|
-
data: {
|
|
157
|
-
activeParts: {
|
|
158
|
-
fullScreen: fullyQualifiedId(document)
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
]);
|
|
143
|
+
void dispatch(createIntent(PresenterAction.TogglePresentation, {
|
|
144
|
+
object: document,
|
|
145
|
+
state: false
|
|
146
|
+
}));
|
|
163
147
|
}
|
|
164
148
|
}));
|
|
165
149
|
};
|
|
@@ -167,4 +151,4 @@ var RevealMain_default = PresenterMain;
|
|
|
167
151
|
export {
|
|
168
152
|
RevealMain_default as default
|
|
169
153
|
};
|
|
170
|
-
//# sourceMappingURL=RevealMain-
|
|
154
|
+
//# sourceMappingURL=RevealMain-JGKAQMQ4.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/RevealMain.tsx", "../../../src/components/Reveal/Reveal.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type FC } from 'react';\n\nimport { useIntentDispatcher, useResolvePlugin, parseLayoutPlugin, createIntent } from '@dxos/app-framework';\nimport { type DocumentType } from '@dxos/plugin-markdown/types';\nimport { Main } from '@dxos/react-ui';\nimport { topbarBlockPaddingStart, fixedInsetFlexLayout, bottombarBlockPaddingEnd } from '@dxos/react-ui-theme';\n\nimport { RevealPlayer } from './Reveal';\nimport { PresenterAction } from '../types';\n\nconst PresenterMain: FC<{ document: DocumentType }> = ({ document }) => {\n const fullscreen = useResolvePlugin(parseLayoutPlugin)?.provides.layout.layoutMode === 'fullscreen';\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n\n return (\n <Main.Content\n classNames={[\n fixedInsetFlexLayout,\n !fullscreen && topbarBlockPaddingStart,\n !fullscreen && bottombarBlockPaddingEnd,\n ]}\n >\n <RevealPlayer\n content={document.content.target?.content ?? ''}\n onExit={() => {\n void dispatch(createIntent(PresenterAction.TogglePresentation, { object: document, state: false }));\n }}\n />\n </Main.Content>\n );\n};\n\nexport default PresenterMain;\n", "//\n// Copyright 2024 DXOS.org\n//\n\n// eslint-disable-next-line no-restricted-imports\nimport 'reveal.js/dist/reveal.css';\n// eslint-disable-next-line no-restricted-imports\nimport 'reveal.js/dist/theme/black.css';\n\nimport React, { useEffect, useRef } from 'react';\nimport Reveal from 'reveal.js';\nimport Markdown from 'reveal.js/plugin/markdown/plugin.js';\n// import Notes from 'reveal.js/plugin/notes/notes.js';\n\nconst styles = `\n<style type=\"text/css\">\n .reveal h1 {\n font-weight: 100;\n padding-left: 36px;\n opacity: 0.5;\n }\n .reveal h2 {\n font-weight: 100;\n padding-top: 60px;\n padding-left: 40px;\n font-size: 48px;\n opacity: 0.3;\n }\n .reveal h1, h2, p {\n font-family: \"Raleway\", sans-serif;\n text-align: left;\n font-weight: 200;\n }\n .reveal ul {\n font-family: \"Raleway\", sans-serif;\n display: block;\n list-style: \"- \";\n }\n .reveal blockquote p {\n text-align: center;\n font-weight: 100;\n padding: 32px;\n }\n</style>\n`;\n\nexport type RevealProps = {\n content: string;\n slide?: number;\n onExit?: () => void;\n};\n\n// https://revealjs.com/react\nexport const RevealPlayer = ({ content, slide, onExit }: RevealProps) => {\n const deckDivRef = useRef<HTMLDivElement>(null);\n const deckRef = useRef<Reveal.Api | null>(null);\n useEffect(() => {\n if (deckRef.current) {\n return;\n }\n\n setTimeout(async () => {\n // https://revealjs.com/config\n // https://github.com/hakimel/reveal.js\n // TODO(burdon): Fragments and scroll view steps 2 at a time (safe mode?)\n deckRef.current = new Reveal(deckDivRef.current!, {\n // view: 'scroll',\n progress: false,\n transition: 'none',\n slideNumber: false,\n embedded: true,\n // https://revealjs.com/speaker-view\n showNotes: false,\n\n center: true,\n margin: 0.01,\n minScale: 0.2,\n maxScale: 1.4,\n\n // https://revealjs.com/markdown\n plugins: [\n Markdown,\n // TODO(burdon): Requires server to serve popout window.\n // Notes\n ],\n\n // See https://marked.js.org/using_advanced#options\n markdown: {\n gfm: true,\n },\n });\n\n await deckRef.current.initialize();\n if (slide !== undefined) {\n deckRef.current.slide(slide < 0 ? deckRef.current?.getTotalSlides() + slide : slide - 1);\n }\n // TODO(burdon): Translation.\n deckRef.current.addKeyBinding({ keyCode: 27, key: 'Escape', description: 'Exit full screen' }, () => {\n onExit?.();\n });\n });\n\n return () => {\n try {\n if (deckRef.current) {\n deckRef.current.destroy();\n deckRef.current = null;\n }\n } catch (err) {\n // Ignore.\n }\n };\n });\n\n return (\n <div className='absolute inset-0 h-full'>\n <div ref={deckDivRef} className='reveal'>\n {/* TODO(burdon): Must be in head. */}\n <style>\n <link rel='preconnect' href='https://fonts.googleapis.com' />\n <link rel='preconnect' href='https://fonts.gstatic.com' {...{ crossOrigin: '' }} />\n <link\n href='https://fonts.googleapis.com/css2?family=Raleway:ital,wght@0,100..900;1,100..900&display=swap'\n rel='stylesheet'\n />\n </style>\n <div className='slides'>\n <div className='!text-center' />\n <section {...{ 'data-markdown': [] }}>\n <textarea {...{ 'data-template': true }} defaultValue={[styles, content].join('\\n')}></textarea>\n </section>\n </div>\n </div>\n </div>\n );\n};\n"],
|
|
5
|
+
"mappings": ";;;;;;AAIA,OAAOA,YAAwB;AAE/B,SAASC,qBAAqBC,kBAAkBC,mBAAmBC,oBAAoB;AAEvF,SAASC,YAAY;AACrB,SAASC,yBAAyBC,sBAAsBC,gCAAgC;;;ACJxF,OAAO;AAEP,OAAO;AAEP,OAAOC,SAASC,WAAWC,cAAc;AACzC,OAAOC,YAAY;AACnB,OAAOC,cAAc;AAGrB,IAAMC,SAAS;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAuCR,IAAMC,eAAe,CAAC,EAAEC,SAASC,OAAOC,OAAM,MAAe;AAClE,QAAMC,aAAaC,OAAuB,IAAA;AAC1C,QAAMC,UAAUD,OAA0B,IAAA;AAC1CE,YAAU,MAAA;AACR,QAAID,QAAQE,SAAS;AACnB;IACF;AAEAC,eAAW,YAAA;AAITH,cAAQE,UAAU,IAAIE,OAAON,WAAWI,SAAU;;QAEhDG,UAAU;QACVC,YAAY;QACZC,aAAa;QACbC,UAAU;;QAEVC,WAAW;QAEXC,QAAQ;QACRC,QAAQ;QACRC,UAAU;QACVC,UAAU;;QAGVC,SAAS;UACPC;;;QAMFC,UAAU;UACRC,KAAK;QACP;MACF,CAAA;AAEA,YAAMjB,QAAQE,QAAQgB,WAAU;AAChC,UAAItB,UAAUuB,QAAW;AACvBnB,gBAAQE,QAAQN,MAAMA,QAAQ,IAAII,QAAQE,SAASkB,eAAAA,IAAmBxB,QAAQA,QAAQ,CAAA;MACxF;AAEAI,cAAQE,QAAQmB,cAAc;QAAEC,SAAS;QAAIC,KAAK;QAAUC,aAAa;MAAmB,GAAG,MAAA;AAC7F3B,iBAAAA;MACF,CAAA;IACF,CAAA;AAEA,WAAO,MAAA;AACL,UAAI;AACF,YAAIG,QAAQE,SAAS;AACnBF,kBAAQE,QAAQuB,QAAO;AACvBzB,kBAAQE,UAAU;QACpB;MACF,SAASwB,KAAK;MAEd;IACF;EACF,CAAA;AAEA,SACE,sBAAA,cAACC,OAAAA;IAAIC,WAAU;KACb,sBAAA,cAACD,OAAAA;IAAIE,KAAK/B;IAAY8B,WAAU;KAE9B,sBAAA,cAACE,SAAAA,MACC,sBAAA,cAACC,QAAAA;IAAKC,KAAI;IAAaC,MAAK;MAC5B,sBAAA,cAACF,QAAAA;IAAKC,KAAI;IAAaC,MAAK;IAAkCC,aAAa;MAC3E,sBAAA,cAACH,QAAAA;IACCE,MAAK;IACLD,KAAI;OAGR,sBAAA,cAACL,OAAAA;IAAIC,WAAU;KACb,sBAAA,cAACD,OAAAA;IAAIC,WAAU;MACf,sBAAA,cAACO,WAAY;IAAE,iBAAiB,CAAA;EAAG,GACjC,sBAAA,cAACC,YAAAA;IAAe,iBAAiB;IAAQC,cAAc;MAAC5C;MAAQE;MAAS2C,KAAK,IAAA;;AAM1F;;;ADzHA,IAAMC,gBAAgD,CAAC,EAAEC,SAAQ,MAAE;AACjE,QAAMC,aAAaC,iBAAiBC,iBAAAA,GAAoBC,SAASC,OAAOC,eAAe;AACvF,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AAEtC,SACE,gBAAAC,OAAA,cAACC,KAAKC,SAAO;IACXC,YAAY;MACVC;MACA,CAACb,cAAcc;MACf,CAACd,cAAce;;KAGjB,gBAAAN,OAAA,cAACO,cAAAA;IACCC,SAASlB,SAASkB,QAAQC,QAAQD,WAAW;IAC7CE,QAAQ,MAAA;AACN,WAAKZ,SAASa,aAAaC,gBAAgBC,oBAAoB;QAAEC,QAAQxB;QAAUyB,OAAO;MAAM,CAAA,CAAA;IAClG;;AAIR;AAEA,IAAA,qBAAe1B;",
|
|
6
|
+
"names": ["React", "useIntentDispatcher", "useResolvePlugin", "parseLayoutPlugin", "createIntent", "Main", "topbarBlockPaddingStart", "fixedInsetFlexLayout", "bottombarBlockPaddingEnd", "React", "useEffect", "useRef", "Reveal", "Markdown", "styles", "RevealPlayer", "content", "slide", "onExit", "deckDivRef", "useRef", "deckRef", "useEffect", "current", "setTimeout", "Reveal", "progress", "transition", "slideNumber", "embedded", "showNotes", "center", "margin", "minScale", "maxScale", "plugins", "Markdown", "markdown", "gfm", "initialize", "undefined", "getTotalSlides", "addKeyBinding", "keyCode", "key", "description", "destroy", "err", "div", "className", "ref", "style", "link", "rel", "href", "crossOrigin", "section", "textarea", "defaultValue", "join", "PresenterMain", "document", "fullscreen", "useResolvePlugin", "parseLayoutPlugin", "provides", "layout", "layoutMode", "dispatchPromise", "dispatch", "useIntentDispatcher", "React", "Main", "Content", "classNames", "fixedInsetFlexLayout", "topbarBlockPaddingStart", "bottombarBlockPaddingEnd", "RevealPlayer", "content", "target", "onExit", "createIntent", "PresenterAction", "TogglePresentation", "object", "state"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import {
|
|
2
|
+
PRESENTER_PLUGIN
|
|
3
|
+
} from "./chunk-67PDV7KN.mjs";
|
|
4
|
+
|
|
5
|
+
// packages/plugins/plugin-presenter/src/types.ts
|
|
6
|
+
import { createContext } from "react";
|
|
7
|
+
import { S } from "@dxos/echo-schema";
|
|
8
|
+
import { DocumentType } from "@dxos/plugin-markdown/types";
|
|
9
|
+
import { CollectionType } from "@dxos/plugin-space/types";
|
|
10
|
+
var PresenterAction;
|
|
11
|
+
(function(PresenterAction2) {
|
|
12
|
+
const PRESENTER_ACTION = `${PRESENTER_PLUGIN}/action`;
|
|
13
|
+
class TogglePresentation extends S.TaggedClass()(`${PRESENTER_ACTION}/toggle-presentation`, {
|
|
14
|
+
input: S.Struct({
|
|
15
|
+
object: S.Union(DocumentType, CollectionType),
|
|
16
|
+
state: S.optional(S.Boolean)
|
|
17
|
+
}),
|
|
18
|
+
output: S.Void
|
|
19
|
+
}) {
|
|
20
|
+
}
|
|
21
|
+
PresenterAction2.TogglePresentation = TogglePresentation;
|
|
22
|
+
})(PresenterAction || (PresenterAction = {}));
|
|
23
|
+
var PresenterContext = createContext({
|
|
24
|
+
running: false,
|
|
25
|
+
start: () => {
|
|
26
|
+
},
|
|
27
|
+
stop: () => {
|
|
28
|
+
}
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
export {
|
|
32
|
+
PresenterAction,
|
|
33
|
+
PresenterContext
|
|
34
|
+
};
|
|
35
|
+
//# sourceMappingURL=chunk-Z6QQB6KB.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 Context, createContext } from 'react';\n\nimport type {\n GraphBuilderProvides,\n IntentResolverProvides,\n SettingsProvides,\n SurfaceProvides,\n TranslationsProvides,\n} from '@dxos/app-framework';\nimport { S } from '@dxos/echo-schema';\nimport { DocumentType } from '@dxos/plugin-markdown/types';\nimport { CollectionType } from '@dxos/plugin-space/types';\n\nimport { PRESENTER_PLUGIN } from './meta';\n\nexport namespace PresenterAction {\n const PRESENTER_ACTION = `${PRESENTER_PLUGIN}/action`;\n\n export class TogglePresentation extends S.TaggedClass<TogglePresentation>()(\n `${PRESENTER_ACTION}/toggle-presentation`,\n {\n input: S.Struct({\n object: S.Union(DocumentType, CollectionType),\n state: S.optional(S.Boolean),\n }),\n output: S.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 type PresenterSettingsProps = {\n presentCollections?: boolean;\n};\n\nexport type PresenterPluginProvides = SurfaceProvides &\n IntentResolverProvides &\n GraphBuilderProvides &\n TranslationsProvides &\n SettingsProvides<PresenterSettingsProps>;\n"],
|
|
5
|
+
"mappings": ";;;;;AAIA,SAAuBA,qBAAqB;AAS5C,SAASC,SAAS;AAClB,SAASC,oBAAoB;AAC7B,SAASC,sBAAsB;;UAIdC,kBAAAA;AACf,QAAMC,mBAAmB,GAAGC,gBAAAA;EAErB,MAAMC,2BAA2BC,EAAEC,YAAW,EACnD,GAAGJ,gBAAAA,wBACH;IACEK,OAAOF,EAAEG,OAAO;MACdC,QAAQJ,EAAEK,MAAMC,cAAcC,cAAAA;MAC9BC,OAAOR,EAAES,SAAST,EAAEU,OAAO;IAC7B,CAAA;IACAC,QAAQX,EAAEY;EACZ,CAAA,EAAA;EACC;mBATUb,qBAAAA;AAUf,GAbiBH,oBAAAA,kBAAAA,CAAAA,EAAAA;AAqBV,IAAMiB,mBAAkDC,cAAoC;EACjGC,SAAS;EACTC,OAAO,MAAA;EAAO;EACdC,MAAM,MAAA;EAAO;AACf,CAAA;",
|
|
6
|
+
"names": ["createContext", "S", "DocumentType", "CollectionType", "PresenterAction", "PRESENTER_ACTION", "PRESENTER_PLUGIN", "TogglePresentation", "S", "TaggedClass", "input", "Struct", "object", "Union", "DocumentType", "CollectionType", "state", "optional", "Boolean", "output", "Void", "PresenterContext", "createContext", "running", "start", "stop"]
|
|
7
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
} from "./chunk-
|
|
2
|
+
PresenterAction,
|
|
3
|
+
PresenterContext
|
|
4
|
+
} from "./chunk-Z6QQB6KB.mjs";
|
|
5
5
|
import {
|
|
6
6
|
PRESENTER_PLUGIN,
|
|
7
7
|
meta_default
|
|
@@ -9,10 +9,9 @@ import {
|
|
|
9
9
|
|
|
10
10
|
// packages/plugins/plugin-presenter/src/PresenterPlugin.tsx
|
|
11
11
|
import React2 from "react";
|
|
12
|
-
import { resolvePlugin, parseIntentPlugin, LayoutAction, NavigationAction } from "@dxos/app-framework";
|
|
12
|
+
import { resolvePlugin, parseIntentPlugin, LayoutAction, NavigationAction, createSurface, createIntent, createResolver } from "@dxos/app-framework";
|
|
13
13
|
import { create } from "@dxos/live-object";
|
|
14
14
|
import { LocalStorageStore } from "@dxos/local-storage";
|
|
15
|
-
import { parseClientPlugin } from "@dxos/plugin-client";
|
|
16
15
|
import { createExtension } from "@dxos/plugin-graph";
|
|
17
16
|
import { DocumentType } from "@dxos/plugin-markdown/types";
|
|
18
17
|
import { CollectionType } from "@dxos/plugin-space/types";
|
|
@@ -36,9 +35,9 @@ var PresenterSettings = ({ settings }) => {
|
|
|
36
35
|
};
|
|
37
36
|
|
|
38
37
|
// packages/plugins/plugin-presenter/src/components/index.ts
|
|
39
|
-
var RevealMain = lazy(() => import("./RevealMain-
|
|
40
|
-
var PresenterMain = lazy(() => import("./PresenterMain-
|
|
41
|
-
var MarkdownSlide = lazy(() => import("./MarkdownSlide-
|
|
38
|
+
var RevealMain = lazy(() => import("./RevealMain-JGKAQMQ4.mjs"));
|
|
39
|
+
var PresenterMain = lazy(() => import("./PresenterMain-TQE4OZK2.mjs"));
|
|
40
|
+
var MarkdownSlide = lazy(() => import("./MarkdownSlide-5NYXG5SC.mjs"));
|
|
42
41
|
|
|
43
42
|
// packages/plugins/plugin-presenter/src/translations.ts
|
|
44
43
|
var translations_default = [
|
|
@@ -66,9 +65,8 @@ var PresenterPlugin = () => {
|
|
|
66
65
|
settings: settings.values,
|
|
67
66
|
graph: {
|
|
68
67
|
builder: (plugins) => {
|
|
69
|
-
const
|
|
70
|
-
|
|
71
|
-
if (!client || !dispatch) {
|
|
68
|
+
const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatchPromise;
|
|
69
|
+
if (!dispatch) {
|
|
72
70
|
return [];
|
|
73
71
|
}
|
|
74
72
|
return createExtension({
|
|
@@ -79,27 +77,13 @@ var PresenterPlugin = () => {
|
|
|
79
77
|
const id = fullyQualifiedId(object);
|
|
80
78
|
return [
|
|
81
79
|
{
|
|
82
|
-
id: `${
|
|
80
|
+
id: `${PresenterAction.TogglePresentation._tag}/${id}`,
|
|
83
81
|
// TODO(burdon): Allow function so can generate state when activated.
|
|
84
82
|
// So can set explicit fullscreen state coordinated with current presenter state.
|
|
85
83
|
data: async () => {
|
|
86
|
-
await dispatch(
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
action: TOGGLE_PRESENTATION,
|
|
90
|
-
data: {
|
|
91
|
-
object
|
|
92
|
-
}
|
|
93
|
-
},
|
|
94
|
-
{
|
|
95
|
-
action: NavigationAction.OPEN,
|
|
96
|
-
data: {
|
|
97
|
-
activeParts: {
|
|
98
|
-
fullScreen: id
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
]);
|
|
84
|
+
await dispatch(createIntent(PresenterAction.TogglePresentation, {
|
|
85
|
+
object
|
|
86
|
+
}));
|
|
103
87
|
},
|
|
104
88
|
properties: {
|
|
105
89
|
label: [
|
|
@@ -130,74 +114,74 @@ var PresenterPlugin = () => {
|
|
|
130
114
|
}, children);
|
|
131
115
|
},
|
|
132
116
|
surface: {
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
117
|
+
definitions: () => [
|
|
118
|
+
createSurface({
|
|
119
|
+
id: `${PRESENTER_PLUGIN}/document`,
|
|
120
|
+
role: "main",
|
|
121
|
+
disposition: "hoist",
|
|
122
|
+
filter: (data) => data.subject instanceof DocumentType,
|
|
123
|
+
component: ({ data }) => /* @__PURE__ */ React2.createElement(RevealMain, {
|
|
124
|
+
document: data.subject
|
|
125
|
+
})
|
|
126
|
+
}),
|
|
127
|
+
createSurface({
|
|
128
|
+
id: `${PRESENTER_PLUGIN}/collection`,
|
|
129
|
+
role: "main",
|
|
130
|
+
disposition: "hoist",
|
|
131
|
+
filter: (data) => data.subject instanceof CollectionType,
|
|
132
|
+
component: ({ data }) => /* @__PURE__ */ React2.createElement(PresenterMain, {
|
|
133
|
+
collection: data.subject
|
|
134
|
+
})
|
|
135
|
+
}),
|
|
136
|
+
createSurface({
|
|
137
|
+
id: `${PRESENTER_PLUGIN}/slide`,
|
|
138
|
+
role: "slide",
|
|
139
|
+
filter: (data) => data.subject instanceof DocumentType,
|
|
140
|
+
component: ({ data }) => /* @__PURE__ */ React2.createElement(MarkdownSlide, {
|
|
141
|
+
document: data.subject
|
|
142
|
+
})
|
|
143
|
+
}),
|
|
144
|
+
createSurface({
|
|
145
|
+
id: `${PRESENTER_PLUGIN}/settings`,
|
|
146
|
+
role: "settings",
|
|
147
|
+
filter: (data) => data.subject === PRESENTER_PLUGIN,
|
|
148
|
+
component: () => /* @__PURE__ */ React2.createElement(PresenterSettings, {
|
|
149
|
+
settings: settings.values
|
|
150
|
+
})
|
|
151
|
+
})
|
|
152
|
+
]
|
|
168
153
|
},
|
|
169
154
|
intent: {
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
}
|
|
155
|
+
resolvers: () => createResolver(PresenterAction.TogglePresentation, ({ object, state: next }) => {
|
|
156
|
+
state.presenting = next ?? !state.presenting;
|
|
157
|
+
if (state.presenting) {
|
|
158
|
+
return {
|
|
159
|
+
intents: [
|
|
160
|
+
createIntent(LayoutAction.SetLayoutMode, {
|
|
161
|
+
layoutMode: "fullscreen"
|
|
162
|
+
}),
|
|
163
|
+
createIntent(NavigationAction.Open, {
|
|
164
|
+
activeParts: {
|
|
165
|
+
fullScreen: fullyQualifiedId(object)
|
|
182
166
|
}
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
167
|
+
})
|
|
168
|
+
]
|
|
169
|
+
};
|
|
170
|
+
} else {
|
|
171
|
+
return {
|
|
172
|
+
intents: [
|
|
173
|
+
createIntent(LayoutAction.SetLayoutMode, {
|
|
174
|
+
revert: true
|
|
175
|
+
}),
|
|
176
|
+
createIntent(NavigationAction.Close, {
|
|
177
|
+
activeParts: {
|
|
178
|
+
fullScreen: fullyQualifiedId(object)
|
|
191
179
|
}
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
data: state.presenting,
|
|
196
|
-
intents
|
|
197
|
-
};
|
|
198
|
-
}
|
|
180
|
+
})
|
|
181
|
+
]
|
|
182
|
+
};
|
|
199
183
|
}
|
|
200
|
-
}
|
|
184
|
+
})
|
|
201
185
|
}
|
|
202
186
|
}
|
|
203
187
|
};
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/PresenterPlugin.tsx", "../../../src/components/index.ts", "../../../src/components/PresenterSettings.tsx", "../../../src/translations.ts", "../../../src/index.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport {\n resolvePlugin,\n type PluginDefinition,\n parseIntentPlugin,\n LayoutAction,\n NavigationAction,\n
|
|
5
|
-
"mappings": ";;;;;;;;;;AAIA,OAAOA,YAAW;AAElB,SACEC,eAEAC,mBACAC,cACAC,
|
|
6
|
-
"names": ["React", "resolvePlugin", "parseIntentPlugin", "LayoutAction", "NavigationAction", "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport {\n resolvePlugin,\n type PluginDefinition,\n parseIntentPlugin,\n LayoutAction,\n NavigationAction,\n createSurface,\n createIntent,\n createResolver,\n} from '@dxos/app-framework';\nimport { create } from '@dxos/live-object';\nimport { LocalStorageStore } from '@dxos/local-storage';\nimport { createExtension, type Node } from '@dxos/plugin-graph';\nimport { DocumentType } from '@dxos/plugin-markdown/types';\nimport { CollectionType } from '@dxos/plugin-space/types';\nimport { fullyQualifiedId } from '@dxos/react-client/echo';\n\nimport { PresenterMain, PresenterSettings, MarkdownSlide, RevealMain } from './components';\nimport meta, { PRESENTER_PLUGIN } from './meta';\nimport translations from './translations';\nimport { PresenterContext, type PresenterSettingsProps, type PresenterPluginProvides, PresenterAction } from './types';\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\ntype PresenterState = {\n presenting: boolean;\n};\n\nexport const PresenterPlugin = (): PluginDefinition<PresenterPluginProvides> => {\n const settings = new LocalStorageStore<PresenterSettingsProps>(PRESENTER_PLUGIN);\n\n // TODO(burdon): Do we need context providers if we can get the state from the plugin?\n const state = create<PresenterState>({ presenting: false });\n\n return {\n meta,\n provides: {\n translations,\n settings: settings.values,\n graph: {\n builder: (plugins) => {\n const dispatch = resolvePlugin(plugins, parseIntentPlugin)?.provides.intent.dispatchPromise;\n if (!dispatch) {\n return [];\n }\n\n return createExtension({\n id: PRESENTER_PLUGIN,\n filter: (node): node is Node<CollectionType | DocumentType> =>\n settings.values.presentCollections\n ? node.data instanceof CollectionType || node.data instanceof DocumentType\n : node.data instanceof DocumentType,\n actions: ({ node }) => {\n const object = node.data;\n const id = fullyQualifiedId(object);\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 await dispatch(createIntent(PresenterAction.TogglePresentation, { object }));\n },\n properties: {\n label: ['toggle presentation label', { ns: PRESENTER_PLUGIN }],\n icon: 'ph--presentation--regular',\n keyBinding: {\n macos: 'shift+meta+p',\n windows: 'shift+alt+p',\n },\n },\n },\n ];\n },\n });\n },\n },\n context: ({ children }) => {\n return (\n <PresenterContext.Provider\n value={{\n running: state.presenting,\n start: () => (state.presenting = true),\n stop: () => (state.presenting = false),\n }}\n >\n {children}\n </PresenterContext.Provider>\n );\n },\n surface: {\n definitions: () => [\n createSurface({\n id: `${PRESENTER_PLUGIN}/document`,\n role: 'main',\n disposition: 'hoist',\n filter: (data): data is { subject: DocumentType } => data.subject instanceof DocumentType,\n component: ({ data }) => <RevealMain document={data.subject} />,\n }),\n createSurface({\n id: `${PRESENTER_PLUGIN}/collection`,\n role: 'main',\n disposition: 'hoist',\n filter: (data): data is { subject: CollectionType } => data.subject instanceof CollectionType,\n component: ({ data }) => <PresenterMain collection={data.subject} />,\n }),\n createSurface({\n id: `${PRESENTER_PLUGIN}/slide`,\n role: 'slide',\n filter: (data): data is { subject: DocumentType } => data.subject instanceof DocumentType,\n component: ({ data }) => <MarkdownSlide document={data.subject} />,\n }),\n createSurface({\n id: `${PRESENTER_PLUGIN}/settings`,\n role: 'settings',\n filter: (data): data is any => data.subject === PRESENTER_PLUGIN,\n component: () => <PresenterSettings settings={settings.values} />,\n }),\n ],\n },\n intent: {\n resolvers: () =>\n createResolver(PresenterAction.TogglePresentation, ({ object, state: next }) => {\n state.presenting = next ?? !state.presenting;\n\n if (state.presenting) {\n return {\n intents: [\n createIntent(LayoutAction.SetLayoutMode, { layoutMode: 'fullscreen' }),\n createIntent(NavigationAction.Open, { activeParts: { fullScreen: fullyQualifiedId(object) } }),\n ],\n };\n } else {\n return {\n intents: [\n createIntent(LayoutAction.SetLayoutMode, { revert: true }),\n createIntent(NavigationAction.Close, { activeParts: { fullScreen: fullyQualifiedId(object) } }),\n ],\n };\n }\n }),\n },\n },\n };\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './PresenterSettings';\n\nexport const RevealMain = lazy(() => import('./RevealMain'));\nexport const PresenterMain = lazy(() => import('./PresenterMain'));\nexport const MarkdownSlide = lazy(() => import('./MarkdownSlide'));\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React from 'react';\n\nimport { Input, useTranslation } from '@dxos/react-ui';\nimport { DeprecatedFormInput } from '@dxos/react-ui-form';\n\nimport { PRESENTER_PLUGIN } from '../meta';\nimport { type PresenterSettingsProps } from '../types';\n\nexport const PresenterSettings = ({ settings }: { settings: PresenterSettingsProps }) => {\n const { t } = useTranslation(PRESENTER_PLUGIN);\n\n return (\n <>\n <DeprecatedFormInput label={t('present collections label')}>\n <Input.Switch\n checked={settings.presentCollections}\n onCheckedChange={(checked) => (settings.presentCollections = !!checked)}\n />\n </DeprecatedFormInput>\n </>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { PRESENTER_PLUGIN } from './meta';\n\nexport default [\n {\n 'en-US': {\n [PRESENTER_PLUGIN]: {\n 'plugin name': 'Presenter',\n 'toggle presentation label': 'Present',\n 'present collections label': 'Present collections (experimental)',\n },\n },\n },\n];\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { PresenterPlugin } from './PresenterPlugin';\n\nexport default PresenterPlugin;\n\nexport * from './components';\n\nexport * from './PresenterPlugin';\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["React", "resolvePlugin", "parseIntentPlugin", "LayoutAction", "NavigationAction", "createSurface", "createIntent", "createResolver", "create", "LocalStorageStore", "createExtension", "DocumentType", "CollectionType", "fullyQualifiedId", "lazy", "React", "Input", "useTranslation", "DeprecatedFormInput", "PresenterSettings", "settings", "t", "useTranslation", "PRESENTER_PLUGIN", "DeprecatedFormInput", "label", "Input", "Switch", "checked", "presentCollections", "onCheckedChange", "RevealMain", "lazy", "PresenterMain", "MarkdownSlide", "PRESENTER_PLUGIN", "PresenterPlugin", "settings", "LocalStorageStore", "PRESENTER_PLUGIN", "state", "create", "presenting", "meta", "provides", "translations", "values", "graph", "builder", "plugins", "dispatch", "resolvePlugin", "parseIntentPlugin", "intent", "dispatchPromise", "createExtension", "id", "filter", "node", "presentCollections", "data", "CollectionType", "DocumentType", "actions", "object", "fullyQualifiedId", "PresenterAction", "TogglePresentation", "_tag", "createIntent", "properties", "label", "ns", "icon", "keyBinding", "macos", "windows", "context", "children", "React", "PresenterContext", "Provider", "value", "running", "start", "stop", "surface", "definitions", "createSurface", "role", "disposition", "subject", "component", "RevealMain", "document", "PresenterMain", "collection", "MarkdownSlide", "PresenterSettings", "resolvers", "createResolver", "next", "intents", "LayoutAction", "SetLayoutMode", "layoutMode", "NavigationAction", "Open", "activeParts", "fullScreen", "revert", "Close", "PresenterPlugin"]
|
|
7
7
|
}
|