@dxos/plugin-presenter 0.8.4-main.c4373fc → 0.8.4-main.d9fc60f731

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 (207) hide show
  1. package/LICENSE +102 -5
  2. package/PLUGIN.mdl +309 -0
  3. package/dist/lib/neutral/CollectionPresenterArticle-DFREOQTG.mjs +46 -0
  4. package/dist/lib/neutral/CollectionPresenterArticle-DFREOQTG.mjs.map +7 -0
  5. package/dist/lib/neutral/DocumentPresenterContainer-KCDZ2O2C.mjs +24 -0
  6. package/dist/lib/neutral/DocumentPresenterContainer-KCDZ2O2C.mjs.map +7 -0
  7. package/dist/lib/neutral/MarkdownSlide-WXILOIBE.mjs +18 -0
  8. package/dist/lib/neutral/MarkdownSlide-WXILOIBE.mjs.map +7 -0
  9. package/dist/lib/neutral/PresenterPlugin.mjs +35 -0
  10. package/dist/lib/neutral/PresenterPlugin.mjs.map +7 -0
  11. package/dist/lib/neutral/PresenterPlugin.node.mjs +16 -0
  12. package/dist/lib/neutral/PresenterPlugin.node.mjs.map +7 -0
  13. package/dist/lib/neutral/PresenterPlugin.workerd.mjs +12 -0
  14. package/dist/lib/neutral/PresenterPlugin.workerd.mjs.map +7 -0
  15. package/dist/lib/neutral/PresenterSettings-2G4XD4QY.mjs +25 -0
  16. package/dist/lib/neutral/PresenterSettings-2G4XD4QY.mjs.map +7 -0
  17. package/dist/lib/neutral/app-graph-builder-DIEDSRPX.mjs +97 -0
  18. package/dist/lib/neutral/app-graph-builder-DIEDSRPX.mjs.map +7 -0
  19. package/dist/lib/neutral/capabilities/index.mjs +13 -0
  20. package/dist/lib/neutral/capabilities/index.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/neutral/chunk-PPL2FF6R.mjs +38 -0
  24. package/dist/lib/neutral/chunk-PPL2FF6R.mjs.map +7 -0
  25. package/dist/lib/neutral/chunk-V323QBC3.mjs +41 -0
  26. package/dist/lib/neutral/chunk-V323QBC3.mjs.map +7 -0
  27. package/dist/lib/neutral/chunk-VVALMI52.mjs +69 -0
  28. package/dist/lib/neutral/chunk-VVALMI52.mjs.map +7 -0
  29. package/dist/lib/neutral/components/index.mjs +502 -0
  30. package/dist/lib/neutral/components/index.mjs.map +7 -0
  31. package/dist/lib/neutral/containers/index.mjs +13 -0
  32. package/dist/lib/neutral/containers/index.mjs.map +7 -0
  33. package/dist/lib/neutral/index.mjs +18 -0
  34. package/dist/lib/neutral/index.mjs.map +7 -0
  35. package/dist/lib/neutral/meta.json +1 -0
  36. package/dist/lib/neutral/meta.mjs +8 -0
  37. package/dist/lib/neutral/meta.mjs.map +7 -0
  38. package/dist/lib/neutral/plugin.mjs +12 -0
  39. package/dist/lib/neutral/plugin.mjs.map +7 -0
  40. package/dist/lib/neutral/react-surface-SPJGAJIF.mjs +54 -0
  41. package/dist/lib/neutral/react-surface-SPJGAJIF.mjs.map +7 -0
  42. package/dist/lib/neutral/settings-R6LRDAAK.mjs +28 -0
  43. package/dist/lib/neutral/settings-R6LRDAAK.mjs.map +7 -0
  44. package/dist/lib/neutral/translations.mjs +19 -0
  45. package/dist/lib/neutral/translations.mjs.map +7 -0
  46. package/dist/lib/neutral/types/index.mjs +14 -0
  47. package/dist/lib/neutral/types/index.mjs.map +7 -0
  48. package/dist/types/src/PresenterPlugin.d.ts +3 -1
  49. package/dist/types/src/PresenterPlugin.d.ts.map +1 -1
  50. package/dist/types/src/PresenterPlugin.node.d.ts +4 -0
  51. package/dist/types/src/PresenterPlugin.node.d.ts.map +1 -0
  52. package/dist/types/src/PresenterPlugin.test.d.ts +2 -0
  53. package/dist/types/src/PresenterPlugin.test.d.ts.map +1 -0
  54. package/dist/types/src/PresenterPlugin.workerd.d.ts +4 -0
  55. package/dist/types/src/PresenterPlugin.workerd.d.ts.map +1 -0
  56. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  57. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  58. package/dist/types/src/capabilities/index.d.ts +4 -3
  59. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  60. package/dist/types/src/capabilities/react-surface.d.ts +3 -2
  61. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  62. package/dist/types/src/capabilities/settings.d.ts +5 -2
  63. package/dist/types/src/capabilities/settings.d.ts.map +1 -1
  64. package/dist/types/src/components/Markdown/Panel.d.ts +8 -0
  65. package/dist/types/src/components/Markdown/Panel.d.ts.map +1 -0
  66. package/dist/types/src/components/Markdown/{Container.stories.d.ts → Panel.stories.d.ts} +1 -1
  67. package/dist/types/src/components/Markdown/Panel.stories.d.ts.map +1 -0
  68. package/dist/types/src/components/Markdown/Slide.d.ts +1 -1
  69. package/dist/types/src/components/Markdown/Slide.d.ts.map +1 -1
  70. package/dist/types/src/components/Markdown/Slide.stories.d.ts.map +1 -1
  71. package/dist/types/src/components/Markdown/index.d.ts +1 -1
  72. package/dist/types/src/components/Markdown/index.d.ts.map +1 -1
  73. package/dist/types/src/components/Markdown/theme.d.ts.map +1 -1
  74. package/dist/types/src/components/Presenter/Layout.d.ts +5 -5
  75. package/dist/types/src/components/Presenter/Layout.d.ts.map +1 -1
  76. package/dist/types/src/components/Presenter/Pager.d.ts +1 -1
  77. package/dist/types/src/components/Presenter/Pager.d.ts.map +1 -1
  78. package/dist/types/src/components/Presenter/Pager.stories.d.ts.map +1 -1
  79. package/dist/types/src/components/PresenterSettings/PresenterSettings.d.ts +6 -0
  80. package/dist/types/src/components/PresenterSettings/PresenterSettings.d.ts.map +1 -0
  81. package/dist/types/src/components/PresenterSettings/PresenterSettings.stories.d.ts +23 -0
  82. package/dist/types/src/components/PresenterSettings/PresenterSettings.stories.d.ts.map +1 -0
  83. package/dist/types/src/components/PresenterSettings/index.d.ts +2 -0
  84. package/dist/types/src/components/PresenterSettings/index.d.ts.map +1 -0
  85. package/dist/types/src/components/RevealPlayer/RevealPlayer.d.ts +5 -4
  86. package/dist/types/src/components/RevealPlayer/RevealPlayer.d.ts.map +1 -1
  87. package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts +7 -6
  88. package/dist/types/src/components/RevealPlayer/RevealPlayer.stories.d.ts.map +1 -1
  89. package/dist/types/src/components/index.d.ts +5 -25
  90. package/dist/types/src/components/index.d.ts.map +1 -1
  91. package/dist/types/src/containers/CollectionPresenterArticle/CollectionPresenterArticle.d.ts +6 -0
  92. package/dist/types/src/containers/CollectionPresenterArticle/CollectionPresenterArticle.d.ts.map +1 -0
  93. package/dist/types/src/containers/CollectionPresenterArticle/index.d.ts +2 -0
  94. package/dist/types/src/containers/CollectionPresenterArticle/index.d.ts.map +1 -0
  95. package/dist/types/src/containers/DocumentPresenterContainer/DocumentPresenterContainer.d.ts +6 -0
  96. package/dist/types/src/containers/DocumentPresenterContainer/DocumentPresenterContainer.d.ts.map +1 -0
  97. package/dist/types/src/containers/DocumentPresenterContainer/index.d.ts +2 -0
  98. package/dist/types/src/containers/DocumentPresenterContainer/index.d.ts.map +1 -0
  99. package/dist/types/src/containers/MarkdownSlide/MarkdownSlide.d.ts +8 -0
  100. package/dist/types/src/containers/MarkdownSlide/MarkdownSlide.d.ts.map +1 -0
  101. package/dist/types/src/containers/MarkdownSlide/index.d.ts +2 -0
  102. package/dist/types/src/containers/MarkdownSlide/index.d.ts.map +1 -0
  103. package/dist/types/src/containers/index.d.ts +5 -0
  104. package/dist/types/src/containers/index.d.ts.map +1 -0
  105. package/dist/types/src/index.d.ts +1 -2
  106. package/dist/types/src/index.d.ts.map +1 -1
  107. package/dist/types/src/meta.d.ts +2 -2
  108. package/dist/types/src/meta.d.ts.map +1 -1
  109. package/dist/types/src/plugin.d.ts +3 -0
  110. package/dist/types/src/plugin.d.ts.map +1 -0
  111. package/dist/types/src/testing.d.ts.map +1 -1
  112. package/dist/types/src/translations.d.ts +4 -6
  113. package/dist/types/src/translations.d.ts.map +1 -1
  114. package/dist/types/src/types/PresenterCapabilities.d.ts +4 -0
  115. package/dist/types/src/types/PresenterCapabilities.d.ts.map +1 -0
  116. package/dist/types/src/types/PresenterOperation.d.ts +17 -0
  117. package/dist/types/src/types/PresenterOperation.d.ts.map +1 -0
  118. package/dist/types/src/types/Settings.d.ts +7 -0
  119. package/dist/types/src/types/Settings.d.ts.map +1 -0
  120. package/dist/types/src/types/index.d.ts +11 -0
  121. package/dist/types/src/types/index.d.ts.map +1 -0
  122. package/dist/types/src/useExitPresenter.d.ts +3 -4
  123. package/dist/types/src/useExitPresenter.d.ts.map +1 -1
  124. package/dist/types/tsconfig.tsbuildinfo +1 -1
  125. package/package.json +99 -43
  126. package/src/PresenterPlugin.node.ts +16 -0
  127. package/src/PresenterPlugin.test.ts +23 -0
  128. package/src/PresenterPlugin.tsx +19 -25
  129. package/src/PresenterPlugin.workerd.ts +11 -0
  130. package/src/capabilities/app-graph-builder.ts +92 -103
  131. package/src/capabilities/index.ts +4 -4
  132. package/src/capabilities/react-surface.tsx +59 -55
  133. package/src/capabilities/settings.ts +24 -12
  134. package/src/components/Markdown/{Container.stories.tsx → Panel.stories.tsx} +7 -7
  135. package/src/components/Markdown/{Container.tsx → Panel.tsx} +6 -6
  136. package/src/components/Markdown/Slide.stories.tsx +4 -4
  137. package/src/components/Markdown/Slide.tsx +2 -2
  138. package/src/components/Markdown/index.ts +1 -1
  139. package/src/components/Markdown/theme.ts +5 -5
  140. package/src/components/Presenter/Layout.tsx +24 -23
  141. package/src/components/Presenter/Pager.stories.tsx +2 -2
  142. package/src/components/Presenter/Pager.tsx +53 -18
  143. package/src/components/PresenterSettings/PresenterSettings.stories.tsx +32 -0
  144. package/src/components/PresenterSettings/PresenterSettings.tsx +31 -0
  145. package/src/components/PresenterSettings/index.ts +5 -0
  146. package/src/components/RevealPlayer/RevealPlayer.stories.tsx +5 -5
  147. package/src/components/RevealPlayer/RevealPlayer.tsx +104 -95
  148. package/src/components/index.ts +5 -5
  149. package/src/containers/CollectionPresenterArticle/CollectionPresenterArticle.tsx +50 -0
  150. package/src/containers/CollectionPresenterArticle/index.ts +5 -0
  151. package/src/containers/DocumentPresenterContainer/DocumentPresenterContainer.tsx +24 -0
  152. package/src/containers/DocumentPresenterContainer/index.ts +5 -0
  153. package/src/containers/MarkdownSlide/MarkdownSlide.tsx +26 -0
  154. package/src/containers/MarkdownSlide/index.ts +5 -0
  155. package/src/containers/index.ts +9 -0
  156. package/src/index.ts +1 -3
  157. package/src/meta.ts +29 -5
  158. package/src/plugin.ts +9 -0
  159. package/src/testing.ts +6 -6
  160. package/src/translations.ts +4 -5
  161. package/src/types/PresenterCapabilities.ts +15 -0
  162. package/src/types/PresenterOperation.ts +29 -0
  163. package/src/types/Settings.ts +20 -0
  164. package/src/types/index.ts +21 -0
  165. package/src/useExitPresenter.ts +26 -25
  166. package/src/vite-env.d.ts +5 -0
  167. package/dist/lib/browser/CollectionPresenterContainer-LPJILYRF.mjs +0 -191
  168. package/dist/lib/browser/CollectionPresenterContainer-LPJILYRF.mjs.map +0 -7
  169. package/dist/lib/browser/DocumentPresenterContainer-F42V4KAL.mjs +0 -183
  170. package/dist/lib/browser/DocumentPresenterContainer-F42V4KAL.mjs.map +0 -7
  171. package/dist/lib/browser/MarkdownSlide-BLVWTH3U.mjs +0 -223
  172. package/dist/lib/browser/MarkdownSlide-BLVWTH3U.mjs.map +0 -7
  173. package/dist/lib/browser/app-graph-builder-RLGABE65.mjs +0 -106
  174. package/dist/lib/browser/app-graph-builder-RLGABE65.mjs.map +0 -7
  175. package/dist/lib/browser/chunk-6ZM323ED.mjs +0 -13
  176. package/dist/lib/browser/chunk-6ZM323ED.mjs.map +0 -7
  177. package/dist/lib/browser/chunk-7DV6S5XB.mjs +0 -39
  178. package/dist/lib/browser/chunk-7DV6S5XB.mjs.map +0 -7
  179. package/dist/lib/browser/chunk-QTSOWA2K.mjs +0 -41
  180. package/dist/lib/browser/chunk-QTSOWA2K.mjs.map +0 -7
  181. package/dist/lib/browser/chunk-UVGTHJUO.mjs +0 -36
  182. package/dist/lib/browser/chunk-UVGTHJUO.mjs.map +0 -7
  183. package/dist/lib/browser/index.mjs +0 -65
  184. package/dist/lib/browser/index.mjs.map +0 -7
  185. package/dist/lib/browser/meta.json +0 -1
  186. package/dist/lib/browser/react-surface-P7YJFHF3.mjs +0 -57
  187. package/dist/lib/browser/react-surface-P7YJFHF3.mjs.map +0 -7
  188. package/dist/lib/browser/settings-7A4A2H6X.mjs +0 -22
  189. package/dist/lib/browser/settings-7A4A2H6X.mjs.map +0 -7
  190. package/dist/types/src/components/CollectionPresenterContainer.d.ts +0 -7
  191. package/dist/types/src/components/CollectionPresenterContainer.d.ts.map +0 -1
  192. package/dist/types/src/components/DocumentPresenterContainer.d.ts +0 -7
  193. package/dist/types/src/components/DocumentPresenterContainer.d.ts.map +0 -1
  194. package/dist/types/src/components/Markdown/Container.d.ts +0 -8
  195. package/dist/types/src/components/Markdown/Container.d.ts.map +0 -1
  196. package/dist/types/src/components/Markdown/Container.stories.d.ts.map +0 -1
  197. package/dist/types/src/components/MarkdownSlide.d.ts +0 -7
  198. package/dist/types/src/components/MarkdownSlide.d.ts.map +0 -1
  199. package/dist/types/src/components/PresenterSettings.d.ts +0 -6
  200. package/dist/types/src/components/PresenterSettings.d.ts.map +0 -1
  201. package/dist/types/src/types.d.ts +0 -39
  202. package/dist/types/src/types.d.ts.map +0 -1
  203. package/src/components/CollectionPresenterContainer.tsx +0 -44
  204. package/src/components/DocumentPresenterContainer.tsx +0 -23
  205. package/src/components/MarkdownSlide.tsx +0 -24
  206. package/src/components/PresenterSettings.tsx +0 -30
  207. package/src/types.ts +0 -46
