@dxos/plugin-presenter 0.8.4-main.5ea62a8 → 0.8.4-main.ae835ea

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/dist/lib/browser/{CollectionPresenterContainer-U7D57ZVN.mjs → CollectionPresenterContainer-ASH2TGJR.mjs} +3 -3
  2. package/dist/lib/browser/{MarkdownSlide-KG7ESCSU.mjs → MarkdownSlide-BLVWTH3U.mjs} +15 -128
  3. package/dist/lib/browser/MarkdownSlide-BLVWTH3U.mjs.map +7 -0
  4. package/dist/lib/browser/{app-graph-builder-5LNLRZBN.mjs → app-graph-builder-UGCZOBA6.mjs} +16 -15
  5. package/dist/lib/browser/app-graph-builder-UGCZOBA6.mjs.map +7 -0
  6. package/dist/lib/browser/{chunk-W4IR3DJE.mjs → chunk-EOT6RIHJ.mjs} +5 -5
  7. package/dist/lib/browser/chunk-EOT6RIHJ.mjs.map +7 -0
  8. package/dist/lib/browser/chunk-TMTUZQCK.mjs +18 -0
  9. package/dist/lib/browser/chunk-TMTUZQCK.mjs.map +7 -0
  10. package/dist/lib/browser/{chunk-NINDSVTB.mjs → chunk-WWKBVJB3.mjs} +7 -7
  11. package/dist/lib/browser/chunk-WWKBVJB3.mjs.map +7 -0
  12. package/dist/lib/browser/index.mjs +6 -8
  13. package/dist/lib/browser/index.mjs.map +2 -2
  14. package/dist/lib/browser/meta.json +1 -1
  15. package/dist/lib/browser/{react-surface-GZIAFGCD.mjs → react-surface-UIAHN2NJ.mjs} +13 -13
  16. package/dist/lib/browser/react-surface-UIAHN2NJ.mjs.map +7 -0
  17. package/dist/lib/browser/{settings-VQVVDAGY.mjs → settings-RZWQTJI2.mjs} +5 -5
  18. package/dist/lib/browser/{settings-VQVVDAGY.mjs.map → settings-RZWQTJI2.mjs.map} +1 -1
  19. package/dist/types/src/PresenterPlugin.d.ts +1 -1
  20. package/dist/types/src/PresenterPlugin.d.ts.map +1 -1
  21. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  22. package/dist/types/src/components/Markdown/Container.stories.d.ts +0 -1
  23. package/dist/types/src/components/Markdown/Container.stories.d.ts.map +1 -1
  24. package/dist/types/src/components/Markdown/Slide.d.ts +1 -3
  25. package/dist/types/src/components/Markdown/Slide.d.ts.map +1 -1
  26. package/dist/types/src/components/Markdown/Slide.stories.d.ts +1 -1
  27. package/dist/types/src/components/Markdown/Slide.stories.d.ts.map +1 -1
  28. package/dist/types/src/components/Presenter/Pager.stories.d.ts +0 -1
  29. package/dist/types/src/components/Presenter/Pager.stories.d.ts.map +1 -1
  30. package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts +1 -1
  31. package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts.map +1 -1
  32. package/dist/types/src/components/index.d.ts +8 -6
  33. package/dist/types/src/components/index.d.ts.map +1 -1
  34. package/dist/types/src/meta.d.ts +0 -1
  35. package/dist/types/src/meta.d.ts.map +1 -1
  36. package/dist/types/src/types.d.ts +4 -3
  37. package/dist/types/src/types.d.ts.map +1 -1
  38. package/dist/types/tsconfig.tsbuildinfo +1 -1
  39. package/package.json +35 -35
  40. package/src/PresenterPlugin.tsx +22 -23
  41. package/src/capabilities/app-graph-builder.ts +11 -14
  42. package/src/capabilities/react-surface.tsx +10 -10
  43. package/src/components/Markdown/Container.stories.tsx +2 -4
  44. package/src/components/Markdown/Slide.stories.tsx +3 -2
  45. package/src/components/Markdown/Slide.tsx +12 -128
  46. package/src/components/Markdown/styles.css +104 -0
  47. package/src/components/Markdown/typings.d.ts +8 -0
  48. package/src/components/Presenter/Pager.stories.tsx +1 -3
  49. package/src/components/PresenterSettings.tsx +3 -3
  50. package/src/components/RevealPlayer/RevealPlayer.stories.tsx +3 -2
  51. package/src/meta.ts +7 -4
  52. package/src/types.ts +3 -3
  53. package/dist/lib/browser/MarkdownSlide-KG7ESCSU.mjs.map +0 -7
  54. package/dist/lib/browser/app-graph-builder-5LNLRZBN.mjs.map +0 -7
  55. package/dist/lib/browser/chunk-NINDSVTB.mjs.map +0 -7
  56. package/dist/lib/browser/chunk-VSD5LSE5.mjs +0 -15
  57. package/dist/lib/browser/chunk-VSD5LSE5.mjs.map +0 -7
  58. package/dist/lib/browser/chunk-W4IR3DJE.mjs.map +0 -7
  59. package/dist/lib/browser/react-surface-GZIAFGCD.mjs.map +0 -7
  60. /package/dist/lib/browser/{CollectionPresenterContainer-U7D57ZVN.mjs.map → CollectionPresenterContainer-ASH2TGJR.mjs.map} +0 -0
@@ -3,8 +3,8 @@ import {
3
3
  } from "./chunk-UVGTHJUO.mjs";
