@opexa/portal-components 0.0.862 → 0.0.863

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 (224) hide show
  1. package/dist/components/AccountInfo/GoogleDisconnect.d.ts +7 -0
  2. package/dist/components/AccountInfo/GoogleDisconnect.js +11 -0
  3. package/dist/components/DepositWithdrawal/Deposit/GCashWebpayDeposit /GCashWebpayDeposit .d.ts +1 -0
  4. package/dist/components/DepositWithdrawal/Deposit/GCashWebpayDeposit /GCashWebpayDeposit .js +191 -0
  5. package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/OnlineBankDepositContext.d.ts +2 -2
  6. package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/useOnlineBankDeposit.d.ts +1 -1
  7. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositContext.d.ts +2 -2
  8. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/useQRPHDeposit.d.ts +1 -1
  9. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.d.ts +2 -2
  10. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.d.ts +1 -1
  11. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositContext.d.ts +2 -2
  12. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/useOnlineBankDeposit.d.ts +1 -1
  13. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositContext.d.ts +2 -2
  14. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/useQRPHDeposit.d.ts +1 -1
  15. package/dist/components/DigitainLauncher/Loading.js +1 -1
  16. package/dist/components/Jackpots/Jackpots.module.css +221 -221
  17. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.module.css +184 -184
  18. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.module.css +184 -184
  19. package/dist/components/KYC/BasicInformation.js +1 -1
  20. package/dist/components/KYC/IdentityVerification.js +1 -1
  21. package/dist/components/KYC/KYC.lazy.js +1 -1
  22. package/dist/components/KYC/KYCDefault/KYCVerificationStatus.lazy.js +2 -2
  23. package/dist/components/KYC/KYCVerificationStatus.lazy.js +7 -13
  24. package/dist/components/KYC/PersonalInformation.js +1 -1
  25. package/dist/components/SignIn/MobileNumberSignIn.js +4 -1
  26. package/dist/components/Tournaments/TournamentsCarousel/TournamentsCarouselItem.module.css +184 -184
  27. package/dist/components/Tournaments/TournamentsList/TournamentItem.module.css +184 -184
  28. package/dist/icons/LinkBrokenIcon.d.ts +2 -0
  29. package/dist/icons/LinkBrokenIcon.js +4 -0
  30. package/dist/services/queries.js +3153 -3153
  31. package/dist/styles/theme.css +776 -776
  32. package/dist/ui/AlertDialog/AlertDialog.d.ts +121 -121
  33. package/dist/ui/AlertDialog/alertDialog.recipe.d.ts +11 -11
  34. package/dist/ui/Carousel/Carousel.d.ts +72 -72
  35. package/dist/ui/Carousel/carousel.recipe.d.ts +8 -8
  36. package/dist/ui/Checkbox/Checkbox.d.ts +23 -23
  37. package/dist/ui/Checkbox/checkbox.recipe.d.ts +3 -3
  38. package/dist/ui/Clipboard/Clipboard.d.ts +18 -18
  39. package/dist/ui/Clipboard/clipboard.recipe.d.ts +3 -3
  40. package/dist/ui/Collapsible/Collapsible.d.ts +20 -20
  41. package/dist/ui/Collapsible/collapsible.recipe.d.ts +5 -5
  42. package/dist/ui/Combobox/Combobox.d.ts +42 -42
  43. package/dist/ui/Combobox/combobox.recipe.d.ts +3 -3
  44. package/dist/ui/DatePicker/DatePicker.d.ts +72 -72
  45. package/dist/ui/DatePicker/datePicker.recipe.d.ts +3 -3
  46. package/dist/ui/Dialog/Dialog.d.ts +33 -33
  47. package/dist/ui/Dialog/dialog.recipe.d.ts +3 -3
  48. package/dist/ui/Drawer/Drawer.d.ts +33 -33
  49. package/dist/ui/Drawer/drawer.recipe.d.ts +3 -3
  50. package/dist/ui/Field/Field.d.ts +21 -21
  51. package/dist/ui/Field/field.recipe.d.ts +3 -3
  52. package/dist/ui/Menu/Menu.d.ts +90 -90
  53. package/dist/ui/Menu/menu.recipe.d.ts +5 -5
  54. package/dist/ui/NumberInput/NumberInput.d.ts +24 -24
  55. package/dist/ui/NumberInput/numberInput.recipe.d.ts +3 -3
  56. package/dist/ui/PasswordInput/PasswordInput.d.ts +18 -18
  57. package/dist/ui/PasswordInput/passwordInput.recipe.d.ts +3 -3
  58. package/dist/ui/PinInput/PinInput.d.ts +12 -12
  59. package/dist/ui/PinInput/pinInput.recipe.d.ts +3 -3
  60. package/dist/ui/Popover/Popover.d.ts +88 -88
  61. package/dist/ui/Popover/popover.recipe.d.ts +8 -8
  62. package/dist/ui/Progress/Progress.d.ts +27 -27
  63. package/dist/ui/Progress/progress.recipe.d.ts +3 -3
  64. package/dist/ui/QrCode/QrCode.d.ts +25 -25
  65. package/dist/ui/QrCode/qrCode.recipe.d.ts +5 -5
  66. package/dist/ui/SegmentGroup/SegmentGroup.d.ts +18 -18
  67. package/dist/ui/SegmentGroup/segmentGroup.recipe.d.ts +3 -3
  68. package/dist/ui/Select/Select.d.ts +45 -45
  69. package/dist/ui/Select/select.recipe.d.ts +3 -3
  70. package/dist/ui/Tabs/Tabs.d.ts +15 -15
  71. package/dist/ui/Tabs/tabs.recipe.d.ts +3 -3
  72. package/package.json +177 -177
  73. package/dist/components/Disclaimer/ResponsibleGaming.d.ts +0 -10
  74. package/dist/components/Disclaimer/ResponsibleGaming.js +0 -13
  75. package/dist/components/Disclaimer/TermsOfUse.d.ts +0 -11
  76. package/dist/components/Disclaimer/TermsOfUse.js +0 -13
  77. package/dist/components/FeatureFlag/FeatureFlag.d.ts +0 -1
  78. package/dist/components/FeatureFlag/FeatureFlag.js +0 -29
  79. package/dist/components/FeatureFlag/index.d.ts +0 -1
  80. package/dist/components/FeatureFlag/index.js +0 -1
  81. package/dist/components/KYC/AutoOpen.d.ts +0 -1
  82. package/dist/components/KYC/AutoOpen.js +0 -40
  83. package/dist/components/KYC/CaptureIdDocument.d.ts +0 -1
  84. package/dist/components/KYC/CaptureIdDocument.js +0 -219
  85. package/dist/components/KYC/CaptureSelfie.d.ts +0 -1
  86. package/dist/components/KYC/CaptureSelfie.js +0 -285
  87. package/dist/components/KYC/DisplayImage.d.ts +0 -5
  88. package/dist/components/KYC/DisplayImage.js +0 -8
  89. package/dist/components/KYC/FileUpload.d.ts +0 -10
  90. package/dist/components/KYC/FileUpload.js +0 -72
  91. package/dist/components/KYC/NoCameraError.d.ts +0 -7
  92. package/dist/components/KYC/NoCameraError.js +0 -6
  93. package/dist/components/KYC/PersonOverlayDesktop.d.ts +0 -7
  94. package/dist/components/KYC/PersonOverlayDesktop.js +0 -9
  95. package/dist/components/KYC/backup/Header.d.ts +0 -1
  96. package/dist/components/KYC/backup/Header.js +0 -8
  97. package/dist/components/KYC/backup/Indicator.d.ts +0 -1
  98. package/dist/components/KYC/backup/Indicator.js +0 -9
  99. package/dist/components/KYC/backup/KYC.d.ts +0 -1
  100. package/dist/components/KYC/backup/KYC.js +0 -14
  101. package/dist/components/KYC/backup/KYC.lazy.d.ts +0 -1
  102. package/dist/components/KYC/backup/KYC.lazy.js +0 -26
  103. package/dist/components/KYC/backup/KYCContext.d.ts +0 -6
  104. package/dist/components/KYC/backup/KYCContext.js +0 -2
  105. package/dist/components/KYC/backup/Step1.d.ts +0 -1
  106. package/dist/components/KYC/backup/Step1.js +0 -13
  107. package/dist/components/KYC/backup/Step2.d.ts +0 -1
  108. package/dist/components/KYC/backup/Step2.js +0 -13
  109. package/dist/components/KYC/backup/Step3.d.ts +0 -1
  110. package/dist/components/KYC/backup/Step3.js +0 -13
  111. package/dist/components/KYC/backup/Step4.d.ts +0 -1
  112. package/dist/components/KYC/backup/Step4.js +0 -7
  113. package/dist/components/KYC/backup/useKYC.d.ts +0 -10
  114. package/dist/components/KYC/backup/useKYC.js +0 -8
  115. package/dist/components/KYC/loadModels.d.ts +0 -1
  116. package/dist/components/KYC/loadModels.js +0 -9
  117. package/dist/components/KYC/utils.d.ts +0 -9
  118. package/dist/components/KYC/utils.js +0 -79
  119. package/dist/components/Messages/Message.d.ts +0 -1
  120. package/dist/components/Messages/Message.js +0 -35
  121. package/dist/components/Messages/MessageContext.d.ts +0 -6
  122. package/dist/components/Messages/MessageContext.js +0 -2
  123. package/dist/components/Messages/MessagePopup.d.ts +0 -1
  124. package/dist/components/Messages/MessagePopup.js +0 -20
  125. package/dist/components/Messages/MessageTrigger.d.ts +0 -8
  126. package/dist/components/Messages/MessageTrigger.js +0 -19
  127. package/dist/components/Quests/CountdownTimer.d.ts +0 -15
  128. package/dist/components/Quests/CountdownTimer.js +0 -33
  129. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.d.ts +0 -4
  130. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.js +0 -78
  131. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.d.ts +0 -8
  132. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.js +0 -9
  133. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.d.ts +0 -4
  134. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.js +0 -4
  135. package/dist/components/Quests/WageringQuest/WageringQuest.d.ts +0 -4
  136. package/dist/components/Quests/WageringQuest/WageringQuest.js +0 -20
  137. package/dist/components/Quests/WageringQuest/WageringQuestModal.d.ts +0 -9
  138. package/dist/components/Quests/WageringQuest/WageringQuestModal.js +0 -9
  139. package/dist/components/SignIn/utils.d.ts +0 -8
  140. package/dist/components/SignIn/utils.js +0 -26
  141. package/dist/components/SignUp/SignUp.lazy.d.ts +0 -12
  142. package/dist/components/SignUp/SignUp.lazy.js +0 -18
  143. package/dist/components/SignUp/SignUpContext.d.ts +0 -6
  144. package/dist/components/SignUp/SignUpContext.js +0 -2
  145. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.d.ts +0 -17
  146. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.js +0 -18
  147. package/dist/components/SignUp/SignUpDefault/SignUpContext.d.ts +0 -6
  148. package/dist/components/SignUp/SignUpDefault/SignUpContext.js +0 -2
  149. package/dist/components/SignUp/SignUpDefault/SignUpForm.d.ts +0 -1
  150. package/dist/components/SignUp/SignUpDefault/SignUpForm.js +0 -310
  151. package/dist/components/SignUp/SignUpForm.d.ts +0 -1
  152. package/dist/components/SignUp/SignUpForm.js +0 -284
  153. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.d.ts +0 -1
  154. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.js +0 -198
  155. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.d.ts +0 -1
  156. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.js +0 -251
  157. package/dist/components/SignUp/SignUpKYC/ImageUploader.d.ts +0 -10
  158. package/dist/components/SignUp/SignUpKYC/ImageUploader.js +0 -42
  159. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.d.ts +0 -7
  160. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.js +0 -9
  161. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.d.ts +0 -1
  162. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.js +0 -464
  163. package/dist/components/SignUp/SignUpKYC/useImageUploader.d.ts +0 -11
  164. package/dist/components/SignUp/SignUpKYC/useImageUploader.js +0 -20
  165. package/dist/components/SignUp/SignUpKYC/utils.d.ts +0 -9
  166. package/dist/components/SignUp/SignUpKYC/utils.js +0 -79
  167. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.d.ts +0 -1
  168. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.js +0 -198
  169. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.d.ts +0 -1
  170. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.js +0 -251
  171. package/dist/components/SignUp/SignUpPagcor/ImageUploader.d.ts +0 -10
  172. package/dist/components/SignUp/SignUpPagcor/ImageUploader.js +0 -41
  173. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.d.ts +0 -1
  174. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.js +0 -429
  175. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.d.ts +0 -13
  176. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.js +0 -26
  177. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.d.ts +0 -7
  178. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.js +0 -2
  179. package/dist/components/SignUp/SignUpPagcor/useImageUploader.d.ts +0 -11
  180. package/dist/components/SignUp/SignUpPagcor/useImageUploader.js +0 -20
  181. package/dist/components/shared/IdDocumentField.client.d.ts +0 -25
  182. package/dist/components/shared/IdDocumentField.client.js +0 -204
  183. package/dist/components/shared/IdDocumentField.d.ts +0 -2
  184. package/dist/components/shared/IdDocumentField.js +0 -11
  185. package/dist/components/shared/SelfieField.client.d.ts +0 -20
  186. package/dist/components/shared/SelfieField.client.js +0 -327
  187. package/dist/components/shared/SelfieField.d.ts +0 -2
  188. package/dist/components/shared/SelfieField.js +0 -11
  189. package/dist/constants/BranchCode.d.ts +0 -4
  190. package/dist/constants/BranchCode.js +0 -42
  191. package/dist/constants/Branches.d.ts +0 -2
  192. package/dist/constants/Branches.js +0 -42
  193. package/dist/handlers/postTransformIdFrontImage.d.ts +0 -3
  194. package/dist/handlers/postTransformIdFrontImage.js +0 -67
  195. package/dist/handlers/postTransformSelfieImage.d.ts +0 -3
  196. package/dist/handlers/postTransformSelfieImage.js +0 -71
  197. package/dist/handlers.d.ts +0 -43
  198. package/dist/handlers.js +0 -297
  199. package/dist/icons/BellRingIcon.d.ts +0 -2
  200. package/dist/icons/BellRingIcon.js +0 -4
  201. package/dist/third-parties/FacebookPixel/FacebookPixel.d.ts +0 -4
  202. package/dist/third-parties/FacebookPixel/FacebookPixel.js +0 -4
  203. package/dist/third-parties/FacebookPixel/api.d.ts +0 -0
  204. package/dist/third-parties/FacebookPixel/api.js +0 -1
  205. package/dist/third-parties/FacebookPixel/index.d.ts +0 -1
  206. package/dist/third-parties/FacebookPixel/index.js +0 -1
  207. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.d.ts +0 -4
  208. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.js +0 -4
  209. package/dist/third-parties/GoogleRecaptcha/api.d.ts +0 -0
  210. package/dist/third-parties/GoogleRecaptcha/api.js +0 -1
  211. package/dist/third-parties/GoogleRecaptcha/index.d.ts +0 -1
  212. package/dist/third-parties/GoogleRecaptcha/index.js +0 -1
  213. package/dist/third-parties/index.d.ts +0 -2
  214. package/dist/third-parties/index.js +0 -2
  215. package/dist/utils/dataUrlToBlob.d.ts +0 -1
  216. package/dist/utils/dataUrlToBlob.js +0 -11
  217. package/dist/utils/gamesAvailable3pmTo3am.d.ts +0 -1
  218. package/dist/utils/gamesAvailable3pmTo3am.js +0 -1
  219. package/dist/utils/getGameName.d.ts +0 -1
  220. package/dist/utils/getGameName.js +0 -6
  221. package/dist/utils/isBetween3amAnd3pm.d.ts +0 -1
  222. package/dist/utils/isBetween3amAnd3pm.js +0 -5
  223. package/dist/utils/resizeImageSize.d.ts +0 -2
  224. package/dist/utils/resizeImageSize.js +0 -11
