@dxos/plugin-presenter 0.8.4-main.3eb6e50203 → 0.8.4-main.3fbcb4aa9b

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 (205) hide show
  1. package/dist/lib/neutral/CollectionPresenterContainer-JMX6INMS.mjs +46 -0
  2. package/dist/lib/neutral/CollectionPresenterContainer-JMX6INMS.mjs.map +7 -0
  3. package/dist/lib/neutral/DocumentPresenterContainer-KCDZ2O2C.mjs +24 -0
  4. package/dist/lib/neutral/DocumentPresenterContainer-KCDZ2O2C.mjs.map +7 -0
  5. package/dist/lib/neutral/MarkdownSlide-WXILOIBE.mjs +18 -0
  6. package/dist/lib/neutral/MarkdownSlide-WXILOIBE.mjs.map +7 -0
  7. package/dist/lib/neutral/PresenterPlugin.mjs +23 -0
  8. package/dist/lib/neutral/PresenterPlugin.mjs.map +7 -0
  9. package/dist/lib/neutral/PresenterPlugin.node.mjs +16 -0
  10. package/dist/lib/neutral/PresenterPlugin.node.mjs.map +7 -0
  11. package/dist/lib/neutral/PresenterSettings-2G4XD4QY.mjs +25 -0
  12. package/dist/lib/neutral/PresenterSettings-2G4XD4QY.mjs.map +7 -0
  13. package/dist/lib/{browser/app-graph-builder-OH6QU3DC.mjs → neutral/app-graph-builder-LOVUQ6U5.mjs} +25 -40
  14. package/dist/lib/neutral/app-graph-builder-LOVUQ6U5.mjs.map +7 -0
  15. package/dist/lib/neutral/capabilities/index.mjs +13 -0
  16. package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
  17. package/dist/lib/{browser/chunk-VQVZVXPJ.mjs → neutral/chunk-4XSSDLGN.mjs} +2 -2
  18. package/dist/lib/{browser/chunk-VQVZVXPJ.mjs.map → neutral/chunk-4XSSDLGN.mjs.map} +3 -3
  19. package/dist/lib/neutral/chunk-DCPA267T.mjs +68 -0
  20. package/dist/lib/neutral/chunk-DCPA267T.mjs.map +7 -0
  21. package/dist/lib/neutral/chunk-J5LGTIGS.mjs +10 -0
  22. package/dist/lib/neutral/chunk-J5LGTIGS.mjs.map +7 -0
  23. package/dist/lib/{browser/chunk-46CHA6Y5.mjs → neutral/chunk-V323QBC3.mjs} +8 -8
  24. package/dist/lib/neutral/chunk-V323QBC3.mjs.map +7 -0
  25. package/dist/lib/neutral/components/index.mjs +502 -0
  26. package/dist/lib/neutral/components/index.mjs.map +7 -0
  27. package/dist/lib/neutral/containers/index.mjs +13 -0
  28. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  29. package/dist/lib/neutral/index.mjs +18 -0
  30. package/dist/lib/neutral/index.mjs.map +7 -0
  31. package/dist/lib/neutral/meta.json +1 -0
  32. package/dist/lib/neutral/meta.mjs +8 -0
  33. package/dist/lib/neutral/meta.mjs.map +7 -0
  34. package/dist/lib/neutral/plugin.mjs +12 -0
  35. package/dist/lib/neutral/plugin.mjs.map +7 -0
  36. package/dist/lib/neutral/react-surface-ATYTHPAA.mjs +55 -0
  37. package/dist/lib/neutral/react-surface-ATYTHPAA.mjs.map +7 -0
  38. package/dist/lib/{browser/settings-OLQ7QNLC.mjs → neutral/settings-R6LRDAAK.mjs} +7 -11
  39. package/dist/lib/neutral/settings-R6LRDAAK.mjs.map +7 -0
  40. package/dist/lib/neutral/translations.mjs +19 -0
  41. package/dist/lib/neutral/translations.mjs.map +7 -0
  42. package/dist/lib/neutral/types/index.mjs +14 -0
  43. package/dist/lib/neutral/types/index.mjs.map +7 -0
  44. package/dist/types/src/PresenterPlugin.d.ts +1 -0
  45. package/dist/types/src/PresenterPlugin.d.ts.map +1 -1
  46. package/dist/types/src/PresenterPlugin.node.d.ts +4 -0
  47. package/dist/types/src/PresenterPlugin.node.d.ts.map +1 -0
  48. package/dist/types/src/PresenterPlugin.test.d.ts +2 -0
  49. package/dist/types/src/PresenterPlugin.test.d.ts.map +1 -0
  50. package/dist/types/src/capabilities/app-graph-builder.d.ts +6 -0
  51. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  52. package/dist/types/src/capabilities/index.d.ts +4 -3
  53. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  54. package/dist/types/src/capabilities/react-surface.d.ts +5 -0
  55. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  56. package/dist/types/src/capabilities/settings.d.ts +7 -0
  57. package/dist/types/src/capabilities/settings.d.ts.map +1 -0
  58. package/dist/types/src/components/Markdown/Panel.d.ts +8 -0
  59. package/dist/types/src/components/Markdown/Panel.d.ts.map +1 -0
  60. package/dist/types/src/components/Markdown/{Container.stories.d.ts → Panel.stories.d.ts} +1 -1
  61. package/dist/types/src/components/Markdown/Panel.stories.d.ts.map +1 -0
  62. package/dist/types/src/components/Markdown/Slide.d.ts +1 -1
  63. package/dist/types/src/components/Markdown/Slide.d.ts.map +1 -1
  64. package/dist/types/src/components/Markdown/Slide.stories.d.ts.map +1 -1
  65. package/dist/types/src/components/Markdown/index.d.ts +1 -1
  66. package/dist/types/src/components/Markdown/index.d.ts.map +1 -1
  67. package/dist/types/src/components/Markdown/theme.d.ts.map +1 -1
  68. package/dist/types/src/components/Presenter/Layout.d.ts +5 -5
  69. package/dist/types/src/components/Presenter/Layout.d.ts.map +1 -1
  70. package/dist/types/src/components/Presenter/Pager.d.ts.map +1 -1
  71. package/dist/types/src/components/Presenter/Pager.stories.d.ts.map +1 -1
  72. package/dist/types/src/components/PresenterSettings/PresenterSettings.d.ts +6 -0
  73. package/dist/types/src/components/PresenterSettings/PresenterSettings.d.ts.map +1 -0
  74. package/dist/types/src/components/PresenterSettings/PresenterSettings.stories.d.ts +23 -0
  75. package/dist/types/src/components/PresenterSettings/PresenterSettings.stories.d.ts.map +1 -0
  76. package/dist/types/src/components/PresenterSettings/index.d.ts +2 -0
  77. package/dist/types/src/components/PresenterSettings/index.d.ts.map +1 -0
  78. package/dist/types/src/components/RevealPlayer/RevealPlayer.d.ts +5 -4
  79. package/dist/types/src/components/RevealPlayer/RevealPlayer.d.ts.map +1 -1
  80. package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts +7 -6
  81. package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts.map +1 -1
  82. package/dist/types/src/components/index.d.ts +5 -28
  83. package/dist/types/src/components/index.d.ts.map +1 -1
  84. package/dist/types/src/containers/CollectionPresenterContainer/CollectionPresenterContainer.d.ts +6 -0
  85. package/dist/types/src/containers/CollectionPresenterContainer/CollectionPresenterContainer.d.ts.map +1 -0
  86. package/dist/types/src/containers/CollectionPresenterContainer/index.d.ts +2 -0
  87. package/dist/types/src/containers/CollectionPresenterContainer/index.d.ts.map +1 -0
  88. package/dist/types/src/containers/DocumentPresenterContainer/DocumentPresenterContainer.d.ts +6 -0
  89. package/dist/types/src/containers/DocumentPresenterContainer/DocumentPresenterContainer.d.ts.map +1 -0
  90. package/dist/types/src/containers/DocumentPresenterContainer/index.d.ts +2 -0
  91. package/dist/types/src/containers/DocumentPresenterContainer/index.d.ts.map +1 -0
  92. package/dist/types/src/containers/MarkdownSlide/MarkdownSlide.d.ts +8 -0
  93. package/dist/types/src/containers/MarkdownSlide/MarkdownSlide.d.ts.map +1 -0
  94. package/dist/types/src/containers/MarkdownSlide/index.d.ts +2 -0
  95. package/dist/types/src/containers/MarkdownSlide/index.d.ts.map +1 -0
  96. package/dist/types/src/containers/index.d.ts +5 -0
  97. package/dist/types/src/containers/index.d.ts.map +1 -0
  98. package/dist/types/src/index.d.ts +1 -2
  99. package/dist/types/src/index.d.ts.map +1 -1
  100. package/dist/types/src/plugin.d.ts +3 -0
  101. package/dist/types/src/plugin.d.ts.map +1 -0
  102. package/dist/types/src/testing.d.ts.map +1 -1
  103. package/dist/types/src/translations.d.ts +4 -6
  104. package/dist/types/src/translations.d.ts.map +1 -1
  105. package/dist/types/src/types/PresenterCapabilities.d.ts +4 -0
  106. package/dist/types/src/types/PresenterCapabilities.d.ts.map +1 -0
  107. package/dist/types/src/types/PresenterOperation.d.ts +17 -0
  108. package/dist/types/src/types/PresenterOperation.d.ts.map +1 -0
  109. package/dist/types/src/types/Settings.d.ts +7 -0
  110. package/dist/types/src/types/Settings.d.ts.map +1 -0
  111. package/dist/types/src/types/index.d.ts +11 -0
  112. package/dist/types/src/types/index.d.ts.map +1 -0
  113. package/dist/types/src/useExitPresenter.d.ts +1 -1
  114. package/dist/types/src/useExitPresenter.d.ts.map +1 -1
  115. package/dist/types/tsconfig.tsbuildinfo +1 -1
  116. package/package.json +85 -34
  117. package/src/PresenterPlugin.node.ts +16 -0
  118. package/src/PresenterPlugin.test.ts +23 -0
  119. package/src/PresenterPlugin.tsx +5 -3
  120. package/src/capabilities/{app-graph-builder/app-graph-builder.ts → app-graph-builder.ts} +24 -27
  121. package/src/capabilities/index.ts +5 -3
  122. package/src/capabilities/react-surface.tsx +68 -0
  123. package/src/capabilities/{settings/settings.ts → settings.ts} +4 -4
  124. package/src/components/Markdown/{Container.stories.tsx → Panel.stories.tsx} +7 -7
  125. package/src/components/Markdown/{Container.tsx → Panel.tsx} +5 -5
  126. package/src/components/Markdown/Slide.stories.tsx +4 -4
  127. package/src/components/Markdown/Slide.tsx +2 -2
  128. package/src/components/Markdown/index.ts +1 -1
  129. package/src/components/Markdown/theme.ts +6 -6
  130. package/src/components/Presenter/Layout.tsx +24 -23
  131. package/src/components/Presenter/Pager.stories.tsx +1 -1
  132. package/src/components/PresenterSettings/PresenterSettings.stories.tsx +32 -0
  133. package/src/components/PresenterSettings/PresenterSettings.tsx +31 -0
  134. package/src/components/PresenterSettings/index.ts +5 -0
  135. package/src/components/RevealPlayer/RevealPlayer.stories.tsx +5 -5
  136. package/src/components/RevealPlayer/RevealPlayer.tsx +104 -105
  137. package/src/components/index.ts +5 -5
  138. package/src/containers/CollectionPresenterContainer/CollectionPresenterContainer.tsx +50 -0
  139. package/src/containers/CollectionPresenterContainer/index.ts +5 -0
  140. package/src/containers/DocumentPresenterContainer/DocumentPresenterContainer.tsx +24 -0
  141. package/src/containers/DocumentPresenterContainer/index.ts +5 -0
  142. package/src/{components → containers/MarkdownSlide}/MarkdownSlide.tsx +5 -7
  143. package/src/containers/MarkdownSlide/index.ts +5 -0
  144. package/src/containers/index.ts +9 -0
  145. package/src/index.ts +1 -3
  146. package/src/meta.ts +1 -1
  147. package/src/plugin.ts +9 -0
  148. package/src/testing.ts +6 -6
  149. package/src/translations.ts +4 -5
  150. package/src/types/PresenterCapabilities.ts +15 -0
  151. package/src/types/PresenterOperation.ts +25 -0
  152. package/src/types/Settings.ts +20 -0
  153. package/src/types/index.ts +21 -0
  154. package/src/useExitPresenter.ts +9 -8
  155. package/dist/lib/browser/CollectionPresenterContainer-WE7HOMFY.mjs +0 -176
  156. package/dist/lib/browser/CollectionPresenterContainer-WE7HOMFY.mjs.map +0 -7
  157. package/dist/lib/browser/DocumentPresenterContainer-3BU2DS5E.mjs +0 -173
  158. package/dist/lib/browser/DocumentPresenterContainer-3BU2DS5E.mjs.map +0 -7
  159. package/dist/lib/browser/MarkdownSlide-GIYJABHE.mjs +0 -200
  160. package/dist/lib/browser/MarkdownSlide-GIYJABHE.mjs.map +0 -7
  161. package/dist/lib/browser/app-graph-builder-OH6QU3DC.mjs.map +0 -7
  162. package/dist/lib/browser/chunk-46CHA6Y5.mjs.map +0 -7
  163. package/dist/lib/browser/chunk-4PZXJXBO.mjs +0 -50
  164. package/dist/lib/browser/chunk-4PZXJXBO.mjs.map +0 -7
  165. package/dist/lib/browser/chunk-L7QYO6LF.mjs +0 -38
  166. package/dist/lib/browser/chunk-L7QYO6LF.mjs.map +0 -7
  167. package/dist/lib/browser/index.mjs +0 -59
  168. package/dist/lib/browser/index.mjs.map +0 -7
  169. package/dist/lib/browser/meta.json +0 -1
  170. package/dist/lib/browser/react-surface-QY4ETW6S.mjs +0 -64
  171. package/dist/lib/browser/react-surface-QY4ETW6S.mjs.map +0 -7
  172. package/dist/lib/browser/settings-OLQ7QNLC.mjs.map +0 -7
  173. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts +0 -6
  174. package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +0 -1
  175. package/dist/types/src/capabilities/app-graph-builder/index.d.ts +0 -3
  176. package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +0 -1
  177. package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
  178. package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
  179. package/dist/types/src/capabilities/react-surface/react-surface.d.ts +0 -5
  180. package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
  181. package/dist/types/src/capabilities/settings/index.d.ts +0 -7
  182. package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
  183. package/dist/types/src/capabilities/settings/settings.d.ts +0 -10
  184. package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
  185. package/dist/types/src/components/CollectionPresenterContainer.d.ts +0 -7
  186. package/dist/types/src/components/CollectionPresenterContainer.d.ts.map +0 -1
  187. package/dist/types/src/components/DocumentPresenterContainer.d.ts +0 -7
  188. package/dist/types/src/components/DocumentPresenterContainer.d.ts.map +0 -1
  189. package/dist/types/src/components/Markdown/Container.d.ts +0 -8
  190. package/dist/types/src/components/Markdown/Container.d.ts.map +0 -1
  191. package/dist/types/src/components/Markdown/Container.stories.d.ts.map +0 -1
  192. package/dist/types/src/components/MarkdownSlide.d.ts +0 -8
  193. package/dist/types/src/components/MarkdownSlide.d.ts.map +0 -1
  194. package/dist/types/src/components/PresenterSettings.d.ts +0 -8
  195. package/dist/types/src/components/PresenterSettings.d.ts.map +0 -1
  196. package/dist/types/src/types.d.ts +0 -49
  197. package/dist/types/src/types.d.ts.map +0 -1
  198. package/src/capabilities/app-graph-builder/index.ts +0 -7
  199. package/src/capabilities/react-surface/index.ts +0 -7
  200. package/src/capabilities/react-surface/react-surface.tsx +0 -71
  201. package/src/capabilities/settings/index.ts +0 -7
  202. package/src/components/CollectionPresenterContainer.tsx +0 -44
  203. package/src/components/DocumentPresenterContainer.tsx +0 -23
  204. package/src/components/PresenterSettings.tsx +0 -35
  205. package/src/types.ts +0 -54
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxos/plugin-presenter",
3
- "version": "0.8.4-main.3eb6e50203",
3
+ "version": "0.8.4-main.3fbcb4aa9b",
4
4
  "description": "Braneframe presenter plugin",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
