@opexa/portal-components 0.0.752 → 0.0.753

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.
Files changed (194) hide show
  1. package/dist/client/hooks/useRequireFirstDepositQuery.d.ts +2 -0
  2. package/dist/client/hooks/useRequireFirstDepositQuery.js +31 -0
  3. package/dist/components/AccountInfo/GoogleDisconnect.d.ts +7 -0
  4. package/dist/components/AccountInfo/GoogleDisconnect.js +11 -0
  5. package/dist/components/DepositWithdrawal/Deposit/GCashWebpayDeposit /GCashWebpayDeposit .d.ts +1 -0
  6. package/dist/components/DepositWithdrawal/Deposit/GCashWebpayDeposit /GCashWebpayDeposit .js +191 -0
  7. package/dist/components/DepositWithdrawal/Withdrawal/GCashStandardCashInWithdrawal/GCashStandardCashInWithdrawal.js +2 -1
  8. package/dist/components/DepositWithdrawal/Withdrawal/GCashWithdrawal/GCashWithdrawal.js +2 -1
  9. package/dist/components/DepositWithdrawal/Withdrawal/InstapayWithdrawal/InstapayWithdrawal.js +2 -1
  10. package/dist/components/DepositWithdrawal/Withdrawal/MayaAppWithdrawal/MayaAppWithdrawal.js +2 -1
  11. package/dist/components/DepositWithdrawal/Withdrawal/MayaWithdrawal/MayaWithdrawal.js +2 -1
  12. package/dist/components/DepositWithdrawal/Withdrawal/PisoPayWithdrawal/PisoPayWithdrawal.js +2 -1
  13. package/dist/components/DepositWithdrawal/Withdrawal/RequireFirstDeposit.d.ts +1 -0
  14. package/dist/components/DepositWithdrawal/Withdrawal/RequireFirstDeposit.js +10 -0
  15. package/dist/components/DepositWithdrawal/Withdrawal/VentajaWithdrawal/VentajaWithdrawal.js +2 -1
  16. package/dist/components/DepositWithdrawal/utils.js +1 -0
  17. package/dist/components/DigitainLauncher/Loading.js +1 -1
  18. package/dist/components/Jackpots/Jackpots.module.css +219 -219
  19. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.module.css +184 -184
  20. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.module.css +184 -184
  21. package/dist/components/KYC/BasicInformation.js +1 -1
  22. package/dist/components/KYC/IdentityVerification.js +1 -1
  23. package/dist/components/KYC/KYC.lazy.js +1 -1
  24. package/dist/components/KYC/KYCDefault/KYCVerificationStatus.lazy.js +2 -2
  25. package/dist/components/KYC/KYCVerificationStatus.lazy.js +7 -13
  26. package/dist/components/KYC/PersonalInformation.js +1 -1
  27. package/dist/components/Tournaments/TournamentsCarousel/TournamentsCarouselItem.module.css +184 -184
  28. package/dist/components/Tournaments/TournamentsList/TournamentItem.module.css +184 -184
  29. package/dist/icons/CreditCardUpIcon.d.ts +2 -0
  30. package/dist/icons/CreditCardUpIcon.js +4 -0
  31. package/dist/icons/LinkBrokenIcon.d.ts +2 -0
  32. package/dist/icons/LinkBrokenIcon.js +4 -0
  33. package/dist/services/account.d.ts +4 -0
  34. package/dist/services/account.js +5 -1
  35. package/dist/services/queries.d.ts +12 -11
  36. package/dist/services/queries.js +3122 -3072
  37. package/dist/services/wallet.d.ts +3 -0
  38. package/dist/services/wallet.js +1 -0
  39. package/dist/styles/theme.css +773 -773
  40. package/dist/utils/queryKeys.d.ts +1 -0
  41. package/dist/utils/queryKeys.js +1 -0
  42. package/package.json +176 -176
  43. package/dist/components/Disclaimer/ResponsibleGaming.d.ts +0 -10
  44. package/dist/components/Disclaimer/ResponsibleGaming.js +0 -13
  45. package/dist/components/Disclaimer/TermsOfUse.d.ts +0 -11
  46. package/dist/components/Disclaimer/TermsOfUse.js +0 -13
  47. package/dist/components/FeatureFlag/FeatureFlag.d.ts +0 -1
  48. package/dist/components/FeatureFlag/FeatureFlag.js +0 -29
  49. package/dist/components/FeatureFlag/index.d.ts +0 -1
  50. package/dist/components/FeatureFlag/index.js +0 -1
  51. package/dist/components/KYC/AutoOpen.d.ts +0 -1
  52. package/dist/components/KYC/AutoOpen.js +0 -40
  53. package/dist/components/KYC/CaptureIdDocument.d.ts +0 -1
  54. package/dist/components/KYC/CaptureIdDocument.js +0 -219
  55. package/dist/components/KYC/CaptureSelfie.d.ts +0 -1
  56. package/dist/components/KYC/CaptureSelfie.js +0 -285
  57. package/dist/components/KYC/DisplayImage.d.ts +0 -5
  58. package/dist/components/KYC/DisplayImage.js +0 -8
  59. package/dist/components/KYC/FileUpload.d.ts +0 -10
  60. package/dist/components/KYC/FileUpload.js +0 -72
  61. package/dist/components/KYC/NoCameraError.d.ts +0 -7
  62. package/dist/components/KYC/NoCameraError.js +0 -6
  63. package/dist/components/KYC/PersonOverlayDesktop.d.ts +0 -7
  64. package/dist/components/KYC/PersonOverlayDesktop.js +0 -9
  65. package/dist/components/KYC/backup/Header.d.ts +0 -1
  66. package/dist/components/KYC/backup/Header.js +0 -8
  67. package/dist/components/KYC/backup/Indicator.d.ts +0 -1
  68. package/dist/components/KYC/backup/Indicator.js +0 -9
  69. package/dist/components/KYC/backup/KYC.d.ts +0 -1
  70. package/dist/components/KYC/backup/KYC.js +0 -14
  71. package/dist/components/KYC/backup/KYC.lazy.d.ts +0 -1
  72. package/dist/components/KYC/backup/KYC.lazy.js +0 -26
  73. package/dist/components/KYC/backup/KYCContext.d.ts +0 -6
  74. package/dist/components/KYC/backup/KYCContext.js +0 -2
  75. package/dist/components/KYC/backup/Step1.d.ts +0 -1
  76. package/dist/components/KYC/backup/Step1.js +0 -13
  77. package/dist/components/KYC/backup/Step2.d.ts +0 -1
  78. package/dist/components/KYC/backup/Step2.js +0 -13
  79. package/dist/components/KYC/backup/Step3.d.ts +0 -1
  80. package/dist/components/KYC/backup/Step3.js +0 -13
  81. package/dist/components/KYC/backup/Step4.d.ts +0 -1
  82. package/dist/components/KYC/backup/Step4.js +0 -7
  83. package/dist/components/KYC/backup/useKYC.d.ts +0 -10
  84. package/dist/components/KYC/backup/useKYC.js +0 -8
  85. package/dist/components/KYC/loadModels.d.ts +0 -1
  86. package/dist/components/KYC/loadModels.js +0 -9
  87. package/dist/components/KYC/utils.d.ts +0 -9
  88. package/dist/components/KYC/utils.js +0 -79
  89. package/dist/components/Messages/Message.d.ts +0 -1
  90. package/dist/components/Messages/Message.js +0 -35
  91. package/dist/components/Messages/MessageContext.d.ts +0 -6
  92. package/dist/components/Messages/MessageContext.js +0 -2
  93. package/dist/components/Messages/MessagePopup.d.ts +0 -1
  94. package/dist/components/Messages/MessagePopup.js +0 -20
  95. package/dist/components/Messages/MessageTrigger.d.ts +0 -8
  96. package/dist/components/Messages/MessageTrigger.js +0 -19
  97. package/dist/components/Quests/CountdownTimer.d.ts +0 -15
  98. package/dist/components/Quests/CountdownTimer.js +0 -33
  99. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.d.ts +0 -4
  100. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.js +0 -78
  101. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.d.ts +0 -8
  102. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.js +0 -9
  103. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.d.ts +0 -4
  104. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.js +0 -4
  105. package/dist/components/Quests/WageringQuest/WageringQuest.d.ts +0 -4
  106. package/dist/components/Quests/WageringQuest/WageringQuest.js +0 -20
  107. package/dist/components/Quests/WageringQuest/WageringQuestModal.d.ts +0 -9
  108. package/dist/components/Quests/WageringQuest/WageringQuestModal.js +0 -9
  109. package/dist/components/SignIn/utils.d.ts +0 -8
  110. package/dist/components/SignIn/utils.js +0 -26
  111. package/dist/components/SignUp/SignUp.lazy.d.ts +0 -12
  112. package/dist/components/SignUp/SignUp.lazy.js +0 -18
  113. package/dist/components/SignUp/SignUpContext.d.ts +0 -6
  114. package/dist/components/SignUp/SignUpContext.js +0 -2
  115. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.d.ts +0 -17
  116. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.js +0 -18
  117. package/dist/components/SignUp/SignUpDefault/SignUpContext.d.ts +0 -6
  118. package/dist/components/SignUp/SignUpDefault/SignUpContext.js +0 -2
  119. package/dist/components/SignUp/SignUpDefault/SignUpForm.d.ts +0 -1
  120. package/dist/components/SignUp/SignUpDefault/SignUpForm.js +0 -310
  121. package/dist/components/SignUp/SignUpForm.d.ts +0 -1
  122. package/dist/components/SignUp/SignUpForm.js +0 -284
  123. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.d.ts +0 -1
  124. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.js +0 -198
  125. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.d.ts +0 -1
  126. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.js +0 -251
  127. package/dist/components/SignUp/SignUpKYC/ImageUploader.d.ts +0 -10
  128. package/dist/components/SignUp/SignUpKYC/ImageUploader.js +0 -42
  129. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.d.ts +0 -7
  130. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.js +0 -9
  131. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.d.ts +0 -1
  132. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.js +0 -464
  133. package/dist/components/SignUp/SignUpKYC/useImageUploader.d.ts +0 -11
  134. package/dist/components/SignUp/SignUpKYC/useImageUploader.js +0 -20
  135. package/dist/components/SignUp/SignUpKYC/utils.d.ts +0 -9
  136. package/dist/components/SignUp/SignUpKYC/utils.js +0 -79
  137. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.d.ts +0 -1
  138. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.js +0 -198
  139. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.d.ts +0 -1
  140. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.js +0 -251
  141. package/dist/components/SignUp/SignUpPagcor/ImageUploader.d.ts +0 -10
  142. package/dist/components/SignUp/SignUpPagcor/ImageUploader.js +0 -41
  143. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.d.ts +0 -1
  144. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.js +0 -429
  145. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.d.ts +0 -13
  146. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.js +0 -26
  147. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.d.ts +0 -7
  148. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.js +0 -2
  149. package/dist/components/SignUp/SignUpPagcor/useImageUploader.d.ts +0 -11
  150. package/dist/components/SignUp/SignUpPagcor/useImageUploader.js +0 -20
  151. package/dist/components/shared/IdDocumentField.client.d.ts +0 -25
  152. package/dist/components/shared/IdDocumentField.client.js +0 -204
  153. package/dist/components/shared/IdDocumentField.d.ts +0 -2
  154. package/dist/components/shared/IdDocumentField.js +0 -11
  155. package/dist/components/shared/SelfieField.client.d.ts +0 -20
  156. package/dist/components/shared/SelfieField.client.js +0 -327
  157. package/dist/components/shared/SelfieField.d.ts +0 -2
  158. package/dist/components/shared/SelfieField.js +0 -11
  159. package/dist/constants/BranchCode.d.ts +0 -4
  160. package/dist/constants/BranchCode.js +0 -42
  161. package/dist/constants/Branches.d.ts +0 -2
  162. package/dist/constants/Branches.js +0 -42
  163. package/dist/handlers/postTransformIdFrontImage.d.ts +0 -3
  164. package/dist/handlers/postTransformIdFrontImage.js +0 -67
  165. package/dist/handlers/postTransformSelfieImage.d.ts +0 -3
  166. package/dist/handlers/postTransformSelfieImage.js +0 -71
  167. package/dist/handlers.d.ts +0 -43
  168. package/dist/handlers.js +0 -297
  169. package/dist/icons/BellRingIcon.d.ts +0 -2
  170. package/dist/icons/BellRingIcon.js +0 -4
  171. package/dist/third-parties/FacebookPixel/FacebookPixel.d.ts +0 -4
  172. package/dist/third-parties/FacebookPixel/FacebookPixel.js +0 -4
  173. package/dist/third-parties/FacebookPixel/api.d.ts +0 -0
  174. package/dist/third-parties/FacebookPixel/api.js +0 -1
  175. package/dist/third-parties/FacebookPixel/index.d.ts +0 -1
  176. package/dist/third-parties/FacebookPixel/index.js +0 -1
  177. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.d.ts +0 -4
  178. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.js +0 -4
  179. package/dist/third-parties/GoogleRecaptcha/api.d.ts +0 -0
  180. package/dist/third-parties/GoogleRecaptcha/api.js +0 -1
  181. package/dist/third-parties/GoogleRecaptcha/index.d.ts +0 -1
  182. package/dist/third-parties/GoogleRecaptcha/index.js +0 -1
  183. package/dist/third-parties/index.d.ts +0 -2
  184. package/dist/third-parties/index.js +0 -2
  185. package/dist/utils/dataUrlToBlob.d.ts +0 -1
  186. package/dist/utils/dataUrlToBlob.js +0 -11
  187. package/dist/utils/gamesAvailable3pmTo3am.d.ts +0 -1
  188. package/dist/utils/gamesAvailable3pmTo3am.js +0 -1
  189. package/dist/utils/getGameName.d.ts +0 -1
  190. package/dist/utils/getGameName.js +0 -6
  191. package/dist/utils/isBetween3amAnd3pm.d.ts +0 -1
  192. package/dist/utils/isBetween3amAnd3pm.js +0 -5
  193. package/dist/utils/resizeImageSize.d.ts +0 -2
  194. package/dist/utils/resizeImageSize.js +0 -11