@@ -1,20 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
- import { useState } from 'react';
4
- import { twMerge } from 'tailwind-merge';
5
- import { ClockStopWatchIcon } from '../../../icons/ClockStopWatchIcon.js';
6
- import { InfoCircleIcon } from '../../../icons/InfoCircleIcon.js';
7
- import { Badge } from '../../../ui/Badge/index.js';
8
- import CountdownTimer from '../CountdownTimer.js';
9
- import { WageringQuestModal } from './WageringQuestModal.js';
10
- export function WageringQuest({ quest }) {
11
- const [showRules, setShowRules] = useState(false);
12
- const [isExpired, setIsExpired] = useState(false);
13
- const { progressPercentage, turnover, targetTurnover, name, description, endDateTime, bonus, status, } = quest;
14
- return (_jsxs(_Fragment, { children: [_jsx(WageringQuestModal, { questName: name, modalState: {
15
- isOpen: showRules,
16
- setIsOpen: setShowRules,
17
- } }), _jsxs("div", { className: "border-border-primary bg-bg-tertiary flex h-full w-full flex-col space-y-6 rounded-2xl border px-4 pb-6 pt-5", children: [_jsxs("div", { className: "flex flex-col space-y-2", children: [_jsxs("div", { className: "flex max-h-7.5 items-start justify-between", children: [_jsx(CountdownTimer, { endDateTime: endDateTime, renderAction: (timeLeft) => (_jsxs(Badge.Root, { size: "lg", colorScheme: "brand", round: false, children: [_jsx(Badge.Icon, { children: _jsx(ClockStopWatchIcon, {}) }), _jsxs(Badge.Label, { children: [timeLeft.days, "d:", timeLeft.hours, "h:", timeLeft.minutes, "m:", timeLeft.seconds, "s"] })] })), onEnd: () => setIsExpired(true) }), _jsx("div", { role: "button", className: "bg-bg-primary border-border-secondary flex size-9 cursor-pointer items-center justify-center rounded-md border", onClick: () => setShowRules((prev) => !prev), children: _jsx(InfoCircleIcon, { className: "text-text-disabled size-5" }) })] }), _jsx("p", { className: "text-xl font-semibold", children: name }), _jsx("p", { className: "text-text-secondary-700 text-wrap text-sm font-normal", dangerouslySetInnerHTML: { __html: description } })] }), _jsxs("div", { className: "flex w-full flex-col space-y-2", children: [_jsxs("div", { className: "text-text-primary-brand group flex items-center justify-between", children: [_jsxs("p", { children: ["Progress ", parseInt(progressPercentage).toFixed(2), "%"] }), _jsxs("p", { children: [turnover, _jsxs("span", { className: "text-text-quarterary-brand", children: ["/", targetTurnover, " PHP"] })] })] }), _jsx("div", { className: "bg-bg-primary h-2 w-full overflow-hidden rounded-full", children: _jsx("div", { className: "bg-utility-brand-600 h-full rounded-full transition-all duration-300", style: { width: `${progressPercentage}%` } }) })] }), _jsx("div", { className: "flex h-full items-end", children: _jsx("div", { className: "bg-button-secondary-bg border-bg-primary-hover w-full rounded-md border px-3.5 py-2.5 text-center text-white", children: _jsxs("p", { className: twMerge(isExpired || status === 'COMPLETED' || status === 'FAILED'
18
- ? ['opacity-50 grayscale']
19
- : ''), children: ["Complete to get ", _jsxs("span", { className: "text-brand-400", children: ["\u20B1", bonus] }), ' ', "bonus!"] }) }) })] })] }));
20
- }
@@ -1,9 +0,0 @@
1
- interface Props {
2
- questName: string;
3
- modalState: {
4
- isOpen: boolean;
5
- setIsOpen: (isOpen: boolean) => void;
6
- };
7
- }
8
- export declare function WageringQuestModal(props: Props): import("react/jsx-runtime").JSX.Element;
9
- export {};
@@ -1,9 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import { XIcon } from '../../../icons/XIcon.js';
4
- import { Button } from '../../../ui/Button/index.js';
5
- import { Dialog } from '../../../ui/Dialog/index.js';
6
- import { Portal } from '../../../ui/Portal/index.js';
7
- export function WageringQuestModal(props) {
8
- return (_jsx(Dialog.Root, { lazyMount: true, unmountOnExit: true, open: props.modalState.isOpen, onOpenChange: ({ open }) => props.modalState.setIsOpen(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: "min-h-auto mx-auto max-w-[343px] rounded-xl px-4 pb-0 pt-5", children: [_jsx(Dialog.CloseTrigger, { children: _jsx(XIcon, {}) }), _jsxs("div", { className: "flex flex-col space-y-5", children: [_jsx("p", { className: "text-text-primary-900 text-lg font-semibold", children: props.questName }), _jsxs("ul", { className: "text-text-tertiary-600 group list-disc text-wrap pl-4 text-sm font-normal", children: [_jsx("li", { children: "Earn extra rewards just by playing Slots, every bet counts, win or lose!" }), _jsx("li", { children: "Reach the wagering requirement in bets to complete the quest and claim your reward." })] })] }), _jsx("div", { className: "pb-4 pt-6", children: _jsx(Button, { onClick: () => props.modalState.setIsOpen(false), children: "Ok" }) })] }) })] }) }));
9
- }
@@ -1,8 +0,0 @@
1
- type Options = {
2
- accountName?: string;
3
- siteName?: string;
4
- signInOptions?: 'MOBILE_NUMBER' | 'NAME_AND_PASSWORD';
5
- };
6
- export type ErrorCode = 'MEMBER_ACCOUNT_BLACKLISTED' | 'MEMBER_ACCOUNT_SUSPENDED' | 'INVALID_RECAPTCHA_RESPONSE' | 'MEMBER_NOT_FOUND' | 'RATE_LIMIT_REACH' | 'NOT_READY_TO_SEND_VERIFICATION_ERROR' | 'Forbidden';
7
- export declare function getFriendlyErrorMessage(code: ErrorCode, options?: Options): string;
8
- export {};
@@ -1,26 +0,0 @@
1
- export function getFriendlyErrorMessage(code, options) {
2
- const accountName = options?.accountName ?? '';
3
- const siteName = options?.siteName ?? '';
4
- const signInOptions = options?.signInOptions ?? 'NAME_AND_PASSWORD';
5
- switch (code) {
6
- case 'MEMBER_ACCOUNT_BLACKLISTED':
7
- return `Your account ${accountName} has been blacklisted due to a serious violation of our policies. For more information or to appeal, please contact the ${siteName} Chat Support team.`;
8
- case 'MEMBER_ACCOUNT_SUSPENDED':
9
- return `Your account ${accountName} has been temporarily suspended. Please reach out to the ${siteName} Chat Support team to learn more and get help with resolving the issue.`;
10
- case 'INVALID_RECAPTCHA_RESPONSE':
11
- return 'Invalid reCAPTCHA response';
12
- case 'MEMBER_NOT_FOUND':
13
- return 'Account not found. Please check your username and try again.';
14
- case 'RATE_LIMIT_REACH':
15
- return 'Rate limit exceeded';
16
- case 'NOT_READY_TO_SEND_VERIFICATION_ERROR':
17
- return 'Your account is not ready to send verification requests. Please try again later.';
18
- case 'Forbidden':
19
- if (signInOptions === 'MOBILE_NUMBER') {
20
- return 'Invalid verification code. Please check the code and try again.';
21
- }
22
- return 'Invalid username or password, please try again.';
23
- default:
24
- return 'Something went wrong. Please try again later.';
25
- }
26
- }
@@ -1,12 +0,0 @@
1
- import { type ImageProps } from 'next/image';
2
- import { type ReactNode } from 'react';
3
- import type { Branch } from '../../types';
4
- export interface SignUpProps {
5
- logo: ImageProps['src'];
6
- children?: ReactNode;
7
- /** @default "/terms-and-conditions" */
8
- termsAndConditionsUrl?: string;
9
- className?: string;
10
- branches?: Branch[];
11
- }
12
- export declare function SignUp(props: SignUpProps): import("react/jsx-runtime").JSX.Element;
@@ -1,18 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import Image, {} from 'next/image';
4
- import { Suspense } from 'react';
5
- import { twMerge } from 'tailwind-merge';
6
- import { useShallow } from 'zustand/shallow';
7
- import { useGlobalStore } from '../../client/hooks/useGlobalStore.js';
8
- import { XIcon } from '../../icons/XIcon.js';
9
- import { Dialog } from '../../ui/Dialog/index.js';
10
- import { Portal } from '../../ui/Portal/index.js';
11
- import { SignUpPropsProvider } from './SignUpContext.js';
12
- import { SignUpForm } from './SignUpForm.js';
13
- export function SignUp(props) {
14
- const signUpStore = useGlobalStore(useShallow((ctx) => ctx.signUp));
15
- return (_jsx(SignUpPropsProvider, { value: props, children: _jsx(Dialog.Root, { open: signUpStore.open, onOpenChange: (details) => {
16
- signUpStore.setOpen(details.open);
17
- }, lazyMount: true, unmountOnExit: true, closeOnEscape: false, closeOnInteractOutside: false, children: _jsxs(Portal, { children: [_jsx(Dialog.Backdrop, {}), _jsx(Dialog.Positioner, { children: _jsxs(Dialog.Content, { className: twMerge('bg-bg-primary-alt mx-auto h-full w-full items-start p-3xl pb-4xl lg:h-auto lg:w-[400px] lg:rounded-xl', props.className), children: [_jsx(Dialog.CloseTrigger, { children: _jsx(XIcon, {}) }), _jsx(Image, { src: props.logo, alt: "", width: 200, height: 100, className: "mx-auto h-auto w-[120px]", draggable: false }), _jsx(Suspense, { children: _jsx(SignUpForm, {}) })] }) })] }) }) }));
18
- }
@@ -1,6 +0,0 @@
1
- import type { SignUpProps } from './SignUp.lazy';
2
- export declare const SignUpPropsProvider: (props: {
3
- value: SignUpProps;
4
- } & {
5
- children?: import("react").ReactNode | undefined;
6
- }) => React.ReactNode, useSignUpPropsContext: () => SignUpProps;
@@ -1,2 +0,0 @@
1
- import { createContext } from '../../client/utils/createContext.js';
2
- export const [SignUpPropsProvider, useSignUpPropsContext] = createContext();
@@ -1,17 +0,0 @@
1
- import { type ImageProps } from 'next/image';
2
- import { type ReactNode } from 'react';
3
- import type { Branch } from '../../../types';
4
- export interface SignUpProps {
5
- logo: ImageProps['src'];
6
- children?: ReactNode;
7
- /** @default "/terms-and-conditions" */
8
- termsAndConditionsUrl?: string;
9
- termsOfUseContent?: ReactNode;
10
- responsibleGamingContent?: ReactNode;
11
- responsibleGamingLogo?: ImageProps['src'];
12
- siteName?: string;
13
- className?: string;
14
- branches?: Branch[];
15
- layout: 'default';
16
- }
17
- export declare function SignUp(props: SignUpProps): import("react/jsx-runtime").JSX.Element;
@@ -1,18 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import Image, {} from 'next/image';
4
- import { Suspense } from 'react';
5
- import { twMerge } from 'tailwind-merge';
6
- import { useShallow } from 'zustand/shallow';
7
- import { useGlobalStore } from '../../../client/hooks/useGlobalStore.js';
8
- import { XIcon } from '../../../icons/XIcon.js';
9
- import { Dialog } from '../../../ui/Dialog/index.js';
10
- import { Portal } from '../../../ui/Portal/index.js';
11
- import { SignUpPropsProvider } from './SignUpContext.js';
12
- import { SignUpForm } from './SignUpForm.js';
13
- export function SignUp(props) {
14
- const signUpStore = useGlobalStore(useShallow((ctx) => ctx.signUp));
15
- return (_jsx(SignUpPropsProvider, { value: props, children: _jsx(Dialog.Root, { open: signUpStore.open, onOpenChange: (details) => {
16
- signUpStore.setOpen(details.open);
17
- }, lazyMount: true, unmountOnExit: true, closeOnEscape: false, closeOnInteractOutside: false, children: _jsxs(Portal, { children: [_jsx(Dialog.Backdrop, {}), _jsx(Dialog.Positioner, { children: _jsxs(Dialog.Content, { className: twMerge('bg-bg-primary-alt mx-auto h-full w-full items-start overflow-y-auto p-3xl pb-4xl lg:h-auto lg:w-[400px] lg:rounded-xl', props.className), children: [_jsx(Dialog.CloseTrigger, { children: _jsx(XIcon, {}) }), _jsx(Image, { src: props.logo, alt: "", width: 200, height: 100, className: "mx-auto h-auto w-[120px]", draggable: false }), _jsx(Suspense, { children: _jsx(SignUpForm, {}) })] }) })] }) }) }));
18
- }
@@ -1,6 +0,0 @@
1
- import type { SignUpProps } from './SignUp.lazy';
2
- export declare const SignUpPropsProvider: (props: {
3
- value: SignUpProps;
4
- } & {
5
- children?: import("react").ReactNode | undefined;
6
- }) => React.ReactNode, useSignUpPropsContext: () => SignUpProps;
@@ -1,2 +0,0 @@
1
- import { createContext } from '../../../client/utils/createContext.js';
2
- export const [SignUpPropsProvider, useSignUpPropsContext] = createContext();
@@ -1 +0,0 @@
1
- export declare function SignUpForm(): import("react/jsx-runtime").JSX.Element;
@@ -1,310 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
- import { createListCollection, parseDate } from '@ark-ui/react';
4
- import { zodResolver } from '@hookform/resolvers/zod';
5
- import { ObjectId } from '@opexa/object-id';
6
- import { differenceInYears, format } from 'date-fns';
7
- import { useSearchParams } from 'next/navigation';
8
- import { useEffect, useRef, useState } from 'react';
9
- import { Controller, useForm } from 'react-hook-form';
10
- import { twMerge } from 'tailwind-merge';
11
- import { z } from 'zod';
12
- import { useShallow } from 'zustand/shallow';
13
- import { useControllableState } from '../../../client/hooks/useControllableState.js';
14
- import { useCooldown } from '../../../client/hooks/useCooldown.js';
15
- import { useGlobalStore } from '../../../client/hooks/useGlobalStore.js';
16
- import { useLocaleInfo } from '../../../client/hooks/useLocaleInfo.js';
17
- import { useMobileNumberParser } from '../../../client/hooks/useMobileNumberParser.js';
18
- import { useSendVerificationCodeMutation } from '../../../client/hooks/useSendVerificationCodeMutation.js';
19
- import { useSignInMutation } from '../../../client/hooks/useSignInMutation.js';
20
- import { useSignUpMutation } from '../../../client/hooks/useSignUpMutation.js';
21
- import { useUpdateAccountMutation } from '../../../client/hooks/useUpdateAccountMutation.js';
22
- import { toaster } from '../../../client/utils/toaster.js';
23
- import { BRANCHES } from '../../../constants/index.js';
24
- import { ArrowLeftIcon } from '../../../icons/ArrowLeftIcon.js';
25
- import { CalendarIcon } from '../../../icons/CalendarIcon.js';
26
- import { CheckIcon } from '../../../icons/CheckIcon.js';
27
- import { ChevronDownIcon } from '../../../icons/ChevronDownIcon.js';
28
- import { ChevronLeftIcon } from '../../../icons/ChevronLeftIcon.js';
29
- import { ChevronRightIcon } from '../../../icons/ChevronRightIcon.js';
30
- import { HelpCircleIcon } from '../../../icons/HelpCircleIcon.js';
31
- import { ObjectType } from '../../../services/ObjectType.js';
32
- import { Button } from '../../../ui/Button/index.js';
33
- import { Checkbox } from '../../../ui/Checkbox/index.js';
34
- import { DatePicker } from '../../../ui/DatePicker/index.js';
35
- import { Field } from '../../../ui/Field/index.js';
36
- import { PinInput } from '../../../ui/PinInput/index.js';
37
- import { Select } from '../../../ui/Select/index.js';
38
- import { Tooltip } from '../../../ui/Tooltip/index.js';
39
- import { createPoll } from '../../../utils/createPoll.js';
40
- import { ResponsibleGaming } from '../../Disclaimer/ResponsibleGaming.js';
41
- import { TermsOfUse } from '../../Disclaimer/TermsOfUse.js';
42
- import { useSignUpPropsContext } from './SignUpContext.js';
43
- export function SignUpForm() {
44
- const signUpProps = useSignUpPropsContext();
45
- const branchCollection = createListCollection({
46
- items: signUpProps.branches ?? BRANCHES,
47
- itemToValue: (item) => item.code,
48
- itemToString: (item) => `${item.code} - ${item.name}`,
49
- });
50
- const [step, setStep] = useState(1);
51
- const globalStore = useGlobalStore(useShallow((ctx) => ({
52
- kycReminder: ctx.kycReminder,
53
- signIn: ctx.signIn,
54
- signUp: ctx.signUp,
55
- })));
56
- const search = useSearchParams();
57
- const signUpMutation = useSignUpMutation();
58
- const signInMutation = useSignInMutation();
59
- const updateAccountMutation = useUpdateAccountMutation();
60
- const sendVerificationCodeMutation = useSendVerificationCodeMutation();
61
- const localeInfo = useLocaleInfo();
62
- const mobileNumberParser = useMobileNumberParser();
63
- const Step1Definition = z.object({
64
- mobileNumber: z
65
- .string()
66
- .min(1, 'Mobile number is required')
67
- .superRefine((v, ctx) => {
68
- if (!mobileNumberParser.validate(v)) {
69
- ctx.addIssue({
70
- code: z.ZodIssueCode.custom,
71
- message: 'Invalid mobile number',
72
- });
73
- }
74
- }),
75
- termsAccepted: z.boolean().superRefine((v, ctx) => {
76
- if (!v) {
77
- ctx.addIssue({
78
- code: z.ZodIssueCode.custom,
79
- message: 'You must accept the terms and conditions and the responsible gaming guidelines',
80
- });
81
- }
82
- }),
83
- realName: z
84
- .string()
85
- .min(2, 'Real name must be 2 or more characters')
86
- .max(50, 'Real name must not be more than 50 characters')
87
- .trim(),
88
- birthDay: z
89
- .date({
90
- invalid_type_error: 'Date of birth is required',
91
- required_error: 'Date of birth is required',
92
- })
93
- .superRefine((val, ctx) => {
94
- const now = new Date();
95
- const age = differenceInYears(now, val);
96
- if (age < 21) {
97
- return ctx.addIssue({
98
- code: z.ZodIssueCode.custom,
99
- message: 'You must be at least 21 years old',
100
- });
101
- }
102
- }),
103
- branchCode: z.string().min(1, 'Branch is required').trim(),
104
- });
105
- const Step2Definition = z.object({
106
- verificationCode: z.array(z.string()).superRefine((val, ctx) => {
107
- if (val.length !== 6 || val.some((v) => v.length !== 1)) {
108
- ctx.addIssue({
109
- code: z.ZodIssueCode.custom,
110
- message: 'Please Enter your 6 digits verification code',
111
- });
112
- }
113
- }),
114
- });
115
- const step1Form = useForm({
116
- mode: 'all',
117
- resolver: zodResolver(Step1Definition),
118
- defaultValues: {
119
- mobileNumber: '',
120
- termsAccepted: false,
121
- branchCode: signUpProps?.branches?.[0]?.code ?? BRANCHES[0].code,
122
- realName: '',
123
- },
124
- });
125
- const step2Form = useForm({
126
- resolver: zodResolver(Step2Definition),
127
- defaultValues: {
128
- verificationCode: Array.from({ length: 6 }).fill(''),
129
- },
130
- });
131
- const cooldown = useCooldown({
132
- max: 60,
133
- duration: 1000 * 60,
134
- });
135
- const form2Ref = useRef(null);
136
- const birthDay = step1Form.watch('birthDay');
137
- const branchCode = step1Form.watch('branchCode', '');
138
- const [isTermsOfUseOpen, setTermsOfUseOpen] = useState(false);
139
- const [isResponsibleGamingOpen, setResponsibleGamingOpen] = useState(false);
140
- const [isTermsOfUseAccepted, setIsTermsOfUseAccepted] = useState(false);
141
- const [isResponsibleGamingAccepted, setIsResponsibleGamingAccepted] = useState(false);
142
- useEffect(() => {
143
- if (isTermsOfUseAccepted && isResponsibleGamingAccepted) {
144
- step1Form.setValue('termsAccepted', true);
145
- }
146
- }, [isResponsibleGamingAccepted, isTermsOfUseAccepted, step1Form]);
147
- return (_jsxs(_Fragment, { children: [_jsx(TermsOfUse, { termsOfUseContent: signUpProps.termsOfUseContent ?? 'Terms of Use content', siteName: signUpProps.siteName ?? 'Site', logo: signUpProps.logo, open: isTermsOfUseOpen, onCloseAction: () => {
148
- setIsTermsOfUseAccepted(true);
149
- setTermsOfUseOpen(false);
150
- }, responsibleGamingLogo: signUpProps.responsibleGamingLogo }), _jsx(ResponsibleGaming, { responsibleGamingContent: signUpProps.responsibleGamingContent ?? 'Responsible Gaming content', logo: signUpProps.logo, open: isResponsibleGamingOpen, onCloseAction: () => {
151
- setIsResponsibleGamingAccepted(true);
152
- setResponsibleGamingOpen(false);
153
- }, responsibleGamingLogo: signUpProps.responsibleGamingLogo }), step === 1 && (_jsxs(_Fragment, { children: [_jsx("h2", { className: "mt-xl text-center text-lg font-semibold", children: "Create an account" }), _jsx("p", { className: "text-text-secondary-700 mt-xs text-center text-sm", children: "Register instantly and start playing!" }), _jsxs("form", { className: "mt-3xl", autoComplete: "off", onSubmit: step1Form.handleSubmit(async (data) => {
154
- try {
155
- await sendVerificationCodeMutation.mutateAsync({
156
- channel: 'SMS',
157
- recipient: mobileNumberParser.format(data.mobileNumber),
158
- });
159
- setStep(2);
160
- cooldown.start();
161
- }
162
- catch (e) {
163
- toaster.error({
164
- description: e instanceof Error
165
- ? e.message
166
- : 'Failed to send verification code',
167
- });
168
- }
169
- }), children: [_jsxs(Field.Root, { invalid: !!step1Form.formState.errors.mobileNumber, children: [_jsx(Field.Label, { children: "Mobile Number" }), _jsxs("div", { className: "relative", children: [_jsxs("div", { className: "absolute left-3.5 top-1/2 flex shrink-0 -translate-y-1/2 items-center gap-md", children: [_jsx(localeInfo.country.flag, { className: "size-5" }), _jsx("span", { className: "text-text-placeholder", children: localeInfo.mobileNumber.areaCode })] }), _jsx(Field.Input, { style: {
170
- paddingLeft: `calc(2.75rem + ${localeInfo.mobileNumber.areaCode.length}ch)`,
171
- }, ...step1Form.register('mobileNumber') })] }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.mobileNumber?.message })] }), _jsxs(Field.Root, { invalid: !!step1Form.formState.errors.realName, className: "mt-xl", children: [_jsx(Field.Label, { children: "Real Name" }), _jsx(Field.Input, { placeholder: "Enter your real name", ...step1Form.register('realName') }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.realName?.message })] }), _jsxs(Field.Root, { invalid: !!step1Form.formState.errors.birthDay, className: "mt-xl", children: [_jsx(DateOfBirthField, { value: birthDay, onChange: (value) => {
172
- if (!value)
173
- return;
174
- step1Form.setValue('birthDay', value, {
175
- shouldDirty: true,
176
- shouldTouch: true,
177
- shouldValidate: true,
178
- });
179
- }, onBlur: () => {
180
- step1Form.trigger('birthDay');
181
- } }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.birthDay?.message })] }), _jsxs(Field.Root, { invalid: !!step1Form.formState.errors.branchCode, className: "mt-xl", children: [_jsxs(Select.Root, { value: [branchCode], onValueChange: (details) => {
182
- step1Form.setValue('branchCode', details.value.at(0) ??
183
- signUpProps?.branches?.[0]?.code ??
184
- BRANCHES[0].code, {
185
- shouldDirty: true,
186
- shouldTouch: true,
187
- shouldValidate: true,
188
- });
189
- }, collection: branchCollection, positioning: {
190
- sameWidth: true,
191
- placement: 'bottom',
192
- }, lazyMount: true, unmountOnExit: true, children: [_jsxs(Select.Label, { className: "flex items-center gap-1", children: ["Branch", _jsxs(Tooltip.Root, { openDelay: 0, closeDelay: 100, lazyMount: true, unmountOnExit: true, positioning: {
193
- placement: 'top',
194
- }, children: [_jsx(Tooltip.Trigger, { children: _jsx(HelpCircleIcon, { className: "text-text-nav-item-button-icon size-4" }) }), _jsx(Tooltip.Positioner, { children: _jsxs(Tooltip.Content, { children: [_jsx(Tooltip.Arrow, { children: _jsx(Tooltip.ArrowTip, {}) }), "Choose branch closest to your residence."] }) })] })] }), _jsxs(Select.Trigger, { children: [_jsx(Select.ValueText, {}), _jsx(Select.Indicator, { asChild: true, children: _jsx(ChevronDownIcon, {}) })] }), _jsx(Select.Positioner, { children: _jsx(Select.Content, { children: branchCollection.items.map((item) => {
195
- const label = branchCollection.stringifyItem(item) ?? '';
196
- return (_jsx(Select.Item, { item: item, "aria-disabled": item.disabled, className: twMerge(item.disabled && 'text-border-disabled'), children: _jsx("div", { title: label, className: "line-clamp-1", children: label }) }, item.code));
197
- }) }) })] }), _jsx(Field.ErrorText, { children: step1Form.formState.errors.branchCode?.message })] }), _jsx(Controller, { control: step1Form.control, name: "termsAccepted", render: (o) => (_jsxs(Field.Root, { className: "mt-2xl", invalid: o.fieldState.invalid, children: [_jsxs(Checkbox.Root, { checked: o.field.value, onCheckedChange: (details) => {
198
- o.field.onChange(details.checked);
199
- if (!details.checked) {
200
- setIsTermsOfUseAccepted(false);
201
- setIsResponsibleGamingAccepted(false);
202
- }
203
- }, children: [_jsx(Checkbox.Control, { children: _jsx(Checkbox.Indicator, { asChild: true, children: _jsx(CheckIcon, {}) }) }), _jsxs(Checkbox.Label, { children: ["I am at least 21 years of age and I have read and accept the", ' ', _jsx("button", { type: "button", className: "text-brand-400 underline underline-offset-2", onClick: () => {
204
- setTermsOfUseOpen(true);
205
- }, children: "Terms and Conditions" }), ' ', "and", ' ', _jsx("button", { type: "button", className: "text-brand-400 underline underline-offset-2", onClick: () => {
206
- setResponsibleGamingOpen(true);
207
- }, children: "Responsible Gaming" }), ' ', "guidelines."] }), _jsx(Checkbox.HiddenInput, {})] }), _jsx(Field.ErrorText, { className: "ml-6 text-xs", children: o.fieldState.error?.message })] })) }), _jsx(Button, { type: "submit", className: "mt-3xl", disabled: step1Form.formState.isSubmitting, children: "Create Account" })] }), _jsxs("div", { className: "mt-6 flex w-full items-center justify-center gap-xs text-sm", children: [_jsx("span", { className: "text-text-tertiary-600", children: "Already have an account?" }), _jsx("button", { type: "submit", className: "text-button-tertiary-fg font-semibold", onClick: () => {
208
- globalStore.signUp.setOpen(false);
209
- globalStore.signIn.setOpen(true);
210
- }, children: "Log In" })] })] })), step === 2 && (_jsxs(_Fragment, { children: [_jsx("h2", { className: "mt-xl text-center text-lg font-semibold", children: "Check your Phone" }), _jsxs("p", { className: "text-text-secondary-700 mt-xs text-center text-sm", children: ["We\u2019ve sent a verification code to your mobile number", ' ', _jsx("span", { className: "font-semibold", children: mobileNumberParser.format(step1Form.getValues('mobileNumber')) }), ' ', "via text"] }), _jsxs("form", { ref: form2Ref, className: "mt-5", onSubmit: step2Form.handleSubmit(async ({ verificationCode }) => {
211
- const id = ObjectId.generate(ObjectType.MemberAccount).toString();
212
- const { mobileNumber } = step1Form.getValues();
213
- try {
214
- await signUpMutation.mutateAsync({
215
- id,
216
- mobileNumber: mobileNumberParser.format(mobileNumber),
217
- verificationCode: verificationCode.join(''),
218
- referralCode: search.get('referralCode') ?? undefined,
219
- btag: search.get('btag') ?? undefined,
220
- });
221
- const name = mobileNumberParser.format(mobileNumber);
222
- const password = `${name}${id}`;
223
- const pollLogin = createPoll(async () => {
224
- try {
225
- await signInMutation.mutateAsync({
226
- type: 'NAME_AND_PASSWORD',
227
- name,
228
- password,
229
- });
230
- return true;
231
- }
232
- catch {
233
- return false;
234
- }
235
- }, {
236
- until: (ok) => ok,
237
- maxAttempt: 5,
238
- });
239
- const ok = await pollLogin();
240
- if (!ok) {
241
- globalStore.signIn.setOpen(true);
242
- return;
243
- }
244
- else {
245
- const pollUpdateAccount = createPoll(async () => {
246
- try {
247
- await updateAccountMutation.mutateAsync({
248
- branchCode: step1Form.getValues('branchCode'),
249
- realName: step1Form.getValues('realName'),
250
- birthDay: format(step1Form.getValues('birthDay'), 'yyyy-MM-dd'),
251
- });
252
- return true;
253
- }
254
- catch {
255
- return false;
256
- }
257
- }, {
258
- until: (ok) => ok,
259
- maxAttempt: 5,
260
- interval: 300,
261
- });
262
- await pollUpdateAccount();
263
- }
264
- globalStore.signUp.setOpen(false);
265
- globalStore.kycReminder.setOpen(true);
266
- step1Form.reset();
267
- step2Form.reset();
268
- setStep(1);
269
- }
270
- catch (error) {
271
- toaster.error({
272
- description: error instanceof Error
273
- ? error.message
274
- : 'Invalid Verification Code',
275
- });
276
- }
277
- }), children: [_jsx(Controller, { name: "verificationCode", control: step2Form.control, render: (o) => (_jsxs(Field.Root, { invalid: o.fieldState.invalid, children: [_jsxs(PinInput.Root, { placeholder: "0", value: o.field.value, onValueChange: (details) => {
278
- o.field.onChange(details.value);
279
- }, onValueComplete: () => {
280
- form2Ref.current?.requestSubmit();
281
- }, blurOnComplete: true, readOnly: step2Form.formState.isSubmitting, type: "numeric", children: [_jsxs(PinInput.Control, { className: "grid-cols-[1fr_1fr_1fr_auto_1fr_1fr_1fr] items-center gap-md", children: [_jsx(PinInput.Input, { index: 0 }), _jsx(PinInput.Input, { index: 1 }), _jsx(PinInput.Input, { index: 2 }), _jsx("span", { className: "text-text-placeholder-subtle text-2xl font-medium", children: "\u2013" }), _jsx(PinInput.Input, { index: 3 }), _jsx(PinInput.Input, { index: 4 }), _jsx(PinInput.Input, { index: 5 })] }), _jsx(PinInput.HiddenInput, {})] }), _jsx(Field.ErrorText, { children: o.formState.errors.verificationCode?.message })] })) }), _jsx(Button, { type: "submit", className: "mt-4xl", disabled: step2Form.formState.isSubmitting, children: "Verify" }), _jsxs("div", { className: "mt-3 flex w-full items-center justify-center gap-xs text-sm", children: [_jsx("span", { className: "text-text-secondary-700", children: "Didn't recieve the code?" }), _jsx("button", { type: "button", className: "text-button-secondary-fg font-semibold disabled:cursor-not-allowed disabled:opacity-75", disabled: cooldown.cooling, onClick: async () => {
282
- await sendVerificationCodeMutation.mutateAsync({
283
- channel: 'SMS',
284
- recipient: mobileNumberParser.format(step1Form.getValues('mobileNumber')),
285
- });
286
- cooldown.start();
287
- }, children: cooldown.cooling
288
- ? `Resend in ${cooldown.countdown}s`
289
- : 'Resend' })] }), _jsxs("button", { type: "button", className: "text-text-tertiary-600 mx-auto mt-3xl flex w-fit items-center gap-1 text-sm font-semibold", onClick: () => {
290
- setStep(1);
291
- step2Form.reset();
292
- cooldown.stop();
293
- }, children: [_jsx(ArrowLeftIcon, { className: "size-5" }), "Back"] })] })] }))] }));
294
- }
295
- const DEVICE_TIMEZONE = Intl.DateTimeFormat().resolvedOptions().timeZone;
296
- function DateOfBirthField(props) {
297
- const [value, setValue] = useControllableState({
298
- value: props.value,
299
- defaultValue: props.defaultValue ?? null,
300
- onChange: props.onChange,
301
- });
302
- return (_jsxs(DatePicker.Root, { size: "md", variant: "outline", placeholder: "MM/DD/YYYY", lazyMount: true, unmountOnExit: true, fixedWeeks: true, selectionMode: "single", value: value ? [parseDate(value)] : [], onValueChange: (details) => {
303
- const value = details.value.at(0)?.toDate(DEVICE_TIMEZONE);
304
- setValue(value ?? null);
305
- }, children: [_jsx(DatePicker.Label, { children: "Date of Birth" }), _jsxs(DatePicker.Control, { children: [_jsx(DatePicker.Input, { onBlur: props.onBlur, onFocus: props.onFocus }), _jsx(DatePicker.Trigger, { children: _jsx(CalendarIcon, {}) })] }), _jsx(DatePicker.Positioner, { children: _jsxs(DatePicker.Content, { children: [_jsx(DatePicker.View, { view: "day", children: _jsx(DatePicker.Context, { children: (api) => (_jsxs(_Fragment, { children: [_jsxs(DatePicker.ViewControl, { children: [_jsx(DatePicker.PrevTrigger, { children: _jsx(ChevronLeftIcon, {}) }), _jsx(DatePicker.ViewTrigger, { children: _jsx(DatePicker.RangeText, {}) }), _jsx(DatePicker.NextTrigger, { children: _jsx(ChevronRightIcon, {}) })] }), _jsxs(DatePicker.Table, { children: [_jsx(DatePicker.TableHead, { children: _jsx(DatePicker.TableRow, { children: api.weekDays.map((weekDay, id) => (_jsx(DatePicker.TableHeader, { children: weekDay.short.substring(0, 2) }, id))) }) }), _jsx(DatePicker.TableBody, { children: api.weeks.map((week, id) => (_jsx(DatePicker.TableRow, { children: week.map((day, id) => (_jsx(DatePicker.TableCell, { value: day, children: _jsx(DatePicker.TableCellTrigger, { children: day.day }) }, id))) }, id))) })] })] })) }) }), _jsx(DatePicker.View, { view: "month", children: _jsx(DatePicker.Context, { children: (datePicker) => (_jsxs(_Fragment, { children: [_jsxs(DatePicker.ViewControl, { children: [_jsx(DatePicker.PrevTrigger, { children: _jsx(ChevronLeftIcon, {}) }), _jsx(DatePicker.ViewTrigger, { children: _jsx(DatePicker.RangeText, {}) }), _jsx(DatePicker.NextTrigger, { children: _jsx(ChevronRightIcon, {}) })] }), _jsx(DatePicker.Table, { children: _jsx(DatePicker.TableBody, { children: datePicker
306
- .getMonthsGrid({ columns: 4, format: 'short' })
307
- .map((months, id) => (_jsx(DatePicker.TableRow, { children: months.map((month, id) => (_jsx(DatePicker.TableCell, { value: month.value, children: _jsx(DatePicker.TableCellTrigger, { className: "w-[4.425rem]", children: month.label }) }, id))) }, id))) }) })] })) }) }), _jsx(DatePicker.View, { view: "year", children: _jsx(DatePicker.Context, { children: (datePicker) => (_jsxs(_Fragment, { children: [_jsxs(DatePicker.ViewControl, { children: [_jsx(DatePicker.PrevTrigger, { children: _jsx(ChevronLeftIcon, {}) }), _jsx(DatePicker.ViewTrigger, { children: _jsx(DatePicker.RangeText, {}) }), _jsx(DatePicker.NextTrigger, { children: _jsx(ChevronRightIcon, {}) })] }), _jsx(DatePicker.Table, { children: _jsx(DatePicker.TableBody, { children: datePicker
308
- .getYearsGrid({ columns: 4 })
309
- .map((years, id) => (_jsx(DatePicker.TableRow, { children: years.map((year, id) => (_jsx(DatePicker.TableCell, { value: year.value, children: _jsx(DatePicker.TableCellTrigger, { className: "w-[4.425rem]", children: year.label }) }, id))) }, id))) }) })] })) }) })] }) })] }));
310
- }
@@ -1 +0,0 @@
1
- export declare function SignUpForm(): import("react/jsx-runtime").JSX.Element;