mirror of
https://github.com/streamich/react-use.git
synced 2026-01-18 14:06:52 +00:00
18 lines
478 B
TypeScript
18 lines
478 B
TypeScript
import { useCallback, useState } from 'react';
|
|
|
|
const useSetState = <T extends object>(
|
|
initialState: T = {} as T
|
|
): [T, (patch: Partial<T> | ((prevState: T) => Partial<T>)) => void] => {
|
|
const [state, set] = useState<T>(initialState);
|
|
const setState = useCallback(
|
|
patch => {
|
|
set(prevState => Object.assign({}, prevState, patch instanceof Function ? patch(prevState) : patch));
|
|
},
|
|
[set]
|
|
);
|
|
|
|
return [state, setState];
|
|
};
|
|
|
|
export default useSetState;
|