4
4
  import {
5
5
  PresenterContext
6
- } from "./chunk-W4IR3DJE.mjs";
7
- import "./chunk-VSD5LSE5.mjs";
6
+ } from "./chunk-EOT6RIHJ.mjs";
7
+ import "./chunk-TMTUZQCK.mjs";
8
8
 
9
9
  // src/components/CollectionPresenterContainer.tsx
10
10
  import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
@@ -188,4 +188,4 @@ var CollectionPresenterContainer_default = CollectionPresenterContainer;
188
188
  export {
189
189
  CollectionPresenterContainer_default as default
190
190
  };
191
- //# sourceMappingURL=CollectionPresenterContainer-U7D57ZVN.mjs.map
191
+ //# sourceMappingURL=CollectionPresenterContainer-ASH2TGJR.mjs.map
@@ -56,12 +56,15 @@ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking"
56
56
  import { h } from "hastscript";
57
57
  import React2 from "react";
58
58
  import ReactMarkdown from "react-markdown";
59
- import addClasses from "rehype-add-classes";
60
- import highlight from "rehype-highlight";
59
+ import rehypeAddClasses from "rehype-add-classes";
60
+ import rehypeHighlight from "rehype-highlight";
61
61
  import remarkFrontmatter from "remark-frontmatter";
62
62
  import remarkParseFrontmatter from "remark-parse-frontmatter";
63
63
  import "highlight.js/styles/github.css";
64
64
 
65
+ // raw-loader:/__w/dxos/dxos/packages/plugins/plugin-presenter/src/components/Markdown/styles.css?raw
66
+ var styles_default = "/*!\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 Outdated base version: https://github.com/primer/github-syntax-dark\n Current colors taken from GitHub's CSS\n*/\n/* TODO(burdon): Use tokens. */\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.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 color: #ff7b72;\n}\n.dark .hljs-title,\n.dark .hljs-title.class_,\n.dark .hljs-title.class_.inherited__,\n.dark .hljs-title.function_ {\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 color: #79c0ff;\n}\n.dark .hljs-regexp,\n.dark .hljs-string,\n.dark .hljs-meta .hljs-string {\n color: #a5d6ff;\n}\n.dark .hljs-built_in,\n.dark .hljs-symbol {\n color: #ffa657;\n}\n.dark .hljs-comment,\n.dark .hljs-code,\n.dark .hljs-formula {\n color: #8b949e;\n}\n.dark .hljs-name,\n.dark .hljs-quote,\n.dark .hljs-selector-tag,\n.dark .hljs-selector-pseudo {\n color: #7ee787;\n}\n.dark .hljs-subst {\n color: #c9d1d9;\n}\n.dark .hljs-section {\n color: #1f6feb;\n font-weight: bold;\n}\n.dark .hljs-bullet {\n color: #f2cc60;\n}\n.dark .hljs-emphasis {\n color: #c9d1d9;\n font-style: italic;\n}\n.dark .hljs-strong {\n color: #c9d1d9;\n font-weight: bold;\n}\n.dark .hljs-addition {\n color: #aff5b4;\n background-color: #033a16;\n}\n.dark .hljs-deletion {\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 all: unset;\n}\n";
67
+
65
68
  // src/components/Markdown/theme.ts
