@opexa/portal-components 0.0.933 → 0.0.935

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 (348) hide show
  1. package/dist/assets/providers/alize.png +0 -0
  2. package/dist/assets/providers/bigtime-gaming.png +0 -0
  3. package/dist/assets/providers/bng.png +0 -0
  4. package/dist/assets/providers/boongo.png +0 -0
  5. package/dist/assets/providers/btg.png +0 -0
  6. package/dist/assets/providers/cq9.png +0 -0
  7. package/dist/assets/providers/darwin.png +0 -0
  8. package/dist/assets/providers/digitain.png +0 -0
  9. package/dist/assets/providers/evolution.png +0 -0
  10. package/dist/assets/providers/fantasma-games.png +0 -0
  11. package/dist/assets/providers/fc.png +0 -0
  12. package/dist/assets/providers/fp.png +0 -0
  13. package/dist/assets/providers/habanero.png +0 -0
  14. package/dist/assets/providers/hacksaw.png +0 -0
  15. package/dist/assets/providers/jdb.png +0 -0
  16. package/dist/assets/providers/jili.png +0 -0
  17. package/dist/assets/providers/leap.png +0 -0
  18. package/dist/assets/providers/live-22-metaverse.png +0 -0
  19. package/dist/assets/providers/netent.png +0 -0
  20. package/dist/assets/providers/no-limit.png +0 -0
  21. package/dist/assets/providers/pg.png +0 -0
  22. package/dist/assets/providers/pgsoft.png +0 -0
  23. package/dist/assets/providers/pragmatic-play.png +0 -0
  24. package/dist/assets/providers/realtime-gaming.png +0 -0
  25. package/dist/assets/providers/redtiger.png +0 -0
  26. package/dist/assets/providers/rtg.png +0 -0
  27. package/dist/assets/providers/sagaming.png +0 -0
  28. package/dist/client/hooks/useAiOGCashDepositMutation.d.ts +4 -0
  29. package/dist/client/hooks/useAiOGCashDepositMutation.js +90 -0
  30. package/dist/client/hooks/useAiOGrabPayDepositMutation.d.ts +4 -0
  31. package/dist/client/hooks/useAiOGrabPayDepositMutation.js +80 -0
  32. package/dist/client/hooks/useAiOPalawanPayDepositMutation.d.ts +4 -0
  33. package/dist/client/hooks/useAiOPalawanPayDepositMutation.js +80 -0
  34. package/dist/client/hooks/useAiOPayMayaDepositMutation.d.ts +4 -0
  35. package/dist/client/hooks/useAiOPayMayaDepositMutation.js +80 -0
  36. package/dist/components/DepositWithdrawal/AiOPaymentMethods.d.ts +11 -0
  37. package/dist/components/DepositWithdrawal/AiOPaymentMethods.js +55 -0
  38. package/dist/components/DepositWithdrawal/Deposit/AurixPayPayMayaDeposit/AurixPayGrabPayDeposit.js +21 -2
  39. package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/OnlineBankDepositContext.d.ts +2 -2
  40. package/dist/components/DepositWithdrawal/Deposit/OnlineBankDeposit/useOnlineBankDeposit.d.ts +1 -1
  41. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositAlert.d.ts +1 -0
  42. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositAlert.js +99 -0
  43. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositDetails.d.ts +1 -0
  44. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositDetails.js +17 -0
  45. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositForm.d.ts +1 -0
  46. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositForm.js +116 -0
  47. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHQRCode.d.ts +3 -0
  48. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHQRCode.js +69 -0
  49. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDeposit.d.ts +1 -0
  50. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDeposit.js +10 -0
  51. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositAlert.d.ts +1 -0
  52. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositAlert.js +99 -0
  53. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositContext.d.ts +25 -0
  54. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositContext.js +2 -0
  55. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositDetails.d.ts +1 -0
  56. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositDetails.js +17 -0
  57. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositForm.d.ts +1 -0
  58. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositForm.js +116 -0
  59. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHQRCode.d.ts +3 -0
  60. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHQRCode.js +69 -0
  61. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/useQRPHDeposit.d.ts +13 -0
  62. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/useQRPHDeposit.js +85 -0
  63. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Confirmed.d.ts +1 -0
  64. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Confirmed.js +11 -0
  65. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Failed.d.ts +1 -0
  66. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Failed.js +11 -0
  67. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Form.d.ts +1 -0
  68. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Form.js +126 -0
  69. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/GeneratingQrCode.d.ts +1 -0
  70. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/GeneratingQrCode.js +10 -0
  71. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDeposit.d.ts +1 -0
  72. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDeposit.js +12 -0
  73. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.d.ts +17 -0
  74. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.js +2 -0
  75. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QrCodeGenerated.d.ts +1 -0
  76. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QrCodeGenerated.js +41 -0
  77. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.d.ts +13 -0
  78. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.js +91 -0
  79. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGCashDeposit/AiOGCashDeposit.d.ts +1 -0
  80. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGCashDeposit/AiOGCashDeposit.js +173 -0
  81. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGrabPayDeposit/AiOGrabPayDeposit.d.ts +1 -0
  82. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGrabPayDeposit/AiOGrabPayDeposit.js +171 -0
  83. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPalawanPayDeposit/AiOPalawanPayDeposit.d.ts +1 -0
  84. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPalawanPayDeposit/AiOPalawanPayDeposit.js +171 -0
  85. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPayMayaDeposit/AiOPayMayaDeposit.d.ts +1 -0
  86. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPayMayaDeposit/AiOPayMayaDeposit.js +171 -0
  87. package/dist/components/DepositWithdrawal/Deposit__legacy/AvailablePromos.d.ts +8 -0
  88. package/dist/components/DepositWithdrawal/Deposit__legacy/AvailablePromos.js +33 -0
  89. package/dist/components/DepositWithdrawal/Deposit__legacy/Deposit.d.ts +1 -0
  90. package/dist/components/DepositWithdrawal/Deposit__legacy/Deposit.js +120 -0
  91. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashDeposit/GCashDeposit.d.ts +1 -0
  92. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashDeposit/GCashDeposit.js +163 -0
  93. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashWebpayDeposit/GCashWebpayDeposit.d.ts +1 -0
  94. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashWebpayDeposit/GCashWebpayDeposit.js +165 -0
  95. package/dist/components/DepositWithdrawal/Deposit__legacy/LibanganDeposit/LibanganDeposit.d.ts +1 -0
  96. package/dist/components/DepositWithdrawal/Deposit__legacy/LibanganDeposit/LibanganDeposit.js +186 -0
  97. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaAppDeposit/MayaAppDeposit.d.ts +1 -0
  98. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaAppDeposit/MayaAppDeposit.js +157 -0
  99. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaDeposit/MayaDeposit.d.ts +1 -0
  100. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaDeposit/MayaDeposit.js +163 -0
  101. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaWebpayDeposit/MayaWebpayDeposit.d.ts +1 -0
  102. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaWebpayDeposit/MayaWebpayDeposit.js +166 -0
  103. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDeposit.d.ts +1 -0
  104. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDeposit.js +10 -0
  105. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositAlert.d.ts +1 -0
  106. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositAlert.js +99 -0
  107. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositContext.d.ts +25 -0
  108. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositContext.js +2 -0
  109. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositDetails.d.ts +1 -0
  110. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositDetails.js +19 -0
  111. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositForm.d.ts +1 -0
  112. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositForm.js +115 -0
  113. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/useOnlineBankDeposit.d.ts +13 -0
  114. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/useOnlineBankDeposit.js +81 -0
  115. package/dist/components/DepositWithdrawal/Deposit__legacy/PisoPayDeposit/PisoPayDeposit.d.ts +1 -0
  116. package/dist/components/DepositWithdrawal/Deposit__legacy/PisoPayDeposit/PisoPayDeposit.js +180 -0
  117. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDeposit.d.ts +1 -0
  118. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDeposit.js +10 -0
  119. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositAlert.d.ts +1 -0
  120. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositAlert.js +99 -0
  121. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositContext.d.ts +25 -0
  122. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositContext.js +2 -0
  123. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositDetails.d.ts +1 -0
  124. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositDetails.js +17 -0
  125. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositForm.d.ts +1 -0
  126. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositForm.js +116 -0
  127. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHQRCode.d.ts +3 -0
  128. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHQRCode.js +69 -0
  129. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/useQRPHDeposit.d.ts +13 -0
  130. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/useQRPHDeposit.js +85 -0
  131. package/dist/components/DigitainLauncher/Loading.d.ts +1 -0
  132. package/dist/components/DigitainLauncher/Loading.js +5 -0
  133. package/dist/components/Disclaimer/DisclaimerV3.js +5 -5
  134. package/dist/components/Disclaimer/ResponsibleGaming.d.ts +10 -0
  135. package/dist/components/Disclaimer/ResponsibleGaming.js +13 -0
  136. package/dist/components/Disclaimer/TermsOfUse.d.ts +11 -0
  137. package/dist/components/Disclaimer/TermsOfUse.js +13 -0
  138. package/dist/components/FeatureFlag/FeatureFlag.d.ts +1 -0
  139. package/dist/components/FeatureFlag/FeatureFlag.js +29 -0
  140. package/dist/components/FeatureFlag/index.d.ts +1 -0
  141. package/dist/components/FeatureFlag/index.js +1 -0
  142. package/dist/components/ForgotPassword/Crazywin/ForgotPassword.module.css +42 -42
  143. package/dist/components/Games/Game.js +2 -2
  144. package/dist/components/GamesSearch/GamesSearch.js +5 -3
  145. package/dist/components/Jackpots/Jackpots.module.css +288 -288
  146. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.module.css +184 -0
  147. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.module.css +184 -0
  148. package/dist/components/KYC/AutoOpen.d.ts +1 -0
  149. package/dist/components/KYC/AutoOpen.js +40 -0
  150. package/dist/components/KYC/BasicInformation.d.ts +1 -0
  151. package/dist/components/KYC/BasicInformation.js +101 -0
  152. package/dist/components/KYC/CaptureIdDocument.d.ts +1 -0
  153. package/dist/components/KYC/CaptureIdDocument.js +219 -0
  154. package/dist/components/KYC/CaptureSelfie.d.ts +1 -0
  155. package/dist/components/KYC/CaptureSelfie.js +285 -0
  156. package/dist/components/KYC/DisplayImage.d.ts +5 -0
  157. package/dist/components/KYC/DisplayImage.js +8 -0
  158. package/dist/components/KYC/FileUpload.d.ts +10 -0
  159. package/dist/components/KYC/FileUpload.js +72 -0
  160. package/dist/components/KYC/IdentityVerification.d.ts +1 -0
  161. package/dist/components/KYC/IdentityVerification.js +120 -0
  162. package/dist/components/KYC/Indicator.d.ts +1 -0
  163. package/dist/components/KYC/Indicator.js +8 -0
  164. package/dist/components/KYC/KYC.lazy.d.ts +6 -0
  165. package/dist/components/KYC/KYC.lazy.js +45 -0
  166. package/dist/components/KYC/KYCContext.d.ts +6 -0
  167. package/dist/components/KYC/KYCContext.js +2 -0
  168. package/dist/components/KYC/KYCDefault/BasicInformation.d.ts +1 -0
  169. package/dist/components/KYC/KYCDefault/BasicInformation.js +101 -0
  170. package/dist/components/KYC/KYCDefault/KYCVerificationStatus.lazy.js +2 -2
  171. package/dist/components/KYC/KYCNonPagCor/KYCVerificationStatus.lazy.js +2 -2
  172. package/dist/components/KYC/KYCVerificationStatus.d.ts +1 -0
  173. package/dist/components/KYC/KYCVerificationStatus.js +10 -0
  174. package/dist/components/KYC/KYCVerificationStatus.lazy.d.ts +1 -0
  175. package/dist/components/KYC/KYCVerificationStatus.lazy.js +39 -0
  176. package/dist/components/KYC/NoCameraError.d.ts +7 -0
  177. package/dist/components/KYC/NoCameraError.js +6 -0
  178. package/dist/components/KYC/PersonOverlayDesktop.d.ts +7 -0
  179. package/dist/components/KYC/PersonOverlayDesktop.js +9 -0
  180. package/dist/components/KYC/PersonalInformation.d.ts +1 -0
  181. package/dist/components/KYC/PersonalInformation.js +122 -0
  182. package/dist/components/KYC/backup/Header.d.ts +1 -0
  183. package/dist/components/KYC/backup/Header.js +8 -0
  184. package/dist/components/KYC/backup/Indicator.d.ts +1 -0
  185. package/dist/components/KYC/backup/Indicator.js +9 -0
  186. package/dist/components/KYC/backup/KYC.d.ts +1 -0
  187. package/dist/components/KYC/backup/KYC.js +14 -0
  188. package/dist/components/KYC/backup/KYC.lazy.d.ts +1 -0
  189. package/dist/components/KYC/backup/KYC.lazy.js +26 -0
  190. package/dist/components/KYC/backup/KYCContext.d.ts +6 -0
  191. package/dist/components/KYC/backup/KYCContext.js +2 -0
  192. package/dist/components/KYC/backup/Step1.d.ts +1 -0
  193. package/dist/components/KYC/backup/Step1.js +13 -0
  194. package/dist/components/KYC/backup/Step2.d.ts +1 -0
  195. package/dist/components/KYC/backup/Step2.js +13 -0
  196. package/dist/components/KYC/backup/Step3.d.ts +1 -0
  197. package/dist/components/KYC/backup/Step3.js +13 -0
  198. package/dist/components/KYC/backup/Step4.d.ts +1 -0
  199. package/dist/components/KYC/backup/Step4.js +7 -0
  200. package/dist/components/KYC/backup/useKYC.d.ts +10 -0
  201. package/dist/components/KYC/backup/useKYC.js +8 -0
  202. package/dist/components/KYC/loadModels.d.ts +1 -0
  203. package/dist/components/KYC/loadModels.js +9 -0
  204. package/dist/components/KYC/useKYC.d.ts +25 -0
  205. package/dist/components/KYC/useKYC.js +38 -0
  206. package/dist/components/KYC/utils.d.ts +9 -0
  207. package/dist/components/KYC/utils.js +79 -0
  208. package/dist/components/KYCNotRequired/KYCNotRequired.d.ts +0 -0
  209. package/dist/components/KYCNotRequired/KYCNotRequired.js +1 -0
  210. package/dist/components/Messages/Message.d.ts +1 -0
  211. package/dist/components/Messages/Message.js +35 -0
  212. package/dist/components/Messages/MessageContext.d.ts +6 -0
  213. package/dist/components/Messages/MessageContext.js +2 -0
  214. package/dist/components/Messages/MessagePopup.d.ts +1 -0
  215. package/dist/components/Messages/MessagePopup.js +20 -0
  216. package/dist/components/Messages/MessageTrigger.d.ts +8 -0
  217. package/dist/components/Messages/MessageTrigger.js +19 -0
  218. package/dist/components/PortalProvider/CXDTokenObserver.d.ts +1 -0
  219. package/dist/components/PortalProvider/CXDTokenObserver.js +30 -0
  220. package/dist/components/PortalProvider/LinkGoogleAccountObserver.d.ts +1 -0
  221. package/dist/components/PortalProvider/LinkGoogleAccountObserver.js +29 -0
  222. package/dist/components/Quests/CountdownTimer.d.ts +15 -0
  223. package/dist/components/Quests/CountdownTimer.js +33 -0
  224. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.d.ts +4 -0
  225. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.js +78 -0
  226. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.d.ts +8 -0
  227. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.js +9 -0
  228. package/dist/components/Quests/MultiWageringQuest.d.ts +1 -0
  229. package/dist/components/Quests/MultiWageringQuest.js +111 -0
  230. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.d.ts +4 -0
  231. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.js +4 -0
  232. package/dist/components/Quests/WageringQuest/WageringQuest.d.ts +4 -0
  233. package/dist/components/Quests/WageringQuest/WageringQuest.js +20 -0
  234. package/dist/components/Quests/WageringQuest/WageringQuestModal.d.ts +9 -0
  235. package/dist/components/Quests/WageringQuest/WageringQuestModal.js +9 -0
  236. package/dist/components/ResponsibleGaming/ResponsibleGaming.d.ts +1 -1
  237. package/dist/components/ResponsibleGaming/ResponsibleGaming.js +7 -0
  238. package/dist/components/ResponsibleGaming/ResponsibleGamingV3.lazy.d.ts +8 -0
  239. package/dist/components/ResponsibleGaming/ResponsibleGamingV3.lazy.js +71 -0
  240. package/dist/components/SessionWatcher/SessionWatcher.d.ts +1 -0
  241. package/dist/components/SessionWatcher/SessionWatcher.js +20 -0
  242. package/dist/components/SessionWatcher/index.d.ts +1 -0
  243. package/dist/components/SessionWatcher/index.js +1 -0
  244. package/dist/components/SignIn/utils.d.ts +8 -0
  245. package/dist/components/SignIn/utils.js +26 -0
  246. package/dist/components/SignUp/SignUp.lazy.d.ts +12 -0
  247. package/dist/components/SignUp/SignUp.lazy.js +18 -0
  248. package/dist/components/SignUp/SignUpContext.d.ts +6 -0
  249. package/dist/components/SignUp/SignUpContext.js +2 -0
  250. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.d.ts +17 -0
  251. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.js +18 -0
  252. package/dist/components/SignUp/SignUpDefault/SignUpContext.d.ts +6 -0
  253. package/dist/components/SignUp/SignUpDefault/SignUpContext.js +2 -0
  254. package/dist/components/SignUp/SignUpDefault/SignUpForm.d.ts +1 -0
  255. package/dist/components/SignUp/SignUpDefault/SignUpForm.js +310 -0
  256. package/dist/components/SignUp/SignUpForm.d.ts +1 -0
  257. package/dist/components/SignUp/SignUpForm.js +284 -0
  258. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.d.ts +1 -0
  259. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.js +198 -0
  260. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.d.ts +1 -0
  261. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.js +251 -0
  262. package/dist/components/SignUp/SignUpKYC/ImageUploader.d.ts +10 -0
  263. package/dist/components/SignUp/SignUpKYC/ImageUploader.js +42 -0
  264. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.d.ts +7 -0
  265. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.js +9 -0
  266. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.d.ts +1 -0
  267. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.js +464 -0
  268. package/dist/components/SignUp/SignUpKYC/useImageUploader.d.ts +11 -0
  269. package/dist/components/SignUp/SignUpKYC/useImageUploader.js +20 -0
  270. package/dist/components/SignUp/SignUpKYC/utils.d.ts +9 -0
  271. package/dist/components/SignUp/SignUpKYC/utils.js +79 -0
  272. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.d.ts +1 -0
  273. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.js +198 -0
  274. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.d.ts +1 -0
  275. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.js +251 -0
  276. package/dist/components/SignUp/SignUpPagcor/ImageUploader.d.ts +10 -0
  277. package/dist/components/SignUp/SignUpPagcor/ImageUploader.js +41 -0
  278. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.d.ts +1 -0
  279. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.js +429 -0
  280. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.d.ts +13 -0
  281. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.js +26 -0
  282. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.d.ts +7 -0
  283. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.js +2 -0
  284. package/dist/components/SignUp/SignUpPagcor/useImageUploader.d.ts +11 -0
  285. package/dist/components/SignUp/SignUpPagcor/useImageUploader.js +20 -0
  286. package/dist/components/SingleSignOn/SingleSignOn.d.ts +1 -1
  287. package/dist/components/SingleSignOn/SingleSignOn.js +7 -15
  288. package/dist/components/TermsOfUse/TermsOfUse.d.ts +1 -1
  289. package/dist/components/TermsOfUse/TermsOfUse.js +7 -0
  290. package/dist/components/TermsOfUse/TermsOfUseV3.lazy.d.ts +9 -0
  291. package/dist/components/TermsOfUse/TermsOfUseV3.lazy.js +69 -0
  292. package/dist/components/Tournaments/TournamentsCarousel/TournamentsCarouselItem.module.css +184 -184
  293. package/dist/components/Tournaments/TournamentsList/TournamentItem.module.css +184 -184
  294. package/dist/components/shared/IdDocumentField.client.d.ts +25 -0
  295. package/dist/components/shared/IdDocumentField.client.js +204 -0
  296. package/dist/components/shared/IdDocumentField.d.ts +2 -0
  297. package/dist/components/shared/IdDocumentField.js +11 -0
  298. package/dist/components/shared/SelfieField.client.d.ts +20 -0
  299. package/dist/components/shared/SelfieField.client.js +327 -0
  300. package/dist/components/shared/SelfieField.d.ts +2 -0
  301. package/dist/components/shared/SelfieField.js +11 -0
  302. package/dist/constants/BranchCode.d.ts +4 -0
  303. package/dist/constants/BranchCode.js +42 -0
  304. package/dist/constants/Branches.d.ts +2 -0
  305. package/dist/constants/Branches.js +42 -0
  306. package/dist/handlers/postTransformIdFrontImage.d.ts +3 -0
  307. package/dist/handlers/postTransformIdFrontImage.js +67 -0
  308. package/dist/handlers/postTransformSelfieImage.d.ts +3 -0
  309. package/dist/handlers/postTransformSelfieImage.js +71 -0
  310. package/dist/handlers.d.ts +43 -0
  311. package/dist/handlers.js +297 -0
  312. package/dist/icons/BellRingIcon.d.ts +2 -0
  313. package/dist/icons/BellRingIcon.js +4 -0
  314. package/dist/images/game-providers/ALPHACHINKO.png +0 -0
  315. package/dist/images/phone-icon.svg +10 -10
  316. package/dist/images/responsible-gaming-new.png +0 -0
  317. package/dist/images/responsible-gaming-yellow.png +0 -0
  318. package/dist/services/queries.js +3369 -3369
  319. package/dist/styles/theme.css +776 -776
  320. package/dist/third-parties/FacebookPixel/FacebookPixel.d.ts +4 -0
  321. package/dist/third-parties/FacebookPixel/FacebookPixel.js +4 -0
  322. package/dist/third-parties/FacebookPixel/api.d.ts +0 -0
  323. package/dist/third-parties/FacebookPixel/api.js +1 -0
  324. package/dist/third-parties/FacebookPixel/index.d.ts +1 -0
  325. package/dist/third-parties/FacebookPixel/index.js +1 -0
  326. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.d.ts +4 -0
  327. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.js +4 -0
  328. package/dist/third-parties/GoogleRecaptcha/api.d.ts +0 -0
  329. package/dist/third-parties/GoogleRecaptcha/api.js +1 -0
  330. package/dist/third-parties/GoogleRecaptcha/index.d.ts +1 -0
  331. package/dist/third-parties/GoogleRecaptcha/index.js +1 -0
  332. package/dist/third-parties/index.d.ts +2 -0
  333. package/dist/third-parties/index.js +2 -0
  334. package/dist/ui/QrCode/QrCode.d.ts +25 -25
  335. package/dist/ui/QrCode/qrCode.recipe.d.ts +5 -5
  336. package/dist/utils/dataUrlToBlob.d.ts +1 -0
  337. package/dist/utils/dataUrlToBlob.js +11 -0
  338. package/dist/utils/gamesAvailable3pmTo3am.d.ts +1 -0
  339. package/dist/utils/gamesAvailable3pmTo3am.js +1 -0
  340. package/dist/utils/getGameName.d.ts +1 -0
  341. package/dist/utils/getGameName.js +6 -0
  342. package/dist/utils/getLocaleInfo.d.ts +79 -0
  343. package/dist/utils/getLocaleInfo.js +175 -0
  344. package/dist/utils/isBetween3amAnd3pm.d.ts +1 -0
  345. package/dist/utils/isBetween3amAnd3pm.js +5 -0
  346. package/dist/utils/resizeImageSize.d.ts +2 -0
  347. package/dist/utils/resizeImageSize.js +11 -0
  348. package/package.json +179 -179
