@everymatrix/casino-challenge-details 0.0.1

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 (83) hide show
  1. package/dist/casino-challenge-details/app-globals-0f993ce5.js +1 -0
  2. package/dist/casino-challenge-details/casino-challenge-details-5a765f2c.js +1 -0
  3. package/dist/casino-challenge-details/casino-challenge-details.esm.js +1 -0
  4. package/dist/casino-challenge-details/casino-challenge-details_4.entry.js +1 -0
  5. package/dist/casino-challenge-details/index-30adf0cb.js +2 -0
  6. package/dist/casino-challenge-details/index.esm.js +1 -0
  7. package/dist/cjs/app-globals-3a1e7e63.js +5 -0
  8. package/dist/cjs/casino-challenge-details-ddf27d4e.js +761 -0
  9. package/dist/cjs/casino-challenge-details.cjs.js +25 -0
  10. package/dist/cjs/casino-challenge-details_4.cjs.entry.js +144 -0
  11. package/dist/cjs/index-2a30d71d.js +1250 -0
  12. package/dist/cjs/index.cjs.js +10 -0
  13. package/dist/cjs/loader.cjs.js +15 -0
  14. package/dist/collection/assets/active-chevron.svg +3 -0
  15. package/dist/collection/assets/alert.svg +3 -0
  16. package/dist/collection/assets/back-arrow.svg +9 -0
  17. package/dist/collection/assets/check.svg +10 -0
  18. package/dist/collection/assets/finish.svg +7 -0
  19. package/dist/collection/assets/gift.svg +14 -0
  20. package/dist/collection/assets/inactive-chevron.svg +3 -0
  21. package/dist/collection/assets/info-circle.svg +3 -0
  22. package/dist/collection/assets/lock.svg +3 -0
  23. package/dist/collection/assets/notification.svg +20 -0
  24. package/dist/collection/assets/target.svg +9 -0
  25. package/dist/collection/assets/title-icon.svg +1 -0
  26. package/dist/collection/assets/trophy.svg +14 -0
  27. package/dist/collection/collection-manifest.json +15 -0
  28. package/dist/collection/components/casino-challenge-details/casino-challenge-details.css +592 -0
  29. package/dist/collection/components/casino-challenge-details/casino-challenge-details.js +684 -0
  30. package/dist/collection/components/casino-challenge-details/index.js +1 -0
  31. package/dist/collection/components/components/casino-challenge-expandable-paragraph.css +76 -0
  32. package/dist/collection/components/components/casino-challenge-expandable-paragraph.js +116 -0
  33. package/dist/collection/components/components/casino-challenge-level-progress-bar.css +33 -0
  34. package/dist/collection/components/components/casino-challenge-level-progress-bar.js +81 -0
  35. package/dist/collection/components/components/casino-challenge-progress-bar.css +66 -0
  36. package/dist/collection/components/components/casino-challenge-progress-bar.js +120 -0
  37. package/dist/collection/index.js +1 -0
  38. package/dist/collection/utils/locale.utils.js +166 -0
  39. package/dist/collection/utils/mock.js +238 -0
  40. package/dist/collection/utils/types.js +60 -0
  41. package/dist/collection/utils/utils.js +29 -0
  42. package/dist/esm/app-globals-0f993ce5.js +3 -0
  43. package/dist/esm/casino-challenge-details-5a765f2c.js +758 -0
  44. package/dist/esm/casino-challenge-details.js +20 -0
  45. package/dist/esm/casino-challenge-details_4.entry.js +138 -0
  46. package/dist/esm/index-30adf0cb.js +1221 -0
  47. package/dist/esm/index.js +2 -0
  48. package/dist/esm/loader.js +11 -0
  49. package/dist/index.cjs.js +1 -0
  50. package/dist/index.js +1 -0
  51. package/dist/stencil.config.dev.js +19 -0
  52. package/dist/stencil.config.js +19 -0
  53. package/dist/storybook/main.js +43 -0
  54. package/dist/storybook/preview.js +9 -0
  55. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/libs/common/src/storybook/storybook-utils.d.ts +39 -0
  56. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/packages/stencil/casino-challenge-details/stencil.config.d.ts +2 -0
  57. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/packages/stencil/casino-challenge-details/stencil.config.dev.d.ts +2 -0
  58. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/packages/stencil/casino-challenge-details/storybook/main.d.ts +3 -0
  59. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/packages/stencil/casino-challenge-details/storybook/preview.d.ts +70 -0
  60. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/tools/plugins/index.d.ts +4 -0
  61. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/tools/plugins/lazy-load-chunk-plugin.d.ts +12 -0
  62. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/tools/plugins/stencil-clean-deps-plugin.d.ts +5 -0
  63. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/tools/plugins/vite-chunk-plugin.d.ts +6 -0
  64. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenge-details/.stencil/tools/plugins/vite-clean-deps-plugin.d.ts +4 -0
  65. package/dist/types/components/casino-challenge-details/casino-challenge-details.d.ts +105 -0
  66. package/dist/types/components/casino-challenge-details/index.d.ts +1 -0
  67. package/dist/types/components/components/casino-challenge-expandable-paragraph.d.ts +16 -0
  68. package/dist/types/components/components/casino-challenge-level-progress-bar.d.ts +6 -0
  69. package/dist/types/components/components/casino-challenge-progress-bar.d.ts +8 -0
  70. package/dist/types/components.d.ts +198 -0
  71. package/dist/types/index.d.ts +1 -0
  72. package/dist/types/stencil-public-runtime.d.ts +1674 -0
  73. package/dist/types/utils/locale.utils.d.ts +3 -0
  74. package/dist/types/utils/mock.d.ts +76 -0
  75. package/dist/types/utils/types.d.ts +127 -0
  76. package/dist/types/utils/utils.d.ts +3 -0
  77. package/loader/cdn.js +1 -0
  78. package/loader/index.cjs.js +1 -0
  79. package/loader/index.d.ts +24 -0
  80. package/loader/index.es2017.js +1 -0
  81. package/loader/index.js +2 -0
  82. package/loader/package.json +11 -0
  83. package/package.json +27 -0