package/package.json CHANGED
@@ -1,31 +1,87 @@
1
1
  {
2
2
  "name": "@dxos/plugin-presenter",
3
- "version": "0.8.4-main.c4373fc",
3
+ "version": "0.8.4-main.d9fc60f731",
4
4
  "description": "Braneframe presenter plugin",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
7
- "license": "MIT",
7
+ "repository": {
8
+ "type": "git",
9
+ "url": "https://github.com/dxos/dxos"
10
+ },
11
+ "license": "FSL-1.1-Apache-2.0",
8
12
  "author": "DXOS.org",
9
13
  "sideEffects": true,
10
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
+ "workerd": "./src/PresenterPlugin.workerd.ts",
39
+ "node": "./src/PresenterPlugin.node.ts",
40
+ "default": "./src/PresenterPlugin.tsx"
41
+ },
42
+ "types": "./dist/types/src/PresenterPlugin.d.ts",
43
+ "workerd": "./dist/lib/neutral/PresenterPlugin.workerd.mjs",
44
+ "node": "./dist/lib/neutral/PresenterPlugin.node.mjs",
45
+ "default": "./dist/lib/neutral/PresenterPlugin.mjs"
46
+ },
47
+ "#testing": "./src/testing.ts",
48
+ "#translations": {
49
+ "source": "./src/translations.ts",
50
+ "types": "./dist/types/src/translations.d.ts",
51
+ "default": "./dist/lib/neutral/translations.mjs"
52
+ },
53
+ "#types": {
54
+ "source": "./src/types/index.ts",
55
+ "types": "./dist/types/src/types/index.d.ts",
56
+ "default": "./dist/lib/neutral/types/index.mjs"
57
+ }
58
+ },
11
59
  "exports": {
12
60
  ".": {
13
61
  "source": "./src/index.ts",
14
62
  "types": "./dist/types/src/index.d.ts",
15
- "browser": "./dist/lib/browser/index.mjs"
63
+ "default": "./dist/lib/neutral/index.mjs"
64
+ },
65
+ "./assets/PLUGIN.mdl": "./PLUGIN.mdl",
66
+ "./plugin": {
67
+ "source": "./src/plugin.ts",
68
+ "types": "./dist/types/src/plugin.d.ts",
69
+ "default": "./dist/lib/neutral/plugin.mjs"
70
+ },
71
+ "./translations": {
72
+ "source": "./src/translations.ts",
73
+ "types": "./dist/types/src/translations.d.ts",
74
+ "default": "./dist/lib/neutral/translations.mjs"
16
75
  }
17
76
  },
