@akashjs/runtime 0.1.29 → 0.1.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{chunk-4PK4YNND.js → chunk-DZGRBVSY.js} +2 -2
- package/dist/chunk-DZGRBVSY.js.map +1 -0
- package/dist/chunk-JDJQW4YE.js +2 -0
- package/dist/chunk-JDJQW4YE.js.map +1 -0
- package/dist/{chunk-A3VPGLBN.cjs → chunk-OCBLY4E4.cjs} +2 -2
- package/dist/chunk-OCBLY4E4.cjs.map +1 -0
- package/dist/chunk-OPXWBGJL.cjs +2 -0
- package/dist/chunk-OPXWBGJL.cjs.map +1 -0
- package/dist/index.cjs +10 -10
- package/dist/index.cjs.map +1 -1
- package/dist/index.js +10 -10
- package/dist/index.js.map +1 -1
- package/dist/machine.cjs +1 -1
- package/dist/machine.js +1 -1
- package/dist/store.cjs +1 -1
- package/dist/store.js +1 -1
- package/package.json +1 -1
- package/dist/chunk-4PK4YNND.js.map +0 -1
- package/dist/chunk-A3VPGLBN.cjs.map +0 -1
- package/dist/chunk-TS5UKZTG.js +0 -2
- package/dist/chunk-TS5UKZTG.js.map +0 -1
- package/dist/chunk-VBAO65QP.cjs +0 -2
- package/dist/chunk-VBAO65QP.cjs.map +0 -1
package/dist/machine.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkOPXWBGJL_cjs=require('./chunk-OPXWBGJL.cjs');require('./chunk-RTJ6UDGV.cjs');Object.defineProperty(exports,"createMachine",{enumerable:true,get:function(){return chunkOPXWBGJL_cjs.a}});//# sourceMappingURL=machine.cjs.map
|
|
2
2
|
//# sourceMappingURL=machine.cjs.map
|
package/dist/machine.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{a as createMachine}from'./chunk-
|
|
1
|
+
export{a as createMachine}from'./chunk-JDJQW4YE.js';import'./chunk-TWA4T6PX.js';//# sourceMappingURL=machine.js.map
|
|
2
2
|
//# sourceMappingURL=machine.js.map
|
package/dist/store.cjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
'use strict';var
|
|
1
|
+
'use strict';var chunkOCBLY4E4_cjs=require('./chunk-OCBLY4E4.cjs');require('./chunk-RTJ6UDGV.cjs');Object.defineProperty(exports,"__getStoreInstances",{enumerable:true,get:function(){return chunkOCBLY4E4_cjs.d}});Object.defineProperty(exports,"clearStores",{enumerable:true,get:function(){return chunkOCBLY4E4_cjs.c}});Object.defineProperty(exports,"configureStores",{enumerable:true,get:function(){return chunkOCBLY4E4_cjs.a}});Object.defineProperty(exports,"defineStore",{enumerable:true,get:function(){return chunkOCBLY4E4_cjs.b}});//# sourceMappingURL=store.cjs.map
|
|
2
2
|
//# sourceMappingURL=store.cjs.map
|
package/dist/store.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export{d as __getStoreInstances,c as clearStores,a as configureStores,b as defineStore}from'./chunk-
|
|
1
|
+
export{d as __getStoreInstances,c as clearStores,a as configureStores,b as defineStore}from'./chunk-DZGRBVSY.js';import'./chunk-TWA4T6PX.js';//# sourceMappingURL=store.js.map
|
|
2
2
|
//# sourceMappingURL=store.js.map
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/store.ts"],"names":["globalPlugins","configureStores","options","storeInstances","defineStore","id","definition","initialState","store","createStoreInstance","stateSignals","stateKeys","key","signal","getterFn","computed","plugins","actionFn","args","plugin","fresh","partial","value","snapshot","subscribers","subscribeEffect","callback","isInitial","effect","cb","clearStores","__getStoreInstances"],"mappings":"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","file":"chunk-4PK4YNND.js","sourcesContent":["/**\n * Global state management via defineStore().\n *\n * Stores are singleton signal containers that persist across\n * components. They provide shared state, computed getters,\n * and actions — no external library needed.\n *\n * ```ts\n * const useCounterStore = defineStore('counter', {\n * state: () => ({ count: 0, name: 'Counter' }),\n * getters: {\n * doubled: (state) => state.count() * 2,\n * },\n * actions: {\n * increment() { this.count.update(c => c + 1); },\n * reset() { this.count.set(0); },\n * },\n * });\n *\n * // In any component:\n * const store = useCounterStore();\n * store.count(); // 0\n * store.doubled(); // 0\n * store.increment();\n * store.count(); // 1\n * ```\n */\n\nimport { signal, computed, effect } from './signals.js';\nimport type { Signal, ReadonlySignal } from './signals.js';\n\n// --- Types ---\n\ntype StateFactory<S> = () => S;\n\ntype Getters<S, G> = {\n [K in keyof G]: (state: SignalifiedState<S>) => G[K];\n};\n\ntype Actions<A> = {\n [K in keyof A]: A[K] extends (...args: infer P) => infer R\n ? (...args: P) => R\n : never;\n};\n\n/** Maps plain state values to signals */\ntype SignalifiedState<S> = {\n [K in keyof S]: Signal<S[K]>;\n};\n\n/** The store instance returned to consumers */\nexport type Store<S, G, A> = SignalifiedState<S> & {\n [K in keyof G]: ReadonlySignal<G[K]>;\n} & {\n [K in keyof A]: A[K] extends (...args: infer P) => infer R\n ? (...args: P) => R\n : never;\n} & {\n /** Reset all state to initial values */\n $reset(): void;\n /** Merge partial state into the store */\n $patch(partial: Partial<S>): void;\n /** Subscribe to all state changes */\n $subscribe(callback: (state: S) => void): () => void;\n /** Get a plain snapshot of current state */\n $snapshot(): S;\n /** Store ID */\n $id: string;\n};\n\nexport interface StoreDefinition<S, G, A> {\n state: StateFactory<S>;\n getters?: Getters<S, G>;\n actions?: A;\n plugins?: StorePlugin[];\n}\n\n// --- Plugin system ---\n\nexport interface StorePlugin {\n init?(store: Store<any, any, any>): void;\n onAction?(store: Store<any, any, any>, actionName: string, args: unknown[]): void;\n}\n\nconst globalPlugins: StorePlugin[] = [];\n\n/** Register global plugins that apply to all stores */\nexport function configureStores(options: { plugins: StorePlugin[] }): void {\n globalPlugins.push(...options.plugins);\n}\n\n// --- Store registry (singleton) ---\n\nconst storeInstances = new Map<string, Store<any, any, any>>();\n\n// --- defineStore ---\n\n/**\n * Define a global store. Returns a composable function that\n * always returns the same store instance (singleton).\n */\nexport function defineStore<\n S extends Record<string, unknown>,\n G extends Record<string, unknown> = {},\n A extends Record<string, (...args: any[]) => any> = {},\n>(\n id: string,\n definition: StoreDefinition<S, G, A>,\n): () => Store<S, G, A> {\n return () => {\n // Return existing instance if already created\n if (storeInstances.has(id)) {\n return storeInstances.get(id) as Store<S, G, A>;\n }\n\n const initialState = definition.state();\n const store = createStoreInstance(id, initialState, definition);\n storeInstances.set(id, store);\n return store;\n };\n}\n\nfunction createStoreInstance<\n S extends Record<string, unknown>,\n G extends Record<string, unknown>,\n A extends Record<string, (...args: any[]) => any>,\n>(\n id: string,\n initialState: S,\n definition: StoreDefinition<S, G, A>,\n): Store<S, G, A> {\n // Create signals for each state property\n const stateSignals: Record<string, Signal<unknown>> = {};\n const stateKeys = Object.keys(initialState);\n\n for (const key of stateKeys) {\n stateSignals[key] = signal(initialState[key]);\n }\n\n // Build the store object first so getters can reference other getters via `this`\n const store: any = { $id: id };\n\n // Add state signals\n for (const key of stateKeys) {\n store[key] = stateSignals[key];\n }\n\n // Create computed getters — bound to store so `this.otherGetter()` works\n if (definition.getters) {\n for (const [key, getterFn] of Object.entries(definition.getters)) {\n store[key] = computed(() =>\n (getterFn as Function).call(store, stateSignals),\n );\n }\n }\n\n // Collect all plugins (global + per-store)\n const plugins = [...globalPlugins, ...(definition.plugins ?? [])];\n\n // Bind actions with `this` pointing to the full store (state + getters + actions)\n if (definition.actions) {\n for (const [key, actionFn] of Object.entries(definition.actions)) {\n store[key] = (...args: unknown[]) => {\n for (const plugin of plugins) plugin.onAction?.(store, key, args);\n return (actionFn as Function).apply(store, args);\n };\n }\n }\n\n // $reset\n store.$reset = () => {\n const fresh = definition.state();\n for (const key of stateKeys) {\n stateSignals[key].set(fresh[key as keyof S]);\n }\n };\n\n // $patch — merge partial state\n store.$patch = (partial: Partial<S>) => {\n for (const [key, value] of Object.entries(partial)) {\n if (key in stateSignals) {\n stateSignals[key].set(value);\n }\n }\n };\n\n // $snapshot\n store.$snapshot = (): S => {\n const snapshot: Record<string, unknown> = {};\n for (const key of stateKeys) {\n snapshot[key] = stateSignals[key]();\n }\n return snapshot as S;\n };\n\n // $subscribe — watch all state signals and notify on change\n const subscribers = new Set<(state: S) => void>();\n let subscribeEffect: (() => void) | null = null;\n store.$subscribe = (callback: (state: S) => void): (() => void) => {\n subscribers.add(callback);\n // Start watching if this is the first subscriber\n if (!subscribeEffect) {\n let isInitial = true;\n subscribeEffect = effect(() => {\n // Read all state signals to track them\n for (const key of stateKeys) {\n stateSignals[key]();\n }\n // Skip initial run — only notify on actual changes\n if (isInitial) {\n isInitial = false;\n return;\n }\n const snapshot = store.$snapshot();\n for (const cb of subscribers) {\n cb(snapshot);\n }\n });\n }\n return () => {\n subscribers.delete(callback);\n // Dispose effect when no subscribers remain\n if (subscribers.size === 0 && subscribeEffect) {\n subscribeEffect();\n subscribeEffect = null;\n }\n };\n };\n\n // Initialize plugins\n for (const plugin of plugins) plugin.init?.(store);\n\n return store as Store<S, G, A>;\n}\n\n/**\n * Clear all store instances (useful for testing).\n */\nexport function clearStores(): void {\n storeInstances.clear();\n}\n\n/** @internal — exposes store registry for devtools */\nexport function __getStoreInstances(): Map<string, Store<any, any, any>> {\n return storeInstances;\n}\n"]}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/store.ts"],"names":["globalPlugins","configureStores","options","storeInstances","defineStore","id","definition","initialState","store","createStoreInstance","stateSignals","stateKeys","key","signal","getterFn","computed","plugins","actionFn","args","plugin","fresh","partial","value","snapshot","subscribers","subscribeEffect","callback","isInitial","effect","cb","clearStores","__getStoreInstances"],"mappings":"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","file":"chunk-A3VPGLBN.cjs","sourcesContent":["/**\n * Global state management via defineStore().\n *\n * Stores are singleton signal containers that persist across\n * components. They provide shared state, computed getters,\n * and actions — no external library needed.\n *\n * ```ts\n * const useCounterStore = defineStore('counter', {\n * state: () => ({ count: 0, name: 'Counter' }),\n * getters: {\n * doubled: (state) => state.count() * 2,\n * },\n * actions: {\n * increment() { this.count.update(c => c + 1); },\n * reset() { this.count.set(0); },\n * },\n * });\n *\n * // In any component:\n * const store = useCounterStore();\n * store.count(); // 0\n * store.doubled(); // 0\n * store.increment();\n * store.count(); // 1\n * ```\n */\n\nimport { signal, computed, effect } from './signals.js';\nimport type { Signal, ReadonlySignal } from './signals.js';\n\n// --- Types ---\n\ntype StateFactory<S> = () => S;\n\ntype Getters<S, G> = {\n [K in keyof G]: (state: SignalifiedState<S>) => G[K];\n};\n\ntype Actions<A> = {\n [K in keyof A]: A[K] extends (...args: infer P) => infer R\n ? (...args: P) => R\n : never;\n};\n\n/** Maps plain state values to signals */\ntype SignalifiedState<S> = {\n [K in keyof S]: Signal<S[K]>;\n};\n\n/** The store instance returned to consumers */\nexport type Store<S, G, A> = SignalifiedState<S> & {\n [K in keyof G]: ReadonlySignal<G[K]>;\n} & {\n [K in keyof A]: A[K] extends (...args: infer P) => infer R\n ? (...args: P) => R\n : never;\n} & {\n /** Reset all state to initial values */\n $reset(): void;\n /** Merge partial state into the store */\n $patch(partial: Partial<S>): void;\n /** Subscribe to all state changes */\n $subscribe(callback: (state: S) => void): () => void;\n /** Get a plain snapshot of current state */\n $snapshot(): S;\n /** Store ID */\n $id: string;\n};\n\nexport interface StoreDefinition<S, G, A> {\n state: StateFactory<S>;\n getters?: Getters<S, G>;\n actions?: A;\n plugins?: StorePlugin[];\n}\n\n// --- Plugin system ---\n\nexport interface StorePlugin {\n init?(store: Store<any, any, any>): void;\n onAction?(store: Store<any, any, any>, actionName: string, args: unknown[]): void;\n}\n\nconst globalPlugins: StorePlugin[] = [];\n\n/** Register global plugins that apply to all stores */\nexport function configureStores(options: { plugins: StorePlugin[] }): void {\n globalPlugins.push(...options.plugins);\n}\n\n// --- Store registry (singleton) ---\n\nconst storeInstances = new Map<string, Store<any, any, any>>();\n\n// --- defineStore ---\n\n/**\n * Define a global store. Returns a composable function that\n * always returns the same store instance (singleton).\n */\nexport function defineStore<\n S extends Record<string, unknown>,\n G extends Record<string, unknown> = {},\n A extends Record<string, (...args: any[]) => any> = {},\n>(\n id: string,\n definition: StoreDefinition<S, G, A>,\n): () => Store<S, G, A> {\n return () => {\n // Return existing instance if already created\n if (storeInstances.has(id)) {\n return storeInstances.get(id) as Store<S, G, A>;\n }\n\n const initialState = definition.state();\n const store = createStoreInstance(id, initialState, definition);\n storeInstances.set(id, store);\n return store;\n };\n}\n\nfunction createStoreInstance<\n S extends Record<string, unknown>,\n G extends Record<string, unknown>,\n A extends Record<string, (...args: any[]) => any>,\n>(\n id: string,\n initialState: S,\n definition: StoreDefinition<S, G, A>,\n): Store<S, G, A> {\n // Create signals for each state property\n const stateSignals: Record<string, Signal<unknown>> = {};\n const stateKeys = Object.keys(initialState);\n\n for (const key of stateKeys) {\n stateSignals[key] = signal(initialState[key]);\n }\n\n // Build the store object first so getters can reference other getters via `this`\n const store: any = { $id: id };\n\n // Add state signals\n for (const key of stateKeys) {\n store[key] = stateSignals[key];\n }\n\n // Create computed getters — bound to store so `this.otherGetter()` works\n if (definition.getters) {\n for (const [key, getterFn] of Object.entries(definition.getters)) {\n store[key] = computed(() =>\n (getterFn as Function).call(store, stateSignals),\n );\n }\n }\n\n // Collect all plugins (global + per-store)\n const plugins = [...globalPlugins, ...(definition.plugins ?? [])];\n\n // Bind actions with `this` pointing to the full store (state + getters + actions)\n if (definition.actions) {\n for (const [key, actionFn] of Object.entries(definition.actions)) {\n store[key] = (...args: unknown[]) => {\n for (const plugin of plugins) plugin.onAction?.(store, key, args);\n return (actionFn as Function).apply(store, args);\n };\n }\n }\n\n // $reset\n store.$reset = () => {\n const fresh = definition.state();\n for (const key of stateKeys) {\n stateSignals[key].set(fresh[key as keyof S]);\n }\n };\n\n // $patch — merge partial state\n store.$patch = (partial: Partial<S>) => {\n for (const [key, value] of Object.entries(partial)) {\n if (key in stateSignals) {\n stateSignals[key].set(value);\n }\n }\n };\n\n // $snapshot\n store.$snapshot = (): S => {\n const snapshot: Record<string, unknown> = {};\n for (const key of stateKeys) {\n snapshot[key] = stateSignals[key]();\n }\n return snapshot as S;\n };\n\n // $subscribe — watch all state signals and notify on change\n const subscribers = new Set<(state: S) => void>();\n let subscribeEffect: (() => void) | null = null;\n store.$subscribe = (callback: (state: S) => void): (() => void) => {\n subscribers.add(callback);\n // Start watching if this is the first subscriber\n if (!subscribeEffect) {\n let isInitial = true;\n subscribeEffect = effect(() => {\n // Read all state signals to track them\n for (const key of stateKeys) {\n stateSignals[key]();\n }\n // Skip initial run — only notify on actual changes\n if (isInitial) {\n isInitial = false;\n return;\n }\n const snapshot = store.$snapshot();\n for (const cb of subscribers) {\n cb(snapshot);\n }\n });\n }\n return () => {\n subscribers.delete(callback);\n // Dispose effect when no subscribers remain\n if (subscribers.size === 0 && subscribeEffect) {\n subscribeEffect();\n subscribeEffect = null;\n }\n };\n };\n\n // Initialize plugins\n for (const plugin of plugins) plugin.init?.(store);\n\n return store as Store<S, G, A>;\n}\n\n/**\n * Clear all store instances (useful for testing).\n */\nexport function clearStores(): void {\n storeInstances.clear();\n}\n\n/** @internal — exposes store registry for devtools */\nexport function __getStoreInstances(): Map<string, Store<any, any, any>> {\n return storeInstances;\n}\n"]}
|
package/dist/chunk-TS5UKZTG.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
import {l,m}from'./chunk-TWA4T6PX.js';function p(t){let n=l(t.initial),o=l(t.context??{}),C=l([t.initial]),g=m(()=>t.states[n()]?.type==="final"),v=m(()=>{let e=t.states[n()];return e?.on?Object.keys(e.on):[]}),u=t.states[t.initial];u?.entry&&u.entry({data:o(),event:""});function y(e){if(g())return;let T=n(),a=t.states[T];if(!a?.on)return;let i=a.on[e];if(!i)return;let s,d,l;if(typeof i=="string")s=i;else {let r=i;s=r.target,d=r.guard,l=r.action;}let x={data:o(),event:e};if(d&&!d(x))return;a.exit&&a.exit(x),l&&l(x),o.set(x.data),n.set(s),C.update(r=>[...r,s]);let S=t.states[s];S?.entry&&S.entry({data:o(),event:e});}function E(e){let T=t.states[n()];if(!T?.on)return false;let a=T.on[e];if(!a)return false;if(typeof a!="string"){let i=a;if(i.guard)return i.guard({data:o(),event:e})}return true}return {state:()=>n(),context:()=>o(),send:y,matches:e=>n()===e,done:g,reset(){n.set(t.initial),o.set(t.context??{}),C.set([t.initial]);},history:()=>C(),can:E,nextEvents:v}}export{p as a};//# sourceMappingURL=chunk-TS5UKZTG.js.map
|
|
2
|
-
//# sourceMappingURL=chunk-TS5UKZTG.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/machine.ts"],"names":["createMachine","config","currentState","signal","contextData","stateHistory","done","computed","nextEvents","stateCfg","initialStateCfg","send","event","state","transition","target","guard","action","t","ctx","h","targetCfg","can"],"mappings":"sCAgGO,SAASA,CAAAA,CAIdC,CAAAA,CAAoF,CACpF,IAAMC,EAAeC,CAAAA,CAAeF,CAAAA,CAAO,OAAO,CAAA,CAC5CG,CAAAA,CAAcD,CAAAA,CAAkBF,CAAAA,CAAO,OAAA,EAAW,EAAe,CAAA,CACjEI,CAAAA,CAAeF,CAAAA,CAAiB,CAACF,CAAAA,CAAO,OAAO,CAAC,EAEhDK,CAAAA,CAAOC,CAAAA,CAAS,IACHN,CAAAA,CAAO,OAAOC,CAAAA,EAAc,CAAA,EAC5B,IAAA,GAAS,OAC3B,CAAA,CAEKM,CAAAA,CAAaD,CAAAA,CAAS,IAAgB,CAC1C,IAAME,CAAAA,CAAWR,CAAAA,CAAO,OAAOC,CAAAA,EAAc,CAAA,CAC7C,OAAKO,GAAU,EAAA,CACR,MAAA,CAAO,IAAA,CAAKA,CAAAA,CAAS,EAAE,CAAA,CADJ,EAE5B,CAAC,CAAA,CAGKC,CAAAA,CAAkBT,CAAAA,CAAO,MAAA,CAAOA,EAAO,OAAO,CAAA,CAChDS,CAAAA,EAAiB,KAAA,EACnBA,EAAgB,KAAA,CAAM,CAAE,IAAA,CAAMN,CAAAA,GAA2B,KAAA,CAAO,EAAG,CAAC,CAAA,CAGtE,SAASO,CAAAA,CAAKC,CAAAA,CAAqB,CACjC,GAAIN,CAAAA,EAAK,CAAG,OAEZ,IAAMO,CAAAA,CAAQX,CAAAA,EAAa,CACrBO,CAAAA,CAAWR,EAAO,MAAA,CAAOY,CAAK,CAAA,CACpC,GAAI,CAACJ,CAAAA,EAAU,EAAA,CAAI,OAEnB,IAAMK,CAAAA,CAAaL,CAAAA,CAAS,EAAA,CAAGG,CAAK,EACpC,GAAI,CAACE,CAAAA,CAAY,OAEjB,IAAIC,CAAAA,CACAC,CAAAA,CACAC,CAAAA,CAEJ,GAAI,OAAOH,CAAAA,EAAe,QAAA,CACxBC,CAAAA,CAASD,OACJ,CACL,IAAMI,CAAAA,CAAIJ,CAAAA,CACVC,EAASG,CAAAA,CAAE,MAAA,CACXF,CAAAA,CAAQE,CAAAA,CAAE,MACVD,CAAAA,CAASC,CAAAA,CAAE,OACb,CAEA,IAAMC,CAAAA,CAAgC,CACpC,IAAA,CAAMf,GAAY,CAClB,KAAA,CAAAQ,CACF,CAAA,CAGA,GAAII,CAAAA,EAAS,CAACA,CAAAA,CAAMG,CAAG,EAAG,OAGtBV,CAAAA,CAAS,IAAA,EACXA,CAAAA,CAAS,IAAA,CAAKU,CAAG,CAAA,CAIfF,CAAAA,EACFA,EAAOE,CAAG,CAAA,CAIZf,CAAAA,CAAY,GAAA,CAAIe,CAAAA,CAAI,IAAI,CAAA,CAGxBjB,CAAAA,CAAa,IAAIa,CAAM,CAAA,CACvBV,CAAAA,CAAa,MAAA,CAAQe,CAAAA,EAAM,CAAC,GAAGA,CAAAA,CAAGL,CAAM,CAAC,CAAA,CAGzC,IAAMM,CAAAA,CAAYpB,EAAO,MAAA,CAAOc,CAAM,CAAA,CAClCM,CAAAA,EAAW,OACbA,CAAAA,CAAU,KAAA,CAAM,CAAE,IAAA,CAAMjB,CAAAA,EAAY,CAAe,KAAA,CAAAQ,CAAM,CAAC,EAE9D,CAEA,SAASU,CAAAA,CAAIV,EAAwB,CACnC,IAAMH,CAAAA,CAAWR,CAAAA,CAAO,OAAOC,CAAAA,EAAc,CAAA,CAC7C,GAAI,CAACO,CAAAA,EAAU,EAAA,CAAI,OAAO,OAC1B,IAAMK,CAAAA,CAAaL,CAAAA,CAAS,EAAA,CAAGG,CAAK,CAAA,CACpC,GAAI,CAACE,CAAAA,CAAY,OAAO,MAAA,CAExB,GAAI,OAAOA,CAAAA,EAAe,QAAA,CAAU,CAClC,IAAMI,CAAAA,CAAIJ,EACV,GAAII,CAAAA,CAAE,KAAA,CACJ,OAAOA,EAAE,KAAA,CAAM,CAAE,IAAA,CAAMd,CAAAA,GAA2B,KAAA,CAAAQ,CAAM,CAAC,CAE7D,CACA,OAAO,KACT,CAEA,OAAO,CACL,KAAA,CAAO,IAAMV,CAAAA,GACb,OAAA,CAAS,IAAME,CAAAA,EAAY,CAC3B,KAAAO,CAAAA,CACA,OAAA,CAAUE,CAAAA,EAAkBX,CAAAA,EAAa,GAAMW,CAAAA,CAC/C,IAAA,CAAAP,CAAAA,CACA,OAAQ,CACNJ,CAAAA,CAAa,GAAA,CAAID,CAAAA,CAAO,OAAO,CAAA,CAC/BG,CAAAA,CAAY,GAAA,CAAKH,CAAAA,CAAO,SAAW,EAAe,CAAA,CAClDI,CAAAA,CAAa,GAAA,CAAI,CAACJ,CAAAA,CAAO,OAAO,CAAC,EACnC,CAAA,CACA,OAAA,CAAS,IAAMI,GAAa,CAC5B,GAAA,CAAAiB,CAAAA,CACA,UAAA,CAAAd,CACF,CACF","file":"chunk-TS5UKZTG.js","sourcesContent":["/**\n * State machines for complex UI flows.\n *\n * Finite state machines with typed states, events, guards,\n * actions, and reactive current state signal.\n *\n * ```ts\n * const checkout = createMachine({\n * initial: 'cart',\n * states: {\n * cart: { on: { CHECKOUT: 'shipping' } },\n * shipping: { on: { NEXT: 'payment', BACK: 'cart' } },\n * payment: { on: { PAY: 'processing', BACK: 'shipping' } },\n * processing: { on: { SUCCESS: 'complete', FAIL: 'payment' } },\n * complete: { type: 'final' },\n * },\n * });\n *\n * checkout.state(); // 'cart'\n * checkout.send('CHECKOUT');\n * checkout.state(); // 'shipping'\n * checkout.matches('shipping'); // true\n * ```\n */\n\nimport { signal, computed } from './signals.js';\nimport type { ReadonlySignal } from './signals.js';\n\n// =========================================================================\n// Types\n// =========================================================================\n\nexport interface MachineConfig<TState extends string, TEvent extends string, TContext = unknown> {\n /** Initial state */\n initial: TState;\n /** Initial context data */\n context?: TContext;\n /** State definitions */\n states: Record<TState, StateConfig<TState, TEvent, TContext>>;\n}\n\nexport interface StateConfig<TState extends string, TEvent extends string, TContext = unknown> {\n /** Transitions: event → target state */\n on?: Partial<Record<TEvent, TState | TransitionConfig<TState, TEvent, TContext>>>;\n /** Entry action — runs when entering this state */\n entry?: (ctx: MachineContext<TContext>) => void;\n /** Exit action — runs when leaving this state */\n exit?: (ctx: MachineContext<TContext>) => void;\n /** Final state — machine stops accepting events */\n type?: 'final';\n}\n\nexport interface TransitionConfig<TState extends string, TEvent extends string, TContext = unknown> {\n /** Target state */\n target: TState;\n /** Guard — transition only if this returns true */\n guard?: (ctx: MachineContext<TContext>) => boolean;\n /** Action — runs during the transition */\n action?: (ctx: MachineContext<TContext>) => void;\n}\n\nexport interface MachineContext<TContext> {\n /** The context data (mutable) */\n data: TContext;\n /** The current event that triggered the transition */\n event: string;\n}\n\nexport interface Machine<TState extends string, TEvent extends string, TContext = unknown> {\n /** Current state (reactive signal) */\n state: ReadonlySignal<TState>;\n /** Context data (reactive signal) */\n context: ReadonlySignal<TContext>;\n /** Send an event to the machine */\n send(event: TEvent, payload?: Record<string, unknown>): void;\n /** Check if currently in a specific state */\n matches(state: TState): boolean;\n /** Whether the machine is in a final state */\n done: ReadonlySignal<boolean>;\n /** Reset to initial state */\n reset(): void;\n /** State history */\n history: ReadonlySignal<TState[]>;\n /** Can a specific event be sent in the current state? */\n can(event: TEvent): boolean;\n /** Get all possible events from current state */\n nextEvents: ReadonlySignal<TEvent[]>;\n}\n\n// =========================================================================\n// createMachine\n// =========================================================================\n\n/**\n * Create a finite state machine.\n */\nexport function createMachine<\n TState extends string,\n TEvent extends string,\n TContext = unknown,\n>(config: MachineConfig<TState, TEvent, TContext>): Machine<TState, TEvent, TContext> {\n const currentState = signal<TState>(config.initial);\n const contextData = signal<TContext>((config.context ?? {}) as TContext);\n const stateHistory = signal<TState[]>([config.initial]);\n\n const done = computed(() => {\n const stateCfg = config.states[currentState()];\n return stateCfg?.type === 'final';\n });\n\n const nextEvents = computed((): TEvent[] => {\n const stateCfg = config.states[currentState()];\n if (!stateCfg?.on) return [];\n return Object.keys(stateCfg.on) as TEvent[];\n });\n\n // Run entry action for initial state\n const initialStateCfg = config.states[config.initial];\n if (initialStateCfg?.entry) {\n initialStateCfg.entry({ data: contextData() as TContext, event: '' });\n }\n\n function send(event: TEvent): void {\n if (done()) return; // Final state — no more transitions\n\n const state = currentState();\n const stateCfg = config.states[state];\n if (!stateCfg?.on) return;\n\n const transition = stateCfg.on[event];\n if (!transition) return;\n\n let target: TState;\n let guard: ((ctx: MachineContext<TContext>) => boolean) | undefined;\n let action: ((ctx: MachineContext<TContext>) => void) | undefined;\n\n if (typeof transition === 'string') {\n target = transition;\n } else {\n const t = transition as TransitionConfig<TState, TEvent, TContext>;\n target = t.target;\n guard = t.guard;\n action = t.action;\n }\n\n const ctx: MachineContext<TContext> = {\n data: contextData() as TContext,\n event,\n };\n\n // Check guard\n if (guard && !guard(ctx)) return;\n\n // Exit action\n if (stateCfg.exit) {\n stateCfg.exit(ctx);\n }\n\n // Transition action\n if (action) {\n action(ctx);\n }\n\n // Update context if modified\n contextData.set(ctx.data);\n\n // Enter new state\n currentState.set(target);\n stateHistory.update((h) => [...h, target]);\n\n // Entry action for new state\n const targetCfg = config.states[target];\n if (targetCfg?.entry) {\n targetCfg.entry({ data: contextData() as TContext, event });\n }\n }\n\n function can(event: TEvent): boolean {\n const stateCfg = config.states[currentState()];\n if (!stateCfg?.on) return false;\n const transition = stateCfg.on[event];\n if (!transition) return false;\n\n if (typeof transition !== 'string') {\n const t = transition as TransitionConfig<TState, TEvent, TContext>;\n if (t.guard) {\n return t.guard({ data: contextData() as TContext, event });\n }\n }\n return true;\n }\n\n return {\n state: () => currentState(),\n context: () => contextData(),\n send,\n matches: (state: TState) => currentState() === state,\n done,\n reset() {\n currentState.set(config.initial);\n contextData.set((config.context ?? {}) as TContext);\n stateHistory.set([config.initial]);\n },\n history: () => stateHistory(),\n can,\n nextEvents,\n };\n}\n"]}
|
package/dist/chunk-VBAO65QP.cjs
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
'use strict';var chunkRTJ6UDGV_cjs=require('./chunk-RTJ6UDGV.cjs');function p(t){let n=chunkRTJ6UDGV_cjs.l(t.initial),o=chunkRTJ6UDGV_cjs.l(t.context??{}),C=chunkRTJ6UDGV_cjs.l([t.initial]),g=chunkRTJ6UDGV_cjs.m(()=>t.states[n()]?.type==="final"),v=chunkRTJ6UDGV_cjs.m(()=>{let e=t.states[n()];return e?.on?Object.keys(e.on):[]}),u=t.states[t.initial];u?.entry&&u.entry({data:o(),event:""});function y(e){if(g())return;let T=n(),a=t.states[T];if(!a?.on)return;let i=a.on[e];if(!i)return;let s,d,l;if(typeof i=="string")s=i;else {let r=i;s=r.target,d=r.guard,l=r.action;}let x={data:o(),event:e};if(d&&!d(x))return;a.exit&&a.exit(x),l&&l(x),o.set(x.data),n.set(s),C.update(r=>[...r,s]);let S=t.states[s];S?.entry&&S.entry({data:o(),event:e});}function E(e){let T=t.states[n()];if(!T?.on)return false;let a=T.on[e];if(!a)return false;if(typeof a!="string"){let i=a;if(i.guard)return i.guard({data:o(),event:e})}return true}return {state:()=>n(),context:()=>o(),send:y,matches:e=>n()===e,done:g,reset(){n.set(t.initial),o.set(t.context??{}),C.set([t.initial]);},history:()=>C(),can:E,nextEvents:v}}exports.a=p;//# sourceMappingURL=chunk-VBAO65QP.cjs.map
|
|
2
|
-
//# sourceMappingURL=chunk-VBAO65QP.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/machine.ts"],"names":["createMachine","config","currentState","signal","contextData","stateHistory","done","computed","nextEvents","stateCfg","initialStateCfg","send","event","state","transition","target","guard","action","t","ctx","h","targetCfg","can"],"mappings":"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","file":"chunk-VBAO65QP.cjs","sourcesContent":["/**\n * State machines for complex UI flows.\n *\n * Finite state machines with typed states, events, guards,\n * actions, and reactive current state signal.\n *\n * ```ts\n * const checkout = createMachine({\n * initial: 'cart',\n * states: {\n * cart: { on: { CHECKOUT: 'shipping' } },\n * shipping: { on: { NEXT: 'payment', BACK: 'cart' } },\n * payment: { on: { PAY: 'processing', BACK: 'shipping' } },\n * processing: { on: { SUCCESS: 'complete', FAIL: 'payment' } },\n * complete: { type: 'final' },\n * },\n * });\n *\n * checkout.state(); // 'cart'\n * checkout.send('CHECKOUT');\n * checkout.state(); // 'shipping'\n * checkout.matches('shipping'); // true\n * ```\n */\n\nimport { signal, computed } from './signals.js';\nimport type { ReadonlySignal } from './signals.js';\n\n// =========================================================================\n// Types\n// =========================================================================\n\nexport interface MachineConfig<TState extends string, TEvent extends string, TContext = unknown> {\n /** Initial state */\n initial: TState;\n /** Initial context data */\n context?: TContext;\n /** State definitions */\n states: Record<TState, StateConfig<TState, TEvent, TContext>>;\n}\n\nexport interface StateConfig<TState extends string, TEvent extends string, TContext = unknown> {\n /** Transitions: event → target state */\n on?: Partial<Record<TEvent, TState | TransitionConfig<TState, TEvent, TContext>>>;\n /** Entry action — runs when entering this state */\n entry?: (ctx: MachineContext<TContext>) => void;\n /** Exit action — runs when leaving this state */\n exit?: (ctx: MachineContext<TContext>) => void;\n /** Final state — machine stops accepting events */\n type?: 'final';\n}\n\nexport interface TransitionConfig<TState extends string, TEvent extends string, TContext = unknown> {\n /** Target state */\n target: TState;\n /** Guard — transition only if this returns true */\n guard?: (ctx: MachineContext<TContext>) => boolean;\n /** Action — runs during the transition */\n action?: (ctx: MachineContext<TContext>) => void;\n}\n\nexport interface MachineContext<TContext> {\n /** The context data (mutable) */\n data: TContext;\n /** The current event that triggered the transition */\n event: string;\n}\n\nexport interface Machine<TState extends string, TEvent extends string, TContext = unknown> {\n /** Current state (reactive signal) */\n state: ReadonlySignal<TState>;\n /** Context data (reactive signal) */\n context: ReadonlySignal<TContext>;\n /** Send an event to the machine */\n send(event: TEvent, payload?: Record<string, unknown>): void;\n /** Check if currently in a specific state */\n matches(state: TState): boolean;\n /** Whether the machine is in a final state */\n done: ReadonlySignal<boolean>;\n /** Reset to initial state */\n reset(): void;\n /** State history */\n history: ReadonlySignal<TState[]>;\n /** Can a specific event be sent in the current state? */\n can(event: TEvent): boolean;\n /** Get all possible events from current state */\n nextEvents: ReadonlySignal<TEvent[]>;\n}\n\n// =========================================================================\n// createMachine\n// =========================================================================\n\n/**\n * Create a finite state machine.\n */\nexport function createMachine<\n TState extends string,\n TEvent extends string,\n TContext = unknown,\n>(config: MachineConfig<TState, TEvent, TContext>): Machine<TState, TEvent, TContext> {\n const currentState = signal<TState>(config.initial);\n const contextData = signal<TContext>((config.context ?? {}) as TContext);\n const stateHistory = signal<TState[]>([config.initial]);\n\n const done = computed(() => {\n const stateCfg = config.states[currentState()];\n return stateCfg?.type === 'final';\n });\n\n const nextEvents = computed((): TEvent[] => {\n const stateCfg = config.states[currentState()];\n if (!stateCfg?.on) return [];\n return Object.keys(stateCfg.on) as TEvent[];\n });\n\n // Run entry action for initial state\n const initialStateCfg = config.states[config.initial];\n if (initialStateCfg?.entry) {\n initialStateCfg.entry({ data: contextData() as TContext, event: '' });\n }\n\n function send(event: TEvent): void {\n if (done()) return; // Final state — no more transitions\n\n const state = currentState();\n const stateCfg = config.states[state];\n if (!stateCfg?.on) return;\n\n const transition = stateCfg.on[event];\n if (!transition) return;\n\n let target: TState;\n let guard: ((ctx: MachineContext<TContext>) => boolean) | undefined;\n let action: ((ctx: MachineContext<TContext>) => void) | undefined;\n\n if (typeof transition === 'string') {\n target = transition;\n } else {\n const t = transition as TransitionConfig<TState, TEvent, TContext>;\n target = t.target;\n guard = t.guard;\n action = t.action;\n }\n\n const ctx: MachineContext<TContext> = {\n data: contextData() as TContext,\n event,\n };\n\n // Check guard\n if (guard && !guard(ctx)) return;\n\n // Exit action\n if (stateCfg.exit) {\n stateCfg.exit(ctx);\n }\n\n // Transition action\n if (action) {\n action(ctx);\n }\n\n // Update context if modified\n contextData.set(ctx.data);\n\n // Enter new state\n currentState.set(target);\n stateHistory.update((h) => [...h, target]);\n\n // Entry action for new state\n const targetCfg = config.states[target];\n if (targetCfg?.entry) {\n targetCfg.entry({ data: contextData() as TContext, event });\n }\n }\n\n function can(event: TEvent): boolean {\n const stateCfg = config.states[currentState()];\n if (!stateCfg?.on) return false;\n const transition = stateCfg.on[event];\n if (!transition) return false;\n\n if (typeof transition !== 'string') {\n const t = transition as TransitionConfig<TState, TEvent, TContext>;\n if (t.guard) {\n return t.guard({ data: contextData() as TContext, event });\n }\n }\n return true;\n }\n\n return {\n state: () => currentState(),\n context: () => contextData(),\n send,\n matches: (state: TState) => currentState() === state,\n done,\n reset() {\n currentState.set(config.initial);\n contextData.set((config.context ?? {}) as TContext);\n stateHistory.set([config.initial]);\n },\n history: () => stateHistory(),\n can,\n nextEvents,\n };\n}\n"]}
|