@@ -0,0 +1,2 @@
1
+ import type { Query } from '../../types';
2
+ export declare const useRequireFirstDepositQuery: Query<boolean | null>;
@@ -0,0 +1,31 @@
1
+ import { useQuery } from '@tanstack/react-query';
2
+ import invariant from 'tiny-invariant';
3
+ import { getRequireFirstDeposit } from '../../services/account.js';
4
+ import { getQueryClient } from '../../utils/getQueryClient.js';
5
+ import { getRequireFirstDepositQueryKey, getSessionQueryKey } from '../../utils/queryKeys.js';
6
+ import { getSession } from '../services/getSession.js';
7
+ import { useSessionQuery } from './useSessionQuery.js';
8
+ export const useRequireFirstDepositQuery = (config) => {
9
+ const sessionQuery = useSessionQuery();
10
+ const query = useQuery({
11
+ ...config,
12
+ enabled: config?.enabled === false
13
+ ? false
14
+ : sessionQuery.data?.status === 'authenticated',
15
+ queryKey: getRequireFirstDepositQueryKey(),
16
+ queryFn: async ({ signal }) => {
17
+ const session = await getQueryClient().fetchQuery({
18
+ queryKey: getSessionQueryKey(),
19
+ queryFn: async () => getSession(),
20
+ });
21
+ invariant(session.status === 'authenticated');
22
+ return await getRequireFirstDeposit({
23
+ signal,
24
+ headers: {
25
+ Authorization: `Bearer ${session.token}`,
26
+ },
27
+ });
28
+ },
29
+ });
30
+ return query;
31
+ };
@@ -0,0 +1,7 @@
1
+ import { type UseDisclosureReturn } from '../../client/hooks/useDisclosure';
2
+ interface GoogleDisconnectProps {
3
+ onConfirmAction?: (ctx: UseDisclosureReturn) => React.ReactNode;
4
+ children?: (ctx: UseDisclosureReturn) => React.ReactNode;
5
+ }
6
+ export declare function GoogleDisconnect(props: GoogleDisconnectProps): import("react/jsx-runtime").JSX.Element;
7
+ export {};
@@ -0,0 +1,11 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import { useDisclosure, } from '../../client/hooks/useDisclosure.js';
4
+ import { LinkBrokenIcon } from '../../icons/LinkBrokenIcon.js';
5
+ import { XIcon } from '../../icons/XIcon.js';
6
+ import { Dialog } from '../../ui/Dialog/index.js';
7
+ import { Portal } from '../../ui/Portal/index.js';
8
+ export function GoogleDisconnect(props) {
9
+ const disclosure = useDisclosure();
10
+ return (_jsxs(_Fragment, { children: [props.children?.(disclosure), _jsx(Dialog.Root, { lazyMount: true, unmountOnExit: true, open: disclosure.open, onOpenChange: (details) => disclosure.setOpen(details.open), closeOnEscape: false, closeOnInteractOutside: false, children: _jsxs(Portal, { children: [_jsx(Dialog.Backdrop, { className: "!z-[calc(var(--z-dialog)+1)]" }), _jsx(Dialog.Positioner, { className: "!z-[calc(var(--z-dialog)+2)] flex items-center justify-center", children: _jsxs(Dialog.Content, { className: "mx-auto min-h-auto max-w-[25rem] overflow-y-auto rounded-xl p-6", children: [_jsx(Dialog.CloseTrigger, { children: _jsx(XIcon, {}) }), _jsxs("div", { className: "flex flex-col ", children: [_jsx("div", { className: "mx-auto flex size-12 items-center justify-center rounded-full bg-bg-brand-secondary text-text-brand", children: _jsx(LinkBrokenIcon, {}) }), _jsx("h2", { className: "mb-1 text-center font-semibold text-lg xl:mt-xl", children: "Disconnect Google Account" }), _jsx("p", { className: "text-center text-sm text-text-tertiary-600 leading-2xl", children: "Are you sure you want to disconnect your Google account? This may affect your ability to log in or sync data." })] }), _jsx("div", { className: "pt-6", children: props.onConfirmAction?.(disclosure) })] }) })] }) })] }));
11
+ }
@@ -0,0 +1 @@
1
+ export declare function GCashWebpayDeposit(): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,191 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { zodResolver } from '@hookform/resolvers/zod';
3
+ import Link from 'next/link';
4
+ import { useEffect, useState } from 'react';
5
+ import { Controller, useForm } from 'react-hook-form';
6
+ import invariant from 'tiny-invariant';
7
+ import { z } from 'zod';
8
+ import { useShallow } from 'zustand/shallow';
9
+ import { useAvailablePromosQuery } from '../../../../client/hooks/useAvailablePromosQuery.js';
10
+ import { useCreateGCashWebpayDepositMutation } from '../../../../client/hooks/useCreateGCashWebpayDepositMutation.js';
11
+ import { useDepositQuery } from '../../../../client/hooks/useDepositQuery.js';
12
+ import { useDepositsCountQuery } from '../../../../client/hooks/useDepositsCountQuery.js';
13
+ import { useDisclosure } from '../../../../client/hooks/useDisclosure.js';
14
+ import { useGlobalStore } from '../../../../client/hooks/useGlobalStore.js';
15
+ import { useMemberVerificationQuery } from '../../../../client/hooks/useMemberVerificationQuery.js';
16
+ import { usePaymentSettingsQuery } from '../../../../client/hooks/usePaymentSettingsQuery.js';
17
+ import { AlertCircleIcon } from '../../../../icons/AlertCircleIcon.js';
18
+ import { ChevronDownIcon } from '../../../../icons/ChevronDownIcon.js';
19
+ import { ChevronUpIcon } from '../../../../icons/ChevronUpIcon.js';
20
+ import { SpinnerIcon } from '../../../../icons/SpinnerIcon.js';
21
+ import { XIcon } from '../../../../icons/XIcon.js';
22
+ import { AlertDialog } from '../../../../ui/AlertDialog/index.js';
23
+ import { Button } from '../../../../ui/Button/index.js';
24
+ import { Field } from '../../../../ui/Field/index.js';
25
+ import { NumberInput } from '../../../../ui/NumberInput/index.js';
26
+ import { Portal } from '../../../../ui/Portal/index.js';
27
+ import { parseDecimal } from '../../../../utils/parseDecimal.js';
28
+ import { AmountChoices } from '../../AmountChoices.js';
29
+ import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
30
+ import { AvailablePromos } from '../AvailablePromos.js';
31
+ export function GCashWebpayDeposit() {
32
+ const depositWithdrawalProps = useDepositWithdrawalPropsContext();
33
+ const disclosure = useDisclosure();
34
+ const globalStore = useGlobalStore(useShallow((ctx) => ({
35
+ depositWithdrawal: ctx.depositWithdrawal,
36
+ kycVerificationStatus: ctx.kycVerificationStatus,
37
+ })));
38
+ const verificationQuery = useMemberVerificationQuery();
39
+ const verificationStatus = verificationQuery.data?.status ?? 'UNVERIFIED';
40
+ const [status, setStatus] = useState('waiting');
41
+ const createDepositMutation = useCreateGCashWebpayDepositMutation({
42
+ onMutate() {
43
+ disclosure.setOpen(true);
44
+ setStatus('processing');
45
+ },
46
+ onSuccess(data) {
47
+ invariant(data.checkoutUrl);
48
+ window.open(data.checkoutUrl, '_blank', 'noopener,noreferrer');
49
+ form.reset();
50
+ disclosure.setOpen(false);
51
+ },
52
+ onError() {
53
+ disclosure.setOpen(true);
54
+ setStatus('failed');
55
+ },
56
+ });
57
+ const depositQuery = useDepositQuery(createDepositMutation.data?.id, {
58
+ enabled: createDepositMutation.data != null,
59
+ refetchInterval(ctx) {
60
+ if (ctx.state.data?.status === 'CANCELLED' ||
61
+ ctx.state.data?.status === 'CONFIRMED') {
62
+ return false;
63
+ }
64
+ else {
65
+ return 2500;
66
+ }
67
+ },
68
+ });
69
+ useEffect(() => {
70
+ if (depositQuery.data?.status === 'CANCELLED') {
71
+ disclosure.setOpen(true);
72
+ setStatus('failed');
73
+ }
74
+ else if (depositQuery.data?.status === 'CONFIRMED') {
75
+ disclosure.setOpen(true);
76
+ setStatus('success');
77
+ }
78
+ }, [depositQuery.data?.status, disclosure]);
79
+ const depositsCountQuery = useDepositsCountQuery();
80
+ const depositsCount = depositsCountQuery.data ?? 0;
81
+ const paymentSettingsQuery = usePaymentSettingsQuery();
82
+ const paymentSettings = paymentSettingsQuery.data;
83
+ const gatewaySettings = paymentSettings?.gcashWebpayDepositGatewaySettings;
84
+ const maximumAmount = parseDecimal(gatewaySettings?.maximumAmount, 0);
85
+ const minimumAmount = depositsCount <= 0
86
+ ? parseDecimal(paymentSettingsQuery.data?.minimumFirstDepositAmount, 0)
87
+ : parseDecimal(gatewaySettings?.minimumAmount, 0);
88
+ const promosQuery = useAvailablePromosQuery();
89
+ const promos = promosQuery.data ?? [];
90
+ const definition = z
91
+ .object({
92
+ amount: z.string().superRefine((val, ctx) => {
93
+ const n = parseDecimal(val, 0);
94
+ if (n < minimumAmount) {
95
+ ctx.addIssue({
96
+ type: 'number',
97
+ code: z.ZodIssueCode.too_small,
98
+ inclusive: true,
99
+ minimum: minimumAmount,
100
+ message: `Minimum amount is ${minimumAmount.toLocaleString()}`,
101
+ });
102
+ }
103
+ if (n > maximumAmount) {
104
+ ctx.addIssue({
105
+ type: 'number',
106
+ code: z.ZodIssueCode.too_big,
107
+ inclusive: true,
108
+ maximum: maximumAmount,
109
+ message: `Maximum amount is ${maximumAmount.toLocaleString()}`,
110
+ });
111
+ }
112
+ }),
113
+ promo: z.string().optional().nullable(),
114
+ })
115
+ .superRefine((value, ctx) => {
116
+ const promo = promos.find((o) => o.id === value.promo);
117
+ const promoMinAmount = parseDecimal(promo?.minimumDepositAmount, 0);
118
+ const promoMaxAmount = parseDecimal(promo?.maximumDepositAmount, 0);
119
+ const amount = parseDecimal(value.amount, 0);
120
+ if (promo && amount < promoMinAmount) {
121
+ ctx.addIssue({
122
+ path: ['amount'],
123
+ code: z.ZodIssueCode.custom,
124
+ message: `Minimum amount for this promo is ${promoMinAmount.toLocaleString()}`,
125
+ });
126
+ }
127
+ if (promo && amount > promoMaxAmount) {
128
+ ctx.addIssue({
129
+ path: ['amount'],
130
+ code: z.ZodIssueCode.custom,
131
+ message: `Maximum amount for this promo is ${promoMaxAmount}`,
132
+ });
133
+ }
134
+ });
135
+ const form = useForm({
136
+ mode: 'all',
137
+ resolver: zodResolver(definition),
138
+ defaultValues: {
139
+ amount: '0',
140
+ promo: globalStore.depositWithdrawal.promo ?? null,
141
+ },
142
+ });
143
+ useEffect(() => {
144
+ if (minimumAmount) {
145
+ form.reset({
146
+ amount: minimumAmount.toString(),
147
+ promo: form.getValues('promo') ?? null,
148
+ });
149
+ }
150
+ }, [form, minimumAmount]);
151
+ return (_jsxs("form", { onSubmit: form.handleSubmit(async (data) => {
152
+ //handle new kyc process
153
+ if (verificationStatus === 'PENDING' ||
154
+ verificationStatus === 'UNVERIFIED' ||
155
+ verificationStatus === 'REJECTED' ||
156
+ verificationStatus === 'CREATED') {
157
+ globalStore.kycVerificationStatus.setOpen(true);
158
+ return;
159
+ }
160
+ else {
161
+ createDepositMutation.reset();
162
+ createDepositMutation.mutate({
163
+ amount: data.amount.toString(),
164
+ promo: data.promo ?? undefined,
165
+ successRedirectionUrl: window.location.origin,
166
+ cancelRedirectionUrl: window.location.origin,
167
+ });
168
+ }
169
+ }), noValidate: true, children: [_jsx(Controller, { control: form.control, name: "amount", render: (o) => (_jsxs(Field.Root, { invalid: !!form.formState.errors.amount, children: [_jsxs(NumberInput.Root, { min: 0, step: 1, value: o.field.value, onValueChange: (details) => {
170
+ o.field.onChange(details.value);
171
+ }, formatOptions: {
172
+ maximumFractionDigits: 2,
173
+ minimumFractionDigits: 0,
174
+ }, 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) => {
175
+ form.setValue('amount', value.toString(), {
176
+ shouldTouch: true,
177
+ shouldDirty: true,
178
+ shouldValidate: true,
179
+ });
180
+ }, min: minimumAmount, max: maximumAmount, className: "mt-lg" }), _jsx(Controller, { control: form.control, name: "promo", render: (o) => (_jsx(AvailablePromos, { value: o.field.value, onChange: (value) => {
181
+ o.field.onChange(value);
182
+ globalStore.depositWithdrawal.setPromo(null);
183
+ }, 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) => {
184
+ disclosure.setOpen(details.open);
185
+ }, lazyMount: true, unmountOnExit: true, 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.CloseTrigger, { children: _jsx(XIcon, {}) }), _jsxs(AlertDialog.Header, { children: [status === 'processing' && (_jsx(SpinnerIcon, { className: "size-12 text-text-brand-primary-600" })), status === 'success' && (_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' && 'Deposit Successful', status === 'failed' && 'Deposit Failed'] }), _jsxs(AlertDialog.Description, { children: [status === 'processing' &&
186
+ "We're verifying your account and amount. Please hold a moment.", status === 'success' &&
187
+ 'Your deposit has been successfully processed.', status === 'failed' &&
188
+ 'Something went wrong while processing your deposit. Please try again or contact support.'] })] }), (status === 'failed' || status === 'success') && (_jsx(AlertDialog.Footer, { children: _jsx(AlertDialog.Context, { children: (api) => (_jsx(Button, { onClick: () => {
189
+ api.setOpen(false);
190
+ }, children: status === 'failed' ? 'Try Again' : 'Ok' })) }) }))] }) })] }) })] }));
191
+ }
@@ -29,6 +29,7 @@ import { AmountChoices } from '../../AmountChoices.js';
29
29
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
30
30
  import { explainError } from '../../utils.js';
