@xmachines/docs 1.0.0-beta.33 → 1.0.0-beta.34

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 (366) hide show
  1. package/api/@xmachines/play/classes/NonNullableError.md +4 -4
  2. package/api/@xmachines/play/classes/PlayError.md +4 -4
  3. package/api/@xmachines/play/functions/assertNonNullable.md +1 -1
  4. package/api/@xmachines/play/type-aliases/PlayEvent.md +2 -2
  5. package/api/@xmachines/play-actor/README.md +9 -10
  6. package/api/@xmachines/play-actor/classes/AbstractActor.md +3 -3
  7. package/api/@xmachines/play-actor/functions/typedSpec.md +7 -10
  8. package/api/@xmachines/play-actor/interfaces/BaseActorProviderProps.md +46 -0
  9. package/api/@xmachines/play-actor/interfaces/BaseViewContextValue.md +33 -0
  10. package/api/@xmachines/play-actor/interfaces/PlaySpec.md +2 -2
  11. package/api/@xmachines/play-actor/interfaces/Routable.md +3 -3
  12. package/api/@xmachines/play-actor/interfaces/Viewable.md +4 -4
  13. package/api/@xmachines/play-dom/README.md +98 -15
  14. package/api/@xmachines/play-dom/classes/PlayRenderer.md +4 -4
  15. package/api/@xmachines/play-dom/functions/connectRenderer.md +1 -1
  16. package/api/@xmachines/play-dom/functions/createPlayUI.md +28 -0
  17. package/api/@xmachines/play-dom/functions/createRenderer.md +1 -1
  18. package/api/@xmachines/play-dom/functions/defineRegistry.md +1 -1
  19. package/api/@xmachines/play-dom/functions/renderSpec.md +1 -1
  20. package/api/@xmachines/play-dom/interfaces/ComponentContext.md +9 -9
  21. package/api/@xmachines/play-dom/interfaces/ConnectRendererOptions.md +19 -11
  22. package/api/@xmachines/play-dom/interfaces/CreatePlayUIOptions.md +29 -0
  23. package/api/@xmachines/play-dom/interfaces/DefineRegistryResult.md +6 -6
  24. package/api/@xmachines/play-dom/interfaces/DomRenderContext.md +14 -14
  25. package/api/@xmachines/play-dom/interfaces/EventHandle.md +6 -6
  26. package/api/@xmachines/play-dom/interfaces/MountOptions.md +14 -0
  27. package/api/@xmachines/play-dom/interfaces/PlayDomOptions.md +7 -7
  28. package/api/@xmachines/play-dom/interfaces/UIProviderOptions.md +27 -0
  29. package/api/@xmachines/play-dom/type-aliases/ActionFn.md +1 -1
  30. package/api/@xmachines/play-dom/type-aliases/Actions.md +1 -1
  31. package/api/@xmachines/play-dom/type-aliases/BaseComponentProps.md +7 -7
  32. package/api/@xmachines/play-dom/type-aliases/CatalogHasActions.md +1 -1
  33. package/api/@xmachines/play-dom/type-aliases/ComponentFn.md +1 -1
  34. package/api/@xmachines/play-dom/type-aliases/ComponentRegistry.md +1 -1
  35. package/api/@xmachines/play-dom/type-aliases/DefineRegistryOptions.md +4 -4
  36. package/api/@xmachines/play-dom/type-aliases/DomComponentRenderer.md +1 -1
  37. package/api/@xmachines/play-dom/type-aliases/DomRegistry.md +1 -1
  38. package/api/@xmachines/play-dom/type-aliases/DomSchema.md +1 -1
  39. package/api/@xmachines/play-dom/type-aliases/MountFn.md +25 -0
  40. package/api/@xmachines/play-dom/type-aliases/RenderErrorHandler.md +23 -0
  41. package/api/@xmachines/play-dom/type-aliases/SetState.md +1 -1
  42. package/api/@xmachines/play-dom/variables/schema.md +1 -1
  43. package/api/@xmachines/play-dom-router/functions/connectRouter.md +1 -1
  44. package/api/@xmachines/play-dom-router/functions/createBrowserHistory.md +1 -1
  45. package/api/@xmachines/play-dom-router/functions/createRouteMap.md +1 -1
  46. package/api/@xmachines/play-dom-router/functions/createRouter.md +1 -1
  47. package/api/@xmachines/play-dom-router/interfaces/BrowserHistory.md +14 -14
  48. package/api/@xmachines/play-dom-router/interfaces/BrowserWindow.md +14 -14
  49. package/api/@xmachines/play-dom-router/interfaces/ConnectRouterOptions.md +4 -4
  50. package/api/@xmachines/play-dom-router/interfaces/PlayRouteEvent.md +6 -6
  51. package/api/@xmachines/play-dom-router/interfaces/RouteMap.md +3 -3
  52. package/api/@xmachines/play-dom-router/interfaces/RouteMapLike.md +3 -3
  53. package/api/@xmachines/play-dom-router/interfaces/RouteMapping.md +3 -3
  54. package/api/@xmachines/play-dom-router/interfaces/RouterBridge.md +3 -3
  55. package/api/@xmachines/play-dom-router/interfaces/VanillaRouter.md +4 -4
  56. package/api/@xmachines/play-dom-router/type-aliases/RoutableActor.md +1 -1
  57. package/api/@xmachines/play-react/README.md +165 -48
  58. package/api/@xmachines/play-react/classes/PlayErrorBoundary.md +5 -5
  59. package/api/@xmachines/play-react/functions/ActionProvider.md +21 -0
  60. package/api/@xmachines/play-react/functions/JSONUIProvider.md +21 -0
  61. package/api/@xmachines/play-react/functions/Renderer.md +21 -0
  62. package/api/@xmachines/play-react/functions/StateProvider.md +27 -0
  63. package/api/@xmachines/play-react/functions/ValidationProvider.md +21 -0
  64. package/api/@xmachines/play-react/functions/VisibilityProvider.md +21 -0
  65. package/api/@xmachines/play-react/functions/useActor.md +1 -1
  66. package/api/@xmachines/play-react/functions/usePlayView.md +32 -0
  67. package/api/@xmachines/play-react/functions/useSignalEffect.md +1 -1
  68. package/api/@xmachines/play-react/interfaces/ActionProviderProps.md +15 -0
  69. package/api/@xmachines/play-react/interfaces/ActorProviderProps.md +27 -0
  70. package/api/@xmachines/play-react/interfaces/JSONUIProviderProps.md +21 -0
  71. package/api/@xmachines/play-react/interfaces/PlayErrorBoundaryProps.md +4 -4
  72. package/api/@xmachines/play-react/interfaces/PlayErrorBoundaryState.md +3 -3
  73. package/api/@xmachines/play-react/interfaces/PlayUIProviderProps.md +26 -0
  74. package/api/@xmachines/play-react/interfaces/RendererProps.md +17 -0
  75. package/api/@xmachines/play-react/interfaces/StateProviderProps.md +16 -0
  76. package/api/@xmachines/play-react/interfaces/ValidationProviderProps.md +14 -0
  77. package/api/@xmachines/play-react/interfaces/ViewContextValue.md +20 -0
  78. package/api/@xmachines/play-react/interfaces/VisibilityProviderProps.md +13 -0
  79. package/api/@xmachines/play-react/type-aliases/PlayActor.md +1 -1
  80. package/api/@xmachines/play-react/type-aliases/RenderErrorHandler.md +3 -2
  81. package/api/@xmachines/play-react/variables/ActorProvider.md +33 -0
  82. package/api/@xmachines/play-react/variables/PlayRenderer.md +5 -50
  83. package/api/@xmachines/play-react/variables/PlayUIProvider.md +43 -0
  84. package/api/@xmachines/play-react-router/classes/ReactRouterBridge.md +23 -23
  85. package/api/@xmachines/play-react-router/classes/RouteMap.md +4 -4
  86. package/api/@xmachines/play-react-router/functions/PlayRouterProvider.md +1 -1
  87. package/api/@xmachines/play-react-router/functions/createRouteMapFromTree.md +1 -1
  88. package/api/@xmachines/play-react-router/interfaces/PlayRouteEvent.md +6 -6
  89. package/api/@xmachines/play-react-router/interfaces/PlayRouterProviderProps.md +5 -5
  90. package/api/@xmachines/play-react-router/interfaces/RouteMapping.md +3 -3
  91. package/api/@xmachines/play-react-router/interfaces/RouterBridge.md +3 -3
  92. package/api/@xmachines/play-router/classes/BaseRouteMap.md +4 -4
  93. package/api/@xmachines/play-router/classes/RouterBridgeBase.md +23 -23
  94. package/api/@xmachines/play-router/functions/buildPlayRouteEvent.md +1 -1
  95. package/api/@xmachines/play-router/functions/buildRouteTree.md +1 -1
  96. package/api/@xmachines/play-router/functions/createRouteMap.md +1 -1
  97. package/api/@xmachines/play-router/functions/createRouteMapFromMachine.md +1 -1
  98. package/api/@xmachines/play-router/functions/createRouteMapFromTree.md +1 -1
  99. package/api/@xmachines/play-router/functions/detectDuplicateRoutes.md +1 -1
  100. package/api/@xmachines/play-router/functions/extractMachineRoutes.md +1 -1
  101. package/api/@xmachines/play-router/functions/extractQuery.md +1 -1
  102. package/api/@xmachines/play-router/functions/extractRouteParams.md +1 -1
  103. package/api/@xmachines/play-router/functions/findRouteById.md +1 -1
  104. package/api/@xmachines/play-router/functions/findRouteByPath.md +1 -1
  105. package/api/@xmachines/play-router/functions/getNavigableRoutes.md +1 -1
  106. package/api/@xmachines/play-router/functions/getRoutableRoutes.md +1 -1
  107. package/api/@xmachines/play-router/functions/getTransitionReachableRoutes.md +1 -1
  108. package/api/@xmachines/play-router/functions/isRouteReachable.md +1 -1
  109. package/api/@xmachines/play-router/functions/machineToGraph.md +1 -1
  110. package/api/@xmachines/play-router/functions/routeExists.md +1 -1
  111. package/api/@xmachines/play-router/functions/sanitizePathname.md +1 -1
  112. package/api/@xmachines/play-router/functions/validateRouteFormat.md +1 -1
  113. package/api/@xmachines/play-router/functions/validateStateExists.md +1 -1
  114. package/api/@xmachines/play-router/interfaces/BuildPlayRouteEventOptions.md +4 -4
  115. package/api/@xmachines/play-router/interfaces/LocationLike.md +3 -3
  116. package/api/@xmachines/play-router/interfaces/MachineEdgeData.md +3 -3
  117. package/api/@xmachines/play-router/interfaces/MachineNodeData.md +5 -5
  118. package/api/@xmachines/play-router/interfaces/PlayRouteEvent.md +6 -6
  119. package/api/@xmachines/play-router/interfaces/RouteInfo.md +8 -8
  120. package/api/@xmachines/play-router/interfaces/RouteMap.md +4 -4
  121. package/api/@xmachines/play-router/interfaces/RouteMapping.md +3 -3
  122. package/api/@xmachines/play-router/interfaces/RouteMatch.md +3 -3
  123. package/api/@xmachines/play-router/interfaces/RouteNode.md +10 -10
  124. package/api/@xmachines/play-router/interfaces/RouteObject.md +2 -2
  125. package/api/@xmachines/play-router/interfaces/RouteTree.md +5 -5
  126. package/api/@xmachines/play-router/interfaces/RouteWatcherHandle.md +3 -3
  127. package/api/@xmachines/play-router/interfaces/RouterBridge.md +3 -3
  128. package/api/@xmachines/play-router/interfaces/WindowLike.md +3 -3
  129. package/api/@xmachines/play-router/type-aliases/MachineGraph.md +1 -1
  130. package/api/@xmachines/play-router/type-aliases/RouteMetadata.md +1 -1
  131. package/api/@xmachines/play-signals/functions/watchSignal.md +1 -1
  132. package/api/@xmachines/play-signals/interfaces/ComputedOptions.md +2 -2
  133. package/api/@xmachines/play-signals/interfaces/SignalComputed.md +2 -2
  134. package/api/@xmachines/play-signals/interfaces/SignalOptions.md +2 -2
  135. package/api/@xmachines/play-signals/interfaces/SignalState.md +3 -3
  136. package/api/@xmachines/play-signals/interfaces/SignalWatcher.md +4 -4
  137. package/api/@xmachines/play-signals/type-aliases/WatcherNotify.md +1 -1
  138. package/api/@xmachines/play-solid/README.md +158 -42
  139. package/api/@xmachines/play-solid/functions/ActionProvider.md +19 -0
  140. package/api/@xmachines/play-solid/functions/JSONUIProvider.md +21 -0
  141. package/api/@xmachines/play-solid/functions/Renderer.md +21 -0
  142. package/api/@xmachines/play-solid/functions/StateProvider.md +19 -0
  143. package/api/@xmachines/play-solid/functions/ValidationProvider.md +19 -0
  144. package/api/@xmachines/play-solid/functions/VisibilityProvider.md +20 -0
  145. package/api/@xmachines/play-solid/functions/defineRegistry.md +1 -1
  146. package/api/@xmachines/play-solid/functions/useAction.md +24 -0
  147. package/api/@xmachines/play-solid/functions/useActions.md +13 -0
  148. package/api/@xmachines/play-solid/functions/useActor.md +1 -1
  149. package/api/@xmachines/play-solid/functions/useFieldValidation.md +29 -0
  150. package/api/@xmachines/play-solid/functions/useIsVisible.md +19 -0
  151. package/api/@xmachines/play-solid/functions/useOptionalValidation.md +13 -0
  152. package/api/@xmachines/play-solid/functions/usePlayView.md +30 -0
  153. package/api/@xmachines/play-solid/functions/useStateBinding.md +25 -0
  154. package/api/@xmachines/play-solid/functions/useStateStore.md +13 -0
  155. package/api/@xmachines/play-solid/functions/useStateValue.md +25 -0
  156. package/api/@xmachines/play-solid/functions/useVisibility.md +13 -0
  157. package/api/@xmachines/play-solid/interfaces/ActionProviderProps.md +12 -0
  158. package/api/@xmachines/play-solid/interfaces/ActorProviderProps.md +30 -0
  159. package/api/@xmachines/play-solid/interfaces/DefineRegistryResult.md +15 -0
  160. package/api/@xmachines/play-solid/interfaces/JSONUIProviderProps.md +21 -0
  161. package/api/@xmachines/play-solid/interfaces/PlayUIProviderProps.md +26 -0
  162. package/api/@xmachines/play-solid/interfaces/RendererProps.md +17 -0
  163. package/api/@xmachines/play-solid/interfaces/StateProviderProps.md +13 -0
  164. package/api/@xmachines/play-solid/interfaces/ValidationProviderProps.md +11 -0
  165. package/api/@xmachines/play-solid/interfaces/ViewContextValue.md +21 -0
  166. package/api/@xmachines/play-solid/type-aliases/ComponentRegistry.md +17 -0
  167. package/api/@xmachines/play-solid/type-aliases/PlayActor.md +1 -1
  168. package/api/@xmachines/play-solid/type-aliases/RenderErrorHandler.md +3 -2
  169. package/api/@xmachines/play-solid/type-aliases/SetState.md +21 -0
  170. package/api/@xmachines/play-solid/type-aliases/VisibilityProviderProps.md +9 -0
  171. package/api/@xmachines/play-solid/variables/ActorContext.md +13 -0
  172. package/api/@xmachines/play-solid/variables/ActorProvider.md +27 -0
  173. package/api/@xmachines/play-solid/variables/PlayRenderer.md +5 -18
  174. package/api/@xmachines/play-solid/variables/PlayUIProvider.md +26 -0
  175. package/api/@xmachines/play-solid-router/classes/RouteMap.md +4 -4
  176. package/api/@xmachines/play-solid-router/classes/SolidRouterBridge.md +24 -24
  177. package/api/@xmachines/play-solid-router/functions/PlayRouterProvider.md +1 -1
  178. package/api/@xmachines/play-solid-router/functions/createRouteMap.md +1 -1
  179. package/api/@xmachines/play-solid-router/interfaces/AbstractActor.md +3 -3
  180. package/api/@xmachines/play-solid-router/interfaces/PlayRouteEvent.md +6 -6
  181. package/api/@xmachines/play-solid-router/interfaces/PlayRouterProviderProps.md +5 -5
  182. package/api/@xmachines/play-solid-router/interfaces/RouteMapping.md +3 -3
  183. package/api/@xmachines/play-solid-router/interfaces/RouterBridge.md +3 -3
  184. package/api/@xmachines/play-solid-router/type-aliases/RoutableActor.md +1 -1
  185. package/api/@xmachines/play-solid-router/type-aliases/SolidRouterHooks.md +4 -4
  186. package/api/@xmachines/play-svelte/README.md +105 -25
  187. package/api/@xmachines/play-svelte/functions/defineRegistry.md +1 -1
  188. package/api/@xmachines/play-svelte/functions/getActorContext.md +21 -0
  189. package/api/@xmachines/play-svelte/functions/getPlayViewContext.md +19 -0
  190. package/api/@xmachines/play-svelte/functions/setActorContext.md +19 -0
  191. package/api/@xmachines/play-svelte/interfaces/ActorProviderProps.md +40 -0
  192. package/api/@xmachines/play-svelte/interfaces/DefineRegistryOptions.md +6 -6
  193. package/api/@xmachines/play-svelte/interfaces/ViewContextValue.md +24 -0
  194. package/api/@xmachines/play-svelte/type-aliases/PlayActor.md +9 -0
  195. package/api/@xmachines/play-svelte/type-aliases/RenderErrorHandler.md +1 -17
  196. package/api/@xmachines/play-svelte-spa-router/classes/RouteMap.md +4 -4
  197. package/api/@xmachines/play-svelte-spa-router/functions/connectRouter.md +1 -1
  198. package/api/@xmachines/play-svelte-spa-router/functions/createRouteMap.md +1 -1
  199. package/api/@xmachines/play-svelte-spa-router/interfaces/ConnectRouterOptions.md +4 -4
  200. package/api/@xmachines/play-svelte-spa-router/interfaces/PlayRouteEvent.md +6 -6
  201. package/api/@xmachines/play-svelte-spa-router/interfaces/RouteMapping.md +3 -3
  202. package/api/@xmachines/play-svelte-spa-router/interfaces/RouterBridge.md +3 -3
  203. package/api/@xmachines/play-svelte-spa-router/interfaces/WindowLike.md +3 -3
  204. package/api/@xmachines/play-svelte-spa-router/type-aliases/RoutableActor.md +1 -1
  205. package/api/@xmachines/play-sveltekit-router/classes/RouteMap.md +4 -4
  206. package/api/@xmachines/play-sveltekit-router/functions/connectRouter.md +1 -1
  207. package/api/@xmachines/play-sveltekit-router/functions/createRouteMap.md +1 -1
  208. package/api/@xmachines/play-sveltekit-router/interfaces/ConnectRouterOptions.md +4 -4
  209. package/api/@xmachines/play-sveltekit-router/interfaces/LocationLike.md +3 -3
  210. package/api/@xmachines/play-sveltekit-router/interfaces/PlayRouteEvent.md +6 -6
  211. package/api/@xmachines/play-sveltekit-router/interfaces/RouteMapping.md +3 -3
  212. package/api/@xmachines/play-sveltekit-router/interfaces/RouterBridge.md +3 -3
  213. package/api/@xmachines/play-sveltekit-router/type-aliases/RoutableActor.md +1 -1
  214. package/api/@xmachines/play-tanstack-react-router/classes/RouteMap.md +4 -4
  215. package/api/@xmachines/play-tanstack-react-router/classes/TanStackReactRouterBridge.md +23 -23
  216. package/api/@xmachines/play-tanstack-react-router/functions/PlayRouterProvider.md +1 -1
  217. package/api/@xmachines/play-tanstack-react-router/functions/createRouteMap.md +1 -1
  218. package/api/@xmachines/play-tanstack-react-router/functions/createRouteMapFromTree.md +1 -1
  219. package/api/@xmachines/play-tanstack-react-router/functions/extractMachineRoutes.md +1 -1
  220. package/api/@xmachines/play-tanstack-react-router/interfaces/PlayRouteEvent.md +6 -6
  221. package/api/@xmachines/play-tanstack-react-router/interfaces/PlayRouterProviderProps.md +5 -5
  222. package/api/@xmachines/play-tanstack-react-router/interfaces/RouteMapping.md +3 -3
  223. package/api/@xmachines/play-tanstack-react-router/interfaces/RouteNavigateEvent.md +3 -3
  224. package/api/@xmachines/play-tanstack-react-router/interfaces/RouterBridge.md +3 -3
  225. package/api/@xmachines/play-tanstack-react-router/type-aliases/TanStackRouterInstance.md +1 -1
  226. package/api/@xmachines/play-tanstack-react-router/type-aliases/TanStackRouterLike.md +4 -4
  227. package/api/@xmachines/play-tanstack-solid-router/classes/RouteMap.md +4 -4
  228. package/api/@xmachines/play-tanstack-solid-router/classes/SolidRouterBridge.md +24 -24
  229. package/api/@xmachines/play-tanstack-solid-router/functions/PlayRouterProvider.md +1 -1
  230. package/api/@xmachines/play-tanstack-solid-router/functions/createRouteMap.md +1 -1
  231. package/api/@xmachines/play-tanstack-solid-router/interfaces/PlayRouteEvent.md +6 -6
  232. package/api/@xmachines/play-tanstack-solid-router/interfaces/PlayRouterProviderProps.md +5 -5
  233. package/api/@xmachines/play-tanstack-solid-router/interfaces/RouteMapping.md +3 -3
  234. package/api/@xmachines/play-tanstack-solid-router/interfaces/RouterBridge.md +3 -3
  235. package/api/@xmachines/play-tanstack-solid-router/type-aliases/RoutableActor.md +1 -1
  236. package/api/@xmachines/play-tanstack-solid-router/type-aliases/TanStackRouterInstance.md +1 -1
  237. package/api/@xmachines/play-tanstack-solid-router/type-aliases/TanStackRouterLike.md +3 -3
  238. package/api/@xmachines/play-vue/README.md +136 -40
  239. package/api/@xmachines/play-vue/functions/defineRegistry.md +2 -2
  240. package/api/@xmachines/play-vue/functions/getPlayViewContext.md +28 -0
  241. package/api/@xmachines/play-vue/functions/useActor.md +1 -1
  242. package/api/@xmachines/play-vue/interfaces/ActionProviderProps.md +12 -0
  243. package/api/@xmachines/play-vue/interfaces/ActorProviderProps.md +25 -0
  244. package/api/@xmachines/play-vue/interfaces/DefineRegistryResult.md +15 -0
  245. package/api/@xmachines/play-vue/interfaces/JSONUIProviderProps.md +20 -0
  246. package/api/@xmachines/play-vue/interfaces/PlayUIProviderProps.md +24 -0
  247. package/api/@xmachines/play-vue/interfaces/RendererProps.md +17 -0
  248. package/api/@xmachines/play-vue/interfaces/StateProviderProps.md +15 -0
  249. package/api/@xmachines/play-vue/interfaces/ValidationProviderProps.md +11 -0
  250. package/api/@xmachines/play-vue/interfaces/ViewContextValue.md +21 -0
  251. package/api/@xmachines/play-vue/type-aliases/ComponentEntry.md +1 -1
  252. package/api/@xmachines/play-vue/type-aliases/ComponentsMap.md +1 -1
  253. package/api/@xmachines/play-vue/type-aliases/DefineRegistryOptions.md +2 -2
  254. package/api/@xmachines/play-vue/type-aliases/PlayActor.md +1 -1
  255. package/api/@xmachines/play-vue/type-aliases/RenderErrorHandler.md +3 -2
  256. package/api/@xmachines/play-vue/variables/ActionProvider.md +64 -0
  257. package/api/@xmachines/play-vue/variables/JSONUIProvider.md +96 -0
  258. package/api/@xmachines/play-vue/variables/PlayRenderer.md +1 -1
  259. package/api/@xmachines/play-vue/variables/Renderer.md +79 -0
  260. package/api/@xmachines/play-vue/variables/StateProvider.md +79 -0
  261. package/api/@xmachines/play-vue/variables/ValidationProvider.md +55 -0
  262. package/api/@xmachines/play-vue/variables/VisibilityProvider.md +40 -0
  263. package/api/@xmachines/play-vue-router/classes/RouteMap.md +4 -4
  264. package/api/@xmachines/play-vue-router/classes/VueBaseRouteMap.md +4 -4
  265. package/api/@xmachines/play-vue-router/classes/VueRouterBridge.md +24 -24
  266. package/api/@xmachines/play-vue-router/functions/createRouteMap.md +1 -1
  267. package/api/@xmachines/play-vue-router/interfaces/PlayRouteEvent.md +6 -6
  268. package/api/@xmachines/play-vue-router/interfaces/RouteMapping.md +3 -3
  269. package/api/@xmachines/play-vue-router/interfaces/RouterBridge.md +3 -3
  270. package/api/@xmachines/play-vue-router/type-aliases/RoutableActor.md +1 -1
  271. package/api/@xmachines/play-vue-router/variables/PlayRouterProvider.md +1 -1
  272. package/api/@xmachines/play-xstate/classes/PlayerActor.md +24 -24
  273. package/api/@xmachines/play-xstate/functions/buildRouteUrl.md +1 -1
  274. package/api/@xmachines/play-xstate/functions/composeGuards.md +1 -1
  275. package/api/@xmachines/play-xstate/functions/composeGuardsOr.md +1 -1
  276. package/api/@xmachines/play-xstate/functions/contextFieldMatches.md +1 -1
  277. package/api/@xmachines/play-xstate/functions/definePlayer.md +1 -1
  278. package/api/@xmachines/play-xstate/functions/deriveRoute.md +1 -1
  279. package/api/@xmachines/play-xstate/functions/eventMatches.md +1 -1
  280. package/api/@xmachines/play-xstate/functions/formatPlayRouteTransitions.md +1 -1
  281. package/api/@xmachines/play-xstate/functions/hasContext.md +1 -1
  282. package/api/@xmachines/play-xstate/functions/isAbsoluteRoute.md +1 -1
  283. package/api/@xmachines/play-xstate/functions/negateGuard.md +1 -1
  284. package/api/@xmachines/play-xstate/interfaces/PlayerConfig.md +3 -3
  285. package/api/@xmachines/play-xstate/interfaces/PlayerFactoryResumeOptions.md +2 -2
  286. package/api/@xmachines/play-xstate/interfaces/PlayerOptions.md +6 -6
  287. package/api/@xmachines/play-xstate/interfaces/RouteContext.md +5 -5
  288. package/api/@xmachines/play-xstate/type-aliases/ComposedGuard.md +1 -1
  289. package/api/@xmachines/play-xstate/type-aliases/Guard.md +1 -1
  290. package/api/@xmachines/play-xstate/type-aliases/GuardArray.md +1 -1
  291. package/api/@xmachines/play-xstate/type-aliases/PlayerFactory.md +1 -1
  292. package/api/@xmachines/play-xstate/type-aliases/RouteMachineConfig.md +4 -4
  293. package/api/@xmachines/play-xstate/type-aliases/RouteStateNode.md +4 -4
  294. package/api/@xmachines/shared/functions/defineXmVitestConfig.md +1 -1
  295. package/api/@xmachines/shared/functions/xmAliases.md +1 -1
  296. package/api/_media/README.md +98 -15
  297. package/examples/@xmachines/play-dom-demo/README.md +42 -22
  298. package/examples/@xmachines/play-dom-demo/functions/createNavBar.md +1 -1
  299. package/examples/@xmachines/play-dom-demo/functions/initShell.md +1 -1
  300. package/examples/@xmachines/play-dom-demo/type-aliases/AuthCatalog.md +1 -1
  301. package/examples/@xmachines/play-dom-demo/variables/About.md +1 -1
  302. package/examples/@xmachines/play-dom-demo/variables/Contact.md +1 -1
  303. package/examples/@xmachines/play-dom-demo/variables/Dashboard.md +1 -1
  304. package/examples/@xmachines/play-dom-demo/variables/Home.md +1 -1
  305. package/examples/@xmachines/play-dom-demo/variables/Login.md +1 -1
  306. package/examples/@xmachines/play-dom-demo/variables/NavBarView.md +1 -1
  307. package/examples/@xmachines/play-dom-demo/variables/Navigation.md +1 -1
  308. package/examples/@xmachines/play-dom-demo/variables/Overview.md +1 -1
  309. package/examples/@xmachines/play-dom-demo/variables/Profile.md +1 -1
  310. package/examples/@xmachines/play-dom-demo/variables/Settings.md +1 -1
  311. package/examples/@xmachines/play-dom-demo/variables/Stats.md +1 -1
  312. package/examples/@xmachines/play-dom-demo/variables/authCatalog.md +1 -1
  313. package/examples/@xmachines/play-react-demo/README.md +53 -46
  314. package/examples/@xmachines/play-react-demo/functions/App.md +1 -1
  315. package/examples/@xmachines/play-react-demo/type-aliases/AuthCatalog.md +1 -1
  316. package/examples/@xmachines/play-react-demo/variables/About.md +1 -1
  317. package/examples/@xmachines/play-react-demo/variables/Contact.md +1 -1
  318. package/examples/@xmachines/play-react-demo/variables/Dashboard.md +1 -1
  319. package/examples/@xmachines/play-react-demo/variables/DebugPanel.md +1 -1
  320. package/examples/@xmachines/play-react-demo/variables/Home.md +1 -1
  321. package/examples/@xmachines/play-react-demo/variables/Login.md +1 -1
  322. package/examples/@xmachines/play-react-demo/variables/NavBar.md +1 -1
  323. package/examples/@xmachines/play-react-demo/variables/NavBarView.md +1 -1
  324. package/examples/@xmachines/play-react-demo/variables/Navigation.md +1 -1
  325. package/examples/@xmachines/play-react-demo/variables/Overview.md +1 -1
  326. package/examples/@xmachines/play-react-demo/variables/Profile.md +1 -1
  327. package/examples/@xmachines/play-react-demo/variables/Settings.md +1 -1
  328. package/examples/@xmachines/play-react-demo/variables/Shell.md +1 -1
  329. package/examples/@xmachines/play-react-demo/variables/Stats.md +1 -1
  330. package/examples/@xmachines/play-react-demo/variables/authCatalog.md +1 -1
  331. package/examples/@xmachines/play-solid-demo/README.md +53 -34
  332. package/examples/@xmachines/play-solid-demo/functions/App.md +1 -1
  333. package/examples/@xmachines/play-solid-demo/type-aliases/AuthCatalog.md +1 -1
  334. package/examples/@xmachines/play-solid-demo/variables/About.md +1 -1
  335. package/examples/@xmachines/play-solid-demo/variables/Contact.md +1 -1
  336. package/examples/@xmachines/play-solid-demo/variables/Dashboard.md +1 -1
  337. package/examples/@xmachines/play-solid-demo/variables/DebugPanel.md +1 -1
  338. package/examples/@xmachines/play-solid-demo/variables/Home.md +1 -1
  339. package/examples/@xmachines/play-solid-demo/variables/Login.md +1 -1
  340. package/examples/@xmachines/play-solid-demo/variables/NavBar.md +1 -1
  341. package/examples/@xmachines/play-solid-demo/variables/NavBarView.md +1 -1
  342. package/examples/@xmachines/play-solid-demo/variables/Navigation.md +1 -1
  343. package/examples/@xmachines/play-solid-demo/variables/Overview.md +1 -1
  344. package/examples/@xmachines/play-solid-demo/variables/Profile.md +1 -1
  345. package/examples/@xmachines/play-solid-demo/variables/Settings.md +1 -1
  346. package/examples/@xmachines/play-solid-demo/variables/Shell.md +1 -1
  347. package/examples/@xmachines/play-solid-demo/variables/Stats.md +1 -1
  348. package/examples/@xmachines/play-solid-demo/variables/authCatalog.md +1 -1
  349. package/examples/@xmachines/play-svelte-demo/README.md +23 -20
  350. package/examples/@xmachines/play-svelte-spa-router-demo/README.md +8 -10
  351. package/examples/@xmachines/play-sveltekit-router-demo/README.md +10 -12
  352. package/examples/@xmachines/play-vue-demo/README.md +55 -37
  353. package/examples/form-validation.md +33 -42
  354. package/guides/README.md +8 -0
  355. package/guides/actor-model.md +180 -0
  356. package/guides/getting-started.md +18 -14
  357. package/guides/signals.md +166 -0
  358. package/guides/state-machines.md +288 -0
  359. package/package.json +2 -2
  360. package/rfc/play.md +62 -35
  361. package/api/@xmachines/play-actor/interfaces/ViewMetadata.md +0 -17
  362. package/api/@xmachines/play-react/interfaces/PlayRendererProps.md +0 -24
  363. package/api/@xmachines/play-solid/interfaces/PlayRendererProps.md +0 -24
  364. package/api/@xmachines/play-svelte/interfaces/PlayRendererProps.md +0 -22
  365. package/api/@xmachines/play-svelte/variables/getBoundProp.md +0 -7
  366. package/api/@xmachines/play-vue/interfaces/PlayRendererProps.md +0 -22
