@opexa/portal-components 0.0.775 → 0.0.777

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 (214) hide show
  1. package/dist/components/AccountInfo/GoogleDisconnect.d.ts +7 -0
  2. package/dist/components/AccountInfo/GoogleDisconnect.js +11 -0
  3. package/dist/components/DepositWithdrawal/Deposit/GCashWebpayDeposit /GCashWebpayDeposit .d.ts +1 -0
  4. package/dist/components/DepositWithdrawal/Deposit/GCashWebpayDeposit /GCashWebpayDeposit .js +191 -0
  5. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/QRPHDepositContext.d.ts +2 -2
  6. package/dist/components/DepositWithdrawal/Deposit/QRPHDeposit/useQRPHDeposit.d.ts +1 -1
  7. package/dist/components/DigitainLauncher/Loading.js +1 -1
  8. package/dist/components/Jackpots/Jackpots.module.css +223 -219
  9. package/dist/components/Jackpots/JackpotsCarousel/JackpotsCarouselItem.module.css +184 -184
  10. package/dist/components/Jackpots/JackpotsCarouselNext/JackpotsCarouselItem.js +1 -1
  11. package/dist/components/Jackpots/JackpotsList/JackpotsListItem.module.css +184 -184
  12. package/dist/components/KYC/BasicInformation.js +1 -1
  13. package/dist/components/KYC/IdentityVerification.js +1 -1
  14. package/dist/components/KYC/KYC.lazy.js +1 -1
  15. package/dist/components/KYC/KYCDefault/KYCVerificationStatus.lazy.js +2 -2
  16. package/dist/components/KYC/KYCVerificationStatus.lazy.js +7 -13
  17. package/dist/components/KYC/PersonalInformation.js +1 -1
  18. package/dist/components/Quests/Quests.client.js +9 -6
  19. package/dist/components/Quests/WageringQuest__next.d.ts +27 -0
  20. package/dist/components/Quests/WageringQuest__next.js +125 -0
  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.d.ts +2 -2
  26. package/dist/services/queries.js +3128 -3122
  27. package/dist/styles/theme.css +773 -773
  28. package/dist/types/index.d.ts +8 -0
  29. package/dist/ui/AlertDialog/AlertDialog.d.ts +187 -187
  30. package/dist/ui/AlertDialog/alertDialog.recipe.d.ts +17 -17
  31. package/dist/ui/Carousel/Carousel.d.ts +72 -72
  32. package/dist/ui/Carousel/carousel.recipe.d.ts +8 -8
  33. package/dist/ui/Checkbox/Checkbox.d.ts +23 -23
  34. package/dist/ui/Checkbox/checkbox.recipe.d.ts +3 -3
  35. package/dist/ui/Clipboard/Clipboard.d.ts +18 -18
  36. package/dist/ui/Clipboard/clipboard.recipe.d.ts +3 -3
  37. package/dist/ui/Collapsible/Collapsible.d.ts +20 -20
  38. package/dist/ui/Collapsible/collapsible.recipe.d.ts +5 -5
  39. package/dist/ui/Combobox/Combobox.d.ts +42 -42
  40. package/dist/ui/Combobox/combobox.recipe.d.ts +3 -3
  41. package/dist/ui/DatePicker/DatePicker.d.ts +72 -72
  42. package/dist/ui/DatePicker/datePicker.recipe.d.ts +3 -3
  43. package/dist/ui/Dialog/Dialog.d.ts +33 -33
  44. package/dist/ui/Dialog/dialog.recipe.d.ts +3 -3
  45. package/dist/ui/Drawer/Drawer.d.ts +33 -33
  46. package/dist/ui/Drawer/drawer.recipe.d.ts +3 -3
  47. package/dist/ui/Menu/Menu.d.ts +306 -306
  48. package/dist/ui/Menu/menu.recipe.d.ts +17 -17
  49. package/dist/ui/Popover/Popover.d.ts +121 -121
  50. package/dist/ui/Popover/popover.recipe.d.ts +11 -11
  51. package/dist/ui/SegmentGroup/SegmentGroup.d.ts +18 -18
  52. package/dist/ui/SegmentGroup/segmentGroup.recipe.d.ts +3 -3
  53. package/dist/ui/Select/Select.d.ts +45 -45
  54. package/dist/ui/Select/select.recipe.d.ts +3 -3
  55. package/dist/ui/Table/Table.d.ts +21 -21
  56. package/dist/ui/Table/table.anatomy.d.ts +1 -1
  57. package/dist/ui/Table/table.recipe.d.ts +3 -3
  58. package/dist/ui/Tabs/Tabs.d.ts +15 -15
  59. package/dist/ui/Tabs/tabs.recipe.d.ts +3 -3
  60. package/dist/ui/Tooltip/Tooltip.d.ts +30 -30
  61. package/dist/ui/Tooltip/tooltip.recipe.d.ts +5 -5
  62. package/package.json +176 -176
  63. package/dist/components/Disclaimer/ResponsibleGaming.d.ts +0 -10
  64. package/dist/components/Disclaimer/ResponsibleGaming.js +0 -13
  65. package/dist/components/Disclaimer/TermsOfUse.d.ts +0 -11
  66. package/dist/components/Disclaimer/TermsOfUse.js +0 -13
  67. package/dist/components/FeatureFlag/FeatureFlag.d.ts +0 -1
  68. package/dist/components/FeatureFlag/FeatureFlag.js +0 -29
  69. package/dist/components/FeatureFlag/index.d.ts +0 -1
  70. package/dist/components/FeatureFlag/index.js +0 -1
  71. package/dist/components/KYC/AutoOpen.d.ts +0 -1
  72. package/dist/components/KYC/AutoOpen.js +0 -40
  73. package/dist/components/KYC/CaptureIdDocument.d.ts +0 -1
  74. package/dist/components/KYC/CaptureIdDocument.js +0 -219
  75. package/dist/components/KYC/CaptureSelfie.d.ts +0 -1
  76. package/dist/components/KYC/CaptureSelfie.js +0 -285
  77. package/dist/components/KYC/DisplayImage.d.ts +0 -5
  78. package/dist/components/KYC/DisplayImage.js +0 -8
  79. package/dist/components/KYC/FileUpload.d.ts +0 -10
  80. package/dist/components/KYC/FileUpload.js +0 -72
  81. package/dist/components/KYC/NoCameraError.d.ts +0 -7
  82. package/dist/components/KYC/NoCameraError.js +0 -6
  83. package/dist/components/KYC/PersonOverlayDesktop.d.ts +0 -7
  84. package/dist/components/KYC/PersonOverlayDesktop.js +0 -9
  85. package/dist/components/KYC/backup/Header.d.ts +0 -1
  86. package/dist/components/KYC/backup/Header.js +0 -8
  87. package/dist/components/KYC/backup/Indicator.d.ts +0 -1
  88. package/dist/components/KYC/backup/Indicator.js +0 -9
  89. package/dist/components/KYC/backup/KYC.d.ts +0 -1
  90. package/dist/components/KYC/backup/KYC.js +0 -14
  91. package/dist/components/KYC/backup/KYC.lazy.d.ts +0 -1
  92. package/dist/components/KYC/backup/KYC.lazy.js +0 -26
  93. package/dist/components/KYC/backup/KYCContext.d.ts +0 -6
  94. package/dist/components/KYC/backup/KYCContext.js +0 -2
  95. package/dist/components/KYC/backup/Step1.d.ts +0 -1
  96. package/dist/components/KYC/backup/Step1.js +0 -13
  97. package/dist/components/KYC/backup/Step2.d.ts +0 -1
  98. package/dist/components/KYC/backup/Step2.js +0 -13
  99. package/dist/components/KYC/backup/Step3.d.ts +0 -1
  100. package/dist/components/KYC/backup/Step3.js +0 -13
  101. package/dist/components/KYC/backup/Step4.d.ts +0 -1
  102. package/dist/components/KYC/backup/Step4.js +0 -7
  103. package/dist/components/KYC/backup/useKYC.d.ts +0 -10
  104. package/dist/components/KYC/backup/useKYC.js +0 -8
  105. package/dist/components/KYC/loadModels.d.ts +0 -1
  106. package/dist/components/KYC/loadModels.js +0 -9
  107. package/dist/components/KYC/utils.d.ts +0 -9
  108. package/dist/components/KYC/utils.js +0 -79
  109. package/dist/components/Messages/Message.d.ts +0 -1
  110. package/dist/components/Messages/Message.js +0 -35
  111. package/dist/components/Messages/MessageContext.d.ts +0 -6
  112. package/dist/components/Messages/MessageContext.js +0 -2
  113. package/dist/components/Messages/MessagePopup.d.ts +0 -1
  114. package/dist/components/Messages/MessagePopup.js +0 -20
  115. package/dist/components/Messages/MessageTrigger.d.ts +0 -8
  116. package/dist/components/Messages/MessageTrigger.js +0 -19
  117. package/dist/components/Quests/CountdownTimer.d.ts +0 -15
  118. package/dist/components/Quests/CountdownTimer.js +0 -33
  119. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.d.ts +0 -4
  120. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuest.js +0 -78
  121. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.d.ts +0 -8
  122. package/dist/components/Quests/DailyCheckInQuest/DailyCheckInQuestModal.js +0 -9
  123. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.d.ts +0 -4
  124. package/dist/components/Quests/OnboardingQuest/OnboardingQuest.js +0 -4
  125. package/dist/components/Quests/WageringQuest/WageringQuest.d.ts +0 -4
  126. package/dist/components/Quests/WageringQuest/WageringQuest.js +0 -20
  127. package/dist/components/Quests/WageringQuest/WageringQuestModal.d.ts +0 -9
  128. package/dist/components/Quests/WageringQuest/WageringQuestModal.js +0 -9
  129. package/dist/components/SignIn/utils.d.ts +0 -8
  130. package/dist/components/SignIn/utils.js +0 -26
  131. package/dist/components/SignUp/SignUp.lazy.d.ts +0 -12
  132. package/dist/components/SignUp/SignUp.lazy.js +0 -18
  133. package/dist/components/SignUp/SignUpContext.d.ts +0 -6
  134. package/dist/components/SignUp/SignUpContext.js +0 -2
  135. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.d.ts +0 -17
  136. package/dist/components/SignUp/SignUpDefault/SignUp.lazy.js +0 -18
  137. package/dist/components/SignUp/SignUpDefault/SignUpContext.d.ts +0 -6
  138. package/dist/components/SignUp/SignUpDefault/SignUpContext.js +0 -2
  139. package/dist/components/SignUp/SignUpDefault/SignUpForm.d.ts +0 -1
  140. package/dist/components/SignUp/SignUpDefault/SignUpForm.js +0 -310
  141. package/dist/components/SignUp/SignUpForm.d.ts +0 -1
  142. package/dist/components/SignUp/SignUpForm.js +0 -284
  143. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.d.ts +0 -1
  144. package/dist/components/SignUp/SignUpKYC/CaptureIdDocument.js +0 -198
  145. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.d.ts +0 -1
  146. package/dist/components/SignUp/SignUpKYC/CaptureSelfie.js +0 -251
  147. package/dist/components/SignUp/SignUpKYC/ImageUploader.d.ts +0 -10
  148. package/dist/components/SignUp/SignUpKYC/ImageUploader.js +0 -42
  149. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.d.ts +0 -7
  150. package/dist/components/SignUp/SignUpKYC/PersonOverlayDesktop.js +0 -9
  151. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.d.ts +0 -1
  152. package/dist/components/SignUp/SignUpKYC/SignUpFormKYC.js +0 -464
  153. package/dist/components/SignUp/SignUpKYC/useImageUploader.d.ts +0 -11
  154. package/dist/components/SignUp/SignUpKYC/useImageUploader.js +0 -20
  155. package/dist/components/SignUp/SignUpKYC/utils.d.ts +0 -9
  156. package/dist/components/SignUp/SignUpKYC/utils.js +0 -79
  157. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.d.ts +0 -1
  158. package/dist/components/SignUp/SignUpPagcor/CaptureIdDocument.js +0 -198
  159. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.d.ts +0 -1
  160. package/dist/components/SignUp/SignUpPagcor/CaptureSelfie.js +0 -251
  161. package/dist/components/SignUp/SignUpPagcor/ImageUploader.d.ts +0 -10
  162. package/dist/components/SignUp/SignUpPagcor/ImageUploader.js +0 -41
  163. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.d.ts +0 -1
  164. package/dist/components/SignUp/SignUpPagcor/SignUpFormPagcor.js +0 -429
  165. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.d.ts +0 -13
  166. package/dist/components/SignUp/SignUpPagcor/SignUpPagcor.lazy.js +0 -26
  167. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.d.ts +0 -7
  168. package/dist/components/SignUp/SignUpPagcor/SignUpPagcorContext.js +0 -2
  169. package/dist/components/SignUp/SignUpPagcor/useImageUploader.d.ts +0 -11
  170. package/dist/components/SignUp/SignUpPagcor/useImageUploader.js +0 -20
  171. package/dist/components/shared/IdDocumentField.client.d.ts +0 -25
  172. package/dist/components/shared/IdDocumentField.client.js +0 -204
  173. package/dist/components/shared/IdDocumentField.d.ts +0 -2
  174. package/dist/components/shared/IdDocumentField.js +0 -11
  175. package/dist/components/shared/SelfieField.client.d.ts +0 -20
  176. package/dist/components/shared/SelfieField.client.js +0 -327
  177. package/dist/components/shared/SelfieField.d.ts +0 -2
  178. package/dist/components/shared/SelfieField.js +0 -11
  179. package/dist/constants/BranchCode.d.ts +0 -4
  180. package/dist/constants/BranchCode.js +0 -42
  181. package/dist/constants/Branches.d.ts +0 -2
  182. package/dist/constants/Branches.js +0 -42
  183. package/dist/handlers/postTransformIdFrontImage.d.ts +0 -3
  184. package/dist/handlers/postTransformIdFrontImage.js +0 -67
  185. package/dist/handlers/postTransformSelfieImage.d.ts +0 -3
  186. package/dist/handlers/postTransformSelfieImage.js +0 -71
  187. package/dist/handlers.d.ts +0 -43
  188. package/dist/handlers.js +0 -297
  189. package/dist/icons/BellRingIcon.d.ts +0 -2
  190. package/dist/icons/BellRingIcon.js +0 -4
  191. package/dist/third-parties/FacebookPixel/FacebookPixel.d.ts +0 -4
  192. package/dist/third-parties/FacebookPixel/FacebookPixel.js +0 -4
  193. package/dist/third-parties/FacebookPixel/api.d.ts +0 -0
  194. package/dist/third-parties/FacebookPixel/api.js +0 -1
  195. package/dist/third-parties/FacebookPixel/index.d.ts +0 -1
  196. package/dist/third-parties/FacebookPixel/index.js +0 -1
  197. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.d.ts +0 -4
  198. package/dist/third-parties/GoogleRecaptcha/GoogleRecaptcha.js +0 -4
  199. package/dist/third-parties/GoogleRecaptcha/api.d.ts +0 -0
  200. package/dist/third-parties/GoogleRecaptcha/api.js +0 -1
  201. package/dist/third-parties/GoogleRecaptcha/index.d.ts +0 -1
  202. package/dist/third-parties/GoogleRecaptcha/index.js +0 -1
  203. package/dist/third-parties/index.d.ts +0 -2
  204. package/dist/third-parties/index.js +0 -2
  205. package/dist/utils/dataUrlToBlob.d.ts +0 -1
  206. package/dist/utils/dataUrlToBlob.js +0 -11
  207. package/dist/utils/gamesAvailable3pmTo3am.d.ts +0 -1
  208. package/dist/utils/gamesAvailable3pmTo3am.js +0 -1
  209. package/dist/utils/getGameName.d.ts +0 -1
  210. package/dist/utils/getGameName.js +0 -6
  211. package/dist/utils/isBetween3amAnd3pm.d.ts +0 -1
  212. package/dist/utils/isBetween3amAnd3pm.js +0 -5
  213. package/dist/utils/resizeImageSize.d.ts +0 -2
  214. package/dist/utils/resizeImageSize.js +0 -11
