@everymatrix/casino-challenge-card 1.85.11 → 1.85.13

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.
@@ -1,573 +0,0 @@
1
- import { r as registerInstance, c as createEvent, h } from './index-3c031981.js';
2
-
3
- const DEFAULT_LANGUAGE = 'en';
4
- const SUPPORTED_LANGUAGES = ['ro', 'en', 'fr', 'ar', 'hr'];
5
- const TRANSLATIONS = {
6
- en: {
7
- totalLevels: 'Total levels:',
8
- level1: 'Level 1:',
9
- get: 'Get:',
10
- endsIn: 'Ends In',
11
- expired: 'Expired',
12
- viewDetails: 'View details',
13
- placeBetsOf: 'Place bets of',
14
- place: 'Place',
15
- bet: 'bet',
16
- bets: 'bets',
17
- minBet: 'min bet',
18
- forfeited: 'Forfeited',
19
- finished: 'Finished',
20
- suspended: 'Suspended',
21
- unavailable: 'Unavailable',
22
- start: 'Start',
23
- resume: 'Resume',
24
- pause: 'Pause',
25
- new: 'New'
26
- },
27
- ro: {
28
- totalLevels: 'Niveluri totale:',
29
- level1: 'Nivel 1:',
30
- get: 'Obține:',
31
- endsIn: 'Se termină în',
32
- expired: 'Expirat',
33
- viewDetails: 'Vezi detalii',
34
- placeBetsOf: 'Plasează pariuri de',
35
- place: 'Plasare',
36
- bet: 'pariu',
37
- bets: 'pariuri',
38
- minBet: 'pariu minim',
39
- forfeited: 'Pierdut',
40
- finished: 'Terminat',
41
- suspended: 'Suspendat',
42
- unavailable: 'Indisponibil',
43
- start: 'Start',
44
- resume: 'Reia',
45
- pause: 'Pauză'
46
- },
47
- fr: {
48
- totalLevels: 'Niveaux totaux :',
49
- level1: 'Niveau 1 :',
50
- get: 'Obtenir :',
51
- endsIn: 'Se termine dans',
52
- expired: 'Expiré',
53
- viewDetails: 'Voir les détails',
54
- placeBetsOf: 'Placez des paris de',
55
- place: 'Placer',
56
- bet: 'pari',
57
- bets: 'paris',
58
- minBet: 'mise minimale',
59
- forfeited: 'Forfait',
60
- finished: 'Terminé',
61
- suspended: 'Suspendu',
62
- unavailable: 'Indisponible',
63
- start: 'Démarrer',
64
- resume: 'Reprendre',
65
- pause: 'Pause'
66
- },
67
- ar: {
68
- totalLevels: 'إجمالي المستويات:',
69
- level1: 'المستوى 1:',
70
- get: 'احصل على:',
71
- endsIn: 'ينتهي في',
72
- expired: 'منتهي الصلاحية',
73
- viewDetails: 'عرض التفاصيل',
74
- placeBetsOf: 'قم بوضع رهانات بقيمة',
75
- place: 'ضع',
76
- bet: 'رهان',
77
- bets: 'رهانات',
78
- minBet: 'الحد الأدنى للرهان',
79
- forfeited: 'خاسر',
80
- finished: 'منتهي',
81
- suspended: 'معلق',
82
- unavailable: 'غير متاح',
83
- start: 'ابدأ',
84
- resume: 'استئناف',
85
- pause: 'إيقاف مؤقت'
86
- },
87
- hr: {
88
- totalLevels: 'Ukupno razina:',
89
- level1: 'Razina 1:',
90
- get: 'Dobiti:',
91
- endsIn: 'Završava za',
92
- expired: 'Isteklo',
93
- viewDetails: 'Pogledaj detalje',
94
- placeBetsOf: 'Postavite oklade od',
95
- place: 'Postavi',
96
- bet: 'kladnja',
97
- bets: 'kladnje',
98
- minBet: 'minimalna oklada',
99
- forfeited: 'Oduzeto',
100
- finished: 'Završeno',
101
- suspended: 'Suspendirano',
102
- unavailable: 'غير متاح',
103
- start: 'Počni',
104
- resume: 'Nastavi',
105
- pause: 'Pauza'
106
- }
107
- };
108
- const translate = (key, customLang) => {
109
- const lang = customLang;
110
- return TRANSLATIONS[lang !== undefined && SUPPORTED_LANGUAGES.includes(lang) ? lang : DEFAULT_LANGUAGE][key];
111
- };
112
- const getTranslations = (data) => {
113
- Object.keys(data).forEach((item) => {
114
- for (let key in data[item]) {
115
- TRANSLATIONS[item][key] = data[item][key];
116
- }
117
- });
118
- };
119
- const resolveTranslationUrl = async (translationUrl) => {
120
- if (translationUrl) {
121
- try {
122
- const response = await fetch(translationUrl);
123
- if (!response.ok) {
124
- throw new Error(`HTTP error! status: ${response.status}`);
125
- }
126
- const translations = await response.json();
127
- getTranslations(translations);
128
- }
129
- catch (error) {
130
- console.error('Failed to fetch or parse translations from URL:', error);
131
- }
132
- }
133
- };
134
-
135
- var EChallengeLevelTargetType;
136
- (function (EChallengeLevelTargetType) {
137
- EChallengeLevelTargetType[EChallengeLevelTargetType["Accumulative"] = 0] = "Accumulative";
138
- EChallengeLevelTargetType[EChallengeLevelTargetType["SingleBet"] = 1] = "SingleBet";
139
- EChallengeLevelTargetType[EChallengeLevelTargetType["MultipleOneBetSize"] = 2] = "MultipleOneBetSize";
140
- })(EChallengeLevelTargetType || (EChallengeLevelTargetType = {}));
141
- var EChallengeRecurrenceType;
142
- (function (EChallengeRecurrenceType) {
143
- EChallengeRecurrenceType[EChallengeRecurrenceType["Single"] = 0] = "Single";
144
- EChallengeRecurrenceType[EChallengeRecurrenceType["Daily"] = 1] = "Daily";
145
- EChallengeRecurrenceType[EChallengeRecurrenceType["Weekly"] = 2] = "Weekly";
146
- EChallengeRecurrenceType[EChallengeRecurrenceType["Monthly"] = 3] = "Monthly";
147
- })(EChallengeRecurrenceType || (EChallengeRecurrenceType = {}));
148
- var EChallengeRewardType;
149
- (function (EChallengeRewardType) {
150
- EChallengeRewardType[EChallengeRewardType["FreeSpins"] = 0] = "FreeSpins";
151
- EChallengeRewardType[EChallengeRewardType["LuckyWheel"] = 1] = "LuckyWheel";
152
- EChallengeRewardType[EChallengeRewardType["Leaderboard"] = 2] = "Leaderboard";
153
- EChallengeRewardType[EChallengeRewardType["Challenge"] = 3] = "Challenge";
154
- EChallengeRewardType[EChallengeRewardType["Custom"] = 4] = "Custom";
155
- })(EChallengeRewardType || (EChallengeRewardType = {}));
156
- var EChallengeStatus;
157
- (function (EChallengeStatus) {
158
- EChallengeStatus[EChallengeStatus["Draft"] = 0] = "Draft";
159
- EChallengeStatus[EChallengeStatus["Enabled"] = 1] = "Enabled";
160
- EChallengeStatus[EChallengeStatus["Paused"] = 2] = "Paused";
161
- EChallengeStatus[EChallengeStatus["Closed"] = 3] = "Closed";
162
- EChallengeStatus[EChallengeStatus["Deleted"] = 4] = "Deleted";
163
- })(EChallengeStatus || (EChallengeStatus = {}));
164
- var EChallengeProgressStatus;
165
- (function (EChallengeProgressStatus) {
166
- EChallengeProgressStatus[EChallengeProgressStatus["Started"] = 0] = "Started";
167
- EChallengeProgressStatus[EChallengeProgressStatus["InProgress"] = 1] = "InProgress";
168
- EChallengeProgressStatus[EChallengeProgressStatus["PendingLevelReward"] = 2] = "PendingLevelReward";
169
- EChallengeProgressStatus[EChallengeProgressStatus["Completed"] = 3] = "Completed";
170
- EChallengeProgressStatus[EChallengeProgressStatus["Expired"] = 4] = "Expired";
171
- EChallengeProgressStatus[EChallengeProgressStatus["Forfeited"] = 5] = "Forfeited";
172
- EChallengeProgressStatus[EChallengeProgressStatus["Awaiting"] = 6] = "Awaiting";
173
- EChallengeProgressStatus[EChallengeProgressStatus["Paused"] = 7] = "Paused";
174
- })(EChallengeProgressStatus || (EChallengeProgressStatus = {}));
175
- var EChallengeProgressLevelStatus;
176
- (function (EChallengeProgressLevelStatus) {
177
- EChallengeProgressLevelStatus[EChallengeProgressLevelStatus["Closed"] = 0] = "Closed";
178
- EChallengeProgressLevelStatus[EChallengeProgressLevelStatus["InProgress"] = 1] = "InProgress";
179
- EChallengeProgressLevelStatus[EChallengeProgressLevelStatus["Fillup"] = 2] = "Fillup";
180
- EChallengeProgressLevelStatus[EChallengeProgressLevelStatus["Completed"] = 3] = "Completed";
181
- })(EChallengeProgressLevelStatus || (EChallengeProgressLevelStatus = {}));
182
- const ChallengeStatusDictionary = [
183
- 'started',
184
- 'inProgress',
185
- 'pendingLevelReward',
186
- 'completed',
187
- 'expired',
188
- 'forfeited',
189
- 'awaiting',
190
- 'paused'
191
- ];
192
- var EChallengeTriggerType;
193
- (function (EChallengeTriggerType) {
194
- EChallengeTriggerType[EChallengeTriggerType["GameLaunch"] = 0] = "GameLaunch";
195
- EChallengeTriggerType[EChallengeTriggerType["Reward"] = 1] = "Reward";
196
- EChallengeTriggerType[EChallengeTriggerType["Manual"] = 2] = "Manual";
197
- })(EChallengeTriggerType || (EChallengeTriggerType = {}));
198
- var EChallengeValidityType;
199
- (function (EChallengeValidityType) {
200
- EChallengeValidityType[EChallengeValidityType["Period"] = 0] = "Period";
201
- EChallengeValidityType[EChallengeValidityType["Date"] = 1] = "Date";
202
- })(EChallengeValidityType || (EChallengeValidityType = {}));
203
-
204
- function getTimeLeft(endTime) {
205
- const now = new Date();
206
- const end = new Date(endTime);
207
- let diff = end.getTime() - now.getTime();
208
- if (diff <= 0) {
209
- return;
210
- }
211
- const days = Math.floor(diff / (1000 * 60 * 60 * 24));
212
- diff -= days * (1000 * 60 * 60 * 24);
213
- const hours = Math.floor(diff / (1000 * 60 * 60));
214
- diff -= hours * (1000 * 60 * 60);
215
- const minutes = Math.floor(diff / (1000 * 60));
216
- diff -= minutes * (1000 * 60);
217
- const seconds = Math.floor(diff / 1000);
218
- const pad = (n) => n.toString().padStart(2, '0');
219
- return `${pad(days)} : ${pad(hours)} : ${pad(minutes)} : ${pad(seconds)}`;
220
- }
221
-
222
- /**
223
- * @name setClientStyling
224
- * @description Method used to create and append to the passed element of the widget a style element with the content received
225
- * @param {HTMLElement} stylingContainer The reference element of the widget
226
- * @param {string} clientStyling The style content
227
- */
228
- function setClientStyling(stylingContainer, clientStyling) {
229
- if (stylingContainer) {
230
- const sheet = document.createElement('style');
231
- sheet.innerHTML = clientStyling;
232
- stylingContainer.appendChild(sheet);
233
- }
234
- }
235
-
236
- /**
237
- * @name setClientStylingURL
238
- * @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
239
- * @param {HTMLElement} stylingContainer The reference element of the widget
240
- * @param {string} clientStylingUrl The URL of the style content
241
- */
242
- function setClientStylingURL(stylingContainer, clientStylingUrl) {
243
- const url = new URL(clientStylingUrl);
244
-
245
- fetch(url.href)
246
- .then((res) => res.text())
247
- .then((data) => {
248
- const cssFile = document.createElement('style');
249
- cssFile.innerHTML = data;
250
- if (stylingContainer) {
251
- stylingContainer.appendChild(cssFile);
252
- }
253
- })
254
- .catch((err) => {
255
- console.error('There was an error while trying to load client styling from URL', err);
256
- });
257
- }
258
-
259
- /**
260
- * @name setStreamLibrary
261
- * @description Method used to create and append to the passed element of the widget a style element with content fetched from the MessageBus
262
- * @param {HTMLElement} stylingContainer The highest element of the widget
263
- * @param {string} domain The domain from where the content should be fetched (e.g. 'Casino.Style', 'App.Style', 'casino-footer.style', etc.)
264
- * @param {ref} subscription A reference to a variable where the subscription should be saved for unsubscribing when no longer needed
265
- */
266
- function setStreamStyling(stylingContainer, domain, subscription) {
267
- if (window.emMessageBus) {
268
- const sheet = document.createElement('style');
269
-
270
- window.emMessageBus.subscribe(domain, (data) => {
271
- sheet.innerHTML = data;
272
- if (stylingContainer) {
273
- stylingContainer.appendChild(sheet);
274
- }
275
- });
276
- }
277
- }
278
-
279
- const finishSvg = '';
280
-
281
- const trophySvg = '';
282
-
283
- const casinoChallengeCardCss = ".card {\n width: 308px;\n border-radius: 16px;\n border: 2px solid var(--emw--button-border-color, rgba(221, 255, 207, 0.1019607843));\n background-color: var(--emw--color-background, #141515);\n box-sizing: border-box;\n position: relative;\n}\n@container challenges-container (max-width: 670px) {\n .card {\n width: 100%;\n }\n}\n.card:hover {\n background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);\n cursor: pointer;\n}\n.card__image {\n width: 100%;\n height: 200px;\n border-radius: 16px 16px 0 0;\n object-fit: cover;\n}\n@container challenges-container (max-width: 576px) {\n .card__image {\n height: 224px;\n }\n}\n.card__image.grayed {\n opacity: 0.6;\n}\n.card__title {\n color: var(--emw--color-white, #FFFFFF);\n font-size: var(--emw--font-size-medium, 16px);\n height: 39px;\n display: -webkit-box;\n -webkit-box-orient: vertical;\n -webkit-line-clamp: 2;\n overflow: hidden;\n text-overflow: ellipsis;\n margin: 0 0 10px;\n}\n.card__content {\n padding: 20px;\n}\n.card__button {\n margin-top: 20px;\n width: 100%;\n height: 34px;\n background: transparent;\n text-transform: uppercase;\n border-radius: var(--emw--button-border-radius, 99px);\n border: 2px solid var(--emw--button-border-color, #727672);\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-bold, 700);\n color: var(--emw--color-secondary, #e9931e);\n}\n.card__button:hover {\n border-color: var(--emw--color-secondary, #e9931e);\n cursor: pointer;\n}\n.card__button.filled {\n background-color: var(--emw--button-background-primary-color, #18CE51);\n color: var(--emw--color-white, #FFFFFF);\n border-color: var(--emw--color-gray-300, #083B17);\n}\n.card__button.filled:hover {\n color: var(--emw--color-gray-300, #083B17);\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.card__button.grayed {\n color: var(--emw--color-gray-50, #E2E2E2);\n}\n.card__button.grayed:hover {\n color: var(--emw--color-white, #FFFFFF);\n border-color: var(--emw--button-primary-border, #24B24E);\n}\n.card__button:hover {\n border-color: var(--emw--color-secondary, #e9931e);\n cursor: pointer;\n}\n.card__button:disabled, .card__button:disabled:hover {\n color: var(--emw--color-gray-50, #E2E2E2);\n cursor: not-allowed;\n border: 2px solid var(--emw--button-border-color, #727672);\n opacity: 0.7;\n}\n.card__badge {\n position: absolute;\n background: var(--emw--color-white, #FFFFFF);\n top: 6px;\n right: 6px;\n border-radius: 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 var(--emw--button-box-shadow-color, rgba(0, 0, 0, 0.25));\n backdrop-filter: blur(20px);\n box-sizing: border-box;\n}\n.card__badge span {\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.card__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: 700;\n}\n.card__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: 700;\n}\n.card__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: 700;\n}\n.card__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: 700;\n}\n\n.info-item {\n line-height: 24px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n color: var(--emw--color-primary, #1dbf51);\n}\n@container challenges-container (min-width: 576px) {\n .info-item {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n vertical-align: bottom;\n }\n}\n.info-item.grayed {\n color: var(--emw--disabled-color, #727672);\n}\n.info-item__label {\n font-weight: var(--emw--font-weight-medium, 500);\n margin-right: 3px;\n color: var(--emw--color-gray-150, #C8D6CE);\n}\n.info-item__tooltip {\n position: absolute;\n line-height: 22px;\n padding: 8px 12px;\n border-radius: 8px;\n opacity: 1;\n z-index: 200;\n white-space: normal;\n font-size: var(--emw--font-size-x-small, 12px);\n font-weight: var(--emw--font-weight-medium, 500);\n color: var(--emw--color-white, #FFFFFF);\n background-color: var(--emw--color-background-secondary, #1B1C2B);\n}\n.info-item__tooltip::before {\n content: \"\";\n position: absolute;\n top: -5px;\n left: 50%;\n transform: translateX(-50%);\n border-left: 6px solid transparent;\n border-right: 6px solid transparent;\n border-bottom: 6px solid var(--emw--color-background-secondary, #1B1C2B);\n width: 0;\n height: 0;\n z-index: 201;\n}\n\n.progress {\n background-color: var(--emw--progress-background, rgba(188, 252, 177, 0.1019607843));\n border-radius: 100px;\n height: 20px;\n margin-bottom: 8px;\n position: relative;\n align-content: center;\n padding: 0 2px;\n box-sizing: border-box;\n}\n.progress.paused {\n opacity: 0.5;\n}\n.progress.grayed {\n mix-blend-mode: luminosity;\n}\n.progress__placeholder {\n height: 28px;\n}\n.progress__icon {\n padding-top: 4px;\n width: 12px;\n}\n.progress__point {\n position: absolute;\n text-align: center;\n font-size: 12px;\n color: var(--emw--color-gray-150, #C8D6CE);\n font-weight: 700;\n line-height: 19px;\n top: 0;\n height: 19px;\n width: 19px;\n border-radius: 50%;\n}\n.progress__point.start {\n left: 0;\n border: 2px solid var(--emw--button-background-primary-color, #18CE51);\n background: linear-gradient(90deg, var(--emw--progress-active-level, #24AA4D) 0%, var(--emw--progress-active-level-secondary, #113F21) 100%);\n}\n.progress__point.end {\n right: 0;\n border: 2px solid var(--emw--dark-green, #1C8D56);\n background: var(--emw--color-gray-300, #083B17);\n opacity: 0.7;\n}\n.progress__point.finished {\n opacity: 1;\n}\n.progress__point.hidden {\n opacity: 0;\n}\n.progress__bar {\n border-radius: 73px;\n height: 16px;\n background: linear-gradient(90deg, var(--emw--secondary-green, #1E654F) 0%, var(--emw--dark-green, #1C8D56) 100%);\n text-align: end;\n color: var(--emw--color-gray-50, #E2E2E2);\n font-size: 11px;\n font-weight: 700;\n line-height: 16px;\n padding-right: 6px;\n box-sizing: border-box;\n}\n.progress__bar.finished {\n text-align: center;\n}\n\n.new-label {\n height: 28px;\n width: 37px;\n background: linear-gradient(0deg, var(--emw--new-badge-background-color, #FF3D3D) 0%, var(--emw--new-badge-background-color-2, #A80000) 100%);\n position: absolute;\n top: 32px;\n right: 16px;\n display: flex;\n align-items: center;\n justify-content: center;\n clip-path: polygon(0% 0%, 100% 0%, 100% 70%, 50% 100%, 0% 70%);\n}\n.new-label span {\n background: linear-gradient(to bottom right, var(--emw--color-white, #FFFFFF) 0%, var(--emw--color-gray-100, #D4D4D4) 50%) bottom right/50% 50% no-repeat, linear-gradient(to bottom left, var(--emw--color-white, #FFFFFF) 0%, var(--emw--color-gray-100, #D4D4D4) 50%) bottom left/50% 50% no-repeat, linear-gradient(to top left, var(--emw--color-white, #FFFFFF) 0%, var(--emw--color-gray-100, #D4D4D4) 50%) top left/50% 50% no-repeat, linear-gradient(to top right, var(--emw--color-white, #FFFFFF) 0%, var(--emw--color-gray-100, #D4D4D4) 50%) top right/50% 50% no-repeat;\n -webkit-background-clip: text;\n background-clip: text;\n color: transparent;\n font-weight: var(--emw--font-weight-bold, 700);\n font-size: var(--emw--font-size-medium, 14px);\n padding-bottom: 3px;\n}";
284
- const CasinoChallengeCardStyle0 = casinoChallengeCardCss;
285
-
286
- const CasinoChallengeCard = class {
287
- constructor(hostRef) {
288
- registerInstance(this, hostRef);
289
- this.timerExpired = createEvent(this, "timerExpired", 7);
290
- this.itemViewed = createEvent(this, "itemViewed", 7);
291
- this.calculateTargetValue = (level, currencySymbol) => {
292
- var _a;
293
- if (!level)
294
- return '';
295
- switch (level.LevelTargetType) {
296
- case EChallengeLevelTargetType.Accumulative: {
297
- const minbet = ((_a = level.BetRange) === null || _a === void 0 ? void 0 : _a.MinBet)
298
- ? `, ${translate('minBet', this.language)} ${currencySymbol + level.BetRange.MinBet}`
299
- : '';
300
- return `${translate('placeBetsOf', this.language)} ${currencySymbol + level.DisplayCurrencyTargetTurnover + minbet}`;
301
- }
302
- case EChallengeLevelTargetType.SingleBet:
303
- return `${translate('place', this.language)} ${currencySymbol + level.TargetTurnover} ${translate('bet', this.language)}`;
304
- case EChallengeLevelTargetType.MultipleOneBetSize: {
305
- const minbet = level.TargetTurnover
306
- ? `, ${translate('minBet', this.language)} ${currencySymbol + level.TargetTurnover}`
307
- : '';
308
- return `${translate('place', this.language)} ${level.TargetBetCount} ${translate('bets', this.language) + minbet}`;
309
- }
310
- }
311
- };
312
- this.onMouseEnterHandler = (index, el) => {
313
- if (el.scrollWidth > el.clientWidth) {
314
- this.tooltipIndex = index;
315
- }
316
- };
317
- this.onMouseLeaveHandler = () => {
318
- this.tooltipIndex = null;
319
- };
320
- this.getBadgeContent = () => {
321
- if (this.isChallengePaused) {
322
- return translate('unavailable', this.language);
323
- }
324
- switch (this.challenge.Status) {
325
- case EChallengeProgressStatus.Expired:
326
- return translate('expired', this.language);
327
- case EChallengeProgressStatus.Forfeited:
328
- return translate('forfeited', this.language);
329
- case EChallengeProgressStatus.Completed:
330
- return translate('finished', this.language);
331
- case EChallengeProgressStatus.Paused:
332
- return translate('suspended', this.language);
333
- default:
334
- return this.timeLeft
335
- ? [translate('endsIn', this.language), ' - ', h("span", null, this.timeLeft)]
336
- : translate('expired', this.language);
337
- }
338
- };
339
- this.goToDetailsPage = () => {
340
- this.itemViewed.emit(this.challenge.Id);
341
- window.postMessage({
342
- type: 'GoToDetailsPage',
343
- info: {
344
- challengeId: this.challenge.ChallengeId,
345
- activeTabIndex: this.activeTabIndex
346
- }
347
- }, window.location.href);
348
- };
349
- this.checkAttrs = () => {
350
- if (!this.endpoint) {
351
- this.error = 'Endpoint is missing! Please provide a valid endpointURL.';
352
- this.hasError = true;
353
- console.error(this.error);
354
- }
355
- return this.hasError;
356
- };
357
- this.mbSource = undefined;
358
- this.clientStyling = undefined;
359
- this.clientStylingUrl = undefined;
360
- this.translationUrl = '';
361
- this.language = 'en';
362
- this.endpoint = '';
363
- this.domain = '';
364
- this.session = '';
365
- this.challenge = undefined;
366
- this.isUserAuthorized = true;
367
- this.activeTabIndex = 0;
368
- this.userId = '';
369
- this.tooltipIndex = null;
370
- this.timeLeft = undefined;
371
- this.error = '';
372
- this.hasError = false;
373
- this.actionLoading = false;
374
- this.isChallengePaused = false;
375
- }
376
- get infoItems() {
377
- var _a, _b, _c, _d, _e;
378
- let level = (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.LevelProgresses.find((x) => x.OrderNumber === 0);
379
- if (this.isUserAuthorized) {
380
- level =
381
- (_c = (_b = this.challenge) === null || _b === void 0 ? void 0 : _b.LevelProgresses.find((x) => x.ProgressStatus === EChallengeProgressLevelStatus.InProgress)) !== null && _c !== void 0 ? _c : level;
382
- }
383
- if (level) {
384
- return [
385
- {
386
- lable: translate('totalLevels', this.language),
387
- value: ((_d = this.challenge.LevelProgresses) === null || _d === void 0 ? void 0 : _d.length) || '-'
388
- },
389
- {
390
- lable: translate('level1', this.language),
391
- value: this.calculateTargetValue(level, (_e = this.challenge) === null || _e === void 0 ? void 0 : _e.CurrencySymbol) || '-'
392
- },
393
- {
394
- lable: translate('get', this.language),
395
- value: level.CustomRewardMessage || '-'
396
- }
397
- ];
398
- }
399
- return [];
400
- }
401
- handleClientStylingChange(newValue, oldValue) {
402
- if (newValue != oldValue) {
403
- setClientStyling(this.stylingContainer, this.clientStyling);
404
- }
405
- }
406
- handleClientStylingUrlChange(newValue, oldValue) {
407
- if (newValue != oldValue) {
408
- setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
409
- }
410
- }
411
- handleMbSourceChange(newValue, oldValue) {
412
- if (newValue != oldValue) {
413
- setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
414
- }
415
- }
416
- handleChallengeChange(newValue) {
417
- if (newValue) {
418
- this.isChallengePaused = (newValue === null || newValue === void 0 ? void 0 : newValue.ChallengeStatus) === EChallengeStatus.Paused;
419
- }
420
- }
421
- connectedCallback() {
422
- this.timerId = setInterval(() => {
423
- this.updateTime();
424
- }, 1000);
425
- }
426
- componentWillLoad() {
427
- if (this.translationUrl) {
428
- resolveTranslationUrl(this.translationUrl);
429
- }
430
- this.updateTime();
431
- }
432
- componentDidLoad() {
433
- this.isChallengePaused = this.challenge.ChallengeStatus === EChallengeStatus.Paused;
434
- if (this.stylingContainer) {
435
- if (this.mbSource)
436
- setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
437
- if (this.clientStyling)
438
- setClientStyling(this.stylingContainer, this.clientStyling);
439
- if (this.clientStylingUrl)
440
- setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
441
- }
442
- }
443
- disconnectedCallback() {
444
- if (this.stylingSubscription) {
445
- this.stylingSubscription.unsubscribe();
446
- }
447
- clearInterval(this.timerId);
448
- }
449
- updateTime() {
450
- var _a;
451
- this.timeLeft = getTimeLeft((_a = this.challenge) === null || _a === void 0 ? void 0 : _a.ExpirationTime);
452
- if (!this.timeLeft && this.timerExpired) {
453
- clearInterval(this.timerId);
454
- this.challenge.Status = EChallengeProgressStatus.Expired;
455
- this.timerExpired.emit(this.challenge.Id);
456
- }
457
- }
458
- renderInfoItem(item, index) {
459
- return (h("div", { class: `info-item ${this.isChallengeGrayed}`, onMouseEnter: (e) => this.onMouseEnterHandler(index, e.currentTarget), onMouseLeave: this.onMouseLeaveHandler }, h("span", { class: "info-item__label" }, item.lable), item.value, this.tooltipIndex === index && h("div", { class: "info-item__tooltip" }, item.value)));
460
- }
461
- get getCardBadge() {
462
- return (h("div", { class: `card__badge ${this.isChallengePaused
463
- ? ChallengeStatusDictionary[EChallengeProgressStatus.Expired]
464
- : ChallengeStatusDictionary[this.challenge.Status]}` }, this.getBadgeContent()));
465
- }
466
- get isChallengeGrayed() {
467
- return [
468
- EChallengeProgressStatus.Expired,
469
- EChallengeProgressStatus.Forfeited,
470
- EChallengeProgressStatus.Completed
471
- ].includes(this.challenge.Status) || this.isChallengePaused
472
- ? 'grayed'
473
- : '';
474
- }
475
- get getChallengeProgress() {
476
- var _a;
477
- const currLevel = (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.LevelProgresses.find((x) => x.ProgressStatus === EChallengeProgressLevelStatus.InProgress);
478
- if (!this.isUserAuthorized) {
479
- return;
480
- }
481
- const { Status, LevelProgresses } = this.challenge;
482
- if (Status === EChallengeProgressStatus.Awaiting ||
483
- Status === EChallengeProgressStatus.Expired ||
484
- Status === EChallengeProgressStatus.Started ||
485
- this.isChallengePaused ||
486
- !currLevel) {
487
- return h("div", { class: "progress__placeholder" });
488
- }
489
- const barValue = Status === EChallengeProgressStatus.Paused
490
- ? translate('suspended', this.language)
491
- : Status === EChallengeProgressStatus.Completed
492
- ? translate('finished', this.language)
493
- : `${Math.floor(currLevel.ProgressPercentage)}%`;
494
- const isLastLevel = !LevelProgresses.some((x) => x.OrderNumber > currLevel.OrderNumber);
495
- const secondImgSrc = Status === EChallengeProgressStatus.Completed ? trophySvg : isLastLevel ? finishSvg : '';
496
- return (h("div", { class: {
497
- progress: true,
498
- paused: Status === EChallengeProgressStatus.Paused,
499
- grayed: Status === EChallengeProgressStatus.Forfeited
500
- } }, h("div", { class: {
501
- progress__point: true,
502
- start: true,
503
- hidden: Status === EChallengeProgressStatus.Completed
504
- } }, currLevel.OrderNumber + 1), h("div", { class: {
505
- progress__bar: true,
506
- finished: Status === EChallengeProgressStatus.Completed
507
- }, style: { width: `${currLevel.ProgressPercentage}%` } }, barValue), h("div", { class: {
508
- progress__point: true,
509
- end: true,
510
- finished: Status === EChallengeProgressStatus.Completed
511
- } }, secondImgSrc ? h("img", { class: "progress__icon", src: secondImgSrc }) : currLevel.OrderNumber + 2)));
512
- }
513
- get getCardButton() {
514
- if (this.isUserAuthorized && !this.isChallengePaused) {
515
- if (this.challenge.Status === EChallengeProgressStatus.Started) {
516
- return (h("button", { class: "card__button filled", disabled: this.actionLoading, onClick: (e) => (e.stopPropagation(), this.joinUnjoinProgress(true)) }, translate('start', this.language)));
517
- }
518
- if (this.challenge.Status === EChallengeProgressStatus.Paused) {
519
- return (h("button", { class: "card__button grayed", disabled: this.actionLoading, onClick: (e) => (e.stopPropagation(), this.joinUnjoinProgress(true)) }, translate('resume', this.language)));
520
- }
521
- if (this.challenge.Status === EChallengeProgressStatus.InProgress ||
522
- this.challenge.Status === EChallengeProgressStatus.PendingLevelReward) {
523
- return (h("button", { class: "card__button grayed", disabled: this.actionLoading, onClick: (e) => (e.stopPropagation(), this.joinUnjoinProgress(false)) }, translate('pause', this.language)));
524
- }
525
- }
526
- return h("button", { class: "card__button" }, translate('viewDetails', this.language));
527
- }
528
- async joinUnjoinProgress(join) {
529
- if (!this.checkAttrs() && this.challenge) {
530
- const url = `${this.endpoint}/challenge/ChangeProgressStatus`;
531
- const body = Object.assign(Object.assign(Object.assign({ DomainId: this.domain }, (this.session && { PlayerSessionId: this.session })), (this.userId && { InternalUserId: this.userId })), (join ? { ProgressToActivate: this.challenge.Id } : { ProgressToDeactivate: this.challenge.Id }));
532
- this.actionLoading = true;
533
- return fetch(url, {
534
- method: 'POST',
535
- headers: {
536
- 'Content-Type': 'application/json'
537
- },
538
- body: JSON.stringify(body)
539
- })
540
- .then((res) => res.json())
541
- .then((res) => {
542
- if (res.Success) {
543
- if (join) {
544
- this.challenge.Status = EChallengeProgressStatus.InProgress;
545
- }
546
- else {
547
- this.challenge.Status = EChallengeProgressStatus.Paused;
548
- }
549
- }
550
- })
551
- .finally(() => (this.actionLoading = false));
552
- }
553
- }
554
- renderNewLabel() {
555
- return (h("div", { class: "new-label" }, h("span", null, translate('new', this.language))));
556
- }
557
- render() {
558
- var _a, _b, _c, _d;
559
- return (h("div", { key: '0468a7f2fa29a88ea49e08e277b1040db4d7ecfa', ref: (el) => (this.stylingContainer = el) }, h("div", { key: '88abd78585e195c21dcc2f3770b176e84475dc10', class: "card", onClick: this.goToDetailsPage }, h("img", { key: '16da3c6d047c9138a47c979dc8286bdbb91a0258', class: {
560
- card__image: true,
561
- grayed: !!this.isChallengeGrayed || this.challenge.Status === EChallengeProgressStatus.Awaiting
562
- }, src: (_b = (_a = this.challenge) === null || _a === void 0 ? void 0 : _a.ChallengePresentation) === null || _b === void 0 ? void 0 : _b.BannerUrl }), this.getCardBadge, this.challenge.IsNew && this.renderNewLabel(), h("div", { key: '19f205347c401edea1dcce3ff6c4b090eee32a80', class: "card__content" }, h("h1", { key: '04fd604addd8d6f589dbe54d4647b9a3221eeece', class: "card__title" }, (_d = (_c = this.challenge) === null || _c === void 0 ? void 0 : _c.ChallengePresentation) === null || _d === void 0 ? void 0 : _d.PresentationName), this.getChallengeProgress, this.infoItems.map((x, index) => this.renderInfoItem(x, index)), this.getCardButton))));
563
- }
564
- static get watchers() { return {
565
- "clientStyling": ["handleClientStylingChange"],
566
- "clientStylingUrl": ["handleClientStylingUrlChange"],
567
- "mbSource": ["handleMbSourceChange"],
568
- "challenge": ["handleChallengeChange"]
569
- }; }
570
- };
571
- CasinoChallengeCard.style = CasinoChallengeCardStyle0;
572
-
573
- export { CasinoChallengeCard as C };