18
77
  "types": "dist/types/src/index.d.ts",
19
- "typesVersions": {
20
- "*": {}
21
- },
22
78
  "files": [
23
79
  "dist",
24
- "src"
80
+ "src",
81
+ "PLUGIN.mdl"
25
82
  ],
26
83
  "dependencies": {
27
- "@preact-signals/safe-react": "^0.9.0",
28
- "@preact/signals-core": "^1.12.1",
84
+ "@effect-atom/atom-react": "^0.5.0",
29
85
  "hastscript": "^7.1.0",
30
86
  "highlight.js": "^11.9.0",
31
87
  "marked": "^12.0.2",
@@ -36,45 +92,45 @@
36
92
  "remark-frontmatter": "^5.0.0",
37
93
  "remark-parse-frontmatter": "^1.0.3",
38
94
  "reveal.js": "^5.1.0",
39
- "@dxos/app-framework": "0.8.4-main.c4373fc",
40
- "@dxos/echo": "0.8.4-main.c4373fc",
41
- "@dxos/async": "0.8.4-main.c4373fc",
42
- "@dxos/live-object": "0.8.4-main.c4373fc",
43
- "@dxos/local-storage": "0.8.4-main.c4373fc",
44
- "@dxos/log": "0.8.4-main.c4373fc",
45
- "@dxos/plugin-deck": "0.8.4-main.c4373fc",
46
- "@dxos/plugin-client": "0.8.4-main.c4373fc",
47
- "@dxos/plugin-graph": "0.8.4-main.c4373fc",
48
- "@dxos/plugin-markdown": "0.8.4-main.c4373fc",
49
- "@dxos/plugin-stack": "0.8.4-main.c4373fc",
50
- "@dxos/react-client": "0.8.4-main.c4373fc",
51
- "@dxos/react-ui-form": "0.8.4-main.c4373fc",
52
- "@dxos/schema": "0.8.4-main.c4373fc",
53
- "@dxos/react-ui-stack": "0.8.4-main.c4373fc"
95
+ "@dxos/app-framework": "0.8.4-main.d9fc60f731",
96
+ "@dxos/compute": "0.8.4-main.d9fc60f731",
97
+ "@dxos/app-toolkit": "0.8.4-main.d9fc60f731",
98
+ "@dxos/echo": "0.8.4-main.d9fc60f731",
99
+ "@dxos/effect": "0.8.4-main.d9fc60f731",
100
+ "@dxos/keys": "0.8.4-main.d9fc60f731",
101
+ "@dxos/log": "0.8.4-main.d9fc60f731",
102
+ "@dxos/plugin-client": "0.8.4-main.d9fc60f731",
103
+ "@dxos/plugin-deck": "0.8.4-main.d9fc60f731",
104
+ "@dxos/plugin-graph": "0.8.4-main.d9fc60f731",
105
+ "@dxos/plugin-markdown": "0.8.4-main.d9fc60f731",
106
+ "@dxos/react-ui-attention": "0.8.4-main.d9fc60f731",
107
+ "@dxos/util": "0.8.4-main.d9fc60f731",
108
+ "@dxos/react-ui-form": "0.8.4-main.d9fc60f731"
54
109
  },
