@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.
Files changed (410) hide show
  1. package/dist/components/BottomBarButton.d.ts +2 -1
  2. package/dist/components/BottomBarButton.d.ts.map +1 -1
  3. package/dist/components/BottomBarButton.js +2 -1
  4. package/dist/components/BottomBarButton.js.map +1 -1
  5. package/dist/components/ClientTrustMatchViewer.d.ts +4 -1
  6. package/dist/components/ClientTrustMatchViewer.d.ts.map +1 -1
  7. package/dist/components/ClientTrustMatchViewer.js +11 -4
  8. package/dist/components/ClientTrustMatchViewer.js.map +1 -1
  9. package/dist/components/ContextGalleryDisplay.js +1 -1
  10. package/dist/components/ContextGalleryDisplay.js.map +1 -1
  11. package/dist/components/DemoWrapper.d.ts +9 -0
  12. package/dist/components/DemoWrapper.d.ts.map +1 -0
  13. package/dist/components/DemoWrapper.js +76 -0
  14. package/dist/components/DemoWrapper.js.map +1 -0
  15. package/dist/components/FullScreenGalleryDisplay.d.ts +2 -0
  16. package/dist/components/FullScreenGalleryDisplay.d.ts.map +1 -0
  17. package/dist/components/FullScreenGalleryDisplay.js +56 -0
  18. package/dist/components/FullScreenGalleryDisplay.js.map +1 -0
  19. package/dist/components/Gallery/AnimationController.d.ts +19 -0
  20. package/dist/components/Gallery/AnimationController.d.ts.map +1 -0
  21. package/dist/components/Gallery/AnimationController.js +81 -0
  22. package/dist/components/Gallery/AnimationController.js.map +1 -0
  23. package/dist/components/Gallery/BuiltItem.d.ts +58 -0
  24. package/dist/components/Gallery/BuiltItem.d.ts.map +1 -0
  25. package/dist/components/Gallery/BuiltItem.js +301 -0
  26. package/dist/components/Gallery/BuiltItem.js.map +1 -0
  27. package/dist/components/Gallery/CameraManager.d.ts +14 -0
  28. package/dist/components/Gallery/CameraManager.d.ts.map +1 -0
  29. package/dist/components/Gallery/CameraManager.js +41 -0
  30. package/dist/components/Gallery/CameraManager.js.map +1 -0
  31. package/dist/components/Gallery/GalleryController.d.ts +30 -0
  32. package/dist/components/Gallery/GalleryController.d.ts.map +1 -0
  33. package/dist/components/Gallery/GalleryController.js +134 -0
  34. package/dist/components/Gallery/GalleryController.js.map +1 -0
  35. package/dist/components/Gallery/GalleryViewer.d.ts +18 -0
  36. package/dist/components/Gallery/GalleryViewer.d.ts.map +1 -0
  37. package/dist/components/Gallery/GalleryViewer.js +141 -0
  38. package/dist/components/Gallery/GalleryViewer.js.map +1 -0
  39. package/dist/components/Gallery/LayoutManager.d.ts +49 -0
  40. package/dist/components/Gallery/LayoutManager.d.ts.map +1 -0
  41. package/dist/components/Gallery/LayoutManager.js +129 -0
  42. package/dist/components/Gallery/LayoutManager.js.map +1 -0
  43. package/dist/components/Gallery/constants.d.ts +13 -0
  44. package/dist/components/Gallery/constants.d.ts.map +1 -0
  45. package/dist/components/Gallery/constants.js +13 -0
  46. package/dist/components/Gallery/constants.js.map +1 -0
  47. package/dist/components/Gallery/index.d.ts +3 -0
  48. package/dist/components/Gallery/index.d.ts.map +1 -0
  49. package/dist/components/Gallery/index.js +2 -0
  50. package/dist/components/Gallery/index.js.map +1 -0
  51. package/dist/components/Gallery/types.d.ts +45 -0
  52. package/dist/components/Gallery/types.d.ts.map +1 -0
  53. package/dist/components/Gallery/types.js +2 -0
  54. package/dist/components/Gallery/types.js.map +1 -0
  55. package/dist/components/GalleryPlayground.js +1 -1
  56. package/dist/components/GalleryPlayground.js.map +1 -1
  57. package/dist/components/GalleryViewer.d.ts +2 -47
  58. package/dist/components/GalleryViewer.d.ts.map +1 -1
  59. package/dist/components/GalleryViewer.js +3 -569
  60. package/dist/components/GalleryViewer.js.map +1 -1
  61. package/dist/components/GameDesigner.d.ts.map +1 -1
  62. package/dist/components/GameDesigner.js +13 -2
  63. package/dist/components/GameDesigner.js.map +1 -1
  64. package/dist/components/InlineGalleryDisplay.d.ts +2 -0
  65. package/dist/components/InlineGalleryDisplay.d.ts.map +1 -0
  66. package/dist/components/InlineGalleryDisplay.js +69 -0
  67. package/dist/components/InlineGalleryDisplay.js.map +1 -0
  68. package/dist/components/LiveButton.d.ts.map +1 -1
  69. package/dist/components/LiveButton.js +1 -1
  70. package/dist/components/LiveButton.js.map +1 -1
  71. package/dist/components/MatchViewer.d.ts +0 -1
  72. package/dist/components/MatchViewer.d.ts.map +1 -1
  73. package/dist/components/MatchViewer.js +20 -10
  74. package/dist/components/MatchViewer.js.map +1 -1
  75. package/dist/components/Panel/MultiPanel.d.ts.map +1 -1
  76. package/dist/components/Panel/MultiPanel.js +14 -7
  77. package/dist/components/Panel/MultiPanel.js.map +1 -1
  78. package/dist/components/Panel/PanelContents.d.ts +2 -1
  79. package/dist/components/Panel/PanelContents.d.ts.map +1 -1
  80. package/dist/components/Panel/PanelContents.js +16 -11
  81. package/dist/components/Panel/PanelContents.js.map +1 -1
  82. package/dist/components/Panel/SinglePanel.d.ts.map +1 -1
  83. package/dist/components/Panel/SinglePanel.js +4 -3
  84. package/dist/components/Panel/SinglePanel.js.map +1 -1
  85. package/dist/components/Panel/ViewerWrapper.d.ts +1 -3
  86. package/dist/components/Panel/ViewerWrapper.d.ts.map +1 -1
  87. package/dist/components/Panel/ViewerWrapper.js +2 -3
  88. package/dist/components/Panel/ViewerWrapper.js.map +1 -1
  89. package/dist/components/Playground.d.ts.map +1 -1
  90. package/dist/components/Playground.js +351 -50
  91. package/dist/components/Playground.js.map +1 -1
  92. package/dist/components/PromptControls.d.ts.map +1 -1
  93. package/dist/components/PromptControls.js +39 -6
  94. package/dist/components/PromptControls.js.map +1 -1
  95. package/dist/components/ServerTrustMatchViewer.d.ts +11 -0
  96. package/dist/components/ServerTrustMatchViewer.d.ts.map +1 -0
  97. package/dist/components/ServerTrustMatchViewer.js +26 -0
  98. package/dist/components/ServerTrustMatchViewer.js.map +1 -0
  99. package/dist/components/Viewer.d.ts.map +1 -1
  100. package/dist/components/Viewer.js +54 -14
  101. package/dist/components/Viewer.js.map +1 -1
  102. package/dist/game/Chit.d.ts +6 -2
  103. package/dist/game/Chit.d.ts.map +1 -1
  104. package/dist/game/Chit.js +40 -27
  105. package/dist/game/Chit.js.map +1 -1
  106. package/dist/game/ClientTimeState.d.ts +1 -0
  107. package/dist/game/ClientTimeState.d.ts.map +1 -1
  108. package/dist/game/ClientTimeState.js +4 -2
  109. package/dist/game/ClientTimeState.js.map +1 -1
  110. package/dist/game/ConnectionObject.js.map +1 -1
  111. package/dist/game/ConnectionTransport.js +0 -1
  112. package/dist/game/ConnectionTransport.js.map +1 -1
  113. package/dist/game/DropdownChit.js.map +1 -1
  114. package/dist/game/GalleryItemChitChildrenSource.d.ts +1 -0
  115. package/dist/game/GalleryItemChitChildrenSource.d.ts.map +1 -1
  116. package/dist/game/GalleryItemChitChildrenSource.js +1 -1
  117. package/dist/game/GalleryItemChitChildrenSource.js.map +1 -1
  118. package/dist/game/GalleryItemRawSource.d.ts +1 -0
  119. package/dist/game/GalleryItemRawSource.d.ts.map +1 -1
  120. package/dist/game/GalleryItemRawSource.js +1 -0
  121. package/dist/game/GalleryItemRawSource.js.map +1 -1
  122. package/dist/game/Game.d.ts +2 -1
  123. package/dist/game/Game.d.ts.map +1 -1
  124. package/dist/game/GameBagChit.js.map +1 -1
  125. package/dist/game/GameButton.d.ts +1 -0
  126. package/dist/game/GameButton.d.ts.map +1 -1
  127. package/dist/game/GameButton.js +2 -9
  128. package/dist/game/GameButton.js.map +1 -1
  129. package/dist/game/GameDeckChit.d.ts +6 -0
  130. package/dist/game/GameDeckChit.d.ts.map +1 -1
  131. package/dist/game/GameDeckChit.js +33 -6
  132. package/dist/game/GameDeckChit.js.map +1 -1
  133. package/dist/game/GameMetaData.d.ts +18 -0
  134. package/dist/game/GameMetaData.d.ts.map +1 -0
  135. package/dist/game/GameMetaData.js +2 -0
  136. package/dist/game/GameMetaData.js.map +1 -0
  137. package/dist/game/GameTheme.d.ts +11 -0
  138. package/dist/game/GameTheme.d.ts.map +1 -1
  139. package/dist/game/GameTheme.js +19 -5
  140. package/dist/game/GameTheme.js.map +1 -1
  141. package/dist/game/Match.d.ts +2 -1
  142. package/dist/game/Match.d.ts.map +1 -1
  143. package/dist/game/Match.js +4 -3
  144. package/dist/game/Match.js.map +1 -1
  145. package/dist/game/MatchStorage.d.ts +10 -0
  146. package/dist/game/MatchStorage.d.ts.map +1 -1
  147. package/dist/game/MatchStorage.js +29 -0
  148. package/dist/game/MatchStorage.js.map +1 -1
  149. package/dist/game/ModalState.d.ts +1 -0
  150. package/dist/game/ModalState.d.ts.map +1 -1
  151. package/dist/game/ModalState.js +1 -0
  152. package/dist/game/ModalState.js.map +1 -1
  153. package/dist/game/OrderedOutlet.d.ts.map +1 -1
  154. package/dist/game/OrderedOutlet.js +6 -10
  155. package/dist/game/OrderedOutlet.js.map +1 -1
  156. package/dist/game/Pick.d.ts +11 -1
  157. package/dist/game/Pick.d.ts.map +1 -1
  158. package/dist/game/Pick.js +83 -11
  159. package/dist/game/Pick.js.map +1 -1
  160. package/dist/game/PlayerChit.d.ts +2 -1
  161. package/dist/game/PlayerChit.d.ts.map +1 -1
  162. package/dist/game/PlayerChit.js +12 -2
  163. package/dist/game/PlayerChit.js.map +1 -1
  164. package/dist/game/PlayerInfo.d.ts +2 -1
  165. package/dist/game/PlayerInfo.d.ts.map +1 -1
  166. package/dist/game/PlayerInfo.js +18 -5
  167. package/dist/game/PlayerInfo.js.map +1 -1
  168. package/dist/game/PlayerPromptStatusChit.js +0 -2
  169. package/dist/game/PlayerPromptStatusChit.js.map +1 -1
  170. package/dist/game/Prompt.d.ts +1 -11
  171. package/dist/game/Prompt.d.ts.map +1 -1
  172. package/dist/game/Prompt.js +0 -36
  173. package/dist/game/Prompt.js.map +1 -1
  174. package/dist/game/RootChit.d.ts +4 -0
  175. package/dist/game/RootChit.d.ts.map +1 -1
  176. package/dist/game/RootChit.js +36 -3
  177. package/dist/game/RootChit.js.map +1 -1
  178. package/dist/game/SparkChit.js +0 -3
  179. package/dist/game/SparkChit.js.map +1 -1
  180. package/dist/game/Turn.d.ts +9 -8
  181. package/dist/game/Turn.d.ts.map +1 -1
  182. package/dist/game/Turn.js +34 -42
  183. package/dist/game/Turn.js.map +1 -1
  184. package/dist/game/TurnState.d.ts +3 -2
  185. package/dist/game/TurnState.d.ts.map +1 -1
  186. package/dist/game/TurnState.js +22 -4
  187. package/dist/game/TurnState.js.map +1 -1
  188. package/dist/game/badAiTransport/BadAIClientPrompts.d.ts +14 -0
  189. package/dist/game/badAiTransport/BadAIClientPrompts.d.ts.map +1 -0
  190. package/dist/game/badAiTransport/BadAIClientPrompts.js +50 -0
  191. package/dist/game/badAiTransport/BadAIClientPrompts.js.map +1 -0
  192. package/dist/game/clientTransport/ClientPrompts.js +0 -2
  193. package/dist/game/clientTransport/ClientPrompts.js.map +1 -1
  194. package/dist/game/clientTransport/ClientStatus.js +0 -1
  195. package/dist/game/clientTransport/ClientStatus.js.map +1 -1
  196. package/dist/game/clientTransport/ClientTime.js +1 -3
  197. package/dist/game/clientTransport/ClientTime.js.map +1 -1
  198. package/dist/game/serverTransport/ServerPrompts.js +0 -1
  199. package/dist/game/serverTransport/ServerPrompts.js.map +1 -1
  200. package/dist/game/serverTransport/ServerStatus.js +0 -1
  201. package/dist/game/serverTransport/ServerStatus.js.map +1 -1
  202. package/dist/game/serverTransport/ServerTime.js +1 -2
  203. package/dist/game/serverTransport/ServerTime.js.map +1 -1
  204. package/dist/hooks/useButtonGalleriesOptions.d.ts +4 -0
  205. package/dist/hooks/useButtonGalleriesOptions.d.ts.map +1 -0
  206. package/dist/hooks/useButtonGalleriesOptions.js +7 -0
  207. package/dist/hooks/useButtonGalleriesOptions.js.map +1 -0
  208. package/dist/hooks/useEventChannelState.js +1 -1
  209. package/dist/hooks/useEventChannelState.js.map +1 -1
  210. package/dist/hooks/useLoadingStates.d.ts +17 -0
  211. package/dist/hooks/useLoadingStates.d.ts.map +1 -0
  212. package/dist/hooks/useLoadingStates.js +44 -0
  213. package/dist/hooks/useLoadingStates.js.map +1 -0
  214. package/dist/hooks/useModalState.d.ts +2 -1
  215. package/dist/hooks/useModalState.d.ts.map +1 -1
  216. package/dist/hooks/useModalState.js +2 -2
  217. package/dist/hooks/useModalState.js.map +1 -1
  218. package/dist/hooks/usePanelPositioning.d.ts +0 -1
  219. package/dist/hooks/usePanelPositioning.d.ts.map +1 -1
  220. package/dist/hooks/usePanelPositioning.js.map +1 -1
  221. package/dist/hooks/useTimeController.js.map +1 -1
  222. package/dist/hooks/useWebGlRenderer.js +0 -2
  223. package/dist/hooks/useWebGlRenderer.js.map +1 -1
  224. package/dist/index.d.ts +7 -5
  225. package/dist/index.d.ts.map +1 -1
  226. package/dist/index.js +17 -1
  227. package/dist/index.js.map +1 -1
  228. package/dist/rendering/CameraSpec.js.map +1 -1
  229. package/dist/rendering/CameraWrapperPerspective.d.ts.map +1 -1
  230. package/dist/rendering/CameraWrapperPerspective.js +1 -2
  231. package/dist/rendering/CameraWrapperPerspective.js.map +1 -1
  232. package/dist/rendering/ChitGalleryItemInstance.d.ts +2 -0
  233. package/dist/rendering/ChitGalleryItemInstance.d.ts.map +1 -1
  234. package/dist/rendering/ChitGalleryItemInstance.js +0 -12
  235. package/dist/rendering/ChitGalleryItemInstance.js.map +1 -1
  236. package/dist/rendering/ChitRenderInstance.d.ts +13 -2
  237. package/dist/rendering/ChitRenderInstance.d.ts.map +1 -1
  238. package/dist/rendering/ChitRenderInstance.js +95 -52
  239. package/dist/rendering/ChitRenderInstance.js.map +1 -1
  240. package/dist/rendering/ChitRenderSpec.d.ts +3 -0
  241. package/dist/rendering/ChitRenderSpec.d.ts.map +1 -1
  242. package/dist/rendering/ChitRenderSpec.js +1 -11
  243. package/dist/rendering/ChitRenderSpec.js.map +1 -1
  244. package/dist/rendering/HighlightSpec.js +0 -2
  245. package/dist/rendering/HighlightSpec.js.map +1 -1
  246. package/dist/rendering/LightSpec.js +1 -0
  247. package/dist/rendering/LightSpec.js.map +1 -1
  248. package/dist/rendering/RootChitRenderInstance.d.ts +5 -2
  249. package/dist/rendering/RootChitRenderInstance.d.ts.map +1 -1
  250. package/dist/rendering/RootChitRenderInstance.js +76 -17
  251. package/dist/rendering/RootChitRenderInstance.js.map +1 -1
  252. package/dist/rendering/Splay.js.map +1 -1
  253. package/dist/rendering/SplayCounter.d.ts.map +1 -1
  254. package/dist/rendering/SplayCounter.js +1 -1
  255. package/dist/rendering/SplayCounter.js.map +1 -1
  256. package/dist/rendering/TextureReferenceCounter.d.ts +1 -1
  257. package/dist/rendering/TextureReferenceCounter.d.ts.map +1 -1
  258. package/dist/rendering/TextureReferenceCounter.js +10 -10
  259. package/dist/rendering/TextureReferenceCounter.js.map +1 -1
  260. package/dist/rendering/outline/DepthVisualizationPass.js +0 -3
  261. package/dist/rendering/outline/DepthVisualizationPass.js.map +1 -1
  262. package/dist/rendering/outline/EffectComposer.js +0 -9
  263. package/dist/rendering/outline/EffectComposer.js.map +1 -1
  264. package/dist/rendering/outline/FullScreenQuad.js +0 -1
  265. package/dist/rendering/outline/FullScreenQuad.js.map +1 -1
  266. package/dist/rendering/outline/IDBasedOutlinePass.js +0 -19
  267. package/dist/rendering/outline/IDBasedOutlinePass.js.map +1 -1
  268. package/dist/rendering/outline/OutputPass.js +0 -5
  269. package/dist/rendering/outline/OutputPass.js.map +1 -1
  270. package/dist/rendering/outline/RenderPass.js +0 -2
  271. package/dist/rendering/outline/RenderPass.js.map +1 -1
  272. package/dist/rendering/outline/SceneWrapper.js +0 -2
  273. package/dist/rendering/outline/SceneWrapper.js.map +1 -1
  274. package/dist/rendering/outline/ShaderPass.js +0 -4
  275. package/dist/rendering/outline/ShaderPass.js.map +1 -1
  276. package/dist/rendering/outline/passes/DebugIDMappingPass.js +0 -2
  277. package/dist/rendering/outline/passes/DebugIDMappingPass.js.map +1 -1
  278. package/dist/rendering/outline/passes/DepthOcclusionPass.js +1 -3
  279. package/dist/rendering/outline/passes/DepthOcclusionPass.js.map +1 -1
  280. package/dist/rendering/outline/passes/InterMeshEdgeDetectionPass.js +0 -3
  281. package/dist/rendering/outline/passes/InterMeshEdgeDetectionPass.js.map +1 -1
  282. package/dist/rendering/outline/types.js.map +1 -1
  283. package/dist/utilities/Annotations.d.ts +59 -0
  284. package/dist/utilities/Annotations.d.ts.map +1 -1
  285. package/dist/utilities/Annotations.js +63 -0
  286. package/dist/utilities/Annotations.js.map +1 -1
  287. package/dist/utilities/BaseTable.js +0 -5
  288. package/dist/utilities/BaseTable.js.map +1 -1
  289. package/dist/utilities/CanvasStack/CanvasOperations.d.ts +10 -1
  290. package/dist/utilities/CanvasStack/CanvasOperations.d.ts.map +1 -1
  291. package/dist/utilities/CanvasStack/CanvasOperations.js +8 -0
  292. package/dist/utilities/CanvasStack/CanvasOperations.js.map +1 -1
  293. package/dist/utilities/CanvasStack/CanvasStack.js +0 -4
  294. package/dist/utilities/CanvasStack/CanvasStack.js.map +1 -1
  295. package/dist/utilities/CanvasStack/ImageCache.js +0 -4
  296. package/dist/utilities/CanvasStack/ImageCache.js.map +1 -1
  297. package/dist/utilities/CanvasStack/ReactCanvas.d.ts +4 -2
  298. package/dist/utilities/CanvasStack/ReactCanvas.d.ts.map +1 -1
  299. package/dist/utilities/CanvasStack/ReactCanvas.js +5 -2
  300. package/dist/utilities/CanvasStack/ReactCanvas.js.map +1 -1
  301. package/dist/utilities/CanvasStack/RichTextRenderer.d.ts.map +1 -1
  302. package/dist/utilities/CanvasStack/RichTextRenderer.js +12 -4
  303. package/dist/utilities/CanvasStack/RichTextRenderer.js.map +1 -1
  304. package/dist/utilities/Dice.js.map +1 -1
  305. package/dist/utilities/EventChannel.d.ts.map +1 -1
  306. package/dist/utilities/EventChannel.js +2 -3
  307. package/dist/utilities/EventChannel.js.map +1 -1
  308. package/dist/utilities/GlbLoader.d.ts +15 -0
  309. package/dist/utilities/GlbLoader.d.ts.map +1 -0
  310. package/dist/utilities/GlbLoader.js +212 -0
  311. package/dist/utilities/GlbLoader.js.map +1 -0
  312. package/dist/utilities/LayoutHelper.js +23 -2
  313. package/dist/utilities/LayoutHelper.js.map +1 -1
  314. package/dist/utilities/ObjectWithProps.d.ts.map +1 -1
  315. package/dist/utilities/ObjectWithProps.js +32 -3
  316. package/dist/utilities/ObjectWithProps.js.map +1 -1
  317. package/dist/utilities/ParameterizedCanvas.js +1 -1
  318. package/dist/utilities/ParameterizedCanvas.js.map +1 -1
  319. package/dist/utilities/StaticImage.js +0 -1
  320. package/dist/utilities/StaticImage.js.map +1 -1
  321. package/dist/utilities/ThreeDisposer.js +0 -1
  322. package/dist/utilities/ThreeDisposer.js.map +1 -1
  323. package/package.json +6 -5
  324. package/src/library/components/BottomBarButton.tsx +3 -0
  325. package/src/library/components/ClientTrustMatchViewer.tsx +23 -8
  326. package/src/library/components/ContextGalleryDisplay.tsx +2 -2
  327. package/src/library/components/DemoWrapper.tsx +113 -0
  328. package/src/library/components/{GalleryDisplay.tsx → FullScreenGalleryDisplay.tsx} +28 -2
  329. package/src/library/components/Gallery/AnimationController.ts +110 -0
  330. package/src/library/components/Gallery/BuiltItem.ts +385 -0
  331. package/src/library/components/Gallery/CameraManager.ts +54 -0
  332. package/src/library/components/Gallery/GalleryController.ts +193 -0
  333. package/src/library/components/Gallery/GalleryViewer.tsx +211 -0
  334. package/src/library/components/Gallery/LayoutManager.ts +166 -0
  335. package/src/library/components/Gallery/constants.ts +12 -0
  336. package/src/library/components/Gallery/index.ts +2 -0
  337. package/src/library/components/Gallery/types.ts +55 -0
  338. package/src/library/components/GalleryPlayground.tsx +1 -1
  339. package/src/library/components/GalleryViewer.tsx +4 -773
  340. package/src/library/components/GameDesigner.tsx +21 -4
  341. package/src/library/components/InlineGalleryDisplay.tsx +101 -0
  342. package/src/library/components/LiveButton.tsx +2 -1
  343. package/src/library/components/MatchViewer.tsx +32 -14
  344. package/src/library/components/Panel/MultiPanel.tsx +20 -8
  345. package/src/library/components/Panel/PanelContents.tsx +17 -12
  346. package/src/library/components/Panel/SinglePanel.tsx +5 -4
  347. package/src/library/components/Panel/ViewerWrapper.tsx +0 -5
  348. package/src/library/components/Playground.tsx +692 -119
  349. package/src/library/components/PromptControls.tsx +61 -8
  350. package/src/library/components/ServerTrustMatchViewer.tsx +53 -0
  351. package/src/library/components/Viewer.tsx +60 -20
  352. package/src/library/game/Chit.ts +46 -6
  353. package/src/library/game/ClientTimeState.ts +5 -1
  354. package/src/library/game/GalleryItemChitChildrenSource.ts +2 -0
  355. package/src/library/game/GalleryItemRawSource.ts +2 -0
  356. package/src/library/game/Game.ts +3 -1
  357. package/src/library/game/GameButton.ts +3 -0
  358. package/src/library/game/GameDeckChit.ts +36 -5
  359. package/src/library/game/GameMetaData.ts +19 -0
  360. package/src/library/game/GameTheme.ts +23 -5
  361. package/src/library/game/Match.ts +4 -3
  362. package/src/library/game/MatchStorage.ts +37 -0
  363. package/src/library/game/ModalState.ts +1 -0
  364. package/src/library/game/OrderedOutlet.ts +6 -6
  365. package/src/library/game/Pick.ts +98 -2
  366. package/src/library/game/PlayerChit.ts +13 -1
  367. package/src/library/game/PlayerInfo.ts +22 -3
  368. package/src/library/game/Prompt.ts +1 -36
  369. package/src/library/game/RootChit.ts +41 -1
  370. package/src/library/game/Turn.ts +37 -40
  371. package/src/library/game/TurnState.ts +22 -3
  372. package/src/library/game/badAiTransport/BadAIClientPrompts.ts +60 -0
  373. package/src/library/game/clientTransport/ClientTime.ts +1 -1
  374. package/src/library/game/serverTransport/ServerTime.ts +2 -2
  375. package/src/library/hooks/useButtonGalleriesOptions.tsx +9 -0
  376. package/src/library/hooks/useEventChannelState.ts +1 -1
  377. package/src/library/hooks/useLoadingStates.tsx +55 -0
  378. package/src/library/hooks/useModalState.tsx +2 -2
  379. package/src/library/hooks/usePanelPositioning.tsx +0 -1
  380. package/src/library/index.ts +21 -1
  381. package/src/library/rendering/CameraWrapperPerspective.ts +10 -12
  382. package/src/library/rendering/ChitGalleryItemInstance.ts +2 -0
  383. package/src/library/rendering/ChitRenderInstance.ts +119 -61
  384. package/src/library/rendering/ChitRenderSpec.ts +4 -0
  385. package/src/library/rendering/RootChitRenderInstance.ts +87 -13
  386. package/src/library/rendering/SplayCounter.tsx +2 -1
  387. package/src/library/rendering/TextureReferenceCounter.ts +9 -9
  388. package/src/library/rendering/outline/passes/DepthOcclusionPass.ts +1 -1
  389. package/src/library/utilities/Annotations.ts +99 -0
  390. package/src/library/utilities/CanvasStack/CanvasOperations.tsx +19 -1
  391. package/src/library/utilities/CanvasStack/ReactCanvas.tsx +10 -3
  392. package/src/library/utilities/CanvasStack/RichTextRenderer.ts +14 -4
  393. package/src/library/utilities/EventChannel.ts +2 -4
  394. package/src/library/utilities/GlbLoader.ts +292 -0
  395. package/src/library/utilities/LayoutHelper.ts +28 -2
  396. package/src/library/utilities/ObjectWithProps.ts +27 -3
  397. package/dist/components/GalleryDisplay.d.ts +0 -2
  398. package/dist/components/GalleryDisplay.d.ts.map +0 -1
  399. package/dist/components/GalleryDisplay.js +0 -42
  400. package/dist/components/GalleryDisplay.js.map +0 -1
  401. package/dist/utilities/OutlineCanvas.d.ts +0 -12
  402. package/dist/utilities/OutlineCanvas.d.ts.map +0 -1
  403. package/dist/utilities/OutlineCanvas.js +0 -31
  404. package/dist/utilities/OutlineCanvas.js.map +0 -1
  405. package/dist/utilities/OutlineGeometry.d.ts +0 -3
  406. package/dist/utilities/OutlineGeometry.d.ts.map +0 -1
  407. package/dist/utilities/OutlineGeometry.js +0 -57
  408. package/dist/utilities/OutlineGeometry.js.map +0 -1
  409. package/src/library/utilities/OutlineCanvas.tsx +0 -45
  410. 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":"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"}
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;QALxB,cAAS,aAAS;QAQ1B,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
+ {"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"}
@@ -2,7 +2,6 @@ export class ThreeDisposer {
2
2
  constructor(cleanup) {
3
3
  this.cleanup = cleanup;
4
4
  this.references = {};
5
- this.changeCallback = undefined;
6
5
  }
7
6
  notifyChange(_uuid) {
8
7
  if (this.changeCallback) {
@@ -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;QACnD,mBAAc,aAAc;IAHU,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"}
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.1.2",
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 docs && yarn pack",
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
- <GameProvider game={game}>
76
- <ConnectionProvider connection={localConnection}>
77
- <PlayerProvider playerId={playerId}>
78
- <MatchViewer onBack={onBack} />
79
- </PlayerProvider>
80
- </ConnectionProvider>
81
- </GameProvider>
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={false}
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={0}
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 GalleryDisplay() {
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
+ }