react-use/src/useSetState.ts
xobotyi 9577d63ec2 editorconfig:
- typescript rules separated from others;
- more alignment rules;
2019-08-24 01:57:29 +03:00

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;