init
This commit is contained in:
commit
ec53fcbe95
1905 changed files with 513762 additions and 0 deletions
34
state/store.ts
Normal file
34
state/store.ts
Normal file
|
|
@ -0,0 +1,34 @@
|
|||
type Listener = () => void
|
||||
type OnChange<T> = (args: { newState: T; oldState: T }) => void
|
||||
|
||||
export type Store<T> = {
|
||||
getState: () => T
|
||||
setState: (updater: (prev: T) => T) => void
|
||||
subscribe: (listener: Listener) => () => void
|
||||
}
|
||||
|
||||
export function createStore<T>(
|
||||
initialState: T,
|
||||
onChange?: OnChange<T>,
|
||||
): Store<T> {
|
||||
let state = initialState
|
||||
const listeners = new Set<Listener>()
|
||||
|
||||
return {
|
||||
getState: () => state,
|
||||
|
||||
setState: (updater: (prev: T) => T) => {
|
||||
const prev = state
|
||||
const next = updater(prev)
|
||||
if (Object.is(next, prev)) return
|
||||
state = next
|
||||
onChange?.({ newState: next, oldState: prev })
|
||||
for (const listener of listeners) listener()
|
||||
},
|
||||
|
||||
subscribe: (listener: Listener) => {
|
||||
listeners.add(listener)
|
||||
return () => listeners.delete(listener)
|
||||
},
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue