@opexa/portal-components 0.0.934 → 0.0.936

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 (350) hide show
  1. package/dist/client/hooks/useSessionHealthQuery.js +16 -0
  2. package/dist/components/DepositWithdrawal/Deposit/AurixPayPayMayaDeposit/AurixPayGrabPayDeposit.js +2 -21
  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/Disclaimer/DisclaimerV3.js +5 -5
  6. package/dist/components/ForgotPassword/Crazywin/ForgotPassword.module.css +42 -42
  7. package/dist/components/Games/Game.js +2 -2
  8. package/dist/components/GamesSearch/GamesSearch.js +2 -3
  9. package/dist/components/Jackpots/Jackpots.module.css +288 -288
  10. package/dist/components/KYC/KYCDefault/KYCVerificationStatus.lazy.js +2 -2
  11. package/dist/components/KYC/KYCNonPagCor/KYCVerificationStatus.lazy.js +2 -2
  12. package/dist/components/PortalProvider/SessionWatcher.js +0 -2
  13. package/dist/components/ResponsibleGaming/ResponsibleGaming.d.ts +1 -1
  14. package/dist/components/ResponsibleGaming/ResponsibleGaming.js +7 -0
  15. package/dist/components/ResponsibleGaming/ResponsibleGamingV3.lazy.d.ts +8 -0
  16. package/dist/components/ResponsibleGaming/ResponsibleGamingV3.lazy.js +71 -0
  17. package/dist/components/SingleSignOn/SingleSignOn.d.ts +1 -1
  18. package/dist/components/SingleSignOn/SingleSignOn.js +15 -7
  19. package/dist/components/TermsOfUse/TermsOfUse.d.ts +1 -1
  20. package/dist/components/TermsOfUse/TermsOfUse.js +7 -0
  21. package/dist/components/TermsOfUse/TermsOfUseV3.lazy.d.ts +9 -0
  22. package/dist/components/TermsOfUse/TermsOfUseV3.lazy.js +69 -0
  23. package/dist/components/Tournaments/TournamentsCarousel/TournamentsCarouselItem.module.css +184 -184
  24. package/dist/components/Tournaments/TournamentsList/TournamentItem.module.css +184 -184
  25. package/dist/images/phone-icon.svg +10 -10
  26. package/dist/images/responsible-gaming-new.png +0 -0
  27. package/dist/services/queries.js +3369 -3369
  28. package/dist/styles/theme.css +776 -776
  29. package/dist/ui/QrCode/QrCode.d.ts +25 -25
  30. package/dist/ui/QrCode/qrCode.recipe.d.ts +5 -5
  31. package/package.json +179 -179
  32. package/dist/assets/providers/alize.png +0 -0
  33. package/dist/assets/providers/bigtime-gaming.png +0 -0
  34. package/dist/assets/providers/bng.png +0 -0
  35. package/dist/assets/providers/boongo.png +0 -0
  36. package/dist/assets/providers/btg.png +0 -0
  37. package/dist/assets/providers/cq9.png +0 -0
  38. package/dist/assets/providers/darwin.png +0 -0
  39. package/dist/assets/providers/digitain.png +0 -0
  40. package/dist/assets/providers/evolution.png +0 -0
  41. package/dist/assets/providers/fantasma-games.png +0 -0
  42. package/dist/assets/providers/fc.png +0 -0
  43. package/dist/assets/providers/fp.png +0 -0
  44. package/dist/assets/providers/habanero.png +0 -0
  45. package/dist/assets/providers/hacksaw.png +0 -0
  46. package/dist/assets/providers/jdb.png +0 -0
  47. package/dist/assets/providers/jili.png +0 -0
  48. package/dist/assets/providers/leap.png +0 -0
  49. package/dist/assets/providers/live-22-metaverse.png +0 -0
  50. package/dist/assets/providers/netent.png +0 -0
  51. package/dist/assets/providers/no-limit.png +0 -0
  52. package/dist/assets/providers/pg.png +0 -0
  53. package/dist/assets/providers/pgsoft.png +0 -0
  54. package/dist/assets/providers/pragmatic-play.png +0 -0
  55. package/dist/assets/providers/realtime-gaming.png +0 -0
  56. package/dist/assets/providers/redtiger.png +0 -0
  57. package/dist/assets/providers/rtg.png +0 -0
  58. package/dist/assets/providers/sagaming.png +0 -0
  59. package/dist/client/hooks/useAiOGCashDepositMutation.d.ts +0 -4
  60. package/dist/client/hooks/useAiOGCashDepositMutation.js +0 -90
  61. package/dist/client/hooks/useAiOGrabPayDepositMutation.d.ts +0 -4
  62. package/dist/client/hooks/useAiOGrabPayDepositMutation.js +0 -80
  63. package/dist/client/hooks/useAiOPalawanPayDepositMutation.d.ts +0 -4
  64. package/dist/client/hooks/useAiOPalawanPayDepositMutation.js +0 -80
  65. package/dist/client/hooks/useAiOPayMayaDepositMutation.d.ts +0 -4
  66. package/dist/client/hooks/useAiOPayMayaDepositMutation.js +0 -80
  67. package/dist/components/DepositWithdrawal/AiOPaymentMethods.d.ts +0 -11
  68. package/dist/components/DepositWithdrawal/AiOPaymentMethods.js +0 -55
  69. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositAlert.d.ts +0 -1
  70. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositAlert.js +0 -99
  71. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositDetails.d.ts +0 -1
  72. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositDetails.js +0 -17
  73. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositForm.d.ts +0 -1
  74. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositForm.js +0 -116
  75. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHQRCode.d.ts +0 -3
  76. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHQRCode.js +0 -69
  77. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDeposit.d.ts +0 -1
  78. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDeposit.js +0 -10
  79. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositAlert.d.ts +0 -1
  80. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositAlert.js +0 -99
  81. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositContext.d.ts +0 -25
  82. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositContext.js +0 -2
  83. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositDetails.d.ts +0 -1
  84. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositDetails.js +0 -17
  85. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositForm.d.ts +0 -1
  86. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHDepositForm.js +0 -116
  87. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHQRCode.d.ts +0 -3
  88. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/QRPHQRCode.js +0 -69
  89. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/useQRPHDeposit.d.ts +0 -13
  90. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__legacy/useQRPHDeposit.js +0 -85
  91. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Confirmed.d.ts +0 -1
  92. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Confirmed.js +0 -11
  93. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Failed.d.ts +0 -1
  94. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Failed.js +0 -11
  95. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Form.d.ts +0 -1
  96. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/Form.js +0 -126
  97. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/GeneratingQrCode.d.ts +0 -1
  98. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/GeneratingQrCode.js +0 -10
  99. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDeposit.d.ts +0 -1
  100. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDeposit.js +0 -12
  101. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.d.ts +0 -17
  102. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QRPHDepositContext.js +0 -2
  103. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QrCodeGenerated.d.ts +0 -1
  104. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/QrCodeGenerated.js +0 -41
  105. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.d.ts +0 -13
  106. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit__next/useQRPHDeposit.js +0 -91
  107. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGCashDeposit/AiOGCashDeposit.d.ts +0 -1
  108. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGCashDeposit/AiOGCashDeposit.js +0 -173
  109. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGrabPayDeposit/AiOGrabPayDeposit.d.ts +0 -1
  110. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOGrabPayDeposit/AiOGrabPayDeposit.js +0 -171
  111. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPalawanPayDeposit/AiOPalawanPayDeposit.d.ts +0 -1
  112. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPalawanPayDeposit/AiOPalawanPayDeposit.js +0 -171
  113. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPayMayaDeposit/AiOPayMayaDeposit.d.ts +0 -1
  114. package/dist/components/DepositWithdrawal/Deposit__legacy/AiOPayMayaDeposit/AiOPayMayaDeposit.js +0 -171
  115. package/dist/components/DepositWithdrawal/Deposit__legacy/AvailablePromos.d.ts +0 -8
  116. package/dist/components/DepositWithdrawal/Deposit__legacy/AvailablePromos.js +0 -33
  117. package/dist/components/DepositWithdrawal/Deposit__legacy/Deposit.d.ts +0 -1
  118. package/dist/components/DepositWithdrawal/Deposit__legacy/Deposit.js +0 -120
  119. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashDeposit/GCashDeposit.d.ts +0 -1
  120. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashDeposit/GCashDeposit.js +0 -163
  121. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashWebpayDeposit/GCashWebpayDeposit.d.ts +0 -1
  122. package/dist/components/DepositWithdrawal/Deposit__legacy/GCashWebpayDeposit/GCashWebpayDeposit.js +0 -165
  123. package/dist/components/DepositWithdrawal/Deposit__legacy/LibanganDeposit/LibanganDeposit.d.ts +0 -1
  124. package/dist/components/DepositWithdrawal/Deposit__legacy/LibanganDeposit/LibanganDeposit.js +0 -186
  125. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaAppDeposit/MayaAppDeposit.d.ts +0 -1
  126. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaAppDeposit/MayaAppDeposit.js +0 -157
  127. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaDeposit/MayaDeposit.d.ts +0 -1
  128. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaDeposit/MayaDeposit.js +0 -163
  129. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaWebpayDeposit/MayaWebpayDeposit.d.ts +0 -1
  130. package/dist/components/DepositWithdrawal/Deposit__legacy/MayaWebpayDeposit/MayaWebpayDeposit.js +0 -166
  131. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDeposit.d.ts +0 -1
  132. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDeposit.js +0 -10
  133. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositAlert.d.ts +0 -1
  134. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositAlert.js +0 -99
  135. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositContext.d.ts +0 -25
  136. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositContext.js +0 -2
  137. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositDetails.d.ts +0 -1
  138. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositDetails.js +0 -19
  139. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositForm.d.ts +0 -1
  140. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/OnlineBankDepositForm.js +0 -115
  141. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/useOnlineBankDeposit.d.ts +0 -13
  142. package/dist/components/DepositWithdrawal/Deposit__legacy/OnlineBankDeposit/useOnlineBankDeposit.js +0 -81
  143. package/dist/components/DepositWithdrawal/Deposit__legacy/PisoPayDeposit/PisoPayDeposit.d.ts +0 -1
  144. package/dist/components/DepositWithdrawal/Deposit__legacy/PisoPayDeposit/PisoPayDeposit.js +0 -180
  145. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDeposit.d.ts +0 -1
  146. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDeposit.js +0 -10
  147. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositAlert.d.ts +0 -1
  148. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositAlert.js +0 -99
  149. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositContext.d.ts +0 -25
  150. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositContext.js +0 -2
  151. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositDetails.d.ts +0 -1
  152. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositDetails.js +0 -17
  153. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositForm.d.ts +0 -1
  154. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHDepositForm.js +0 -116
  155. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHQRCode.d.ts +0 -3
  156. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/QRPHQRCode.js +0 -69
  157. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/useQRPHDeposit.d.ts +0 -13
  158. package/dist/components/DepositWithdrawal/Deposit__legacy/QRPHDeposit/useQRPHDeposit.js +0 -85
  159. package/dist/components/DigitainLauncher/Loading.d.ts +0 -1
  160. package/dist/components/DigitainLauncher/Loading.js +0 -5
  161. package/dist/components/Disclaimer/ResponsibleGaming.d.ts +0 -10
  162. package/dist/components/Disclaimer/ResponsibleGaming.js +0 -13
  163. package/dist/components/Disclaimer/TermsOfUse.d.ts +0 -11
  164. package/dist/components/Disclaimer/TermsOfUse.js +0 -13
  165. package/dist/components/FeatureFlag/FeatureFlag.d.ts +0 -1
  166. package/dist/components/FeatureFlag/FeatureFlag.js +0 -29
  167. package/dist/components/FeatureFlag/index.d.ts +0 -1
  168. package/dist/components/FeatureFlag/index.js +0 -1
  169. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.module.css +0 -184
  170. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.module.css +0 -184
  171. package/dist/components/KYC/AutoOpen.d.ts +0 -1
  172. package/dist/components/KYC/AutoOpen.js +0 -40
  173. package/dist/components/KYC/BasicInformation.d.ts +0 -1
  174. package/dist/components/KYC/BasicInformation.js +0 -101
  175. package/dist/components/KYC/CaptureIdDocument.d.ts +0 -1
  176. package/dist/components/KYC/CaptureIdDocument.js +0 -219
  177. package/dist/components/KYC/CaptureSelfie.d.ts +0 -1
  178. package/dist/components/KYC/CaptureSelfie.js +0 -285
  179. package/dist/components/KYC/DisplayImage.d.ts +0 -5
  180. package/dist/components/KYC/DisplayImage.js +0 -8
  181. package/dist/components/KYC/FileUpload.d.ts +0 -10
  182. package/dist/components/KYC/FileUpload.js +0 -72
  183. package/dist/components/KYC/IdentityVerification.d.ts +0 -1
  184. package/dist/components/KYC/IdentityVerification.js +0 -120
  185. package/dist/components/KYC/Indicator.d.ts +0 -1
  186. package/dist/components/KYC/Indicator.js +0 -8
  187. package/dist/components/KYC/KYC.lazy.d.ts +0 -6
  188. package/dist/components/KYC/KYC.lazy.js +0 -45
  189. package/dist/components/KYC/KYCContext.d.ts +0 -6
  190. package/dist/components/KYC/KYCContext.js +0 -2
  191. package/dist/components/KYC/KYCDefault/BasicInformation.d.ts +0 -1
  192. package/dist/components/KYC/KYCDefault/BasicInformation.js +0 -101
  193. package/dist/components/KYC/KYCVerificationStatus.d.ts +0 -1
  194. package/dist/components/KYC/KYCVerificationStatus.js +0 -10
  195. package/dist/components/KYC/KYCVerificationStatus.lazy.d.ts +0 -1
  196. package/dist/components/KYC/KYCVerificationStatus.lazy.js +0 -39
  197. package/dist/components/KYC/NoCameraError.d.ts +0 -7
  198. package/dist/components/KYC/NoCameraError.js +0 -6
  199. package/dist/components/KYC/PersonOverlayDesktop.d.ts +0 -7
  200. package/dist/components/KYC/PersonOverlayDesktop.js +0 -9
  201. package/dist/components/KYC/PersonalInformation.d.ts +0 -1
  202. package/dist/components/KYC/PersonalInformation.js +0 -122
  203. package/dist/components/KYC/backup/Header.d.ts +0 -1
  204. package/dist/components/KYC/backup/Header.js +0 -8
  205. package/dist/components/KYC/backup/Indicator.d.ts +0 -1
  206. package/dist/components/KYC/backup/Indicator.js +0 -9
  207. package/dist/components/KYC/backup/KYC.d.ts +0 -1
  208. package/dist/components/KYC/backup/KYC.js +0 -14
  209. package/dist/components/KYC/backup/KYC.lazy.d.ts +0 -1
  210. package/dist/components/KYC/backup/KYC.lazy.js +0 -26
  211. package/dist/components/KYC/backup/KYCContext.d.ts +0 -6
  212. package/dist/components/KYC/backup/KYCContext.js +0 -2
  213. package/dist/components/KYC/backup/Step1.d.ts +0 -1
  214. package/dist/components/KYC/backup/Step1.js +0 -13
  215. package/dist/components/KYC/backup/Step2.d.ts +0 -1
  216. package/dist/components/KYC/backup/Step2.js +0 -13
  217. package/dist/components/KYC/backup/Step3.d.ts +0 -1
  218. package/dist/components/KYC/backup/Step3.js +0 -13
  219. package/dist/components/KYC/backup/Step4.d.ts +0 -1
  220. package/dist/components/KYC/backup/Step4.js +0 -7
  221. package/dist/components/KYC/backup/useKYC.d.ts +0 -10
  222. package/dist/components/KYC/backup/useKYC.js +0 -8
  223. package/dist/components/KYC/loadModels.d.ts +0 -1
  224. package/dist/components/KYC/loadModels.js +0 -9
  225. package/dist/components/KYC/useKYC.d.ts +0 -25
  226. package/dist/components/KYC/useKYC.js +0 -38
  227. package/dist/components/KYC/utils.d.ts +0 -9
  228. package/dist/components/KYC/utils.js +0 -79
  229. package/dist/components/KYCNotRequired/KYCNotRequired.d.ts +0 -0
  230. package/dist/components/KYCNotRequired/KYCNotRequired.js +0 -1
  231. package/dist/components/Messages/Message.d.ts +0 -1
  232. package/dist/components/Messages/Message.js +0 -35
  233. package/dist/components/Messages/MessageContext.d.ts +0 -6
  234. package/dist/components/Messages/MessageContext.js +0 -2
  235. package/dist/components/Messages/MessagePopup.d.ts +0 -1
  236. package/dist/components/Messages/MessagePopup.js +0 -20
  237. package/dist/components/Messages/MessageTrigger.d.ts +0 -8
  238. package/dist/components/Messages/MessageTrigger.js +0 -19
  239. package/dist/components/PortalProvider/CXDTokenObserver.d.ts +0 -1
  240. package/dist/components/PortalProvider/CXDTokenObserver.js +0 -30
  241. package/dist/components/PortalProvider/LinkGoogleAccountObserver.d.ts +0 -1
  242. package/dist/components/PortalProvider/LinkGoogleAccountObserver.js +0 -29
  243. package/dist/components/Quests/CountdownTimer.d.ts +0 -15
  244. package/dist/components/Quests/CountdownTimer.js +0 -33
  245. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.d.ts +0 -4
  246. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.js +0 -78
  247. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.d.ts +0 -8
  248. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.js +0 -9
  249. package/dist/components/Quests/MultiWageringQuest.d.ts +0 -1
  250. package/dist/components/Quests/MultiWageringQuest.js +0 -111
  251. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.d.ts +0 -4
  252. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.js +0 -4
  253. package/dist/components/Quests/WageringQuest/WageringQuest.d.ts +0 -4
  254. package/dist/components/Quests/WageringQuest/WageringQuest.js +0 -20
  255. package/dist/components/Quests/WageringQuest/WageringQuestModal.d.ts +0 -9
  256. package/dist/components/Quests/WageringQuest/WageringQuestModal.js +0 -9
  257. package/dist/components/SessionWatcher/SessionWatcher.d.ts +0 -1
  258. package/dist/components/SessionWatcher/SessionWatcher.js +0 -20
  259. package/dist/components/SessionWatcher/index.d.ts +0 -1
  260. package/dist/components/SessionWatcher/index.js +0 -1
  261. package/dist/components/SignIn/utils.d.ts +0 -8
  262. package/dist/components/SignIn/utils.js +0 -26
  263. package/dist/components/SignUp/SignUp.lazy.d.ts +0 -12
  264. package/dist/components/SignUp/SignUp.lazy.js +0 -18
  265. package/dist/components/SignUp/SignUpContext.d.ts +0 -6
  266. package/dist/components/SignUp/SignUpContext.js +0 -2
  267. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.d.ts +0 -17
  268. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.js +0 -18
  269. package/dist/components/SignUp/SignUpDefault/SignUpContext.d.ts +0 -6
  270. package/dist/components/SignUp/SignUpDefault/SignUpContext.js +0 -2
  271. package/dist/components/SignUp/SignUpDefault/SignUpForm.d.ts +0 -1
  272. package/dist/components/SignUp/SignUpDefault/SignUpForm.js +0 -310
  273. package/dist/components/SignUp/SignUpForm.d.ts +0 -1
  274. package/dist/components/SignUp/SignUpForm.js +0 -284
  275. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.d.ts +0 -1
  276. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.js +0 -198
  277. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.d.ts +0 -1
  278. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.js +0 -251
  279. package/dist/components/SignUp/SignUpKYC/ImageUploader.d.ts +0 -10
  280. package/dist/components/SignUp/SignUpKYC/ImageUploader.js +0 -42
  281. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.d.ts +0 -7
  282. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.js +0 -9
  283. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.d.ts +0 -1
  284. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.js +0 -464
  285. package/dist/components/SignUp/SignUpKYC/useImageUploader.d.ts +0 -11
  286. package/dist/components/SignUp/SignUpKYC/useImageUploader.js +0 -20
  287. package/dist/components/SignUp/SignUpKYC/utils.d.ts +0 -9
  288. package/dist/components/SignUp/SignUpKYC/utils.js +0 -79
  289. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.d.ts +0 -1
  290. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.js +0 -198
  291. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.d.ts +0 -1
  292. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.js +0 -251
  293. package/dist/components/SignUp/SignUpPagcor/ImageUploader.d.ts +0 -10
  294. package/dist/components/SignUp/SignUpPagcor/ImageUploader.js +0 -41
  295. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.d.ts +0 -1
  296. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.js +0 -429
  297. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.d.ts +0 -13
  298. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.js +0 -26
  299. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.d.ts +0 -7
  300. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.js +0 -2
  301. package/dist/components/SignUp/SignUpPagcor/useImageUploader.d.ts +0 -11
  302. package/dist/components/SignUp/SignUpPagcor/useImageUploader.js +0 -20
  303. package/dist/components/shared/IdDocumentField.client.d.ts +0 -25
  304. package/dist/components/shared/IdDocumentField.client.js +0 -204
  305. package/dist/components/shared/IdDocumentField.d.ts +0 -2
  306. package/dist/components/shared/IdDocumentField.js +0 -11
  307. package/dist/components/shared/SelfieField.client.d.ts +0 -20
  308. package/dist/components/shared/SelfieField.client.js +0 -327
  309. package/dist/components/shared/SelfieField.d.ts +0 -2
  310. package/dist/components/shared/SelfieField.js +0 -11
  311. package/dist/constants/BranchCode.d.ts +0 -4
  312. package/dist/constants/BranchCode.js +0 -42
  313. package/dist/constants/Branches.d.ts +0 -2
  314. package/dist/constants/Branches.js +0 -42
  315. package/dist/handlers/postTransformIdFrontImage.d.ts +0 -3
  316. package/dist/handlers/postTransformIdFrontImage.js +0 -67
  317. package/dist/handlers/postTransformSelfieImage.d.ts +0 -3
  318. package/dist/handlers/postTransformSelfieImage.js +0 -71
  319. package/dist/handlers.d.ts +0 -43
  320. package/dist/handlers.js +0 -297
  321. package/dist/icons/BellRingIcon.d.ts +0 -2
  322. package/dist/icons/BellRingIcon.js +0 -4
  323. package/dist/images/game-providers/ALPHACHINKO.png +0 -0
  324. package/dist/images/responsible-gaming-yellow.png +0 -0
  325. package/dist/third-parties/FacebookPixel/FacebookPixel.d.ts +0 -4
  326. package/dist/third-parties/FacebookPixel/FacebookPixel.js +0 -4
  327. package/dist/third-parties/FacebookPixel/api.d.ts +0 -0
  328. package/dist/third-parties/FacebookPixel/api.js +0 -1
  329. package/dist/third-parties/FacebookPixel/index.d.ts +0 -1
  330. package/dist/third-parties/FacebookPixel/index.js +0 -1
  331. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.d.ts +0 -4
  332. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.js +0 -4
  333. package/dist/third-parties/GoogleRecaptcha/api.d.ts +0 -0
  334. package/dist/third-parties/GoogleRecaptcha/api.js +0 -1
  335. package/dist/third-parties/GoogleRecaptcha/index.d.ts +0 -1
  336. package/dist/third-parties/GoogleRecaptcha/index.js +0 -1
  337. package/dist/third-parties/index.d.ts +0 -2
  338. package/dist/third-parties/index.js +0 -2
  339. package/dist/utils/dataUrlToBlob.d.ts +0 -1
  340. package/dist/utils/dataUrlToBlob.js +0 -11
  341. package/dist/utils/gamesAvailable3pmTo3am.d.ts +0 -1
  342. package/dist/utils/gamesAvailable3pmTo3am.js +0 -1
  343. package/dist/utils/getGameName.d.ts +0 -1
  344. package/dist/utils/getGameName.js +0 -6
  345. package/dist/utils/getLocaleInfo.d.ts +0 -79
  346. package/dist/utils/getLocaleInfo.js +0 -175
  347. package/dist/utils/isBetween3amAnd3pm.d.ts +0 -1
  348. package/dist/utils/isBetween3amAnd3pm.js +0 -5
  349. package/dist/utils/resizeImageSize.d.ts +0 -2
  350. package/dist/utils/resizeImageSize.js +0 -11