55
110
  "devDependencies": {
56
- "@effect-rx/rx-react": "0.42.4",
57
- "@effect/platform": "0.92.1",
58
- "@types/react": "~19.2.2",
59
- "@types/react-dom": "~19.2.1",
111
+ "@effect-atom/atom-react": "^0.5.0",
112
+ "@effect/platform": "0.96.1",
113
+ "@types/react": "~19.2.7",
114
+ "@types/react-dom": "~19.2.3",
60
115
  "@types/reveal.js": "^5.0.3",
61
- "effect": "3.18.3",
62
- "react": "~19.2.0",
63
- "react-dom": "~19.2.0",
64
- "vite": "7.1.9",
65
- "@dxos/react-ui": "0.8.4-main.c4373fc",
66
- "@dxos/react-ui-theme": "0.8.4-main.c4373fc",
67
- "@dxos/storybook-utils": "0.8.4-main.c4373fc",
68
- "@dxos/random": "0.8.4-main.c4373fc"
116
+ "effect": "3.21.2",
117
+ "react": "~19.2.3",
118
+ "react-dom": "~19.2.3",
119
+ "vite": "^8.0.14",
120
+ "@dxos/plugin-testing": "0.8.4-main.d9fc60f731",
121
+ "@dxos/storybook-utils": "0.8.4-main.d9fc60f731",
122
+ "@dxos/random": "0.8.4-main.d9fc60f731",
123
+ "@dxos/react-ui": "0.8.4-main.d9fc60f731",
124
+ "@dxos/ui-theme": "0.8.4-main.d9fc60f731"
69
125
  },
