@dreamboard-games/ui-sdk 0.0.41
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +89 -0
- package/NOTICE +1 -0
- package/README.md +154 -0
- package/dist/components/ActionButton.d.ts +13 -0
- package/dist/components/ActionButton.d.ts.map +1 -0
- package/dist/components/ActionButton.js +14 -0
- package/dist/components/ActionPanel.d.ts +33 -0
- package/dist/components/ActionPanel.d.ts.map +1 -0
- package/dist/components/ActionPanel.js +148 -0
- package/dist/components/Card.d.ts +29 -0
- package/dist/components/Card.d.ts.map +1 -0
- package/dist/components/Card.js +220 -0
- package/dist/components/ChromeSuppressionContext.d.ts +7 -0
- package/dist/components/ChromeSuppressionContext.d.ts.map +1 -0
- package/dist/components/ChromeSuppressionContext.js +34 -0
- package/dist/components/CostDisplay.d.ts +22 -0
- package/dist/components/CostDisplay.d.ts.map +1 -0
- package/dist/components/CostDisplay.js +41 -0
- package/dist/components/DiceRoller.d.ts +30 -0
- package/dist/components/DiceRoller.d.ts.map +1 -0
- package/dist/components/DiceRoller.js +319 -0
- package/dist/components/Drawer.d.ts +19 -0
- package/dist/components/Drawer.d.ts.map +1 -0
- package/dist/components/Drawer.js +55 -0
- package/dist/components/ErrorBoundary.d.ts +24 -0
- package/dist/components/ErrorBoundary.d.ts.map +1 -0
- package/dist/components/ErrorBoundary.js +37 -0
- package/dist/components/GameEndDisplay.d.ts +27 -0
- package/dist/components/GameEndDisplay.d.ts.map +1 -0
- package/dist/components/GameEndDisplay.js +185 -0
- package/dist/components/GameSkeleton.d.ts +12 -0
- package/dist/components/GameSkeleton.d.ts.map +1 -0
- package/dist/components/GameSkeleton.js +54 -0
- package/dist/components/Hand.d.ts +99 -0
- package/dist/components/Hand.d.ts.map +1 -0
- package/dist/components/Hand.js +162 -0
- package/dist/components/HandDock.d.ts +35 -0
- package/dist/components/HandDock.d.ts.map +1 -0
- package/dist/components/HandDock.js +124 -0
- package/dist/components/InteractionForm.d.ts +50 -0
- package/dist/components/InteractionForm.d.ts.map +1 -0
- package/dist/components/InteractionForm.js +402 -0
- package/dist/components/MoreActions.d.ts +49 -0
- package/dist/components/MoreActions.d.ts.map +1 -0
- package/dist/components/MoreActions.js +64 -0
- package/dist/components/PhaseIndicator.d.ts +35 -0
- package/dist/components/PhaseIndicator.d.ts.map +1 -0
- package/dist/components/PhaseIndicator.js +212 -0
- package/dist/components/PlayArea.d.ts +28 -0
- package/dist/components/PlayArea.d.ts.map +1 -0
- package/dist/components/PlayArea.js +48 -0
- package/dist/components/PluginRuntime.d.ts +37 -0
- package/dist/components/PluginRuntime.d.ts.map +1 -0
- package/dist/components/PluginRuntime.js +47 -0
- package/dist/components/PrimaryActionButton.d.ts +98 -0
- package/dist/components/PrimaryActionButton.d.ts.map +1 -0
- package/dist/components/PrimaryActionButton.js +183 -0
- package/dist/components/PrimaryButton.d.ts +20 -0
- package/dist/components/PrimaryButton.d.ts.map +1 -0
- package/dist/components/PrimaryButton.js +5 -0
- package/dist/components/PromptDialogHost.d.ts +15 -0
- package/dist/components/PromptDialogHost.d.ts.map +1 -0
- package/dist/components/PromptDialogHost.js +22 -0
- package/dist/components/ResourceCounter.d.ts +38 -0
- package/dist/components/ResourceCounter.d.ts.map +1 -0
- package/dist/components/ResourceCounter.js +118 -0
- package/dist/components/ThemedButton.d.ts +12 -0
- package/dist/components/ThemedButton.d.ts.map +1 -0
- package/dist/components/ThemedButton.js +38 -0
- package/dist/components/Toast.d.ts +35 -0
- package/dist/components/Toast.d.ts.map +1 -0
- package/dist/components/Toast.js +116 -0
- package/dist/components/board/HexGrid.d.ts +344 -0
- package/dist/components/board/HexGrid.d.ts.map +1 -0
- package/dist/components/board/HexGrid.js +340 -0
- package/dist/components/board/NetworkGraph.d.ts +100 -0
- package/dist/components/board/NetworkGraph.d.ts.map +1 -0
- package/dist/components/board/NetworkGraph.js +123 -0
- package/dist/components/board/SlotSystem.d.ts +71 -0
- package/dist/components/board/SlotSystem.d.ts.map +1 -0
- package/dist/components/board/SlotSystem.js +87 -0
- package/dist/components/board/SquareGrid.d.ts +188 -0
- package/dist/components/board/SquareGrid.d.ts.map +1 -0
- package/dist/components/board/SquareGrid.js +328 -0
- package/dist/components/board/TrackBoard.d.ts +113 -0
- package/dist/components/board/TrackBoard.d.ts.map +1 -0
- package/dist/components/board/TrackBoard.js +135 -0
- package/dist/components/board/ZoneMap.d.ts +88 -0
- package/dist/components/board/ZoneMap.d.ts.map +1 -0
- package/dist/components/board/ZoneMap.js +133 -0
- package/dist/components/board/hex-board-view.d.ts +69 -0
- package/dist/components/board/hex-board-view.d.ts.map +1 -0
- package/dist/components/board/hex-board-view.js +60 -0
- package/dist/components/board/index.d.ts +23 -0
- package/dist/components/board/index.d.ts.map +1 -0
- package/dist/components/board/index.js +40 -0
- package/dist/components/board/interaction-accessibility.d.ts +5 -0
- package/dist/components/board/interaction-accessibility.d.ts.map +1 -0
- package/dist/components/board/interaction-accessibility.js +13 -0
- package/dist/components/board/target-layer.d.ts +13 -0
- package/dist/components/board/target-layer.d.ts.map +1 -0
- package/dist/components/board/target-layer.js +10 -0
- package/dist/components/card-render-content.type-test.d.ts +2 -0
- package/dist/components/card-render-content.type-test.d.ts.map +1 -0
- package/dist/components/card-render-content.type-test.js +1 -0
- package/dist/components/index.d.ts +34 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +35 -0
- package/dist/components/interaction-dialog-behavior.d.ts +15 -0
- package/dist/components/interaction-dialog-behavior.d.ts.map +1 -0
- package/dist/components/interaction-dialog-behavior.js +9 -0
- package/dist/components/surfaces/BlockerSurface.d.ts +27 -0
- package/dist/components/surfaces/BlockerSurface.d.ts.map +1 -0
- package/dist/components/surfaces/BlockerSurface.js +38 -0
- package/dist/components/surfaces/BoardSurface.d.ts +77 -0
- package/dist/components/surfaces/BoardSurface.d.ts.map +1 -0
- package/dist/components/surfaces/BoardSurface.js +180 -0
- package/dist/components/surfaces/ChromeSurface.d.ts +29 -0
- package/dist/components/surfaces/ChromeSurface.d.ts.map +1 -0
- package/dist/components/surfaces/ChromeSurface.js +34 -0
- package/dist/components/surfaces/ExhaustivenessAudit.d.ts +32 -0
- package/dist/components/surfaces/ExhaustivenessAudit.d.ts.map +1 -0
- package/dist/components/surfaces/ExhaustivenessAudit.js +65 -0
- package/dist/components/surfaces/InboxSurface.d.ts +40 -0
- package/dist/components/surfaces/InboxSurface.d.ts.map +1 -0
- package/dist/components/surfaces/InboxSurface.js +99 -0
- package/dist/components/surfaces/MarketSurface.d.ts +62 -0
- package/dist/components/surfaces/MarketSurface.d.ts.map +1 -0
- package/dist/components/surfaces/MarketSurface.js +242 -0
- package/dist/components/surfaces/PanelSurface.d.ts +111 -0
- package/dist/components/surfaces/PanelSurface.d.ts.map +1 -0
- package/dist/components/surfaces/PanelSurface.js +180 -0
- package/dist/components/surfaces/PlayerCardsSurface.d.ts +104 -0
- package/dist/components/surfaces/PlayerCardsSurface.d.ts.map +1 -0
- package/dist/components/surfaces/PlayerCardsSurface.js +178 -0
- package/dist/components/surfaces/internal/CardZoneFollowUpForm.d.ts +7 -0
- package/dist/components/surfaces/internal/CardZoneFollowUpForm.d.ts.map +1 -0
- package/dist/components/surfaces/internal/CardZoneFollowUpForm.js +9 -0
- package/dist/components/surfaces/internal/DefaultInteractionButton.d.ts +71 -0
- package/dist/components/surfaces/internal/DefaultInteractionButton.d.ts.map +1 -0
- package/dist/components/surfaces/internal/DefaultInteractionButton.js +82 -0
- package/dist/components/surfaces/internal/useCardZoneInteractions.d.ts +21 -0
- package/dist/components/surfaces/internal/useCardZoneInteractions.d.ts.map +1 -0
- package/dist/components/surfaces/internal/useCardZoneInteractions.js +202 -0
- package/dist/components/surfaces/types.d.ts +59 -0
- package/dist/components/surfaces/types.d.ts.map +1 -0
- package/dist/components/surfaces/types.js +1 -0
- package/dist/context/ClientParamSchemaContext.d.ts +21 -0
- package/dist/context/ClientParamSchemaContext.d.ts.map +1 -0
- package/dist/context/ClientParamSchemaContext.js +12 -0
- package/dist/context/InteractionDraftContext.d.ts +69 -0
- package/dist/context/InteractionDraftContext.d.ts.map +1 -0
- package/dist/context/InteractionDraftContext.js +145 -0
- package/dist/context/PluginSessionContext.d.ts +33 -0
- package/dist/context/PluginSessionContext.d.ts.map +1 -0
- package/dist/context/PluginSessionContext.js +38 -0
- package/dist/context/PluginStateContext.d.ts +116 -0
- package/dist/context/PluginStateContext.d.ts.map +1 -0
- package/dist/context/PluginStateContext.js +186 -0
- package/dist/context/RuntimeContext.d.ts +49 -0
- package/dist/context/RuntimeContext.d.ts.map +1 -0
- package/dist/context/RuntimeContext.js +67 -0
- package/dist/defaults/components.d.ts +52 -0
- package/dist/defaults/components.d.ts.map +1 -0
- package/dist/defaults/components.js +159 -0
- package/dist/defaults/index.d.ts +2 -0
- package/dist/defaults/index.d.ts.map +1 -0
- package/dist/defaults/index.js +1 -0
- package/dist/errors/ValidationError.d.ts +10 -0
- package/dist/errors/ValidationError.d.ts.map +1 -0
- package/dist/errors/ValidationError.js +23 -0
- package/dist/helpers/cards.d.ts +3 -0
- package/dist/helpers/cards.d.ts.map +1 -0
- package/dist/helpers/cards.js +11 -0
- package/dist/helpers/track-board.d.ts +79 -0
- package/dist/helpers/track-board.d.ts.map +1 -0
- package/dist/helpers/track-board.js +56 -0
- package/dist/hooks/useActivePlayers.d.ts +16 -0
- package/dist/hooks/useActivePlayers.d.ts.map +1 -0
- package/dist/hooks/useActivePlayers.js +17 -0
- package/dist/hooks/useBoardInteractions.d.ts +110 -0
- package/dist/hooks/useBoardInteractions.d.ts.map +1 -0
- package/dist/hooks/useBoardInteractions.js +248 -0
- package/dist/hooks/useBoardTopology.d.ts +23 -0
- package/dist/hooks/useBoardTopology.d.ts.map +1 -0
- package/dist/hooks/useBoardTopology.js +128 -0
- package/dist/hooks/useCards.d.ts +3 -0
- package/dist/hooks/useCards.d.ts.map +1 -0
- package/dist/hooks/useCards.js +5 -0
- package/dist/hooks/useGameSelector.d.ts +13 -0
- package/dist/hooks/useGameSelector.d.ts.map +1 -0
- package/dist/hooks/useGameSelector.js +67 -0
- package/dist/hooks/useGameView.d.ts +6 -0
- package/dist/hooks/useGameView.d.ts.map +1 -0
- package/dist/hooks/useGameView.js +7 -0
- package/dist/hooks/useHandLayout.d.ts +120 -0
- package/dist/hooks/useHandLayout.d.ts.map +1 -0
- package/dist/hooks/useHandLayout.js +235 -0
- package/dist/hooks/useHexBoard.d.ts +19 -0
- package/dist/hooks/useHexBoard.d.ts.map +1 -0
- package/dist/hooks/useHexBoard.js +28 -0
- package/dist/hooks/useHexGrid.d.ts +56 -0
- package/dist/hooks/useHexGrid.d.ts.map +1 -0
- package/dist/hooks/useHexGrid.js +112 -0
- package/dist/hooks/useInteractionByKey.d.ts +29 -0
- package/dist/hooks/useInteractionByKey.d.ts.map +1 -0
- package/dist/hooks/useInteractionByKey.js +263 -0
- package/dist/hooks/useInteractionHandle.d.ts +103 -0
- package/dist/hooks/useInteractionHandle.d.ts.map +1 -0
- package/dist/hooks/useInteractionHandle.js +254 -0
- package/dist/hooks/useIsMobile.d.ts +7 -0
- package/dist/hooks/useIsMobile.d.ts.map +1 -0
- package/dist/hooks/useIsMobile.js +29 -0
- package/dist/hooks/useIsMyTurn.d.ts +6 -0
- package/dist/hooks/useIsMyTurn.d.ts.map +1 -0
- package/dist/hooks/useIsMyTurn.js +11 -0
- package/dist/hooks/useLobby.d.ts +28 -0
- package/dist/hooks/useLobby.d.ts.map +1 -0
- package/dist/hooks/useLobby.js +60 -0
- package/dist/hooks/useMe.d.ts +11 -0
- package/dist/hooks/useMe.d.ts.map +1 -0
- package/dist/hooks/useMe.js +32 -0
- package/dist/hooks/usePanZoom.d.ts +113 -0
- package/dist/hooks/usePanZoom.d.ts.map +1 -0
- package/dist/hooks/usePanZoom.js +165 -0
- package/dist/hooks/usePlayerInfo.d.ts +4 -0
- package/dist/hooks/usePlayerInfo.d.ts.map +1 -0
- package/dist/hooks/usePlayerInfo.js +21 -0
- package/dist/hooks/usePlayerTurnOrder.d.ts +15 -0
- package/dist/hooks/usePlayerTurnOrder.d.ts.map +1 -0
- package/dist/hooks/usePlayerTurnOrder.js +22 -0
- package/dist/hooks/usePluginRuntime.d.ts +45 -0
- package/dist/hooks/usePluginRuntime.d.ts.map +1 -0
- package/dist/hooks/usePluginRuntime.js +92 -0
- package/dist/hooks/useSeatInbox.d.ts +22 -0
- package/dist/hooks/useSeatInbox.d.ts.map +1 -0
- package/dist/hooks/useSeatInbox.js +43 -0
- package/dist/hooks/useSimultaneousPhase.d.ts +7 -0
- package/dist/hooks/useSimultaneousPhase.d.ts.map +1 -0
- package/dist/hooks/useSimultaneousPhase.js +8 -0
- package/dist/hooks/useSquareBoard.d.ts +21 -0
- package/dist/hooks/useSquareBoard.d.ts.map +1 -0
- package/dist/hooks/useSquareBoard.js +67 -0
- package/dist/hooks/useSquareGrid.d.ts +96 -0
- package/dist/hooks/useSquareGrid.d.ts.map +1 -0
- package/dist/hooks/useSquareGrid.js +152 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +20 -0
- package/dist/internal/ui/alert.d.ts +8 -0
- package/dist/internal/ui/alert.d.ts.map +1 -0
- package/dist/internal/ui/alert.js +11 -0
- package/dist/internal/ui/button.d.ts +10 -0
- package/dist/internal/ui/button.d.ts.map +1 -0
- package/dist/internal/ui/button.js +21 -0
- package/dist/internal/ui/dialog.d.ts +16 -0
- package/dist/internal/ui/dialog.d.ts.map +1 -0
- package/dist/internal/ui/dialog.js +35 -0
- package/dist/internal/ui/input.d.ts +3 -0
- package/dist/internal/ui/input.d.ts.map +1 -0
- package/dist/internal/ui/input.js +5 -0
- package/dist/internal/ui/label.d.ts +4 -0
- package/dist/internal/ui/label.d.ts.map +1 -0
- package/dist/internal/ui/label.js +7 -0
- package/dist/internal/ui/select.d.ts +9 -0
- package/dist/internal/ui/select.d.ts.map +1 -0
- package/dist/internal/ui/select.js +23 -0
- package/dist/internal/ui/tooltip.d.ts +7 -0
- package/dist/internal/ui/tooltip.d.ts.map +1 -0
- package/dist/internal/ui/tooltip.js +16 -0
- package/dist/internal/ui/utils.d.ts +3 -0
- package/dist/internal/ui/utils.d.ts.map +1 -0
- package/dist/internal/ui/utils.js +4 -0
- package/dist/internal.d.ts +7 -0
- package/dist/internal.d.ts.map +1 -0
- package/dist/internal.js +4 -0
- package/dist/plugin-styles.css +246 -0
- package/dist/primitives/board.d.ts +29 -0
- package/dist/primitives/board.d.ts.map +1 -0
- package/dist/primitives/board.js +163 -0
- package/dist/primitives/game-ui-provider.d.ts +12 -0
- package/dist/primitives/game-ui-provider.d.ts.map +1 -0
- package/dist/primitives/game-ui-provider.js +7 -0
- package/dist/primitives/index.d.ts +8 -0
- package/dist/primitives/index.d.ts.map +1 -0
- package/dist/primitives/index.js +7 -0
- package/dist/primitives/interaction.d.ts +52 -0
- package/dist/primitives/interaction.d.ts.map +1 -0
- package/dist/primitives/interaction.js +250 -0
- package/dist/primitives/phase.d.ts +15 -0
- package/dist/primitives/phase.d.ts.map +1 -0
- package/dist/primitives/phase.js +18 -0
- package/dist/primitives/player-roster.d.ts +64 -0
- package/dist/primitives/player-roster.d.ts.map +1 -0
- package/dist/primitives/player-roster.js +149 -0
- package/dist/primitives/primitive-props.d.ts +15 -0
- package/dist/primitives/primitive-props.d.ts.map +1 -0
- package/dist/primitives/primitive-props.js +39 -0
- package/dist/primitives/prompt.d.ts +44 -0
- package/dist/primitives/prompt.d.ts.map +1 -0
- package/dist/primitives/prompt.js +101 -0
- package/dist/primitives/zone.d.ts +31 -0
- package/dist/primitives/zone.d.ts.map +1 -0
- package/dist/primitives/zone.js +58 -0
- package/dist/reducer.d.ts +21 -0
- package/dist/reducer.d.ts.map +1 -0
- package/dist/reducer.js +14 -0
- package/dist/runtime/createPluginRuntimeAPI.d.ts +67 -0
- package/dist/runtime/createPluginRuntimeAPI.d.ts.map +1 -0
- package/dist/runtime/createPluginRuntimeAPI.js +419 -0
- package/dist/theme/ThemeProvider.d.ts +98 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +148 -0
- package/dist/theme/board.d.ts +42 -0
- package/dist/theme/board.d.ts.map +1 -0
- package/dist/theme/board.js +34 -0
- package/dist/theme/css-vars.d.ts +31 -0
- package/dist/theme/css-vars.d.ts.map +1 -0
- package/dist/theme/css-vars.js +88 -0
- package/dist/theme/derive.d.ts +66 -0
- package/dist/theme/derive.d.ts.map +1 -0
- package/dist/theme/derive.js +161 -0
- package/dist/theme/index.d.ts +22 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +20 -0
- package/dist/theme/presets/arcade.d.ts +10 -0
- package/dist/theme/presets/arcade.d.ts.map +1 -0
- package/dist/theme/presets/arcade.js +257 -0
- package/dist/theme/presets/studio.d.ts +10 -0
- package/dist/theme/presets/studio.d.ts.map +1 -0
- package/dist/theme/presets/studio.js +257 -0
- package/dist/theme/presets/tabletop.d.ts +15 -0
- package/dist/theme/presets/tabletop.d.ts.map +1 -0
- package/dist/theme/presets/tabletop.js +262 -0
- package/dist/theme/tokens.d.ts +345 -0
- package/dist/theme/tokens.d.ts.map +1 -0
- package/dist/theme/tokens.js +57 -0
- package/dist/types/player-state.d.ts +337 -0
- package/dist/types/player-state.d.ts.map +1 -0
- package/dist/types/player-state.js +1 -0
- package/dist/types/plugin-state.d.ts +324 -0
- package/dist/types/plugin-state.d.ts.map +1 -0
- package/dist/types/plugin-state.js +1 -0
- package/dist/types/reducer-state.d.ts +10 -0
- package/dist/types/reducer-state.d.ts.map +1 -0
- package/dist/types/reducer-state.js +1 -0
- package/dist/types/runtime-api.d.ts +99 -0
- package/dist/types/runtime-api.d.ts.map +1 -0
- package/dist/types/runtime-api.js +1 -0
- package/dist/types/tiled-board.d.ts +187 -0
- package/dist/types/tiled-board.d.ts.map +1 -0
- package/dist/types/tiled-board.js +226 -0
- package/dist/ui-contract.d.ts +78 -0
- package/dist/ui-contract.d.ts.map +1 -0
- package/dist/ui-contract.js +15 -0
- package/dist/ui-sdk.d.ts +3409 -0
- package/dist/utils/interaction-inputs.d.ts +22 -0
- package/dist/utils/interaction-inputs.d.ts.map +1 -0
- package/dist/utils/interaction-inputs.js +219 -0
- package/dist/utils/interaction-labels.d.ts +4 -0
- package/dist/utils/interaction-labels.d.ts.map +1 -0
- package/dist/utils/interaction-labels.js +18 -0
- package/dist/utils/interaction-status.d.ts +15 -0
- package/dist/utils/interaction-status.d.ts.map +1 -0
- package/dist/utils/interaction-status.js +31 -0
- package/package.json +101 -0
- package/src/components/ActionButton.tsx +48 -0
- package/src/components/ActionPanel.tsx +310 -0
- package/src/components/Card.tsx +385 -0
- package/src/components/ChromeSuppressionContext.tsx +70 -0
- package/src/components/CostDisplay.test.tsx +23 -0
- package/src/components/CostDisplay.tsx +145 -0
- package/src/components/DiceRoller.tsx +601 -0
- package/src/components/Drawer.tsx +179 -0
- package/src/components/ErrorBoundary.tsx +119 -0
- package/src/components/GameEndDisplay.test.tsx +19 -0
- package/src/components/GameEndDisplay.tsx +398 -0
- package/src/components/GameSkeleton.tsx +260 -0
- package/src/components/Hand.tsx +387 -0
- package/src/components/HandDock.tsx +257 -0
- package/src/components/InteractionForm.test.tsx +303 -0
- package/src/components/InteractionForm.tsx +1029 -0
- package/src/components/MoreActions.test.tsx +93 -0
- package/src/components/MoreActions.tsx +143 -0
- package/src/components/PhaseIndicator.tsx +341 -0
- package/src/components/PlayArea.tsx +125 -0
- package/src/components/PluginRuntime.tsx +92 -0
- package/src/components/PrimaryActionButton.test.tsx +138 -0
- package/src/components/PrimaryActionButton.tsx +351 -0
- package/src/components/PrimaryButton.tsx +44 -0
- package/src/components/PromptDialogHost.tsx +92 -0
- package/src/components/ResourceCounter.test.tsx +29 -0
- package/src/components/ResourceCounter.tsx +275 -0
- package/src/components/ThemedButton.tsx +78 -0
- package/src/components/Toast.tsx +251 -0
- package/src/components/__fixtures__/ActionButton.fixture.tsx +234 -0
- package/src/components/__fixtures__/ActionPanel.fixture.tsx +298 -0
- package/src/components/__fixtures__/Card.fixture.tsx +185 -0
- package/src/components/__fixtures__/CostDisplay.fixture.tsx +156 -0
- package/src/components/__fixtures__/DiceRoller.fixture.tsx +435 -0
- package/src/components/__fixtures__/Drawer.fixture.tsx +113 -0
- package/src/components/__fixtures__/ErrorBoundary.fixture.tsx +82 -0
- package/src/components/__fixtures__/GameEndDisplay.fixture.tsx +188 -0
- package/src/components/__fixtures__/GameSkeleton.fixture.tsx +46 -0
- package/src/components/__fixtures__/Hand.fixture.tsx +522 -0
- package/src/components/__fixtures__/HexGrid.fixture.tsx +1181 -0
- package/src/components/__fixtures__/NetworkGraph.fixture.tsx +599 -0
- package/src/components/__fixtures__/PhaseIndicator.fixture.tsx +181 -0
- package/src/components/__fixtures__/PlayArea.fixture.tsx +221 -0
- package/src/components/__fixtures__/ResourceCounter.fixture.tsx +227 -0
- package/src/components/__fixtures__/SlotSystem.fixture.tsx +824 -0
- package/src/components/__fixtures__/SquareGrid.fixture.tsx +764 -0
- package/src/components/__fixtures__/Toast.fixture.tsx +97 -0
- package/src/components/__fixtures__/TrackBoard.fixture.tsx +685 -0
- package/src/components/__fixtures__/ZoneMap.fixture.tsx +754 -0
- package/src/components/board/HexGrid.tsx +1294 -0
- package/src/components/board/NetworkGraph.tsx +476 -0
- package/src/components/board/SlotSystem.tsx +339 -0
- package/src/components/board/SquareGrid.tsx +1165 -0
- package/src/components/board/TrackBoard.tsx +496 -0
- package/src/components/board/ZoneMap.tsx +448 -0
- package/src/components/board/hex-board-view.test.tsx +114 -0
- package/src/components/board/hex-board-view.ts +123 -0
- package/src/components/board/index.ts +142 -0
- package/src/components/board/interaction-accessibility.ts +21 -0
- package/src/components/board/target-layer-grids.test.tsx +420 -0
- package/src/components/board/target-layer.ts +30 -0
- package/src/components/card-render-content.type-test.ts +27 -0
- package/src/components/index.ts +208 -0
- package/src/components/interaction-dialog-behavior.test.ts +23 -0
- package/src/components/interaction-dialog-behavior.ts +22 -0
- package/src/components/surfaces/BlockerSurface.test.tsx +158 -0
- package/src/components/surfaces/BlockerSurface.tsx +127 -0
- package/src/components/surfaces/BoardSurface.tsx +340 -0
- package/src/components/surfaces/ChromeSurface.tsx +123 -0
- package/src/components/surfaces/ExhaustivenessAudit.tsx +91 -0
- package/src/components/surfaces/InboxSurface.test.tsx +149 -0
- package/src/components/surfaces/InboxSurface.tsx +245 -0
- package/src/components/surfaces/MarketSurface.tsx +544 -0
- package/src/components/surfaces/PanelSurface.test.tsx +496 -0
- package/src/components/surfaces/PanelSurface.tsx +458 -0
- package/src/components/surfaces/PlayerCardsSurface.tsx +525 -0
- package/src/components/surfaces/internal/CardZoneFollowUpForm.tsx +35 -0
- package/src/components/surfaces/internal/DefaultInteractionButton.tsx +219 -0
- package/src/components/surfaces/internal/useCardZoneInteractions.ts +311 -0
- package/src/components/surfaces/types.ts +100 -0
- package/src/context/ClientParamSchemaContext.tsx +44 -0
- package/src/context/InteractionDraftContext.tsx +204 -0
- package/src/context/PluginSessionContext.tsx +47 -0
- package/src/context/PluginStateContext.tsx +254 -0
- package/src/context/RuntimeContext.tsx +96 -0
- package/src/defaults/components.tsx +442 -0
- package/src/defaults/defaults.test.tsx +230 -0
- package/src/defaults/index.ts +1 -0
- package/src/errors/ValidationError.ts +29 -0
- package/src/helpers/cards.ts +19 -0
- package/src/helpers/track-board.ts +211 -0
- package/src/hooks/useActivePlayers.ts +19 -0
- package/src/hooks/useBoardInteractions.test.tsx +622 -0
- package/src/hooks/useBoardInteractions.ts +434 -0
- package/src/hooks/useBoardTopology.ts +316 -0
- package/src/hooks/useCards.test.tsx +129 -0
- package/src/hooks/useCards.ts +10 -0
- package/src/hooks/useGameSelector.ts +105 -0
- package/src/hooks/useGameView.ts +9 -0
- package/src/hooks/useHandLayout.ts +349 -0
- package/src/hooks/useHexBoard.ts +74 -0
- package/src/hooks/useHexGrid.ts +185 -0
- package/src/hooks/useInteractionByKey.ts +349 -0
- package/src/hooks/useInteractionHandle.ts +437 -0
- package/src/hooks/useIsMobile.ts +35 -0
- package/src/hooks/useIsMyTurn.test.tsx +99 -0
- package/src/hooks/useIsMyTurn.ts +15 -0
- package/src/hooks/useLobby.ts +76 -0
- package/src/hooks/useMe.ts +48 -0
- package/src/hooks/usePanZoom.ts +278 -0
- package/src/hooks/usePlayerInfo.ts +28 -0
- package/src/hooks/usePlayerTurnOrder.ts +23 -0
- package/src/hooks/usePluginRuntime.test.tsx +102 -0
- package/src/hooks/usePluginRuntime.ts +130 -0
- package/src/hooks/useSeatInbox.ts +61 -0
- package/src/hooks/useSimultaneousPhase.ts +10 -0
- package/src/hooks/useSquareBoard.ts +124 -0
- package/src/hooks/useSquareGrid.ts +328 -0
- package/src/index.test.ts +474 -0
- package/src/index.ts +148 -0
- package/src/internal/ui/alert.tsx +51 -0
- package/src/internal/ui/button.tsx +58 -0
- package/src/internal/ui/dialog.tsx +134 -0
- package/src/internal/ui/input.tsx +21 -0
- package/src/internal/ui/label.tsx +21 -0
- package/src/internal/ui/select.tsx +129 -0
- package/src/internal/ui/tooltip.tsx +54 -0
- package/src/internal/ui/utils.ts +5 -0
- package/src/internal.ts +18 -0
- package/src/plugin-styles.css +246 -0
- package/src/primitives/board.test.tsx +139 -0
- package/src/primitives/board.tsx +267 -0
- package/src/primitives/game-ui-provider.tsx +35 -0
- package/src/primitives/index.ts +83 -0
- package/src/primitives/interaction.test.tsx +420 -0
- package/src/primitives/interaction.tsx +405 -0
- package/src/primitives/phase.test.tsx +82 -0
- package/src/primitives/phase.tsx +43 -0
- package/src/primitives/player-roster.test.tsx +168 -0
- package/src/primitives/player-roster.tsx +301 -0
- package/src/primitives/primitive-props.tsx +82 -0
- package/src/primitives/prompt.test.tsx +159 -0
- package/src/primitives/prompt.tsx +203 -0
- package/src/primitives/zone.tsx +113 -0
- package/src/reducer.ts +42 -0
- package/src/runtime/createPluginRuntimeAPI.ts +605 -0
- package/src/theme/ThemeProvider.test.tsx +36 -0
- package/src/theme/ThemeProvider.tsx +252 -0
- package/src/theme/board.ts +61 -0
- package/src/theme/css-vars.ts +105 -0
- package/src/theme/derive.ts +240 -0
- package/src/theme/index.ts +61 -0
- package/src/theme/presets/arcade.ts +261 -0
- package/src/theme/presets/studio.ts +261 -0
- package/src/theme/presets/tabletop.ts +266 -0
- package/src/theme/theme.test.ts +258 -0
- package/src/theme/tokens.ts +392 -0
- package/src/types/player-state.ts +445 -0
- package/src/types/plugin-state.ts +407 -0
- package/src/types/reducer-state.ts +24 -0
- package/src/types/runtime-api.ts +114 -0
- package/src/types/tiled-board.ts +785 -0
- package/src/ui-contract.ts +168 -0
- package/src/utils/interaction-inputs.test.ts +109 -0
- package/src/utils/interaction-inputs.ts +331 -0
- package/src/utils/interaction-labels.ts +23 -0
- package/src/utils/interaction-status.ts +59 -0
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { createContext, useContext, useMemo } from "react";
|
|
3
|
+
import { useStore } from "zustand";
|
|
4
|
+
import { createStore } from "zustand/vanilla";
|
|
5
|
+
import { useShallow } from "zustand/shallow";
|
|
6
|
+
const EMPTY_DRAFT = Object.freeze({});
|
|
7
|
+
export function createInteractionUiStore() {
|
|
8
|
+
const store = createStore()(() => ({
|
|
9
|
+
drafts: {},
|
|
10
|
+
arms: {},
|
|
11
|
+
submitting: {},
|
|
12
|
+
}));
|
|
13
|
+
const api = {
|
|
14
|
+
getDraft(interactionId) {
|
|
15
|
+
return store.getState().drafts[interactionId] ?? EMPTY_DRAFT;
|
|
16
|
+
},
|
|
17
|
+
setInput(interactionId, key, value) {
|
|
18
|
+
store.setState((prev) => {
|
|
19
|
+
const current = prev.drafts[interactionId];
|
|
20
|
+
if (current && current[key] === value)
|
|
21
|
+
return prev;
|
|
22
|
+
return {
|
|
23
|
+
...prev,
|
|
24
|
+
drafts: {
|
|
25
|
+
...prev.drafts,
|
|
26
|
+
[interactionId]: { ...(current ?? {}), [key]: value },
|
|
27
|
+
},
|
|
28
|
+
};
|
|
29
|
+
});
|
|
30
|
+
},
|
|
31
|
+
clearInput(interactionId, key) {
|
|
32
|
+
store.setState((prev) => {
|
|
33
|
+
const current = prev.drafts[interactionId];
|
|
34
|
+
if (!current)
|
|
35
|
+
return prev;
|
|
36
|
+
if (key === undefined) {
|
|
37
|
+
const { [interactionId]: _omit, ...rest } = prev.drafts;
|
|
38
|
+
return { ...prev, drafts: rest };
|
|
39
|
+
}
|
|
40
|
+
if (!(key in current))
|
|
41
|
+
return prev;
|
|
42
|
+
const { [key]: _omitKey, ...remainingKeys } = current;
|
|
43
|
+
if (Object.keys(remainingKeys).length === 0) {
|
|
44
|
+
const { [interactionId]: _omit, ...rest } = prev.drafts;
|
|
45
|
+
return { ...prev, drafts: rest };
|
|
46
|
+
}
|
|
47
|
+
return {
|
|
48
|
+
...prev,
|
|
49
|
+
drafts: { ...prev.drafts, [interactionId]: remainingKeys },
|
|
50
|
+
};
|
|
51
|
+
});
|
|
52
|
+
},
|
|
53
|
+
clearAll() {
|
|
54
|
+
store.setState((prev) => {
|
|
55
|
+
if (Object.keys(prev.drafts).length === 0 &&
|
|
56
|
+
Object.keys(prev.arms).length === 0 &&
|
|
57
|
+
Object.keys(prev.submitting).length === 0) {
|
|
58
|
+
return prev;
|
|
59
|
+
}
|
|
60
|
+
return { drafts: {}, arms: {}, submitting: {} };
|
|
61
|
+
});
|
|
62
|
+
},
|
|
63
|
+
getArmed(surface) {
|
|
64
|
+
return store.getState().arms[surface] ?? null;
|
|
65
|
+
},
|
|
66
|
+
arm(surface, interactionId) {
|
|
67
|
+
store.setState((prev) => {
|
|
68
|
+
const current = prev.arms[surface] ?? null;
|
|
69
|
+
if (current === interactionId)
|
|
70
|
+
return prev;
|
|
71
|
+
if (interactionId === null) {
|
|
72
|
+
const { [surface]: _omit, ...rest } = prev.arms;
|
|
73
|
+
return { ...prev, arms: rest };
|
|
74
|
+
}
|
|
75
|
+
return { ...prev, arms: { ...prev.arms, [surface]: interactionId } };
|
|
76
|
+
});
|
|
77
|
+
},
|
|
78
|
+
isSubmitting(interactionId) {
|
|
79
|
+
return store.getState().submitting[interactionId] === true;
|
|
80
|
+
},
|
|
81
|
+
setSubmitting(interactionId, submitting) {
|
|
82
|
+
store.setState((prev) => {
|
|
83
|
+
const current = prev.submitting[interactionId] === true;
|
|
84
|
+
if (current === submitting)
|
|
85
|
+
return prev;
|
|
86
|
+
if (!submitting) {
|
|
87
|
+
const { [interactionId]: _omit, ...rest } = prev.submitting;
|
|
88
|
+
return { ...prev, submitting: rest };
|
|
89
|
+
}
|
|
90
|
+
return {
|
|
91
|
+
...prev,
|
|
92
|
+
submitting: { ...prev.submitting, [interactionId]: true },
|
|
93
|
+
};
|
|
94
|
+
});
|
|
95
|
+
},
|
|
96
|
+
};
|
|
97
|
+
return Object.assign(store, api);
|
|
98
|
+
}
|
|
99
|
+
const InteractionUiCtx = createContext(null);
|
|
100
|
+
/**
|
|
101
|
+
* React provider that holds draft input state shared across every surface
|
|
102
|
+
* inside the tree. Auto-installed by `<PluginRuntime>`; authors rarely
|
|
103
|
+
* mount it directly. Mount manually when rendering surface components in
|
|
104
|
+
* isolation (e.g., Storybook, snapshot tests).
|
|
105
|
+
*
|
|
106
|
+
* ```tsx
|
|
107
|
+
* <InteractionUiProvider>
|
|
108
|
+
* <PanelSurface />
|
|
109
|
+
* <BoardSurface>{(ctx) => <Board ctx={ctx} />}</BoardSurface>
|
|
110
|
+
* </InteractionUiProvider>
|
|
111
|
+
* ```
|
|
112
|
+
*/
|
|
113
|
+
export function InteractionUiProvider({ children, store, }) {
|
|
114
|
+
const ownedStore = useMemo(() => createInteractionUiStore(), []);
|
|
115
|
+
return (_jsx(InteractionUiCtx.Provider, { value: store ?? ownedStore, children: children }));
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Access the active draft store. Falls back to an inert in-memory store
|
|
119
|
+
* when no provider is mounted, so surface hooks remain callable in bare
|
|
120
|
+
* test harnesses without crashing — draft state simply isn't shared
|
|
121
|
+
* across components in that case.
|
|
122
|
+
*/
|
|
123
|
+
export function useInteractionUiStore() {
|
|
124
|
+
const ctx = useContext(InteractionUiCtx);
|
|
125
|
+
const fallback = useMemo(() => createInteractionUiStore(), []);
|
|
126
|
+
return ctx ?? fallback;
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* Subscribe to the draft for a single interaction id with per-slice
|
|
130
|
+
* re-renders. Returns a stable empty object when the draft is unset.
|
|
131
|
+
*/
|
|
132
|
+
export function useInteractionDraft(interactionId) {
|
|
133
|
+
const store = useInteractionUiStore();
|
|
134
|
+
return useStore(store, useShallow((state) => state.drafts[interactionId] ?? EMPTY_DRAFT));
|
|
135
|
+
}
|
|
136
|
+
/** Subscribe to the armed interaction id on a given surface. */
|
|
137
|
+
export function useArmedInteraction(surface) {
|
|
138
|
+
const store = useInteractionUiStore();
|
|
139
|
+
return useStore(store, (state) => state.arms[surface] ?? null);
|
|
140
|
+
}
|
|
141
|
+
/** Subscribe to local submitting status for a single interaction key. */
|
|
142
|
+
export function useInteractionSubmitting(interactionId) {
|
|
143
|
+
const store = useInteractionUiStore();
|
|
144
|
+
return useStore(store, (state) => state.submitting[interactionId] === true);
|
|
145
|
+
}
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { PluginSessionState } from "../types/runtime-api";
|
|
2
|
+
/**
|
|
3
|
+
* Context for plugin session metadata.
|
|
4
|
+
* This context is provided by the RuntimeContext after receiving init message from parent.
|
|
5
|
+
*/
|
|
6
|
+
export declare const PluginSessionContext: import("react").Context<PluginSessionState | null>;
|
|
7
|
+
/**
|
|
8
|
+
* Hook to access plugin session metadata.
|
|
9
|
+
* Returns session initialization status and IDs.
|
|
10
|
+
*
|
|
11
|
+
* @returns Plugin session state with status, sessionId, controllablePlayerIds, and controllingPlayerId
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```tsx
|
|
15
|
+
* function MyPluginComponent() {
|
|
16
|
+
* const { status, sessionId, controllablePlayerIds, controllingPlayerId } = usePluginSession();
|
|
17
|
+
*
|
|
18
|
+
* if (status === "loading") {
|
|
19
|
+
* return <div>Initializing...</div>;
|
|
20
|
+
* }
|
|
21
|
+
*
|
|
22
|
+
* return (
|
|
23
|
+
* <div>
|
|
24
|
+
* <p>Session: {sessionId}</p>
|
|
25
|
+
* <p>Can control: {controllablePlayerIds.join(", ")}</p>
|
|
26
|
+
* <p>Currently controlling: {controllingPlayerId}</p>
|
|
27
|
+
* </div>
|
|
28
|
+
* );
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export declare function usePluginSession(): PluginSessionState;
|
|
33
|
+
//# sourceMappingURL=PluginSessionContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PluginSessionContext.d.ts","sourceRoot":"","sources":["../../src/context/PluginSessionContext.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAE/D;;;GAGG;AACH,eAAO,MAAM,oBAAoB,oDAEhC,CAAC;AAEF;;;;;;;;;;;;;;;;;;;;;;;;GAwBG;AACH,wBAAgB,gBAAgB,IAAI,kBAAkB,CAUrD"}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import { createContext, useContext } from "react";
|
|
2
|
+
/**
|
|
3
|
+
* Context for plugin session metadata.
|
|
4
|
+
* This context is provided by the RuntimeContext after receiving init message from parent.
|
|
5
|
+
*/
|
|
6
|
+
export const PluginSessionContext = createContext(null);
|
|
7
|
+
/**
|
|
8
|
+
* Hook to access plugin session metadata.
|
|
9
|
+
* Returns session initialization status and IDs.
|
|
10
|
+
*
|
|
11
|
+
* @returns Plugin session state with status, sessionId, controllablePlayerIds, and controllingPlayerId
|
|
12
|
+
*
|
|
13
|
+
* @example
|
|
14
|
+
* ```tsx
|
|
15
|
+
* function MyPluginComponent() {
|
|
16
|
+
* const { status, sessionId, controllablePlayerIds, controllingPlayerId } = usePluginSession();
|
|
17
|
+
*
|
|
18
|
+
* if (status === "loading") {
|
|
19
|
+
* return <div>Initializing...</div>;
|
|
20
|
+
* }
|
|
21
|
+
*
|
|
22
|
+
* return (
|
|
23
|
+
* <div>
|
|
24
|
+
* <p>Session: {sessionId}</p>
|
|
25
|
+
* <p>Can control: {controllablePlayerIds.join(", ")}</p>
|
|
26
|
+
* <p>Currently controlling: {controllingPlayerId}</p>
|
|
27
|
+
* </div>
|
|
28
|
+
* );
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export function usePluginSession() {
|
|
33
|
+
const context = useContext(PluginSessionContext);
|
|
34
|
+
if (context === null) {
|
|
35
|
+
throw new Error("usePluginSession must be used within a PluginSessionContext.Provider (provided by RuntimeContext)");
|
|
36
|
+
}
|
|
37
|
+
return context;
|
|
38
|
+
}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { default as React } from "react";
|
|
2
|
+
import type { PluginStateSnapshot } from "../types/plugin-state.js";
|
|
3
|
+
/**
|
|
4
|
+
* React Context for providing plugin state from state-sync messages.
|
|
5
|
+
* This is the new architecture where the host app maintains state and syncs to plugin.
|
|
6
|
+
*/
|
|
7
|
+
declare const PluginStateContext: React.Context<PluginStateSnapshot<unknown, string, string, string> | null>;
|
|
8
|
+
export interface PluginStateProviderProps {
|
|
9
|
+
children: React.ReactNode;
|
|
10
|
+
/**
|
|
11
|
+
* Custom loading component to show while waiting for state
|
|
12
|
+
* @default DefaultLoadingScreen
|
|
13
|
+
*/
|
|
14
|
+
loadingComponent?: React.ReactNode;
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* PluginStateProvider subscribes to state-sync messages from the host
|
|
18
|
+
* and provides the state to child components via context.
|
|
19
|
+
*
|
|
20
|
+
* In the new architecture:
|
|
21
|
+
* - Host only renders authored game UI after state-sync begins
|
|
22
|
+
* - Plugin receives complete state in first state-sync message
|
|
23
|
+
* - No buffering or waiting needed - state is immediately available
|
|
24
|
+
*
|
|
25
|
+
* This replaces the complex usePluginRuntime hook which had:
|
|
26
|
+
* - waitForGameStart() promise handling
|
|
27
|
+
* - finishSetup() coordination with queueMicrotask
|
|
28
|
+
* - Error timeout handling
|
|
29
|
+
*
|
|
30
|
+
* @example
|
|
31
|
+
* ```tsx
|
|
32
|
+
* function PluginRoot() {
|
|
33
|
+
* return (
|
|
34
|
+
* <RuntimeProvider runtime={runtime}>
|
|
35
|
+
* <PluginStateProvider>
|
|
36
|
+
* <App />
|
|
37
|
+
* </PluginStateProvider>
|
|
38
|
+
* </RuntimeProvider>
|
|
39
|
+
* );
|
|
40
|
+
* }
|
|
41
|
+
* ```
|
|
42
|
+
*/
|
|
43
|
+
export declare function PluginStateProvider({ children, loadingComponent, }: PluginStateProviderProps): import("react/jsx-runtime").JSX.Element;
|
|
44
|
+
/**
|
|
45
|
+
* Hook to access the full plugin state snapshot.
|
|
46
|
+
*
|
|
47
|
+
* @throws Error if used outside of PluginStateProvider
|
|
48
|
+
* @returns Current plugin state snapshot
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* ```typescript
|
|
52
|
+
* function MyComponent() {
|
|
53
|
+
* const state = usePluginStateSnapshot();
|
|
54
|
+
* console.log('Current phase:', state.gameplay.currentPhase);
|
|
55
|
+
* }
|
|
56
|
+
* ```
|
|
57
|
+
*/
|
|
58
|
+
export declare function usePluginStateSnapshot(): PluginStateSnapshot;
|
|
59
|
+
/**
|
|
60
|
+
* Hook to select a specific part of the plugin state.
|
|
61
|
+
* Uses useSyncExternalStore for optimal performance - only re-renders
|
|
62
|
+
* when the selected value changes (using reference equality).
|
|
63
|
+
*
|
|
64
|
+
* @param selector - Function to select a part of the state
|
|
65
|
+
* @returns Selected value from state
|
|
66
|
+
*
|
|
67
|
+
* @example
|
|
68
|
+
* ```typescript
|
|
69
|
+
* // Only re-renders when gameplay.currentPhase changes
|
|
70
|
+
* function CurrentStateDisplay() {
|
|
71
|
+
* const currentState = usePluginState((s) => s.gameplay.currentPhase);
|
|
72
|
+
* return <div>State: {currentState}</div>;
|
|
73
|
+
* }
|
|
74
|
+
* ```
|
|
75
|
+
*/
|
|
76
|
+
export declare function usePluginState<T>(selector: (state: PluginStateSnapshot) => T): T;
|
|
77
|
+
/**
|
|
78
|
+
* Hook to access plugin actions (like marking notifications read).
|
|
79
|
+
*
|
|
80
|
+
* @returns Object with action functions
|
|
81
|
+
*
|
|
82
|
+
* @example
|
|
83
|
+
* ```typescript
|
|
84
|
+
* function NotificationsList() {
|
|
85
|
+
* const notifications = usePluginState((s) => s.notifications);
|
|
86
|
+
* const { markNotificationRead, switchPlayer } = usePluginActions();
|
|
87
|
+
*
|
|
88
|
+
* return (
|
|
89
|
+
* <ul>
|
|
90
|
+
* {notifications.map((n) => (
|
|
91
|
+
* <li key={n.id} onClick={() => markNotificationRead(n.id)}>
|
|
92
|
+
* {n.type}
|
|
93
|
+
* </li>
|
|
94
|
+
* ))}
|
|
95
|
+
* </ul>
|
|
96
|
+
* );
|
|
97
|
+
* }
|
|
98
|
+
* ```
|
|
99
|
+
*/
|
|
100
|
+
export declare function usePluginActions(): {
|
|
101
|
+
/**
|
|
102
|
+
* Mark a notification as read.
|
|
103
|
+
* Sends message to host which updates the notification in GameSessionStore.
|
|
104
|
+
*/
|
|
105
|
+
markNotificationRead: (notificationId: string) => void;
|
|
106
|
+
/**
|
|
107
|
+
* Switch to a different player (for users controlling multiple seats).
|
|
108
|
+
*/
|
|
109
|
+
switchPlayer: (playerId: string) => void;
|
|
110
|
+
/**
|
|
111
|
+
* Submit a player interaction (action or prompt response).
|
|
112
|
+
*/
|
|
113
|
+
submitInteraction: (playerId: import("../../type-stubs/manifest-contract.js").PlayerId, interactionId: string, params: unknown) => Promise<void>;
|
|
114
|
+
};
|
|
115
|
+
export { PluginStateContext };
|
|
116
|
+
//# sourceMappingURL=PluginStateContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PluginStateContext.d.ts","sourceRoot":"","sources":["../../src/context/PluginStateContext.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,IAAI,KAAK,EAOjB,MAAM,OAAO,CAAC;AACf,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAIpE;;;GAGG;AACH,QAAA,MAAM,kBAAkB,4EAAkD,CAAC;AAoC3E,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B;;;OAGG;IACH,gBAAgB,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;CACpC;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,wBAAgB,mBAAmB,CAAC,EAClC,QAAQ,EACR,gBAA2C,GAC5C,EAAE,wBAAwB,2CAkC1B;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,sBAAsB,IAAI,mBAAmB,CAW5D;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,cAAc,CAAC,CAAC,EAC9B,QAAQ,EAAE,CAAC,KAAK,EAAE,mBAAmB,KAAK,CAAC,GAC1C,CAAC,CAyBH;AAED;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,gBAAgB;IAI5B;;;OAGG;2CACoC,MAAM;IAO7C;;OAEG;6BACsB,MAAM;IAI/B;;OAEG;;EAGN;AAED,OAAO,EAAE,kBAAkB,EAAE,CAAC"}
|
|
@@ -0,0 +1,186 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { createContext, useContext, useState, useEffect, useMemo, useSyncExternalStore, } from "react";
|
|
3
|
+
import { useRuntimeContext } from "./RuntimeContext.js";
|
|
4
|
+
/**
|
|
5
|
+
* React Context for providing plugin state from state-sync messages.
|
|
6
|
+
* This is the new architecture where the host app maintains state and syncs to plugin.
|
|
7
|
+
*/
|
|
8
|
+
const PluginStateContext = createContext(null);
|
|
9
|
+
/**
|
|
10
|
+
* Loading component shown while waiting for initial state
|
|
11
|
+
*/
|
|
12
|
+
function DefaultLoadingScreen() {
|
|
13
|
+
return (_jsx("div", { style: {
|
|
14
|
+
display: "flex",
|
|
15
|
+
alignItems: "center",
|
|
16
|
+
justifyContent: "center",
|
|
17
|
+
height: "100%",
|
|
18
|
+
width: "100%",
|
|
19
|
+
color: "#666",
|
|
20
|
+
}, children: _jsxs("div", { style: { textAlign: "center" }, children: [_jsx("div", { style: {
|
|
21
|
+
width: "40px",
|
|
22
|
+
height: "40px",
|
|
23
|
+
border: "3px solid #e0e0e0",
|
|
24
|
+
borderTopColor: "#666",
|
|
25
|
+
borderRadius: "50%",
|
|
26
|
+
animation: "spin 1s linear infinite",
|
|
27
|
+
margin: "0 auto 12px",
|
|
28
|
+
} }), _jsx("style", { children: `@keyframes spin { to { transform: rotate(360deg); } }` }), _jsx("p", { children: "Loading game view..." })] }) }));
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* PluginStateProvider subscribes to state-sync messages from the host
|
|
32
|
+
* and provides the state to child components via context.
|
|
33
|
+
*
|
|
34
|
+
* In the new architecture:
|
|
35
|
+
* - Host only renders authored game UI after state-sync begins
|
|
36
|
+
* - Plugin receives complete state in first state-sync message
|
|
37
|
+
* - No buffering or waiting needed - state is immediately available
|
|
38
|
+
*
|
|
39
|
+
* This replaces the complex usePluginRuntime hook which had:
|
|
40
|
+
* - waitForGameStart() promise handling
|
|
41
|
+
* - finishSetup() coordination with queueMicrotask
|
|
42
|
+
* - Error timeout handling
|
|
43
|
+
*
|
|
44
|
+
* @example
|
|
45
|
+
* ```tsx
|
|
46
|
+
* function PluginRoot() {
|
|
47
|
+
* return (
|
|
48
|
+
* <RuntimeProvider runtime={runtime}>
|
|
49
|
+
* <PluginStateProvider>
|
|
50
|
+
* <App />
|
|
51
|
+
* </PluginStateProvider>
|
|
52
|
+
* </RuntimeProvider>
|
|
53
|
+
* );
|
|
54
|
+
* }
|
|
55
|
+
* ```
|
|
56
|
+
*/
|
|
57
|
+
export function PluginStateProvider({ children, loadingComponent = _jsx(DefaultLoadingScreen, {}), }) {
|
|
58
|
+
const runtime = useRuntimeContext();
|
|
59
|
+
const [state, setState] = useState(() => runtime.getSnapshot?.() ?? null);
|
|
60
|
+
useEffect(() => {
|
|
61
|
+
// Get initial state if available
|
|
62
|
+
const initialState = runtime.getSnapshot?.();
|
|
63
|
+
if (initialState) {
|
|
64
|
+
setState(initialState);
|
|
65
|
+
}
|
|
66
|
+
// Subscribe to state changes
|
|
67
|
+
if (runtime.subscribeToState) {
|
|
68
|
+
return runtime.subscribeToState((newState) => {
|
|
69
|
+
setState(newState);
|
|
70
|
+
});
|
|
71
|
+
}
|
|
72
|
+
return () => { };
|
|
73
|
+
}, [runtime]);
|
|
74
|
+
// Don't render children until state is available
|
|
75
|
+
// In the new architecture, host guarantees state exists before rendering plugin
|
|
76
|
+
if (!state) {
|
|
77
|
+
return _jsx(_Fragment, { children: loadingComponent });
|
|
78
|
+
}
|
|
79
|
+
return (_jsx(PluginStateContext.Provider, { value: state, children: children }));
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* Hook to access the full plugin state snapshot.
|
|
83
|
+
*
|
|
84
|
+
* @throws Error if used outside of PluginStateProvider
|
|
85
|
+
* @returns Current plugin state snapshot
|
|
86
|
+
*
|
|
87
|
+
* @example
|
|
88
|
+
* ```typescript
|
|
89
|
+
* function MyComponent() {
|
|
90
|
+
* const state = usePluginStateSnapshot();
|
|
91
|
+
* console.log('Current phase:', state.gameplay.currentPhase);
|
|
92
|
+
* }
|
|
93
|
+
* ```
|
|
94
|
+
*/
|
|
95
|
+
export function usePluginStateSnapshot() {
|
|
96
|
+
const state = useContext(PluginStateContext);
|
|
97
|
+
if (!state) {
|
|
98
|
+
throw new Error("usePluginStateSnapshot must be used within PluginStateProvider. " +
|
|
99
|
+
"Make sure you have wrapped your app with <PluginStateProvider>.");
|
|
100
|
+
}
|
|
101
|
+
return state;
|
|
102
|
+
}
|
|
103
|
+
/**
|
|
104
|
+
* Hook to select a specific part of the plugin state.
|
|
105
|
+
* Uses useSyncExternalStore for optimal performance - only re-renders
|
|
106
|
+
* when the selected value changes (using reference equality).
|
|
107
|
+
*
|
|
108
|
+
* @param selector - Function to select a part of the state
|
|
109
|
+
* @returns Selected value from state
|
|
110
|
+
*
|
|
111
|
+
* @example
|
|
112
|
+
* ```typescript
|
|
113
|
+
* // Only re-renders when gameplay.currentPhase changes
|
|
114
|
+
* function CurrentStateDisplay() {
|
|
115
|
+
* const currentState = usePluginState((s) => s.gameplay.currentPhase);
|
|
116
|
+
* return <div>State: {currentState}</div>;
|
|
117
|
+
* }
|
|
118
|
+
* ```
|
|
119
|
+
*/
|
|
120
|
+
export function usePluginState(selector) {
|
|
121
|
+
const runtime = useRuntimeContext();
|
|
122
|
+
const subscribe = (onStoreChange) => {
|
|
123
|
+
if (!runtime.subscribeToState) {
|
|
124
|
+
return () => { };
|
|
125
|
+
}
|
|
126
|
+
return runtime.subscribeToState(() => {
|
|
127
|
+
onStoreChange();
|
|
128
|
+
});
|
|
129
|
+
};
|
|
130
|
+
const getSnapshot = () => {
|
|
131
|
+
const state = runtime.getSnapshot?.();
|
|
132
|
+
if (!state) {
|
|
133
|
+
throw new Error("usePluginState: No state available. " +
|
|
134
|
+
"Make sure you have wrapped your app with <PluginStateProvider>.");
|
|
135
|
+
}
|
|
136
|
+
return state;
|
|
137
|
+
};
|
|
138
|
+
const state = useSyncExternalStore(subscribe, getSnapshot, getSnapshot);
|
|
139
|
+
return useMemo(() => selector(state), [selector, state]);
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Hook to access plugin actions (like marking notifications read).
|
|
143
|
+
*
|
|
144
|
+
* @returns Object with action functions
|
|
145
|
+
*
|
|
146
|
+
* @example
|
|
147
|
+
* ```typescript
|
|
148
|
+
* function NotificationsList() {
|
|
149
|
+
* const notifications = usePluginState((s) => s.notifications);
|
|
150
|
+
* const { markNotificationRead, switchPlayer } = usePluginActions();
|
|
151
|
+
*
|
|
152
|
+
* return (
|
|
153
|
+
* <ul>
|
|
154
|
+
* {notifications.map((n) => (
|
|
155
|
+
* <li key={n.id} onClick={() => markNotificationRead(n.id)}>
|
|
156
|
+
* {n.type}
|
|
157
|
+
* </li>
|
|
158
|
+
* ))}
|
|
159
|
+
* </ul>
|
|
160
|
+
* );
|
|
161
|
+
* }
|
|
162
|
+
* ```
|
|
163
|
+
*/
|
|
164
|
+
export function usePluginActions() {
|
|
165
|
+
const runtime = useRuntimeContext();
|
|
166
|
+
return {
|
|
167
|
+
/**
|
|
168
|
+
* Mark a notification as read.
|
|
169
|
+
* Sends message to host which updates the notification in GameSessionStore.
|
|
170
|
+
*/
|
|
171
|
+
markNotificationRead: (notificationId) => {
|
|
172
|
+
window.parent.postMessage({ type: "mark-notification-read", notificationId }, "*");
|
|
173
|
+
},
|
|
174
|
+
/**
|
|
175
|
+
* Switch to a different player (for users controlling multiple seats).
|
|
176
|
+
*/
|
|
177
|
+
switchPlayer: (playerId) => {
|
|
178
|
+
runtime.switchPlayer?.(playerId);
|
|
179
|
+
},
|
|
180
|
+
/**
|
|
181
|
+
* Submit a player interaction (action or prompt response).
|
|
182
|
+
*/
|
|
183
|
+
submitInteraction: runtime.submitInteraction,
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
export { PluginStateContext };
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import type { RuntimeAPI } from "../types/runtime-api.js";
|
|
3
|
+
/**
|
|
4
|
+
* React Context for providing RuntimeAPI to plugin components.
|
|
5
|
+
* This context must be provided by the plugin wrapper, not by the plugin code itself.
|
|
6
|
+
*/
|
|
7
|
+
export declare const RuntimeContext: React.Context<RuntimeAPI | null>;
|
|
8
|
+
/**
|
|
9
|
+
* Hook to access the RuntimeAPI from context.
|
|
10
|
+
*
|
|
11
|
+
* @throws Error if used outside of RuntimeContext.Provider
|
|
12
|
+
* @returns RuntimeAPI instance
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```typescript
|
|
16
|
+
* function MyPluginComponent() {
|
|
17
|
+
* const runtime = useRuntimeContext();
|
|
18
|
+
* return (
|
|
19
|
+
* <button onClick={() => runtime.submitInteraction("player-1", "pass", {})}>
|
|
20
|
+
* Pass
|
|
21
|
+
* </button>
|
|
22
|
+
* );
|
|
23
|
+
* }
|
|
24
|
+
* ```
|
|
25
|
+
*/
|
|
26
|
+
export declare function useRuntimeContext(): RuntimeAPI;
|
|
27
|
+
/**
|
|
28
|
+
* RuntimeProvider component that provides both RuntimeAPI and PluginSessionContext.
|
|
29
|
+
* This component subscribes to session state changes from the RuntimeAPI and provides
|
|
30
|
+
* them through PluginSessionContext.
|
|
31
|
+
*
|
|
32
|
+
* @example
|
|
33
|
+
* ```tsx
|
|
34
|
+
* function PluginRoot() {
|
|
35
|
+
* const runtime = createPluginRuntimeAPI();
|
|
36
|
+
*
|
|
37
|
+
* return (
|
|
38
|
+
* <RuntimeProvider runtime={runtime}>
|
|
39
|
+
* <App />
|
|
40
|
+
* </RuntimeProvider>
|
|
41
|
+
* );
|
|
42
|
+
* }
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
45
|
+
export declare function RuntimeProvider({ runtime, children, }: {
|
|
46
|
+
runtime: RuntimeAPI;
|
|
47
|
+
children: React.ReactNode;
|
|
48
|
+
}): import("react/jsx-runtime").JSX.Element;
|
|
49
|
+
//# sourceMappingURL=RuntimeContext.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"RuntimeContext.d.ts","sourceRoot":"","sources":["../../src/context/RuntimeContext.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAyD,MAAM,OAAO,CAAC;AAC9E,OAAO,KAAK,EAAE,UAAU,EAAsB,MAAM,yBAAyB,CAAC;AAG9E;;;GAGG;AACH,eAAO,MAAM,cAAc,kCAAyC,CAAC;AAErE;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,iBAAiB,IAAI,UAAU,CAU9C;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,eAAe,CAAC,EAC9B,OAAO,EACP,QAAQ,GACT,EAAE;IACD,OAAO,EAAE,UAAU,CAAC;IACpB,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;CAC3B,2CA+BA"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { createContext, useContext, useState, useEffect } from "react";
|
|
3
|
+
import { PluginSessionContext } from "./PluginSessionContext.js";
|
|
4
|
+
/**
|
|
5
|
+
* React Context for providing RuntimeAPI to plugin components.
|
|
6
|
+
* This context must be provided by the plugin wrapper, not by the plugin code itself.
|
|
7
|
+
*/
|
|
8
|
+
export const RuntimeContext = createContext(null);
|
|
9
|
+
/**
|
|
10
|
+
* Hook to access the RuntimeAPI from context.
|
|
11
|
+
*
|
|
12
|
+
* @throws Error if used outside of RuntimeContext.Provider
|
|
13
|
+
* @returns RuntimeAPI instance
|
|
14
|
+
*
|
|
15
|
+
* @example
|
|
16
|
+
* ```typescript
|
|
17
|
+
* function MyPluginComponent() {
|
|
18
|
+
* const runtime = useRuntimeContext();
|
|
19
|
+
* return (
|
|
20
|
+
* <button onClick={() => runtime.submitInteraction("player-1", "pass", {})}>
|
|
21
|
+
* Pass
|
|
22
|
+
* </button>
|
|
23
|
+
* );
|
|
24
|
+
* }
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export function useRuntimeContext() {
|
|
28
|
+
const context = useContext(RuntimeContext);
|
|
29
|
+
if (!context) {
|
|
30
|
+
throw new Error("useRuntimeContext must be used within a RuntimeContext.Provider");
|
|
31
|
+
}
|
|
32
|
+
return context;
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* RuntimeProvider component that provides both RuntimeAPI and PluginSessionContext.
|
|
36
|
+
* This component subscribes to session state changes from the RuntimeAPI and provides
|
|
37
|
+
* them through PluginSessionContext.
|
|
38
|
+
*
|
|
39
|
+
* @example
|
|
40
|
+
* ```tsx
|
|
41
|
+
* function PluginRoot() {
|
|
42
|
+
* const runtime = createPluginRuntimeAPI();
|
|
43
|
+
*
|
|
44
|
+
* return (
|
|
45
|
+
* <RuntimeProvider runtime={runtime}>
|
|
46
|
+
* <App />
|
|
47
|
+
* </RuntimeProvider>
|
|
48
|
+
* );
|
|
49
|
+
* }
|
|
50
|
+
* ```
|
|
51
|
+
*/
|
|
52
|
+
export function RuntimeProvider({ runtime, children, }) {
|
|
53
|
+
// Subscribe to session state changes
|
|
54
|
+
const [sessionState, setSessionState] = useState(() => runtime.getSessionState());
|
|
55
|
+
useEffect(() => {
|
|
56
|
+
// Subscribe to session state changes via internal API
|
|
57
|
+
const runtimeWithInternal = runtime;
|
|
58
|
+
if (runtimeWithInternal._subscribeToSessionState) {
|
|
59
|
+
return runtimeWithInternal._subscribeToSessionState((state) => {
|
|
60
|
+
setSessionState(state);
|
|
61
|
+
});
|
|
62
|
+
}
|
|
63
|
+
// Fallback: no session state subscription available
|
|
64
|
+
return () => { };
|
|
65
|
+
}, [runtime]);
|
|
66
|
+
return (_jsx(RuntimeContext.Provider, { value: runtime, children: _jsx(PluginSessionContext.Provider, { value: sessionState, children: children }) }));
|
|
67
|
+
}
|