@@ -1,40 +0,0 @@
1
- import { useEffect } from 'react';
2
- import { useShallow } from 'zustand/shallow';
3
- import { useAccountQuery } from '../../client/hooks/useAccountQuery.js';
4
- import { useGlobalStore } from '../../client/hooks/useGlobalStore.js';
5
- import { useMemberVerificationQuery } from '../../client/hooks/useMemberVerificationQuery.js';
6
- import { useSessionQuery } from '../../client/hooks/useSessionQuery.js';
7
- import { KYC_PROMPT_LOCALSTORAGE_KEY } from '../../constants/index.js';
8
- export function AutoOpen() {
9
- const kycStore = useGlobalStore(useShallow((ctx) => ctx.kyc));
10
- const { data: session } = useSessionQuery();
11
- const { data: account } = useAccountQuery();
12
- const { data: verification } = useMemberVerificationQuery();
13
- const isBasicInfoCompleted = account?.realName !== null && account?.birthDay !== null;
14
- const isUploadCompleted = verification &&
15
- verification.idFrontImage !== null &&
16
- verification.selfieImage !== null;
17
- const isRejected = Boolean(verification?.status === 'REJECTED');
18
- const step = !isBasicInfoCompleted
19
- ? 1
20
- : isRejected
21
- ? 2
22
- : isUploadCompleted
23
- ? 3
24
- : 2;
25
- const shouldOpen = !isBasicInfoCompleted || !isUploadCompleted || isRejected;
26
- useEffect(() => {
27
- if (session?.status == 'authenticated' &&
28
- shouldOpen &&
29
- localStorage.getItem(KYC_PROMPT_LOCALSTORAGE_KEY) === null) {
30
- kycStore.setKycReminder(true);
31
- return;
32
- }
33
- }, [kycStore, session?.status, shouldOpen]);
34
- useEffect(() => {
35
- if (step) {
36
- kycStore.setStep(step);
37
- }
38
- }, [kycStore, step]);
39
- return null;
40
- }
@@ -1 +0,0 @@
1
- export declare function BasicInformation(): import("react/jsx-runtime").JSX.Element;
@@ -1,101 +0,0 @@
1
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
- import { zodResolver } from '@hookform/resolvers/zod';
3
- import { differenceInYears, format, isSameDay, isValid, parse } from 'date-fns';
4
- import { isNil, omitBy, size } from 'lodash-es';
5
- import { useEffect } from 'react';
6
- import { useForm } from 'react-hook-form';
7
- import invariant from 'tiny-invariant';
8
- import { z } from 'zod';
9
- import { useAccountQuery } from '../../client/hooks/useAccountQuery.js';
10
- import { useUpdateAccountMutation } from '../../client/hooks/useUpdateAccountMutation.js';
11
- import { toaster } from '../../client/utils/toaster.js';
12
- import { Button } from '../../ui/Button/index.js';
13
- import { Dialog } from '../../ui/Dialog/index.js';
14
- import { Field } from '../../ui/Field/index.js';
15
- import { useKYCContext } from './KYCContext.js';
16
- const definition = z.object({
17
- realName: z
18
- .string()
19
- .min(3, 'Name must be 3 or more characters')
20
- .max(50, 'Name must not be more than 50 characters')
21
- .regex(/^[a-z0-9 ]+$/gi, 'Name must not contain special characters')
22
- .trim(),
23
- birthDay: z
24
- .string()
25
- .min(1, 'Date of birth is required')
26
- .superRefine((value, ctx) => {
27
- const dob = parse(value, 'yyyy-MM-dd', new Date());
28
- if (!isValid(dob)) {
29
- return ctx.addIssue({
30
- code: z.ZodIssueCode.invalid_date,
31
- });
32
- }
33
- const now = new Date();
34
- const age = differenceInYears(now, dob);
35
- if (age < 21) {
36
- return ctx.addIssue({
37
- code: z.ZodIssueCode.custom,
38
- message: 'You must be at least 21 years old',
39
- });
40
- }
41
- }),
42
- branchCode: z.string().min(4).max(10).optional().or(z.literal('')),
43
- });
44
- export function BasicInformation() {
45
- const kyc = useKYCContext();
46
- const form = useForm({
47
- resolver: zodResolver(definition),
48
- mode: 'all',
49
- defaultValues: {
50
- birthDay: '',
51
- branchCode: '',
52
- realName: '',
53
- },
54
- });
55
- const accountQuery = useAccountQuery();
56
- const account = accountQuery.data;
57
- const stepCompleted = account != null && account.realName != null && account.birthDay != null;
58
- useEffect(() => {
59
- if (stepCompleted)
60
- kyc.setStep(2);
61
- }, [stepCompleted, kyc]);
62
- useEffect(() => {
63
- if (account) {
64
- form.reset({
65
- realName: account.realName ?? '',
66
- birthDay: account.birthDay
67
- ? format(account.birthDay, 'yyyy-MM-dd')
68
- : '',
69
- });
70
- }
71
- }, [account, form]);
72
- const updateAccountMutation = useUpdateAccountMutation({
73
- onError(error) {
74
- toaster.error({
75
- title: 'Error',
76
- description: error.message,
77
- });
78
- },
79
- onSuccess() {
80
- kyc.setStep(2);
81
- toaster.success({
82
- title: 'Success',
83
- description: 'Basic information has been set successfully.',
84
- });
85
- },
86
- });
87
- return (_jsxs("div", { children: [_jsx(Dialog.Title, { className: "text-center text-lg font-semibold", children: "Basic Information" }), _jsx(Dialog.Description, { className: "text-text-secondary-700 mt-xs text-center text-sm", children: "Enter your basic details for identification and communication." }), _jsxs("form", { className: "mt-3", onSubmit: form.handleSubmit((data) => {
88
- invariant(account);
89
- const input = omitBy({
90
- realName: account.realName === data.realName ? undefined : data.realName,
91
- birthDay: account.birthDay && isSameDay(data.birthDay, account.birthDay)
92
- ? undefined
93
- : format(data.birthDay, 'yyyy-MM-dd'),
94
- }, isNil);
95
- if (size(input) === 0)
96
- return kyc.setStep(2);
97
- updateAccountMutation.mutate(input);
98
- }), children: [_jsxs(Field.Root, { invalid: !!form.formState.errors.realName, readOnly: !!accountQuery.data?.realName, children: [_jsx(Field.Label, { children: "Real Name" }), _jsx(Field.Input, { placeholder: "Enter your real name", ...form.register('realName') }), _jsx(Field.ErrorText, { children: form.formState.errors.realName?.message })] }), _jsxs(Field.Root, { className: "mt-3", invalid: !!form.formState.errors.branchCode, readOnly: !!accountQuery.data?.birthDay, children: [_jsx(Field.Label, { children: "Date of Birth" }), _jsx(Field.Input, { type: "date", ...form.register('birthDay') }), _jsx(Field.ErrorText, { children: form.formState.errors.birthDay?.message })] }), _jsx(Button, { type: "submit", className: "mt-8", disabled: accountQuery.isLoading ||
99
- updateAccountMutation.isPending ||
100
- stepCompleted, children: "Continue" })] })] }));
101
- }
@@ -1 +0,0 @@
1
- export declare function CaptureIdDocument(): import("react/jsx-runtime").JSX.Element;
@@ -1,219 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
- import { useEffect, useRef, useState } from 'react';
4
- import { twMerge } from 'tailwind-merge';
5
- import { useUploadImageFileMutation } from '../../client/hooks/useUploadImageFileMutation.js';
6
- import { ArrowLeftIcon } from '../../icons/ArrowLeftIcon.js';
7
- import { Camera01Icon } from '../../icons/Camera01Icon.js';
8
- import { CheckCircleIcon } from '../../icons/CheckCircleIcon.js';
9
- import { XIcon } from '../../icons/XIcon.js';
10
- import { Button } from '../../ui/Button/index.js';
11
- import { Dialog } from '../../ui/Dialog/index.js';
12
- import { useKYCContext } from './KYCContext.js';
13
- import NoCameraError from './NoCameraError.js';
14
- import { cameraErrorDescriptions, dataURLtoBlob, resizeFile, showPermissionInstructions, } from './utils.js';
15
- export function CaptureIdDocument() {
16
- const kyc = useKYCContext();
17
- const { mutate, isPending } = useUploadImageFileMutation();
18
- const [videoStream, setVideoStream] = useState(null);
19
- const [cameraError, setCameraError] = useState(null);
20
- const [isLoading, setIsLoading] = useState(false);
21
- const [selectedImage, setSelectedImage] = useState(null);
22
- const [captureInProgress, setCaptureInProgress] = useState(false);
23
- const [proccessImageCanvas, setProccessImageCanvas] = useState(null);
24
- const videoElement = useRef(null);
25
- const containerRef = useRef(null);
26
- function stopCamera() {
27
- if (videoStream) {
28
- videoStream.getTracks().forEach((track) => track.stop());
29
- setVideoStream(null);
30
- }
31
- }
32
- useEffect(() => {
33
- return () => {
34
- stopCamera();
35
- };
36
- }, [videoStream]);
37
- async function startCamera() {
38
- try {
39
- setIsLoading(true);
40
- setCameraError(null);
41
- setCaptureInProgress(true);
42
- console.log('Starting camera...');
43
- const stream = await navigator.mediaDevices.getUserMedia({
44
- video: {
45
- facingMode: 'environment',
46
- aspectRatio: 16 / 9,
47
- width: { ideal: 1920, max: 1920 },
48
- height: { ideal: 1080, max: 1080 },
49
- frameRate: {
50
- ideal: 30,
51
- max: 60,
52
- },
53
- },
54
- audio: false,
55
- });
56
- // Set the stream directly to the video element
57
- if (videoElement.current) {
58
- videoElement.current.srcObject = stream;
59
- videoElement.current.onloadedmetadata = () => {
60
- console.log('Video metadata loaded, starting playback...');
61
- videoElement.current
62
- ?.play()
63
- .then(() => {
64
- setVideoStream(stream);
65
- setIsLoading(false);
66
- })
67
- .catch(() => {
68
- setCameraError('Failed to start camera stream. Please try again.');
69
- setIsLoading(false);
70
- // Stop the stream if playback fails
71
- stream.getTracks().forEach((track) => track.stop());
72
- });
73
- };
74
- videoElement.current.onerror = (err) => {
75
- console.error('Video element error:', err);
76
- setCameraError('Video playback error. Please try again.');
77
- setIsLoading(false);
78
- stream.getTracks().forEach((track) => track.stop());
79
- };
80
- }
81
- else {
82
- console.error('Video element not available');
83
- setCameraError('Camera initialization failed. Please try again.');
84
- setCaptureInProgress(false);
85
- setIsLoading(false);
86
- stream.getTracks().forEach((track) => track.stop());
87
- }
88
- }
89
- catch (error) {
90
- setIsLoading(false);
91
- if (error instanceof DOMException) {
92
- console.error('Error accessing camera:', error.message);
93
- setCameraError(error.name);
94
- }
95
- else {
96
- console.error('Unknown error accessing camera:', error);
97
- setCameraError('An unknown error occurred. Please check permissions and try again.');
98
- }
99
- setCaptureInProgress(false);
100
- }
101
- }
102
- function captureAndProcessImage() {
103
- if (!videoElement.current || !videoStream) {
104
- console.error('Video element or stream not available for capture');
105
- return;
106
- }
107
- try {
108
- const canvas = document.createElement('canvas');
109
- const parentDiv = document.getElementById('parent');
110
- canvas.width = parentDiv?.clientWidth || videoElement.current.width;
111
- canvas.height = parentDiv?.clientHeight || videoElement.current.height;
112
- const ctx = canvas.getContext('2d');
113
- if (!ctx) {
114
- console.error('Could not get 2D context for canvas');
115
- setCameraError('Failed to process image. Please try again.');
116
- setCaptureInProgress(false);
117
- return;
118
- }
119
- ctx.drawImage(videoElement.current, 0, 0, canvas.width, canvas.height);
120
- const imageSrc = canvas.toDataURL('image/png', 1.0);
121
- setSelectedImage({ src: imageSrc });
122
- setCaptureInProgress(false);
123
- stopCamera();
124
- const newImg = document.createElement('img');
125
- newImg.src = imageSrc;
126
- //@ts-expect-error jscanify is not typed
127
- const scanner = new jscanify();
128
- newImg.onload = () => {
129
- try {
130
- if (containerRef.current) {
131
- // containerRef.current.innerHTML = '';
132
- const paperWidth = parentDiv?.clientWidth || videoElement.current?.videoWidth;
133
- const paperHeight = parentDiv?.clientHeight || videoElement.current?.videoHeight;
134
- //@ts-expect-error jscanify is not typed
135
- const contour = scanner.findPaperContour(cv.imread(newImg));
136
- const cornerPoints = scanner.getCornerPoints(contour);
137
- const resultCanvas = scanner.extractPaper(newImg, paperWidth, paperHeight, cornerPoints);
138
- newImg.className =
139
- 'absolute inset-0 m-auto w-full h-auto md:max-h-[333px] md:max-w-[643px] aspect-video rounded-lg object-contain';
140
- setProccessImageCanvas(resultCanvas);
141
- containerRef.current.appendChild(resultCanvas);
142
- setCaptureInProgress(false);
143
- setSelectedImage({ src: resultCanvas.toDataURL('image/png') });
144
- }
145
- }
146
- catch (error) {
147
- console.error('Error processing image:', error);
148
- setCameraError('Failed to process image. Please try again.');
149
- }
150
- };
151
- newImg.onerror = () => {
152
- console.error('Error loading image');
153
- setCameraError('NoIdDetectedError');
154
- };
155
- }
156
- catch (error) {
157
- console.error('Error capturing image:', error);
158
- setCameraError('NoIdDetectedError');
159
- setCaptureInProgress(false);
160
- }
161
- }
162
- async function uploadPhoto() {
163
- if (!proccessImageCanvas) {
164
- console.error('Failed to process the image. Please try again.');
165
- return;
166
- }
167
- const blob = proccessImageCanvas.toDataURL('image/png', 1.0);
168
- const processedBlob = dataURLtoBlob(blob);
169
- const img = new File([processedBlob], 'frontImage', { type: 'image/jpeg' });
170
- const resizedImage = (await resizeFile(img));
171
- if (resizedImage) {
172
- await mutate({
173
- file: resizedImage,
174
- }, {
175
- onSuccess: (data) => {
176
- kyc.setFrontImageId(data);
177
- kyc.setCapturing(null);
178
- },
179
- });
180
- }
181
- }
182
- function retakePhoto() {
183
- setSelectedImage(null);
184
- setCaptureInProgress(true);
185
- setCameraError(null);
186
- if (containerRef.current) {
187
- const canvas = containerRef.current.querySelector('canvas');
188
- if (canvas) {
189
- canvas.width = canvas.width;
190
- }
191
- containerRef.current.innerHTML = '';
192
- }
193
- if (videoElement.current) {
194
- videoElement.current.play();
195
- }
196
- startCamera();
197
- }
198
- function checkCameraPermission() {
199
- const constraints = { video: true };
200
- navigator.mediaDevices
201
- .getUserMedia(constraints)
202
- .then(() => {
203
- setCameraError(null);
204
- startCamera();
205
- })
206
- .catch(() => {
207
- showPermissionInstructions();
208
- });
209
- }
210
- return (_jsx(_Fragment, { children: _jsxs("div", { className: "w-full p-4 lg:w-[640px] lg:px-12 lg:py-4xl", children: [_jsxs("button", { type: "button", className: "flex items-center gap-lg lg:absolute lg:right-5 lg:top-5 lg:p-md", onClick: () => {
211
- stopCamera();
212
- kyc.setCapturing(null);
213
- }, children: [_jsx(XIcon, { className: "text-text-senary-300 hidden size-5 lg:block" }), _jsx(ArrowLeftIcon, { className: "text-text-senary-300 size-5 lg:hidden" }), _jsx("span", { className: "text-lg font-semibold lg:hidden", children: "Back" })] }), _jsx(Dialog.Title, { className: "mt-6 text-center text-lg font-semibold lg:mt-0", children: "Take a Picture of Your Front ID" }), _jsxs(Dialog.Description, { className: "lg:max-w-auto text-text-tertiary-600 mx-auto mt-sm max-w-[19rem] text-center text-sm lg:max-w-full", children: ["Make sure your ID is clearly visible, well-lit, and not blurry.", _jsx("br", { className: "hidden lg:block" }), " Avoid glare or reflections, and ensure all corners are within the frame."] }), _jsx("div", { id: "parent", className: "border-border-disabled mt-6 aspect-video rounded-xl border bg-black lg:mt-8", children: [
214
- 'NotAllowedError',
215
- 'NotReadableError',
216
- 'NotFoundError',
217
- 'NoIdDetectedError',
218
- ].includes(cameraError) ? (_jsx(NoCameraError, { onRetry: checkCameraPermission, title: "Camera Access Required", description: cameraErrorDescriptions[cameraError] })) : captureInProgress ? (_jsxs("div", { className: "relative flex h-fit w-full flex-col items-center justify-center", children: [_jsx("video", { ref: videoElement, autoPlay: true, muted: true, playsInline: true, className: "relative h-[50vh] w-full rounded-lg object-cover md:aspect-video md:max-h-[333px]", width: "100%", height: "100%" }), _jsxs("div", { className: "pointer-events-none absolute inset-0 z-50", children: [_jsx("div", { className: twMerge('absolute inset-0 w-full bg-black/60 backdrop-blur-sm [clip-path:polygon(0%_0%,0%_100%,calc(50%-158px)_100%,calc(50%-158px)_calc(50%-100px),calc(50%+158px)_calc(50%-100px),calc(50%+158px)_calc(50%+100px),calc(50%-158px)_calc(50%+100px),calc(50%-158px)_100%,100%_100%,100%_0%)] md:[clip-path:polygon(0%_0%,0%_100%,calc(50%-225px)_100%,calc(50%-225px)_calc(50%-142px),calc(50%+225px)_calc(50%-142px),calc(50%+225px)_calc(50%+142px),calc(50%-225px)_calc(50%+142px),calc(50%-225px)_100%,100%_100%,100%_0%)]') }), _jsx("div", { className: "absolute inset-0 z-[60] mx-auto flex items-center justify-center", children: _jsx("div", { className: "relative aspect-[1011/638] h-[200px] md:h-[295px] md:w-[450px]", children: _jsx("div", { className: "h-full w-full rounded-lg border-4 border-dashed border-[#B54708]" }) }) })] })] })) : (_jsx("div", { ref: containerRef, className: "relative grid h-full w-full place-items-center rounded-lg object-contain md:max-h-[333px]" })) }), captureInProgress ? (_jsxs(Button, { className: "disabled:bg-bg-disabled disabled:text-text-disabled mx-auto mt-6 px-xl disabled:opacity-100 lg:mt-8 lg:w-fit", onClick: captureAndProcessImage, children: ["Capture Image", _jsx(Camera01Icon, { className: "size-5" })] })) : selectedImage && selectedImage.src ? (_jsxs("div", { className: "mt-4 flex flex-col items-center justify-center gap-2 md:flex-row", children: [_jsxs(Button, { className: "lg:w-fit", type: "button", onClick: retakePhoto, children: ["Retake Photo ", _jsx(Camera01Icon, { className: "ml-1" })] }), _jsxs(Button, { className: "lg:w-fit", type: "button", onClick: uploadPhoto, disabled: isPending, children: ["Use Photo ", _jsx(CheckCircleIcon, { className: "ml-1" })] })] })) : (_jsxs(Button, { className: twMerge('disabled:bg-bg-disabled disabled:text-text-disabled mx-auto mt-6 px-xl disabled:opacity-100 lg:mt-8 lg:w-fit', cameraError && 'hidden'), onClick: startCamera, disabled: isLoading || !!videoStream, children: [isLoading ? 'Starting Camera...' : 'Start Camera', _jsx(Camera01Icon, { className: "size-5" })] }))] }) }));
219
- }
@@ -1 +0,0 @@
1
- export declare function CaptureSelfie(): import("react/jsx-runtime").JSX.Element;
@@ -1,285 +0,0 @@
1
- 'use client';
2
- import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
- import * as faceapi from 'face-api.js';
4
- import { useEffect, useRef, useState } from 'react';
5
- import { twMerge } from 'tailwind-merge';
6
- import { useUploadImageFileMutation } from '../../client/hooks/useUploadImageFileMutation.js';
7
- import { ArrowLeftIcon } from '../../icons/ArrowLeftIcon.js';
8
- import { Camera01Icon } from '../../icons/Camera01Icon.js';
9
- import { XIcon } from '../../icons/XIcon.js';
10
- import { Button } from '../../ui/Button/index.js';
11
- import { Dialog } from '../../ui/Dialog/index.js';
12
- import { onMobileDevice } from '../../utils/onMobileDevice.js';
13
- import { useKYCContext } from './KYCContext.js';
14
- import NoCameraError from './NoCameraError.js';
15
- import PersonOverlayDesktop from './PersonOverlayDesktop.js';
16
- import { dataURLtoBlob, loadFaceApiModels, resizeFile, showPermissionInstructions, } from './utils.js';
17
- export function CaptureSelfie() {
18
- const kyc = useKYCContext();
19
- const { mutate, isPending } = useUploadImageFileMutation();
20
- const mobileDevice = onMobileDevice();
21
- const [modelsLoaded, setModelsLoaded] = useState(false);
22
- const [videoStream, setVideoStream] = useState(null);
23
- const [cameraError, setCameraError] = useState(null);
24
- const [captureInProgress, setCaptureInProgress] = useState(false);
25
- const [selectedImage, setSelectedImage] = useState(null);
26
- const [isFaceCentered, setIsFaceCentered] = useState(false);
27
- const [isCapturing, setIsCapturing] = useState(false);
28
- const [countdown, setCountdown] = useState(3);
29
- const videoRef = useRef(null);
30
- const faceCanvasRef = useRef(null);
31
- const detectionIntervalRef = useRef(null);
32
- const countdownTimerRef = useRef(null);
33
- useEffect(() => {
34
- loadFaceApiModels()
35
- .then(() => setModelsLoaded(true))
36
- .catch(() => setModelsLoaded(false));
37
- }, []);
38
- useEffect(() => {
39
- if (captureInProgress) {
40
- startFaceDetection();
41
- }
42
- }, [captureInProgress]);
43
- async function startCamera() {
44
- try {
45
- setCaptureInProgress(true);
46
- const stream = await navigator.mediaDevices.getUserMedia({
47
- video: {
48
- facingMode: mobileDevice ? 'user' : 'environment',
49
- aspectRatio: mobileDevice ? 9 / 16 : 16 / 9,
50
- width: { ideal: 1920 },
51
- height: { ideal: 1080 },
52
- },
53
- audio: false,
54
- });
55
- setVideoStream(stream);
56
- if (videoRef.current) {
57
- videoRef.current.srcObject = stream;
58
- videoRef.current.onloadedmetadata = () => {
59
- videoRef.current
60
- ?.play()
61
- .then(() => {
62
- if (modelsLoaded) {
63
- startFaceDetection();
64
- }
65
- })
66
- .catch((error) => {
67
- console.error('Error playing video:', error);
68
- setCameraError('Failed to play video stream. Please check your camera settings.');
69
- });
70
- };
71
- }
72
- }
73
- catch (error) {
74
- if (error instanceof DOMException) {
75
- console.error('Error accessing camera:', error.message);
76
- setCameraError(error.name);
77
- }
78
- else {
79
- console.error('Unknown error accessing camera:', error);
80
- setCameraError('An unknown error occurred. Please check permissions and try again.');
81
- }
82
- setCaptureInProgress(false);
83
- stopCamera();
84
- }
85
- }
86
- function startFaceDetection() {
87
- if (!modelsLoaded) {
88
- console.error('Cannot start face detection: video element not ready or models not loaded');
89
- return;
90
- }
91
- if (!faceCanvasRef.current) {
92
- faceCanvasRef.current = faceapi.createCanvasFromMedia(videoRef.current);
93
- const parentDiv = document.getElementById('parent');
94
- faceCanvasRef.current.className = `absolute inset-0 m-auto h-${parentDiv?.clientHeight} w-${parentDiv?.clientWidth} md:aspect-video object-cover md:object-contain`;
95
- faceCanvasRef.current.style.width = `${videoRef.current?.clientWidth}px`;
96
- faceCanvasRef.current.style.height = `${videoRef.current?.clientHeight}px`;
97
- }
98
- const displaySize = {
99
- width: videoRef.current?.clientWidth || 643,
100
- height: videoRef.current?.clientHeight || 333,
101
- };
102
- // Clear any existing interval
103
- if (detectionIntervalRef.current) {
104
- clearInterval(detectionIntervalRef.current);
105
- }
106
- faceapi.matchDimensions(faceCanvasRef.current, displaySize);
107
- let countdownInterval = null;
108
- detectionIntervalRef.current = window.setInterval(async () => {
109
- if (!videoRef.current || !faceCanvasRef.current) {
110
- console.error('Video or canvas element is not ready');
111
- return;
112
- }
113
- try {
114
- const detection = await faceapi
115
- .detectSingleFace(videoRef.current, new faceapi.TinyFaceDetectorOptions())
116
- .withFaceLandmarks();
117
- if (detection) {
118
- const resizedDetection = faceapi.resizeResults(detection, displaySize);
119
- const frame_height = resizedDetection.detection.box.height;
120
- const frame_width = resizedDetection.detection.box.width;
121
- const frame_x = resizedDetection.detection.box.x;
122
- const frame_y = resizedDetection.detection.box.y;
123
- const faceCenterX = frame_x + frame_width / 2;
124
- const faceCenterY = frame_y + frame_height / 2;
125
- const screenCenterX = displaySize.width / 2;
126
- const screenCenterY = displaySize.height / 2;
127
- const centerThresholdX = displaySize.width * 0.15;
128
- const centerThresholdY = displaySize.height * 0.15;
129
- const isFaceCentered = Math.abs(faceCenterX - screenCenterX) <= centerThresholdX &&
130
- Math.abs(faceCenterY - screenCenterY) <= centerThresholdY;
131
- setIsFaceCentered(isFaceCentered);
132
- const faceDetectionConfidence = detection.detection.score * 100;
133
- // const context = faceCanvasRef.current.getContext('2d');
134
- // if (context) {
135
- // context.clearRect(
136
- // 0,
137
- // 0,
138
- // faceCanvasRef.current.width,
139
- // faceCanvasRef.current.height,
140
- // );
141
- // faceapi.draw.drawDetections(
142
- // faceCanvasRef.current,
143
- // resizedDetection,
144
- // );
145
- // faceapi.draw.drawFaceLandmarks(
146
- // faceCanvasRef.current,
147
- // resizedDetection,
148
- // );
149
- // }
150
- //adjust the faceDetectionConfidence if need
151
- if (isFaceCentered && faceDetectionConfidence >= 65) {
152
- if (!countdownInterval) {
153
- setIsCapturing(true);
154
- countdownInterval = setInterval(() => {
155
- setCountdown((prev) => {
156
- if (prev === 1) {
157
- clearInterval(countdownInterval);
158
- countdownInterval = null;
159
- captureImage();
160
- return 3;
161
- }
162
- return prev - 1;
163
- });
164
- }, 1000);
165
- }
166
- }
167
- else {
168
- if (countdownInterval) {
169
- clearInterval(countdownInterval);
170
- countdownInterval = null;
171
- setCountdown(3);
172
- setIsCapturing(false);
173
- }
174
- }
175
- }
176
- }
177
- catch (error) {
178
- console.error('Error during face detection:', error);
179
- setCameraError('An error occurred while detecting your face. Please try again.');
180
- }
181
- }, 100);
182
- }
183
- function stopCamera() {
184
- setCaptureInProgress(false);
185
- if (detectionIntervalRef.current) {
186
- clearInterval(detectionIntervalRef.current);
187
- detectionIntervalRef.current = null;
188
- }
189
- if (countdownTimerRef.current) {
190
- clearInterval(countdownTimerRef.current);
191
- countdownTimerRef.current = null;
192
- }
193
- if (videoStream) {
194
- videoStream.getTracks().forEach((track) => track.stop());
195
- setVideoStream(null);
196
- }
197
- if (videoRef.current && videoRef.current.srcObject) {
198
- const stream = videoRef.current.srcObject;
199
- stream.getTracks().forEach((track) => {
200
- track.stop();
201
- });
202
- videoRef.current.srcObject = null;
203
- videoRef.current.pause();
204
- videoRef.current.currentTime = 0;
205
- videoRef.current.load();
206
- }
207
- setCountdown(3);
208
- }
209
- function captureImage() {
210
- if (videoRef.current && faceCanvasRef.current) {
211
- const canvas = document.createElement('canvas');
212
- canvas.width = videoRef.current.videoWidth;
213
- canvas.height = videoRef.current.videoHeight;
214
- const context = canvas.getContext('2d');
215
- if (context) {
216
- context.drawImage(videoRef.current, 0, 0, canvas.width, canvas.height);
217
- const imageData = canvas.toDataURL('image/png');
218
- setSelectedImage(imageData);
219
- stopCamera();
220
- }
221
- }
222
- }
223
- function retakePhoto() {
224
- setSelectedImage(null);
225
- setCaptureInProgress(true);
226
- setCameraError(null);
227
- if (faceCanvasRef.current) {
228
- const canvas = faceCanvasRef.current.querySelector('canvas');
229
- if (canvas) {
230
- canvas.width = canvas.width;
231
- }
232
- faceCanvasRef.current.innerHTML = '';
233
- }
234
- if (videoRef.current) {
235
- videoRef.current.play();
236
- }
237
- startCamera();
238
- }
239
- async function usePhoto() {
240
- if (!selectedImage) {
241
- console.error('No photo selected to use');
242
- return;
243
- }
244
- const blob = dataURLtoBlob(selectedImage);
245
- const img = new File([blob], 'image', { type: blob.type });
246
- const resizedImage = (await resizeFile(img));
247
- if (resizedImage) {
248
- await mutate({
249
- file: resizedImage,
250
- }, {
251
- onSuccess: (data) => {
252
- kyc.setSelfieImageId(data);
253
- kyc.setCapturing(null);
254
- stopCamera();
255
- },
256
- });
257
- }
258
- }
259
- function checkCameraPermission() {
260
- const constraints = { video: true };
261
- navigator.mediaDevices
262
- .getUserMedia(constraints)
263
- .then(() => {
264
- setCameraError(null);
265
- startCamera();
266
- })
267
- .catch(() => {
268
- showPermissionInstructions();
269
- });
270
- }
271
- useEffect(() => {
272
- return () => {
273
- if (detectionIntervalRef.current) {
274
- clearInterval(detectionIntervalRef.current);
275
- }
276
- if (countdownTimerRef.current) {
277
- clearInterval(countdownTimerRef.current);
278
- }
279
- };
280
- }, []);
281
- return (_jsxs("div", { className: "w-full p-4 lg:w-[640px] lg:px-12 lg:py-4xl", children: [_jsxs("button", { type: "button", className: "flex items-center gap-lg lg:absolute lg:right-5 lg:top-5 lg:p-md", onClick: () => {
282
- stopCamera();
283
- kyc.setCapturing(null);
284
- }, children: [_jsx(XIcon, { className: "text-text-senary-300 hidden size-5 lg:block" }), _jsx(ArrowLeftIcon, { className: "text-text-senary-300 size-5 lg:hidden" }), _jsx("span", { className: "text-lg font-semibold lg:hidden", children: "Back" })] }), _jsx(Dialog.Title, { className: "mt-6 text-center text-lg font-semibold lg:mt-0", children: "Take a Selfie Holding Your ID" }), _jsx(Dialog.Description, { className: "text-text-tertiary-600 mx-auto mt-sm max-w-[19rem] text-center text-sm lg:max-w-full", children: "Make sure your face and ID are clearly visible, with no glare or blur." }), _jsx("div", { id: "parent", className: "border-border-disabled mt-6 aspect-video rounded-xl border bg-black lg:mt-8", children: ['NotAllowedError', 'NotReadableError', 'NotFoundError'].includes(cameraError) ? (_jsx(NoCameraError, { onRetry: checkCameraPermission, title: "Camera Access Required", description: "We were unable to detect a camera on your device. Please ensure it is properly connected and accessible to this application." })) : captureInProgress && !cameraError ? (_jsxs("div", { className: "relative flex h-fit w-full flex-col items-center justify-center", children: [_jsx("video", { ref: videoRef, autoPlay: true, muted: true, playsInline: true, className: "h-[60vh] w-full rounded-lg object-cover md:aspect-video md:h-[333px]", width: "100%", height: "100%" }), _jsx("canvas", { ref: faceCanvasRef, className: "absolute inset-0 h-[60vh] w-full object-cover md:aspect-video md:h-[333px] md:object-contain", width: "100%", height: "100%" }), isCapturing && (_jsx("span", { className: "absolute inset-x-0 bottom-8 flex items-center justify-center text-5xl font-bold text-[#713B12CC] md:bottom-4", children: countdown })), !isFaceCentered && (_jsx("span", { className: "absolute inset-x-0 bottom-12 mx-auto w-1/2 text-center text-xs text-white md:bottom-3", children: "Please center your face in the camera view. Make sure your ID is clearly visible next to your face." })), _jsx(PersonOverlayDesktop, { isFaceCentered: isFaceCentered, width: videoRef.current?.clientWidth || 543, height: videoRef.current?.clientHeight || 333 })] })) : (selectedImage && (_jsx("img", { src: selectedImage, alt: "Captured Photo", className: "h-full w-full rounded-lg object-cover md:aspect-video md:h-[333px]" }))) }), selectedImage && (_jsxs("div", { className: "flex flex-col items-center justify-center gap-2 md:flex-row", children: [_jsxs(Button, { className: "disabled:bg-bg-disabled disabled:text-text-disabled mx-auto mt-4 px-xl disabled:opacity-100", size: "sm", onClick: retakePhoto, type: "button", children: ["Rekate Photo", _jsx(Camera01Icon, { className: "size-5" })] }), _jsxs(Button, { className: "disabled:bg-bg-disabled disabled:text-text-disabled mx-auto mt-4 px-xl disabled:opacity-100", size: "sm", onClick: usePhoto, type: "button", disabled: isPending, children: ["Use Photo", _jsx(Camera01Icon, { className: "size-5" })] })] })), !captureInProgress && !cameraError && (_jsxs(Button, { className: twMerge('mx-auto mt-6 px-xl lg:mt-8', selectedImage && 'hidden'), onClick: startCamera, disabled: !modelsLoaded, type: "button", children: ["Start Camera", _jsx(Camera01Icon, { className: "size-5" })] }))] }));
285
- }
@@ -1,5 +0,0 @@
1
- interface Props {
2
- id: string;
3
- }
4
- declare function DisplayImage({ id }: Props): import("react/jsx-runtime").JSX.Element;
5
- export default DisplayImage;