@@ -12,17 +12,66 @@
12
12
  "author": "DXOS.org",
13
13
  "sideEffects": true,
14
14
  "type": "module",
15
+ "imports": {
16
+ "#capabilities": {
17
+ "source": "./src/capabilities/index.ts",
18
+ "types": "./dist/types/src/capabilities/index.d.ts",
19
+ "default": "./dist/lib/neutral/capabilities/index.mjs"
20
+ },
21
+ "#components": {
22
+ "source": "./src/components/index.ts",
23
+ "types": "./dist/types/src/components/index.d.ts",
24
+ "default": "./dist/lib/neutral/components/index.mjs"
25
+ },
26
+ "#containers": {
27
+ "source": "./src/containers/index.ts",
28
+ "types": "./dist/types/src/containers/index.d.ts",
29
+ "default": "./dist/lib/neutral/containers/index.mjs"
30
+ },
31
+ "#meta": {
32
+ "source": "./src/meta.ts",
33
+ "types": "./dist/types/src/meta.d.ts",
34
+ "default": "./dist/lib/neutral/meta.mjs"
35
+ },
36
+ "#plugin": {
37
+ "source": {
38
+ "node": "./src/PresenterPlugin.node.ts",
39
+ "default": "./src/PresenterPlugin.tsx"
40
+ },
41
+ "types": "./dist/types/src/PresenterPlugin.d.ts",
42
+ "node": "./dist/lib/neutral/PresenterPlugin.node.mjs",
43
+ "default": "./dist/lib/neutral/PresenterPlugin.mjs"
44
+ },
45
+ "#testing": "./src/testing.ts",
46
+ "#translations": {
47
+ "source": "./src/translations.ts",
48
+ "types": "./dist/types/src/translations.d.ts",
49
+ "default": "./dist/lib/neutral/translations.mjs"
50
+ },
51
+ "#types": {
52
+ "source": "./src/types/index.ts",
53
+ "types": "./dist/types/src/types/index.d.ts",
54
+ "default": "./dist/lib/neutral/types/index.mjs"
55
+ }
56
+ },
15
57
  "exports": {
16
58
  ".": {
17
- "browser": "./dist/lib/browser/index.mjs",
18
59
  "source": "./src/index.ts",
19
- "types": "./dist/types/src/index.d.ts"
60
+ "types": "./dist/types/src/index.d.ts",
61
+ "default": "./dist/lib/neutral/index.mjs"
62
+ },
63
+ "./plugin": {
64
+ "source": "./src/plugin.ts",
65
+ "types": "./dist/types/src/plugin.d.ts",
66
+ "default": "./dist/lib/neutral/plugin.mjs"
67
+ },
68
+ "./translations": {
69
+ "source": "./src/translations.ts",
70
+ "types": "./dist/types/src/translations.d.ts",
71
+ "default": "./dist/lib/neutral/translations.mjs"
20
72
  }
21
73
  },