31
31
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
32
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
32
33
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
33
34
  export function GCashStandardCashInWithdrawal() {
34
35
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -125,7 +126,7 @@ export function GCashStandardCashInWithdrawal() {
125
126
  shouldDirty: true,
126
127
  shouldValidate: true,
127
128
  });
128
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
129
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
129
130
  if (!details.open) {
130
131
  setStatus('waiting');
131
132
  }
@@ -29,6 +29,7 @@ import { AmountChoices } from '../../AmountChoices.js';
29
29
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
30
30
  import { explainError } from '../../utils.js';
31
31
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
32
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
32
33
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
33
34
  export function GCashWithdrawal() {
34
35
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -125,7 +126,7 @@ export function GCashWithdrawal() {
125
126
  shouldDirty: true,
126
127
  shouldValidate: true,
127
128
  });
128
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
129
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
129
130
  if (!details.open) {
130
131
  setStatus('waiting');
131
132
  }
@@ -32,6 +32,7 @@ import { AmountChoices } from '../../AmountChoices.js';
32
32
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
33
33
  import { explainError } from '../../utils.js';
34
34
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
35
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
35
36
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
36
37
  export function InstapayWithdrawal() {
37
38
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -162,7 +163,7 @@ export function InstapayWithdrawal() {
162
163
  shouldDirty: true,
163
164
  shouldValidate: true,
164
165
  });
