atomic-state
Advanced tools
Comparing version 2.7.6 to 2.7.7
export { AtomicState } from './server'; | ||
export type { ActionType, ActionsObjectType, Atom, PersistenceStoreType, useAtomType } from './mod'; | ||
export { atom, atomProvider, stateProvider, storage, takeSnapshot, useActions, useAtom, useValueAndActions, useDispatch, useStorage, useStorageItem, useValue, session, createAtomicHook, createPersistence, setAtom, getActions } from './mod'; | ||
export { atom, atomProvider, stateProvider, storage, takeSnapshot, useActions, useAtom, useValueAndActions, useDispatch, useStorage, useStorageItem, useValue, session, createAtomicHook, createPersistence, setAtom, getActions, createStore } from './mod'; | ||
export { getAtomValue, getAtom, getValue } from './store'; |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.getValue = exports.getAtom = exports.getAtomValue = exports.getActions = exports.setAtom = exports.createPersistence = exports.createAtomicHook = exports.session = exports.useValue = exports.useStorageItem = exports.useStorage = exports.useDispatch = exports.useValueAndActions = exports.useAtom = exports.useActions = exports.takeSnapshot = exports.storage = exports.stateProvider = exports.atomProvider = exports.atom = exports.AtomicState = void 0; | ||
exports.getValue = exports.getAtom = exports.getAtomValue = exports.createStore = exports.getActions = exports.setAtom = exports.createPersistence = exports.createAtomicHook = exports.session = exports.useValue = exports.useStorageItem = exports.useStorage = exports.useDispatch = exports.useValueAndActions = exports.useAtom = exports.useActions = exports.takeSnapshot = exports.storage = exports.stateProvider = exports.atomProvider = exports.atom = exports.AtomicState = void 0; | ||
var server_1 = require("./server"); | ||
@@ -24,2 +24,3 @@ Object.defineProperty(exports, "AtomicState", { enumerable: true, get: function () { return server_1.AtomicState; } }); | ||
Object.defineProperty(exports, "getActions", { enumerable: true, get: function () { return mod_1.getActions; } }); | ||
Object.defineProperty(exports, "createStore", { enumerable: true, get: function () { return mod_1.createStore; } }); | ||
var store_1 = require("./store"); | ||
@@ -26,0 +27,0 @@ Object.defineProperty(exports, "getAtomValue", { enumerable: true, get: function () { return store_1.getAtomValue; } }); |
@@ -8,3 +8,3 @@ /** @license Atomic State | ||
import { Dispatch, SetStateAction } from 'react'; | ||
declare type Observable = { | ||
type Observable = { | ||
addListener(event: string, listener?: any): void; | ||
@@ -14,3 +14,3 @@ removeListener(event: string, listener?: any): void; | ||
}; | ||
export declare type ActionType<Args, T = any> = (args: { | ||
export type ActionType<Args, T = any> = (args: { | ||
args: Args; | ||
@@ -23,3 +23,3 @@ state: T; | ||
*/ | ||
export declare type Atom<T = any, ActionArgs = any> = { | ||
export type Atom<T = any, ActionArgs = any> = { | ||
/** | ||
@@ -63,10 +63,10 @@ * @deprecated Use `key` instead | ||
}; | ||
export declare type ActionsObjectType<ArgsTypes = any> = { | ||
export type ActionsObjectType<ArgsTypes = any> = { | ||
[E in keyof ArgsTypes]: <Returns = any>(args?: ArgsTypes[E]) => Returns; | ||
}; | ||
export declare type useAtomType<R, ActionsArgs = any> = () => (R | Dispatch<SetStateAction<R>> | ActionsObjectType<ActionsArgs>)[]; | ||
export type useAtomType<R, ActionsArgs = any> = () => (R | Dispatch<SetStateAction<R>> | ActionsObjectType<ActionsArgs>)[]; | ||
/** | ||
* Type for the `get` function of filters | ||
*/ | ||
export declare type SelectorGet = { | ||
export type SelectorGet = { | ||
get<R>(atom: useAtomType<R> | Atom<R, any>): R; | ||
@@ -77,3 +77,3 @@ }; | ||
*/ | ||
export declare type ActionGet = { | ||
export type ActionGet = { | ||
get<R>(atom: useAtomType<R> | Atom<R, any>, storeName?: string | boolean): R; | ||
@@ -84,3 +84,3 @@ }; | ||
*/ | ||
export declare type Selector<T = any> = { | ||
export type Selector<T = any> = { | ||
/** | ||
@@ -98,6 +98,6 @@ * @deprecated Use `key` instead | ||
}; | ||
declare type PersistenceGet = (key: string) => any; | ||
declare type PersistenceSet = (key: string, value: any) => void; | ||
declare type PersistenceRemove = (key: string) => void; | ||
export declare type PersistenceStoreType = { | ||
type PersistenceGet = (key: string) => any; | ||
type PersistenceSet = (key: string, value: any) => void; | ||
type PersistenceRemove = (key: string) => void; | ||
export type PersistenceStoreType = { | ||
get?: PersistenceGet; | ||
@@ -157,3 +157,3 @@ getItem?: PersistenceGet; | ||
/** | ||
* Creates a store with the `setPartialvalue`, `replace` and `setValue` methods. | ||
* Creates a store with the `setPartialvalue`, `setValue` and `reset` methods. | ||
* It returns a hook that returns an array with the value and the actions | ||
@@ -178,2 +178,13 @@ */ | ||
/** | ||
* Creates a store with the `setPartialvalue`, `setValue` and `reset` methods. | ||
* It uses `createAtomicHook` under the hood but instead of returing an array, it returns an object with the store value and actions merged | ||
*/ | ||
export declare function createStore<R>(config?: Partial<Atom<R>>): () => R & ActionsObjectType<{ | ||
setPartialvalue: Partial<R> | ((v: Required<R>) => Partial<R>); | ||
setValue: R | ((v: Required<R>) => R); | ||
reset: any; | ||
} & { | ||
[key: string]: any; | ||
}>; | ||
/** | ||
* Get an atom's value | ||
@@ -186,3 +197,3 @@ */ | ||
*/ | ||
export declare function useDispatch<R>(atom: useAtomType<R> | Atom<R, any>): (cb: R | ((c: R) => R)) => void; | ||
export declare function useDispatch<R>(atom: useAtomType<R> | Atom<R, any>): (cb: ((c: R) => R) | R) => void; | ||
export declare const useAtomDispatch: typeof useDispatch; | ||
@@ -189,0 +200,0 @@ /** |
export { AtomicState } from '../mod'; |
@@ -0,0 +0,0 @@ 'use client'; |
@@ -0,0 +0,0 @@ import { Atom, Selector } from './mod'; |
@@ -0,0 +0,0 @@ "use strict"; |
{ | ||
"name": "atomic-state", | ||
"version": "2.7.6", | ||
"version": "2.7.7", | ||
"description": "Atomic State is a state management library for React", | ||
@@ -25,15 +25,16 @@ "main": "dist/index.js", | ||
"devDependencies": { | ||
"@babel/preset-env": "^7.15.8", | ||
"@babel/preset-react": "^7.14.5", | ||
"@testing-library/react": "^12.1.2", | ||
"@types/jest": "^27.0.2", | ||
"@types/react": "^18.0.27", | ||
"@types/react-dom": "^18.0.10", | ||
"babel-jest": "27.2.5", | ||
"jest": "27.2.5", | ||
"react": ">=16.13.1", | ||
"react-dom": ">=16.13.1", | ||
"react-test-renderer": "17.0.2", | ||
"ts-jest": "27.0.5", | ||
"typescript": "4.4.4" | ||
"@babel/preset-env": "^7.24.4", | ||
"@babel/preset-react": "^7.24.1", | ||
"@testing-library/react": "^15.0.2", | ||
"@types/jest": "^29.5.12", | ||
"@types/react": "^18.2.79", | ||
"@types/react-dom": "^18.2.25", | ||
"babel-jest": "^29.7.0", | ||
"jest": "^29.7.0", | ||
"jest-environment-jsdom": "^29.7.0", | ||
"react": "^18.2.0", | ||
"react-dom": "^18.2.0", | ||
"react-test-renderer": "^18.2.0", | ||
"ts-jest": "^29.1.2", | ||
"typescript": "^5.4.5" | ||
}, | ||
@@ -43,4 +44,3 @@ "peerDependencies": { | ||
"react-dom": ">=16.13.1" | ||
}, | ||
"dependencies": {} | ||
} | ||
} |
@@ -0,0 +0,0 @@ <h1> |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
1881
711407
14