22
74
  "types": "dist/types/src/index.d.ts",
23
- "typesVersions": {
24
- "*": {}
25
- },
26
75
  "files": [
27
76
  "dist",
28
77
  "src"
@@ -40,25 +89,26 @@
40
89
  "remark-frontmatter": "^5.0.0",
41
90
  "remark-parse-frontmatter": "^1.0.3",
42
91
  "reveal.js": "^5.1.0",
43
- "@dxos/app-toolkit": "0.8.4-main.3eb6e50203",
44
- "@dxos/echo": "0.8.4-main.3eb6e50203",
45
- "@dxos/effect": "0.8.4-main.3eb6e50203",
46
- "@dxos/log": "0.8.4-main.3eb6e50203",
47
- "@dxos/app-framework": "0.8.4-main.3eb6e50203",
48
- "@dxos/operation": "0.8.4-main.3eb6e50203",
49
- "@dxos/plugin-deck": "0.8.4-main.3eb6e50203",
50
- "@dxos/plugin-markdown": "0.8.4-main.3eb6e50203",
51
- "@dxos/plugin-client": "0.8.4-main.3eb6e50203",
52
- "@dxos/plugin-graph": "0.8.4-main.3eb6e50203",
53
- "@dxos/react-client": "0.8.4-main.3eb6e50203",
54
- "@dxos/plugin-stack": "0.8.4-main.3eb6e50203",
55
- "@dxos/react-ui-form": "0.8.4-main.3eb6e50203",
56
- "@dxos/react-ui-stack": "0.8.4-main.3eb6e50203",
57
- "@dxos/react-ui-mosaic": "0.8.4-main.3eb6e50203",
58
- "@dxos/async": "0.8.4-main.3eb6e50203",
59
- "@dxos/types": "0.8.4-main.3eb6e50203",
60
- "@dxos/schema": "0.8.4-main.3eb6e50203",
61
- "@dxos/util": "0.8.4-main.3eb6e50203"
92
+ "@dxos/app-framework": "0.8.4-main.3fbcb4aa9b",
93
+ "@dxos/echo": "0.8.4-main.3fbcb4aa9b",
94
+ "@dxos/async": "0.8.4-main.3fbcb4aa9b",
95
+ "@dxos/compute": "0.8.4-main.3fbcb4aa9b",
96
+ "@dxos/app-toolkit": "0.8.4-main.3fbcb4aa9b",
97
+ "@dxos/effect": "0.8.4-main.3fbcb4aa9b",
98
+ "@dxos/log": "0.8.4-main.3fbcb4aa9b",
99
+ "@dxos/plugin-client": "0.8.4-main.3fbcb4aa9b",
100
+ "@dxos/plugin-deck": "0.8.4-main.3fbcb4aa9b",
101
+ "@dxos/plugin-graph": "0.8.4-main.3fbcb4aa9b",
102
+ "@dxos/plugin-markdown": "0.8.4-main.3fbcb4aa9b",
103
+ "@dxos/react-client": "0.8.4-main.3fbcb4aa9b",
104
+ "@dxos/plugin-stack": "0.8.4-main.3fbcb4aa9b",
105
+ "@dxos/react-ui-attention": "0.8.4-main.3fbcb4aa9b",
106
+ "@dxos/react-ui-mosaic": "0.8.4-main.3fbcb4aa9b",
107
+ "@dxos/types": "0.8.4-main.3fbcb4aa9b",
108
+ "@dxos/react-ui-form": "0.8.4-main.3fbcb4aa9b",
109
+ "@dxos/react-ui-stack": "0.8.4-main.3fbcb4aa9b",
110
+ "@dxos/util": "0.8.4-main.3fbcb4aa9b",
111
+ "@dxos/schema": "0.8.4-main.3fbcb4aa9b"
62
112
  },
63
113
  "devDependencies": {
64
114
  "@effect-atom/atom-react": "^0.5.0",
@@ -66,23 +116,24 @@
66
116
  "@types/react": "~19.2.7",
67
117
  "@types/react-dom": "~19.2.3",
68
118
  "@types/reveal.js": "^5.0.3",
69
- "effect": "3.19.16",
119
+ "effect": "3.20.0",
70
120
  "react": "~19.2.3",
71
121
  "react-dom": "~19.2.3",
72
- "vite": "7.1.9",
73
- "@dxos/random": "0.8.4-main.3eb6e50203",
74
- "@dxos/react-ui": "0.8.4-main.3eb6e50203",
75
- "@dxos/storybook-utils": "0.8.4-main.3eb6e50203",
76
- "@dxos/ui-theme": "0.8.4-main.3eb6e50203"
122
+ "vite": "^8.0.10",
123
+ "@dxos/plugin-testing": "0.8.4-main.3fbcb4aa9b",
124
+ "@dxos/random": "0.8.4-main.3fbcb4aa9b",
125
+ "@dxos/react-ui": "0.8.4-main.3fbcb4aa9b",
126
+ "@dxos/storybook-utils": "0.8.4-main.3fbcb4aa9b",
127
+ "@dxos/ui-theme": "0.8.4-main.3fbcb4aa9b"
77
128
  },
