@pretty-chitty/core 1.1.2 → 1.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.
- package/dist/components/BottomBarButton.d.ts +2 -1
- package/dist/components/BottomBarButton.d.ts.map +1 -1
- package/dist/components/BottomBarButton.js +2 -1
- package/dist/components/BottomBarButton.js.map +1 -1
- package/dist/components/ClientTrustMatchViewer.d.ts +4 -1
- package/dist/components/ClientTrustMatchViewer.d.ts.map +1 -1
- package/dist/components/ClientTrustMatchViewer.js +11 -4
- package/dist/components/ClientTrustMatchViewer.js.map +1 -1
- package/dist/components/ContextGalleryDisplay.js +1 -1
- package/dist/components/ContextGalleryDisplay.js.map +1 -1
- package/dist/components/DemoWrapper.d.ts +9 -0
- package/dist/components/DemoWrapper.d.ts.map +1 -0
- package/dist/components/DemoWrapper.js +76 -0
- package/dist/components/DemoWrapper.js.map +1 -0
- package/dist/components/FullScreenGalleryDisplay.d.ts +2 -0
- package/dist/components/FullScreenGalleryDisplay.d.ts.map +1 -0
- package/dist/components/FullScreenGalleryDisplay.js +56 -0
- package/dist/components/FullScreenGalleryDisplay.js.map +1 -0
- package/dist/components/Gallery/AnimationController.d.ts +19 -0
- package/dist/components/Gallery/AnimationController.d.ts.map +1 -0
- package/dist/components/Gallery/AnimationController.js +81 -0
- package/dist/components/Gallery/AnimationController.js.map +1 -0
- package/dist/components/Gallery/BuiltItem.d.ts +58 -0
- package/dist/components/Gallery/BuiltItem.d.ts.map +1 -0
- package/dist/components/Gallery/BuiltItem.js +301 -0
- package/dist/components/Gallery/BuiltItem.js.map +1 -0
- package/dist/components/Gallery/CameraManager.d.ts +14 -0
- package/dist/components/Gallery/CameraManager.d.ts.map +1 -0
- package/dist/components/Gallery/CameraManager.js +41 -0
- package/dist/components/Gallery/CameraManager.js.map +1 -0
- package/dist/components/Gallery/GalleryController.d.ts +30 -0
- package/dist/components/Gallery/GalleryController.d.ts.map +1 -0
- package/dist/components/Gallery/GalleryController.js +134 -0
- package/dist/components/Gallery/GalleryController.js.map +1 -0
- package/dist/components/Gallery/GalleryViewer.d.ts +18 -0
- package/dist/components/Gallery/GalleryViewer.d.ts.map +1 -0
- package/dist/components/Gallery/GalleryViewer.js +141 -0
- package/dist/components/Gallery/GalleryViewer.js.map +1 -0
- package/dist/components/Gallery/LayoutManager.d.ts +49 -0
- package/dist/components/Gallery/LayoutManager.d.ts.map +1 -0
- package/dist/components/Gallery/LayoutManager.js +129 -0
- package/dist/components/Gallery/LayoutManager.js.map +1 -0
- package/dist/components/Gallery/constants.d.ts +13 -0
- package/dist/components/Gallery/constants.d.ts.map +1 -0
- package/dist/components/Gallery/constants.js +13 -0
- package/dist/components/Gallery/constants.js.map +1 -0
- package/dist/components/Gallery/index.d.ts +3 -0
- package/dist/components/Gallery/index.d.ts.map +1 -0
- package/dist/components/Gallery/index.js +2 -0
- package/dist/components/Gallery/index.js.map +1 -0
- package/dist/components/Gallery/types.d.ts +45 -0
- package/dist/components/Gallery/types.d.ts.map +1 -0
- package/dist/components/Gallery/types.js +2 -0
- package/dist/components/Gallery/types.js.map +1 -0
- package/dist/components/GalleryPlayground.js +1 -1
- package/dist/components/GalleryPlayground.js.map +1 -1
- package/dist/components/GalleryViewer.d.ts +2 -47
- package/dist/components/GalleryViewer.d.ts.map +1 -1
- package/dist/components/GalleryViewer.js +3 -569
- package/dist/components/GalleryViewer.js.map +1 -1
- package/dist/components/GameDesigner.d.ts.map +1 -1
- package/dist/components/GameDesigner.js +13 -2
- package/dist/components/GameDesigner.js.map +1 -1
- package/dist/components/InlineGalleryDisplay.d.ts +2 -0
- package/dist/components/InlineGalleryDisplay.d.ts.map +1 -0
- package/dist/components/InlineGalleryDisplay.js +69 -0
- package/dist/components/InlineGalleryDisplay.js.map +1 -0
- package/dist/components/LiveButton.d.ts.map +1 -1
- package/dist/components/LiveButton.js +1 -1
- package/dist/components/LiveButton.js.map +1 -1
- package/dist/components/MatchViewer.d.ts +0 -1
- package/dist/components/MatchViewer.d.ts.map +1 -1
- package/dist/components/MatchViewer.js +20 -10
- package/dist/components/MatchViewer.js.map +1 -1
- package/dist/components/Panel/MultiPanel.d.ts.map +1 -1
- package/dist/components/Panel/MultiPanel.js +14 -7
- package/dist/components/Panel/MultiPanel.js.map +1 -1
- package/dist/components/Panel/PanelContents.d.ts +2 -1
- package/dist/components/Panel/PanelContents.d.ts.map +1 -1
- package/dist/components/Panel/PanelContents.js +16 -11
- package/dist/components/Panel/PanelContents.js.map +1 -1
- package/dist/components/Panel/SinglePanel.d.ts.map +1 -1
- package/dist/components/Panel/SinglePanel.js +4 -3
- package/dist/components/Panel/SinglePanel.js.map +1 -1
- package/dist/components/Panel/ViewerWrapper.d.ts +1 -3
- package/dist/components/Panel/ViewerWrapper.d.ts.map +1 -1
- package/dist/components/Panel/ViewerWrapper.js +2 -3
- package/dist/components/Panel/ViewerWrapper.js.map +1 -1
- package/dist/components/Playground.d.ts.map +1 -1
- package/dist/components/Playground.js +351 -50
- package/dist/components/Playground.js.map +1 -1
- package/dist/components/PromptControls.d.ts.map +1 -1
- package/dist/components/PromptControls.js +39 -6
- package/dist/components/PromptControls.js.map +1 -1
- package/dist/components/ServerTrustMatchViewer.d.ts +11 -0
- package/dist/components/ServerTrustMatchViewer.d.ts.map +1 -0
- package/dist/components/ServerTrustMatchViewer.js +26 -0
- package/dist/components/ServerTrustMatchViewer.js.map +1 -0
- package/dist/components/Viewer.d.ts.map +1 -1
- package/dist/components/Viewer.js +54 -14
- package/dist/components/Viewer.js.map +1 -1
- package/dist/game/Chit.d.ts +6 -2
- package/dist/game/Chit.d.ts.map +1 -1
- package/dist/game/Chit.js +40 -27
- package/dist/game/Chit.js.map +1 -1
- package/dist/game/ClientTimeState.d.ts +1 -0
- package/dist/game/ClientTimeState.d.ts.map +1 -1
- package/dist/game/ClientTimeState.js +4 -2
- package/dist/game/ClientTimeState.js.map +1 -1
- package/dist/game/ConnectionObject.js.map +1 -1
- package/dist/game/ConnectionTransport.js +0 -1
- package/dist/game/ConnectionTransport.js.map +1 -1
- package/dist/game/DropdownChit.js.map +1 -1
- package/dist/game/GalleryItemChitChildrenSource.d.ts +1 -0
- package/dist/game/GalleryItemChitChildrenSource.d.ts.map +1 -1
- package/dist/game/GalleryItemChitChildrenSource.js +1 -1
- package/dist/game/GalleryItemChitChildrenSource.js.map +1 -1
- package/dist/game/GalleryItemRawSource.d.ts +1 -0
- package/dist/game/GalleryItemRawSource.d.ts.map +1 -1
- package/dist/game/GalleryItemRawSource.js +1 -0
- package/dist/game/GalleryItemRawSource.js.map +1 -1
- package/dist/game/Game.d.ts +2 -1
- package/dist/game/Game.d.ts.map +1 -1
- package/dist/game/GameBagChit.js.map +1 -1
- package/dist/game/GameButton.d.ts +1 -0
- package/dist/game/GameButton.d.ts.map +1 -1
- package/dist/game/GameButton.js +2 -9
- package/dist/game/GameButton.js.map +1 -1
- package/dist/game/GameDeckChit.d.ts +6 -0
- package/dist/game/GameDeckChit.d.ts.map +1 -1
- package/dist/game/GameDeckChit.js +33 -6
- package/dist/game/GameDeckChit.js.map +1 -1
- package/dist/game/GameMetaData.d.ts +18 -0
- package/dist/game/GameMetaData.d.ts.map +1 -0
- package/dist/game/GameMetaData.js +2 -0
- package/dist/game/GameMetaData.js.map +1 -0
- package/dist/game/GameTheme.d.ts +11 -0
- package/dist/game/GameTheme.d.ts.map +1 -1
- package/dist/game/GameTheme.js +19 -5
- package/dist/game/GameTheme.js.map +1 -1
- package/dist/game/Match.d.ts +2 -1
- package/dist/game/Match.d.ts.map +1 -1
- package/dist/game/Match.js +4 -3
- package/dist/game/Match.js.map +1 -1
- package/dist/game/MatchStorage.d.ts +10 -0
- package/dist/game/MatchStorage.d.ts.map +1 -1
- package/dist/game/MatchStorage.js +29 -0
- package/dist/game/MatchStorage.js.map +1 -1
- package/dist/game/ModalState.d.ts +1 -0
- package/dist/game/ModalState.d.ts.map +1 -1
- package/dist/game/ModalState.js +1 -0
- package/dist/game/ModalState.js.map +1 -1
- package/dist/game/OrderedOutlet.d.ts.map +1 -1
- package/dist/game/OrderedOutlet.js +6 -10
- package/dist/game/OrderedOutlet.js.map +1 -1
- package/dist/game/Pick.d.ts +11 -1
- package/dist/game/Pick.d.ts.map +1 -1
- package/dist/game/Pick.js +83 -11
- package/dist/game/Pick.js.map +1 -1
- package/dist/game/PlayerChit.d.ts +2 -1
- package/dist/game/PlayerChit.d.ts.map +1 -1
- package/dist/game/PlayerChit.js +12 -2
- package/dist/game/PlayerChit.js.map +1 -1
- package/dist/game/PlayerInfo.d.ts +2 -1
- package/dist/game/PlayerInfo.d.ts.map +1 -1
- package/dist/game/PlayerInfo.js +18 -5
- package/dist/game/PlayerInfo.js.map +1 -1
- package/dist/game/PlayerPromptStatusChit.js +0 -2
- package/dist/game/PlayerPromptStatusChit.js.map +1 -1
- package/dist/game/Prompt.d.ts +1 -11
- package/dist/game/Prompt.d.ts.map +1 -1
- package/dist/game/Prompt.js +0 -36
- package/dist/game/Prompt.js.map +1 -1
- package/dist/game/RootChit.d.ts +4 -0
- package/dist/game/RootChit.d.ts.map +1 -1
- package/dist/game/RootChit.js +36 -3
- package/dist/game/RootChit.js.map +1 -1
- package/dist/game/SparkChit.js +0 -3
- package/dist/game/SparkChit.js.map +1 -1
- package/dist/game/Turn.d.ts +9 -8
- package/dist/game/Turn.d.ts.map +1 -1
- package/dist/game/Turn.js +34 -42
- package/dist/game/Turn.js.map +1 -1
- package/dist/game/TurnState.d.ts +3 -2
- package/dist/game/TurnState.d.ts.map +1 -1
- package/dist/game/TurnState.js +22 -4
- package/dist/game/TurnState.js.map +1 -1
- package/dist/game/badAiTransport/BadAIClientPrompts.d.ts +14 -0
- package/dist/game/badAiTransport/BadAIClientPrompts.d.ts.map +1 -0
- package/dist/game/badAiTransport/BadAIClientPrompts.js +50 -0
- package/dist/game/badAiTransport/BadAIClientPrompts.js.map +1 -0
- package/dist/game/clientTransport/ClientPrompts.js +0 -2
- package/dist/game/clientTransport/ClientPrompts.js.map +1 -1
- package/dist/game/clientTransport/ClientStatus.js +0 -1
- package/dist/game/clientTransport/ClientStatus.js.map +1 -1
- package/dist/game/clientTransport/ClientTime.js +1 -3
- package/dist/game/clientTransport/ClientTime.js.map +1 -1
- package/dist/game/serverTransport/ServerPrompts.js +0 -1
- package/dist/game/serverTransport/ServerPrompts.js.map +1 -1
- package/dist/game/serverTransport/ServerStatus.js +0 -1
- package/dist/game/serverTransport/ServerStatus.js.map +1 -1
- package/dist/game/serverTransport/ServerTime.js +1 -2
- package/dist/game/serverTransport/ServerTime.js.map +1 -1
- package/dist/hooks/useButtonGalleriesOptions.d.ts +4 -0
- package/dist/hooks/useButtonGalleriesOptions.d.ts.map +1 -0
- package/dist/hooks/useButtonGalleriesOptions.js +7 -0
- package/dist/hooks/useButtonGalleriesOptions.js.map +1 -0
- package/dist/hooks/useEventChannelState.js +1 -1
- package/dist/hooks/useEventChannelState.js.map +1 -1
- package/dist/hooks/useLoadingStates.d.ts +17 -0
- package/dist/hooks/useLoadingStates.d.ts.map +1 -0
- package/dist/hooks/useLoadingStates.js +44 -0
- package/dist/hooks/useLoadingStates.js.map +1 -0
- package/dist/hooks/useModalState.d.ts +2 -1
- package/dist/hooks/useModalState.d.ts.map +1 -1
- package/dist/hooks/useModalState.js +2 -2
- package/dist/hooks/useModalState.js.map +1 -1
- package/dist/hooks/usePanelPositioning.d.ts +0 -1
- package/dist/hooks/usePanelPositioning.d.ts.map +1 -1
- package/dist/hooks/usePanelPositioning.js.map +1 -1
- package/dist/hooks/useTimeController.js.map +1 -1
- package/dist/hooks/useWebGlRenderer.js +0 -2
- package/dist/hooks/useWebGlRenderer.js.map +1 -1
- package/dist/index.d.ts +7 -5
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +17 -1
- package/dist/index.js.map +1 -1
- package/dist/rendering/CameraSpec.js.map +1 -1
- package/dist/rendering/CameraWrapperPerspective.d.ts.map +1 -1
- package/dist/rendering/CameraWrapperPerspective.js +1 -2
- package/dist/rendering/CameraWrapperPerspective.js.map +1 -1
- package/dist/rendering/ChitGalleryItemInstance.d.ts +2 -0
- package/dist/rendering/ChitGalleryItemInstance.d.ts.map +1 -1
- package/dist/rendering/ChitGalleryItemInstance.js +0 -12
- package/dist/rendering/ChitGalleryItemInstance.js.map +1 -1
- package/dist/rendering/ChitRenderInstance.d.ts +13 -2
- package/dist/rendering/ChitRenderInstance.d.ts.map +1 -1
- package/dist/rendering/ChitRenderInstance.js +95 -52
- package/dist/rendering/ChitRenderInstance.js.map +1 -1
- package/dist/rendering/ChitRenderSpec.d.ts +3 -0
- package/dist/rendering/ChitRenderSpec.d.ts.map +1 -1
- package/dist/rendering/ChitRenderSpec.js +1 -11
- package/dist/rendering/ChitRenderSpec.js.map +1 -1
- package/dist/rendering/HighlightSpec.js +0 -2
- package/dist/rendering/HighlightSpec.js.map +1 -1
- package/dist/rendering/LightSpec.js +1 -0
- package/dist/rendering/LightSpec.js.map +1 -1
- package/dist/rendering/RootChitRenderInstance.d.ts +5 -2
- package/dist/rendering/RootChitRenderInstance.d.ts.map +1 -1
- package/dist/rendering/RootChitRenderInstance.js +76 -17
- package/dist/rendering/RootChitRenderInstance.js.map +1 -1
- package/dist/rendering/Splay.js.map +1 -1
- package/dist/rendering/SplayCounter.d.ts.map +1 -1
- package/dist/rendering/SplayCounter.js +1 -1
- package/dist/rendering/SplayCounter.js.map +1 -1
- package/dist/rendering/TextureReferenceCounter.d.ts +1 -1
- package/dist/rendering/TextureReferenceCounter.d.ts.map +1 -1
- package/dist/rendering/TextureReferenceCounter.js +10 -10
- package/dist/rendering/TextureReferenceCounter.js.map +1 -1
- package/dist/rendering/outline/DepthVisualizationPass.js +0 -3
- package/dist/rendering/outline/DepthVisualizationPass.js.map +1 -1
- package/dist/rendering/outline/EffectComposer.js +0 -9
- package/dist/rendering/outline/EffectComposer.js.map +1 -1
- package/dist/rendering/outline/FullScreenQuad.js +0 -1
- package/dist/rendering/outline/FullScreenQuad.js.map +1 -1
- package/dist/rendering/outline/IDBasedOutlinePass.js +0 -19
- package/dist/rendering/outline/IDBasedOutlinePass.js.map +1 -1
- package/dist/rendering/outline/OutputPass.js +0 -5
- package/dist/rendering/outline/OutputPass.js.map +1 -1
- package/dist/rendering/outline/RenderPass.js +0 -2
- package/dist/rendering/outline/RenderPass.js.map +1 -1
- package/dist/rendering/outline/SceneWrapper.js +0 -2
- package/dist/rendering/outline/SceneWrapper.js.map +1 -1
- package/dist/rendering/outline/ShaderPass.js +0 -4
- package/dist/rendering/outline/ShaderPass.js.map +1 -1
- package/dist/rendering/outline/passes/DebugIDMappingPass.js +0 -2
- package/dist/rendering/outline/passes/DebugIDMappingPass.js.map +1 -1
- package/dist/rendering/outline/passes/DepthOcclusionPass.js +1 -3
- package/dist/rendering/outline/passes/DepthOcclusionPass.js.map +1 -1
- package/dist/rendering/outline/passes/InterMeshEdgeDetectionPass.js +0 -3
- package/dist/rendering/outline/passes/InterMeshEdgeDetectionPass.js.map +1 -1
- package/dist/rendering/outline/types.js.map +1 -1
- package/dist/utilities/Annotations.d.ts +59 -0
- package/dist/utilities/Annotations.d.ts.map +1 -1
- package/dist/utilities/Annotations.js +63 -0
- package/dist/utilities/Annotations.js.map +1 -1
- package/dist/utilities/BaseTable.js +0 -5
- package/dist/utilities/BaseTable.js.map +1 -1
- package/dist/utilities/CanvasStack/CanvasOperations.d.ts +10 -1
- package/dist/utilities/CanvasStack/CanvasOperations.d.ts.map +1 -1
- package/dist/utilities/CanvasStack/CanvasOperations.js +8 -0
- package/dist/utilities/CanvasStack/CanvasOperations.js.map +1 -1
- package/dist/utilities/CanvasStack/CanvasStack.js +0 -4
- package/dist/utilities/CanvasStack/CanvasStack.js.map +1 -1
- package/dist/utilities/CanvasStack/ImageCache.js +0 -4
- package/dist/utilities/CanvasStack/ImageCache.js.map +1 -1
- package/dist/utilities/CanvasStack/ReactCanvas.d.ts +4 -2
- package/dist/utilities/CanvasStack/ReactCanvas.d.ts.map +1 -1
- package/dist/utilities/CanvasStack/ReactCanvas.js +5 -2
- package/dist/utilities/CanvasStack/ReactCanvas.js.map +1 -1
- package/dist/utilities/CanvasStack/RichTextRenderer.d.ts.map +1 -1
- package/dist/utilities/CanvasStack/RichTextRenderer.js +12 -4
- package/dist/utilities/CanvasStack/RichTextRenderer.js.map +1 -1
- package/dist/utilities/Dice.js.map +1 -1
- package/dist/utilities/EventChannel.d.ts.map +1 -1
- package/dist/utilities/EventChannel.js +2 -3
- package/dist/utilities/EventChannel.js.map +1 -1
- package/dist/utilities/GlbLoader.d.ts +15 -0
- package/dist/utilities/GlbLoader.d.ts.map +1 -0
- package/dist/utilities/GlbLoader.js +212 -0
- package/dist/utilities/GlbLoader.js.map +1 -0
- package/dist/utilities/LayoutHelper.js +23 -2
- package/dist/utilities/LayoutHelper.js.map +1 -1
- package/dist/utilities/ObjectWithProps.d.ts.map +1 -1
- package/dist/utilities/ObjectWithProps.js +32 -3
- package/dist/utilities/ObjectWithProps.js.map +1 -1
- package/dist/utilities/ParameterizedCanvas.js +1 -1
- package/dist/utilities/ParameterizedCanvas.js.map +1 -1
- package/dist/utilities/StaticImage.js +0 -1
- package/dist/utilities/StaticImage.js.map +1 -1
- package/dist/utilities/ThreeDisposer.js +0 -1
- package/dist/utilities/ThreeDisposer.js.map +1 -1
- package/package.json +6 -5
- package/src/library/components/BottomBarButton.tsx +3 -0
- package/src/library/components/ClientTrustMatchViewer.tsx +23 -8
- package/src/library/components/ContextGalleryDisplay.tsx +2 -2
- package/src/library/components/DemoWrapper.tsx +113 -0
- package/src/library/components/{GalleryDisplay.tsx → FullScreenGalleryDisplay.tsx} +28 -2
- package/src/library/components/Gallery/AnimationController.ts +110 -0
- package/src/library/components/Gallery/BuiltItem.ts +385 -0
- package/src/library/components/Gallery/CameraManager.ts +54 -0
- package/src/library/components/Gallery/GalleryController.ts +193 -0
- package/src/library/components/Gallery/GalleryViewer.tsx +211 -0
- package/src/library/components/Gallery/LayoutManager.ts +166 -0
- package/src/library/components/Gallery/constants.ts +12 -0
- package/src/library/components/Gallery/index.ts +2 -0
- package/src/library/components/Gallery/types.ts +55 -0
- package/src/library/components/GalleryPlayground.tsx +1 -1
- package/src/library/components/GalleryViewer.tsx +4 -773
- package/src/library/components/GameDesigner.tsx +21 -4
- package/src/library/components/InlineGalleryDisplay.tsx +101 -0
- package/src/library/components/LiveButton.tsx +2 -1
- package/src/library/components/MatchViewer.tsx +32 -14
- package/src/library/components/Panel/MultiPanel.tsx +20 -8
- package/src/library/components/Panel/PanelContents.tsx +17 -12
- package/src/library/components/Panel/SinglePanel.tsx +5 -4
- package/src/library/components/Panel/ViewerWrapper.tsx +0 -5
- package/src/library/components/Playground.tsx +692 -119
- package/src/library/components/PromptControls.tsx +61 -8
- package/src/library/components/ServerTrustMatchViewer.tsx +53 -0
- package/src/library/components/Viewer.tsx +60 -20
- package/src/library/game/Chit.ts +46 -6
- package/src/library/game/ClientTimeState.ts +5 -1
- package/src/library/game/GalleryItemChitChildrenSource.ts +2 -0
- package/src/library/game/GalleryItemRawSource.ts +2 -0
- package/src/library/game/Game.ts +3 -1
- package/src/library/game/GameButton.ts +3 -0
- package/src/library/game/GameDeckChit.ts +36 -5
- package/src/library/game/GameMetaData.ts +19 -0
- package/src/library/game/GameTheme.ts +23 -5
- package/src/library/game/Match.ts +4 -3
- package/src/library/game/MatchStorage.ts +37 -0
- package/src/library/game/ModalState.ts +1 -0
- package/src/library/game/OrderedOutlet.ts +6 -6
- package/src/library/game/Pick.ts +98 -2
- package/src/library/game/PlayerChit.ts +13 -1
- package/src/library/game/PlayerInfo.ts +22 -3
- package/src/library/game/Prompt.ts +1 -36
- package/src/library/game/RootChit.ts +41 -1
- package/src/library/game/Turn.ts +37 -40
- package/src/library/game/TurnState.ts +22 -3
- package/src/library/game/badAiTransport/BadAIClientPrompts.ts +60 -0
- package/src/library/game/clientTransport/ClientTime.ts +1 -1
- package/src/library/game/serverTransport/ServerTime.ts +2 -2
- package/src/library/hooks/useButtonGalleriesOptions.tsx +9 -0
- package/src/library/hooks/useEventChannelState.ts +1 -1
- package/src/library/hooks/useLoadingStates.tsx +55 -0
- package/src/library/hooks/useModalState.tsx +2 -2
- package/src/library/hooks/usePanelPositioning.tsx +0 -1
- package/src/library/index.ts +21 -1
- package/src/library/rendering/CameraWrapperPerspective.ts +10 -12
- package/src/library/rendering/ChitGalleryItemInstance.ts +2 -0
- package/src/library/rendering/ChitRenderInstance.ts +119 -61
- package/src/library/rendering/ChitRenderSpec.ts +4 -0
- package/src/library/rendering/RootChitRenderInstance.ts +87 -13
- package/src/library/rendering/SplayCounter.tsx +2 -1
- package/src/library/rendering/TextureReferenceCounter.ts +9 -9
- package/src/library/rendering/outline/passes/DepthOcclusionPass.ts +1 -1
- package/src/library/utilities/Annotations.ts +99 -0
- package/src/library/utilities/CanvasStack/CanvasOperations.tsx +19 -1
- package/src/library/utilities/CanvasStack/ReactCanvas.tsx +10 -3
- package/src/library/utilities/CanvasStack/RichTextRenderer.ts +14 -4
- package/src/library/utilities/EventChannel.ts +2 -4
- package/src/library/utilities/GlbLoader.ts +292 -0
- package/src/library/utilities/LayoutHelper.ts +28 -2
- package/src/library/utilities/ObjectWithProps.ts +27 -3
- package/dist/components/GalleryDisplay.d.ts +0 -2
- package/dist/components/GalleryDisplay.d.ts.map +0 -1
- package/dist/components/GalleryDisplay.js +0 -42
- package/dist/components/GalleryDisplay.js.map +0 -1
- package/dist/utilities/OutlineCanvas.d.ts +0 -12
- package/dist/utilities/OutlineCanvas.d.ts.map +0 -1
- package/dist/utilities/OutlineCanvas.js +0 -31
- package/dist/utilities/OutlineCanvas.js.map +0 -1
- package/dist/utilities/OutlineGeometry.d.ts +0 -3
- package/dist/utilities/OutlineGeometry.d.ts.map +0 -1
- package/dist/utilities/OutlineGeometry.js +0 -57
- package/dist/utilities/OutlineGeometry.js.map +0 -1
- package/src/library/utilities/OutlineCanvas.tsx +0 -45
- package/src/library/utilities/OutlineGeometry.ts +0 -69
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ParameterizedCanvas.js","sourceRoot":"","sources":["../../src/library/utilities/ParameterizedCanvas.ts"],"names":[],"mappings":";;;;;;;;;AAGA,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACpD,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,gCAAgC,CAAC;AAExE,MAAM,OAAgB,mBAAoB,SAAQ,eAAe;IAAjE;;
|
|
1
|
+
{"version":3,"file":"ParameterizedCanvas.js","sourceRoot":"","sources":["../../src/library/utilities/ParameterizedCanvas.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,7 +8,6 @@ export class StaticImage extends ParameterizedCanvas {
|
|
|
8
8
|
this.image = image;
|
|
9
9
|
this.overlayColor = overlayColor;
|
|
10
10
|
this.backgroundColor = backgroundColor;
|
|
11
|
-
this.imageInfo = undefined;
|
|
12
11
|
this.width = this.image.primary.bounds.width;
|
|
13
12
|
this.height = this.image.primary.bounds.height;
|
|
14
13
|
this.imageInfo = JSON.stringify(this.image);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"StaticImage.js","sourceRoot":"","sources":["../../src/library/utilities/StaticImage.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAUvC,MAAM,OAAO,WAAY,SAAQ,mBAAmB;IAGlD,YACU,KAAgB,EAChB,YAAqB,EACrB,eAAwB;QAEhC,KAAK,EAAE,CAAC;QAJA,UAAK,GAAL,KAAK,CAAW;QAChB,iBAAY,GAAZ,YAAY,CAAS;QACrB,oBAAe,GAAf,eAAe,CAAS;
|
|
1
|
+
{"version":3,"file":"StaticImage.js","sourceRoot":"","sources":["../../src/library/utilities/StaticImage.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAUvC,MAAM,OAAO,WAAY,SAAQ,mBAAmB;IAGlD,YACU,KAAgB,EAChB,YAAqB,EACrB,eAAwB;QAEhC,KAAK,EAAE,CAAC;QAJA,UAAK,GAAL,KAAK,CAAW;QAChB,iBAAY,GAAZ,YAAY,CAAS;QACrB,oBAAe,GAAf,eAAe,CAAS;QAGhC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC;QAC7C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC;QAC/C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAES,MAAM;QACd,MAAM,SAAS,GAAG,KAAC,KAAK,IAAC,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,IAAI,QAAC,YAAY,EAAE,IAAI,CAAC,YAAY,GAAI,CAAC;QAErF,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,OAAO,CACL,MAAC,OAAO,eACN,KAAC,KAAK,IAAC,GAAG,EAAE,IAAI,CAAC,eAAe,GAAI,EACnC,SAAS,IACF,CACX,CAAC;QACJ,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,MAAM,CAAC,QAAQ,CAAC,KAAgB,EAAE,OAA4B;QAC5D,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;QACvF,OAAO,MAAM,CAAC,GAAG,EAAE,CAAC,QAAQ,CAAC;IAC/B,CAAC;IAED,MAAM,CAAC,OAAO,CAAC,KAAgB,EAAE,OAA4B;QAC3D,MAAM,MAAM,GAAG,IAAI,WAAW,CAAC,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC;QACvF,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC;QACrC,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,EAAE,IAAI,CAAC,CAAC;YACnC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,OAAO,CAAC,EAAE,IAAI,CAAC,CAAC;YACnC,OAAO,CAAC,KAAK,GAAG,cAAc,CAAC;YAC/B,OAAO,CAAC,KAAK,GAAG,cAAc,CAAC;QACjC,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;CACF"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ThreeDisposer.js","sourceRoot":"","sources":["../../src/library/utilities/ThreeDisposer.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,aAAa;IACxB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;QAEnC,eAAU,GAAsC,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"ThreeDisposer.js","sourceRoot":"","sources":["../../src/library/utilities/ThreeDisposer.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,aAAa;IACxB,YAAoB,OAAuB;QAAvB,YAAO,GAAP,OAAO,CAAgB;QAEnC,eAAU,GAAsC,EAAE,CAAC;IAFb,CAAC;IAKxC,YAAY,CAAC,KAAa;QAC/B,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,cAAc,EAAE,CAAC;QACxB,CAAC;IACH,CAAC;IAEM,QAAQ,CAAC,IAAY,EAAE,GAAM;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG;YACtB,IAAI;YACJ,KAAK,EAAE,KAAK;YACZ,WAAW,EAAE,IAAI,CAAC,GAAG,EAAE;YACvB,GAAG;SACJ,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,OAAuB,EAAE,EAAc;QACxD,OAAO,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,IAAI,EAAE,EAAE;YAC5B,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC;IAC7C,CAAC;IAEM,QAAQ,CAAC,KAAkB,EAAE,EAAc;QAChD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;QAEzB,sCAAsC;QACtC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAC7C,IAAI,GAAG,CAAC,KAAK,EAAE,CAAC;gBACd,GAAG,CAAC,KAAK,GAAG,KAAK,CAAC;gBAClB,GAAG,CAAC,WAAW,GAAG,GAAG,CAAC;YACxB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,yCAAyC;QACzC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE;YACrB,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YAClC,IAAI,GAAG,EAAE,CAAC;gBACR,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC;YACnB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,6CAA6C;QAC7C,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YAC7C,IAAI,CAAC,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC,WAAW,GAAG,GAAG,GAAG,IAAI,EAAE,CAAC;gBAC/C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACtB,OAAO,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YACnC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@pretty-chitty/core",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.2.0",
|
|
4
4
|
"license": "SEE LICENSE IN LICENSE.md",
|
|
5
5
|
"description": "A TypeScript framework for building high-quality async or realtime 3D strategy board games",
|
|
6
6
|
"author": "Pretty Chitty, LLC",
|
|
@@ -9,6 +9,9 @@
|
|
|
9
9
|
"type": "git",
|
|
10
10
|
"url": "https://github.com/pretty-chitty/pretty-chitty.git"
|
|
11
11
|
},
|
|
12
|
+
"sideEffects": [
|
|
13
|
+
"*.css"
|
|
14
|
+
],
|
|
12
15
|
"keywords": [
|
|
13
16
|
"game-engine",
|
|
14
17
|
"board-game",
|
|
@@ -39,6 +42,7 @@
|
|
|
39
42
|
"LICENSE.md"
|
|
40
43
|
],
|
|
41
44
|
"devDependencies": {
|
|
45
|
+
"@fontsource/quicksand": "^5.2.10",
|
|
42
46
|
"@babel/core": "^7.23.3",
|
|
43
47
|
"@babel/plugin-proposal-class-properties": "^7.18.6",
|
|
44
48
|
"@babel/plugin-proposal-decorators": "^7.23.5",
|
|
@@ -51,7 +55,6 @@
|
|
|
51
55
|
"@types/base-64": "^1.0.2",
|
|
52
56
|
"@types/color": "^3.0.6",
|
|
53
57
|
"@types/jest": "^29.5.11",
|
|
54
|
-
"@types/next-tick": "^1.0.2",
|
|
55
58
|
"@types/node": "^20.11.3",
|
|
56
59
|
"@types/wheel": "^0.0.3",
|
|
57
60
|
"@typescript-eslint/eslint-plugin": "^6.21.0",
|
|
@@ -89,7 +92,6 @@
|
|
|
89
92
|
"@egjs/hammerjs": "^2.0.17",
|
|
90
93
|
"@emotion/react": "^11.11.0",
|
|
91
94
|
"@emotion/styled": "^11.11.0",
|
|
92
|
-
"@fontsource/raleway": "^5.0.16",
|
|
93
95
|
"@material-ui/core": "^4.12.4",
|
|
94
96
|
"@material-ui/icons": "^4.11.3",
|
|
95
97
|
"@mui/icons-material": "^5.15.0",
|
|
@@ -106,7 +108,6 @@
|
|
|
106
108
|
"color": "^4.2.3",
|
|
107
109
|
"extrude-polyline": "^1.0.6",
|
|
108
110
|
"mui-modal-provider": "^2.4.2",
|
|
109
|
-
"next-tick": "^1.1.0",
|
|
110
111
|
"quick-lru": "^7.0.0",
|
|
111
112
|
"react": "^18.2.0",
|
|
112
113
|
"react-dom": "^18.2.0",
|
|
@@ -125,7 +126,7 @@
|
|
|
125
126
|
"prepare": "ts-patch install -s",
|
|
126
127
|
"dev": "webpack serve",
|
|
127
128
|
"start": "webpack serve",
|
|
128
|
-
"build": "rm -rf dist && yarn tsc --project tsconfig.build.json && yarn
|
|
129
|
+
"build": "rm -rf dist && yarn tsc --project tsconfig.build.json && yarn pack",
|
|
129
130
|
"build:no-sourcemaps": "rm -rf dist && yarn tsc --project tsconfig.build.json --sourceMap false --declarationMap false && yarn pack",
|
|
130
131
|
"build:demo": "NODE_ENV=production webpack --config webpack.demo.config.js",
|
|
131
132
|
"build:all": "yarn build && yarn build:demo",
|
|
@@ -16,6 +16,7 @@ export default function BottomBarButton({
|
|
|
16
16
|
highlight = false,
|
|
17
17
|
disabled = false,
|
|
18
18
|
removeLabel = false,
|
|
19
|
+
invisible = false,
|
|
19
20
|
onClick,
|
|
20
21
|
onLongClick,
|
|
21
22
|
whileHolding,
|
|
@@ -24,6 +25,7 @@ export default function BottomBarButton({
|
|
|
24
25
|
label?: string;
|
|
25
26
|
disabled?: boolean;
|
|
26
27
|
removeLabel?: boolean;
|
|
28
|
+
invisible?: boolean;
|
|
27
29
|
highlight?: boolean;
|
|
28
30
|
onClick?: () => void;
|
|
29
31
|
onLongClick?: () => void;
|
|
@@ -142,6 +144,7 @@ export default function BottomBarButton({
|
|
|
142
144
|
top: isPressed ? 1 : 0,
|
|
143
145
|
left: isPressed ? 1 : 0,
|
|
144
146
|
userSelect: "none",
|
|
147
|
+
opacity: invisible ? 0 : 1,
|
|
145
148
|
cursor: !disabled ? "pointer" : undefined,
|
|
146
149
|
p: 1,
|
|
147
150
|
height: "100%",
|
|
@@ -9,6 +9,7 @@ import { MatchViewer } from "./MatchViewer";
|
|
|
9
9
|
import { Match } from "../game/Match";
|
|
10
10
|
import { Connection } from "../game/Connection";
|
|
11
11
|
import { LocalConnectionTransport } from "../game/ConnectionTransport";
|
|
12
|
+
import { LoadingStateProvider, LoadingStates, LoadingStatesCallback } from "../hooks/useLoadingStates";
|
|
12
13
|
|
|
13
14
|
export function ClientTrustMatchViewer({
|
|
14
15
|
playerId,
|
|
@@ -16,22 +17,34 @@ export function ClientTrustMatchViewer({
|
|
|
16
17
|
game,
|
|
17
18
|
matchStorage,
|
|
18
19
|
onBack,
|
|
20
|
+
onLoadProgress,
|
|
21
|
+
options = {},
|
|
19
22
|
}: {
|
|
20
23
|
playerId: string;
|
|
21
24
|
players: IPlayerInfo[];
|
|
22
25
|
game: Game<any, any>;
|
|
23
26
|
matchStorage: IMatchStorage;
|
|
24
27
|
onBack?: () => void;
|
|
28
|
+
onLoadProgress?: LoadingStatesCallback;
|
|
29
|
+
options?: any;
|
|
25
30
|
}) {
|
|
31
|
+
const [loadingStates] = useState<LoadingStates>(new LoadingStates());
|
|
26
32
|
const [match, setMatch] = useState<Match<any, any> | undefined>();
|
|
27
33
|
const [localConnection, setLocalConnection] = useState<Connection | undefined>();
|
|
28
34
|
|
|
35
|
+
useEffect(() => {
|
|
36
|
+
if (onLoadProgress) {
|
|
37
|
+
return loadingStates.onChange(onLoadProgress);
|
|
38
|
+
}
|
|
39
|
+
}, [loadingStates, onLoadProgress]);
|
|
40
|
+
|
|
29
41
|
useEffect(() => {
|
|
30
42
|
if (game && players && matchStorage) {
|
|
31
43
|
const match = new Match(
|
|
32
44
|
game,
|
|
33
45
|
players.map((p) => new PlayerInfo(p)),
|
|
34
46
|
matchStorage,
|
|
47
|
+
options,
|
|
35
48
|
);
|
|
36
49
|
let cancelled = false;
|
|
37
50
|
match.load().then(() => {
|
|
@@ -48,7 +61,7 @@ export function ClientTrustMatchViewer({
|
|
|
48
61
|
} else {
|
|
49
62
|
setMatch(undefined);
|
|
50
63
|
}
|
|
51
|
-
}, [game, matchStorage, players]);
|
|
64
|
+
}, [game, matchStorage, players, options]);
|
|
52
65
|
|
|
53
66
|
useEffect(() => {
|
|
54
67
|
if (!match) {
|
|
@@ -72,12 +85,14 @@ export function ClientTrustMatchViewer({
|
|
|
72
85
|
}
|
|
73
86
|
|
|
74
87
|
return (
|
|
75
|
-
<
|
|
76
|
-
<
|
|
77
|
-
<
|
|
78
|
-
<
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
88
|
+
<LoadingStateProvider loadingStates={loadingStates}>
|
|
89
|
+
<GameProvider game={game}>
|
|
90
|
+
<ConnectionProvider connection={localConnection}>
|
|
91
|
+
<PlayerProvider playerId={playerId}>
|
|
92
|
+
<MatchViewer onBack={onBack} />
|
|
93
|
+
</PlayerProvider>
|
|
94
|
+
</ConnectionProvider>
|
|
95
|
+
</GameProvider>
|
|
96
|
+
</LoadingStateProvider>
|
|
82
97
|
);
|
|
83
98
|
}
|
|
@@ -56,13 +56,13 @@ export function ContextGalleryDisplay({ size }: { size: number }) {
|
|
|
56
56
|
<GalleryViewer
|
|
57
57
|
fov={2}
|
|
58
58
|
angle={0}
|
|
59
|
-
showSummary={
|
|
59
|
+
showSummary={"none"}
|
|
60
60
|
paused={items.length > 0 ? false : true}
|
|
61
61
|
items={items ?? []}
|
|
62
62
|
tweenDuration={0}
|
|
63
63
|
galleryItemWidth={size - theme.spacing * 2}
|
|
64
64
|
galleryItemHeight={size - theme.spacing * 2}
|
|
65
|
-
itemSpacing={
|
|
65
|
+
itemSpacing={2}
|
|
66
66
|
w={size}
|
|
67
67
|
h={size}
|
|
68
68
|
/>
|
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import React, { useEffect, useState } from "react";
|
|
2
|
+
|
|
3
|
+
import { Chit } from "../game/Chit";
|
|
4
|
+
import { MatchViewer } from "./MatchViewer";
|
|
5
|
+
import { Game } from "../game/Game";
|
|
6
|
+
import { GameProvider } from "../hooks/useGame";
|
|
7
|
+
import { ConnectionProvider } from "../hooks/useConnection";
|
|
8
|
+
import { Connection } from "../game/Connection";
|
|
9
|
+
import { LocalConnectionTransport } from "../game/ConnectionTransport";
|
|
10
|
+
import { Match } from "../game/Match";
|
|
11
|
+
import { PlayerInfo } from "../game/PlayerInfo";
|
|
12
|
+
import { EphemeralMatchStorage } from "../game/MatchStorage";
|
|
13
|
+
import { PlayerProvider } from "../hooks/usePlayer";
|
|
14
|
+
import { LoadingStateProvider, LoadingStates } from "../hooks/useLoadingStates";
|
|
15
|
+
import { BadAIClientPrompts } from "../game/badAiTransport/BadAIClientPrompts";
|
|
16
|
+
import { RootChit } from "../game/RootChit";
|
|
17
|
+
|
|
18
|
+
export interface IChitLibrary {
|
|
19
|
+
[key: string]: new () => Chit;
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
function PlayerEditor({ playerId, match, showBack }: { showBack?: boolean; playerId: string; match: Match<any, any> }) {
|
|
23
|
+
const [localConnection, setLocalConnection] = useState<Connection | undefined>();
|
|
24
|
+
const [, setRemoteConnection] = useState<LocalConnectionTransport>(new LocalConnectionTransport());
|
|
25
|
+
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
const newRemoteConnection = new LocalConnectionTransport();
|
|
28
|
+
const newConnection = new Connection(new LocalConnectionTransport());
|
|
29
|
+
(newConnection.transport as LocalConnectionTransport).connect(newRemoteConnection);
|
|
30
|
+
match.connect(newRemoteConnection, playerId);
|
|
31
|
+
|
|
32
|
+
const opponentRemoteConnection = new LocalConnectionTransport();
|
|
33
|
+
const opponentConnection = new Connection(new LocalConnectionTransport());
|
|
34
|
+
opponentConnection.register(new BadAIClientPrompts<any, any>("p1", opponentConnection), "ClientPrompts");
|
|
35
|
+
(opponentConnection.transport as LocalConnectionTransport).connect(opponentRemoteConnection);
|
|
36
|
+
match.connect(opponentRemoteConnection, "p1");
|
|
37
|
+
|
|
38
|
+
setLocalConnection(newConnection);
|
|
39
|
+
setRemoteConnection(newRemoteConnection);
|
|
40
|
+
return () => {
|
|
41
|
+
newConnection.dispose();
|
|
42
|
+
};
|
|
43
|
+
}, [match, playerId]);
|
|
44
|
+
|
|
45
|
+
if (!localConnection) {
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
return (
|
|
50
|
+
<ConnectionProvider connection={localConnection}>
|
|
51
|
+
<PlayerProvider playerId={playerId}>
|
|
52
|
+
<MatchViewer
|
|
53
|
+
onBack={
|
|
54
|
+
showBack
|
|
55
|
+
? () => {
|
|
56
|
+
window.history.back();
|
|
57
|
+
}
|
|
58
|
+
: undefined
|
|
59
|
+
}
|
|
60
|
+
/>
|
|
61
|
+
</PlayerProvider>
|
|
62
|
+
</ConnectionProvider>
|
|
63
|
+
);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
function Editor({ game }: { game: Game<any, any> }) {
|
|
67
|
+
const [match, setMatch] = useState<Match<any, any> | null>(null);
|
|
68
|
+
|
|
69
|
+
useEffect(() => {
|
|
70
|
+
const storage = new EphemeralMatchStorage("demogame");
|
|
71
|
+
|
|
72
|
+
const tempRoot = new game.chitLibrary.Root() as RootChit<any>;
|
|
73
|
+
const playerCount = tempRoot.setupDemoGame();
|
|
74
|
+
const configOptions = tempRoot.getCurrentlySelectedMatchOptions();
|
|
75
|
+
|
|
76
|
+
const players = [];
|
|
77
|
+
for (let i = 0; i < playerCount; i++) {
|
|
78
|
+
players.push(new PlayerInfo(`p${i}`, i === 0 ? "Human" : `Robot ${i}`));
|
|
79
|
+
}
|
|
80
|
+
const match = new Match(game, players, storage, configOptions);
|
|
81
|
+
let cancelled = false;
|
|
82
|
+
match.load().then(() => {
|
|
83
|
+
if (cancelled) {
|
|
84
|
+
return;
|
|
85
|
+
}
|
|
86
|
+
match.start();
|
|
87
|
+
setMatch(match);
|
|
88
|
+
});
|
|
89
|
+
return () => {
|
|
90
|
+
match.dispose();
|
|
91
|
+
cancelled = true;
|
|
92
|
+
};
|
|
93
|
+
}, [game]);
|
|
94
|
+
|
|
95
|
+
if (!match) {
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
return (
|
|
100
|
+
<GameProvider game={game}>
|
|
101
|
+
<PlayerEditor playerId={"p0"} match={match} showBack />
|
|
102
|
+
</GameProvider>
|
|
103
|
+
);
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
export function DemoWrapper({ game }: { game: Game<any, any> }) {
|
|
107
|
+
const [loadingStates] = useState<LoadingStates>(new LoadingStates());
|
|
108
|
+
return (
|
|
109
|
+
<LoadingStateProvider loadingStates={loadingStates}>
|
|
110
|
+
<Editor game={game} />
|
|
111
|
+
</LoadingStateProvider>
|
|
112
|
+
);
|
|
113
|
+
}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import React, { useEffect, useState, useRef } from "react";
|
|
2
|
-
import { Box } from "@mui/material";
|
|
2
|
+
import { Box, IconButton } from "@mui/material";
|
|
3
3
|
import { useEventChannelState } from "../hooks/useEventChannelState";
|
|
4
4
|
import { useModalState } from "../hooks/useModalState";
|
|
5
5
|
import { GalleryItem, GalleryViewer } from "./GalleryViewer";
|
|
@@ -7,10 +7,12 @@ import useSize from "@react-hook/size";
|
|
|
7
7
|
import { useAnimationSpeedMultiplier } from "../hooks/useTimeController";
|
|
8
8
|
import { useGameTheme } from "../hooks/useGameTheme";
|
|
9
9
|
import { GameModalBackdrop } from "./GameModalBackdrop";
|
|
10
|
+
import { BrandingWatermark } from "@mui/icons-material";
|
|
11
|
+
import { useButtonGalleriesOptions } from "../hooks/useButtonGalleriesOptions";
|
|
10
12
|
|
|
11
13
|
const DELAY = 300;
|
|
12
14
|
|
|
13
|
-
export function
|
|
15
|
+
export function FullScreenGalleryDisplay() {
|
|
14
16
|
const theme = useGameTheme();
|
|
15
17
|
const animationSpeedMultiplier = useAnimationSpeedMultiplier();
|
|
16
18
|
const ref = useRef(null);
|
|
@@ -18,6 +20,9 @@ export function GalleryDisplay() {
|
|
|
18
20
|
const modalState = useModalState();
|
|
19
21
|
const [items, setItems] = useState<GalleryItem[] | undefined>(undefined);
|
|
20
22
|
const [source, setSource] = useEventChannelState(modalState.gallerySource);
|
|
23
|
+
const [_inlineSource, setInlineSource] = useEventChannelState(modalState.inlineGallerySource);
|
|
24
|
+
const [_galleryDisplayMode, setGalleryDisplayMode] = useButtonGalleriesOptions();
|
|
25
|
+
|
|
21
26
|
const hasItems = items && items?.length > 0;
|
|
22
27
|
|
|
23
28
|
useEffect(() => {
|
|
@@ -39,15 +44,36 @@ export function GalleryDisplay() {
|
|
|
39
44
|
// This has to be outside of the modal backdrop so we can get the size correctly
|
|
40
45
|
<Box ref={ref} sx={{ position: "absolute", top: 0, left: 0, right: 0, bottom: 0 }}>
|
|
41
46
|
<GameModalBackdrop visible={!!hasItems}>
|
|
47
|
+
{source?.inlineGallerySize && (
|
|
48
|
+
<IconButton
|
|
49
|
+
sx={{
|
|
50
|
+
backgroundColor: theme.inlineGalleryButtonBackgroundColor,
|
|
51
|
+
position: "absolute",
|
|
52
|
+
bottom: 4,
|
|
53
|
+
right: 4,
|
|
54
|
+
zIndex: 2,
|
|
55
|
+
}}
|
|
56
|
+
size="small"
|
|
57
|
+
onClick={() => {
|
|
58
|
+
setInlineSource(source);
|
|
59
|
+
setSource(undefined);
|
|
60
|
+
setGalleryDisplayMode("inline");
|
|
61
|
+
}}
|
|
62
|
+
>
|
|
63
|
+
<BrandingWatermark sx={{ color: theme.inlineGalleryButtonForegroundColor }} />
|
|
64
|
+
</IconButton>
|
|
65
|
+
)}
|
|
42
66
|
<GalleryViewer
|
|
43
67
|
onClose={() => {
|
|
44
68
|
setSource(undefined);
|
|
45
69
|
}}
|
|
70
|
+
fov={10}
|
|
46
71
|
items={items ?? []}
|
|
47
72
|
tweenDuration={DELAY * animationSpeedMultiplier * 0.8}
|
|
48
73
|
galleryItemWidth={theme.galleryItemWidth}
|
|
49
74
|
galleryItemHeight={theme.galleryItemHeight}
|
|
50
75
|
itemSpacing={theme.galleryItemSpacing}
|
|
76
|
+
showSummary="full"
|
|
51
77
|
w={width}
|
|
52
78
|
h={height}
|
|
53
79
|
/>
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { Easing, Tween } from "@tweenjs/tween.js";
|
|
2
|
+
import { BuiltItem } from "./BuiltItem";
|
|
3
|
+
import { MAX_SNAP_DURATION, SNAP_DURATION_MULTIPLIER } from "./constants";
|
|
4
|
+
|
|
5
|
+
export class AnimationController {
|
|
6
|
+
public dirty = false;
|
|
7
|
+
private tween: Tween<{ x: number }> | undefined;
|
|
8
|
+
private offsetX = 0;
|
|
9
|
+
private tweenDuration = 250;
|
|
10
|
+
|
|
11
|
+
getOffsetX(): number {
|
|
12
|
+
return this.offsetX;
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
isAnimating(): boolean {
|
|
16
|
+
return this.tween !== undefined;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
get exitTweenDuration() {
|
|
20
|
+
return this.tweenDuration;
|
|
21
|
+
}
|
|
22
|
+
get enterTweenDuration() {
|
|
23
|
+
return this.tweenDuration;
|
|
24
|
+
}
|
|
25
|
+
get changeIndexTweenDuration() {
|
|
26
|
+
return this.tweenDuration;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
setTweenDuration(duration: number) {
|
|
30
|
+
this.tweenDuration = duration;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
stop() {
|
|
34
|
+
this.tween?.stop();
|
|
35
|
+
this.tween = undefined;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
pan(
|
|
39
|
+
deltaX: number,
|
|
40
|
+
animate: boolean,
|
|
41
|
+
items: BuiltItem[],
|
|
42
|
+
itemsPerPage: number,
|
|
43
|
+
itemWidth: number,
|
|
44
|
+
itemSpacing: number,
|
|
45
|
+
w: number,
|
|
46
|
+
) {
|
|
47
|
+
const max = 0;
|
|
48
|
+
const min = -(items.length - Math.min(items.length, itemsPerPage)) * (itemWidth + itemSpacing);
|
|
49
|
+
|
|
50
|
+
this.stop();
|
|
51
|
+
this.dirty = true;
|
|
52
|
+
|
|
53
|
+
if (!animate) {
|
|
54
|
+
this.applyPanOffset(deltaX, max, min, w, items);
|
|
55
|
+
} else {
|
|
56
|
+
this.animatePanToNearest(deltaX, max, min, itemWidth, itemSpacing, items);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
private applyPanOffset(delta: number, max: number, min: number, w: number, items: BuiltItem[]) {
|
|
61
|
+
this.offsetX += delta;
|
|
62
|
+
this.offsetX = Math.max(min - w / 2, Math.min(max + w / 2, this.offsetX));
|
|
63
|
+
items.forEach((item) => {
|
|
64
|
+
item.baseOffsetX = this.offsetX;
|
|
65
|
+
});
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
private animatePanToNearest(
|
|
69
|
+
delta: number,
|
|
70
|
+
max: number,
|
|
71
|
+
min: number,
|
|
72
|
+
itemWidth: number,
|
|
73
|
+
itemSpacing: number,
|
|
74
|
+
items: BuiltItem[],
|
|
75
|
+
) {
|
|
76
|
+
let target = this.offsetX + delta;
|
|
77
|
+
const itemIndex = Math.round(target / (itemWidth + itemSpacing));
|
|
78
|
+
target = itemIndex * (itemWidth + itemSpacing);
|
|
79
|
+
target = Math.max(min, Math.min(max, target));
|
|
80
|
+
|
|
81
|
+
const duration = 0.0001 + Math.min(MAX_SNAP_DURATION, SNAP_DURATION_MULTIPLIER * Math.abs(target - this.offsetX));
|
|
82
|
+
|
|
83
|
+
this.tween = new Tween({ x: this.offsetX })
|
|
84
|
+
.onUpdate(({ x }) => {
|
|
85
|
+
this.dirty = true;
|
|
86
|
+
this.offsetX = x;
|
|
87
|
+
items.forEach((item) => {
|
|
88
|
+
item.baseOffsetX = x;
|
|
89
|
+
});
|
|
90
|
+
})
|
|
91
|
+
.easing(Easing.Quadratic.Out)
|
|
92
|
+
.to({ x: target }, duration)
|
|
93
|
+
.onComplete(() => {
|
|
94
|
+
this.tween = undefined;
|
|
95
|
+
})
|
|
96
|
+
.start();
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
update(): boolean {
|
|
100
|
+
let changed = this.dirty;
|
|
101
|
+
|
|
102
|
+
if (this.tween) {
|
|
103
|
+
this.tween.update();
|
|
104
|
+
changed = true;
|
|
105
|
+
}
|
|
106
|
+
this.dirty = false;
|
|
107
|
+
|
|
108
|
+
return changed;
|
|
109
|
+
}
|
|
110
|
+
}
|