66
69
  var theme = {
67
70
  root: "bg-attention leading-relaxed font-mono",
@@ -83,126 +86,7 @@ var theme = {
83
86
  var Slide = ({ content = "", classes = theme.nodes }) => {
84
87
  var _effect = _useSignals2();
85
88
  try {
86
- return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement("style", null, `
87
- .dark pre code.hljs {
88
- display: block;
89
- overflow-x: auto;
90
- padding: 1em
91
- }
92
- .dark code.hljs {
93
- padding: 3px 5px
94
- }
95
- /*!
96
- Theme: GitHub Dark
97
- Description: Dark theme as seen on github.com
98
- Author: github.com
99
- Maintainer: @Hirse
100
- Updated: 2021-05-15
101
-
102
- Outdated base version: https://github.com/primer/github-syntax-dark
103
- Current colors taken from GitHub's CSS
104
- */
105
- .dark .hljs {
106
- color: #c9d1d9;
107
- background: #0d1117
108
- }
109
- .dark .hljs-doctag,
110
- .dark .hljs-keyword,
111
- .dark .hljs-meta .hljs-keyword,
112
- .dark .hljs-template-tag,
113
- .dark .hljs-template-variable,
114
- .dark .hljs-type,
115
- .dark .hljs-variable.language_ {
116
- /* prettylights-syntax-keyword */
117
- color: #ff7b72
118
- }
119
- .dark .hljs-title,
120
- .dark .hljs-title.class_,
121
- .dark .hljs-title.class_.inherited__,
122
- .dark .hljs-title.function_ {
123
- /* prettylights-syntax-entity */
124
- color: #d2a8ff
125
- }
126
- .dark .hljs-attr,
127
- .dark .hljs-attribute,
128
- .dark .hljs-literal,
129
- .dark .hljs-meta,
130
- .dark .hljs-number,
131
- .dark .hljs-operator,
132
- .dark .hljs-variable,
133
- .dark .hljs-selector-attr,
134
- .dark .hljs-selector-class,
135
- .dark .hljs-selector-id {
136
- /* prettylights-syntax-constant */
137
- color: #79c0ff
138
- }
139
- .dark .hljs-regexp,
140
- .dark .hljs-string,
141
- .dark .hljs-meta .hljs-string {
142
- /* prettylights-syntax-string */
143
- color: #a5d6ff
144
- }
145
- .dark .hljs-built_in,
146
- .dark .hljs-symbol {
147
- /* prettylights-syntax-variable */
148
- color: #ffa657
149
- }
150
- .dark .hljs-comment,
151
- .dark .hljs-code,
152
- .dark .hljs-formula {
153
- /* prettylights-syntax-comment */
154
- color: #8b949e
155
- }
156
- .dark .hljs-name,
157
- .dark .hljs-quote,
158
- .dark .hljs-selector-tag,
159
- .dark .hljs-selector-pseudo {
160
- /* prettylights-syntax-entity-tag */
161
- color: #7ee787
162
- }
163
- .dark .hljs-subst {
164
- /* prettylights-syntax-storage-modifier-import */
165
- color: #c9d1d9
166
- }
167
- .dark .hljs-section {
168
- /* prettylights-syntax-markup-heading */
169
- color: #1f6feb;
170
- font-weight: bold
171
- }
172
- .dark .hljs-bullet {
173
- /* prettylights-syntax-markup-list */
174
- color: #f2cc60
175
- }
176
- .dark .hljs-emphasis {
177
- /* prettylights-syntax-markup-italic */
178
- color: #c9d1d9;
179
- font-style: italic
180
- }
181
- .dark .hljs-strong {
182
- /* prettylights-syntax-markup-bold */
183
- color: #c9d1d9;
184
- font-weight: bold
185
- }
186
- .dark .hljs-addition {
187
- /* prettylights-syntax-markup-inserted */
188
- color: #aff5b4;
189
- background-color: #033a16
190
- }
191
- .dark .hljs-deletion {
192
- /* prettylights-syntax-markup-deleted */
193
- color: #ffdcd7;
194
- background-color: #67060c
195
- }
196
- .dark .hljs-char.escape_,
197
- .dark .hljs-link,
198
- .dark .hljs-params,
199
- .dark .hljs-property,
200
- .dark .hljs-punctuation,
201
- .dark .hljs-tag {
202
- /* purposely ignored */
203
-
204
- }
205
- `), /* @__PURE__ */ React2.createElement(ReactMarkdown, {
89
+ return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement("style", null, styles_default), /* @__PURE__ */ React2.createElement(ReactMarkdown, {
206
90
  components,
207
91
  // Markdown to HTML.
208
92
  remarkPlugins: [
@@ -214,11 +98,11 @@ var Slide = ({ content = "", classes = theme.nodes }) => {
214
98
  ],
215
99
  // HTML processing.
216
100
  rehypePlugins: [
217
- highlight,
218
101
  [
219
- addClasses,
102
+ rehypeAddClasses,
220
103
  classes
221
104
  ],
105
+ rehypeHighlight,
222
106
  slideLayout
223
107
  ]
224
108
  }, content));
@@ -226,7 +110,7 @@ var Slide = ({ content = "", classes = theme.nodes }) => {
226
110
  _effect.f();
227
111
  }
228
112
  };
229
- var slideLayout = (options = {}) => (tree, file) => {
113
+ var slideLayout = (_options = {}) => (tree, file) => {
230
114
  const { data: { frontmatter = {} } } = file;
231
115
  let content = tree.children;
232
116
  const { layout, image } = frontmatter;
@@ -298,7 +182,7 @@ var slideLayout = (options = {}) => (tree, file) => {
298
182
  root
299
183
  ];
300
184
  };
301
- var ImageWrapper = ({ node, ...props }) => {
185
+ var ImageWrapper = ({ node: _, ...props }) => {
302
186
  var _effect = _useSignals2();
303
187
  try {
304
188
  const { alt = "", src } = props;
@@ -311,7 +195,10 @@ var ImageWrapper = ({ node, ...props }) => {
311
195
  }
312
196
  };
313
197
  var components = {
314
- img: ImageWrapper
198
+ img: ({ node, ...props }) => /* @__PURE__ */ React2.createElement(ImageWrapper, {
199
+ node,
200
+ ...props
201
+ })
315
202
  };
316
203
 
317
204
  // src/components/MarkdownSlide.tsx
@@ -333,4 +220,4 @@ var MarkdownSlide_default = MarkdownSlide;
333
220
  export {
334
221
  MarkdownSlide_default as default
335
222
  };
336
- //# sourceMappingURL=MarkdownSlide-KG7ESCSU.mjs.map
223
+ //# sourceMappingURL=MarkdownSlide-BLVWTH3U.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", "raw-loader:/__w/dxos/dxos/packages/plugins/plugin-presenter/src/components/Markdown/styles.css?raw", "../../../src/components/Markdown/theme.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { type FC } from 'react';\n\nimport { type Markdown } from '@dxos/plugin-markdown/types';\n\nimport { Container, Slide } from './Markdown';\n\nconst MarkdownSlide: FC<{ document: Markdown.Document }> = ({ 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, { type Options as ReactMarkdownOptions } from 'react-markdown';\nimport rehypeAddClasses from 'rehype-add-classes';\nimport rehypeHighlight from 'rehype-highlight';\nimport remarkFrontmatter from 'remark-frontmatter';\nimport remarkParseFrontmatter from 'remark-parse-frontmatter';\n\nimport 'highlight.js/styles/github.css';\n\nimport styles from './styles.css?raw';\nimport { theme } from './theme';\n\nexport type SlideProps = {\n content?: string;\n classes?: Record<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>{styles}</style>\n <ReactMarkdown\n components={components}\n // Markdown to HTML.\n remarkPlugins={[[remarkFrontmatter, 'yaml'], remarkParseFrontmatter as any]}\n // HTML processing.\n rehypePlugins={[[rehypeAddClasses, classes], rehypeHighlight as any, 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: ReactMarkdownOptions['components'] = {\n img: ({ node, ...props }) => <ImageWrapper node={node} {...props} />,\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 Outdated base version: https://github.com/primer/github-syntax-dark\n Current colors taken from GitHub's CSS\n*/\n/* TODO(burdon): Use tokens. */\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.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 color: #ff7b72;\n}\n.dark .hljs-title,\n.dark .hljs-title.class_,\n.dark .hljs-title.class_.inherited__,\n.dark .hljs-title.function_ {\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 color: #79c0ff;\n}\n.dark .hljs-regexp,\n.dark .hljs-string,\n.dark .hljs-meta .hljs-string {\n color: #a5d6ff;\n}\n.dark .hljs-built_in,\n.dark .hljs-symbol {\n color: #ffa657;\n}\n.dark .hljs-comment,\n.dark .hljs-code,\n.dark .hljs-formula {\n color: #8b949e;\n}\n.dark .hljs-name,\n.dark .hljs-quote,\n.dark .hljs-selector-tag,\n.dark .hljs-selector-pseudo {\n color: #7ee787;\n}\n.dark .hljs-subst {\n color: #c9d1d9;\n}\n.dark .hljs-section {\n color: #1f6feb;\n font-weight: bold;\n}\n.dark .hljs-bullet {\n color: #f2cc60;\n}\n.dark .hljs-emphasis {\n color: #c9d1d9;\n font-style: italic;\n}\n.dark .hljs-strong {\n color: #c9d1d9;\n font-weight: bold;\n}\n.dark .hljs-addition {\n color: #aff5b4;\n background-color: #033a16;\n}\n.dark .hljs-deletion {\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 all: unset;\n}\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-inputSurface 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", "rehypeAddClasses", "rehypeHighlight", "remarkFrontmatter", "remarkParseFrontmatter", "theme", "root", "padding", "nodes", "h1", "h2", "h3", "p", "ul", "ol", "li", "pre", "code", "Slide", "content", "classes", "theme", "nodes", "React", "style", "styles", "ReactMarkdown", "components", "remarkPlugins", "remarkFrontmatter", "remarkParseFrontmatter", "rehypePlugins", "rehypeAddClasses", "rehypeHighlight", "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,13 +1,14 @@
1
1
  import {
2
2
  PresenterAction
3
- } from "./chunk-W4IR3DJE.mjs";
3
+ } from "./chunk-EOT6RIHJ.mjs";
4
4
  import {
5
- PRESENTER_PLUGIN
6
- } from "./chunk-VSD5LSE5.mjs";
5
+ meta
6
+ } from "./chunk-TMTUZQCK.mjs";
7
7
 
8
8
  // src/capabilities/app-graph-builder.ts
9
9
  import { Rx } from "@effect-rx/rx-react";
10
- import { Option, pipe } from "effect";
10
+ import * as Function from "effect/Function";
11
+ import * as Option from "effect/Option";
11
12
  import { Capabilities, LayoutAction, contributes, createIntent } from "@dxos/app-framework";
12
13
  import { Obj } from "@dxos/echo";
13
14
  import { DeckCapabilities } from "@dxos/plugin-deck";
@@ -16,12 +17,12 @@ import { createExtension, rxFromSignal } from "@dxos/plugin-graph";
16
17
  import { Markdown } from "@dxos/plugin-markdown/types";
17
18
  import { fullyQualifiedId, getSpace } from "@dxos/react-client/echo";
18
19
  import { DataType } from "@dxos/schema";
19
- var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, createExtension({
20
- id: PRESENTER_PLUGIN,
20
+ var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, createExtension({
21
+ id: `${meta.id}/root`,
21
22
  // TODO(wittjosiah): This is a hack to work around presenter previously relying on "variant". Remove.
22
- connector: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => {
23
+ connector: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
23
24
  const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
24
- const settings = get(rxFromSignal(() => settingsStore?.getStore(PRESENTER_PLUGIN)?.value));
25
+ const settings = get(rxFromSignal(() => settingsStore?.getStore(meta.id)?.value));
25
26
  const isPresentable = settings?.presentCollections ? Obj.instanceOf(DataType.Collection, node2.data) || Obj.instanceOf(Markdown.Document, node2.data) : Obj.instanceOf(Markdown.Document, node2.data);
26
27
  return isPresentable ? Option.some(node2.data) : Option.none();
27
28
  }), Option.map((object) => {
@@ -33,10 +34,10 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
33
34
  "presenter"
34
35
  ].join(ATTENDABLE_PATH_SEPARATOR),
35
36
  data: {
36
- type: PRESENTER_PLUGIN,
37
+ type: meta.id,
37
38
  object
38
39
  },
39
- type: PRESENTER_PLUGIN,
40
+ type: meta.id,
40
41
  properties: {
41
42
  label: "Presenter",
42
43
  icon: "ph--presentation--regular",
@@ -45,9 +46,9 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
45
46
  }
46
47
  ];
47
48
  }), Option.getOrElse(() => []))),
48
- actions: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => {
49
+ actions: (node) => Rx.make((get) => Function.pipe(get(node), Option.flatMap((node2) => {
49
50
  const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
50
- const settings = get(rxFromSignal(() => settingsStore?.getStore(PRESENTER_PLUGIN)?.value));
51
+ const settings = get(rxFromSignal(() => settingsStore?.getStore(meta.id)?.value));
51
52
  const isPresentable = settings?.presentCollections ? Obj.instanceOf(DataType.Collection, node2.data) || Obj.instanceOf(Markdown.Document, node2.data) : Obj.instanceOf(Markdown.Document, node2.data);
52
53
  return isPresentable ? Option.some(node2.data) : Option.none();
53
54
  }), Option.map((object) => {
@@ -85,7 +86,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
85
86
  label: [
86
87
  "toggle presentation label",
87
88
  {
88
- ns: PRESENTER_PLUGIN
89
+ ns: meta.id
89
90
  }
90
91
  ],
91
92
  icon: "ph--presentation--regular",
@@ -98,8 +99,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
98
99
  }
99
100
  ];
100
101
  }), Option.getOrElse(() => [])))
101
- }));
102
+ })));
102
103
  export {
103
104
  app_graph_builder_default as default
104
105
  };