@@ -0,0 +1,758 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-30adf0cb.js';
2
+
3
+ /**
4
+ * @name setClientStyling
5
+ * @description Method used to create and append to the passed element of the widget a style element with the content received
6
+ * @param {HTMLElement} stylingContainer The reference element of the widget
7
+ * @param {string} clientStyling The style content
8
+ */
9
+ function setClientStyling(stylingContainer, clientStyling) {
10
+ if (stylingContainer) {
11
+ const sheet = document.createElement('style');
12
+ sheet.innerHTML = clientStyling;
13
+ stylingContainer.appendChild(sheet);
14
+ }
15
+ }
16
+
17
+ /**
18
+ * @name setClientStylingURL
19
+ * @description Method used to create and append to the passed element of the widget a style element with the content fetched from a given URL
20
+ * @param {HTMLElement} stylingContainer The reference element of the widget
21
+ * @param {string} clientStylingUrl The URL of the style content
22
+ */
23
+ function setClientStylingURL(stylingContainer, clientStylingUrl) {
24
+ const url = new URL(clientStylingUrl);
25
+
26
+ fetch(url.href)
27
+ .then((res) => res.text())
28
+ .then((data) => {
29
+ const cssFile = document.createElement('style');
30
+ cssFile.innerHTML = data;
31
+ if (stylingContainer) {
32
+ stylingContainer.appendChild(cssFile);
33
+ }
34
+ })
35
+ .catch((err) => {
36
+ console.error('There was an error while trying to load client styling from URL', err);
37
+ });
38
+ }
39
+
40
+ /**
41
+ * @name setStreamLibrary
42
+ * @description Method used to create and append to the passed element of the widget a style element with content fetched from the MessageBus
43
+ * @param {HTMLElement} stylingContainer The highest element of the widget
44
+ * @param {string} domain The domain from where the content should be fetched (e.g. 'Casino.Style', 'App.Style', 'casino-footer.style', etc.)
45
+ * @param {ref} subscription A reference to a variable where the subscription should be saved for unsubscribing when no longer needed
46
+ */
47
+ function setStreamStyling(stylingContainer, domain, subscription) {
48
+ if (window.emMessageBus) {
49
+ const sheet = document.createElement('style');
50
+
51
+ window.emMessageBus.subscribe(domain, (data) => {
52
+ sheet.innerHTML = data;
53
+ if (stylingContainer) {
54
+ stylingContainer.appendChild(sheet);
55
+ }
56
+ });
57
+ }
58
+ }
59
+
60
+ const DEFAULT_LANGUAGE = 'en';
61
+ const SUPPORTED_LANGUAGES = ['ro', 'en', 'fr', 'ar', 'hr'];
62
+ const TRANSLATIONS = {
63
+ en: {
64
+ title: 'Challenges',
65
+ totalLevels: 'Total levels:',
66
+ endsIn: 'Ends In',
67
+ expired: 'Expired',
68
+ placeBetsOf: 'Place bets of',
69
+ place: 'Place',
70
+ bet: 'bet',
71
+ bets: 'bets',
72
+ minBet: 'min bet',
73
+ forfeited: 'Forfeited',
74
+ finished: 'Finished',
75
+ suspended: 'Suspended',
76
+ completed: 'Completed',
77
+ start: 'Start',
78
+ resume: 'Resume',
79
+ pause: 'Pause',
80
+ join: 'Join to Start',
81
+ congrats: 'Congratulations!',
82
+ forfeitNotification: 'Unfortunately, your progress has been forfeited, and you are no longer eligible to continue this challenge. Check out other available challenges!',
83
+ completedNofitication: "You've successfully completed this challenge! Explore the next one and keep playing to earn more rewards!",
84
+ expiredNotification: "Unfortunately, this challenge has expired and is no longer available to complete. Try another one that’s still active!",
85
+ terms: "Terms & Conditions",
86
+ contribution: 'contribution',
87
+ endDate: 'End Date',
88
+ back: 'Back',
89
+ all: 'All Challenges'
90
+ },
91
+ ro: {
92
+ title: 'Provocări',
93
+ totalLevels: 'Niveluri totale:',
94
+ endsIn: 'Se termină în',
95
+ expired: 'Expirat',
96
+ placeBetsOf: 'Plasează pariuri de',
97
+ place: 'Plasare',
98
+ bet: 'pariu',
99
+ bets: 'pariuri',
100
+ minBet: 'pariu minim',
101
+ forfeited: 'Pierdut',
102
+ finished: 'Terminat',
103
+ suspended: 'Suspendat',
104
+ start: 'Start',
105
+ resume: 'Reia',
106
+ pause: 'Pauză',
107
+ join: 'Alătură-te pentru a începe',
108
+ congrats: "Felicitări!",
109
+ forfeitNotification: "Din păcate, progresul tău a fost abandonat și nu mai poți continua această provocare. Consultă celelalte provocări disponibile!",
110
+ completedNofitication: "Ai finalizat cu succes această provocare! Explorează următoarea și continuă să joci pentru a câștiga mai multe recompense!",
111
+ expiredNotification: "Din păcate, această provocare a expirat și nu mai este disponibilă pentru finalizare. Încearcă una care este încă activă!",
112
+ terms: "Termeni și condiții",
113
+ contribution: "contribuție",
114
+ endDate: "Data de încheiere",
115
+ back: "Înapoi",
116
+ all: "Toate Provocările"
117
+ },
118
+ fr: {
119
+ title: 'Défis',
120
+ totalLevels: 'Niveaux totaux :',
121
+ endsIn: 'Se termine dans',
122
+ expired: 'Expiré',
123
+ placeBetsOf: 'Placez des paris de',
124
+ place: 'Placer',
125
+ bet: 'pari',
126
+ bets: 'paris',
127
+ minBet: 'mise minimale',
128
+ forfeited: 'Forfait',
129
+ finished: 'Terminé',
130
+ suspended: 'Suspendu',
131
+ start: 'Démarrer',
132
+ resume: 'Reprendre',
133
+ pause: 'Pause',
134
+ join: 'Rejoindre pour commencer',
135
+ congrats: "Félicitations !",
136
+ forfeitNotification: "Malheureusement, votre progression a été abandonnée et vous n'êtes plus éligible pour continuer ce défi. Découvrez les autres défis disponibles !",
137
+ completedNofitication: "Vous avez réussi ce défi ! Découvrez le suivant et continuez à jouer pour gagner plus de récompenses !",
138
+ expiredNotification: "Malheureusement, ce défi a expiré et n’est plus disponible à compléter. Essayez-en un autre qui est encore actif !",
139
+ terms: "Termes et conditions",
140
+ contribution: "contribution",
141
+ endDate: "Date de fin",
142
+ back: "Retour",
143
+ all: "Tous les Défis"
144
+ },
145
+ ar: {
146
+ title: 'تحديات',
147
+ totalLevels: 'إجمالي المستويات:',
148
+ endsIn: 'ينتهي في',
149
+ expired: 'منتهي الصلاحية',
150
+ placeBetsOf: 'قم بوضع رهانات بقيمة',
151
+ place: 'ضع',
152
+ bet: 'رهان',
153
+ bets: 'رهانات',
154
+ minBet: 'الحد الأدنى للرهان',
155
+ forfeited: 'خاسر',
156
+ finished: 'منتهي',
157
+ suspended: 'معلق',
158
+ start: 'ابدأ',
159
+ resume: 'استئناف',
160
+ pause: 'إيقاف مؤقت',
161
+ join: 'انضم للبدء',
162
+ congrats: "تهانينا!",
163
+ forfeitNotification: "للأسف، تم التخلي عن تقدمك ولم تعد مؤهلاً لمتابعة هذا التحدي. تحقق من التحديات الأخرى المتاحة!",
164
+ completedNofitication: "لقد أكملت هذا التحدي بنجاح! استكشف التحدي التالي واستمر في اللعب للحصول على مزيد من الجوائز!",
165
+ expiredNotification: "للأسف، هذا التحدي انتهت صلاحيته ولم يعد متاحًا لإكماله. جرّب تحديًا آخر لا يزال نشطًا!",
166
+ terms: "الشروط والأحكام",
167
+ contribution: "مساهمة",
168
+ endDate: "تاريخ الانتهاء",
169
+ back: "عودة",
170
+ all: "جميع التحديات"
171
+ },
172
+ hr: {
173
+ title: 'Izazovi',
174
+ totalLevels: 'Ukupno razina:',
175
+ endsIn: 'Završava za',
176
+ expired: 'Isteklo',
177
+ placeBetsOf: 'Postavite oklade od',
178
+ place: 'Postavi',
179
+ bet: 'kladnja',
180
+ bets: 'kladnje',
181
+ minBet: 'minimalna oklada',
182
+ forfeited: 'Oduzeto',
183
+ finished: 'Završeno',
184
+ suspended: 'Suspendirano',
185
+ start: 'Počni',
186
+ resume: 'Nastavi',
187
+ pause: 'Pauza',
188
+ join: 'Pridruži se za početak',
189
+ congrats: "Čestitamo!",
190
+ forfeitNotification: "Nažalost, tvoj napredak je izgubljen i više nisi podoban nastaviti ovaj izazov. Pogledaj ostale dostupne izazove!",
191
+ completedNofitication: "Uspješno si završio ovaj izazov! Istraži sljedeći i nastavi igrati kako bi zaradio/la više nagrada!",
192
+ expiredNotification: "Nažalost, ovaj izazov je istekao i više nije dostupan za dovršavanje. Probaj neki drugi koji je još aktivan!",
193
+ terms: "Uvjeti i odredbe",
194
+ contribution: "doprinos",
195
+ endDate: "Datum završetka",
196
+ back: "Nazad",
197
+ all: "Svi Izazovi"
198
+ }
199
+ };
200
+ const translate = (key, customLang) => {
201
+ const lang = customLang;
202
+ return TRANSLATIONS[lang !== undefined && SUPPORTED_LANGUAGES.includes(lang) ? lang : DEFAULT_LANGUAGE][key];
203
+ };
204
+ const getTranslations = (data) => {
205
+ Object.keys(data).forEach((item) => {
206
+ for (let key in data[item]) {
207
+ TRANSLATIONS[item][key] = data[item][key];
208
+ }
209
+ });
210
+ };
211
+ const resolveTranslationUrl = async (translationUrl) => {
212
+ if (translationUrl) {
213
+ try {
214
+ const response = await fetch(translationUrl);
215
+ if (!response.ok) {
216
+ throw new Error(`HTTP error! status: ${response.status}`);
217
+ }
218
+ const translations = await response.json();
219
+ getTranslations(translations);
220
+ }
221
+ catch (error) {
222
+ console.error('Failed to fetch or parse translations from URL:', error);
223
+ }
224
+ }
225
+ };
226
+
227
+ function getTimeLeft(endTime) {
228
+ const now = new Date();
229
+ const end = new Date(endTime);
230
+ let diff = end.getTime() - now.getTime();
231
+ if (diff <= 0) {
232
+ return;
233
+ }
234
+ const days = Math.floor(diff / (1000 * 60 * 60 * 24));
235
+ diff -= days * (1000 * 60 * 60 * 24);
236
+ const hours = Math.floor(diff / (1000 * 60 * 60));
237
+ diff -= hours * (1000 * 60 * 60);
238
+ const minutes = Math.floor(diff / (1000 * 60));
239
+ diff -= minutes * (1000 * 60);
240
+ const seconds = Math.floor(diff / 1000);
241
+ const pad = (n) => n.toString().padStart(2, '0');
242
+ return `${pad(days)} : ${pad(hours)} : ${pad(minutes)} : ${pad(seconds)}`;
243
+ }
244
+ function formatDate(dateToFormat) {
245
+ const formatter = new Intl.DateTimeFormat('en-CA', {
246
+ year: 'numeric',
247
+ month: '2-digit',
248
+ day: '2-digit'
249
+ });
250
+ const date = new Date(dateToFormat);
251
+ return formatter.format(date).replace(/-/g, '/');
252
+ }
253
+
254
+ const giftSvg = '';
255
+
256
+ const targetSvg = '';
257
+
258
+ const backArrowSvg = '';
259
+
260
+ const lockSvg = '';
261
+
262
+ const alertSvg = '';
263
+
264
+ const checkSvg = '';
265
+
266
+ const infoCircleSvg = '';
267
+
268
+ const titleIconSvg = '';
269
+
270
+ const notificationSvg = '';
271
+
272
+ var EChallengeLevelTargetType;
273
+ (function (EChallengeLevelTargetType) {
274
+ EChallengeLevelTargetType[EChallengeLevelTargetType["Accumulative"] = 0] = "Accumulative";
275
+ EChallengeLevelTargetType[EChallengeLevelTargetType["SingleBet"] = 1] = "SingleBet";
276
+ EChallengeLevelTargetType[EChallengeLevelTargetType["MultipleOneBetSize"] = 2] = "MultipleOneBetSize";
277
+ })(EChallengeLevelTargetType || (EChallengeLevelTargetType = {}));
278
+ var EChallengeRecurrenceType;
279
+ (function (EChallengeRecurrenceType) {
280
+ EChallengeRecurrenceType[EChallengeRecurrenceType["Single"] = 0] = "Single";
281
+ EChallengeRecurrenceType[EChallengeRecurrenceType["Daily"] = 1] = "Daily";
282
+ EChallengeRecurrenceType[EChallengeRecurrenceType["Weekly"] = 2] = "Weekly";
283
+ EChallengeRecurrenceType[EChallengeRecurrenceType["Monthly"] = 3] = "Monthly";
284
+ })(EChallengeRecurrenceType || (EChallengeRecurrenceType = {}));
285
+ var EChallengeRewardType;
286
+ (function (EChallengeRewardType) {
287
+ EChallengeRewardType[EChallengeRewardType["FreeSpins"] = 0] = "FreeSpins";
288
+ EChallengeRewardType[EChallengeRewardType["LuckyWheel"] = 1] = "LuckyWheel";
289
+ EChallengeRewardType[EChallengeRewardType["Leaderboard"] = 2] = "Leaderboard";
290
+ EChallengeRewardType[EChallengeRewardType["Challenge"] = 3] = "Challenge";
291
+ EChallengeRewardType[EChallengeRewardType["Custom"] = 4] = "Custom";
292
+ })(EChallengeRewardType || (EChallengeRewardType = {}));
293
+ var EChallengeProgressStatus;
294
+ (function (EChallengeProgressStatus) {
295
+ EChallengeProgressStatus[EChallengeProgressStatus["Closed"] = 0] = "Closed";
296
+ EChallengeProgressStatus[EChallengeProgressStatus["InProgress"] = 1] = "InProgress";
297
+ EChallengeProgressStatus[EChallengeProgressStatus["Fillup"] = 2] = "Fillup";
298
+ EChallengeProgressStatus[EChallengeProgressStatus["Completed"] = 3] = "Completed";
299
+ })(EChallengeProgressStatus || (EChallengeProgressStatus = {}));
300
+ var EChallengeStatus;
301
+ (function (EChallengeStatus) {
302
+ EChallengeStatus[EChallengeStatus["Started"] = 0] = "Started";
303
+ EChallengeStatus[EChallengeStatus["InProgress"] = 1] = "InProgress";
304
+ EChallengeStatus[EChallengeStatus["PendingLevelReward"] = 2] = "PendingLevelReward";
305
+ EChallengeStatus[EChallengeStatus["Completed"] = 3] = "Completed";
306
+ EChallengeStatus[EChallengeStatus["Expired"] = 4] = "Expired";
307
+ EChallengeStatus[EChallengeStatus["Forfeited"] = 5] = "Forfeited";
308
+ EChallengeStatus[EChallengeStatus["Awaiting"] = 6] = "Awaiting";
309
+ EChallengeStatus[EChallengeStatus["Paused"] = 7] = "Paused";
310
+ })(EChallengeStatus || (EChallengeStatus = {}));
311
+ const ChallengeStatusDictionary = [
312
+ 'started',
313
+ 'inProgress',
314
+ 'pendingLevelReward',
315
+ 'completed',
316
+ 'expired',
317
+ 'forfeited',
318
+ 'awaiting',
319
+ 'paused'
320
+ ];
321
+ var EChallengeTriggerType;
322
+ (function (EChallengeTriggerType) {
323
+ EChallengeTriggerType[EChallengeTriggerType["GameLaunch"] = 0] = "GameLaunch";
324
+ EChallengeTriggerType[EChallengeTriggerType["Reward"] = 1] = "Reward";
325
+ EChallengeTriggerType[EChallengeTriggerType["Manual"] = 2] = "Manual";
326
+ })(EChallengeTriggerType || (EChallengeTriggerType = {}));
327
+ var EChallengeValidityType;
328
+ (function (EChallengeValidityType) {
329
+ EChallengeValidityType[EChallengeValidityType["Period"] = 0] = "Period";
330
+ EChallengeValidityType[EChallengeValidityType["Date"] = 1] = "Date";
331
+ })(EChallengeValidityType || (EChallengeValidityType = {}));
332
+
333
+ const casinoChallengeDetailsCss = ".container {\n font-family: var(--emw--font-family-secondary, \"Montserrat\", sans-serif);\n background: var(--emw--color-background, #000);\n min-height: 100vh;\n padding-top: 16px;\n container-type: inline-size;\n container-name: challenges-details;\n min-width: 375px;\n width: 100%;\n margin: 0 auto;\n}\n\n.challenges-header {\n display: none;\n}\n\n.back-button {\n display: flex;\n align-items: center;\n padding: 14px 0 14px 10px;\n outline: none;\n background: var(--emw--color-background-secondary, linear-gradient(180deg, #24b24e 0%, #18ce51 100%));\n background-clip: text;\n border: none;\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: 700;\n line-height: 18px;\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n}\n.back-button__icon {\n margin: 0 4px;\n}\n.back-button__text {\n margin-left: 4px;\n}\n\n.details {\n min-width: 308px;\n box-sizing: border-box;\n position: relative;\n display: flex;\n flex-wrap: wrap;\n justify-content: space-between;\n padding: 16px;\n min-width: 375px;\n width: 100%;\n}\n.details.grayed {\n opacity: 0.5;\n}\n.details__general-info {\n max-width: 344px;\n padding-bottom: 16px;\n}\n.details__general-info-image-container {\n position: relative;\n margin-bottom: 22px;\n}\n.details__general-info-image {\n display: block;\n width: 344px;\n height: 226px;\n border-radius: var(--emw--border-radius-medium, 16px);\n}\n.details__general-info-image.grayed {\n opacity: 0.5;\n}\n.details__general-info-timer-badge {\n position: absolute;\n background: var(--emw--color-white, #fff);\n top: 6px;\n right: 6px;\n border-radius: var(--emw--border-radius-large, 30px);\n padding: 2px 12px;\n line-height: 22px;\n font-weight: var(--emw--font-weight-medium, 500);\n font-size: var(--emw--font-size-x-small, 12px);\n box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);\n backdrop-filter: blur(20px);\n}\n.details__general-info-timer-badge span {\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-timer-badge.expired {\n background: var(--emw--background-gray-color, rgba(250, 250, 250, 0.5019607843));\n border: 1px solid var(--emw--border-gray-color, #292c29);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-timer-badge.completed {\n background: var(--emw--background-success-color, #c9f0d7);\n border: 1px solid var(--emw--border-success-color, #00b74f);\n color: var(--emw--color-gray-300, #083b17);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-timer-badge.forfeited {\n background: var(--emw--background-errored-color, #ffe1df);\n border: 1px solid var(--emw--border-errored-color, #d6421e);\n color: var(--emw--errored-color, #850606);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-timer-badge.paused {\n background: var(--emw--background-warning-color, #f8e4ad);\n border: 1px solid var(--emw--border-warning-color, #ea9018);\n color: var(--emw--warning-color, #6d460a);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-title {\n margin: 0 0 4px;\n color: var(--emw--color-white, #fff);\n font-size: var(--emw--font-size-large, 20px);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-end-date_label {\n color: var(--emw--color-gray-150, #727672);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-medium, 500);\n line-height: 22px;\n margin: 0;\n}\n.details__general-info-end-date_value {\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.details__general-info-action-button,\n.details .footer-action-button {\n width: 100%;\n color: var(--emw--color-white, #fff);\n font-size: var(--emw--font-size-medium, 16px);\n border-radius: var(--emw--button-border-radius, 99px);\n border: 2px solid var(--emw--button-border-color, #083b17);\n background: var(--emw--button-background-color, linear-gradient(180deg, #24b24e 0%, #18ce51 100%));\n text-align: center;\n text-transform: uppercase;\n font-weight: var(--emw--font-weight-bold, 700);\n height: 51px;\n padding: 16px 32px;\n display: flex;\n justify-content: center;\n align-items: center;\n align-self: stretch;\n gap: 10px;\n}\n.details__general-info-action-button:hover,\n.details .footer-action-button:hover {\n border-color: var(--emw--color-secondary, #083b17);\n cursor: pointer;\n}\n.details__general-info-action-button.filled,\n.details .footer-action-button.filled {\n background-color: var(--emw--button-background-primary-color, #18ce51);\n color: var(--emw--color-white, #fff);\n border-color: var(--emw--color-gray-300, #083b17);\n}\n.details__general-info-action-button.filled:hover,\n.details .footer-action-button.filled:hover {\n border-color: transparent;\n box-shadow: 0 0 4px 0 rgba(188, 252, 177, 0.2), 0 0 20px 0 rgba(0, 183, 79, 0.5);\n}\n.details__general-info-action-button.grayed,\n.details .footer-action-button.grayed {\n color: var(--emw--color-gray-50, #e2e2e2);\n background: var(--emw--color-black-150, #000000);\n border-color: var(--emw--button-disabled-border-color, #727672);\n box-shadow: 0 0 20px 0 rgba(188, 252, 177, 0.2);\n}\n.details__general-info-action-button.grayed:hover,\n.details .footer-action-button.grayed:hover {\n color: var(--emw--color-white, #fff);\n}\n.details__general-info-action-button:disabled, .details__general-info-action-button:disabled:hover,\n.details .footer-action-button:disabled,\n.details .footer-action-button:disabled:hover {\n color: var(--emw--color-gray-50, #e2e2e2);\n cursor: not-allowed;\n border: 2px solid var(--emw--button-disabled-border-color, #727672);\n opacity: 0.7;\n}\n.details .footer-action-button {\n height: 44px;\n padding: 14px 20px;\n font-size: var(--emw--font-size-sm, 14px);\n}\n.details__general-info-action-button {\n display: none;\n margin-top: 32px;\n}\n.details__tabs-container {\n flex-grow: 1;\n max-width: 100%;\n}\n.details__tabs {\n position: relative;\n display: flex;\n justify-content: flex-start;\n border-bottom: 1px solid var(--emw--border-warning-color, #ea9018);\n}\n.details__tab {\n padding: 10px 20px;\n cursor: pointer;\n position: relative;\n font-weight: var(--emw--font-weight-medium, 500);\n color: var(--emw--color-gray-300, #555);\n display: flex;\n width: 33.3333333333%;\n padding: 12px 10px;\n justify-content: center;\n align-items: center;\n gap: 10px;\n}\n.details__tab.active {\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-bold, 700);\n text-transform: uppercase;\n background: var(--emw--active-tab, linear-gradient(180deg, #ea9018 0%, #e0a84e 100%));\n background-clip: text;\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n}\n.details__tab {\n color: var(--emw--color-gray-100, #727672);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-bold, 700);\n text-transform: uppercase;\n}\n.details__tab:nth-of-type(1).active ~ .active-tab-indicator {\n left: 0;\n width: 33.3333333333%;\n}\n.details__tab:nth-of-type(2).active ~ .active-tab-indicator {\n left: 33.3333333333%;\n width: 33.3333333333%;\n}\n.details__tab:nth-of-type(3).active ~ .active-tab-indicator {\n left: 66.6666666667%;\n width: 33.3333333333%;\n}\n.details .active-tab-indicator {\n position: absolute;\n bottom: -3px;\n height: 2px;\n background: var(--emw--active-tab-indicator, linear-gradient(180deg, rgba(234, 144, 24, 0.7) 0%, rgba(224, 168, 78, 0.7) 100%), #727672);\n transition: left 0.3s ease, width 0.3s ease;\n}\n.details .levels__tab {\n margin-top: 22px;\n display: flex;\n gap: 12px;\n flex-direction: column;\n overflow-y: auto;\n height: 300px;\n padding-bottom: 80px;\n}\n.details .level {\n display: flex;\n padding: 20px;\n flex-direction: column;\n align-items: flex-start;\n border-radius: var(--emw--border-radius-small, 12px);\n background-color: var(--emw--color-background, rgba(114, 118, 114, 0.2));\n}\n.details .level.grayed {\n background: rgba(114, 118, 114, 0.15);\n}\n.details .level.active {\n background: linear-gradient(90deg, rgba(30, 101, 79, 0.2) 0%, rgba(28, 141, 86, 0.2) 100%);\n border: 2px solid var(--Gradient-Blue, #003e5c);\n box-shadow: 0 0 20px 0 rgba(188, 252, 177, 0.2);\n}\n.details .level.completed {\n background: linear-gradient(90deg, rgba(0, 62, 92, 0.3) 0.05%, rgba(17, 59, 33, 0.3) 87.69%);\n}\n.details .level__status {\n display: flex;\n align-items: center;\n gap: 4px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n line-height: 18px;\n}\n.details .level__title {\n width: 100%;\n display: flex;\n justify-content: space-between;\n color: var(--emw--color-white, #fff);\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n line-height: 18px;\n margin-bottom: 10px;\n}\n.details .level__title .completed, .details .level__title .in-progress {\n color: var(--emw--color-valid, #00b74f);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-medium, 500);\n text-align: right;\n line-height: 22px;\n}\n.details .level__title.grayed {\n color: var(--emw--disabled-color, #727672);\n}\n.details .level__progress {\n width: 100%;\n margin-bottom: 10px;\n}\n.details .level__icon {\n display: flex;\n margin: 5px 6px 5px 0;\n opacity: 1;\n}\n.details .level__icon img {\n display: block;\n width: 12px;\n height: 12px;\n}\n.details .level__icon img.grayed {\n opacity: 0.5;\n}\n.details .level__bonus, .details .level__target {\n display: flex;\n align-items: flex-start;\n color: var(--emw--color-gray-200, #c8d6ce);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-medium, 500);\n line-height: 22px;\n margin-bottom: 4px;\n}\n.details .level__value {\n color: var(--emw--color-gray-200, #c8d6ce);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-medium, 500);\n line-height: 22px;\n}\n.details .level__value.grayed {\n opacity: 0.5;\n}\n.details .games__tab {\n display: flex;\n flex-wrap: wrap;\n gap: 12px;\n padding: 22px 0;\n overflow-y: auto;\n height: 300px;\n padding-bottom: 80px;\n}\n.details .games__tab .game {\n position: relative;\n width: 105px;\n height: 85px;\n}\n.details .games__tab .game img {\n width: 100%;\n height: 100%;\n border-radius: var(--emw--border-radius-medium, 16px);\n}\n.details .games__tab .game .contribution {\n position: absolute;\n top: 4px;\n right: 4px;\n color: var(--emw--color-white, #fff);\n border-radius: var(--emw--border-radius-small, 12px);\n border: 1px solid var(--Gradient-Blue, #003e5c);\n background: rgba(0, 0, 0, 0.5);\n box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);\n backdrop-filter: blur(5px);\n padding: 0 8px;\n font-size: var(--emw--font-size-2x-small, 8px);\n font-weight: var(--emw--font-weight-bold, 700);\n line-height: 22px;\n text-align: center;\n}\n.details .rules__tab {\n display: flex;\n flex-direction: column;\n padding: 22px 0;\n gap: 8px;\n overflow-y: auto;\n height: 300px;\n padding-bottom: 80px;\n}\n.details .rules__tab .rule {\n color: var(--emw--color-gray-200, #c8d6ce);\n font-size: var(--emw--font-size-small, 14px);\n font-style: normal;\n font-weight: 500;\n line-height: 24px;\n}\n.details .rules__tab .link {\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-bold, 700);\n line-height: 18px;\n background: var(--emw--button-background-color, linear-gradient(180deg, #24b24e 0%, #18ce51 100%));\n background-clip: text;\n padding: 14px 0;\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n}\n.details__button {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 10px;\n flex: 1 0 0;\n height: 42px;\n padding: 14px 20px;\n border-radius: var(--emw--button-border-radius, 99px);\n border: 2px solid var(--emw--button-border-color, #083b17);\n background-color: var(--emw--button-background-color, linear-gradient(180deg, #24b24e 0%, #18ce51 100%));\n color: var(--emw--color-white, #fff);\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n text-transform: uppercase;\n}\n\n.button__container {\n position: fixed;\n bottom: 0;\n left: 50%;\n transform: translateX(-50%);\n display: flex;\n width: calc(100% - 32px);\n padding: 16px 16px 22px 16px;\n justify-content: center;\n align-items: center;\n gap: 4px;\n border-top: 1px solid var(--emw--color-blue, #003e5c);\n background: var(--emw--color-background, #000);\n box-shadow: 0 0 20px 0 rgba(188, 252, 177, 0.2);\n}\n\n.lds-dual-ring {\n display: block;\n width: 80px;\n height: 80px;\n margin: 80px auto 0 auto;\n}\n\n.lds-dual-ring:after {\n content: \" \";\n display: block;\n width: 64px;\n height: 64px;\n margin: 8px;\n border-radius: 50%;\n border: 6px solid var(--emw--casino-color-primary, var(--emw--color-primary, #22b04e));\n border-color: var(--emw--casino-color-primary, var(--emw--color-primary, #22b04e)) transparent var(--emw--casino-color-primary, var(--emw--color-primary, #22b04e));\n animation: lds-dual-ring 1.2s linear infinite;\n}\n\n@keyframes lds-dual-ring {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n.notification {\n display: flex;\n align-items: flex-start;\n border-radius: var(--emw--border-radius-small, 12px);\n background: rgba(188, 252, 177, 0.1);\n display: flex;\n padding: 16px;\n align-items: flex-start;\n gap: 10px;\n margin: 16px 16px 22px 16px;\n}\n.notification__icon {\n margin-top: 2px;\n}\n.notification__message, .notification__title {\n color: var(--emw--color-gray-50, #e2e2e2);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-medium, 500);\n line-height: 22px;\n}\n.notification__title {\n background: var(--emw--color-background-secondary, linear-gradient(180deg, #24b24e 0%, #18ce51 100%));\n background-clip: text;\n -webkit-background-clip: text;\n -webkit-text-fill-color: transparent;\n}\n.notification__column {\n display: flex;\n flex-direction: column;\n}\n\n@container challenges-details (min-width: 768px) {\n .button__container {\n display: none;\n }\n .details {\n gap: 36px;\n flex-wrap: nowrap;\n }\n .details__general-info-action-button {\n display: flex;\n }\n .details__general-info-image {\n width: 380px;\n min-height: 226px;\n height: auto;\n }\n .details__general-info {\n max-width: 380px;\n }\n .details__tabs__container {\n max-width: calc(100% - 380px);\n }\n .details .levels__tab {\n gap: 20px;\n height: 60vh;\n }\n .details .levels__tab .level__icon {\n width: 14px;\n height: 14px;\n margin: 4px 6px 4px 0px;\n }\n .details .levels__tab .level__icon img {\n width: 100%;\n height: 100%;\n }\n .details .levels__tab .level__title {\n font-size: var(--emw--font-size-medium, 16px);\n }\n .details .levels__tab .level__title .completed, .details .levels__tab .level__title .in-progress {\n font-size: var(--emw--font-size-sm, 14px);\n }\n .details .levels__tab .level__bonus, .details .levels__tab .level__target, .details .levels__tab .level__value {\n font-size: var(--emw--font-size-sm, 14px);\n }\n .details .games__tab, .details .rules__tab {\n height: 60vh;\n }\n .details .games__tab {\n gap: 20px;\n min-width: 340px;\n }\n .details .games__tab .game {\n width: 160px;\n height: 110px;\n }\n .details .games__tab .game .contribution {\n top: 8px;\n right: 8px;\n padding: 4px 10px;\n font-size: var(--emw--font-size-2x-small, 10px);\n line-height: 18px;\n }\n .challenges-header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n }\n .challenges-title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n color: var(--emw--color-white, #ffffff);\n }\n .challenges-tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #c8d6ce);\n background-color: var(--emw--color-background-secondary, #272727);\n }\n .challenges-tab {\n padding: 10px 16px;\n border-radius: 40px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n cursor: pointer;\n text-align: center;\n width: 95px;\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 4px;\n }\n .challenges-tab.active {\n color: var(--emw--color-white, #ffffff);\n background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);\n }\n .challenges-tab:last-child {\n width: inherit;\n padding: 10px 16px;\n }\n}";
334
+ const CasinoChallengeDetailsStyle0 = casinoChallengeDetailsCss;
335
+
336
+ const CasinoChallengeDetails = class {
337
+ constructor(hostRef) {
338
+ registerInstance(this, hostRef);
339
+ this.timerExpired = createEvent(this, "timerExpired", 7);
340
+ this.activeEntityRef = null;
341
+ this.scrollContainerRef = null;
342
+ this.challengesTabs = ['Active', 'Pending', 'Finished', 'Code'];
343
+ this.tabs = ['LEVELS', 'GAMES', 'RULES'];
344
+ this.showNotification = 10;
345
+ this.checkIsMobile = () => {
346
+ this.isMobile = window.innerWidth <= 768;
347
+ };
348
+ this.calculateTargetValue = (level, currencySymbol) => {
349
+ var _a;
350
+ if (!level)
351
+ return '';
352
+ const minbet = ((_a = level.BetRange) === null || _a === void 0 ? void 0 : _a.MinBet)
353
+ ? `, ${translate('minBet', this.language)} ${currencySymbol + level.BetRange.MinBet}`
354
+ : '';
355
+ switch (level.LevelTargetType) {
356
+ case EChallengeLevelTargetType.Accumulative:
357
+ return `${translate('placeBetsOf', this.language)} ${currencySymbol + level.DisplayCurrencyTargetTurnover + minbet}`;
358
+ case EChallengeLevelTargetType.SingleBet:
359
+ return `${translate('place', this.language)} ${currencySymbol + level.TargetTurnover} ${translate('bet', this.language)}`;
360
+ case EChallengeLevelTargetType.MultipleOneBetSize:
361
+ return `${translate('place', this.language)} ${level.TargetBetCount} ${translate('bets', this.language) + minbet}`;
362
+ default:
363
+ return '-';
364
+ }
365
+ };
366
+ this.getBadgeContent = () => {
367
+ var _a;
368
+ if (this.challenge) {
369
+ switch ((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) {
370
+ case EChallengeStatus.Expired:
371
+ return translate('expired', this.language);
372
+ case EChallengeStatus.Forfeited:
373
+ return translate('forfeited', this.language);
374
+ case EChallengeStatus.Completed:
375
+ return translate('finished', this.language);
376
+ case EChallengeStatus.Paused:
377
+ return translate('suspended', this.language);
378
+ default:
379
+ return [translate('endsIn', this.language), ' - ', h("span", null, this.timeLeft || null)];
380
+ }
381
+ }
382
+ else
383
+ return null;
384
+ };
385
+ this.checkAttrs = () => {
386
+ if (!this.endpoint) {
387
+ this.error = 'Endpoint is missing! Please provide a valid endpointURL.';
388
+ this.hasError = true;
389
+ console.error(this.error);
390
+ }
391
+ return this.hasError;
392
+ };
393
+ this.joinUnjoinProgress = async () => {
394
+ var _a, _b, _c, _d;
395
+ if (!this.isUserAuthorized) {
396
+ this.openLoginRegisterModal();
397
+ }
398
+ const join = ((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) === EChallengeStatus.Started || ((_b = this.challenge) === null || _b === void 0 ? void 0 : _b.Status) === EChallengeStatus.Paused;
399
+ const progress = (_d = (_c = this.challenge) === null || _c === void 0 ? void 0 : _c.LevelProgresses) === null || _d === void 0 ? void 0 : _d.find((x) => (x === null || x === void 0 ? void 0 : x.ProgressStatus) === EChallengeProgressStatus.InProgress);
400
+ if (!this.checkAttrs()) {
401
+ const url = `${this.endpoint}/challenge/ChangeProgressStatus`;
402
+ const body = Object.assign(Object.assign({ DomainId: this.domain }, (this.session && { PlayerSessionId: this.session })), (join ? { ProgressToActivate: progress.LevelId } : { ProgressToDeactivate: progress.LevelId }));
403
+ this.actionLoading = true;
404
+ return fetch(url, {
405
+ method: 'POST',
406
+ headers: {
407
+ 'Content-Type': 'application/json'
408
+ },
409
+ body: JSON.stringify(body)
410
+ })
411
+ .then((res) => res.json())
412
+ .finally(() => (this.actionLoading = false));
413
+ }
414
+ };
415
+ this.handleTabClick = (index) => () => {
416
+ if (index === 0) {
417
+ setTimeout(() => {
418
+ this.scrollToActiveLevel();
419
+ }, 0);
420
+ }
421
+ if (index === 1) {
422
+ this.fetchGames();
423
+ }
424
+ this.activeTabIndex = index;
425
+ };
426
+ this.handleChallengesTabClick = (tabIndex) => () => {
427
+ window.postMessage({ type: 'GoToChallengesPage', tabIndex }, window.location.href);
428
+ };
429
+ this.getBackButtonText = () => {
430
+ return (h("span", { class: "back-button__text" }, this.isMobile ? translate('all', this.language) : translate('back', this.language)));
431
+ };
432
+ this.mbSource = undefined;
433
+ this.clientStyling = undefined;
434
+ this.endpoint = '';
435
+ this.domain = '';
436
+ this.session = '';
437
+ this.clientStylingUrl = undefined;
438
+ this.translationUrl = '';
439
+ this.language = 'en';
440
+ this.isUserAuthorized = true;
441
+ this.challengeId = '';
442
+ this.activeChallengeTabIndex = '0';
443
+ this.timeLeft = undefined;
444
+ this.activeTabIndex = 0;
445
+ this.actionLoading = false;
446
+ this.isMobile = false;
447
+ this.error = '';
448
+ this.hasError = false;
449
+ this.games = [];
450
+ this.gamesAreLoading = false;
451
+ this.challenge = undefined;
452
+ this.loading = false;
453
+ }
454
+ handleClientStylingChange(newValue, oldValue) {
455
+ if (newValue != oldValue) {
456
+ setClientStyling(this.stylingContainer, this.clientStyling);
457
+ }
458
+ }
459
+ handleClientStylingUrlChange(newValue, oldValue) {
460
+ if (newValue != oldValue) {
461
+ setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
462
+ }
463
+ }
464
+ handleMbSourceChange(newValue, oldValue) {
465
+ if (newValue != oldValue) {
466
+ setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
467
+ }
468
+ }
469
+ onEntityChange(newChallenge, previousChallenge) {
470
+ var _a, _b, _c, _d;
471
+ const newActiveProgressId = (_b = (_a = newChallenge === null || newChallenge === void 0 ? void 0 : newChallenge.LevelProgresses) === null || _a === void 0 ? void 0 : _a.find((level) => level.ProgressStatus === EChallengeProgressStatus.InProgress)) === null || _b === void 0 ? void 0 : _b.LevelId;
472
+ const prevActiveProgressId = (_d = (_c = previousChallenge === null || previousChallenge === void 0 ? void 0 : previousChallenge.LevelProgresses) === null || _c === void 0 ? void 0 : _c.find((level) => level.ProgressStatus === EChallengeProgressStatus.InProgress)) === null || _d === void 0 ? void 0 : _d.LevelId;
473
+ if (newActiveProgressId == prevActiveProgressId) {
474
+ setTimeout(() => {
475
+ this.scrollToActiveLevel();
476
+ }, 0);
477
+ }
478
+ }
479
+ scrollToActiveLevel() {
480
+ if (this.activeEntityRef) {
481
+ const container = this.scrollContainerRef;
482
+ const target = this.activeEntityRef;
483
+ const containerTop = container.getBoundingClientRect().top;
484
+ const targetTop = target.getBoundingClientRect().top;
485
+ const scrollOffset = targetTop - containerTop;
486
+ container.scrollTo({
487
+ top: container.scrollTop + scrollOffset - container.clientHeight / 2 + target.clientHeight / 2,
488
+ behavior: 'smooth'
489
+ });
490
+ }
491
+ }
492
+ connectedCallback() {
493
+ this.timerId = setInterval(() => {
494
+ this.updateTime();
495
+ }, 1000);
496
+ }
497
+ async getChallenge() {
498
+ if (!this.checkAttrs()) {
499
+ const url = `${this.endpoint}/challenge/GetChallengesInfo`;
500
+ const body = Object.assign({ DomainId: this.domain, PlayerLanguage: this.language, PageNumber: 1, PageSize: 1, ChallengeId: this.challengeId }, (this.session && { PlayerSessionId: this.session }));
501
+ this.loading = true;
502
+ return fetch(url, {
503
+ method: 'POST',
504
+ headers: {
505
+ 'Content-Type': 'application/json'
506
+ },
507
+ body: JSON.stringify(body)
508
+ })
509
+ .then((res) => res.json())
510
+ .then((res) => {
511
+ this.challenge = res.Data[0];
512
+ })
513
+ .finally(() => (this.loading = false));
514
+ }
515
+ }
516
+ componentWillLoad() {
517
+ if (this.translationUrl) {
518
+ resolveTranslationUrl(this.translationUrl);
519
+ }
520
+ this.updateTime();
521
+ }
522
+ componentDidLoad() {
523
+ if (this.stylingContainer) {
524
+ if (this.mbSource)
525
+ setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
526
+ if (this.clientStyling)
527
+ setClientStyling(this.stylingContainer, this.clientStyling);
528
+ if (this.clientStylingUrl)
529
+ setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
530
+ }
531
+ this.getChallenge();
532
+ this.checkIsMobile();
533
+ window.addEventListener('resize', this.checkIsMobile);
534
+ setTimeout(() => {
535
+ this.scrollToActiveLevel();
536
+ }, 0);
537
+ }
538
+ disconnectedCallback() {
539
+ if (this.stylingSubscription) {
540
+ this.stylingSubscription.unsubscribe();
541
+ }
542
+ clearInterval(this.timerId);
543
+ window.removeEventListener('resize', this.checkIsMobile);
544
+ }
545
+ getReward(level) {
546
+ return level.Rewards.map((r) => r.RewardDescription).join(' + ') || '-';
547
+ }
548
+ getTarget(level) {
549
+ var _a;
550
+ return this.calculateTargetValue(level, (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.CurrencySymbol) || '-';
551
+ }
552
+ updateTime() {
553
+ var _a, _b;
554
+ if (this.challenge) {
555
+ this.timeLeft = getTimeLeft((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.ExpirationTime);
556
+ if (!this.timeLeft && this.timerExpired) {
557
+ clearInterval(this.timerId);
558
+ this.timerExpired.emit((_b = this.challenge) === null || _b === void 0 ? void 0 : _b.Id);
559
+ }
560
+ }
561
+ }
562
+ get getCardBadge() {
563
+ var _a;
564
+ if (this.timeLeft) {
565
+ return (h("div", { class: `details__general-info-timer-badge ${ChallengeStatusDictionary[(_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status]}` }, this.getBadgeContent()));
566
+ }
567
+ return null;
568
+ }
569
+ get actionButtonText() {
570
+ var _a;
571
+ if (this.isUserAuthorized) {
572
+ let buttonText;
573
+ switch ((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) {
574
+ case EChallengeStatus.Started:
575
+ buttonText = 'start';
576
+ break;
577
+ case EChallengeStatus.Paused:
578
+ buttonText = 'resume';
579
+ break;
580
+ case EChallengeStatus.InProgress:
581
+ buttonText = 'resume';
582
+ break;
583
+ case EChallengeStatus.PendingLevelReward:
584
+ buttonText = 'pause';
585
+ break;
586
+ default:
587
+ buttonText = 'start';
588
+ break;
589
+ }
590
+ return buttonText;
591
+ }
592
+ return 'join';
593
+ }
594
+ openLoginRegisterModal() {
595
+ window.postMessage({
596
+ type: 'OpenLoginRegisterModal',
597
+ transition: 'Login'
598
+ });
599
+ }
600
+ async fetchGames() {
601
+ var _a;
602
+ if (!this.checkAttrs()) {
603
+ const url = `${this.endpoint}/challenge/GetChallengeGames`;
604
+ const body = Object.assign({ ChallengeId: (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.ChallengeId }, (this.session && { PlayerSessionId: this.session }));
605
+ this.gamesAreLoading = true;
606
+ return fetch(url, {
607
+ method: 'POST',
608
+ headers: {
609
+ 'Content-Type': 'application/json'
610
+ },
611
+ body: JSON.stringify(body)
612
+ })
613
+ .then((res) => res.json())
614
+ .then((res) => {
615
+ this.games = res.ChallengeGames;
616
+ })
617
+ .finally(() => (this.gamesAreLoading = false));
618
+ }
619
+ }
620
+ getLevelStatus(level, active) {
621
+ if (this.isUserAuthorized) {
622
+ if (level.ProgressStatus === EChallengeProgressStatus.InProgress && !active)
623
+ return (h("div", { class: "level__status" }, h("span", null, level.ProgressPercentage, "%"), h("img", { src: lockSvg, alt: "lock-icon", title: "lock-icon" })));
624
+ else if (level.ProgressStatus === EChallengeProgressStatus.Closed || !active)
625
+ return (h("div", { class: "level__status" }, h("img", { src: lockSvg, alt: "lock-icon", title: "lock-icon" })));
626
+ else if (level.ProgressStatus === EChallengeProgressStatus.Fillup)
627
+ return (h("div", { class: "level__status" }, h("img", { src: lockSvg, alt: "lock-icon", title: "lock-icon" })));
628
+ else if (level.ProgressStatus === EChallengeProgressStatus.Completed)
629
+ return h("span", { class: "completed" }, translate('completed', this.language));
630
+ else if (level.ProgressStatus === EChallengeProgressStatus.InProgress)
631
+ return h("span", { class: "level__status in-progress" }, level.ProgressPercentage, "%");
632
+ }
633
+ return null;
634
+ }
635
+ get pageHeader() {
636
+ return (h("div", { class: "challenges-header" }, h("h1", { class: "challenges-title" }, h("img", { src: titleIconSvg, alt: "icon" }), translate('title', this.language)), this.isUserAuthorized && (h("div", { class: "challenges-tabs" }, this.challengesTabs.map((label, index) => (h("div", { class: `challenges-tab ${index === +this.activeChallengeTabIndex ? 'active' : ''}`, onClick: this.handleChallengesTabClick(index) }, label, this.showNotification === index && h("img", { src: notificationSvg }))))))));
637
+ }
638
+ get cardGeneralInfo() {
639
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k;
640
+ return (h("div", { class: "details__general-info" }, h("div", { class: "details__general-info-image-container" }, h("img", { class: {
641
+ 'details__general-info-image': true,
642
+ grayed: [EChallengeStatus.Expired, EChallengeStatus.Forfeited, EChallengeStatus.Completed].includes((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status)
643
+ }, src: (_c = (_b = this.challenge) === null || _b === void 0 ? void 0 : _b.ChallengePresentation) === null || _c === void 0 ? void 0 : _c.BannerUrl, alt: "banner-image", title: "banner-image" }), this.getCardBadge), h("div", { class: "details__general-info-content" }, h("h1", { class: "details__general-info-title" }, (_e = (_d = this.challenge) === null || _d === void 0 ? void 0 : _d.ChallengePresentation) === null || _e === void 0 ? void 0 : _e.PresentationName), h("h3", { class: "details__general-info-end-date_label" }, translate('endDate', this.language), " -", ' ', h("span", { class: "details__general-info-end-date_value" }, this.challenge ? formatDate((_f = this.challenge) === null || _f === void 0 ? void 0 : _f.ExpirationTime) : '-')), h("casino-challenge-progress-bar", { challenge: this.challenge, isUserAuthorized: this.isUserAuthorized, language: this.language }), h("button", { class: {
644
+ 'details__general-info-action-button': true,
645
+ filled: ((_g = this.challenge) === null || _g === void 0 ? void 0 : _g.Status) === EChallengeStatus.Started,
646
+ grayed: ((_h = this.challenge) === null || _h === void 0 ? void 0 : _h.Status) === EChallengeStatus.Paused ||
647
+ ((_j = this.challenge) === null || _j === void 0 ? void 0 : _j.Status) === EChallengeStatus.InProgress ||
648
+ ((_k = this.challenge) === null || _k === void 0 ? void 0 : _k.Status) === EChallengeStatus.PendingLevelReward
649
+ }, disabled: this.actionLoading, onClick: this.joinUnjoinProgress }, translate(this.actionButtonText, this.language)))));
650
+ }
651
+ get challengeTabs() {
652
+ return (h("div", { class: "details__tabs" }, this.tabs.map((label, index) => (h("div", { class: {
653
+ details__tab: true,
654
+ active: index === this.activeTabIndex
655
+ }, onClick: this.handleTabClick(index) }, label))), h("div", { class: "active-tab-indicator" })));
656
+ }
657
+ get levelsTab() {
658
+ var _a, _b;
659
+ return (h("div", { class: "levels__tab", ref: (el) => (this.scrollContainerRef = el) }, (_b = (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.LevelProgresses) === null || _b === void 0 ? void 0 : _b.map((level, index) => {
660
+ var _a;
661
+ const activeChallenge = [0, 1, 2, 3].includes((_a = this === null || this === void 0 ? void 0 : this.challenge) === null || _a === void 0 ? void 0 : _a.Status);
662
+ const isGrayed = (this.isUserAuthorized && level.ProgressStatus !== EChallengeProgressStatus.InProgress) || !activeChallenge;
663
+ const isActiveMatch = level.ProgressStatus === EChallengeProgressStatus.InProgress;
664
+ return (h("div", { class: {
665
+ level: true,
666
+ active: this.isUserAuthorized &&
667
+ activeChallenge &&
668
+ level.ProgressStatus === EChallengeProgressStatus.InProgress,
669
+ completed: this.isUserAuthorized &&
670
+ activeChallenge &&
671
+ level.ProgressStatus === EChallengeProgressStatus.Completed,
672
+ grayed: this.isUserAuthorized &&
673
+ (level.ProgressStatus === EChallengeProgressStatus.Closed ||
674
+ level.ProgressStatus === EChallengeProgressStatus.Fillup)
675
+ }, ref: isActiveMatch ? (el) => (this.activeEntityRef = el) : undefined, key: level.LevelId }, h("div", { class: {
676
+ level__title: true,
677
+ grayed: isGrayed
678
+ } }, h("span", null, "Level ", index + 1), this.isUserAuthorized && this.getLevelStatus(level, activeChallenge)), this.isUserAuthorized && level.ProgressStatus === EChallengeProgressStatus.InProgress && (h("div", { class: "level__progress" }, h("casino-challenge-level-progress-bar", { height: "8px", value: level.ProgressPercentage, active: activeChallenge }))), h("casino-challenge-expandable-paragraph", { "max-height": "56", active: level.ProgressStatus === EChallengeProgressStatus.InProgress && activeChallenge }, h("div", { class: {
679
+ level__bonus: true,
680
+ grayed: isGrayed
681
+ } }, h("span", { class: "level__icon" }, h("img", { class: {
682
+ grayed: isGrayed
683
+ }, src: giftSvg, alt: "gift-icon", title: "gift-icon" })), h("span", { class: {
684
+ level__value: true,
685
+ grayed: isGrayed
686
+ } }, this.getTarget(level))), h("div", { class: {
687
+ level__target: true,
688
+ grayed: isGrayed
689
+ } }, h("span", { class: "level__icon" }, h("img", { class: {
690
+ grayed: isGrayed
691
+ }, src: targetSvg, alt: "target-icon", title: "target-icon" })), h("span", { class: {
692
+ level__value: true,
693
+ grayed: isGrayed
694
+ } }, this.getReward(level))))));
695
+ })));
696
+ }
697
+ handleGameClick(game) {
698
+ if (!this.isUserAuthorized) {
699
+ this.openLoginRegisterModal();
700
+ return;
701
+ }
702
+ window.postMessage({
703
+ type: 'GameClick',
704
+ detail: {
705
+ ClientCompatibility: game.ClientCompatibility,
706
+ GameId: game.GameId,
707
+ GameName: game.GameName,
708
+ GameLaunchUrl: game.GameLaunchUrl,
709
+ RestrictedCountries: game.RestrictedCountries,
710
+ Vendor: game.Vendor
711
+ }
712
+ });
713
+ }
714
+ get gamesTab() {
715
+ return (h("div", { class: "games__tab" }, this.gamesAreLoading ? (h("div", { class: "lds-dual-ring" })) : (this.games.map((game) => {
716
+ return (h("div", { class: "game", onClick: () => this.handleGameClick(game) }, h("img", { src: game.GameIcon, alt: "game-icon", title: "game-icon" }), h("span", { class: "contribution" }, translate('contribution', this.language), " ", game.Contribution, "%")));
717
+ }))));
718
+ }
719
+ get rulesTab() {
720
+ var _a, _b, _c, _d;
721
+ return (h("div", { class: "rules__tab" }, h("div", { class: "rule" }, (_b = (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.ChallengePresentation) === null || _b === void 0 ? void 0 : _b.Description), h("a", { class: "link", href: (_d = (_c = this.challenge) === null || _c === void 0 ? void 0 : _c.ChallengePresentation) === null || _d === void 0 ? void 0 : _d.Url, target: "_blank" }, translate('terms', this.language))));
722
+ }
723
+ get footer() {
724
+ var _a, _b, _c, _d;
725
+ return (h("div", { class: "button__container" }, h("button", { class: {
726
+ 'footer-action-button': true,
727
+ filled: ((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) === EChallengeStatus.Started || !this.isUserAuthorized,
728
+ grayed: this.isUserAuthorized &&
729
+ (((_b = this.challenge) === null || _b === void 0 ? void 0 : _b.Status) === EChallengeStatus.Paused ||
730
+ ((_c = this.challenge) === null || _c === void 0 ? void 0 : _c.Status) === EChallengeStatus.InProgress ||
731
+ ((_d = this.challenge) === null || _d === void 0 ? void 0 : _d.Status) === EChallengeStatus.PendingLevelReward)
732
+ }, onClick: this.joinUnjoinProgress, disabled: this.actionLoading }, translate(this.actionButtonText, this.language))));
733
+ }
734
+ get forfeitedNofitication() {
735
+ var _a;
736
+ return (((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) === 5 && (h("div", { class: "notification" }, h("img", { class: "notification__icon", src: alertSvg }), h("span", { class: "notification__message" }, translate('forfeitNotification', this.language)))));
737
+ }
738
+ get completedNotification() {
739
+ var _a;
740
+ return (((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) === 3 && (h("div", { class: "notification" }, h("img", { class: "notification__icon", src: checkSvg }), h("div", { class: "notification__column" }, h("span", { class: "notification__title" }, translate('congrats', this.language)), h("span", { class: "notification__message" }, translate('completedNofitication', this.language))))));
741
+ }
742
+ get expiredNotification() {
743
+ var _a;
744
+ return (((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.Status) === 4 && (h("div", { class: "notification" }, h("img", { class: "notification__icon", src: infoCircleSvg }), h("span", { class: "notification__message" }, translate('expiredNotification', this.language)))));
745
+ }
746
+ render() {
747
+ return (h("div", { key: 'ac5dde048e4d00efd0a174bb3b077ecc5e7abce7', ref: (el) => (this.stylingContainer = el), class: "container" }, this.pageHeader, this.loading ? (h("div", { class: "lds-dual-ring" })) : (h("div", null, h("button", { class: "back-button" }, h("img", { class: "back-button__icon", src: backArrowSvg }), this.getBackButtonText()), this.forfeitedNofitication, this.completedNotification, this.expiredNotification, h("div", { class: "details" }, this.cardGeneralInfo, h("div", { class: "details__tabs-container" }, this.challengeTabs, this.activeTabIndex === 0 && this.levelsTab, this.activeTabIndex === 1 && this.gamesTab, this.activeTabIndex === 2 && this.rulesTab), this.footer)))));
748
+ }
749
+ static get watchers() { return {
750
+ "clientStyling": ["handleClientStylingChange"],
751
+ "clientStylingUrl": ["handleClientStylingUrlChange"],
752
+ "mbSource": ["handleMbSourceChange"],
753
+ "challenge": ["onEntityChange"]
754
+ }; }
755
+ };
756
+ CasinoChallengeDetails.style = CasinoChallengeDetailsStyle0;
757
+
758
+ export { CasinoChallengeDetails as C, EChallengeProgressStatus as E, EChallengeStatus as a, translate as t };