@@ -0,0 +1,310 @@
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
+ }
@@ -0,0 +1 @@
1
+ export declare function SignUpForm(): import("react/jsx-runtime").JSX.Element;
@@ -0,0 +1,284 @@
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 { useDialogContext } from '@ark-ui/react/dialog';
5
+ import { zodResolver } from '@hookform/resolvers/zod';
6
+ import { ObjectId } from '@opexa/object-id';
7
+ import { differenceInYears, format } from 'date-fns';
8
+ import Link from 'next/link';
9
+ import { useSearchParams } from 'next/navigation';
10
+ import { useRef, useState } from 'react';
11
+ import { Controller, useForm } from 'react-hook-form';
12
+ import { z } from 'zod';
13
+ import { useShallow } from 'zustand/shallow';
14
+ import { useControllableState } from '../../client/hooks/useControllableState.js';
15
+ import { useCooldown } from '../../client/hooks/useCooldown.js';
16
+ import { useGlobalStore } from '../../client/hooks/useGlobalStore.js';
17
+ import { useLocaleInfo } from '../../client/hooks/useLocaleInfo.js';
18
+ import { useMobileNumberParser } from '../../client/hooks/useMobileNumberParser.js';
19
+ import { useSendVerificationCodeMutation } from '../../client/hooks/useSendVerificationCodeMutation.js';
20
+ import { useSignInMutation } from '../../client/hooks/useSignInMutation.js';
21
+ import { useSignUpMutation } from '../../client/hooks/useSignUpMutation.js';
22
+ import { useUpdateAccountMutation } from '../../client/hooks/useUpdateAccountMutation.js';
23
+ import { toaster } from '../../client/utils/toaster.js';
24
+ import { BRANCHES } from '../../constants/index.js';
25
+ import { ArrowLeftIcon } from '../../icons/ArrowLeftIcon.js';
26
+ import { CalendarIcon } from '../../icons/CalendarIcon.js';
27
+ import { CheckIcon } from '../../icons/CheckIcon.js';
28
+ import { ChevronDownIcon } from '../../icons/ChevronDownIcon.js';
29
+ import { ChevronLeftIcon } from '../../icons/ChevronLeftIcon.js';
30
+ import { ChevronRightIcon } from '../../icons/ChevronRightIcon.js';
31
+ import { HelpCircleIcon } from '../../icons/HelpCircleIcon.js';
32
+ import { ObjectType } from '../../services/ObjectType.js';
33
+ import { Button } from '../../ui/Button/index.js';
34
+ import { Checkbox } from '../../ui/Checkbox/index.js';
35
+ import { DatePicker } from '../../ui/DatePicker/index.js';
36
+ import { Field } from '../../ui/Field/index.js';
37
+ import { PinInput } from '../../ui/PinInput/index.js';
38
+ import { Select } from '../../ui/Select/index.js';
39
+ import { Tooltip } from '../../ui/Tooltip/index.js';
40
+ import { createPoll } from '../../utils/createPoll.js';
41
+ import { useSignUpPropsContext } from './SignUpContext.js';
42
+ export function SignUpForm() {
43
+ const signUpProps = useSignUpPropsContext();
44
+ const branchCollection = createListCollection({
45
+ items: signUpProps.branches ?? BRANCHES,
46
+ itemToValue: (item) => item.code,
47
+ itemToString: (item) => `${item.code} - ${item.name}`,
48
+ });
49
+ const [step, setStep] = useState(1);
50
+ const dialog = useDialogContext();
51
+ const search = useSearchParams();
52
+ const signInStore = useGlobalStore(useShallow((ctx) => ctx.signIn));
53
+ const signUpMutation = useSignUpMutation();
54
+ const signInMutation = useSignInMutation();
55
+ const updateAccountMutation = useUpdateAccountMutation();
56
+ const sendVerificationCodeMutation = useSendVerificationCodeMutation();
57
+ const localeInfo = useLocaleInfo();
58
+ const mobileNumberParser = useMobileNumberParser();
59
+ const Step1Definition = z.object({
60
+ mobileNumber: z
61
+ .string()
62
+ .min(1, 'Mobile number is required')
63
+ .superRefine((v, ctx) => {
64
+ if (!mobileNumberParser.validate(v)) {
65
+ ctx.addIssue({
66
+ code: z.ZodIssueCode.custom,
67
+ message: 'Invalid mobile number',
68
+ });
69
+ }
70
+ }),
71
+ termsAccepted: z.boolean().superRefine((v, ctx) => {
72
+ if (!v) {
73
+ ctx.addIssue({
74
+ code: z.ZodIssueCode.custom,
75
+ message: 'You must accept the terms and conditions',
76
+ });
77
+ }
78
+ }),
79
+ realName: z
80
+ .string()
81
+ .min(2, 'Real name must be 2 or more characters')
82
+ .max(50, 'Real name must not be more than 50 characters')
83
+ .trim(),
84
+ birthDay: z
85
+ .date({
86
+ invalid_type_error: 'Date of birth is required',
87
+ required_error: 'Date of birth is required',
88
+ })
89
+ .superRefine((val, ctx) => {
90
+ const now = new Date();
91
+ const age = differenceInYears(now, val);
92
+ if (age < 21) {
93
+ return ctx.addIssue({
94
+ code: z.ZodIssueCode.custom,
95
+ message: 'You must be at least 21 years old',
96
+ });
97
+ }
98
+ }),
99
+ branchCode: z.string().min(1, 'Branch is required').trim(),
100
+ });
101
+ const Step2Definition = z.object({
102
+ verificationCode: z.array(z.string()).superRefine((val, ctx) => {
103
+ if (val.length !== 6 || val.some((v) => v.length !== 1)) {
104
+ ctx.addIssue({
105
+ code: z.ZodIssueCode.custom,
106
+ message: 'Please Enter your 6 digits verification code',
107
+ });
108
+ }
109
+ }),
110
+ });
111
+ const step1Form = useForm({
112
+ mode: 'all',
113
+ resolver: zodResolver(Step1Definition),
114
+ defaultValues: {
115
+ mobileNumber: '',
116
+ termsAccepted: false,
117
+ branchCode: signUpProps?.branches?.[0]?.code ?? BRANCHES[0].code,
118
+ realName: '',
119
+ },
120
+ });
121
+ const step2Form = useForm({
122
+ resolver: zodResolver(Step2Definition),
123
+ defaultValues: {
124
+ verificationCode: Array.from({ length: 6 }).fill(''),
125
+ },
126
+ });
127
+ const cooldown = useCooldown({
128
+ max: 60,
129
+ duration: 1000 * 60,
130
+ });
131
+ const form2Ref = useRef(null);
132
+ const birthDay = step1Form.watch('birthDay');
133
+ const branchCode = step1Form.watch('branchCode', '');
134
+ return (_jsxs(_Fragment, { children: [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) => {
135
+ try {
136
+ await sendVerificationCodeMutation.mutateAsync({
137
+ channel: 'SMS',
138
+ recipient: mobileNumberParser.format(data.mobileNumber),
139
+ });
140
+ setStep(2);
141
+ cooldown.start();
142
+ }
143
+ catch (e) {
144
+ toaster.error({
145
+ description: e instanceof Error
146
+ ? e.message
147
+ : 'Failed to send verification code',
148
+ });
149
+ }
150
+ }), 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: {
151
+ paddingLeft: `calc(2.75rem + ${localeInfo.mobileNumber.areaCode.length}ch)`,
152
+ }, ...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) => {
153
+ if (!value)
154
+ return;
155
+ step1Form.setValue('birthDay', value, {
156
+ shouldDirty: true,
157
+ shouldTouch: true,
158
+ shouldValidate: true,
159
+ });
160
+ }, onBlur: () => {
161
+ step1Form.trigger('birthDay');
162
+ } }), _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) => {
163
+ step1Form.setValue('branchCode', details.value.at(0) ??
164
+ signUpProps?.branches?.[0]?.code ??
165
+ BRANCHES[0].code, {
166
+ shouldDirty: true,
167
+ shouldTouch: true,
168
+ shouldValidate: true,
169
+ });
170
+ }, collection: branchCollection, positioning: {
171
+ sameWidth: true,
172
+ placement: 'bottom',
173
+ }, 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: {
174
+ placement: 'top',
175
+ }, 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) => {
176
+ const label = branchCollection.stringifyItem(item) ?? '';
177
+ return (_jsx(Select.Item, { item: item, children: _jsx("div", { title: label, className: "line-clamp-1", children: label }) }, item.code));
178
+ }) }) })] }), _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) => {
179
+ o.field.onChange(details.checked);
180
+ }, 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 accept the", ' ', _jsx(Link, { href: signUpProps.termsAndConditionsUrl ??
181
+ '/terms-and-conditions', onClick: () => {
182
+ dialog.setOpen(false);
183
+ }, className: "text-brand-400 whitespace-nowrap underline underline-offset-2", children: "Terms and Conditions." })] }), ' ', _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: () => {
184
+ dialog.setOpen(false);
185
+ signInStore.setOpen(true);
186
+ }, 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 }) => {
187
+ const id = ObjectId.generate(ObjectType.MemberAccount).toString();
188
+ const { mobileNumber } = step1Form.getValues();
189
+ try {
190
+ await signUpMutation.mutateAsync({
191
+ id,
192
+ mobileNumber: mobileNumberParser.format(mobileNumber),
193
+ verificationCode: verificationCode.join(''),
194
+ referralCode: search.get('referralCode') ?? undefined,
195
+ domain: search.get('domain') ?? undefined,
196
+ btag: search.get('btag') ?? undefined,
197
+ });
198
+ const name = mobileNumberParser.format(mobileNumber);
199
+ const password = `${name}${id}`;
200
+ const pollLogin = createPoll(async () => {
201
+ try {
202
+ await signInMutation.mutateAsync({
203
+ type: 'NAME_AND_PASSWORD',
204
+ name,
205
+ password,
206
+ });
207
+ return true;
208
+ }
209
+ catch {
210
+ return false;
211
+ }
212
+ }, {
213
+ until: (ok) => ok,
214
+ maxAttempt: 3,
215
+ });
216
+ const ok = await pollLogin();
217
+ if (!ok) {
218
+ signInStore.setOpen(true);
219
+ }
220
+ else {
221
+ const pollUpdateAccount = createPoll(async () => {
222
+ try {
223
+ await updateAccountMutation.mutateAsync({
224
+ branchCode: step1Form.getValues('branchCode'),
225
+ realName: step1Form.getValues('realName'),
226
+ birthDay: format(step1Form.getValues('birthDay'), 'yyyy-MM-dd'),
227
+ });
228
+ return true;
229
+ }
230
+ catch {
231
+ return false;
232
+ }
233
+ }, {
234
+ until: (ok) => ok,
235
+ maxAttempt: 3,
236
+ });
237
+ await pollUpdateAccount();
238
+ }
239
+ dialog.setOpen(false);
240
+ step1Form.reset();
241
+ step2Form.reset();
242
+ setStep(1);
243
+ }
244
+ catch (error) {
245
+ toaster.error({
246
+ description: error instanceof Error
247
+ ? error.message
248
+ : 'Invalid Verification Code',
249
+ });
250
+ }
251
+ }), 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) => {
252
+ o.field.onChange(details.value);
253
+ }, onValueComplete: () => {
254
+ form2Ref.current?.requestSubmit();
255
+ }, 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 () => {
256
+ await sendVerificationCodeMutation.mutateAsync({
257
+ channel: 'SMS',
258
+ recipient: mobileNumberParser.format(step1Form.getValues('mobileNumber')),
259
+ });
260
+ cooldown.start();
261
+ }, children: cooldown.cooling
262
+ ? `Resend in ${cooldown.countdown}s`
263
+ : '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: () => {
264
+ setStep(1);
265
+ step2Form.reset();
266
+ cooldown.stop();
267
+ }, children: [_jsx(ArrowLeftIcon, { className: "size-5" }), "Back"] })] })] }))] }));
268
+ }
269
+ const DEVICE_TIMEZONE = Intl.DateTimeFormat().resolvedOptions().timeZone;
270
+ function DateOfBirthField(props) {
271
+ const [value, setValue] = useControllableState({
272
+ value: props.value,
273
+ defaultValue: props.defaultValue ?? null,
274
+ onChange: props.onChange,
275
+ });
276
+ 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) => {
277
+ const value = details.value.at(0)?.toDate(DEVICE_TIMEZONE);
278
+ setValue(value ?? null);
279
+ }, 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
280
+ .getMonthsGrid({ columns: 4, format: 'short' })
281
+ .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
282
+ .getYearsGrid({ columns: 4 })
283
+ .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))) }) })] })) }) })] }) })] }));
284
+ }
@@ -0,0 +1 @@
1
+ export declare function CaptureIdDocument(): import("react/jsx-runtime").JSX.Element;