105
- //# sourceMappingURL=app-graph-builder-5LNLRZBN.mjs.map
106
+ //# sourceMappingURL=app-graph-builder-UGCZOBA6.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/app-graph-builder.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Rx } from '@effect-rx/rx-react';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\n\nimport { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';\nimport { Obj } from '@dxos/echo';\nimport { DeckCapabilities } from '@dxos/plugin-deck';\nimport { ATTENDABLE_PATH_SEPARATOR, DeckAction } from '@dxos/plugin-deck/types';\nimport { createExtension, rxFromSignal } from '@dxos/plugin-graph';\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';\nimport { DataType } from '@dxos/schema';\n\nimport { meta } from '../meta';\nimport { PresenterAction, type PresenterSettingsProps } from '../types';\n\nexport default (context: PluginContext) =>\n contributes(\n Capabilities.AppGraphBuilder,\n createExtension({\n id: `${meta.id}/root`,\n // TODO(wittjosiah): This is a hack to work around presenter previously relying on \"variant\". Remove.\n connector: (node) =>\n Rx.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => {\n const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));\n const settings = get(rxFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value));\n const isPresentable = settings?.presentCollections\n ? Obj.instanceOf(DataType.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)\n : Obj.instanceOf(Markdown.Document, node.data);\n return isPresentable ? Option.some(node.data) : Option.none();\n }),\n Option.map((object) => {\n const id = fullyQualifiedId(object);\n return [\n {\n id: [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR),\n data: { type: meta.id, object },\n type: meta.id,\n properties: {\n label: 'Presenter',\n icon: 'ph--presentation--regular',\n disposition: 'hidden',\n },\n },\n ];\n }),\n Option.getOrElse(() => []),\n ),\n ),\n actions: (node) =>\n Rx.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => {\n const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));\n const settings = get(rxFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value));\n const isPresentable = settings?.presentCollections\n ? Obj.instanceOf(DataType.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)\n : Obj.instanceOf(Markdown.Document, node.data);\n return isPresentable ? Option.some(node.data) : Option.none();\n }),\n Option.map((object) => {\n const id = fullyQualifiedId(object);\n const spaceId = getSpace(object)?.id;\n return [\n {\n id: `${PresenterAction.TogglePresentation._tag}/${id}`,\n // TODO(burdon): Allow function so can generate state when activated.\n // So can set explicit fullscreen state coordinated with current presenter state.\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n const layout = context.getCapability(DeckCapabilities.MutableDeckState);\n const presenterId = [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR);\n if (!layout.deck.fullscreen) {\n void dispatch(\n createIntent(DeckAction.Adjust, {\n type: 'solo--fullscreen',\n id: presenterId,\n }),\n );\n }\n await dispatch(\n createIntent(LayoutAction.Open, {\n part: 'main',\n subject: [presenterId],\n options: { workspace: spaceId },\n }),\n );\n },\n properties: {\n label: ['toggle presentation label', { ns: meta.id }],\n icon: 'ph--presentation--regular',\n disposition: 'list-item',\n keyBinding: {\n macos: 'shift+meta+p',\n windows: 'shift+alt+p',\n },\n },\n },\n ];\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n );\n"],
5
+ "mappings": "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",
6
+ "names": ["Rx", "Function", "Option", "Capabilities", "LayoutAction", "contributes", "createIntent", "Obj", "DeckCapabilities", "ATTENDABLE_PATH_SEPARATOR", "DeckAction", "createExtension", "rxFromSignal", "Markdown", "fullyQualifiedId", "getSpace", "DataType", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "connector", "node", "Rx", "make", "get", "pipe", "flatMap", "settingsStore", "capabilities", "SettingsStore", "settings", "rxFromSignal", "getStore", "value", "isPresentable", "presentCollections", "Obj", "instanceOf", "DataType", "Collection", "data", "Markdown", "Document", "some", "none", "map", "object", "fullyQualifiedId", "join", "ATTENDABLE_PATH_SEPARATOR", "type", "properties", "label", "icon", "disposition", "getOrElse", "actions", "spaceId", "getSpace", "PresenterAction", "TogglePresentation", "_tag", "dispatchPromise", "dispatch", "getCapability", "IntentDispatcher", "layout", "DeckCapabilities", "MutableDeckState", "presenterId", "deck", "fullscreen", "createIntent", "DeckAction", "Adjust", "LayoutAction", "Open", "part", "subject", "options", "workspace", "ns", "keyBinding", "macos", "windows"]
7
+ }
@@ -1,14 +1,14 @@
1
1
  import {
2
- PRESENTER_PLUGIN
3
- } from "./chunk-VSD5LSE5.mjs";
2
+ meta
3
+ } from "./chunk-TMTUZQCK.mjs";
4
4
 