70
126
  "peerDependencies": {
71
- "@effect-rx/rx-react": "^0.34.1",
72
- "@effect/platform": "^0.80.12",
73
- "effect": "^3.13.3",
74
- "react": "^19.0.0",
75
- "react-dom": "^19.0.0",
76
- "@dxos/react-ui": "0.8.4-main.c4373fc",
77
- "@dxos/react-ui-theme": "0.8.4-main.c4373fc"
127
+ "@effect-atom/atom-react": "^0.5.0",
128
+ "@effect/platform": "0.96.1",
129
+ "effect": "3.21.2",
130
+ "react": "~19.2.3",
131
+ "react-dom": "~19.2.3",
132
+ "@dxos/react-ui": "0.8.4-main.d9fc60f731",
133
+ "@dxos/ui-theme": "0.8.4-main.d9fc60f731"
78
134
  },
79
135
  "publishConfig": {
80
136
  "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
+ });
@@ -2,34 +2,28 @@
2
2
  // Copyright 2023 DXOS.org
3
3
  //
4
4
 
5
- import { Capabilities, Events, contributes, defineModule, definePlugin } from '@dxos/app-framework';
5
+ import { Plugin } from '@dxos/app-framework';
6
+ import { AppPlugin } from '@dxos/app-toolkit';
6
7
 
7
- import { AppGraphBuilder, PresenterSettings, ReactSurface } from './capabilities';
8
- import { meta } from './meta';
9
- import { translations } from './translations';
8
+ import { AppGraphBuilder, PresenterSettings, ReactSurface } from '#capabilities';
9
+ import { meta } from '#meta';
10
+ import { translations } from '#translations';
11
+
12
+ // eslint-disable-next-line import/no-relative-packages
13
+ import pluginSpec from '../PLUGIN.mdl?raw';
10
14
 
11
15
  // TODO(burdon): Only scale markdown content.
12
16
  // TODO(burdon): Map stack content; Slide content type (e.g., markdown, sketch, IPFS image, table, etc.)
13
17
 
