-
Notifications
You must be signed in to change notification settings - Fork 0
/
AsyncAlert.tsx
104 lines (92 loc) · 2.28 KB
/
AsyncAlert.tsx
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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import React, {useRef} from 'react';
import {useState} from 'react';
import {Text} from 'react-native';
import {DefAlert} from './DefAlert';
import {ShowAlertTypes, UseAlertProps, UseAlertReturnType} from './index';
const useAlert = ({
renderAlert,
}: {
renderAlert: UseAlertProps['renderAlert'];
}): UseAlertReturnType => {
const [visible, setVisible] = useState(false);
const [resolveFn, setResolveFn] = useState<((value: boolean) => void) | null>(
null,
);
const [title, setTitle] = useState('');
const [text, setText] = useState('');
const [alertData, setAlertData] = useState<object | null>(null);
const [hideCancel, setHideCancel] = useState(false);
const onUserEvent = useRef<(event: any) => void>();
const showAlert = ({
title,
text,
alertData,
onEvent,
hideCancel,
}: ShowAlertTypes): Promise<boolean> => {
if (onEvent) {
onUserEvent.current = onEvent;
}
if (!renderAlert && alertData) {
console.warn(
'There is no need to provide alert data while not providing the custom alert in the provider',
);
}
if (alertData && !!renderAlert) {
setAlertData(alertData);
}
setTitle(title ?? '');
setText(text ?? '');
setHideCancel(!!hideCancel);
setVisible(true);
return new Promise<boolean>(resolve => {
setResolveFn(() => resolve);
});
};
const resetStates = () => {
setVisible(false);
setTitle('');
setText('');
setAlertData(null);
setHideCancel(false);
};
const onPressCancel = (): void => {
resetStates();
if (resolveFn) {
resolveFn(false);
}
};
const onPressOk = (): void => {
resetStates();
if (resolveFn) {
resolveFn(true);
}
};
const AlertComp: React.FC = () =>
renderAlert ? (
renderAlert({
alertData,
visible,
hideCancel,
text,
title,
onEvent: onUserEvent.current,
onPressCancel,
onPressOk,
})
) : (
<DefAlert
title={title}
renderBody={() => <Text style={{color: 'black'}}>{text}</Text>}
onClose={onPressCancel}
onOk={onPressOk}
isAlertVisible={!!visible}
hideCancel={hideCancel}
/>
);
return {
showAlert,
AlertComp,
};
};
export default useAlert;