@opexa/portal-components 0.0.786 → 0.0.788

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