| 15 | import {useEffectEvent} from './useEffectEvent'; |
| 16 | |
| 17 | export function useFormReset<T>( |
| 18 | ref: RefObject<HTMLInputElement | HTMLTextAreaElement | HTMLSelectElement | null> | undefined, |
| 19 | initialValue: T, |
| 20 | onReset: (value: T) => void |
| 21 | ): void { |
| 22 | let handleReset = useEffectEvent((e: Event) => { |
| 23 | if (onReset && !e.defaultPrevented) { |
| 24 | onReset(initialValue); |
| 25 | } |
| 26 | }); |
| 27 | |
| 28 | useEffect(() => { |
| 29 | let form = ref?.current?.form; |
| 30 | |
| 31 | form?.addEventListener('reset', handleReset); |
| 32 | return () => { |
| 33 | form?.removeEventListener('reset', handleReset); |
| 34 | }; |
| 35 | }, [ref]); |
| 36 | } |