78
129
  "peerDependencies": {
79
130
  "@effect-atom/atom-react": "^0.5.0",
80
131
  "@effect/platform": "0.94.4",
81
- "effect": "3.19.16",
132
+ "effect": "3.20.0",
82
133
  "react": "~19.2.3",
83
134
  "react-dom": "~19.2.3",
84
- "@dxos/react-ui": "0.8.4-main.3eb6e50203",
85
- "@dxos/ui-theme": "0.8.4-main.3eb6e50203"
135
+ "@dxos/react-ui": "0.8.4-main.3fbcb4aa9b",
136
+ "@dxos/ui-theme": "0.8.4-main.3fbcb4aa9b"
86
137
  },
87
138
  "publishConfig": {
88
139
  "access": "public"
@@ -0,0 +1,16 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { Plugin } from '@dxos/app-framework';
6
+ import { AppPlugin } from '@dxos/app-toolkit';
7
+
8
+ import { AppGraphBuilder } from '#capabilities';
9
+ import { meta } from '#meta';
10
+
11
+ export const PresenterPlugin = Plugin.define(meta).pipe(
12
+ AppPlugin.addAppGraphModule({ activate: AppGraphBuilder }),
13
+ Plugin.make,
14
+ );
15
+
16
+ export default PresenterPlugin;
@@ -0,0 +1,23 @@
1
+ //
2
+ // Copyright 2026 DXOS.org
3
+ //
4
+
5
+ import { describe, test } from 'vitest';
6
+
7
+ import { createComposerTestApp } from '@dxos/plugin-testing/harness';
8
+
9
+ import { PresenterPlugin } from '#plugin';
10
+
11
+ import { meta } from './meta';
12
+
13
+ const moduleId = (name: string) => `${meta.id}.module.${name}`;
14
+
15
+ describe('PresenterPlugin', () => {
16
+ test('modules activate on the expected events', async ({ expect }) => {
17
+ await using harness = await createComposerTestApp({
18
+ plugins: [PresenterPlugin()],
19
+ });
20
+
21
+ expect(harness.manager.getActive()).toContain(moduleId('AppGraphBuilder'));
22
+ });
23
+ });
@@ -5,9 +5,9 @@
5
5
  import { Plugin } from '@dxos/app-framework';
6
6
  import { AppPlugin } from '@dxos/app-toolkit';
7
7
 
8
- import { AppGraphBuilder, PresenterSettings, ReactSurface } from './capabilities';
9
- import { meta } from './meta';
10
- import { translations } from './translations';
8
+ import { AppGraphBuilder, PresenterSettings, ReactSurface } from '#capabilities';
9
+ import { meta } from '#meta';
10
+ import { translations } from '#translations';
11
11
 
12
12
  // TODO(burdon): Only scale markdown content.
13
13
  // TODO(burdon): Map stack content; Slide content type (e.g., markdown, sketch, IPFS image, table, etc.)
@@ -19,3 +19,5 @@ export const PresenterPlugin = Plugin.define(meta).pipe(
19
19
  AppPlugin.addTranslationsModule({ translations }),
20
20
  Plugin.make,
21
21
  );
22
+
23
+ export default PresenterPlugin;
@@ -6,17 +6,18 @@ import * as Effect from 'effect/Effect';
6
6
  import * as Option from 'effect/Option';
7
7
 
8
8
  import { Capabilities, Capability } from '@dxos/app-framework';
9
- import { AppCapabilities, LayoutOperation } from '@dxos/app-toolkit';
9
+ import { AppCapabilities, AppNode, LayoutOperation, getObjectPathFromObject, getSpacePath } from '@dxos/app-toolkit';
10
+ import { Operation } from '@dxos/compute';
10
11
  import { Obj } from '@dxos/echo';
11
- import { Operation } from '@dxos/operation';
12
- import { DeckCapabilities } from '@dxos/plugin-deck';
13
- import { ATTENDABLE_PATH_SEPARATOR, DeckOperation } from '@dxos/plugin-deck/types';
12
+ import { Collection } from '@dxos/echo';
13
+ import { DeckCapabilities, DeckOperation } from '@dxos/plugin-deck';
14
14
  import { GraphBuilder, type Node, NodeMatcher } from '@dxos/plugin-graph';
15
- import { Markdown } from '@dxos/plugin-markdown/types';
16
- import { Collection } from '@dxos/schema';
15
+ import { Markdown } from '@dxos/plugin-markdown';
16
+ import { linkedSegment } from '@dxos/react-ui-attention';
17
17
 
18
- import { meta } from '../../meta';
19
- import { PresenterCapabilities, PresenterOperation } from '../../types';
18
+ import { meta } from '#meta';
19
+ import { PresenterOperation } from '#types';
20
+ import { PresenterCapabilities } from '#types';
20
21
 
21
22
  /** Match nodes that can be presented (Collection or Document). */
22
23
  const whenPresentable = (node: Node.Node) =>
@@ -29,7 +30,7 @@ export default Capability.makeModule(
29
30
  const capabilities = yield* Capability.Service;
30
31
 
31
32
  const extensions = yield* GraphBuilder.createExtension({
32
- id: `${meta.id}/root`,
33
+ id: 'root',
33
34
  // TODO(wittjosiah): This is a hack to work around presenter previously relying on "variant". Remove.
34
35
  match: whenPresentable,
35
36
  connector: (object, get) => {
@@ -41,18 +42,14 @@ export default Capability.makeModule(
41
42
  if (!isPresentable) {
42
43
  return Effect.succeed([]);
43
44
  }
44
- const id = Obj.getDXN(object).toString();
45
+
45
46
  return Effect.succeed([
46
- {
47
- id: [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR),
47
+ AppNode.makeCompanion({
48
+ id: linkedSegment('presenter'),
49
+ label: 'Presenter',
50
+ icon: 'ph--presentation--regular',
48
51
  data: { type: meta.id, object },
49
- type: meta.id,
50
- properties: {
51
- label: 'Presenter',
52
- icon: 'ph--presentation--regular',
53
- disposition: 'hidden',
54
- },
55
- },
52
+ }),
56
53
  ]);
57
54
  },
58
55
  actions: (object, get) => {
@@ -61,21 +58,21 @@ export default Capability.makeModule(
61
58
  const isPresentable = settings?.presentCollections
62
59
  ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object)
63
60
  : Obj.instanceOf(Markdown.Document, object);
64
- if (!isPresentable) {
61
+ const db = Obj.getDatabase(object);
62
+ if (!isPresentable || !db) {
65
63
  return Effect.succeed([]);
66
64
  }
67
- const dxn = Obj.getDXN(object);
68
- const id = dxn.toString();
69
- const { spaceId } = dxn.asEchoDXN()!;
65
+ const objectPath = getObjectPathFromObject(object);
66
+
70
67
  return Effect.succeed([
71
68
  {
72
- id: `${PresenterOperation.TogglePresentation.meta.key}/${id}`,
69
+ id: PresenterOperation.TogglePresentation.meta.key,
73
70
  // TODO(burdon): Allow function so can generate state when activated.
74
71
  // So can set explicit fullscreen state coordinated with current presenter state.
75
72
  data: Effect.fnUntraced(function* () {
76
73
  const deckState = yield* Capabilities.getAtomValue(DeckCapabilities.State);
77
74
  const deck = deckState.decks[deckState.activeDeck];
78
- const presenterId = [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR);
75
+ const presenterId = `${objectPath}/${linkedSegment('presenter')}`;
79
76
  if (!deck?.fullscreen) {
80
77
  yield* Operation.invoke(DeckOperation.Adjust, {
81
78
  type: 'solo--fullscreen' as const,
@@ -84,11 +81,11 @@ export default Capability.makeModule(
84
81
  }
85
82
  yield* Operation.invoke(LayoutOperation.Open, {
86
83
  subject: [presenterId],
87
- workspace: spaceId,
84
+ workspace: getSpacePath(db.spaceId),
88
85
  });
89
86
  }),
90
87
  properties: {
91
- label: ['toggle presentation label', { ns: meta.id }],
88
+ label: ['toggle-presentation.label', { ns: meta.id }],
92
89
  icon: 'ph--presentation--regular',
93
90
  disposition: 'list-item',
94
91
  keyBinding: {
@@ -2,6 +2,8 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- export * from './app-graph-builder';
6
- export * from './react-surface';
7
- export * from './settings';
5
+ import { Capability } from '@dxos/app-framework';
6
+
7
+ export const AppGraphBuilder = Capability.lazy('AppGraphBuilder', () => import('./app-graph-builder'));
8
+ export const ReactSurface = Capability.lazy('ReactSurface', () => import('./react-surface'));
9
+ export const PresenterSettings = Capability.lazy('PresenterSettings', () => import('./settings'));
@@ -0,0 +1,68 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import * as Effect from 'effect/Effect';
6
+ import React from 'react';
7
+
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
+ import { Surface, useSettingsState } from '@dxos/app-framework/ui';
10
+ import { AppSurface } from '@dxos/app-toolkit/ui';
11
+ import { Obj } from '@dxos/echo';
12
+ import { Collection } from '@dxos/echo';
13
+ import { Markdown } from '@dxos/plugin-markdown';
14
+
15
+ import { PresenterSettings } from '#components';
16
+ import { CollectionPresenterContainer, DocumentPresenterContainer, MarkdownSlide } from '#containers';
17
+ import { meta } from '#meta';
18
+ import { type Settings } from '#types';
19
+
20
+ export default Capability.makeModule(() =>
21
+ Effect.succeed(
22
+ Capability.contributes(Capabilities.ReactSurface, [
23
+ Surface.create({
24
+ id: 'document',
25
+ position: 'hoist',
26
+ filter: AppSurface.predicate(
27
+ AppSurface.Article,
28
+ (data): data is AppSurface.ArticleData<{ type: typeof meta.id; object: Markdown.Document }> =>
29
+ !!data.subject &&
30
+ typeof data.subject === 'object' &&
31
+ 'type' in data.subject &&
32
+ 'object' in data.subject &&
33
+ data.subject.type === meta.id &&
34
+ Obj.instanceOf(Markdown.Document, data.subject.object),
35
+ ),
36
+ component: ({ data }) => <DocumentPresenterContainer document={data.subject.object} />,
37
+ }),
38
+ Surface.create({
39
+ id: 'collection',
40
+ position: 'hoist',
41
+ filter: AppSurface.predicate(
42
+ AppSurface.Article,
43
+ (data): data is AppSurface.ArticleData<{ type: typeof meta.id; object: Collection.Collection }> =>
44
+ !!data.subject &&
45
+ typeof data.subject === 'object' &&
46
+ 'type' in data.subject &&
47
+ 'object' in data.subject &&
48
+ data.subject.type === meta.id &&
49
+ Obj.instanceOf(Collection.Collection, data.subject.object),
50
+ ),
51
+ component: ({ role, data }) => <CollectionPresenterContainer role={role} subject={data.subject.object} />,
52
+ }),
53
+ Surface.create({
54
+ id: 'slide',
55
+ filter: AppSurface.object(AppSurface.Slide, Markdown.Document),
56
+ component: ({ data }) => <MarkdownSlide document={data.subject} />,
57
+ }),
58
+ Surface.create({
59
+ id: 'plugin-settings',
60
+ filter: AppSurface.settings(AppSurface.Article, meta.id),
61
+ component: ({ data: { subject } }) => {
62
+ const { settings, updateSettings } = useSettingsState<Settings.Settings>(subject.atom);
63
+ return <PresenterSettings settings={settings} onSettingsChange={updateSettings} />;
64
+ },
65
+ }),
66
+ ]),
67
+ ),
68
+ );
@@ -8,14 +8,14 @@ import { Capability } from '@dxos/app-framework';
8
8
  import { AppCapabilities } from '@dxos/app-toolkit';
9
9
  import { createKvsStore } from '@dxos/effect';
10
10
 
11
- import { meta } from '../../meta';
12
- import { PresenterCapabilities, PresenterSettingsSchema } from '../../types';
11
+ import { meta } from '#meta';
12
+ import { PresenterCapabilities, Settings } from '#types';
13
13
 
14
14
  export default Capability.makeModule(() =>
15
15
  Effect.sync(() => {
16
16
  const settingsAtom = createKvsStore({
17
17
  key: meta.id,
18
- schema: PresenterSettingsSchema,
18
+ schema: Settings.Settings,
19
19
  defaultValue: () => ({}),
20
20
  });
21
21
 
@@ -23,7 +23,7 @@ export default Capability.makeModule(() =>
23
23
  Capability.contributes(PresenterCapabilities.Settings, settingsAtom),
24
24
  Capability.contributes(AppCapabilities.Settings, {
25
25
  prefix: meta.id,
26
- schema: PresenterSettingsSchema,
26
+ schema: Settings.Settings,
27
27
  atom: settingsAtom,
28
28
  }),
29
29
  ];
@@ -5,25 +5,25 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
  import React from 'react';
7
7
 
8
- import { withTheme } from '@dxos/react-ui/testing';
8
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
9
9
 
10
- import { createSlide } from '../../testing';
10
+ import { createSlide } from '#testing';
11
11
 
12
- import { Container } from './Container';
12
+ import { Panel } from './Panel';
13
13
  import { Slide, type SlideProps } from './Slide';
14
14
 
15
15
  const DefaultStory = ({ content = '' }: SlideProps) => {
16
16
  return (
17
- <Container classNames='bg-neutral-200'>
17
+ <Panel classNames='bg-neutral-200'>
18
18
  <Slide content={content} />
19
- </Container>
19
+ </Panel>
20
20
  );
21
21
  };
22
22
 
23
23
  const meta = {
24
- title: 'plugins/plugin-presenter/Container',
24
+ title: 'plugins/plugin-presenter/components/Panel',
25
25
  render: DefaultStory,
26
- decorators: [withTheme()],
26
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
27
27
  parameters: {
28
28
  layout: 'fullscreen',
29
29
  },
@@ -8,12 +8,12 @@ import { useResizeDetector } from 'react-resize-detector';
8
8
  import { type ThemedClassName } from '@dxos/react-ui';
9
9
  import { mx } from '@dxos/ui-theme';
10
10
 
11
- export type ContainerProps = ThemedClassName<PropsWithChildren<{}>>;
11
+ export type PanelProps = ThemedClassName<PropsWithChildren<{}>>;
12
12
 
13
13
  /**
14
- * Scaled markdown container.
14
+ * Scaled markdown panel.
15
15
  */
16
- export const Container = ({ children, classNames }: ContainerProps) => {
16
+ export const Panel = ({ children, classNames }: PanelProps) => {
17
17
  const [props, setProps] = useState({});
18
18
  const {
19
19
  ref: containerRef,
@@ -35,8 +35,8 @@ export const Container = ({ children, classNames }: ContainerProps) => {
35
35
  // TODO(burdon): Reconcile highlight colors with markdown editor.
36
36
  // https://www.npmjs.com/package/react-markdown
37
37
  return (
38
- <div ref={containerRef} className={mx('flex grow relative overflow-hidden bg-attention', classNames)}>
39
- <div className={mx('flex is-full bs-full overflow-hidden absolute')} style={props}>
38
+ <div ref={containerRef} className={mx('flex grow relative overflow-hidden bg-attention-surface', classNames)}>
39
+ <div className={mx('dx-container absolute')} style={props}>
40
40
  {width && height && children}
41
41
  </div>
42
42
  </div>
@@ -4,16 +4,16 @@
4
4
 
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
 
7
- import { withTheme } from '@dxos/react-ui/testing';
7
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
8
8
 
9
- import { createSlide } from '../../testing';
9
+ import { createSlide } from '#testing';
10
10
 
11
11
  import { Slide } from './Slide';
12
12
 
13
13
  const meta = {
14
- title: 'plugins/plugin-presenter/Slide',
14
+ title: 'plugins/plugin-presenter/components/Slide',
15
15
  component: Slide,
16
- decorators: [withTheme()],
16
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' })],
17
17
  parameters: {
18
18
  layout: 'fullscreen',
19
19
  },
@@ -2,6 +2,8 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
+ import 'highlight.js/styles/github.css';
6
+
5
7
  import { h } from 'hastscript';
6
8
  import React from 'react';
7
9
  import ReactMarkdown, { type Options as ReactMarkdownOptions } from 'react-markdown';
@@ -10,8 +12,6 @@ import rehypeHighlight from 'rehype-highlight';
10
12
  import remarkFrontmatter from 'remark-frontmatter';
11
13
  import remarkParseFrontmatter from 'remark-parse-frontmatter';
12
14
 
13
- import 'highlight.js/styles/github.css';
14
-
15
15
  import styles from './styles.css?raw';
16
16
  import { theme } from './theme';
17
17
 
@@ -2,5 +2,5 @@
2
2
  // Copyright 2022 DXOS.org
3
3
  //
4
4
 
5
- export * from './Container';
5
+ export * from './Panel';
6
6
  export * from './Slide';
@@ -5,14 +5,14 @@
5
5
  // TODO(burdon): Create theme type and picker.
6
6
 
7
7
  export const theme = {
8
- root: 'bg-attention leading-relaxed font-mono',
8
+ root: 'bg-attention-surface leading-relaxed font-mono',
9
9
 
10
- padding: 'pli-40 plb-16 gap-8',
10
+ padding: 'px-40 py-16 gap-8',
11
11
 
12
12
  nodes: {
13
- h1: 'text-[80px] text-accentText',
14
- h2: 'text-[60px] text-accentText',
15
- h3: 'text-[48px] text-accentText',
13
+ h1: 'text-[80px] text-accent-text',
14
+ h2: 'text-[60px] text-accent-text',
15
+ h3: 'text-[48px] text-accent-text',
16
16
 
17
17
  p: 'text-[48px]',
18
18
 
@@ -20,7 +20,7 @@ export const theme = {
20
20
  ol: 'my-[16px] ml-24 leading-relaxed list-decimal',
21
21
  li: 'pl-6 text-[48px]',
22
22
 
23
- pre: 'is-full mx-0 my-[32px] p-0 __border-l-[16px] bg-inputSurface p-4 __whitespace-pre-line',
23
+ pre: 'w-full mx-0 my-[32px] p-4 bg-input-surface',
24
24
  code: 'p-0 text-[40px]',
25
25
  },
26
26
  };
@@ -4,30 +4,31 @@
4
4
 
5
5
  import React, { type PropsWithChildren, type ReactNode } from 'react';
6
6
 
7
- import { type ThemedClassName } from '@dxos/react-ui';
8
- import { mx } from '@dxos/ui-theme';
7
+ import { composable, composableProps } from '@dxos/ui-theme';
9
8
 
10
- export type LayoutProps = ThemedClassName<
11
- PropsWithChildren<{
12
- className?: string;
13
- topLeft?: ReactNode;
14
- topRight?: ReactNode;
15
- bottomLeft?: ReactNode;
16
- bottomRight?: ReactNode;
17
- }>
18
- >;
9
+ export type LayoutProps = PropsWithChildren<{
10
+ topLeft?: ReactNode;
11
+ topRight?: ReactNode;
12
+ bottomLeft?: ReactNode;
13
+ bottomRight?: ReactNode;
14
+ }>;
19
15
 
20
- export const Layout = ({ children, classNames, topLeft, topRight, bottomLeft, bottomRight }: LayoutProps) => {
21
- return (
22
- <div className={mx('flex grow relative overflow-hidden bg-attention', classNames)}>
23
- <div className={mx('flex flex-col grow overflow-hidden')}>{children}</div>
16
+ export const Layout = composable<HTMLDivElement, LayoutProps>(
17
+ ({ children, topLeft, topRight, bottomLeft, bottomRight, ...props }, forwardedRef) => {
18
+ return (
19
+ <div
20
+ {...composableProps(props, { classNames: 'flex grow relative overflow-hidden bg-attention-surface' })}
21
+ ref={forwardedRef}
22
+ >
23
+ <div className='flex flex-col grow overflow-hidden'>{children}</div>
24
24
 
25
- <div className='z-[200]'>
26
- <div className='absolute top-4 left-4'>{topLeft}</div>
27
- <div className='absolute top-4 right-4'>{topRight}</div>
28
- <div className='absolute bottom-4 left-4'>{bottomLeft}</div>
29
- <div className='absolute bottom-4 right-4'>{bottomRight}</div>
25
+ <div className='z-[200]'>
26
+ <div className='absolute top-4 left-4'>{topLeft}</div>
27
+ <div className='absolute top-4 right-4'>{topRight}</div>
28
+ <div className='absolute bottom-4 left-4'>{bottomLeft}</div>
29
+ <div className='absolute bottom-4 right-4'>{bottomRight}</div>
30
+ </div>
30
31
  </div>
31
- </div>
32
- );
33
- };
32
+ );
33
+ },
34
+ );
@@ -23,7 +23,7 @@ const DefaultStory = ({ count = 20 }: PagerProps) => {
23
23
  };
24
24
 
25
25
  const meta = {
26
- title: 'plugins/plugin-presenter/Pager',
26
+ title: 'plugins/plugin-presenter/components/Pager',
27
27
  render: DefaultStory,
28
28
  decorators: [withTheme()],
29
29
  parameters: {