From ae730e83984cbf4dc804eebbf260a055bfe635c0 Mon Sep 17 00:00:00 2001 From: TymanWasTaken Date: Mon, 17 Oct 2022 10:05:22 -0600 Subject: Add pronoundb plugin (#104) --- src/utils/misc.tsx | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) (limited to 'src/utils') diff --git a/src/utils/misc.tsx b/src/utils/misc.tsx index f6ea36c..66ea202 100644 --- a/src/utils/misc.tsx +++ b/src/utils/misc.tsx @@ -30,10 +30,11 @@ export function lazyWebpack(filter: FilterFn): T { */ export function useAwaiter(factory: () => Promise): [T | null, any, boolean]; export function useAwaiter(factory: () => Promise, fallbackValue: T): [T, any, boolean]; -export function useAwaiter(factory: () => Promise, fallbackValue: T | null = null): [T | null, any, boolean] { +export function useAwaiter(factory: () => Promise, fallbackValue: null, onError: (e: unknown) => unknown): [T, any, boolean]; +export function useAwaiter(factory: () => Promise, fallbackValue: T | null = null, onError?: (e: unknown) => unknown): [T | null, any, boolean] { const [state, setState] = React.useState({ value: fallbackValue, - error: null as any, + error: null, pending: true }); @@ -41,7 +42,7 @@ export function useAwaiter(factory: () => Promise, fallbackValue: T | null let isAlive = true; factory() .then(value => isAlive && setState({ value, error: null, pending: false })) - .catch(error => isAlive && setState({ value: null, error, pending: false })); + .catch(error => isAlive && (setState({ value: null, error, pending: false }), onError?.(error))); return () => void (isAlive = false); }, []); -- cgit