165
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
166
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
166
167
  if (!details.open) {
167
168
  setStatus('waiting');
168
169
  }
@@ -27,6 +27,7 @@ import { AmountChoices } from '../../AmountChoices.js';
27
27
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
28
28
  import { explainError } from '../../utils.js';
29
29
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
30
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
30
31
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
31
32
  export function MayaAppWithdrawal() {
32
33
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -115,7 +116,7 @@ export function MayaAppWithdrawal() {
115
116
  shouldDirty: true,
116
117
  shouldValidate: true,
117
118
  });
118
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
119
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
119
120
  if (!details.open) {
120
121
  setStatus('waiting');
121
122
  }
@@ -29,6 +29,7 @@ import { AmountChoices } from '../../AmountChoices.js';
29
29
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
30
30
  import { explainError } from '../../utils.js';
31
31
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
32
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
32
33
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
33
34
  export function MayaWithdrawal() {
34
35
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -125,7 +126,7 @@ export function MayaWithdrawal() {
125
126
  shouldDirty: true,
126
127
  shouldValidate: true,
127
128
  });
128
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
129
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
129
130
  if (!details.open) {
130
131
  setStatus('waiting');
131
132
  }
@@ -31,6 +31,7 @@ import { AmountChoices } from '../../AmountChoices.js';
31
31
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
32
32
  import { explainError } from '../../utils.js';