5
5
  // src/types.ts
6
- import { Schema } from "effect";
6
+ import * as Schema from "effect/Schema";
7
7
  import { createContext } from "react";
8
8
  import { Markdown } from "@dxos/plugin-markdown/types";
9
9
  import { DataType } from "@dxos/schema";
10
10
  (function(PresenterAction2) {
11
- const PRESENTER_ACTION = `${PRESENTER_PLUGIN}/action`;
11
+ const PRESENTER_ACTION = `${meta.id}/action`;
12
12
  class TogglePresentation extends Schema.TaggedClass()(`${PRESENTER_ACTION}/toggle-presentation`, {
13
13
  input: Schema.Struct({
14
14
  object: Schema.Union(Markdown.Document, DataType.Collection),
@@ -36,4 +36,4 @@ export {
36
36
  PresenterSettingsSchema,
37
37
  PresenterAction
38
38
  };
39
- //# sourceMappingURL=chunk-W4IR3DJE.mjs.map
39
+ //# sourceMappingURL=chunk-EOT6RIHJ.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 * as Schema from 'effect/Schema';\nimport { type Context, createContext } from 'react';\n\nimport { Markdown } from '@dxos/plugin-markdown/types';\nimport { DataType } from '@dxos/schema';\n\nimport { meta } from './meta';\n\nexport namespace PresenterAction {\n const PRESENTER_ACTION = `${meta.id}/action`;\n\n export class TogglePresentation extends Schema.TaggedClass<TogglePresentation>()(\n `${PRESENTER_ACTION}/toggle-presentation`,\n {\n input: Schema.Struct({\n object: Schema.Union(Markdown.Document, DataType.Collection),\n state: Schema.optional(Schema.Boolean),\n }),\n output: Schema.Void,\n },\n ) {}\n}\n\nexport type PresenterContextType = {\n running: boolean;\n start: () => void;\n stop: () => void;\n};\n\nexport const PresenterContext: Context<PresenterContextType> = createContext<PresenterContextType>({\n running: false,\n start: () => {},\n stop: () => {},\n});\n\nexport const PresenterSettingsSchema = Schema.mutable(\n Schema.Struct({\n presentCollections: Schema.optional(Schema.Boolean),\n }),\n);\n\nexport type PresenterSettingsProps = Schema.Schema.Type<typeof PresenterSettingsSchema>;\n"],
5
+ "mappings": ";;;;;AAIA,YAAYA,YAAY;AACxB,SAAuBC,qBAAqB;AAE5C,SAASC,gBAAgB;AACzB,SAASC,gBAAgB;UAIRC,kBAAAA;AACf,QAAMC,mBAAmB,GAAGC,KAAKC,EAAE;EAE5B,MAAMC,2BAAkCC,mBAAW,EACxD,GAAGJ,gBAAAA,wBACH;IACEK,OAAcC,cAAO;MACnBC,QAAeC,aAAMC,SAASC,UAAUC,SAASC,UAAU;MAC3DC,OAAcC,gBAAgBC,cAAO;IACvC,CAAA;IACAC,QAAeC;EACjB,CAAA,EAAA;EACC;mBATUd,qBAAAA;AAUf,GAbiBJ,oBAAAA,kBAAAA,CAAAA,EAAAA;AAqBV,IAAMmB,mBAAkDC,cAAoC;EACjGC,SAAS;EACTC,OAAO,MAAA;EAAO;EACdC,MAAM,MAAA;EAAO;AACf,CAAA;AAEO,IAAMC,0BAAiCC,eACrClB,cAAO;EACZmB,oBAA2BX,gBAAgBC,cAAO;AACpD,CAAA,CAAA;;",
6
+ "names": ["Schema", "createContext", "Markdown", "DataType", "PresenterAction", "PRESENTER_ACTION", "meta", "id", "TogglePresentation", "TaggedClass", "input", "Struct", "object", "Union", "Markdown", "Document", "DataType", "Collection", "state", "optional", "Boolean", "output", "Void", "PresenterContext", "createContext", "running", "start", "stop", "PresenterSettingsSchema", "mutable", "presentCollections"]
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-TMTUZQCK.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 PluginMeta } from '@dxos/app-framework';\nimport { trim } from '@dxos/util';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/presenter',\n name: 'Presenter',\n description: trim`\n Transform markdown documents into interactive presentation slideshows.\n Navigate between slides with keyboard controls and present content in full-screen mode.\n `,\n icon: 'ph--presentation--regular',\n iconHue: 'indigo',\n source: 'https://github.com/dxos/dxos/tree/main/packages/plugins/plugin-presenter',\n};\n"],
5
+ "mappings": ";AAKA,SAASA,YAAY;AAEd,IAAMC,OAAmB;EAC9BC,IAAI;EACJC,MAAM;EACNC,aAAaC;;;;EAIbC,MAAM;EACNC,SAAS;EACTC,QAAQ;AACV;",
6
+ "names": ["trim", "meta", "id", "name", "description", "trim", "icon", "iconHue", "source"]
7
+ }
@@ -1,6 +1,6 @@
1
1
  import {
2
- PRESENTER_PLUGIN
3
- } from "./chunk-VSD5LSE5.mjs";
2
+ meta
3
+ } from "./chunk-TMTUZQCK.mjs";
4
4
 
5
5
  // src/components/PresenterSettings.tsx
6
6
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
@@ -10,10 +10,10 @@ import { ControlGroup, ControlItemInput, ControlPage, ControlSection } from "@dx
10
10
  var PresenterSettings = ({ settings }) => {
11
11
  var _effect = _useSignals();
12
12
  try {
13
- const { t } = useTranslation(PRESENTER_PLUGIN);
13
+ const { t } = useTranslation(meta.id);
14
14
  return /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
15
15
  title: t("settings title", {
16
- ns: PRESENTER_PLUGIN
16
+ ns: meta.id
17
17
  })
18
18
  }, /* @__PURE__ */ React.createElement(ControlGroup, null, /* @__PURE__ */ React.createElement(ControlItemInput, {
19
19
  title: t("present collections label")
@@ -28,9 +28,9 @@ var PresenterSettings = ({ settings }) => {
28
28
 
29
29
  // src/components/index.ts
30
30
  import { lazy } from "react";
31
- var MarkdownSlide = lazy(() => import("./MarkdownSlide-KG7ESCSU.mjs"));
31
+ var MarkdownSlide = lazy(() => import("./MarkdownSlide-BLVWTH3U.mjs"));
32
32
  var DocumentPresenterContainer = lazy(() => import("./DocumentPresenterContainer-F42V4KAL.mjs"));
33
- var CollectionPresenterContainer = lazy(() => import("./CollectionPresenterContainer-U7D57ZVN.mjs"));
33
+ var CollectionPresenterContainer = lazy(() => import("./CollectionPresenterContainer-ASH2TGJR.mjs"));
34
34
 
35
35
  export {
36
36
  PresenterSettings,
@@ -38,4 +38,4 @@ export {
38
38
  DocumentPresenterContainer,
39
39
  CollectionPresenterContainer
40
40
  };
41
- //# sourceMappingURL=chunk-NINDSVTB.mjs.map
41
+ //# sourceMappingURL=chunk-WWKBVJB3.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 const PresenterSettings = ({ settings }: { settings: PresenterSettingsProps }) => {\n const { t } = useTranslation(meta.id);\n\n return (\n <ControlPage>\n <ControlSection title={t('settings title', { ns: meta.id })}>\n <ControlGroup>\n <ControlItemInput title={t('present collections label')}>\n <Input.Switch\n checked={settings.presentCollections}\n onCheckedChange={(checked) => (settings.presentCollections = !!checked)}\n />\n </ControlItemInput>\n </ControlGroup>\n </ControlSection>\n </ControlPage>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { lazy } from 'react';\n\nexport * from './PresenterSettings';\n\nexport const MarkdownSlide = lazy(() => import('./MarkdownSlide'));\nexport const DocumentPresenterContainer = lazy(() => import('./DocumentPresenterContainer'));\nexport const CollectionPresenterContainer = lazy(() => import('./CollectionPresenterContainer'));\n"],
5
+ "mappings": ";;;;;;AAIA,OAAOA,WAAW;AAElB,SAASC,OAAOC,sBAAsB;AACtC,SAASC,cAAcC,kBAAkBC,aAAaC,sBAAsB;AAKrE,IAAMC,oBAAoB,CAAC,EAAEC,SAAQ,MAAwC;;;AAClF,UAAM,EAAEC,EAAC,IAAKC,eAAeC,KAAKC,EAAE;AAEpC,WACE,sBAAA,cAACC,aAAAA,MACC,sBAAA,cAACC,gBAAAA;MAAeC,OAAON,EAAE,kBAAkB;QAAEO,IAAIL,KAAKC;MAAG,CAAA;OACvD,sBAAA,cAACK,cAAAA,MACC,sBAAA,cAACC,kBAAAA;MAAiBH,OAAON,EAAE,2BAAA;OACzB,sBAAA,cAACU,MAAMC,QAAM;MACXC,SAASb,SAASc;MAClBC,iBAAiB,CAACF,YAAab,SAASc,qBAAqB,CAAC,CAACD;;;;;AAO7E;;;ACzBA,SAASG,YAAY;AAId,IAAMC,gBAAgBC,KAAK,MAAM,OAAO,8BAAA,CAAA;AACxC,IAAMC,6BAA6BD,KAAK,MAAM,OAAO,2CAAA,CAAA;AACrD,IAAME,+BAA+BF,KAAK,MAAM,OAAO,6CAAA,CAAA;",
6
+ "names": ["React", "Input", "useTranslation", "ControlGroup", "ControlItemInput", "ControlPage", "ControlSection", "PresenterSettings", "settings", "t", "useTranslation", "meta", "id", "ControlPage", "ControlSection", "title", "ns", "ControlGroup", "ControlItemInput", "Input", "Switch", "checked", "presentCollections", "onCheckedChange", "lazy", "MarkdownSlide", "lazy", "DocumentPresenterContainer", "CollectionPresenterContainer"]
7
+ }
@@ -3,20 +3,19 @@ import {
3
3
  DocumentPresenterContainer,
4
4
  MarkdownSlide,
5
5
  PresenterSettings
6
- } from "./chunk-NINDSVTB.mjs";
6
+ } from "./chunk-WWKBVJB3.mjs";
7
7
  import {
8
- PRESENTER_PLUGIN,
9
8
  meta
10
- } from "./chunk-VSD5LSE5.mjs";
9
+ } from "./chunk-TMTUZQCK.mjs";
11
10
 
12
11
  // src/PresenterPlugin.tsx
13
12
  import { Capabilities, Events, contributes, defineModule, definePlugin } from "@dxos/app-framework";
14
13
 
15
14
  // src/capabilities/index.ts
16
15
  import { lazy } from "@dxos/app-framework";
17
- var AppGraphBuilder = lazy(() => import("./app-graph-builder-5LNLRZBN.mjs"));
18
- var ReactSurface = lazy(() => import("./react-surface-GZIAFGCD.mjs"));
19
- var PresenterSettings2 = lazy(() => import("./settings-VQVVDAGY.mjs"));
16
+ var AppGraphBuilder = lazy(() => import("./app-graph-builder-UGCZOBA6.mjs"));
17
+ var ReactSurface = lazy(() => import("./react-surface-UIAHN2NJ.mjs"));
18
+ var PresenterSettings2 = lazy(() => import("./settings-RZWQTJI2.mjs"));
20
19
 
21
20
  // src/translations.ts
22
21
  var translations = [
@@ -33,7 +32,7 @@ var translations = [
33
32
  ];
34
33
 
35
34
  // src/PresenterPlugin.tsx
36
- var PresenterPlugin = () => definePlugin(meta, [
35
+ var PresenterPlugin = definePlugin(meta, () => [
37
36
  defineModule({
38
37
  id: `${meta.id}/module/settings`,
39
38
  activatesOn: Events.SetupSettings,
@@ -59,7 +58,6 @@ export {
59
58
  CollectionPresenterContainer,
60
59
  DocumentPresenterContainer,
61
60
  MarkdownSlide,
62
- PRESENTER_PLUGIN,
63
61
  PresenterPlugin,
64
62
  PresenterSettings,
65
63
  meta
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../../src/PresenterPlugin.tsx", "../../../src/capabilities/index.ts", "../../../src/translations.ts"],
4
- "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Capabilities, Events, contributes, defineModule, definePlugin } 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 = () =>\n definePlugin(meta, [\n defineModule({\n id: `${meta.id}/module/settings`,\n activatesOn: Events.SetupSettings,\n activate: PresenterSettings,\n }),\n defineModule({\n id: `${meta.id}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${meta.id}/module/react-surface`,\n activatesOn: Events.SetupReactSurface,\n activate: ReactSurface,\n }),\n defineModule({\n id: `${meta.id}/module/app-graph-builder`,\n activatesOn: Events.SetupAppGraph,\n activate: AppGraphBuilder,\n }),\n ]);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = lazy(() => import('./app-graph-builder'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\nexport const PresenterSettings = lazy(() => 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,cAAcC,QAAQC,aAAaC,cAAcC,oBAAoB;;;ACA9E,SAASC,YAAY;AAEd,IAAMC,kBAAkBC,KAAK,MAAM,OAAO,kCAAA,CAAA;AAC1C,IAAMC,eAAeD,KAAK,MAAM,OAAO,8BAAA,CAAA;AACvC,IAAME,qBAAoBF,KAAK,MAAM,OAAO,yBAAA,CAAA;;;ACA5C,IAAMG,eAAe;EAC1B;IACE,SAAS;MACP,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;QACf,kBAAkB;QAClB,6BAA6B;QAC7B,6BAA6B;MAC/B;IACF;EACF;;;;AFLK,IAAMC,kBAAkB,MAC7BC,aAAaC,MAAM;EACjBC,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOC;IACpBC,UAAUC;EACZ,CAAA;EACAN,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOI;IACpBF,UAAU,MAAMG,YAAYC,aAAaC,cAAcC,YAAAA;EACzD,CAAA;EACAX,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOS;IACpBP,UAAUQ;EACZ,CAAA;EACAb,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOW;IACpBT,UAAUU;EACZ,CAAA;CACD;",
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Capabilities, Events, contributes, defineModule, definePlugin } 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 = definePlugin(meta, () => [\n defineModule({\n id: `${meta.id}/module/settings`,\n activatesOn: Events.SetupSettings,\n activate: PresenterSettings,\n }),\n defineModule({\n id: `${meta.id}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${meta.id}/module/react-surface`,\n activatesOn: Events.SetupReactSurface,\n activate: ReactSurface,\n }),\n defineModule({\n id: `${meta.id}/module/app-graph-builder`,\n activatesOn: Events.SetupAppGraph,\n activate: AppGraphBuilder,\n }),\n]);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { lazy } from '@dxos/app-framework';\n\nexport const AppGraphBuilder = lazy(() => import('./app-graph-builder'));\nexport const ReactSurface = lazy(() => import('./react-surface'));\nexport const PresenterSettings = lazy(() => 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,cAAcC,QAAQC,aAAaC,cAAcC,oBAAoB;;;ACA9E,SAASC,YAAY;AAEd,IAAMC,kBAAkBC,KAAK,MAAM,OAAO,kCAAA,CAAA;AAC1C,IAAMC,eAAeD,KAAK,MAAM,OAAO,8BAAA,CAAA;AACvC,IAAME,qBAAoBF,KAAK,MAAM,OAAO,yBAAA,CAAA;;;ACA5C,IAAMG,eAAe;EAC1B;IACE,SAAS;MACP,CAACC,KAAKC,EAAE,GAAG;QACT,eAAe;QACf,kBAAkB;QAClB,6BAA6B;QAC7B,6BAA6B;MAC/B;IACF;EACF;;;;AFLK,IAAMC,kBAAkBC,aAAaC,MAAM,MAAM;EACtDC,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOC;IACpBC,UAAUC;EACZ,CAAA;EACAN,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOI;IACpBF,UAAU,MAAMG,YAAYC,aAAaC,cAAcC,YAAAA;EACzD,CAAA;EACAX,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOS;IACpBP,UAAUQ;EACZ,CAAA;EACAb,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOW;IACpBT,UAAUU;EACZ,CAAA;CACD;",
6
6
  "names": ["Capabilities", "Events", "contributes", "defineModule", "definePlugin", "lazy", "AppGraphBuilder", "lazy", "ReactSurface", "PresenterSettings", "translations", "meta", "id", "PresenterPlugin", "definePlugin", "meta", "defineModule", "id", "activatesOn", "Events", "SetupSettings", "activate", "PresenterSettings", "SetupTranslations", "contributes", "Capabilities", "Translations", "translations", "SetupReactSurface", "ReactSurface", "SetupAppGraph", "AppGraphBuilder"]
7
7
  }