@dreamboard-games/sdk 0.2.0

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 (369) hide show
  1. package/LICENSE.md +96 -0
  2. package/README.md +12 -0
  3. package/dist/HandView-ncJIVLhN.d.ts +193 -0
  4. package/dist/ResourceCounter-CTREyF73.d.ts +102 -0
  5. package/dist/ThemeProvider-fy0_QzgO.d.ts +99 -0
  6. package/dist/bundle-TIZcw8LB.d.ts +281 -0
  7. package/dist/cards-Sl3b40Mv.d.ts +13 -0
  8. package/dist/chunk-7YAHLYBR.js +481 -0
  9. package/dist/chunk-7YAHLYBR.js.map +1 -0
  10. package/dist/chunk-FDNZTDD6.js +8085 -0
  11. package/dist/chunk-FDNZTDD6.js.map +1 -0
  12. package/dist/chunk-GKKBPPSW.js +598 -0
  13. package/dist/chunk-GKKBPPSW.js.map +1 -0
  14. package/dist/chunk-I46YJSOD.js +1 -0
  15. package/dist/chunk-I46YJSOD.js.map +1 -0
  16. package/dist/chunk-KAELH4KC.js +104 -0
  17. package/dist/chunk-KAELH4KC.js.map +1 -0
  18. package/dist/chunk-PZ5AY32C.js +10 -0
  19. package/dist/chunk-PZ5AY32C.js.map +1 -0
  20. package/dist/chunk-T3ZKNUZ7.js +1 -0
  21. package/dist/chunk-T3ZKNUZ7.js.map +1 -0
  22. package/dist/chunk-T52J5RMF.js +1 -0
  23. package/dist/chunk-T52J5RMF.js.map +1 -0
  24. package/dist/chunk-TDSWKVZ4.js +5401 -0
  25. package/dist/chunk-TDSWKVZ4.js.map +1 -0
  26. package/dist/chunk-U5C6BONG.js +34 -0
  27. package/dist/chunk-U5C6BONG.js.map +1 -0
  28. package/dist/chunk-VDXOF4FW.js +69 -0
  29. package/dist/chunk-VDXOF4FW.js.map +1 -0
  30. package/dist/chunk-VFTAA4WO.js +115 -0
  31. package/dist/chunk-VFTAA4WO.js.map +1 -0
  32. package/dist/chunk-WN74KVNY.js +17 -0
  33. package/dist/chunk-WN74KVNY.js.map +1 -0
  34. package/dist/chunk-WYPQ3GG5.js +10990 -0
  35. package/dist/chunk-WYPQ3GG5.js.map +1 -0
  36. package/dist/components-D5ZRE2Hl.d.ts +1451 -0
  37. package/dist/generated/runtime/primitives.d.ts +12 -0
  38. package/dist/generated/runtime/primitives.js +180 -0
  39. package/dist/generated/runtime/primitives.js.map +1 -0
  40. package/dist/generated/runtime-api.d.ts +3 -0
  41. package/dist/generated/runtime-api.js +2 -0
  42. package/dist/generated/runtime-api.js.map +1 -0
  43. package/dist/generated/runtime.d.ts +14 -0
  44. package/dist/generated/runtime.js +18 -0
  45. package/dist/generated/runtime.js.map +1 -0
  46. package/dist/generated/workspace-contract.d.ts +14 -0
  47. package/dist/generated/workspace-contract.js +14 -0
  48. package/dist/generated/workspace-contract.js.map +1 -0
  49. package/dist/hex-board-view-D_07hO6O.d.ts +933 -0
  50. package/dist/hex-color-MhOyuY-o.d.ts +8 -0
  51. package/dist/index-BwqPQtBu.d.ts +1433 -0
  52. package/dist/index.d.ts +1 -0
  53. package/dist/index.js +12 -0
  54. package/dist/index.js.map +1 -0
  55. package/dist/infrastructure/reducer-bundle-abi.d.ts +1083 -0
  56. package/dist/infrastructure/reducer-bundle-abi.js +14 -0
  57. package/dist/infrastructure/reducer-bundle-abi.js.map +1 -0
  58. package/dist/infrastructure/workspace-codegen.d.ts +53 -0
  59. package/dist/infrastructure/workspace-codegen.js +44 -0
  60. package/dist/infrastructure/workspace-codegen.js.map +1 -0
  61. package/dist/manifest-contract-BNHVGFtU.d.ts +9 -0
  62. package/dist/package-set.d.ts +13 -0
  63. package/dist/package-set.js +12 -0
  64. package/dist/package-set.js.map +1 -0
  65. package/dist/primitive-props-DpKs-GCr.d.ts +11 -0
  66. package/dist/reducer.d.ts +3786 -0
  67. package/dist/reducer.js +8131 -0
  68. package/dist/reducer.js.map +1 -0
  69. package/dist/runtime/primitives.d.ts +226 -0
  70. package/dist/runtime/primitives.js +180 -0
  71. package/dist/runtime/primitives.js.map +1 -0
  72. package/dist/runtime/types/runtime-api.d.ts +1 -0
  73. package/dist/runtime/types/runtime-api.js +2 -0
  74. package/dist/runtime/types/runtime-api.js.map +1 -0
  75. package/dist/runtime/workspace-contract.d.ts +172 -0
  76. package/dist/runtime/workspace-contract.js +14 -0
  77. package/dist/runtime/workspace-contract.js.map +1 -0
  78. package/dist/runtime-api-3dshj6kK.d.ts +101 -0
  79. package/dist/runtime-api-DWxvTr-O.d.ts +379 -0
  80. package/dist/runtime.d.ts +58 -0
  81. package/dist/runtime.js +13 -0
  82. package/dist/runtime.js.map +1 -0
  83. package/dist/slots-1GPGihk8.d.ts +8 -0
  84. package/dist/testing.d.ts +149 -0
  85. package/dist/testing.js +513 -0
  86. package/dist/testing.js.map +1 -0
  87. package/dist/types.d.ts +496 -0
  88. package/dist/types.js +28 -0
  89. package/dist/types.js.map +1 -0
  90. package/dist/ui/components.d.ts +16 -0
  91. package/dist/ui/components.js +192 -0
  92. package/dist/ui/components.js.map +1 -0
  93. package/dist/ui/defaults.d.ts +19 -0
  94. package/dist/ui/defaults.js +104 -0
  95. package/dist/ui/defaults.js.map +1 -0
  96. package/dist/ui/plugin-styles.css +250 -0
  97. package/dist/ui/types/player-state.d.ts +365 -0
  98. package/dist/ui/types/player-state.js +1 -0
  99. package/dist/ui/types/player-state.js.map +1 -0
  100. package/dist/ui-contract-iQfTtUSL.d.ts +1161 -0
  101. package/dist/ui.d.ts +320 -0
  102. package/dist/ui.js +253 -0
  103. package/dist/ui.js.map +1 -0
  104. package/package.json +199 -0
  105. package/src/generated/reducer-contract/builders.ts +90 -0
  106. package/src/generated/reducer-contract/version.ts +9 -0
  107. package/src/generated/reducer-contract/wire.ts +100 -0
  108. package/src/generated/reducer-contract/zod.ts +101 -0
  109. package/src/generated/runtime/primitives.ts +2 -0
  110. package/src/generated/runtime-api.ts +5 -0
  111. package/src/generated/runtime.ts +35 -0
  112. package/src/generated/workspace-contract.ts +2 -0
  113. package/src/index.ts +7 -0
  114. package/src/infrastructure/reducer-bundle-abi.ts +8 -0
  115. package/src/infrastructure/reducer-contract/bundle.ts +37 -0
  116. package/src/infrastructure/workspace-codegen/hex-geometry.ts +69 -0
  117. package/src/infrastructure/workspace-codegen/index.ts +64 -0
  118. package/src/infrastructure/workspace-codegen/manifest-contract.ts +6632 -0
  119. package/src/infrastructure/workspace-codegen/manifest-validation.ts +795 -0
  120. package/src/infrastructure/workspace-codegen/ownership.ts +131 -0
  121. package/src/infrastructure/workspace-codegen/preset-card-sets.ts +169 -0
  122. package/src/infrastructure/workspace-codegen/seeds.ts +1705 -0
  123. package/src/infrastructure/workspace-codegen.ts +1 -0
  124. package/src/package-set.ts +19 -0
  125. package/src/reducer/authoring/contract.ts +157 -0
  126. package/src/reducer/authoring/effect.ts +224 -0
  127. package/src/reducer/authoring/game.ts +23 -0
  128. package/src/reducer/authoring/interaction.ts +98 -0
  129. package/src/reducer/authoring/phase.ts +300 -0
  130. package/src/reducer/authoring/types.ts +70 -0
  131. package/src/reducer/authoring/validation.ts +382 -0
  132. package/src/reducer/authoring/view-stage.ts +68 -0
  133. package/src/reducer/authoring.ts +29 -0
  134. package/src/reducer/bundle/ingress-bundle.ts +491 -0
  135. package/src/reducer/bundle/trusted/engine-instruction-resolver.ts +254 -0
  136. package/src/reducer/bundle/trusted/flow-instruction-resolver.ts +73 -0
  137. package/src/reducer/bundle/trusted/instruction-runner.ts +414 -0
  138. package/src/reducer/bundle/trusted/interaction-authorization.ts +137 -0
  139. package/src/reducer/bundle/trusted/interaction-collectors.ts +859 -0
  140. package/src/reducer/bundle/trusted/interaction-decision.ts +747 -0
  141. package/src/reducer/bundle/trusted/interaction-resolver.ts +95 -0
  142. package/src/reducer/bundle/trusted/interaction-types.ts +171 -0
  143. package/src/reducer/bundle/trusted/lifecycle-runner.ts +427 -0
  144. package/src/reducer/bundle/trusted/projection-builder.ts +356 -0
  145. package/src/reducer/bundle/trusted/projection-context.ts +39 -0
  146. package/src/reducer/bundle/trusted/rng-sampler.ts +150 -0
  147. package/src/reducer/bundle/trusted/runtime-registry.ts +120 -0
  148. package/src/reducer/bundle/trusted/runtime-scope.ts +336 -0
  149. package/src/reducer/bundle/trusted/simultaneous-player.ts +97 -0
  150. package/src/reducer/bundle/trusted/stage-resolver.ts +87 -0
  151. package/src/reducer/bundle/trusted/static-projection.ts +116 -0
  152. package/src/reducer/bundle/trusted/trusted-runtime-args.ts +97 -0
  153. package/src/reducer/bundle/trusted/trusted-runtime-result.ts +39 -0
  154. package/src/reducer/bundle/trusted/trusted-setup-profiles.ts +43 -0
  155. package/src/reducer/bundle/trusted/trusted-state-codec.ts +48 -0
  156. package/src/reducer/bundle/trusted-bundle.ts +97 -0
  157. package/src/reducer/bundle/types.ts +171 -0
  158. package/src/reducer/bundle.ts +2 -0
  159. package/src/reducer/client-param-schemas.ts +57 -0
  160. package/src/reducer/compose.ts +34 -0
  161. package/src/reducer/core/runtime-input.ts +30 -0
  162. package/src/reducer/core/runtime-instruction.ts +59 -0
  163. package/src/reducer/core/types.ts +62 -0
  164. package/src/reducer/definition-index.ts +277 -0
  165. package/src/reducer/derived.ts +106 -0
  166. package/src/reducer/effects.ts +92 -0
  167. package/src/reducer/engine/runtime-instruction-engine.ts +155 -0
  168. package/src/reducer/ingress/decode-runtime-input.ts +7 -0
  169. package/src/reducer/ingress/decode-session-state.ts +9 -0
  170. package/src/reducer/ingress/encode-session-state.ts +6 -0
  171. package/src/reducer/ingress/input-codec.ts +18 -0
  172. package/src/reducer/ingress/phase-schemas.ts +62 -0
  173. package/src/reducer/ingress/raw-types.ts +107 -0
  174. package/src/reducer/ingress/runtime-codec.ts +14 -0
  175. package/src/reducer/ingress/runtime-payload.ts +13 -0
  176. package/src/reducer/ingress/session-codec.ts +392 -0
  177. package/src/reducer/ingress/types.ts +6 -0
  178. package/src/reducer/inputs/boardInput.ts +217 -0
  179. package/src/reducer/inputs/boardTarget.ts +190 -0
  180. package/src/reducer/inputs/cardInput.ts +86 -0
  181. package/src/reducer/inputs/cardTarget.ts +101 -0
  182. package/src/reducer/inputs/choiceTarget.ts +104 -0
  183. package/src/reducer/inputs/defineInputs.ts +71 -0
  184. package/src/reducer/inputs/formInput.ts +809 -0
  185. package/src/reducer/inputs/many.ts +120 -0
  186. package/src/reducer/inputs/promptInput.ts +87 -0
  187. package/src/reducer/inputs/rngInput.ts +58 -0
  188. package/src/reducer/inputs/targetRule.ts +123 -0
  189. package/src/reducer/inputs.ts +41 -0
  190. package/src/reducer/model/definition.ts +1072 -0
  191. package/src/reducer/model/extract.ts +745 -0
  192. package/src/reducer/model/manifest.ts +570 -0
  193. package/src/reducer/model/queries.ts +641 -0
  194. package/src/reducer/model/runtime.ts +264 -0
  195. package/src/reducer/model/spec.ts +1386 -0
  196. package/src/reducer/model/table.ts +260 -0
  197. package/src/reducer/model.ts +7 -0
  198. package/src/reducer/ops.ts +1034 -0
  199. package/src/reducer/parse-utils.ts +28 -0
  200. package/src/reducer/per-player.ts +422 -0
  201. package/src/reducer/rng.ts +69 -0
  202. package/src/reducer/schema-helpers.ts +185 -0
  203. package/src/reducer/setup-bootstrap-helpers.ts +171 -0
  204. package/src/reducer/setup-bootstrap.ts +481 -0
  205. package/src/reducer/table-ops.ts +2671 -0
  206. package/src/reducer/table-queries.ts +372 -0
  207. package/src/reducer/transaction.ts +120 -0
  208. package/src/reducer.ts +314 -0
  209. package/src/runtime/primitives.ts +1 -0
  210. package/src/runtime/types/runtime-api.ts +1 -0
  211. package/src/runtime/workspace-contract.ts +32 -0
  212. package/src/runtime-internal/components/InteractionForm.tsx +1309 -0
  213. package/src/runtime-internal/components/PluginRuntime.tsx +103 -0
  214. package/src/runtime-internal/components/board/target-layer.ts +70 -0
  215. package/src/runtime-internal/context/ClientParamSchemaContext.tsx +44 -0
  216. package/src/runtime-internal/context/InteractionDraftContext.tsx +279 -0
  217. package/src/runtime-internal/context/PluginSessionContext.tsx +47 -0
  218. package/src/runtime-internal/context/PluginStateContext.tsx +262 -0
  219. package/src/runtime-internal/context/RuntimeContext.tsx +96 -0
  220. package/src/runtime-internal/defaults/components.tsx +409 -0
  221. package/src/runtime-internal/defaults/index.ts +11 -0
  222. package/src/runtime-internal/errors/ValidationError.ts +29 -0
  223. package/src/runtime-internal/hooks/useActivePlayers.ts +33 -0
  224. package/src/runtime-internal/hooks/useBoardInteractions.ts +665 -0
  225. package/src/runtime-internal/hooks/useGameSelector.ts +105 -0
  226. package/src/runtime-internal/hooks/useGameView.ts +9 -0
  227. package/src/runtime-internal/hooks/useInteractionByKey.ts +354 -0
  228. package/src/runtime-internal/hooks/useInteractionHandle.ts +438 -0
  229. package/src/runtime-internal/hooks/useIsMyTurn.ts +20 -0
  230. package/src/runtime-internal/hooks/useLobby.ts +76 -0
  231. package/src/runtime-internal/hooks/useMe.ts +48 -0
  232. package/src/runtime-internal/hooks/usePlayerInfo.ts +28 -0
  233. package/src/runtime-internal/hooks/usePlayerTurnOrder.ts +23 -0
  234. package/src/runtime-internal/hooks/usePluginRuntime.ts +147 -0
  235. package/src/runtime-internal/hooks/useSeatInbox.ts +61 -0
  236. package/src/runtime-internal/hooks/useSimultaneousPhase.ts +10 -0
  237. package/src/runtime-internal/index.ts +42 -0
  238. package/src/runtime-internal/internal.ts +43 -0
  239. package/src/runtime-internal/plugin-styles.css +250 -0
  240. package/src/runtime-internal/primitives/board.tsx +459 -0
  241. package/src/runtime-internal/primitives/dialog-lifecycle.ts +58 -0
  242. package/src/runtime-internal/primitives/dice.tsx +79 -0
  243. package/src/runtime-internal/primitives/game-ui-provider.tsx +35 -0
  244. package/src/runtime-internal/primitives/game.tsx +387 -0
  245. package/src/runtime-internal/primitives/hand-intent-adapter.ts +147 -0
  246. package/src/runtime-internal/primitives/hand-surface.tsx +594 -0
  247. package/src/runtime-internal/primitives/index.ts +196 -0
  248. package/src/runtime-internal/primitives/interaction-form-binding.tsx +56 -0
  249. package/src/runtime-internal/primitives/interaction-submit.ts +90 -0
  250. package/src/runtime-internal/primitives/interaction.tsx +987 -0
  251. package/src/runtime-internal/primitives/phase.tsx +43 -0
  252. package/src/runtime-internal/primitives/player-roster.tsx +302 -0
  253. package/src/runtime-internal/primitives/primitive-props.tsx +101 -0
  254. package/src/runtime-internal/primitives/prompt.tsx +255 -0
  255. package/src/runtime-internal/primitives/ui.tsx +60 -0
  256. package/src/runtime-internal/primitives/zone.tsx +791 -0
  257. package/src/runtime-internal/reducer.ts +30 -0
  258. package/src/runtime-internal/runtime/createPluginRuntimeAPI.ts +605 -0
  259. package/src/runtime-internal/types/plugin-state.ts +508 -0
  260. package/src/runtime-internal/types/reducer-state.ts +24 -0
  261. package/src/runtime-internal/types/runtime-api.ts +114 -0
  262. package/src/runtime-internal/ui-contract.ts +519 -0
  263. package/src/runtime-internal/utils/card-intent-adapter.ts +546 -0
  264. package/src/runtime-internal/utils/interaction-inputs.ts +492 -0
  265. package/src/runtime-internal/utils/interaction-labels.ts +23 -0
  266. package/src/runtime-internal/utils/interaction-router.ts +273 -0
  267. package/src/runtime-internal/utils/interaction-status.ts +74 -0
  268. package/src/runtime-internal/workspace-contract.ts +1170 -0
  269. package/src/runtime.ts +34 -0
  270. package/src/testing/create-expect-api.ts +352 -0
  271. package/src/testing/create-test-runtime.ts +381 -0
  272. package/src/testing/definitions.ts +127 -0
  273. package/src/testing/index.ts +3 -0
  274. package/src/testing.ts +1 -0
  275. package/src/type-stubs/manifest-contract.d.ts +42 -0
  276. package/src/type-stubs/manifest-contract.js +72 -0
  277. package/src/type-stubs/ui-contract.d.ts +5 -0
  278. package/src/type-stubs/ui-contract.js +1 -0
  279. package/src/types/authoring-card-properties.type-test.ts +266 -0
  280. package/src/types/authoring.ts +1282 -0
  281. package/src/types/cards.ts +19 -0
  282. package/src/types/contracts.ts +1550 -0
  283. package/src/types/generated-helpers.ts +35 -0
  284. package/src/types/index.ts +147 -0
  285. package/src/types/slots.ts +11 -0
  286. package/src/types.ts +1 -0
  287. package/src/ui/components/ActionButton.tsx +97 -0
  288. package/src/ui/components/ActionPanel.tsx +315 -0
  289. package/src/ui/components/Card.tsx +378 -0
  290. package/src/ui/components/CardDragSurface.tsx +1076 -0
  291. package/src/ui/components/ChromeSuppressionContext.tsx +70 -0
  292. package/src/ui/components/CostDisplay.tsx +145 -0
  293. package/src/ui/components/DiceRoller.tsx +581 -0
  294. package/src/ui/components/Drawer.tsx +180 -0
  295. package/src/ui/components/ErrorBoundary.tsx +275 -0
  296. package/src/ui/components/GameEndDisplay.tsx +398 -0
  297. package/src/ui/components/GameSkeleton.tsx +260 -0
  298. package/src/ui/components/Hand.tsx +468 -0
  299. package/src/ui/components/HandDock.tsx +299 -0
  300. package/src/ui/components/HandView.tsx +441 -0
  301. package/src/ui/components/MobileHandTray.tsx +381 -0
  302. package/src/ui/components/MoreActions.tsx +143 -0
  303. package/src/ui/components/PhaseIndicator.tsx +341 -0
  304. package/src/ui/components/PlayArea.tsx +146 -0
  305. package/src/ui/components/PrimaryActionButton.tsx +336 -0
  306. package/src/ui/components/PrimaryButton.tsx +45 -0
  307. package/src/ui/components/ResourceCounter.tsx +270 -0
  308. package/src/ui/components/StagingZone.tsx +134 -0
  309. package/src/ui/components/ThemedButton.tsx +113 -0
  310. package/src/ui/components/Toast.tsx +264 -0
  311. package/src/ui/components/board/HexGrid.tsx +1294 -0
  312. package/src/ui/components/board/NetworkGraph.tsx +476 -0
  313. package/src/ui/components/board/SlotSystem.tsx +388 -0
  314. package/src/ui/components/board/SquareGrid.tsx +1165 -0
  315. package/src/ui/components/board/TrackBoard.tsx +496 -0
  316. package/src/ui/components/board/ZoneMap.tsx +448 -0
  317. package/src/ui/components/board/hex-board-view.ts +123 -0
  318. package/src/ui/components/board/index.ts +142 -0
  319. package/src/ui/components/board/interaction-accessibility.ts +21 -0
  320. package/src/ui/components/board/target-layer.ts +66 -0
  321. package/src/ui/components/card-render-content.type-test.ts +27 -0
  322. package/src/ui/components/hand-layout-math.ts +163 -0
  323. package/src/ui/components/hand-pointer-engine.ts +413 -0
  324. package/src/ui/components/index.ts +245 -0
  325. package/src/ui/components.ts +1 -0
  326. package/src/ui/defaults/components.tsx +106 -0
  327. package/src/ui/defaults/index.ts +8 -0
  328. package/src/ui/defaults.ts +1 -0
  329. package/src/ui/errors/ValidationError.ts +29 -0
  330. package/src/ui/helpers/cards.ts +19 -0
  331. package/src/ui/helpers/track-board.ts +211 -0
  332. package/src/ui/hooks/useBoardTopology.ts +316 -0
  333. package/src/ui/hooks/useCards.ts +10 -0
  334. package/src/ui/hooks/useHandCardPointer.ts +381 -0
  335. package/src/ui/hooks/useHandLayout.ts +378 -0
  336. package/src/ui/hooks/useHandPresentation.ts +121 -0
  337. package/src/ui/hooks/useHexBoard.ts +74 -0
  338. package/src/ui/hooks/useHexGrid.ts +185 -0
  339. package/src/ui/hooks/useIsMobile.ts +35 -0
  340. package/src/ui/hooks/usePanZoom.ts +278 -0
  341. package/src/ui/hooks/useSquareBoard.ts +124 -0
  342. package/src/ui/hooks/useSquareGrid.ts +328 -0
  343. package/src/ui/index.ts +98 -0
  344. package/src/ui/internal/ui/alert.tsx +51 -0
  345. package/src/ui/internal/ui/button.tsx +58 -0
  346. package/src/ui/internal/ui/dialog.tsx +134 -0
  347. package/src/ui/internal/ui/input.tsx +21 -0
  348. package/src/ui/internal/ui/label.tsx +21 -0
  349. package/src/ui/internal/ui/select.tsx +129 -0
  350. package/src/ui/internal/ui/tooltip.tsx +54 -0
  351. package/src/ui/internal/ui/utils.ts +5 -0
  352. package/src/ui/plugin-styles.css +250 -0
  353. package/src/ui/primitives/dialog-lifecycle.ts +58 -0
  354. package/src/ui/primitives/dice.tsx +79 -0
  355. package/src/ui/primitives/primitive-props.tsx +101 -0
  356. package/src/ui/theme/ThemeProvider.tsx +252 -0
  357. package/src/ui/theme/board.ts +61 -0
  358. package/src/ui/theme/css-vars.ts +105 -0
  359. package/src/ui/theme/derive.ts +240 -0
  360. package/src/ui/theme/index.ts +61 -0
  361. package/src/ui/theme/presets/arcade.ts +261 -0
  362. package/src/ui/theme/presets/studio.ts +261 -0
  363. package/src/ui/theme/presets/tabletop.ts +266 -0
  364. package/src/ui/theme/tokens.ts +392 -0
  365. package/src/ui/types/hex-color.ts +20 -0
  366. package/src/ui/types/player-state.ts +463 -0
  367. package/src/ui/types/tiled-board.ts +785 -0
  368. package/src/ui/types/visual-state.ts +137 -0
  369. package/src/ui.ts +1 -0