@@ -0,0 +1,166 @@
1
+ # Understanding TC39 Signals in XMachines
2
+
3
+ TC39 Signals are the reactive substrate connecting actors to the outside world in XMachines. This page explains what they are, why XMachines uses them instead of observables or callbacks, and how the three Signal primitives map to distinct roles in the architecture.
4
+
5
+ After reading this, you will understand why infrastructure never reads state directly from an actor — and what it does instead.
6
+
7
+ ---
8
+
9
+ ## What problem Signals solve
10
+
11
+ When a state machine transitions, several things may need to react: the URL bar might update, a router might navigate, a renderer might swap views. The naive approach is to let each of those consumers call `actor.getSnapshot()` whenever they feel like it — or to have the actor call back into each consumer via callbacks.
12
+
13
+ Both approaches break down:
14
+
15
+ - **Polling** (`getSnapshot()` on a timer or event) is racy: consumers can observe inconsistent intermediate states during a transition sequence.
16
+ - **Callbacks** create direct dependencies between the actor and infrastructure, violating the architectural invariant that business logic must not depend on runtime APIs.
17
+
18
+ TC39 Signals solve this with a **push–pull model**:
19
+
20
+ - The actor **pushes** state changes into signals synchronously on every transition.
21
+ - Consumers **pull** computed values lazily from signals — only when they actually need the value.
22
+ - Changes propagate **atomically**, so no consumer ever sees a half-updated state.
23
+
24
+ This model is sometimes called _glitch-free reactivity_: intermediate invalid states never escape to the environment.
25
+
26
+ ---
27
+
28
+ ## The three Signal primitives
29
+
30
+ XMachines uses three primitives from the [TC39 Signals proposal](https://github.com/tc39/proposal-signals), accessed via `@xmachines/play-signals`:
31
+
32
+ ### `Signal.State` — writable values
33
+
34
+ `Signal.State<T>` holds a single mutable value. Only the actor (or code it explicitly delegates to) writes to it. Everything else reads from it.
35
+
36
+ ```typescript
37
+ import { Signal } from "@xmachines/play-signals";
38
+
39
+ const count = new Signal.State(0);
40
+
41
+ count.set(1); // write
42
+ count.get(); // read → 1
43
+ ```
44
+
45
+ In XMachines, `actor.state` is a `Signal.State<Snapshot>`. The actor updates it on every XState transition. Infrastructure reads it — never writes it.
46
+
47
+ ### `Signal.Computed` — derived values
48
+
49
+ `Signal.Computed<T>` derives a value from one or more other signals. It recomputes only when its dependencies change — and only when something reads it (lazy evaluation).
50
+
51
+ ```typescript
52
+ const route = new Signal.Computed(() => {
53
+ const snapshot = actor.state.get();
54
+ return snapshot.getMeta()?.route ?? null;
55
+ });
56
+ ```
57
+
58
+ In XMachines, `actor.currentRoute` is a `Signal.Computed<string | null>`. Router adapters read it to know which URL to push — they do not compute the route themselves. Route derivation stays in the actor where the business logic lives.
59
+
60
+ ### `Signal.subtle.Watcher` — reactive observation
61
+
62
+ `Signal.subtle.Watcher` is the low-level primitive for reacting to signal changes. When a watched signal's value changes, the watcher's `notify` callback fires synchronously. You then schedule the actual work with `queueMicrotask` to avoid re-entrant signal reads.
63
+
64
+ ```typescript
65
+ const watcher = new Signal.subtle.Watcher(() => {
66
+ queueMicrotask(() => {
67
+ const pending = watcher.getPending();
68
+ for (const signal of pending) {
69
+ signal.get(); // re-read to flush
70
+ }
71
+ watcher.watch(...pending); // re-arm for next change
72
+ });
73
+ });
74
+
75
+ watcher.watch(actor.currentRoute);
76
+ actor.currentRoute.get(); // initial read required to arm the watcher
77
+ ```
78
+
79
+ Watcher notifications are **one-shot**: if you do not call `watch()` again after draining pending signals, you will miss subsequent changes.
80
+
81
+ Router bridges and renderers use `Signal.subtle.Watcher` internally. For most application code, the `watchSignal()` helper covers the common case.
82
+
83
+ ---
84
+
85
+ ## `watchSignal()` — the safe helper
86
+
87
+ `@xmachines/play-signals` exports `watchSignal(signal, onValue)` as a lifecycle-safe wrapper around the raw watcher pattern. It returns a cleanup function:
88
+
89
+ ```typescript
90
+ import { watchSignal } from "@xmachines/play-signals";
91
+
92
+ const stop = watchSignal(actor.currentRoute, (route) => {
93
+ console.log("Route is now:", route);
94
+ });
95
+
96
+ // Later — stops observing and prevents use-after-free
97
+ stop();
98
+ ```
99
+
100
+ `watchSignal()` handles three subtle correctness concerns for you:
101
+
102
+ | Concern | What happens without it | How `watchSignal` handles it |
103
+ | ---------------------- | -------------------------------------------------- | ---------------------------------------------------------------------- |
104
+ | **Use-after-free** | Callback fires after component unmounts | `disposed` flag checked before invoking callback |
105
+ | **Coalescing** | Rapid synchronous changes cause multiple callbacks | `needsEnqueue` guard — only one microtask queued per synchronous burst |
106
+ | **Idempotent cleanup** | Calling the cleanup twice throws | Safe to call multiple times |
107
+
108
+ Use `watchSignal()` in framework adapters and application code. Use the raw `Signal.subtle.Watcher` only when building infrastructure that needs to watch multiple signals independently.
109
+
110
+ ---
111
+
112
+ ## Why not observables (RxJS) or event emitters?
113
+
114
+ The XMachines architecture chose TC39 Signals over observable libraries and event emitters for three reasons:
115
+
116
+ **1. Standardization.** Signals are a Stage 1 TC39 proposal. They are not tied to any library, bundler, or framework. Isolating the polyfill behind `@xmachines/play-signals` means the entire ecosystem can migrate to native signals when the proposal lands, with a single package update.
117
+
118
+ **2. Synchronous atomic propagation.** RxJS streams are asynchronous by default. Event emitters fire immediately but serially — a listener registered halfway through a sequence can see inconsistent state. Signals propagate atomically: all computeds update before any watcher fires.
119
+
120
+ **3. Pull-based evaluation.** Observables push values to every subscriber immediately. Signals are lazy: `Signal.Computed` does not recompute until something reads it. An adapter that is not currently mounted does not pay the cost of computing derived values.
121
+
122
+ ---
123
+
124
+ ## The five Signal invariants in XMachines
125
+
126
+ The Play RFC defines five invariants that govern how signals are used:
127
+
128
+ | Invariant | What it means in practice |
129
+ | ---------------------------------- | ----------------------------------------------------------------------------------------------------------- |
130
+ | **INV-01: Actor Authority** | Only actor code writes to `actor.state`. Never write to it from infrastructure. |
131
+ | **INV-04: Passive Infrastructure** | Routers and renderers read signals and forward events. They never decide state transitions. |
132
+ | **INV-05: Signal-Only Reactivity** | Cross-boundary communication uses signals. Infrastructure does not poll `getSnapshot()`. |
133
+ | **INV-03: No Direct Queries** | Infrastructure reads from signals, not from snapshot methods, outside of actor code. |
134
+ | **INV-02: Strict Separation** | Business logic (`machine` definition) never imports browser APIs, routing libraries, or framework packages. |
135
+
136
+ ---
137
+
138
+ ## Cleanup is mandatory
139
+
140
+ Signals do not clean themselves up when they go out of scope. Every watcher you create must be explicitly disposed when the consuming component or adapter unmounts.
141
+
142
+ - Framework lifecycle hooks (`useEffect` cleanup in React, `onUnmounted` in Vue, `onCleanup` in Solid) must call `unwatch()` or the cleanup returned by `watchSignal()`.
143
+ - Router bridge `disconnect()` methods must unwatch all signal subscriptions.
144
+ - If you use the raw `Signal.subtle.Watcher` API, pair every `watch()` call with `unwatch()` in teardown.
145
+
146
+ Failing to clean up watchers causes memory leaks and stale callbacks firing after the consumer is gone.
147
+
148
+ ---
149
+
150
+ ## Summary
151
+
152
+ | Primitive | Role in XMachines | Who uses it |
153
+ | ----------------------- | ---------------------------------------------- | ---------------------------------- |
154
+ | `Signal.State` | Actor output: writable snapshot and view state | Actor writes; infrastructure reads |
155
+ | `Signal.Computed` | Lazy derivations: routes, view specs | Actor defines; adapters read |
156
+ | `Signal.subtle.Watcher` | Low-level reactive observation | Framework adapters, router bridges |
157
+ | `watchSignal()` | Lifecycle-safe single-signal subscription | Application code, adapter code |
158
+
159
+ ## See also
160
+
161
+ - [Understanding the Actor Model](concepts-actor-model.md) — why the actor owns all signal writes
162
+ - [Understanding State Machines](concepts-state-machines.md) — how state nodes produce the metadata that signals derive
163
+ - [Getting Started](getting-started.md) — hands-on walkthrough using signals to observe an actor
164
+ - [@xmachines/play-signals README](../api/@xmachines/play-signals/README.md) — API reference
165
+ - [Play RFC](../rfc/play.md) — architectural specification
166
+ - [TC39 Signals proposal](https://github.com/tc39/proposal-signals) — upstream proposal
@@ -0,0 +1,288 @@
1
+ # Understanding State Machines in XMachines
2
+
3
+ XMachines uses XState v5 as its state machine engine. This page explains what finite state machines are, how XMachines extends them with routing and view metadata, and why this design eliminates an entire category of bugs common in traditional frontend architecture.
4
+
5
+ After reading this, you will understand what a machine definition actually encodes — and why state machines are a better unit of business logic than component-level state or ad-hoc if/else trees.
6
+
7
+ ---
8
+
9
+ ## What a finite state machine is
10
+
11
+ A finite state machine (FSM) is a model of computation with three properties:
12
+
13
+ 1. **It is always in exactly one state** from a finite set of possible states.
14
+ 2. **It transitions between states only in response to events**.
15
+ 3. **The same event in different states can produce different outcomes** (or no transition at all).
16
+
17
+ These three properties, taken together, make behavior _deterministic and exhaustive_. You cannot end up in an unlisted state. You cannot receive an event that produces an unspecified outcome — unhandled events are simply ignored.
18
+
19
+ In traditional component-level state (e.g., boolean flags, `useState` combinations), you typically end up managing _n_ booleans for _n_ conditions. With _n_ booleans, you have 2^n possible combinations — and only a handful of them are actually valid. State machines force you to enumerate only the valid states.
20
+
21
+ **Example:** A login flow with two booleans (`isLoading`, `isError`) has four combinations: `{false,false}`, `{true,false}`, `{false,true}`, `{true,true}`. The last one — loading and error simultaneously — is impossible in practice, but the code has no way to rule it out. A state machine with states `idle | loading | success | error` makes the impossible unrepresentable.
22
+
23
+ ---
24
+
25
+ ## How XMachines uses XState v5
26
+
27
+ XMachines wraps XState v5 via `@xmachines/play-xstate`. You define machines using XState's `setup().createMachine()` API:
28
+
29
+ ```typescript
30
+ import { setup } from "xstate";
31
+
32
+ const authSetup = setup({
33
+ types: {
34
+ context: {} as { username: string | null },
35
+ events: {} as { type: "auth.login"; username: string } | { type: "auth.logout" },
36
+ input: {} as undefined,
37
+ },
38
+ });
39
+
40
+ const authMachine = authSetup.createMachine({
41
+ id: "auth",
42
+ initial: "unauthenticated",
43
+ context: { username: null },
44
+ states: {
45
+ unauthenticated: {
46
+ on: {
47
+ "auth.login": {
48
+ target: "authenticated",
49
+ actions: authSetup.assign({
50
+ username: ({ event }) => event.username,
51
+ }),
52
+ },
53
+ },
54
+ },
55
+ authenticated: {
56
+ on: {
57
+ "auth.logout": {
58
+ target: "unauthenticated",
59
+ actions: authSetup.assign({ username: null }),
60
+ },
61
+ },
62
+ },
63
+ },
64
+ });
65
+ ```
66
+
67
+ Key patterns:
68
+
69
+ - **Always use `setup({ types })`** before `createMachine`. The type declarations let TypeScript check that your events, context fields, and actions are consistent throughout the machine.
70
+ - **Use `setup.assign()`**, not the bare `assign` from xstate. This keeps the type checker aware of which context fields the action touches.
71
+ - **Event names use lowercase dot-separated namespaces**: `"auth.login"`, `"play.route"`, `"form.submit"`. This convention makes the event log readable and avoids collisions.
72
+
73
+ ---
74
+
75
+ ## State node metadata: routing and views
76
+
77
+ XMachines extends XState's `meta` field on each state node. This is where routing intent and view structure live:
78
+
79
+ ```typescript
80
+ import { typedSpec } from "@xmachines/play-actor";
81
+
82
+ const appMachine = setup({
83
+ /* ... */
84
+ }).createMachine({
85
+ id: "app",
86
+ initial: "home",
87
+ states: {
88
+ home: {
89
+ meta: {
90
+ route: "/",
91
+ view: typedSpec({
92
+ root: "root",
93
+ elements: {
94
+ root: { type: "HomePage", props: { title: "Welcome" }, children: [] },
95
+ },
96
+ }),
97
+ },
98
+ },
99
+ login: {
100
+ meta: {
101
+ route: "/login",
102
+ view: typedSpec({
103
+ root: "root",
104
+ elements: {
105
+ root: { type: "LoginPage", props: { title: "Sign in" }, children: [] },
106
+ },
107
+ }),
108
+ },
109
+ },
110
+ dashboard: {
111
+ meta: {
112
+ route: "/dashboard",
113
+ view: typedSpec({
114
+ root: "root",
115
+ elements: {
116
+ root: { type: "DashboardPage", props: { title: "Overview" }, children: [] },
117
+ },
118
+ }),
119
+ },
120
+ },
121
+ },
122
+ });
123
+ ```
124
+
125
+ `meta.route` is a string path. When the machine enters a state, `actor.currentRoute` (a `Signal.Computed`) derives this path and emits it. The router bridge reads it and updates the URL.
126
+
127
+ `meta.view` is a `PlaySpec` — a `@json-render/core` spec object describing what to render. Use `typedSpec<TContext>(...)` from `@xmachines/play-actor` to validate `contextProps` entries at compile time. When the machine enters a state, `actor.currentView` is updated with this spec. The renderer reads it and projects it through framework components.
128
+
129
+ **The machine is the single source of truth for both routing and views.** There is no separate route configuration file. There is no switch statement in a component deciding what to render based on the URL. The state machine encodes all of that.
130
+
131
+ ---
132
+
133
+ ## `formatPlayRouteTransitions` — automatic route event wiring
134
+
135
+ For routing to work, the machine must respond to `play.route` events (sent by router bridges when the user navigates). Writing these transitions by hand is mechanical:
136
+
137
+ ```typescript
138
+ // Without formatPlayRouteTransitions — verbose and repetitive
139
+ states: {
140
+ home: {
141
+ on: {
142
+ "play.route": [
143
+ { guard: ({ event }) => event.to === "#login", target: "login" },
144
+ { guard: ({ event }) => event.to === "#dashboard", target: "dashboard" },
145
+ ],
146
+ },
147
+ meta: { route: "/" },
148
+ },
149
+ // ... repeated for every state
150
+ }
151
+ ```
152
+
153
+ `formatPlayRouteTransitions` from `@xmachines/play-xstate` generates these transitions automatically from the `id` and `meta.route` fields you already have:
154
+
155
+ ```typescript
156
+ import { formatPlayRouteTransitions } from "@xmachines/play-xstate";
157
+
158
+ const appMachine = setup({
159
+ /* ... */
160
+ }).createMachine(
161
+ formatPlayRouteTransitions({
162
+ id: "app",
163
+ initial: "home",
164
+ states: {
165
+ home: { id: "home", meta: { route: "/" } },
166
+ login: { id: "login", meta: { route: "/login" } },
167
+ dashboard: { id: "dashboard", meta: { route: "/dashboard" } },
168
+ },
169
+ }),
170
+ );
171
+ ```
172
+
173
+ `formatPlayRouteTransitions` inspects all state nodes with a `meta.route` and generates the corresponding `play.route` guard transitions. The machine's context must include `params` and `query` fields (populated by the router bridge when params or query strings are present):
174
+
175
+ ```typescript
176
+ types: {
177
+ context: {} as {
178
+ params: Record<string, string>;
179
+ query: Record<string, string>;
180
+ // ... other context fields
181
+ },
182
+ events: {} as PlayRouteEvent | OtherEvents,
183
+ }
184
+ ```
185
+
186
+ ---
187
+
188
+ ## Guards — the actor's authority
189
+
190
+ Guards are the mechanism by which the actor controls whether a transition occurs. They are pure functions of `{ context, event }` that return a boolean.
191
+
192
+ ```typescript
193
+ const authSetup = setup({
194
+ guards: {
195
+ isAuthenticated: ({ context }) => context.isAuthenticated,
196
+ isAdmin: ({ context }) => context.role === "admin",
197
+ },
198
+ });
199
+ ```
200
+
201
+ Guards are evaluated by XState before a transition fires. If the guard returns `false`, the transition does not occur — the machine stays in its current state and the `play.route` event is discarded. The router bridge then sees that `actor.currentRoute` has not changed and corrects the URL back to the current valid route.
202
+
203
+ This is the **Actor Authority** invariant in practice: the machine decides, infrastructure adjusts.
204
+
205
+ XMachines provides guard combinators in `@xmachines/play-xstate` for composing complex conditions:
206
+
207
+ | Function | What it does |
208
+ | --------------------------------- | --------------------------------------- |
209
+ | `composeGuards(...guards)` | AND — all guards must pass |
210
+ | `composeGuardsOr(...guards)` | OR — any guard must pass |
211
+ | `negateGuard(guard)` | NOT — inverts the guard result |
212
+ | `hasContext(key)` | Checks that a context field is non-null |
213
+ | `contextFieldMatches(key, value)` | Checks a context field against a value |
214
+ | `eventMatches(type)` | Checks the event type |
215
+
216
+ ---
217
+
218
+ ## Context — persistent state across transitions
219
+
220
+ Context is the machine's persistent data store. It survives transitions and can be read and updated by actions:
221
+
222
+ ```typescript
223
+ // Context is defined in setup({ types })
224
+ types: {
225
+ context: {} as {
226
+ isAuthenticated: boolean;
227
+ username: string | null;
228
+ loginAttempts: number;
229
+ },
230
+ },
231
+
232
+ // Actions mutate context via assign
233
+ actions: {
234
+ recordLoginFailure: assign({
235
+ loginAttempts: ({ context }) => context.loginAttempts + 1,
236
+ }),
237
+ },
238
+ ```
239
+
240
+ Context is accessed in guards, actions, and when computing routes or views. It is not directly observable from outside the actor via signals — only the derived signals (`state`, `currentRoute`, `currentView`) are public. If you need to expose a context field reactively, add a `Signal.Computed` to the actor that derives from `actor.state`.
241
+
242
+ ---
243
+
244
+ ## Snapshots and restoration
245
+
246
+ A snapshot is a point-in-time serialisation of the machine's current state and context. XState produces snapshots in a JSON-compatible format:
247
+
248
+ ```typescript
249
+ const snapshot = actor.getSnapshot();
250
+ // snapshot.value → current state node name, e.g. "dashboard"
251
+ // snapshot.context → current context object
252
+
253
+ // Stop and serialize
254
+ actor.stop();
255
+ const saved = JSON.stringify(snapshot);
256
+
257
+ // Restore
258
+ const restored = JSON.parse(saved);
259
+ const actor = createPlayer(undefined, { snapshot: restored });
260
+ actor.start();
261
+ // Actor resumes from where it left off
262
+ ```
263
+
264
+ `definePlayer` accepts an optional `restore` argument for this purpose. Restoration is useful for server-side rendering (hydrate with the server's snapshot), session persistence (resume after page reload), and testing (start from a known mid-flow state).
265
+
266
+ ---
267
+
268
+ ## What state machines replace
269
+
270
+ | Traditional pattern | State machine equivalent | Why the machine version is better |
271
+ | ----------------------------------------------------- | -------------------------------------------- | ----------------------------------------------------------- |
272
+ | Boolean flags (`isLoading`, `isError`) | Explicit states (`idle \| loading \| error`) | Impossible state combinations are unrepresentable |
273
+ | Switch on URL path in component | `meta.route` on state nodes | Routing intent lives with the state that owns it |
274
+ | `if (user.role === "admin")` scattered in components | Guards on transitions | Auth logic is co-located with the transitions it governs |
275
+ | `useEffect` on route changes to decide what to render | `meta.view` on state nodes | View structure is declared alongside the state that owns it |
276
+ | Shared mutable state across components | Context + signals | Mutations are explicit, traceable, and test-covered |
277
+
278
+ ---
279
+
280
+ ## See also
281
+
282
+ - [Understanding the Actor Model](actor-model.md) — how the machine definition becomes a live actor
283
+ - [Understanding TC39 Signals](signals.md) — how the actor's state is observed by infrastructure
284
+ - [Getting Started](getting-started.md) — step-by-step walkthrough building your first machine and actor
285
+ - [Routing Patterns](../examples/routing-patterns.md) — worked examples of `meta.route` and guards
286
+ - [@xmachines/play-xstate README](../api/@xmachines/play-xstate/README.md) — full API reference for `definePlayer`, `PlayerActor`, guard combinators
287
+ - [XState v5 documentation](https://stately.ai/docs/xstate) — upstream state machine library documentation
288
+ - [Play RFC](../rfc/play.md) — complete architectural specification
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xmachines/docs",
3
- "version": "1.0.0-beta.33",
3
+ "version": "1.0.0-beta.34",
4
4
  "description": "Documentation for XMachines",
5
5
  "keywords": [
6
6
  "documentation",
@@ -49,7 +49,7 @@
49
49
  "test": "vitest run"
50
50
  },
51
51
  "devDependencies": {
52
- "@xmachines/shared": "1.0.0-beta.33",
52
+ "@xmachines/shared": "1.0.0-beta.34",
53
53
  "oxfmt": "^0.45.0",
54
54
  "oxlint": "^1.60.0",
55
55
  "typedoc": "^0.28.19",
package/rfc/play.md CHANGED
@@ -156,13 +156,8 @@ export interface PlaySpec extends Spec {
156
156
  contextProps?: string[];
157
157
  }
158
158
 
159
- export interface ViewMetadata {
160
- component: string;
161
- spec: PlaySpec;
162
- }
163
-
164
159
  export interface Viewable {
165
- readonly currentView: Signal.State<ViewMetadata | null>;
160
+ readonly currentView: Signal.State<PlaySpec | null>;
166
161
  }
167
162
 
168
163
  // The Base Protocol — minimal contract
@@ -231,7 +226,7 @@ class PlayerActor<TMachine extends AnyStateMachine>
231
226
  {
232
227
  public state: Signal.State<AnyMachineSnapshot>;
233
228
  public currentRoute: Signal.Computed<string | null>;
234
- public currentView: Signal.State<ViewMetadata | null>;
229
+ public currentView: Signal.State<PlaySpec | null>;
235
230
  public readonly initialRoute: string | null;
236
231
  }
237
232
  ```
@@ -317,27 +312,44 @@ Each view renderer provides a `PlayRenderer` component that passively observes t
317
312
  **`@xmachines/play-react` exports (representative):**
318
313
 
319
314
  ```ts
320
- // Main component
321
- export const PlayRenderer: React.FC<PlayRendererProps> = ({
322
- actor, // AbstractActor & Viewable
323
- registry, // ComponentRegistry from defineRegistry()
324
- store?, // Optional external StateStore (controlled mode)
325
- fallback?, // Shown when currentView is null
326
- actions?, // Map of action names XState event type strings
327
- }) => { /* ... */ };
315
+ // Batteries-included composite — standard entry point
316
+ // Props: actor, registryResult, store?, fallback?, onError?, onRenderError?,
317
+ // validationFunctions?, navigate?, functions?
318
+ export { PlayUIProvider } from "./PlayUIProvider";
319
+ export type { PlayUIProviderProps } from "./PlayUIProvider";
320
+
321
+ // Escape-hatch primitive owns actor lifecycle, signal bridge, ViewContext
322
+ // Props: actor, registryResult, store?, fallback?, onError?, onRenderError?, children (required)
323
+ export { ActorProvider } from "./ActorProvider";
324
+ export type { ActorProviderProps } from "./ActorProvider";
325
+
326
+ // Zero-prop leaf — reads usePlayView() from ActorProvider tree; renders <Renderer spec={...} />
327
+ // Must be rendered inside <ActorProvider> or <PlayUIProvider>
328
+ export const PlayRenderer: React.FC = () => {
329
+ /* ... */
330
+ };
328
331
 
329
332
  // Hooks
330
- export { useSignalEffect } from './useSignalEffect';
331
- export { useActor } from './useActor';
333
+ export { usePlayView } from "./ActorProvider"; // returns ViewContextValue | null
334
+ export { useSignalEffect } from "./useSignalEffect";
335
+ export { useActor } from "./useActor";
332
336
 
333
337
  // Error handling
334
- export { PlayErrorBoundary } from './PlayErrorBoundary';
338
+ export { PlayErrorBoundary } from "./PlayErrorBoundary";
335
339
 
336
340
  // Re-exports from @json-render/react
337
- export { defineRegistry, useStateBinding, useBoundProp } from '@json-render/react';
341
+ export {
342
+ defineRegistry,
343
+ JSONUIProvider,
344
+ StateProvider,
345
+ ActionProvider,
346
+ VisibilityProvider,
347
+ ValidationProvider,
348
+ Renderer,
349
+ } from "@json-render/react";
338
350
  ```
339
351
 
340
- **Design Rationale:** The original design passed `components: ComponentMap<TCatalog>` and `catalog: Catalog` directly to `PlayRenderer`. The implementation replaced these with a single `registry` (from `defineRegistry`), which bakes catalog validation into the registry at definition time. This eliminates runtime catalog lookups and provides better TypeScript inference.
352
+ **Design Rationale:** `PlayRenderer` is now a **zero-prop leaf component** it reads view context from the enclosing `ActorProvider` via `usePlayView()`. All mount-time concerns (actor bridging, signal subscription, store lifecycle, `onRenderError` injection) are centralised in `ActorProvider`. `PlayUIProvider` is the batteries-included composite that wraps `ActorProvider` + `JSONUIProvider` with a handler bridge. This mirrors the provider/renderer split in `@json-render/*` and makes the separation of concerns explicit.
341
353
 
342
354
  ### 5.5 Schema Layer (External)
343
355
 
@@ -383,11 +395,17 @@ export const machine = setup({
383
395
  overview: {
384
396
  meta: {
385
397
  route: "/dashboard",
386
- view: {
387
- type: "Dashboard",
388
- props: { title: "Q4 Performance" },
389
- children: [{ type: "Metric", props: { value: 100, label: "Sales" } }],
390
- },
398
+ view: typedSpec<DashboardCtx>({
399
+ root: "root",
400
+ elements: {
401
+ root: {
402
+ type: "Dashboard",
403
+ props: { title: "Q4 Performance" },
404
+ children: ["metric"],
405
+ },
406
+ metric: { type: "Metric", props: { value: 100, label: "Sales" } },
407
+ },
408
+ }),
391
409
  },
392
410
  },
393
411
  },
@@ -404,7 +422,7 @@ Binds Logic to a View Renderer and Router Adapter.
404
422
  ```tsx
405
423
  import { createDashboard, machine } from "./features/dashboard/player";
406
424
  import { catalog } from "./catalog";
407
- import { PlayRenderer, defineRegistry } from "@xmachines/play-react";
425
+ import { PlayUIProvider, PlayRenderer, defineRegistry } from "@xmachines/play-react";
408
426
  import { TanStackReactRouterBridge } from "@xmachines/play-tanstack-react-router";
409
427
  import { extractMachineRoutes, createRouteMap } from "@xmachines/play-router";
410
428
 
@@ -412,13 +430,18 @@ import { extractMachineRoutes, createRouteMap } from "@xmachines/play-router";
412
430
  const actor = createDashboard();
413
431
 
414
432
  // 2. Define component implementations (type-checked against catalog)
415
- const registry = defineRegistry(catalog, {
416
- Dashboard: ({ props, children }) => <div className="p-4">{children}</div>,
417
- Metric: ({ props }) => (
418
- <span>
419
- {props.label}: {props.value}
420
- </span>
421
- ),
433
+ const registryResult = defineRegistry(catalog, {
434
+ components: {
435
+ Dashboard: ({ props, children }) => <div className="p-4">{children}</div>,
436
+ Metric: ({ props }) => (
437
+ <span>
438
+ {props.label}: {props.value}
439
+ </span>
440
+ ),
441
+ },
442
+ actions: {
443
+ submit: async () => actor.send({ type: "form.submit" }),
444
+ },
422
445
  });
423
446
 
424
447
  // 3. Build route map from machine definition
@@ -429,9 +452,13 @@ const routeMap = createRouteMap(routeTree);
429
452
  const bridge = new TanStackReactRouterBridge(tanstackRouter, actor, routeMap);
430
453
  bridge.connect();
431
454
 
432
- // 5. Render
455
+ // 5. Render — PlayUIProvider is the batteries-included composite; PlayRenderer is the zero-prop leaf
433
456
  function App() {
434
- return <PlayRenderer actor={actor} registry={registry} actions={{ submit: "form.submit" }} />;
457
+ return (
458
+ <PlayUIProvider actor={actor} registryResult={registryResult}>
459
+ <PlayRenderer />
460
+ </PlayUIProvider>
461
+ );
435
462
  }
436
463
  ```
437
464
 
@@ -1,17 +0,0 @@
1
- [Documentation](../../../README.md) / [@xmachines/play-actor](../README.md) / ViewMetadata
2
-
3
- # Interface: ViewMetadata
4
-
5
- Defined in: [packages/play-actor/src/abstract-actor.ts:100](https://gitlab.com/xmachin-es/xmachines-js/-/blob/v1.0.0-beta.33/packages/play-actor/src/abstract-actor.ts#L100)
6
-
7
- View metadata for rendering.
8
-
9
- Describes the component to be rendered and the json-render Spec to use.
10
- Used by PlayRenderer to dynamically render UI based on actor state.
11
-
12
- ## Properties
13
-
14
- | Property | Type | Description | Defined in |
15
- | ------------------------------------------- | ------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | ---------------------------------------------------------------------------------------------------------------------------------------------------------------- |
16
- | <a id="property-component"></a> `component` | `string` | Root element type name (for diagnostics and component resolution) | [packages/play-actor/src/abstract-actor.ts:102](https://gitlab.com/xmachin-es/xmachines-js/-/blob/v1.0.0-beta.33/packages/play-actor/src/abstract-actor.ts#L102) |
17
- | <a id="property-spec"></a> `spec` | [`PlaySpec`](PlaySpec.md) | XMachines view spec — extends `@json-render/core` Spec with `contextProps` for explicit context field exposure. Use `typedSpec<TContext>(...)` at the definition site to validate `contextProps` entries against the machine context type. | [packages/play-actor/src/abstract-actor.ts:110](https://gitlab.com/xmachin-es/xmachines-js/-/blob/v1.0.0-beta.33/packages/play-actor/src/abstract-actor.ts#L110) |