( effect: () => AsyncGenerator<void, void, void> | Promise<void>, deps?: DependencyList, )
| 9 | } |
| 10 | |
| 11 | function useAsyncEffect( |
| 12 | effect: () => AsyncGenerator<void, void, void> | Promise<void>, |
| 13 | deps?: DependencyList, |
| 14 | ) { |
| 15 | useEffect(() => { |
| 16 | const e = effect(); |
| 17 | let cancelled = false; |
| 18 | async function execute() { |
| 19 | if (isAsyncGenerator(e)) { |
| 20 | while (true) { |
| 21 | const result = await e.next(); |
| 22 | if (result.done || cancelled) { |
| 23 | break; |
| 24 | } |
| 25 | } |
| 26 | } else { |
| 27 | await e; |
| 28 | } |
| 29 | } |
| 30 | execute(); |
| 31 | return () => { |
| 32 | cancelled = true; |
| 33 | }; |
| 34 | }, deps); |
| 35 | } |
| 36 | |
| 37 | export default useAsyncEffect; |
no test coverage detected
searching dependent graphs…