14
- export const PresenterPlugin = definePlugin(meta, () => [
15
- defineModule({
16
- id: `${meta.id}/module/settings`,
17
- activatesOn: Events.SetupSettings,
18
- activate: PresenterSettings,
19
- }),
20
- defineModule({
21
- id: `${meta.id}/module/translations`,
22
- activatesOn: Events.SetupTranslations,
23
- activate: () => contributes(Capabilities.Translations, translations),
24
- }),
25
- defineModule({
26
- id: `${meta.id}/module/react-surface`,
27
- activatesOn: Events.SetupReactSurface,
28
- activate: ReactSurface,
18
+ export const PresenterPlugin = Plugin.define(meta).pipe(
19
+ AppPlugin.addAppGraphModule({ activate: AppGraphBuilder }),
20
+ AppPlugin.addSettingsModule({ activate: PresenterSettings }),
21
+ AppPlugin.addSurfaceModule({ activate: ReactSurface }),
22
+ AppPlugin.addTranslationsModule({ translations }),
23
+ AppPlugin.addPluginAssetModule({
24
+ asset: { pluginId: meta.id, path: 'PLUGIN.mdl', content: pluginSpec, mimeType: 'application/x-mdl' },
29
25
  }),
30
- defineModule({
31
- id: `${meta.id}/module/app-graph-builder`,
32
- activatesOn: Events.SetupAppGraph,
33
- activate: AppGraphBuilder,
34
- }),
35
- ]);
26
+ Plugin.make,
27
+ );
28
+
29
+ export default PresenterPlugin;
@@ -0,0 +1,11 @@
1
+ //
2
+ // Copyright 2023 DXOS.org
3
+ //
4
+
5
+ import { Plugin } from '@dxos/app-framework';
6
+
7
+ import { meta } from '#meta';
8
+
9
+ export const PresenterPlugin = Plugin.define(meta).pipe(Plugin.make);
10
+
11
+ export default PresenterPlugin;
@@ -2,112 +2,101 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { Rx } from '@effect-rx/rx-react';
6
- import * as Function from 'effect/Function';
5
+ import * as Effect from 'effect/Effect';
7
6
  import * as Option from 'effect/Option';
8
7
 
9
- import { Capabilities, LayoutAction, type PluginContext, contributes, createIntent } from '@dxos/app-framework';
10
- import { Obj } from '@dxos/echo';
11
- import { DeckCapabilities } from '@dxos/plugin-deck';
12
- import { ATTENDABLE_PATH_SEPARATOR, DeckAction } from '@dxos/plugin-deck/types';
13
- import { createExtension, rxFromSignal } from '@dxos/plugin-graph';
14
- import { Markdown } from '@dxos/plugin-markdown/types';
15
- import { fullyQualifiedId, getSpace } from '@dxos/react-client/echo';
16
- import { DataType } from '@dxos/schema';
8
+ import { Capabilities, Capability } from '@dxos/app-framework';
9
+ import { AppCapabilities, AppNode, LayoutOperation, getObjectPathFromObject, getSpacePath } from '@dxos/app-toolkit';
10
+ import { Operation } from '@dxos/compute';
11
+ import { Collection, Obj } from '@dxos/echo';
12
+ import { DeckCapabilities, DeckOperation } from '@dxos/plugin-deck';
13
+ import { GraphBuilder, type Node, NodeMatcher } from '@dxos/plugin-graph';
14
+ import { Markdown } from '@dxos/plugin-markdown';
15
+ import { linkedSegment } from '@dxos/react-ui-attention';
17
16
 
18
- import { meta } from '../meta';
19
- import { PresenterAction, type PresenterSettingsProps } from '../types';
17
+ import { meta } from '#meta';
18
+ import { PresenterOperation } from '#types';
19
+ import { PresenterCapabilities } from '#types';
20
20
 
21
- export default (context: PluginContext) =>
22
- contributes(
23
- Capabilities.AppGraphBuilder,
24
- createExtension({
25
- id: meta.id,
21
+ /** Match nodes that can be presented (Collection or Document). */
22
+ const whenPresentable = (node: Node.Node) =>
23
+ Option.orElse(NodeMatcher.whenEchoType(Collection.Collection)(node), () =>
24
+ NodeMatcher.whenEchoType(Markdown.Document)(node),
25
+ );
26
+
27
+ export default Capability.makeModule(
28
+ Effect.fnUntraced(function* () {
29
+ const capabilities = yield* Capability.Service;
30
+
31
+ const extensions = yield* GraphBuilder.createExtension({
32
+ id: 'root',
26
33
  // TODO(wittjosiah): This is a hack to work around presenter previously relying on "variant". Remove.
27
- connector: (node) =>
28
- Rx.make((get) =>
29
- Function.pipe(
30
- get(node),
31
- Option.flatMap((node) => {
32
- const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
33
- const settings = get(rxFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value));
34
- const isPresentable = settings?.presentCollections
35
- ? Obj.instanceOf(DataType.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)
36
- : Obj.instanceOf(Markdown.Document, node.data);
37
- return isPresentable ? Option.some(node.data) : Option.none();
38
- }),
39
- Option.map((object) => {
40
- const id = fullyQualifiedId(object);
41
- return [
42
- {
43
- id: [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR),
44
- data: { type: meta.id, object },
45
- type: meta.id,
46
- properties: {
47
- label: 'Presenter',
48
- icon: 'ph--presentation--regular',
49
- disposition: 'hidden',
50
- },
51
- },
52
- ];
53
- }),
54
- Option.getOrElse(() => []),
55
- ),
56
- ),
57
- actions: (node) =>
58
- Rx.make((get) =>
59
- Function.pipe(
60
- get(node),
61
- Option.flatMap((node) => {
62
- const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
63
- const settings = get(rxFromSignal(() => settingsStore?.getStore<PresenterSettingsProps>(meta.id)?.value));
64
- const isPresentable = settings?.presentCollections
65
- ? Obj.instanceOf(DataType.Collection, node.data) || Obj.instanceOf(Markdown.Document, node.data)
66
- : Obj.instanceOf(Markdown.Document, node.data);
67
- return isPresentable ? Option.some(node.data) : Option.none();
68
- }),
69
- Option.map((object) => {
70
- const id = fullyQualifiedId(object);
71
- const spaceId = getSpace(object)?.id;
72
- return [
73
- {
74
- id: `${PresenterAction.TogglePresentation._tag}/${id}`,
75
- // TODO(burdon): Allow function so can generate state when activated.
76
- // So can set explicit fullscreen state coordinated with current presenter state.
77
- data: async () => {
78
- const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
79
- const layout = context.getCapability(DeckCapabilities.MutableDeckState);
80
- const presenterId = [id, 'presenter'].join(ATTENDABLE_PATH_SEPARATOR);
81
- if (!layout.deck.fullscreen) {
82
- void dispatch(
83
- createIntent(DeckAction.Adjust, {
84
- type: 'solo--fullscreen',
85
- id: presenterId,
86
- }),
87
- );
88
- }
89
- await dispatch(
90
- createIntent(LayoutAction.Open, {
91
- part: 'main',
92
- subject: [presenterId],
93
- options: { workspace: spaceId },
94
- }),
95
- );
96
- },
97
- properties: {
98
- label: ['toggle presentation label', { ns: meta.id }],
99
- icon: 'ph--presentation--regular',
100
- disposition: 'list-item',
101
- keyBinding: {
102
- macos: 'shift+meta+p',
103
- windows: 'shift+alt+p',
104
- },
105
- },
106
- },
107
- ];
34
+ match: whenPresentable,
35
+ connector: (object, get) => {
36
+ const settingsAtom = capabilities.get(PresenterCapabilities.Settings);
37
+ const settings = get(settingsAtom);
38
+ const isPresentable = settings?.presentCollections
39
+ ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object)
40
+ : Obj.instanceOf(Markdown.Document, object);
41
+ if (!isPresentable) {
42
+ return Effect.succeed([]);
43
+ }
44
+
45
+ return Effect.succeed([
46
+ AppNode.makeCompanion({
47
+ id: linkedSegment('presenter'),
48
+ label: 'Presenter',
49
+ icon: 'ph--presentation--regular',
50
+ data: { type: meta.id, object },
51
+ }),
52
+ ]);
53
+ },
54
+ actions: (object, get) => {
55
+ const settingsAtom = capabilities.get(PresenterCapabilities.Settings);
56
+ const settings = get(settingsAtom);
57
+ const isPresentable = settings?.presentCollections
58
+ ? Obj.instanceOf(Collection.Collection, object) || Obj.instanceOf(Markdown.Document, object)
59
+ : Obj.instanceOf(Markdown.Document, object);
60
+ const db = Obj.getDatabase(object);
61
+ if (!isPresentable || !db) {
62
+ return Effect.succeed([]);
63
+ }
64
+ const objectPath = getObjectPathFromObject(object);
65
+
66
+ return Effect.succeed([
67
+ {
68
+ id: PresenterOperation.TogglePresentation.meta.key,
69
+ // TODO(burdon): Allow function so can generate state when activated.
70
+ // So can set explicit fullscreen state coordinated with current presenter state.
71
+ data: Effect.fnUntraced(function* () {
72
+ const deckState = yield* Capabilities.getAtomValue(DeckCapabilities.State);
73
+ const deck = deckState.decks[deckState.activeDeck];
74
+ const presenterId = `${objectPath}/${linkedSegment('presenter')}`;
75
+ if (!deck?.fullscreen) {
76
+ yield* Operation.invoke(DeckOperation.Adjust, {
77
+ type: 'solo--fullscreen' as const,
78
+ id: presenterId,
79
+ });
80
+ }
81
+ yield* Operation.invoke(LayoutOperation.Open, {
82
+ subject: [presenterId],
83
+ workspace: getSpacePath(db.spaceId),
84
+ });
108
85
  }),
109
- Option.getOrElse(() => []),
110
- ),
111
- ),
112
- }),
113
- );
86
+ properties: {
87
+ label: ['toggle-presentation.label', { ns: meta.id }],
88
+ icon: 'ph--presentation--regular',
89
+ disposition: 'list-item',
90
+ keyBinding: {
91
+ macos: 'shift+meta+p',
92
+ windows: 'shift+alt+p',
93
+ },
94
+ },
95
+ },
96
+ ]);
97
+ },
98
+ });
99
+
100
+ return Capability.contributes(AppCapabilities.AppGraphBuilder, extensions);
101
+ }),
102
+ );
@@ -2,8 +2,8 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
- import { lazy } from '@dxos/app-framework';
5
+ import { Capability } from '@dxos/app-framework';
6
6
 
7
- export const AppGraphBuilder = lazy(() => import('./app-graph-builder'));
8
- export const ReactSurface = lazy(() => import('./react-surface'));
9
- export const PresenterSettings = lazy(() => import('./settings'));
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'));
@@ -2,62 +2,66 @@
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
4
 
5
+ import * as Effect from 'effect/Effect';
5
6
  import React from 'react';
6
7
 
7
- import { Capabilities, contributes, createSurface } from '@dxos/app-framework';
8
- import { Obj } from '@dxos/echo';
9
- import { SettingsStore } from '@dxos/local-storage';
10
- import { Markdown } from '@dxos/plugin-markdown/types';
11
- import { DataType } from '@dxos/schema';
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 { Collection, Obj } from '@dxos/echo';
12
+ import { Markdown } from '@dxos/plugin-markdown';
12
13
 
13
- import {
14
- CollectionPresenterContainer,
15
- DocumentPresenterContainer,
16
- MarkdownSlide,
17
- PresenterSettings,
18
- } from '../components';
19
- import { meta } from '../meta';
20
- import { type PresenterSettingsProps } from '../types';
14
+ import { PresenterSettings } from '#components';
15
+ import { CollectionPresenterArticle, DocumentPresenterContainer, MarkdownSlide } from '#containers';
16
+ import { meta } from '#meta';
17
+ import { type Settings } from '#types';
21
18
 
22
- export default () =>
23
- contributes(Capabilities.ReactSurface, [
24
- createSurface({
25
- id: `${meta.id}/document`,
26
- role: 'article',
27
- position: 'hoist',
28
- filter: (data): data is { subject: { type: typeof meta.id; object: Markdown.Document } } =>
29
- !!data.subject &&
30
- typeof data.subject === 'object' &&
31
- 'type' in data.subject &&
32
- 'object' in data.subject &&
33
- data.subject.type === meta.id &&
34
- Obj.instanceOf(Markdown.Document, data.subject.object),
35
- component: ({ data }) => <DocumentPresenterContainer document={data.subject.object} />,
36
- }),
37
- createSurface({
38
- id: `${meta.id}/collection`,
39
- role: 'article',
40
- position: 'hoist',
41
- filter: (data): data is { subject: { type: typeof meta.id; object: DataType.Collection } } =>
42
- !!data.subject &&
43
- typeof data.subject === 'object' &&
44
- 'type' in data.subject &&
45
- 'object' in data.subject &&
46
- data.subject.type === meta.id &&
47
- Obj.instanceOf(DataType.Collection, data.subject.object),
48
- component: ({ data }) => <CollectionPresenterContainer collection={data.subject.object} />,
49
- }),
50
- createSurface({
51
- id: `${meta.id}/slide`,
52
- role: 'slide',
53
- filter: (data): data is { subject: Markdown.Document } => Obj.instanceOf(Markdown.Document, data.subject),
54
- component: ({ data }) => <MarkdownSlide document={data.subject} />,
55
- }),
56
- createSurface({
57
- id: `${meta.id}/plugin-settings`,
58
- role: 'article',
59
- filter: (data): data is { subject: SettingsStore<PresenterSettingsProps> } =>
60
- data.subject instanceof SettingsStore && data.subject.prefix === meta.id,
61
- component: ({ data: { subject } }) => <PresenterSettings settings={subject.value} />,
62
- }),
63
- ]);
19
+ export default Capability.makeModule(() =>
20
+ Effect.succeed(
21
+ Capability.contributes(Capabilities.ReactSurface, [
22
+ Surface.create({
23
+ id: 'document',
24
+ position: 'first',
25
+ filter: AppSurface.predicate(
26
+ AppSurface.Article,
27
+ (data): data is AppSurface.ArticleData<{ type: typeof meta.id; object: Markdown.Document }> =>
28
+ !!data.subject &&
29
+ typeof data.subject === 'object' &&
30
+ 'type' in data.subject &&
31
+ 'object' in data.subject &&
32
+ data.subject.type === meta.id &&
33
+ Obj.instanceOf(Markdown.Document, data.subject.object),
34
+ ),
35
+ component: ({ data }) => <DocumentPresenterContainer document={data.subject.object} />,
36
+ }),
37
+ Surface.create({
38
+ id: 'collection',
39
+ position: 'first',
40
+ filter: AppSurface.predicate(
41
+ AppSurface.Article,
42
+ (data): data is AppSurface.ArticleData<{ type: typeof meta.id; object: Collection.Collection }> =>
43
+ !!data.subject &&
44
+ typeof data.subject === 'object' &&
45
+ 'type' in data.subject &&
46
+ 'object' in data.subject &&
47
+ data.subject.type === meta.id &&
48
+ Obj.instanceOf(Collection.Collection, data.subject.object),
49
+ ),
50
+ component: ({ role, data }) => <CollectionPresenterArticle role={role} subject={data.subject.object} />,
51
+ }),
52
+ Surface.create({
53
+ id: 'slide',
54
+ filter: AppSurface.object(AppSurface.Slide, Markdown.Document),
55
+ component: ({ data }) => <MarkdownSlide document={data.subject} />,
56
+ }),
57
+ Surface.create({
58
+ id: 'pluginSettings',
59
+ filter: AppSurface.settings(AppSurface.Article, meta.id),
60
+ component: ({ data: { subject } }) => {
61
+ const { settings, updateSettings } = useSettingsState<Settings.Settings>(subject.atom);
62
+ return <PresenterSettings settings={settings} onSettingsChange={updateSettings} />;
63
+ },
64
+ }),
65
+ ]),
66
+ ),
67
+ );