33
33
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
34
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
34
35
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
35
36
  export function PisoPayWithdrawal() {
36
37
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -151,7 +152,7 @@ export function PisoPayWithdrawal() {
151
152
  shouldDirty: true,
152
153
  shouldValidate: true,
153
154
  });
154
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
155
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
155
156
  if (!details.open) {
156
157
  setStatus('waiting');
157
158
  }
@@ -0,0 +1 @@
1
+ export declare function RequireFirstDeposit(): import("react/jsx-runtime").JSX.Element | null;
@@ -0,0 +1,10 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useRequireFirstDepositQuery } from '../../../client/hooks/useRequireFirstDepositQuery.js';
3
+ import { CreditCardUpIcon } from '../../../icons/CreditCardUpIcon.js';
4
+ export function RequireFirstDeposit() {
5
+ const requireFirstDepositQuery = useRequireFirstDepositQuery();
6
+ const requireFirstDeposit = requireFirstDepositQuery.data;
7
+ if (!requireFirstDeposit)
8
+ return null;
9
+ return (_jsxs("div", { className: "mt-lg rounded-xl border border-border-primary bg-bg-primary-alt p-xl", children: [_jsx("div", { className: "flex size-8.5 items-center justify-center rounded-full border-[1.667px] border-text-warning-primary/10", children: _jsx("div", { className: "flex size-6.5 items-center justify-center rounded-full border-[1.667px] border-text-warning-primary/30", children: _jsx(CreditCardUpIcon, { className: "size-5 text-text-warning-primary" }) }) }), _jsx("p", { className: "mt-lg text-sm text-text-tertiary-600", children: "It looks like you still need to make your first deposit before you can withdraw funds." })] }));
10
+ }
@@ -31,6 +31,7 @@ import { AmountChoices } from '../../AmountChoices.js';
31
31
  import { useDepositWithdrawalPropsContext } from '../../DepositWithdrawalContext.js';
