@devloops/react-native-variant
Version:
react-native material ui library
24 lines (20 loc) • 535 B
Flow
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;