-
Notifications
You must be signed in to change notification settings - Fork 176
Expand file tree
/
Copy pathuse-paystack.ts
More file actions
71 lines (66 loc) · 1.62 KB
/
use-paystack.ts
File metadata and controls
71 lines (66 loc) · 1.62 KB
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
import {useEffect} from 'react';
import {callback, PaystackProps} from './types';
import usePaystackScript from './paystack-script';
import {callPaystackPop} from './paystack-actions';
export default function usePaystackPayment(
options: PaystackProps,
): (callback?: callback, onClose?: callback) => void {
const [scriptLoaded, scriptError] = usePaystackScript();
const {
publicKey,
firstname,
lastname,
phone,
email,
amount,
reference,
metadata = {},
currency = 'NGN',
channels,
label = '',
plan = '',
quantity = '',
subaccount = '',
transaction_charge = 0,
bearer = 'account',
split,
split_code,
} = options;
function initializePayment(callback?: callback, onClose?: callback): void {
if (scriptError) {
throw new Error('Unable to load paystack inline script');
}
if (scriptLoaded) {
const paystackArgs: Record<string, any> = {
callback: callback ? callback : () => null,
onClose: onClose ? onClose : () => null,
key: publicKey,
ref: reference,
email,
firstname,
lastname,
phone,
amount,
currency,
plan,
quantity,
'data-custom-button': options['data-custom-button'] || '',
channels,
subaccount,
transaction_charge,
bearer,
label,
metadata,
split,
split_code,
};
callPaystackPop(paystackArgs);
}
}
useEffect(() => {
if (scriptError) {
throw new Error('Unable to load paystack inline script');
}
}, [scriptError]);
return initializePayment;
}