forked from CSFrequency/react-firebase-hooks
-
Notifications
You must be signed in to change notification settings - Fork 0
/
useSendEmailVerification.ts
40 lines (36 loc) · 996 Bytes
/
useSendEmailVerification.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
import {
Auth,
AuthError,
sendEmailVerification as fbSendEmailVerification,
} from 'firebase/auth';
import { useMemo, useState } from 'react';
export type SendEmailVerificationHook = [
() => Promise<void>,
boolean,
AuthError | Error | undefined
];
export default (auth: Auth): SendEmailVerificationHook => {
const [error, setError] = useState<AuthError>();
const [loading, setLoading] = useState<boolean>(false);
const sendEmailVerification = async () => {
setLoading(true);
setError(undefined);
try {
if (auth.currentUser) {
await fbSendEmailVerification(auth.currentUser);
} else {
setError(new Error('No user is logged in') as AuthError);
}
} catch (err) {
setError(err as AuthError);
} finally {
setLoading(false);
}
};
const resArray: SendEmailVerificationHook = [
sendEmailVerification,
loading,
error,
];
return useMemo<SendEmailVerificationHook>(() => resArray, resArray);
};