32
32
  import { explainError } from '../../utils.js';
33
33
  import { ActiveTurnoverRequirement } from '../ActiveTurnoverRequirement.js';
34
+ import { RequireFirstDeposit } from '../RequireFirstDeposit.js';
34
35
  import { TransactionPasswordNotSet } from '../TransactionPasswordNotSet.js';
35
36
  export function VentajaWithdrawal() {
36
37
  const depositWithdrawalProps = useDepositWithdrawalPropsContext();
@@ -151,7 +152,7 @@ export function VentajaWithdrawal() {
151
152
  shouldDirty: true,
152
153
  shouldValidate: true,
153
154
  });
154
- }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
155
+ }, min: minimumAmount, max: maximumAmount, className: "mt-xl" }), _jsxs(Field.Root, { className: "mt-3xl", invalid: !!form.formState.errors.password, children: [_jsxs(PasswordInput.Root, { children: [_jsx(PasswordInput.Label, { children: "Transaction Password" }), _jsxs(PasswordInput.Control, { children: [_jsx(PasswordInput.Input, { placeholder: "Enter password", ...form.register('password') }), _jsx(PasswordInput.VisibilityTrigger, { children: _jsx(PasswordInput.Indicator, { fallback: _jsx(EyeOffIcon, {}), asChild: true, children: _jsx(EyeIcon, {}) }) })] })] }), _jsx(Field.ErrorText, { children: form.formState.errors.password?.message })] }), _jsx(TransactionPasswordNotSet, {}), _jsx(ActiveTurnoverRequirement, {}), _jsx(RequireFirstDeposit, {}), _jsx(Button, { type: "submit", className: "mt-6", disabled: createWithdrawalMutation.isPending || turnoverRequirement > 0, children: "Withdraw" }), depositWithdrawalProps.hasPrivacyPolicyAndTermsOfUse && (_jsxs("p", { className: "mt-lg text-text-tertiary-600 text-xs", children: ["Upon withdrawing, 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: status !== 'waiting', onOpenChange: (details) => {
155
156
  if (!details.open) {
156
157
  setStatus('waiting');
157
158
  }
@@ -40,6 +40,7 @@ const errorMap = {
40
40
  ReCAPTCHAVerificationFailedError: 'reCAPTCHA verification failed. Please try again.',
41
41
  WalletDoesNotExistError: 'Wallet does not exist. Please check your wallet settings or contact support.',
42
42
  WithdrawalDailyLimitExceededError: 'You have exceeded your daily withdrawal limit. Please try again tomorrow.',
43
+ FirstDepositRequiredError: 'First deposit is required before making a withdrawal.',
43
44
  };
44
45
  export function explainError(error) {
45
46
  if (error && errorMap[error]) {
@@ -1,5 +1,5 @@
1
1
  'use client';
2
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
3
  export function Loading() {
4
- return (_jsx("div", { className: "flex h-[calc(100vh-400px)] w-full items-center justify-center px-4", children: _jsxs("div", { className: "flex flex-col items-center space-y-4", children: [_jsx("div", { className: "border-blue-500 h-10 w-10 animate-spin rounded-full border-4 border-t-transparent" }), _jsx("p", { className: "text-gray-700 text-lg font-medium", children: "Loading Sports Book\u2026" })] }) }));
4
+ return (_jsx("div", { className: "flex h-[calc(100vh-400px)] w-full items-center justify-center px-4", children: _jsxs("div", { className: "flex flex-col items-center space-y-4", children: [_jsx("div", { className: "h-10 w-10 animate-spin rounded-full border-4 border-blue-500 border-t-transparent" }), _jsx("p", { className: "font-medium text-gray-700 text-lg", children: "Loading Sports Book\u2026" })] }) }));
5
5
  }