@opexa/portal-components 0.0.1006 → 0.0.1008
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/client/hooks/useVerifyMobileNumber.d.ts +3 -0
- package/dist/client/hooks/useVerifyMobileNumber.js +20 -0
- package/dist/components/DepositWithdrawal/Deposit/AurixPayPayMayaDeposit/AurixPayGrabPayDeposit.d.ts +1 -0
- package/dist/components/DepositWithdrawal/Deposit/AurixPayPayMayaDeposit/AurixPayGrabPayDeposit.js +241 -0
- package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/OnlineBankDepositContext.d.ts +4 -4
- package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/useOnlineBankDeposit.d.ts +2 -2
- package/dist/components/KYC/KYCAccountVerificationRequired.lazy.js +2 -2
- package/dist/components/KYC/KYCReview.js +5 -2
- package/dist/components/Messages/Messages.lazy.js +13 -1
- package/dist/components/SignUp/SignUpDefault/SignUpDefault.lazy.d.ts +1 -0
- package/dist/components/SignUp/SignUpDefault/SignUpDefaultForm.js +8 -1
- package/dist/components/SingleSignOn/SingleSignOn.d.ts +4 -0
- package/dist/components/SingleSignOn/SingleSignOn.js +185 -0
- package/dist/components/SingleSignOn/index.d.ts +1 -0
- package/dist/components/SingleSignOn/index.js +1 -0
- package/dist/lib/components/UpdateMobilePhoneNumber/UpdateMobilePhoneNumber.d.ts +1 -0
- package/dist/lib/components/UpdateMobilePhoneNumber/UpdateMobilePhoneNumber.js +152 -0
- package/dist/lib/components/UpdateMobilePhoneNumber/index.d.ts +1 -0
- package/dist/lib/components/UpdateMobilePhoneNumber/index.js +1 -0
- package/dist/schemas/forgotPasswordSchema.d.ts +4 -4
- package/dist/ui/AlertDialog/AlertDialog.d.ts +121 -121
- package/dist/ui/AlertDialog/alertDialog.recipe.d.ts +11 -11
- package/dist/ui/Badge/Badge.d.ts +12 -12
- package/dist/ui/Badge/badge.anatomy.d.ts +1 -1
- package/dist/ui/Badge/badge.recipe.d.ts +3 -3
- package/dist/ui/Carousel/Carousel.d.ts +99 -99
- package/dist/ui/Carousel/carousel.recipe.d.ts +11 -11
- package/dist/ui/Checkbox/Checkbox.d.ts +23 -23
- package/dist/ui/Checkbox/checkbox.recipe.d.ts +3 -3
- package/dist/ui/Clipboard/Clipboard.d.ts +18 -18
- package/dist/ui/Clipboard/clipboard.recipe.d.ts +3 -3
- package/dist/ui/Combobox/Combobox.d.ts +42 -42
- package/dist/ui/Combobox/combobox.recipe.d.ts +3 -3
- package/dist/ui/DatePicker/DatePicker.d.ts +72 -72
- package/dist/ui/DatePicker/datePicker.recipe.d.ts +3 -3
- package/dist/ui/Dialog/Dialog.d.ts +33 -33
- package/dist/ui/Dialog/dialog.recipe.d.ts +3 -3
- package/dist/ui/Drawer/Drawer.d.ts +33 -33
- package/dist/ui/Drawer/drawer.recipe.d.ts +3 -3
- package/dist/ui/Menu/Menu.d.ts +90 -90
- package/dist/ui/Menu/menu.recipe.d.ts +5 -5
- package/dist/ui/SegmentGroup/SegmentGroup.d.ts +18 -18
- package/dist/ui/SegmentGroup/segmentGroup.recipe.d.ts +3 -3
- package/dist/ui/Select/Select.d.ts +45 -45
- package/dist/ui/Select/select.recipe.d.ts +3 -3
- package/dist/ui/Table/Table.d.ts +21 -21
- package/dist/ui/Table/table.anatomy.d.ts +1 -1
- package/dist/ui/Table/table.recipe.d.ts +3 -3
- package/package.json +1 -1
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { useMutation } from '@tanstack/react-query';
|
|
2
|
+
import invariant from 'tiny-invariant';
|
|
3
|
+
import { verifyMobileNumber, } from '../../services/account.js';
|
|
4
|
+
import { getVerifyMobileNumberMutationKey } from '../../utils/mutationKeys.js';
|
|
5
|
+
import { getSession } from '../services/getSession.js';
|
|
6
|
+
export const useVerifyMobileNumber = (config) => {
|
|
7
|
+
return useMutation({
|
|
8
|
+
...config,
|
|
9
|
+
mutationKey: getVerifyMobileNumberMutationKey(),
|
|
10
|
+
mutationFn: async (input) => {
|
|
11
|
+
const session = await getSession();
|
|
12
|
+
invariant(session.status === 'authenticated');
|
|
13
|
+
await verifyMobileNumber(input.verificationCode, {
|
|
14
|
+
headers: {
|
|
15
|
+
Authorization: `Bearer ${session.token}`,
|
|
16
|
+
},
|
|
17
|
+
});
|
|
18
|
+
},
|
|
19
|
+
});
|
|
20
|
+
};
|
package/dist/components/DepositWithdrawal/Deposit/AurixPayPayMayaDeposit/AurixPayGrabPayDeposit.d.ts
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function AurixPayGrabPayDeposit(): import("react/jsx-runtime").JSX.Element;
|
package/dist/components/DepositWithdrawal/Deposit/AurixPayPayMayaDeposit/AurixPayGrabPayDeposit.js
ADDED
|
@@ -0,0 +1,241 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { zodResolver } from '@hookform/resolvers/zod';
|
|
3
|
+
import { ObjectId } from '@opexa/object-id';
|
|
4
|
+
import Link from 'next/link';
|
|
5
|
+
import { useEffect, useState } from 'react';
|
|
6
|
+
import { Controller, useForm } from 'react-hook-form';
|
|
7
|
+
import invariant from 'tiny-invariant';
|
|
8
|
+
import { useBoolean } from 'usehooks-ts';
|
|
9
|
+
import { z } from 'zod';
|
|
10
|
+
import { useShallow } from 'zustand/shallow';
|
|
11
|
+
import { useAvailablePromosQuery } from '../../../../client/hooks/useAvailablePromosQuery.js';
|
|
12
|
+
import { useCreateAurixPayGrabPayDepositMutation } from '../../../../client/hooks/useCreateAurixPayGrabPayDepositMutation.js';
|
|
13
|
+
import { useDepositQuery } from '../../../../client/hooks/useDepositQuery.js';
|
|
14
|
+
import { useDepositsCountQuery } from '../../../../client/hooks/useDepositsCountQuery.js';
|
|
15
|
+
import { useDisclosure } from '../../../../client/hooks/useDisclosure.js';
|
|
16
|
+
import { useGlobalStore } from '../../../../client/hooks/useGlobalStore.js';
|
|
17
|
+
import { useMemberVerificationQuery } from '../../../../client/hooks/useMemberVerificationQuery.js';
|
|
18
|
+
import { usePaymentSettingsQuery } from '../../../../client/hooks/usePaymentSettingsQuery.js';
|
|
19
|
+
import { AlertCircleIcon } from '../../../../icons/AlertCircleIcon.js';
|
|
20
|
+
import { ChevronDownIcon } from '../../../../icons/ChevronDownIcon.js';
|
|
21
|
+
import { ChevronUpIcon } from '../../../../icons/ChevronUpIcon.js';
|
|
22
|
+
import { RefreshCcw01Icon } from '../../../../icons/RefreshCcw01Icon.js';
|
|
23
|
+
import { SpinnerIcon } from '../../../../icons/SpinnerIcon.js';
|
|
24
|
+
import { XIcon } from '../../../../icons/XIcon.js';
|
|
25
|
+
import { ObjectType } from '../../../../services/ObjectType.js';
|
|
26
|
+
import { AlertDialog } from '../../../../ui/AlertDialog/index.js';
|
|
27
|
+
import { Button } from '../../../../ui/Button/index.js';
|
|
28
|
+
import { Field } from '../../../../ui/Field/index.js';
|
|
29
|
+
import { NumberInput } from '../../../../ui/NumberInput/index.js';
|
|
30
|
+
import { Portal } from '../../../../ui/Portal/index.js';
|
|
31
|
+
import { getQueryClient } from '../../../../utils/getQueryClient.js';
|
|
32
|
+
import { parseDecimal } from '../../../../utils/parseDecimal.js';
|
|
33
|
+
import { getDepositsCountQueryKey } from '../../../../utils/queryKeys.js';
|
|
34
|
+
import { AmountChoices } from '../../AmountChoices.js';
|
|
35
|
+
import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
|
|
36
|
+
import { AvailablePromos } from '../AvailablePromos.js';
|
|
37
|
+
export function AurixPayGrabPayDeposit() {
|
|
38
|
+
const depositWithdrawalProps = useDepositWithdrawalPropsContext();
|
|
39
|
+
const disclosure = useDisclosure({
|
|
40
|
+
onOpenChange(open) {
|
|
41
|
+
if (!open) {
|
|
42
|
+
form.reset();
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
const globalStore = useGlobalStore(useShallow((ctx) => ({
|
|
47
|
+
depositWithdrawal: ctx.depositWithdrawal,
|
|
48
|
+
kycVerificationStatus: ctx.kycVerificationStatus,
|
|
49
|
+
})));
|
|
50
|
+
const verificationQuery = useMemberVerificationQuery();
|
|
51
|
+
const verificationStatus = verificationQuery.data?.status ?? 'UNVERIFIED';
|
|
52
|
+
const [status, setStatus] = useState('waiting');
|
|
53
|
+
const [errorMessage, setErrorMessage] = useState(null);
|
|
54
|
+
const createDepositMutation = useCreateAurixPayGrabPayDepositMutation({
|
|
55
|
+
onMutate() {
|
|
56
|
+
disclosure.setOpen(true);
|
|
57
|
+
setStatus('processing');
|
|
58
|
+
},
|
|
59
|
+
onSuccess(data) {
|
|
60
|
+
const queryClient = getQueryClient();
|
|
61
|
+
invariant(data.checkoutUrl);
|
|
62
|
+
window.open(data.checkoutUrl, '_blank', 'noopener,noreferrer');
|
|
63
|
+
queryClient.invalidateQueries({
|
|
64
|
+
queryKey: getDepositsCountQueryKey(),
|
|
65
|
+
});
|
|
66
|
+
setStatus('success');
|
|
67
|
+
},
|
|
68
|
+
onError(data) {
|
|
69
|
+
setStatus('failed');
|
|
70
|
+
setErrorMessage({
|
|
71
|
+
name: data.name,
|
|
72
|
+
message: data.message,
|
|
73
|
+
});
|
|
74
|
+
},
|
|
75
|
+
});
|
|
76
|
+
const warn = useBoolean();
|
|
77
|
+
const depositQuery = useDepositQuery(createDepositMutation.data?.id, {
|
|
78
|
+
enabled: !warn.value && status === 'success',
|
|
79
|
+
refetchInterval: (ctx) => ctx.state.data?.status === 'CONFIRMED' ||
|
|
80
|
+
ctx.state.data?.status === 'REJECTED' ||
|
|
81
|
+
ctx.state.data?.status === 'CANCELLED'
|
|
82
|
+
? false
|
|
83
|
+
: 1000,
|
|
84
|
+
});
|
|
85
|
+
useEffect(() => {
|
|
86
|
+
if (depositQuery.data?.status === 'CONFIRMED') {
|
|
87
|
+
setStatus('confirmed');
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
if (depositQuery.data?.status === 'REJECTED' ||
|
|
91
|
+
depositQuery.data?.status === 'CANCELLED') {
|
|
92
|
+
setStatus('failed');
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
}, [depositQuery.data?.status]);
|
|
96
|
+
const depositsCountQuery = useDepositsCountQuery();
|
|
97
|
+
const depositsCount = depositsCountQuery.data ?? 0;
|
|
98
|
+
const paymentSettingsQuery = usePaymentSettingsQuery();
|
|
99
|
+
const paymentSettings = paymentSettingsQuery.data;
|
|
100
|
+
const gatewaySettings = paymentSettings?.aioGCashDepositGatewaySettings;
|
|
101
|
+
const maximumAmount = parseDecimal(gatewaySettings?.maximumAmount, 0);
|
|
102
|
+
const minimumAmount = depositsCount <= 0
|
|
103
|
+
? parseDecimal(paymentSettingsQuery.data?.minimumFirstDepositAmount, 0)
|
|
104
|
+
: parseDecimal(gatewaySettings?.minimumAmount, 0);
|
|
105
|
+
const promosQuery = useAvailablePromosQuery();
|
|
106
|
+
const promos = promosQuery.data ?? [];
|
|
107
|
+
const definition = z
|
|
108
|
+
.object({
|
|
109
|
+
amount: z.string().superRefine((val, ctx) => {
|
|
110
|
+
const n = parseDecimal(val, 0);
|
|
111
|
+
if (n < minimumAmount) {
|
|
112
|
+
ctx.addIssue({
|
|
113
|
+
type: 'number',
|
|
114
|
+
code: z.ZodIssueCode.too_small,
|
|
115
|
+
inclusive: true,
|
|
116
|
+
minimum: minimumAmount,
|
|
117
|
+
message: `Please enter ${minimumAmount.toLocaleString()} or more to proceed with your deposit.`,
|
|
118
|
+
});
|
|
119
|
+
}
|
|
120
|
+
if (n > maximumAmount) {
|
|
121
|
+
ctx.addIssue({
|
|
122
|
+
type: 'number',
|
|
123
|
+
code: z.ZodIssueCode.too_big,
|
|
124
|
+
inclusive: true,
|
|
125
|
+
maximum: maximumAmount,
|
|
126
|
+
message: `Maximum amount is ${maximumAmount.toLocaleString()}`,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
}),
|
|
130
|
+
promo: z.string().optional().nullable(),
|
|
131
|
+
accountNumber: z
|
|
132
|
+
.string()
|
|
133
|
+
.min(1, 'Account number is required')
|
|
134
|
+
.min(8, 'Account number must be 8 or more characters')
|
|
135
|
+
.max(32, 'Account number must not be more than 32 characters'),
|
|
136
|
+
})
|
|
137
|
+
.superRefine((value, ctx) => {
|
|
138
|
+
const promo = promos.find((o) => o.id === value.promo);
|
|
139
|
+
const promoMinAmount = parseDecimal(promo?.minimumDepositAmount, 0);
|
|
140
|
+
const promoMaxAmount = parseDecimal(promo?.maximumDepositAmount, 0);
|
|
141
|
+
const amount = parseDecimal(value.amount, 0);
|
|
142
|
+
if (promo && amount < promoMinAmount) {
|
|
143
|
+
ctx.addIssue({
|
|
144
|
+
path: ['amount'],
|
|
145
|
+
code: z.ZodIssueCode.custom,
|
|
146
|
+
message: `Minimum amount for this promo is ${promoMinAmount.toLocaleString()}`,
|
|
147
|
+
});
|
|
148
|
+
}
|
|
149
|
+
if (promo && amount > promoMaxAmount) {
|
|
150
|
+
ctx.addIssue({
|
|
151
|
+
path: ['amount'],
|
|
152
|
+
code: z.ZodIssueCode.custom,
|
|
153
|
+
message: `Maximum amount for this promo is ${promoMaxAmount}`,
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
});
|
|
157
|
+
const form = useForm({
|
|
158
|
+
mode: 'all',
|
|
159
|
+
resolver: zodResolver(definition),
|
|
160
|
+
defaultValues: {
|
|
161
|
+
amount: '0',
|
|
162
|
+
promo: globalStore.depositWithdrawal.promo ?? null,
|
|
163
|
+
accountNumber: '',
|
|
164
|
+
},
|
|
165
|
+
});
|
|
166
|
+
useEffect(() => {
|
|
167
|
+
if (minimumAmount) {
|
|
168
|
+
form.reset({
|
|
169
|
+
amount: minimumAmount.toString(),
|
|
170
|
+
promo: form.getValues('promo') ?? null,
|
|
171
|
+
accountNumber: form.getValues('accountNumber') ?? '',
|
|
172
|
+
});
|
|
173
|
+
}
|
|
174
|
+
}, [form, minimumAmount]);
|
|
175
|
+
const redirectUrl = (() => {
|
|
176
|
+
const path = depositWithdrawalProps.depositSuccessPageUrl ?? '/deposits/:id/status';
|
|
177
|
+
const origin = window.location.origin.includes('localhost')
|
|
178
|
+
? 'https://uat.powerplay.ph' +
|
|
179
|
+
depositWithdrawalProps.depositSuccessPageUrl
|
|
180
|
+
: window.location.origin;
|
|
181
|
+
return `${origin}${path}`;
|
|
182
|
+
})();
|
|
183
|
+
return (_jsxs("form", { onSubmit: form.handleSubmit(async (data) => {
|
|
184
|
+
if (!depositWithdrawalProps.bypassDepositKycCheck &&
|
|
185
|
+
(verificationStatus === 'PENDING' ||
|
|
186
|
+
verificationStatus === 'UNVERIFIED' ||
|
|
187
|
+
verificationStatus === 'REJECTED' ||
|
|
188
|
+
verificationStatus === 'CREATED')) {
|
|
189
|
+
globalStore.kycVerificationStatus.setOpen(true);
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
else {
|
|
193
|
+
const id = ObjectId.generate(ObjectType.Deposit).toString();
|
|
194
|
+
createDepositMutation.reset();
|
|
195
|
+
createDepositMutation.mutate({
|
|
196
|
+
id,
|
|
197
|
+
amount: data.amount.toString(),
|
|
198
|
+
promo: data.promo ?? undefined,
|
|
199
|
+
redirectUrl: redirectUrl.replace(':id', id),
|
|
200
|
+
accountNumber: data.accountNumber,
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
}), noValidate: true, children: [_jsxs(Field.Root, { invalid: !!form.formState.errors.accountNumber, children: [_jsx(Field.Label, { children: "Account number" }), _jsx(Field.Input, { ...form.register('accountNumber') }), _jsx(Field.ErrorText, { children: form.formState.errors.accountNumber?.message })] }), _jsx(Controller, { control: form.control, name: "amount", render: (o) => (_jsxs(Field.Root, { invalid: !!form.formState.errors.amount, className: "mt-lg", children: [_jsxs(NumberInput.Root, { min: 0, step: 1, value: o.field.value, onValueChange: (details) => {
|
|
204
|
+
o.field.onChange(details.value);
|
|
205
|
+
}, allowMouseWheel: true, children: [_jsx(NumberInput.Label, { children: "Enter amount you want to deposit" }), _jsxs(NumberInput.Control, { children: [_jsx(NumberInput.Input, {}), _jsx(NumberInput.IncrementTrigger, { children: _jsx(ChevronUpIcon, {}) }), _jsx(NumberInput.DecrementTrigger, { children: _jsx(ChevronDownIcon, {}) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.amount?.message })] })) }), _jsx(AmountChoices, { value: parseDecimal(form.watch('amount'), 0), onChange: (value) => {
|
|
206
|
+
form.setValue('amount', value.toString(), {
|
|
207
|
+
shouldTouch: true,
|
|
208
|
+
shouldDirty: true,
|
|
209
|
+
shouldValidate: true,
|
|
210
|
+
});
|
|
211
|
+
}, min: minimumAmount, max: maximumAmount, className: "mt-lg" }), _jsx(Controller, { control: form.control, name: "promo", render: (o) => (_jsx(AvailablePromos, { value: o.field.value, onChange: (value) => {
|
|
212
|
+
o.field.onChange(value);
|
|
213
|
+
globalStore.depositWithdrawal.setPromo(null);
|
|
214
|
+
}, className: "mt-3xl" })) }), _jsx(Button, { type: "submit", className: "mt-3xl", disabled: createDepositMutation.isPending, children: "Deposit" }), _jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["By depositing, you agree to our", ' ', _jsx(Link, { href: depositWithdrawalProps.termsOfUseUrl ?? '/terms-of-use', onClick: () => globalStore.depositWithdrawal.setOpen(false), className: "text-text-warning-primary-600 underline underline-offset-2", children: "Terms of Use" }), ' ', "and", ' ', _jsx(Link, { href: depositWithdrawalProps.privacyPolicyUrl ?? '/privacy-policy', onClick: () => globalStore.depositWithdrawal.setOpen(false), className: "text-text-warning-primary-600 underline underline-offset-2", children: "Privacy Policy" }), "."] }), _jsx(AlertDialog.Root, { open: disclosure.open, onOpenChange: (details) => {
|
|
215
|
+
disclosure.setOpen(details.open);
|
|
216
|
+
}, lazyMount: true, unmountOnExit: true, closeOnEscape: false, closeOnInteractOutside: false, onExitComplete: () => {
|
|
217
|
+
setStatus('waiting');
|
|
218
|
+
setErrorMessage(null);
|
|
219
|
+
form.reset();
|
|
220
|
+
warn.setFalse();
|
|
221
|
+
}, children: _jsxs(Portal, { children: [_jsx(AlertDialog.Backdrop, { className: "!z-[calc(var(--z-dialog)+2)]" }), _jsx(AlertDialog.Positioner, { className: "!z-[calc(var(--z-dialog)+3)]", children: _jsxs(AlertDialog.Content, { children: [_jsx(AlertDialog.Context, { children: (api) => (_jsx("button", { type: "button", className: "absolute top-2.5 right-2.5 flex icon:size-6 size-11 items-center justify-center text-text-quinary", onClick: () => {
|
|
222
|
+
if (status === 'success' && !warn.value) {
|
|
223
|
+
warn.setTrue();
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
api.setOpen(false);
|
|
227
|
+
}
|
|
228
|
+
}, children: _jsx(XIcon, {}) })) }), _jsxs(AlertDialog.Header, { children: [status === 'processing' && (_jsx(SpinnerIcon, { className: "size-12 text-text-brand-primary-600" })), status === 'success' && !warn.value && (_jsx("div", { className: "flex size-12 items-center justify-center rounded-full bg-bg-brand-secondary text-text-featured-icon-light-brand", children: _jsx(RefreshCcw01Icon, {}) })), status === 'success' && warn.value && (_jsx("div", { className: "flex size-12 items-center justify-center rounded-full bg-bg-error-secondary text-text-featured-icon-light-error", children: _jsx(AlertCircleIcon, {}) })), status === 'confirmed' && (_jsx("div", { className: "flex size-12 items-center justify-center rounded-full bg-bg-success-secondary text-text-featured-icon-light-success", children: _jsx(AlertCircleIcon, {}) })), status === 'failed' && (_jsx("div", { className: "flex size-12 items-center justify-center rounded-full bg-bg-error-secondary text-text-featured-icon-light-error", children: _jsx(AlertCircleIcon, {}) }))] }), _jsxs(AlertDialog.Body, { children: [_jsxs(AlertDialog.Title, { children: [status === 'processing' && 'Processing Deposit', status === 'success' &&
|
|
229
|
+
!warn.value &&
|
|
230
|
+
'Didn’t see the payment window?', status === 'success' && warn.value && (_jsx(_Fragment, { children: "Are you sure you want to close this\u00A0window?" })), status === 'confirmed' && 'Deposit Successful', status === 'failed' && errorMessage?.name] }), _jsxs(AlertDialog.Description, { children: [status === 'processing' &&
|
|
231
|
+
"We're verifying your account and amount. Please hold a moment.", status === 'success' &&
|
|
232
|
+
!warn.value &&
|
|
233
|
+
'Sometimes the payment pop up doesn’t appear right away. Don’t worry, just click the button below to reopen it and continue your deposit.', status === 'success' &&
|
|
234
|
+
warn.value &&
|
|
235
|
+
'Closing this window might cancel your current deposit. Do you want to continue?', status === 'confirmed' &&
|
|
236
|
+
'Your deposit has been successfully processed.', status === 'failed' && errorMessage?.message] })] }), (status === 'failed' ||
|
|
237
|
+
status === 'success' ||
|
|
238
|
+
status === 'confirmed') && (_jsxs(AlertDialog.Footer, { children: [status === 'success' && !warn.value && (_jsx(Button, { asChild: true, children: _jsx("a", { href: createDepositMutation.data?.checkoutUrl ?? '', target: "_blank", rel: "noopener noreferrer", children: "Try Again" }) })), status === 'success' && warn.value && (_jsxs(_Fragment, { children: [_jsx(Button, { variant: "outline", onClick: () => {
|
|
239
|
+
warn.setFalse();
|
|
240
|
+
}, children: "Go back" }), _jsx(AlertDialog.Context, { children: (api) => (_jsx(Button, { onClick: () => api.setOpen(false), children: "Continue" })) })] })), status !== 'success' && (_jsx(AlertDialog.Context, { children: (api) => (_jsx(Button, { onClick: () => api.setOpen(false), children: "Ok" })) }))] }))] }) })] }) })] }));
|
|
241
|
+
}
|
package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/OnlineBankDepositContext.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export declare const OnlineBankDepositContext: (props: {
|
|
2
2
|
value: {
|
|
3
|
-
view: "
|
|
4
|
-
status: "
|
|
3
|
+
view: "form" | "vca";
|
|
4
|
+
status: "failed" | "waiting" | "processing" | "verification-waiting" | "verification-processing" | "verification-failed" | "verification-success";
|
|
5
5
|
verify: () => void;
|
|
6
6
|
reset: () => void;
|
|
7
7
|
deposit: import("../../../../types").Deposit | null;
|
|
@@ -13,8 +13,8 @@ export declare const OnlineBankDepositContext: (props: {
|
|
|
13
13
|
} & {
|
|
14
14
|
children?: import("react").ReactNode | undefined;
|
|
15
15
|
}) => React.ReactNode, useOnlineBankDepositContext: () => {
|
|
16
|
-
view: "
|
|
17
|
-
status: "
|
|
16
|
+
view: "form" | "vca";
|
|
17
|
+
status: "failed" | "waiting" | "processing" | "verification-waiting" | "verification-processing" | "verification-failed" | "verification-success";
|
|
18
18
|
verify: () => void;
|
|
19
19
|
reset: () => void;
|
|
20
20
|
deposit: import("../../../../types").Deposit | null;
|
package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/useOnlineBankDeposit.d.ts
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import type { Deposit } from '../../../../types';
|
|
2
2
|
export type UseOnlineBankDepositReturn = ReturnType<typeof useOnlineBankDeposit>;
|
|
3
3
|
export declare function useOnlineBankDeposit(): {
|
|
4
|
-
view: "
|
|
5
|
-
status: "
|
|
4
|
+
view: "form" | "vca";
|
|
5
|
+
status: "failed" | "waiting" | "processing" | "verification-waiting" | "verification-processing" | "verification-failed" | "verification-success";
|
|
6
6
|
verify: () => void;
|
|
7
7
|
reset: () => void;
|
|
8
8
|
deposit: Deposit | null;
|
|
@@ -20,9 +20,9 @@ function KYCAccountVerificationRequired_lazy() {
|
|
|
20
20
|
const isOpen = globalStore.kycVerificationRequired.open &&
|
|
21
21
|
!globalStore.disclaimer.open &&
|
|
22
22
|
!globalStore.termsOfUse.open;
|
|
23
|
-
return (_jsxs(Dialog.Root, { open: isOpen, closeOnEscape: false, closeOnInteractOutside: false, lazyMount: true, unmountOnExit: true, children: [_jsx(Dialog.Backdrop, { className: "z-[999]" }), _jsx(Dialog.Positioner, { className: "z-[999] flex items-center justify-center", children: _jsx(Dialog.Content, { className: "mx-auto h-fit max-w-[calc(100dvw-1rem)] overflow-y-auto rounded-lg bg-bg-primary lg:max-w-[400px]", children: _jsxs("div", { className: "p-3xl text-center", children: [_jsx("div", { className: "mx-auto w-fit rounded-full bg-bg-brand-secondary p-2", children: _jsx(FileX02Icon, { className: "text-shadow-text-brand" }) }), _jsx("h2", { className: "mt-4 font-semibold text-lg", children: "Account Verification Rejected!" }), _jsxs("p", { className: "mt-xs flex flex-col gap-4 text-sm", children: [_jsx("span", { className: "text-text-tertiary-600", children: "We're sorry, but your verification was rejected for the following reasons:" }), _jsxs("span", { children: [_jsxs("b", { children: [rejectionMessage?.title, ":"] }), _jsx("span", { className: "text-text-tertiary-600", dangerouslySetInnerHTML: {
|
|
23
|
+
return (_jsxs(Dialog.Root, { open: isOpen, closeOnEscape: false, closeOnInteractOutside: false, lazyMount: true, unmountOnExit: true, children: [_jsx(Dialog.Backdrop, { className: "z-[999]" }), _jsx(Dialog.Positioner, { className: "z-[999] flex items-center justify-center", children: _jsx(Dialog.Content, { className: "mx-auto h-fit max-w-[calc(100dvw-1rem)] overflow-y-auto rounded-lg bg-bg-primary lg:max-w-[400px]", children: _jsxs("div", { className: "p-3xl text-center", children: [_jsx("div", { className: "mx-auto w-fit rounded-full bg-bg-brand-secondary p-2", children: _jsx(FileX02Icon, { className: "text-shadow-text-brand" }) }), _jsx("h2", { className: "mt-4 font-semibold text-lg", children: "Account Verification Rejected!" }), _jsxs("p", { className: "mt-xs flex flex-col gap-4 text-sm", children: [_jsx("span", { className: "text-text-tertiary-600", children: "We're sorry, but your verification was rejected for the following reasons:" }), rejectionMessage?.title && rejectionMessage?.content ? (_jsxs("span", { children: [_jsxs("b", { children: [rejectionMessage?.title, ":"] }), _jsx("span", { className: "text-text-tertiary-600", dangerouslySetInnerHTML: {
|
|
24
24
|
__html: rejectionMessage?.content ?? '',
|
|
25
|
-
} })] })] }), _jsx(Button, { type: "button", className: "mt-lg", onClick: () => {
|
|
25
|
+
} })] })) : (_jsxs("div", { className: "flex flex-col gap-4 text-center text-text-tertiary-600", children: [_jsx("span", { children: "Missing Documents: Some required documents were not uploaded. Please ensure you provide all necessary files as outlined in our guidelines." }), _jsx("span", { children: "Unclear Images: The documents uploaded were blurry or not legible. Please re-upload clear, high-quality images where all text and details are visible." }), _jsx("span", { children: "To resolve this, double-check the document requirements and re-submit. If you're unsure about the guidelines or need further clarification, feel free to contact our support team for assistance. We're here to help!" })] }))] }), _jsx(Button, { type: "button", className: "mt-lg", onClick: () => {
|
|
26
26
|
globalStore.kycVerificationRequired.setOpen(false);
|
|
27
27
|
globalStore.kycReminder.setOpen(true);
|
|
28
28
|
}, children: "Ok" })] }) }) })] }));
|
|
@@ -3,6 +3,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
3
3
|
import Image from 'next/image';
|
|
4
4
|
import { useState } from 'react';
|
|
5
5
|
import { useShallow } from 'zustand/shallow';
|
|
6
|
+
import { useFeatureFlag } from '../../client/hooks/useFeatureFlag.js';
|
|
6
7
|
import { useGlobalStore } from '../../client/hooks/useGlobalStore.js';
|
|
7
8
|
import { getSession } from '../../client/services/getSession.js';
|
|
8
9
|
import { toaster } from '../../client/utils/toaster.js';
|
|
@@ -15,7 +16,9 @@ import { Portal } from '../../ui/Portal/index.js';
|
|
|
15
16
|
export function KYCReview() {
|
|
16
17
|
const { kycReview } = useGlobalStore(useShallow((s) => ({ kycReview: s.kycReview })));
|
|
17
18
|
const [isLoading, setIsLoading] = useState(false);
|
|
18
|
-
|
|
19
|
+
const featureFlag = useFeatureFlag();
|
|
20
|
+
const isDialogOpen = kycReview.open && featureFlag.enabled;
|
|
21
|
+
return (_jsx(Dialog.Root, { open: isDialogOpen, lazyMount: true, unmountOnExit: true, closeOnEscape: false, closeOnInteractOutside: false, children: _jsxs(Portal, { children: [_jsx(Dialog.Backdrop, {}), _jsx(Dialog.Positioner, { className: "flex items-center", children: _jsxs(Dialog.Content, { className: "flex w-[375px] flex-col items-center justify-between space-y-4 rounded-lg bg-[#232443] p-6 text-center", children: [_jsxs("div", { className: "flex flex-col items-center", children: [_jsx("div", { className: "mb-4 h-7 w-7 animate-spin rounded-full border-4 border-[#101730] border-t-[#F05027]" }), _jsx("div", { className: "font-semibold text-[#F5F5F6] text-lg", children: "Thanks for your submission." }), _jsxs("div", { className: "mt-1 text-[#CECFD2] text-sm", children: ["We\u2019re now ", '', _jsxs("span", { className: "text-[#F96B47]", children: ["reviewing your KYC information ", ''] }), "and will notify you once the verification is complete."] }), _jsx("div", { className: "mt-6 text-[#CECFD2] text-sm", children: "In the meantime, you can watch your favorite series on CinePop!" })] }), _jsxs("div", { className: "pt-3", children: [_jsx(Image, { src: cinePopLogo, alt: "cine poplogo", width: 151, height: 24, className: "mx-auto mb-2 h-auto w-[151px]" }), _jsxs("div", { className: "flex gap-2", children: [_jsx(Image, { src: secretConfessionsLogo, alt: "secret confessions logo", width: 104, height: 53, className: "h-auto w-[104px]" }), _jsx(Image, { src: dearUtolLogo, alt: "dear utol logo", width: 105, height: 53, className: "h-auto w-[105px]" }), _jsx(Image, { src: mariasDiary, alt: "maria's diary logo", width: 104, height: 53, className: "h-auto w-[104px]" })] })] }), _jsx("button", { disabled: isLoading, type: "button", className: "h-[44px] w-full rounded-md font-semibold", style: {
|
|
19
22
|
background: 'linear-gradient(90deg, #9333E8 0%, #D92778 100%)',
|
|
20
23
|
}, onClick: async () => {
|
|
21
24
|
const session = await getSession();
|
|
@@ -29,7 +32,7 @@ export function KYCReview() {
|
|
|
29
32
|
'Content-Type': 'application/json',
|
|
30
33
|
},
|
|
31
34
|
});
|
|
32
|
-
const data = await response.json();
|
|
35
|
+
const data = (await response.json());
|
|
33
36
|
window.open(data.data.redirectionUrl, '_blank');
|
|
34
37
|
}
|
|
35
38
|
catch {
|
|
@@ -11,6 +11,7 @@ import { useGlobalStore } from '../../client/hooks/useGlobalStore.js';
|
|
|
11
11
|
import { useLocaleInfo } from '../../client/hooks/useLocaleInfo.js';
|
|
12
12
|
import { useMarkAllMessagesAsReadMutation } from '../../client/hooks/useMarkAllMessagesAsReadMutation.js';
|
|
13
13
|
import { useMarkMessageAsReadMutation } from '../../client/hooks/useMarkMessageAsReadMutation.js';
|
|
14
|
+
import { useMemberVerificationQuery } from '../../client/hooks/useMemberVerificationQuery.js';
|
|
14
15
|
import { useMessagesQuery } from '../../client/hooks/useMessagesQuery.js';
|
|
15
16
|
import { useSessionQuery } from '../../client/hooks/useSessionQuery.js';
|
|
16
17
|
import { useUnreadMessagesCountQuery } from '../../client/hooks/useUnreadMessagesCountQuery.js';
|
|
@@ -90,11 +91,16 @@ function Message() {
|
|
|
90
91
|
}, children: action.name }, index))) }))] }));
|
|
91
92
|
}
|
|
92
93
|
export function MessageDetails() {
|
|
94
|
+
const memberVerificationQuery = useMemberVerificationQuery();
|
|
95
|
+
const completed = memberVerificationQuery.data?.status === 'VERIFIED' ||
|
|
96
|
+
memberVerificationQuery.data?.status === 'PENDING' ||
|
|
97
|
+
memberVerificationQuery.data?.status === 'APPROVED';
|
|
93
98
|
const messagesProps = useMessagesPropsContext();
|
|
94
99
|
const questsPageUrl = messagesProps.questsPageUrl ?? '/quests';
|
|
95
100
|
const transactionsPageUrl = messagesProps.transactionsPageUrl ?? '/transactions';
|
|
96
101
|
const globalStore = useGlobalStore(useShallow((ctx) => ({
|
|
97
102
|
message: ctx.message,
|
|
103
|
+
kyc: ctx.kyc,
|
|
98
104
|
})));
|
|
99
105
|
const message = globalStore.message.data;
|
|
100
106
|
const transformContent = (content) => {
|
|
@@ -119,5 +125,11 @@ export function MessageDetails() {
|
|
|
119
125
|
}), onClick: (e) => {
|
|
120
126
|
e.stopPropagation();
|
|
121
127
|
globalStore.message.setOpen(false);
|
|
122
|
-
}, children: action.name }) }, index))) })) : null
|
|
128
|
+
}, children: action.name }) }, index))) })) : null, message?.type === 'MEMBER_VERIFICATION_REJECTION' &&
|
|
129
|
+
!memberVerificationQuery.isLoading &&
|
|
130
|
+
!completed && (_jsx(Button, { onClick: (e) => {
|
|
131
|
+
e.stopPropagation();
|
|
132
|
+
globalStore.message.setOpen(false);
|
|
133
|
+
globalStore.kyc.setOpen(true);
|
|
134
|
+
}, children: "Resubmit KYC Documents" }))] }) })] }) }));
|
|
123
135
|
}
|
|
@@ -22,5 +22,6 @@ export interface SignUpDefaultProps {
|
|
|
22
22
|
responsibleGamingLogo?: ImageProps['src'];
|
|
23
23
|
isRegulated?: boolean;
|
|
24
24
|
variant?: string;
|
|
25
|
+
showEmailAddressField?: boolean;
|
|
25
26
|
}
|
|
26
27
|
export declare function SignUpDefault(props: SignUpDefaultProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -97,6 +97,10 @@ export function SignUpDefaultForm() {
|
|
|
97
97
|
});
|
|
98
98
|
}
|
|
99
99
|
});
|
|
100
|
+
const emailAddressBaseSchema = z
|
|
101
|
+
.string()
|
|
102
|
+
.min(1, 'Email address is required')
|
|
103
|
+
.email('Invalid email address');
|
|
100
104
|
const Step1Definition = z.object({
|
|
101
105
|
mobileNumber: z
|
|
102
106
|
.string()
|
|
@@ -126,6 +130,9 @@ export function SignUpDefaultForm() {
|
|
|
126
130
|
birthDay: signUpProps.basicSignUp
|
|
127
131
|
? z.date().optional()
|
|
128
132
|
: birthdateBaseSchema,
|
|
133
|
+
emailAddress: signUpProps.showEmailAddressField
|
|
134
|
+
? emailAddressBaseSchema
|
|
135
|
+
: z.string().optional(),
|
|
129
136
|
branchCode: !signUpProps.basicSignUp && (signUpProps?.branches ?? []).length > 0
|
|
130
137
|
? z.string().min(1, 'Branch is required').trim()
|
|
131
138
|
: z.string().optional(),
|
|
@@ -212,7 +219,7 @@ export function SignUpDefaultForm() {
|
|
|
212
219
|
});
|
|
213
220
|
}, onBlur: () => {
|
|
214
221
|
step1Form.trigger('birthDay');
|
|
215
|
-
} }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.birthDay?.message })] }), signUpProps.branches && (_jsxs(Field.Root, { invalid: !!step1Form.formState.errors.branchCode, className: "mt-xl", children: [_jsxs(Select.Root, { value: [branchCode ?? ''], onValueChange: (details) => {
|
|
222
|
+
} }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.birthDay?.message })] }), signUpProps.showEmailAddressField && (_jsxs(Field.Root, { invalid: !!step1Form.formState.errors.emailAddress, className: "mt-xl", children: [_jsx(Field.Label, { children: "Email Address" }), _jsx(Field.Input, { placeholder: "Enter your email address", ...step1Form.register('emailAddress') }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.emailAddress?.message })] })), signUpProps.branches && (_jsxs(Field.Root, { invalid: !!step1Form.formState.errors.branchCode, className: "mt-xl", children: [_jsxs(Select.Root, { value: [branchCode ?? ''], onValueChange: (details) => {
|
|
216
223
|
step1Form.setValue('branchCode', details.value?.[0], {
|
|
217
224
|
shouldDirty: true,
|
|
218
225
|
shouldTouch: true,
|