@@ -0,0 +1,125 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ import useEmblaCarousel from 'embla-carousel-react';
4
+ import { isString } from 'lodash-es';
5
+ import Image from 'next/image';
6
+ import Link from 'next/link';
7
+ import { useCallback, useEffect, useMemo, useState } from 'react';
8
+ import { twMerge } from 'tailwind-merge';
9
+ import { useControllableState } from '../../client/hooks/useControllableState.js';
10
+ import { useDisclosure } from '../../client/hooks/useDisclosure.js';
11
+ import { useFeatureFlag } from '../../client/hooks/useFeatureFlag.js';
12
+ import { useLocaleInfo } from '../../client/hooks/useLocaleInfo.js';
13
+ import { GAME_PROVIDER_DATA } from '../../constants/index.js';
14
+ import { ArrowLeftIcon } from '../../icons/ArrowLeftIcon.js';
15
+ import { ArrowRightIcon } from '../../icons/ArrowRightIcon.js';
16
+ import { Flag05Icon } from '../../icons/Flag05Icon.js';
17
+ import { Lock01Icon } from '../../icons/Lock01Icon.js';
18
+ import { XIcon } from '../../icons/XIcon.js';
19
+ import { Button } from '../../ui/Button/index.js';
20
+ import { Dialog } from '../../ui/Dialog/index.js';
21
+ import { Portal } from '../../ui/Portal/index.js';
22
+ import { Prose } from '../../ui/Prose/index.js';
23
+ import { formatNumber } from '../../utils/formatNumber.js';
24
+ import { parseDecimal } from '../../utils/parseDecimal.js';
25
+ import { useQuestContext } from './QuestsContext.js';
26
+ import { RemainingTime } from './RemainingTime.js';
27
+ export function WageringQuestNext(props) {
28
+ const { className, showTurnoverDecimals = true } = props;
29
+ const classNames = isString(className) ? { root: className } : className;
30
+ const quest = useQuestContext();
31
+ const disclosure = useDisclosure();
32
+ const localeInfo = useLocaleInfo();
33
+ const { progressPercentage, turnover, targetTurnover, name, description, bonus, status, } = quest;
34
+ const currentStage = useMemo(() => {
35
+ return quest.stage === null ||
36
+ quest.stage === undefined ||
37
+ quest.stage === 0
38
+ ? (quest?.stage ?? 0) + 1
39
+ : quest.stage;
40
+ }, [quest.stage]);
41
+ const formatTurnover = (value) => {
42
+ if (showTurnoverDecimals) {
43
+ return value;
44
+ }
45
+ // Remove decimals and format as whole number
46
+ const numericValue = parseFloat(value);
47
+ return Math.floor(numericValue).toString();
48
+ };
49
+ return (_jsxs(_Fragment, { children: [_jsxs("div", { className: twMerge('flex h-full w-full flex-col space-y-6 rounded-2xl border border-border-primary bg-bg-tertiary px-4 pt-5 pb-6', classNames?.root), children: [_jsxs("div", { className: "flex flex-col space-y-2", children: [_jsxs("div", { className: "flex max-h-7.5 items-start gap-2", children: [_jsxs("div", { className: "flex w-fit items-center gap-1 rounded-md border border-[#9E165F] bg-[#4E0D30] px-2 py-1", children: [_jsx(Flag05Icon, { className: "size-4 text-[#EE46BC]" }), _jsxs("p", { className: "font-medium text-[#FAA7E0] text-sm", children: ["Stage ", currentStage] })] }), _jsx(RemainingTime, {})] }), _jsx("p", { className: "font-semibold text-xl", children: name }), _jsx(Prose, { className: "text-wrap font-normal text-sm text-text-secondary-700", dangerouslySetInnerHTML: { __html: description } })] }), _jsxs("div", { className: "flex w-full flex-col space-y-2", children: [_jsxs("div", { className: "group flex items-center justify-between text-text-primary-brand", children: [_jsxs("p", { children: ["Progress ", parseDecimal(progressPercentage, 0).toFixed(0), "%"] }), _jsxs("p", { children: [formatTurnover(turnover), _jsxs("span", { className: "text-text-quarterary-brand", children: ["/", targetTurnover, " ", localeInfo.currency.code] })] })] }), _jsx("div", { className: twMerge('h-2 w-full overflow-hidden rounded-full bg-bg-primary', classNames?.progressBarContainer), children: _jsx("div", { className: twMerge('h-full rounded-full bg-utility-brand-600 transition-all duration-300', classNames?.progressBar), style: { width: `${progressPercentage}%` } }) }), _jsxs("div", { className: "group flex items-center justify-between text-text-primary-brand", children: [_jsxs("p", { children: ["Stage ", currentStage, " of ", quest?.program.stages?.length] }), _jsxs("div", { className: twMerge('rounded-[6px] border border-border-secondary bg-bg-secondary-alt px-1.5 py-0.5 font-medium text-xs leading-tight'), children: ["+", formatNumber(bonus, {
50
+ currency: localeInfo.currency.code,
51
+ }), ' ', "Bonus"] })] })] }), status === 'IN_PROGRESS' && (_jsx("div", { className: "flex h-full items-end", children: _jsx(Button, { size: "sm", onClick: () => disclosure.setOpen(true), "aria-label": "View Details", disabled: false, className: "disabled:bg-bg-primary disabled:text-text-disabled", children: "View Details" }) }))] }), _jsx(Rules, { open: disclosure.open, onOpenChange: disclosure.setOpen, gameProviderCarousel: props.gameProviderCarousel, gameProviders: Object.entries(quest.turnoverRequirementContributionPercentagePerGameProvider ?? [])
52
+ .filter(([_, value]) => +value > 0)
53
+ .map(([key]) => key) })] }));
54
+ }
55
+ function Rules(props) {
56
+ const quest = useQuestContext();
57
+ const featureFlag = useFeatureFlag();
58
+ const [open, setOpen] = useControllableState({
59
+ value: props.open,
60
+ defaultValue: props.defaultOpen ?? false,
61
+ onChange: props.onOpenChange,
62
+ });
63
+ const currentStage = useMemo(() => {
64
+ return quest.stage === null ||
65
+ quest.stage === undefined ||
66
+ quest.stage === 0
67
+ ? (quest?.stage ?? 0) + 1
68
+ : quest.stage;
69
+ }, [quest.stage]);
70
+ return (_jsx(Dialog.Root, { lazyMount: true, unmountOnExit: true, open: open, onOpenChange: (details) => setOpen(details.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: "mx-auto min-h-auto max-w-[400px] overflow-y-auto rounded-xl px-4 pt-5 pb-0", children: [_jsx(Dialog.CloseTrigger, { children: _jsx(XIcon, {}) }), _jsxs("div", { className: "flex flex-col space-y-5", children: [_jsx("h2", { className: "font-semibold text-lg text-text-primary-900", children: quest.name }), _jsx("p", { className: "mb-4 font-normal text-sm text-text-tertiary-600", children: "Play and roll your way to rewards! Ready for a challenge? Complete them all and get amazing rewards!" })] }), (quest?.program.stages ?? []).map((stage, index) => currentStage >= index + 1 ? (_jsx(StageItemUnlocked, { stageDetails: stage, stageLevel: currentStage, index: index, writableBonus: quest.bonus, questCompleted: quest.status === 'COMPLETED' }, index)) : (_jsx(StageItemLocked, { index: index }, index))), ((!featureFlag.enabled &&
71
+ (window.location.href.includes('blucky') ||
72
+ window.location.href.includes('powerplay') ||
73
+ window.location.href.includes('inplay'))) ||
74
+ featureFlag.enabled) && (_jsx(GameProvidersCarousel, { gameProviders: props.gameProviders ?? [] })), _jsx("div", { className: "pt-6 pb-4", children: _jsx(Button, { onClick: () => setOpen(false), children: "Close" }) })] }) })] }) }));
75
+ }
76
+ export function GameProvidersCarousel({ ...props }) {
77
+ const context = useQuestContext();
78
+ const [emblaRef, emblaApi] = useEmblaCarousel({
79
+ align: 'start',
80
+ slidesToScroll: 2,
81
+ });
82
+ const [prevBtnDisabled, setPrevBtnDisabled] = useState(true);
83
+ const [nextBtnDisabled, setNextBtnDisabled] = useState(true);
84
+ const onPrevButtonClick = useCallback(() => emblaApi?.scrollPrev(), [emblaApi]);
85
+ const onNextButtonClick = useCallback(async () => {
86
+ emblaApi?.scrollNext();
87
+ }, [emblaApi]);
88
+ const onSelect = useCallback((emblaApi) => {
89
+ setPrevBtnDisabled(!emblaApi?.canScrollPrev());
90
+ setNextBtnDisabled(!emblaApi?.canScrollNext());
91
+ }, []);
92
+ useEffect(() => {
93
+ if (!emblaApi)
94
+ return;
95
+ onSelect(emblaApi);
96
+ emblaApi.on('reInit', onSelect).on('select', onSelect);
97
+ }, [emblaApi, onSelect]);
98
+ const gameProviders = props.gameProviders.map((provider) => GAME_PROVIDER_DATA[provider]);
99
+ const classNames = isString(context.className)
100
+ ? { root: context.className }
101
+ : (context.className ?? {});
102
+ return (_jsxs("div", { className: twMerge(classNames.root, gameProviders.length === 0 && 'hidden'), children: [_jsxs("div", { className: "flex items-center", children: [_jsx("h2", { className: "font-semibold text-lg", children: context.heading ?? 'Game Providers' }), _jsx("div", { className: "grow" }), _jsx("div", { className: "flex items-center justify-center gap-xl", children: _jsxs("div", { className: "hidden lg:flex", children: [_jsx(Button, { variant: "outline", colorScheme: "gray", className: "rounded-r-none border-r-0", onClick: onPrevButtonClick, disabled: prevBtnDisabled, "aria-label": "Previous", children: _jsx(ArrowLeftIcon, { className: "size-5" }) }), _jsx(Button, { variant: "outline", colorScheme: "gray", className: "rounded-l-none", onClick: onNextButtonClick, disabled: nextBtnDisabled, "aria-label": "Next", children: _jsx(ArrowRightIcon, { className: "size-5" }) })] }) })] }), _jsx("div", { ref: emblaRef, className: twMerge('relative mt-lg overflow-hidden', classNames.thumbnailRootContainer), children: _jsx("div", { className: twMerge('flex gap-1.5', classNames.thumbnailContainer), children: gameProviders.map((provider) => {
103
+ const url = context.settings
104
+ ? (context.settings
105
+ .find(({ providers }) => providers.includes(provider.id))
106
+ ?.url.replace(':slug', provider.slug)
107
+ .replace(':id', provider?.id) ??
108
+ `/providers/${provider.slug}`)
109
+ : `/providers/${provider.slug}`;
110
+ return (_jsx(Link, { href: url, className: twMerge('flex h-16 w-[110px] flex-shrink-0 items-center overflow-hidden rounded-md bg-brand-800', classNames.thumbnailRoot), "aria-label": `View ${provider.name} games`, children: _jsx(Image, { src: context.gameProviderImages?.[provider.id] ?? provider.logo, alt: "", width: 300, height: 150, className: twMerge('mx-auto h-auto w-full object-contain', classNames.thumbnailImage) }) }, provider.id));
111
+ }) }) })] }));
112
+ }
113
+ function StageItemUnlocked({ stageLevel, stageDetails, index, writableBonus, questCompleted, }) {
114
+ const quest = useQuestContext();
115
+ const isCompleted = questCompleted || stageLevel > index + 1;
116
+ const progress = stageLevel > index + 1
117
+ ? 100
118
+ : Math.round(Number(quest.progressPercentage ?? 0));
119
+ return (_jsxs("div", { className: "mb-4 flex flex-col justify-between rounded-xl bg-bg-tertiary p-3", children: [_jsxs("div", { className: "flex items-center justify-between space-x-2", children: [_jsxs("p", { className: "font-medium", children: ["Stage ", index + 1] }), isCompleted ? (_jsx("div", { className: "w-fit rounded-full border border-[#085D3A] bg-[#053321] px-2 py-0.5", children: _jsx("p", { className: "font-medium text-[#75E0A7] text-sm", children: "Completed" }) })) : (_jsx("div", { className: "w-fit rounded-full border border-[#065986] bg-[#062C41] px-2 py-0.5", children: _jsx("p", { className: "font-medium text-[#7CD4FD] text-sm", children: "Ongoing" }) }))] }), _jsxs("div", { className: "flex justify-between pt-[11px] pb-2", children: [_jsxs("p", { className: "text-sm", children: ["Progress: ", progress, "%"] }), _jsx("div", { className: "flex items-center justify-center rounded-md border border-[#333741] bg-[#0C111D] p-1 font-medium text-[#CECFD2] text-xs dark:border-[#333741] dark:bg-[#0C111D]", children: stageLevel > index + 1
120
+ ? `+ ${stageDetails.bonusAmount} Bonus`
121
+ : `+ ${writableBonus} Bonus` })] }), _jsx("div", { className: "relative h-2 rounded-full bg-[#0C0E12] md:w-full", children: _jsx("div", { className: "h-full flex-1 rounded-full bg-[#FFE5AF] transition-all duration-1000 ease-in-out", style: { width: `${progress}%` } }) })] }));
122
+ }
123
+ function StageItemLocked({ index }) {
124
+ return (_jsxs("div", { className: "mb-4 flex items-center justify-between rounded-xl bg-bg-tertiary p-3", children: [_jsxs("p", { className: "font-medium", children: ["Stage ", index + 1] }), _jsx("div", { className: "flex size-6 items-center justify-center rounded-full border border-utility-brand-200 bg-utility-brand-50", children: _jsx(Lock01Icon, { className: "size-3 stroke-2 font-medium text-utility-brand-500" }) })] }));
125
+ }
@@ -1,184 +1,184 @@
1
- @keyframes arrow-green-flash {
2
- 0% {
3
- color: #abefc6;
4
- }
5
- 100% {
6
- color: #079455;
7
- }
8
- }
9
-
10
- .animate-arrow-green-flash-1 {
11
- animation: arrow-green-flash 0.4s infinite;
12
- animation-delay: -0.2s;
13
- }
14
-
15
- .animate-arrow-green-flash-2 {
16
- animation: arrow-green-flash 0.4s infinite;
17
- animation-delay: -0.1s;
18
- }
19
-
20
- .animate-arrow-green-flash-3 {
21
- animation: arrow-green-flash 0.4s infinite;
22
- }
23
-
24
- @keyframes arrow-red-flash {
25
- 0%,
26
- 100% {
27
- color: #f97066;
28
- }
29
- 50% {
30
- color: #fecdca;
31
- }
32
- }
33
-
34
- .animate-arrow-red-flash-1 {
35
- animation: arrow-red-flash 0.4s infinite;
36
- }
37
-
38
- .animate-arrow-red-flash-2 {
39
- animation: arrow-red-flash 0.4s infinite;
40
- animation-delay: -0.1s;
41
- }
42
-
43
- .animate-arrow-red-flash-3 {
44
- animation: arrow-red-flash 0.4s infinite;
45
- animation-delay: -0.2s;
46
- }
47
-
48
- /* Animated BG */
49
- @keyframes rotate {
50
- to {
51
- transform: rotate(1turn);
52
- }
53
- }
54
-
55
- .light-rays {
56
- position: absolute;
57
- top: 0;
58
- left: 0;
59
- right: 0;
60
- bottom: 0;
61
- overflow: hidden;
62
-
63
- --first: var(--color-bg-tertiary);
64
- --second: var(--color-bg-quaternary);
65
- }
66
-
67
- .light-rays::before,
68
- .light-rays::after {
69
- content: '';
70
- position: absolute;
71
- top: var(--light-rays-top, 150px);
72
- left: calc(50% - 90px);
73
- margin: -100vmax;
74
- width: 200vmax;
75
- height: 200vmax;
76
- opacity: 0.6;
77
- transform-origin: center;
78
- }
79
-
80
- .light-rays::before {
81
- background: conic-gradient(
82
- var(--first) 0deg 7.2deg,
83
- var(--second) 7.2deg 14.4deg,
84
- var(--first) 14.4deg 21.6deg,
85
- var(--second) 21.6deg 28.8deg,
86
- var(--first) 28.8deg 36deg,
87
- var(--second) 36deg 43.2deg,
88
- var(--first) 43.2deg 50.4deg,
89
- var(--second) 50.4deg 57.6deg,
90
- var(--first) 57.6deg 64.8deg,
91
- var(--second) 64.8deg 72deg,
92
- var(--first) 72deg 79.2deg,
93
- var(--second) 79.2deg 86.4deg,
94
- var(--first) 86.4deg 93.6deg,
95
- var(--second) 93.6deg 100.8deg,
96
- var(--first) 100.8deg 108deg,
97
- var(--second) 108deg 115.2deg,
98
- var(--first) 115.2deg 122.4deg,
99
- var(--second) 122.4deg 129.6deg,
100
- var(--first) 129.6deg 136.8deg,
101
- var(--second) 136.8deg 144deg,
102
- var(--first) 144deg 151.2deg,
103
- var(--second) 151.2deg 158.4deg,
104
- var(--first) 158.4deg 165.6deg,
105
- var(--second) 165.6deg 172.8deg,
106
- var(--first) 172.8deg 180deg,
107
- var(--second) 180deg 187.2deg,
108
- var(--first) 187.2deg 194.4deg,
109
- var(--second) 194.4deg 201.6deg,
110
- var(--first) 201.6deg 208.8deg,
111
- var(--second) 208.8deg 216deg,
112
- var(--first) 216deg 223.2deg,
113
- var(--second) 223.2deg 230.4deg,
114
- var(--first) 230.4deg 237.6deg,
115
- var(--second) 237.6deg 244.8deg,
116
- var(--first) 244.8deg 252deg,
117
- var(--second) 252deg 259.2deg,
118
- var(--first) 259.2deg 266.4deg,
119
- var(--second) 266.4deg 273.6deg,
120
- var(--first) 273.6deg 280.8deg,
121
- var(--second) 280.8deg 288deg,
122
- var(--first) 288deg 295.2deg,
123
- var(--second) 295.2deg 302.4deg,
124
- var(--first) 302.4deg 309.6deg,
125
- var(--second) 309.6deg 316.8deg,
126
- var(--first) 316.8deg 324deg,
127
- var(--second) 324deg 331.2deg,
128
- var(--first) 331.2deg 338.4deg,
129
- var(--second) 338.4deg 345.6deg,
130
- var(--first) 345.6deg 352.8deg,
131
- var(--second) 352.8deg 360deg
132
- );
133
- animation: rotate 20s linear infinite;
134
- }
135
-
136
- @media (max-width: 1024px) {
137
- .light-rays::before,
138
- .light-rays::after {
139
- left: auto;
140
- right: 11%;
141
- }
142
- }
143
-
144
- /* ScrollArea.module.css */
145
- .scrollArea {
146
- overflow-y: scroll;
147
- padding-right: 4px;
148
- }
149
-
150
- /* WebKit-based browsers */
151
- .scrollArea::-webkit-scrollbar {
152
- width: 8px;
153
- }
154
-
155
- .scrollArea::-webkit-scrollbar-track {
156
- background: var(--color-bg-primary-alt);
157
- border-radius: 9999px;
158
- }
159
-
160
- .scrollArea::-webkit-scrollbar-thumb {
161
- background-color: var(--color-bg-quaternary);
162
- border-radius: 9999px;
163
- }
164
-
165
- @keyframes waveColor {
166
- 0%,
167
- 2.5% {
168
- color: var(--wave-highlight-color);
169
- }
170
- 2.51%,
171
- 100% {
172
- color: var(--color-brand-300);
173
- }
174
- }
175
-
176
- .animate-wave-color-success {
177
- --wave-highlight-color: var(--color-success-800);
178
- animation: waveColor 4s ease-in-out infinite;
179
- }
180
-
181
- .animate-wave-color-error {
182
- --wave-highlight-color: var(--color-error-600);
183
- animation: waveColor 4s ease-in-out infinite;
184
- }
1
+ @keyframes arrow-green-flash {
2
+ 0% {
3
+ color: #abefc6;
4
+ }
5
+ 100% {
6
+ color: #079455;
7
+ }
8
+ }
9
+
10
+ .animate-arrow-green-flash-1 {
11
+ animation: arrow-green-flash 0.4s infinite;
12
+ animation-delay: -0.2s;
13
+ }
14
+
15
+ .animate-arrow-green-flash-2 {
16
+ animation: arrow-green-flash 0.4s infinite;
17
+ animation-delay: -0.1s;
18
+ }
19
+
20
+ .animate-arrow-green-flash-3 {
21
+ animation: arrow-green-flash 0.4s infinite;
22
+ }
23
+
24
+ @keyframes arrow-red-flash {
25
+ 0%,
26
+ 100% {
27
+ color: #f97066;
28
+ }
29
+ 50% {
30
+ color: #fecdca;
31
+ }
32
+ }
33
+
34
+ .animate-arrow-red-flash-1 {
35
+ animation: arrow-red-flash 0.4s infinite;
36
+ }
37
+
38
+ .animate-arrow-red-flash-2 {
39
+ animation: arrow-red-flash 0.4s infinite;
40
+ animation-delay: -0.1s;
41
+ }
42
+
43
+ .animate-arrow-red-flash-3 {
44
+ animation: arrow-red-flash 0.4s infinite;
45
+ animation-delay: -0.2s;
46
+ }
47
+
48
+ /* Animated BG */
49
+ @keyframes rotate {
50
+ to {
51
+ transform: rotate(1turn);
52
+ }
53
+ }
54
+
55
+ .light-rays {
56
+ position: absolute;
57
+ top: 0;
58
+ left: 0;
59
+ right: 0;
60
+ bottom: 0;
61
+ overflow: hidden;
62
+
63
+ --first: var(--color-bg-tertiary);
64
+ --second: var(--color-bg-quaternary);
65
+ }
66
+
67
+ .light-rays::before,
68
+ .light-rays::after {
69
+ content: '';
70
+ position: absolute;
71
+ top: var(--light-rays-top, 150px);
72
+ left: calc(50% - 90px);
73
+ margin: -100vmax;
74
+ width: 200vmax;
75
+ height: 200vmax;
76
+ opacity: 0.6;
77
+ transform-origin: center;
78
+ }
79
+
80
+ .light-rays::before {
81
+ background: conic-gradient(
82
+ var(--first) 0deg 7.2deg,
83
+ var(--second) 7.2deg 14.4deg,
84
+ var(--first) 14.4deg 21.6deg,
85
+ var(--second) 21.6deg 28.8deg,
86
+ var(--first) 28.8deg 36deg,
87
+ var(--second) 36deg 43.2deg,
88
+ var(--first) 43.2deg 50.4deg,
89
+ var(--second) 50.4deg 57.6deg,
90
+ var(--first) 57.6deg 64.8deg,
91
+ var(--second) 64.8deg 72deg,
92
+ var(--first) 72deg 79.2deg,
93
+ var(--second) 79.2deg 86.4deg,
94
+ var(--first) 86.4deg 93.6deg,
95
+ var(--second) 93.6deg 100.8deg,
96
+ var(--first) 100.8deg 108deg,
97
+ var(--second) 108deg 115.2deg,
98
+ var(--first) 115.2deg 122.4deg,
99
+ var(--second) 122.4deg 129.6deg,
100
+ var(--first) 129.6deg 136.8deg,
101
+ var(--second) 136.8deg 144deg,
102
+ var(--first) 144deg 151.2deg,
103
+ var(--second) 151.2deg 158.4deg,
104
+ var(--first) 158.4deg 165.6deg,
105
+ var(--second) 165.6deg 172.8deg,
106
+ var(--first) 172.8deg 180deg,
107
+ var(--second) 180deg 187.2deg,
108
+ var(--first) 187.2deg 194.4deg,
109
+ var(--second) 194.4deg 201.6deg,
110
+ var(--first) 201.6deg 208.8deg,
111
+ var(--second) 208.8deg 216deg,
112
+ var(--first) 216deg 223.2deg,
113
+ var(--second) 223.2deg 230.4deg,
114
+ var(--first) 230.4deg 237.6deg,
115
+ var(--second) 237.6deg 244.8deg,
116
+ var(--first) 244.8deg 252deg,
117
+ var(--second) 252deg 259.2deg,
118
+ var(--first) 259.2deg 266.4deg,
119
+ var(--second) 266.4deg 273.6deg,
120
+ var(--first) 273.6deg 280.8deg,
121
+ var(--second) 280.8deg 288deg,
122
+ var(--first) 288deg 295.2deg,
123
+ var(--second) 295.2deg 302.4deg,
124
+ var(--first) 302.4deg 309.6deg,
125
+ var(--second) 309.6deg 316.8deg,
126
+ var(--first) 316.8deg 324deg,
127
+ var(--second) 324deg 331.2deg,
128
+ var(--first) 331.2deg 338.4deg,
129
+ var(--second) 338.4deg 345.6deg,
130
+ var(--first) 345.6deg 352.8deg,
131
+ var(--second) 352.8deg 360deg
132
+ );
133
+ animation: rotate 20s linear infinite;
134
+ }
135
+
136
+ @media (max-width: 1024px) {
137
+ .light-rays::before,
138
+ .light-rays::after {
139
+ left: auto;
140
+ right: 11%;
141
+ }
142
+ }
143
+
144
+ /* ScrollArea.module.css */
145
+ .scrollArea {
146
+ overflow-y: scroll;
147
+ padding-right: 4px;
148
+ }
149
+
150
+ /* WebKit-based browsers */
151
+ .scrollArea::-webkit-scrollbar {
152
+ width: 8px;
153
+ }
154
+
155
+ .scrollArea::-webkit-scrollbar-track {
156
+ background: var(--color-bg-primary-alt);
157
+ border-radius: 9999px;
158
+ }
159
+
160
+ .scrollArea::-webkit-scrollbar-thumb {
161
+ background-color: var(--color-bg-quaternary);
162
+ border-radius: 9999px;
163
+ }
164
+
165
+ @keyframes waveColor {
166
+ 0%,
167
+ 2.5% {
168
+ color: var(--wave-highlight-color);
169
+ }
170
+ 2.51%,
171
+ 100% {
172
+ color: var(--color-brand-300);
173
+ }
174
+ }
175
+
176
+ .animate-wave-color-success {
177
+ --wave-highlight-color: var(--color-success-800);
178
+ animation: waveColor 4s ease-in-out infinite;
179
+ }
180
+
181
+ .animate-wave-color-error {
182
+ --wave-highlight-color: var(--color-error-600);
183
+ animation: waveColor 4s ease-in-out infinite;
184
+ }