@@ -0,0 +1,262 @@
1
+ import {
2
+ default as React,
3
+ createContext,
4
+ useContext,
5
+ useState,
6
+ useEffect,
7
+ useMemo,
8
+ useSyncExternalStore,
9
+ } from "react";
10
+ import type { PluginStateSnapshot } from "../types/plugin-state.js";
11
+ import { useRuntimeContext } from "./RuntimeContext.js";
12
+ import type { PluginRuntimeAPI } from "../runtime/createPluginRuntimeAPI.js";
13
+
14
+ /**
15
+ * React Context for providing plugin state from state-sync messages.
16
+ * This is the new architecture where the host app maintains state and syncs to plugin.
17
+ */
18
+ const PluginStateContext = createContext<PluginStateSnapshot | null>(null);
19
+
20
+ /**
21
+ * Loading component shown while waiting for initial state
22
+ */
23
+ function DefaultLoadingScreen() {
24
+ return (
25
+ <div
26
+ style={{
27
+ display: "flex",
28
+ alignItems: "center",
29
+ justifyContent: "center",
30
+ height: "100%",
31
+ width: "100%",
32
+ color: "#666",
33
+ }}
34
+ >
35
+ <div style={{ textAlign: "center" }}>
36
+ <div
37
+ style={{
38
+ width: "40px",
39
+ height: "40px",
40
+ border: "3px solid #e0e0e0",
41
+ borderTopColor: "#666",
42
+ borderRadius: "50%",
43
+ animation: "spin 1s linear infinite",
44
+ margin: "0 auto 12px",
45
+ }}
46
+ />
47
+ <style>{`@keyframes spin { to { transform: rotate(360deg); } }`}</style>
48
+ <p>Loading game view...</p>
49
+ </div>
50
+ </div>
51
+ );
52
+ }
53
+
54
+ export interface PluginStateProviderProps {
55
+ children: React.ReactNode;
56
+ /**
57
+ * Custom loading component to show while waiting for state
58
+ * @default DefaultLoadingScreen
59
+ */
60
+ loadingComponent?: React.ReactNode;
61
+ }
62
+
63
+ /**
64
+ * PluginStateProvider subscribes to state-sync messages from the host
65
+ * and provides the state to child components via context.
66
+ *
67
+ * In the new architecture:
68
+ * - Host only renders authored game UI after state-sync begins
69
+ * - Plugin receives complete state in first state-sync message
70
+ * - No buffering or waiting needed - state is immediately available
71
+ *
72
+ * This replaces the complex usePluginRuntime hook which had:
73
+ * - waitForGameStart() promise handling
74
+ * - finishSetup() coordination with queueMicrotask
75
+ * - Error timeout handling
76
+ *
77
+ * @example
78
+ * ```tsx
79
+ * function PluginRoot() {
80
+ * return (
81
+ * <RuntimeProvider runtime={runtime}>
82
+ * <PluginStateProvider>
83
+ * <App />
84
+ * </PluginStateProvider>
85
+ * </RuntimeProvider>
86
+ * );
87
+ * }
88
+ * ```
89
+ */
90
+ export function PluginStateProvider({
91
+ children,
92
+ loadingComponent = <DefaultLoadingScreen />,
93
+ }: PluginStateProviderProps) {
94
+ const runtime = useRuntimeContext() as PluginRuntimeAPI;
95
+ const [state, setState] = useState<PluginStateSnapshot | null>(
96
+ () => runtime.getSnapshot?.() ?? null,
97
+ );
98
+
99
+ useEffect(() => {
100
+ // Get initial state if available
101
+ const initialState = runtime.getSnapshot?.();
102
+ if (initialState) {
103
+ setState(initialState);
104
+ }
105
+
106
+ // Subscribe to state changes
107
+ if (runtime.subscribeToState) {
108
+ return runtime.subscribeToState((newState) => {
109
+ setState(newState);
110
+ });
111
+ }
112
+
113
+ return () => {};
114
+ }, [runtime]);
115
+
116
+ // Don't render children until state is available
117
+ // In the new architecture, host guarantees state exists before rendering plugin
118
+ if (!state) {
119
+ return <>{loadingComponent}</>;
120
+ }
121
+
122
+ return (
123
+ <PluginStateContext.Provider value={state}>
124
+ {children}
125
+ </PluginStateContext.Provider>
126
+ );
127
+ }
128
+
129
+ /**
130
+ * Hook to access the full plugin state snapshot.
131
+ *
132
+ * @throws Error if used outside of PluginStateProvider
133
+ * @returns Current plugin state snapshot
134
+ *
135
+ * @example
136
+ * ```typescript
137
+ * function MyComponent() {
138
+ * const state = usePluginStateSnapshot();
139
+ * console.log('Current phase:', state.gameplay.currentPhase);
140
+ * }
141
+ * ```
142
+ */
143
+ export function usePluginStateSnapshot(): PluginStateSnapshot {
144
+ const state = useContext(PluginStateContext);
145
+
146
+ if (!state) {
147
+ throw new Error(
148
+ "usePluginStateSnapshot must be used within PluginStateProvider. " +
149
+ "Make sure you have wrapped your app with <PluginStateProvider>.",
150
+ );
151
+ }
152
+
153
+ return state;
154
+ }
155
+
156
+ /**
157
+ * Hook to select a specific part of the plugin state.
158
+ * Uses useSyncExternalStore for optimal performance - only re-renders
159
+ * when the selected value changes (using reference equality).
160
+ *
161
+ * @param selector - Function to select a part of the state
162
+ * @returns Selected value from state
163
+ *
164
+ * @example
165
+ * ```typescript
166
+ * // Only re-renders when gameplay.currentPhase changes
167
+ * function CurrentStateDisplay() {
168
+ * const currentState = usePluginState((s) => s.gameplay.currentPhase);
169
+ * return <div>State: {currentState}</div>;
170
+ * }
171
+ * ```
172
+ */
173
+ export function usePluginState<T>(
174
+ selector: (state: PluginStateSnapshot) => T,
175
+ ): T {
176
+ const runtime = useRuntimeContext() as PluginRuntimeAPI;
177
+
178
+ const subscribe = (onStoreChange: () => void) => {
179
+ if (!runtime.subscribeToState) {
180
+ return () => {};
181
+ }
182
+ return runtime.subscribeToState(() => {
183
+ onStoreChange();
184
+ });
185
+ };
186
+
187
+ const getSnapshot = () => {
188
+ const state = runtime.getSnapshot?.();
189
+ if (!state) {
190
+ throw new Error(
191
+ "usePluginState: No state available. " +
192
+ "Make sure you have wrapped your app with <PluginStateProvider>.",
193
+ );
194
+ }
195
+ return state;
196
+ };
197
+
198
+ const state = useSyncExternalStore(subscribe, getSnapshot, getSnapshot);
199
+ return useMemo(() => selector(state), [selector, state]);
200
+ }
201
+
202
+ /**
203
+ * Hook to access plugin actions (like marking notifications read).
204
+ *
205
+ * @returns Object with action functions
206
+ *
207
+ * @example
208
+ * ```typescript
209
+ * function NotificationsList() {
210
+ * const notifications = usePluginState((s) => s.notifications);
211
+ * const { markNotificationRead, switchPlayer } = usePluginActions();
212
+ *
213
+ * return (
214
+ * <ul>
215
+ * {notifications.map((n) => (
216
+ * <li key={n.id} onClick={() => markNotificationRead(n.id)}>
217
+ * {n.type}
218
+ * </li>
219
+ * ))}
220
+ * </ul>
221
+ * );
222
+ * }
223
+ * ```
224
+ */
225
+ export function usePluginActions(): {
226
+ markNotificationRead: (notificationId: string) => void;
227
+ switchPlayer: (playerId: string) => void;
228
+ submitInteraction: (
229
+ playerId: string,
230
+ interactionId: string,
231
+ params: unknown,
232
+ ) => Promise<void>;
233
+ } {
234
+ const runtime = useRuntimeContext() as PluginRuntimeAPI;
235
+
236
+ return {
237
+ /**
238
+ * Mark a notification as read.
239
+ * Sends message to host which updates the notification in GameSessionStore.
240
+ */
241
+ markNotificationRead: (notificationId: string) => {
242
+ window.parent.postMessage(
243
+ { type: "mark-notification-read", notificationId },
244
+ "*",
245
+ );
246
+ },
247
+
248
+ /**
249
+ * Switch to a different player (for users controlling multiple seats).
250
+ */
251
+ switchPlayer: (playerId: string) => {
252
+ runtime.switchPlayer?.(playerId);
253
+ },
254
+
255
+ /**
256
+ * Submit a player interaction (action or prompt response).
257
+ */
258
+ submitInteraction: runtime.submitInteraction,
259
+ };
260
+ }
261
+
262
+ export { PluginStateContext };
@@ -0,0 +1,96 @@
1
+ import React, { createContext, useContext, useState, useEffect } from "react";
2
+ import type { RuntimeAPI, PluginSessionState } from "../types/runtime-api.js";
3
+ import { PluginSessionContext } from "./PluginSessionContext.js";
4
+
5
+ /**
6
+ * React Context for providing RuntimeAPI to plugin components.
7
+ * This context must be provided by the plugin wrapper, not by the plugin code itself.
8
+ */
9
+ export const RuntimeContext = createContext<RuntimeAPI | null>(null);
10
+
11
+ /**
12
+ * Hook to access the RuntimeAPI from context.
13
+ *
14
+ * @throws Error if used outside of RuntimeContext.Provider
15
+ * @returns RuntimeAPI instance
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * function MyPluginComponent() {
20
+ * const runtime = useRuntimeContext();
21
+ * return (
22
+ * <button onClick={() => runtime.submitInteraction("player-1", "pass", {})}>
23
+ * Pass
24
+ * </button>
25
+ * );
26
+ * }
27
+ * ```
28
+ */
29
+ export function useRuntimeContext(): RuntimeAPI {
30
+ const context = useContext(RuntimeContext);
31
+
32
+ if (!context) {
33
+ throw new Error(
34
+ "useRuntimeContext must be used within a RuntimeContext.Provider",
35
+ );
36
+ }
37
+
38
+ return context;
39
+ }
40
+
41
+ /**
42
+ * RuntimeProvider component that provides both RuntimeAPI and PluginSessionContext.
43
+ * This component subscribes to session state changes from the RuntimeAPI and provides
44
+ * them through PluginSessionContext.
45
+ *
46
+ * @example
47
+ * ```tsx
48
+ * function PluginRoot() {
49
+ * const runtime = createPluginRuntimeAPI();
50
+ *
51
+ * return (
52
+ * <RuntimeProvider runtime={runtime}>
53
+ * <App />
54
+ * </RuntimeProvider>
55
+ * );
56
+ * }
57
+ * ```
58
+ */
59
+ export function RuntimeProvider({
60
+ runtime,
61
+ children,
62
+ }: {
63
+ runtime: RuntimeAPI;
64
+ children: React.ReactNode;
65
+ }) {
66
+ // Subscribe to session state changes
67
+ const [sessionState, setSessionState] = useState<PluginSessionState>(() =>
68
+ runtime.getSessionState(),
69
+ );
70
+
71
+ useEffect(() => {
72
+ // Subscribe to session state changes via internal API
73
+ const runtimeWithInternal = runtime as RuntimeAPI & {
74
+ _subscribeToSessionState?: (
75
+ listener: (state: PluginSessionState) => void,
76
+ ) => () => void;
77
+ };
78
+
79
+ if (runtimeWithInternal._subscribeToSessionState) {
80
+ return runtimeWithInternal._subscribeToSessionState((state) => {
81
+ setSessionState(state);
82
+ });
83
+ }
84
+
85
+ // Fallback: no session state subscription available
86
+ return () => {};
87
+ }, [runtime]);
88
+
89
+ return (
90
+ <RuntimeContext.Provider value={runtime}>
91
+ <PluginSessionContext.Provider value={sessionState}>
92
+ {children}
93
+ </PluginSessionContext.Provider>
94
+ </RuntimeContext.Provider>
95
+ );
96
+ }