@opexa/portal-components 0.0.884 → 0.0.886

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 (225) hide show
  1. package/dist/components/Banner/Banner.client.d.ts +12 -0
  2. package/dist/components/Banner/Banner.client.js +49 -0
  3. package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/OnlineBankDepositContext.d.ts +2 -2
  4. package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/useOnlineBankDeposit.d.ts +1 -1
  5. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositContext.d.ts +2 -2
  6. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/useQRPHDeposit.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__legacy/OnlineBankDeposit/OnlineBankDepositContext.d.ts +2 -2
  10. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/useOnlineBankDeposit.d.ts +1 -1
  11. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositContext.d.ts +2 -2
  12. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/useQRPHDeposit.d.ts +1 -1
  13. package/dist/components/DigitainLauncher/Loading.js +1 -1
  14. package/dist/components/Jackpots/Jackpots.module.css +288 -288
  15. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarousel.client.js +2 -1
  16. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.CrazyWin.js +4 -4
  17. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.HappyBingo.d.ts +9 -0
  18. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.HappyBingo.js +160 -0
  19. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.module.css +184 -184
  20. package/dist/components/Jackpots/JackpotsList/JackpotsList.d.ts +1 -0
  21. package/dist/components/Jackpots/JackpotsList/JackpotsList.js +2 -1
  22. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.CrazyWin.d.ts +6 -0
  23. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.CrazyWin.js +173 -0
  24. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.module.css +184 -184
  25. package/dist/components/Jackpots/JackpotsList/JackpotsListItemGameProviders.d.ts +3 -1
  26. package/dist/components/Jackpots/JackpotsList/JackpotsListItemGameProviders.js +2 -2
  27. package/dist/components/Jackpots/utils.d.ts +14 -1
  28. package/dist/components/Jackpots/utils.js +53 -1
  29. package/dist/components/KYC/BasicInformation.js +1 -1
  30. package/dist/components/KYC/IdentityVerification.js +1 -1
  31. package/dist/components/KYC/KYC.lazy.js +1 -1
  32. package/dist/components/KYC/KYCDefault/KYCVerificationStatus.lazy.js +2 -2
  33. package/dist/components/KYC/KYCNonPagCor/IdentityVerification.js +3 -1
  34. package/dist/components/KYC/KYCNonPagCor/KYCVerificationStatus.lazy.js +2 -2
  35. package/dist/components/KYC/KYCNonPagCor/PersonalInformation.js +2 -2
  36. package/dist/components/KYC/KYCVerificationStatus.lazy.js +5 -8
  37. package/dist/components/KYC/PersonalInformation.js +1 -1
  38. package/dist/components/PortalProvider/AndroidOnlyComponents.d.ts +1 -0
  39. package/dist/components/PortalProvider/AndroidOnlyComponents.js +12 -0
  40. package/dist/components/PortalProvider/CXDTokenObserver.js +11 -11
  41. package/dist/components/SignIn/MobileNumberField.js +5 -4
  42. package/dist/components/Tournaments/TournamentsCarousel/TournamentsCarouselItem.module.css +184 -184
  43. package/dist/components/Tournaments/TournamentsList/TournamentItem.module.css +184 -184
  44. package/dist/icons/User02Icon.d.ts +2 -0
  45. package/dist/icons/User02Icon.js +4 -0
  46. package/dist/images/happy-bingo-coins.webp +0 -0
  47. package/dist/images/phone-icon.svg +10 -10
  48. package/dist/services/queries.js +3153 -3153
  49. package/dist/styles/theme.css +776 -776
  50. package/dist/ui/AlertDialog/AlertDialog.d.ts +55 -55
  51. package/dist/ui/AlertDialog/alertDialog.recipe.d.ts +5 -5
  52. package/dist/ui/Badge/Badge.d.ts +12 -12
  53. package/dist/ui/Badge/badge.anatomy.d.ts +1 -1
  54. package/dist/ui/Badge/badge.recipe.d.ts +3 -3
  55. package/dist/ui/Carousel/Carousel.d.ts +45 -45
  56. package/dist/ui/Carousel/carousel.recipe.d.ts +5 -5
  57. package/dist/ui/Dialog/Dialog.d.ts +33 -33
  58. package/dist/ui/Dialog/dialog.recipe.d.ts +3 -3
  59. package/dist/ui/Drawer/Drawer.d.ts +33 -33
  60. package/dist/ui/Drawer/drawer.recipe.d.ts +3 -3
  61. package/dist/ui/Menu/Menu.d.ts +252 -252
  62. package/dist/ui/Menu/menu.recipe.d.ts +14 -14
  63. package/dist/ui/Popover/Popover.d.ts +121 -121
  64. package/dist/ui/Popover/popover.recipe.d.ts +11 -11
  65. package/dist/ui/QrCode/QrCode.d.ts +25 -25
  66. package/dist/ui/QrCode/qrCode.recipe.d.ts +5 -5
  67. package/dist/ui/SegmentGroup/SegmentGroup.d.ts +18 -18
  68. package/dist/ui/SegmentGroup/segmentGroup.recipe.d.ts +3 -3
  69. package/dist/ui/Select/Select.d.ts +45 -45
  70. package/dist/ui/Select/select.recipe.d.ts +3 -3
  71. package/dist/ui/Table/Table.d.ts +21 -21
  72. package/dist/ui/Table/table.anatomy.d.ts +1 -1
  73. package/dist/ui/Table/table.recipe.d.ts +3 -3
  74. package/dist/utils/countries/types.d.ts +1 -1
  75. package/package.json +177 -177
  76. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Confirmed.d.ts +0 -1
  77. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Confirmed.js +0 -11
  78. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Failed.d.ts +0 -1
  79. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Failed.js +0 -11
  80. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Form.d.ts +0 -1
  81. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Form.js +0 -126
  82. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/GeneratingQrCode.d.ts +0 -1
  83. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/GeneratingQrCode.js +0 -10
  84. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDeposit.d.ts +0 -1
  85. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDeposit.js +0 -12
  86. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.d.ts +0 -17
  87. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.js +0 -2
  88. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QrCodeGenerated.d.ts +0 -1
  89. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QrCodeGenerated.js +0 -41
  90. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.d.ts +0 -13
  91. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.js +0 -91
  92. package/dist/components/Disclaimer/ResponsibleGaming.d.ts +0 -10
  93. package/dist/components/Disclaimer/ResponsibleGaming.js +0 -13
  94. package/dist/components/Disclaimer/TermsOfUse.d.ts +0 -11
  95. package/dist/components/Disclaimer/TermsOfUse.js +0 -13
  96. package/dist/components/FeatureFlag/FeatureFlag.d.ts +0 -1
  97. package/dist/components/FeatureFlag/FeatureFlag.js +0 -29
  98. package/dist/components/FeatureFlag/index.d.ts +0 -1
  99. package/dist/components/FeatureFlag/index.js +0 -1
  100. package/dist/components/KYC/AutoOpen.d.ts +0 -1
  101. package/dist/components/KYC/AutoOpen.js +0 -40
  102. package/dist/components/KYC/CaptureIdDocument.d.ts +0 -1
  103. package/dist/components/KYC/CaptureIdDocument.js +0 -219
  104. package/dist/components/KYC/CaptureSelfie.d.ts +0 -1
  105. package/dist/components/KYC/CaptureSelfie.js +0 -285
  106. package/dist/components/KYC/DisplayImage.d.ts +0 -5
  107. package/dist/components/KYC/DisplayImage.js +0 -8
  108. package/dist/components/KYC/FileUpload.d.ts +0 -10
  109. package/dist/components/KYC/FileUpload.js +0 -72
  110. package/dist/components/KYC/NoCameraError.d.ts +0 -7
  111. package/dist/components/KYC/NoCameraError.js +0 -6
  112. package/dist/components/KYC/PersonOverlayDesktop.d.ts +0 -7
  113. package/dist/components/KYC/PersonOverlayDesktop.js +0 -9
  114. package/dist/components/KYC/backup/Header.d.ts +0 -1
  115. package/dist/components/KYC/backup/Header.js +0 -8
  116. package/dist/components/KYC/backup/Indicator.d.ts +0 -1
  117. package/dist/components/KYC/backup/Indicator.js +0 -9
  118. package/dist/components/KYC/backup/KYC.d.ts +0 -1
  119. package/dist/components/KYC/backup/KYC.js +0 -14
  120. package/dist/components/KYC/backup/KYC.lazy.d.ts +0 -1
  121. package/dist/components/KYC/backup/KYC.lazy.js +0 -26
  122. package/dist/components/KYC/backup/KYCContext.d.ts +0 -6
  123. package/dist/components/KYC/backup/KYCContext.js +0 -2
  124. package/dist/components/KYC/backup/Step1.d.ts +0 -1
  125. package/dist/components/KYC/backup/Step1.js +0 -13
  126. package/dist/components/KYC/backup/Step2.d.ts +0 -1
  127. package/dist/components/KYC/backup/Step2.js +0 -13
  128. package/dist/components/KYC/backup/Step3.d.ts +0 -1
  129. package/dist/components/KYC/backup/Step3.js +0 -13
  130. package/dist/components/KYC/backup/Step4.d.ts +0 -1
  131. package/dist/components/KYC/backup/Step4.js +0 -7
  132. package/dist/components/KYC/backup/useKYC.d.ts +0 -10
  133. package/dist/components/KYC/backup/useKYC.js +0 -8
  134. package/dist/components/KYC/loadModels.d.ts +0 -1
  135. package/dist/components/KYC/loadModels.js +0 -9
  136. package/dist/components/KYC/utils.d.ts +0 -9
  137. package/dist/components/KYC/utils.js +0 -79
  138. package/dist/components/Messages/Message.d.ts +0 -1
  139. package/dist/components/Messages/Message.js +0 -35
  140. package/dist/components/Messages/MessageContext.d.ts +0 -6
  141. package/dist/components/Messages/MessageContext.js +0 -2
  142. package/dist/components/Messages/MessagePopup.d.ts +0 -1
  143. package/dist/components/Messages/MessagePopup.js +0 -20
  144. package/dist/components/Messages/MessageTrigger.d.ts +0 -8
  145. package/dist/components/Messages/MessageTrigger.js +0 -19
  146. package/dist/components/Quests/CountdownTimer.d.ts +0 -15
  147. package/dist/components/Quests/CountdownTimer.js +0 -33
  148. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.d.ts +0 -4
  149. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.js +0 -78
  150. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.d.ts +0 -8
  151. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.js +0 -9
  152. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.d.ts +0 -4
  153. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.js +0 -4
  154. package/dist/components/Quests/WageringQuest/WageringQuest.d.ts +0 -4
  155. package/dist/components/Quests/WageringQuest/WageringQuest.js +0 -20
  156. package/dist/components/Quests/WageringQuest/WageringQuestModal.d.ts +0 -9
  157. package/dist/components/Quests/WageringQuest/WageringQuestModal.js +0 -9
  158. package/dist/components/SignUp/SignUp.lazy.d.ts +0 -12
  159. package/dist/components/SignUp/SignUp.lazy.js +0 -18
  160. package/dist/components/SignUp/SignUpContext.d.ts +0 -6
  161. package/dist/components/SignUp/SignUpContext.js +0 -2
  162. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.d.ts +0 -17
  163. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.js +0 -18
  164. package/dist/components/SignUp/SignUpDefault/SignUpContext.d.ts +0 -6
  165. package/dist/components/SignUp/SignUpDefault/SignUpContext.js +0 -2
  166. package/dist/components/SignUp/SignUpDefault/SignUpForm.d.ts +0 -1
  167. package/dist/components/SignUp/SignUpDefault/SignUpForm.js +0 -310
  168. package/dist/components/SignUp/SignUpForm.d.ts +0 -1
  169. package/dist/components/SignUp/SignUpForm.js +0 -284
  170. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.d.ts +0 -1
  171. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.js +0 -198
  172. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.d.ts +0 -1
  173. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.js +0 -251
  174. package/dist/components/SignUp/SignUpKYC/ImageUploader.d.ts +0 -10
  175. package/dist/components/SignUp/SignUpKYC/ImageUploader.js +0 -42
  176. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.d.ts +0 -7
  177. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.js +0 -9
  178. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.d.ts +0 -1
  179. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.js +0 -464
  180. package/dist/components/SignUp/SignUpKYC/useImageUploader.d.ts +0 -11
  181. package/dist/components/SignUp/SignUpKYC/useImageUploader.js +0 -20
  182. package/dist/components/SignUp/SignUpKYC/utils.d.ts +0 -9
  183. package/dist/components/SignUp/SignUpKYC/utils.js +0 -79
  184. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.d.ts +0 -1
  185. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.js +0 -198
  186. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.d.ts +0 -1
  187. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.js +0 -251
  188. package/dist/components/SignUp/SignUpPagcor/ImageUploader.d.ts +0 -10
  189. package/dist/components/SignUp/SignUpPagcor/ImageUploader.js +0 -41
  190. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.d.ts +0 -1
  191. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.js +0 -429
  192. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.d.ts +0 -13
  193. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.js +0 -26
  194. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.d.ts +0 -7
  195. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.js +0 -2
  196. package/dist/components/SignUp/SignUpPagcor/useImageUploader.d.ts +0 -11
  197. package/dist/components/SignUp/SignUpPagcor/useImageUploader.js +0 -20
  198. package/dist/components/shared/IdDocumentField.client.d.ts +0 -25
  199. package/dist/components/shared/IdDocumentField.client.js +0 -204
  200. package/dist/components/shared/IdDocumentField.d.ts +0 -2
  201. package/dist/components/shared/IdDocumentField.js +0 -11
  202. package/dist/components/shared/SelfieField.client.d.ts +0 -20
  203. package/dist/components/shared/SelfieField.client.js +0 -327
  204. package/dist/components/shared/SelfieField.d.ts +0 -2
  205. package/dist/components/shared/SelfieField.js +0 -11
  206. package/dist/constants/BranchCode.d.ts +0 -4
  207. package/dist/constants/BranchCode.js +0 -42
  208. package/dist/handlers/postTransformIdFrontImage.d.ts +0 -3
  209. package/dist/handlers/postTransformIdFrontImage.js +0 -67
  210. package/dist/handlers/postTransformSelfieImage.d.ts +0 -3
  211. package/dist/handlers/postTransformSelfieImage.js +0 -71
  212. package/dist/handlers.d.ts +0 -43
  213. package/dist/handlers.js +0 -297
  214. package/dist/icons/BellRingIcon.d.ts +0 -2
  215. package/dist/icons/BellRingIcon.js +0 -4
  216. package/dist/utils/dataUrlToBlob.d.ts +0 -1
  217. package/dist/utils/dataUrlToBlob.js +0 -11
  218. package/dist/utils/gamesAvailable3pmTo3am.d.ts +0 -1
  219. package/dist/utils/gamesAvailable3pmTo3am.js +0 -1
  220. package/dist/utils/getGameName.d.ts +0 -1
  221. package/dist/utils/getGameName.js +0 -6
  222. package/dist/utils/isBetween3amAnd3pm.d.ts +0 -1
  223. package/dist/utils/isBetween3amAnd3pm.js +0 -5
  224. package/dist/utils/resizeImageSize.d.ts +0 -2
  225. 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,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;