17 lines
512 B
JavaScript
17 lines
512 B
JavaScript
import { useReducer } from 'react';
|
|
function reducer(state, action) {
|
|
switch (action.type) {
|
|
case 'RESOLVE':
|
|
return { value: action.value, error: undefined };
|
|
case 'REJECT':
|
|
return { value: false, error: action.error };
|
|
case 'RESET':
|
|
return { value: undefined, error: undefined };
|
|
default:
|
|
return state;
|
|
}
|
|
}
|
|
export default function useResolver() {
|
|
return useReducer((reducer), { value: undefined, error: undefined });
|
|
}
|