@everymatrix/casino-engagement-suite-tournament 1.63.2 → 1.64.0
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.
- package/dist/casino-engagement-suite-tournament/casino-engagement-suite-tournament.esm.js +1 -1
- package/dist/casino-engagement-suite-tournament/index.esm.js +1 -1
- package/dist/casino-engagement-suite-tournament/p-edcd56d0.js +15 -0
- package/dist/casino-engagement-suite-tournament/{p-d24f1017.entry.js → p-fcfced34.entry.js} +1 -1
- package/dist/cjs/casino-engagement-suite-progress-bar_6.cjs.entry.js +11 -10
- package/dist/cjs/{casino-engagement-suite-tournament-785dd5cc.js → casino-engagement-suite-tournament-95aedc10.js} +244 -67
- package/dist/cjs/casino-engagement-suite-tournament.cjs.js +1 -1
- package/dist/cjs/index.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/assets/back.svg +3 -0
- package/dist/collection/assets/iconTrophy.svg +12 -0
- package/dist/collection/assets/iconWarn.svg +15 -0
- package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.css +123 -26
- package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.js +71 -14
- package/dist/collection/shared/TournamentDurationTimer.js +9 -9
- package/dist/collection/shared/TournamentItem.js +20 -2
- package/dist/collection/shared/TournamentItemTitle.js +3 -3
- package/dist/collection/shared/icons.js +6 -2
- package/dist/collection/shared/renders.dialog.js +10 -3
- package/dist/collection/shared/renders.page.js +3 -1
- package/dist/collection/shared/renders.tab.js +10 -3
- package/dist/collection/utils/api.apdater.js +14 -0
- package/dist/collection/utils/bussiness.js +28 -2
- package/dist/collection/utils/message.js +104 -27
- package/dist/collection/utils/translations.js +8 -5
- package/dist/collection/utils/types.js +8 -0
- package/dist/collection/utils/util.date.js +4 -3
- package/dist/collection/utils/utils.js +5 -2
- package/dist/esm/casino-engagement-suite-progress-bar_6.entry.js +12 -11
- package/dist/esm/{casino-engagement-suite-tournament-3be75bd2.js → casino-engagement-suite-tournament-61d378cd.js} +244 -67
- package/dist/esm/casino-engagement-suite-tournament.js +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/types/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.d.ts +20 -3
- package/dist/types/components.d.ts +18 -0
- package/dist/types/shared/TournamentItem.d.ts +7 -1
- package/dist/types/shared/TournamentItemTitle.d.ts +6 -1
- package/dist/types/shared/icons.d.ts +1 -0
- package/dist/types/utils/api.apdater.d.ts +3 -0
- package/dist/types/utils/bussiness.d.ts +10 -1
- package/dist/types/utils/message.d.ts +3 -0
- package/dist/types/utils/translations.d.ts +6 -1
- package/dist/types/utils/types.d.ts +9 -0
- package/dist/types/utils/util.date.d.ts +2 -2
- package/dist/types/utils/utils.d.ts +1 -0
- package/package.json +1 -1
- package/dist/casino-engagement-suite-tournament/p-f478f260.js +0 -15
|
@@ -46,16 +46,19 @@ const localePostprocess = (translationText, props) => {
|
|
|
46
46
|
});
|
|
47
47
|
return translationText;
|
|
48
48
|
};
|
|
49
|
-
const TRANSLATIONS = Object.assign(Object.assign(Object.assign({ Join: 'Join', Unjoin: 'Unjoin' }, Tab), Time), { TC: 'Terms & Conditions', ScoreCriteria: 'Score Criteria', MinimumBetCriteria: 'Minimum bet criteria', Place: 'place', Prizes: 'Rewards', LeaderboardDetails: 'Leaderboard Details', UnjoinDialog: {
|
|
49
|
+
const TRANSLATIONS = Object.assign(Object.assign(Object.assign({ Join: 'Join', Unjoin: 'Unjoin' }, Tab), Time), { TC: 'Terms & Conditions', ScoreCriteria: 'Score Criteria', MinimumBetCriteria: 'Minimum bet criteria', Place: 'place', Places: 'places', Prizes: 'Rewards', LeaderboardDetails: 'Leaderboard Details', UnjoinDialog: {
|
|
50
50
|
Title: 'Quit Leaderboard?',
|
|
51
51
|
Description: 'Any progress on the current Leaderboard won’t be kept and you can not rejoin the Leaderboard any more. <br /><br />Would you still like to quit?',
|
|
52
52
|
ButtonYes: 'Yes, I want to quit leaderboard',
|
|
53
53
|
ButtonNo: 'No, Stay on the leaderboard'
|
|
54
54
|
}, WinDialog: {
|
|
55
|
-
|
|
56
|
-
Description: 'You won <span>{
|
|
57
|
-
ButtonContinue: 'Continue'
|
|
58
|
-
|
|
55
|
+
Title: 'Congratulations!',
|
|
56
|
+
Description: 'You won <span>{rewards}</span>!',
|
|
57
|
+
ButtonContinue: 'Continue',
|
|
58
|
+
FailedTitle: 'Reward cannot be issued',
|
|
59
|
+
FailedDescription: 'Please contact support.',
|
|
60
|
+
FailedButtonContinue: 'Ok, continue',
|
|
61
|
+
}, NoLeaderboards: 'No Leaderboards yet', NoLeaderboardsTip: 'Try winning tickets to Leaderboards as rewards or launching other booster games', Leaderboards: 'Leaderboards', TipPrize: 'You took <span>{place}</span> place and win <span>{prize}</span>', TipPrizeWithoutReward: 'You took <span>{place}</span> place</span>', Tip: 'Competition where your real money bets contribute towards the leaderboard score calculation to win the leaderboard reward.', TournamentNotStarted: 'The leaderboard is not started yet. <br> It will start in {startTime}.', BeOne: 'No winners for the time being. Be one of them!', FailedToJoin: 'Oops! some unexpected error happened, please try it again.', FailedToUnjoin: 'Oops! some unexpected error happened, please try it again.' });
|
|
59
62
|
|
|
60
63
|
const classnames = (...args) => {
|
|
61
64
|
let classnameArray = ['Tab'];
|
|
@@ -76,8 +79,7 @@ const classnames = (...args) => {
|
|
|
76
79
|
return classnameArray.join(' ');
|
|
77
80
|
};
|
|
78
81
|
const getNewItems = (newList, oldList, getCondition) => {
|
|
79
|
-
|
|
80
|
-
return newItems;
|
|
82
|
+
return newList.filter(newItem => !oldList.some(oldItem => getCondition(newItem, oldItem)));
|
|
81
83
|
};
|
|
82
84
|
/**
|
|
83
85
|
* Truncate number to specified decimal places (without rounding)
|
|
@@ -120,6 +122,14 @@ var TournamentState;
|
|
|
120
122
|
TournamentState["Closed"] = "Closed";
|
|
121
123
|
TournamentState["Closing"] = "Closing";
|
|
122
124
|
})(TournamentState || (TournamentState = {}));
|
|
125
|
+
var RewardType;
|
|
126
|
+
(function (RewardType) {
|
|
127
|
+
RewardType["FreeSpin"] = "FreeSpin";
|
|
128
|
+
RewardType["Mission"] = "Challenge";
|
|
129
|
+
RewardType["Leaderboard"] = "TournamentTicket";
|
|
130
|
+
RewardType["Custom"] = "Custom";
|
|
131
|
+
RewardType["LuckyWheel"] = "PrizeEngine";
|
|
132
|
+
})(RewardType || (RewardType = {}));
|
|
123
133
|
exports.DialogType = void 0;
|
|
124
134
|
(function (DialogType) {
|
|
125
135
|
DialogType["unjoin"] = "unjoin";
|
|
@@ -128,6 +138,7 @@ exports.DialogType = void 0;
|
|
|
128
138
|
DialogType["error"] = "error";
|
|
129
139
|
})(exports.DialogType || (exports.DialogType = {}));
|
|
130
140
|
|
|
141
|
+
const DEFAULT_PAGE_SIZE = 12;
|
|
131
142
|
const getMaxRankStr = (playerLeaderboards) => {
|
|
132
143
|
let bestRank = null;
|
|
133
144
|
(playerLeaderboards || []).map((playerLeaderboard) => {
|
|
@@ -138,23 +149,55 @@ const getMaxRankStr = (playerLeaderboards) => {
|
|
|
138
149
|
}
|
|
139
150
|
bestRank = !bestRank || ((_a = bestRank.leaderBoard) === null || _a === void 0 ? void 0 : _a.rank) > rank ? playerLeaderboard : bestRank;
|
|
140
151
|
});
|
|
141
|
-
return
|
|
152
|
+
return {
|
|
153
|
+
rank: bestRank ? `${bestRank.leaderBoard.rank} / ${bestRank.endRank}` : '-',
|
|
154
|
+
detail: bestRank ? {
|
|
155
|
+
playerRank: bestRank.leaderBoard.rank,
|
|
156
|
+
total: bestRank.endRank
|
|
157
|
+
} : null
|
|
158
|
+
};
|
|
142
159
|
};
|
|
143
160
|
const isTournamentClosed = (tournament) => {
|
|
161
|
+
return [TournamentState.Closed].includes(tournament.state);
|
|
162
|
+
};
|
|
163
|
+
const isTournamentEnded = (tournament) => {
|
|
144
164
|
return [TournamentState.Closed, TournamentState.Closing].includes(tournament.state);
|
|
145
165
|
};
|
|
166
|
+
const getRewardNameByType = (reward) => {
|
|
167
|
+
switch (reward.type) {
|
|
168
|
+
case RewardType.FreeSpin:
|
|
169
|
+
return reward.campaignName;
|
|
170
|
+
case RewardType.Mission:
|
|
171
|
+
return reward.challengeName;
|
|
172
|
+
case RewardType.Leaderboard:
|
|
173
|
+
return reward.ticketProgramName;
|
|
174
|
+
case RewardType.LuckyWheel:
|
|
175
|
+
return reward.prizeEngineProgramName;
|
|
176
|
+
case RewardType.Custom:
|
|
177
|
+
return reward.value;
|
|
178
|
+
default:
|
|
179
|
+
return reward.name;
|
|
180
|
+
}
|
|
181
|
+
};
|
|
146
182
|
|
|
147
183
|
const rewardSvg = '';
|
|
148
184
|
|
|
185
|
+
const iconTrophySvg = '';
|
|
186
|
+
|
|
187
|
+
const iconWarnSvg = '';
|
|
188
|
+
|
|
149
189
|
const helpSvg = '';
|
|
150
190
|
|
|
191
|
+
const backSvg = '';
|
|
192
|
+
|
|
151
193
|
const iconClose = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/close.svg" });
|
|
152
194
|
const iconQuestion = index.h("img", { src: helpSvg, alt: "question", class: "Question" });
|
|
153
195
|
const iconEyeOpen = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-open.svg" });
|
|
154
196
|
const iconEyeClose = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-closed.svg" });
|
|
155
|
-
const iconBack = index.h("img", { src: "
|
|
197
|
+
const iconBack = index.h("img", { src: backSvg, alt: "Back", class: "Back" });
|
|
156
198
|
const iconReward = index.h("img", { src: rewardSvg, alt: "reward", class: "Reward" });
|
|
157
|
-
const iconTrophy = index.h("img", { src: "
|
|
199
|
+
const iconTrophy = index.h("img", { src: iconTrophySvg, alt: "iconTrophy", class: "Trophy" });
|
|
200
|
+
const iconWarn = index.h("img", { src: iconWarnSvg, alt: "Reward Assign Failed", class: "Warn" });
|
|
158
201
|
|
|
159
202
|
const renderGradientRoundedButton = (_a) => {
|
|
160
203
|
var { statedClasses, innerHTML } = _a, props = __rest(_a, ["statedClasses", "innerHTML"]);
|
|
@@ -169,6 +212,7 @@ const renderGradientRoundedButton = (_a) => {
|
|
|
169
212
|
var GradientButton;
|
|
170
213
|
(function (GradientButton) {
|
|
171
214
|
GradientButton["normal"] = "normal";
|
|
215
|
+
GradientButton["okContinue"] = "okContinue";
|
|
172
216
|
GradientButton["unjoinYes"] = "unjoinYes";
|
|
173
217
|
GradientButton["unjoinNo"] = "unjoinNo";
|
|
174
218
|
})(GradientButton || (GradientButton = {}));
|
|
@@ -178,6 +222,9 @@ const renderButton = (instance, buttonType, isActionJoinPending = false) => {
|
|
|
178
222
|
normal: {
|
|
179
223
|
innerHTML: locale.WinDialog.ButtonContinue
|
|
180
224
|
},
|
|
225
|
+
okContinue: {
|
|
226
|
+
innerHTML: locale.WinDialog.FailedButtonContinue
|
|
227
|
+
},
|
|
181
228
|
unjoinYes: {
|
|
182
229
|
onClick: () => instance.actionJoin(instance.dialog.data),
|
|
183
230
|
innerHTML: locale.UnjoinDialog.ButtonYes
|
|
@@ -202,14 +249,20 @@ const renderButton = (instance, buttonType, isActionJoinPending = false) => {
|
|
|
202
249
|
};
|
|
203
250
|
const dialog = {
|
|
204
251
|
gift(instance) {
|
|
205
|
-
const { name:
|
|
252
|
+
const { name: rewards, failedRewards } = instance.gifts[0];
|
|
206
253
|
const { locale } = instance;
|
|
207
|
-
return (index.h("div", { class: "PageConfirmContainer" },
|
|
208
|
-
index.h("div", { class: "PageConfirm" },
|
|
254
|
+
return (index.h("div", { class: "PageConfirmContainer" }, !!rewards ?
|
|
255
|
+
index.h("div", { class: "PageConfirm Gift" },
|
|
209
256
|
index.h("div", null, iconTrophy),
|
|
210
|
-
index.h("div", { class: "Title" }, locale.WinDialog.
|
|
211
|
-
index.h("div", { class: "Description", innerHTML: localePostprocess(locale.WinDialog.Description, {
|
|
212
|
-
index.h("div", { class: "PageConfirmButtonsGroup" }, renderButton(instance, GradientButton.normal)))
|
|
257
|
+
index.h("div", { class: "Title" }, locale.WinDialog.Title),
|
|
258
|
+
index.h("div", { class: "Description", innerHTML: localePostprocess(locale.WinDialog.Description, { rewards }) }),
|
|
259
|
+
index.h("div", { class: "PageConfirmButtonsGroup" }, renderButton(instance, GradientButton.normal)))
|
|
260
|
+
:
|
|
261
|
+
index.h("div", { class: "PageConfirm Gift" },
|
|
262
|
+
index.h("div", null, iconWarn),
|
|
263
|
+
index.h("div", { class: "Title", innerHTML: localePostprocess(locale.WinDialog.FailedTitle, { failedRewards }) }),
|
|
264
|
+
index.h("div", { class: "Description" }, locale.WinDialog.FailedDescription),
|
|
265
|
+
index.h("div", { class: "PageConfirmButtonsGroup" }, renderButton(instance, GradientButton.okContinue)))));
|
|
213
266
|
},
|
|
214
267
|
unjoin(instance) {
|
|
215
268
|
const { locale } = instance;
|
|
@@ -242,6 +295,20 @@ const tournamentAdapter = (tournamentApi) => {
|
|
|
242
295
|
});
|
|
243
296
|
return tournament;
|
|
244
297
|
};
|
|
298
|
+
const updateTournament = (target, source) => {
|
|
299
|
+
const keysTime = [
|
|
300
|
+
'startTime',
|
|
301
|
+
'endTime',
|
|
302
|
+
'closeTime',
|
|
303
|
+
'exhibitionStartTime',
|
|
304
|
+
'exhibitionEndTime', 'state',
|
|
305
|
+
'prizes', 'minBetCount', 'scoreCriteria', 'termsUrl'
|
|
306
|
+
];
|
|
307
|
+
keysTime.forEach((key) => {
|
|
308
|
+
target[key] = source[key];
|
|
309
|
+
});
|
|
310
|
+
return Object.assign({}, target);
|
|
311
|
+
};
|
|
245
312
|
const leaderboardsAdapter = (leaderboardRes) => {
|
|
246
313
|
let { item, items: leaderboards } = leaderboardRes;
|
|
247
314
|
if (!item) {
|
|
@@ -280,28 +347,35 @@ const messageSender = {
|
|
|
280
347
|
GameClickReq: (game) => window.postMessage({ type: 'EngagementSuiteGameRedirect', data: { Slug: game.slug } }),
|
|
281
348
|
};
|
|
282
349
|
const messageReceiver = (instance) => {
|
|
283
|
-
|
|
350
|
+
return {
|
|
284
351
|
UpdateLeaderboardsPlayerRes: (rest) => {
|
|
285
|
-
|
|
352
|
+
const { rank, detail } = (getMaxRankStr(rest.data.items));
|
|
353
|
+
window.postMessage({ type: 'UpdateLeaderboardState', rank, detail });
|
|
286
354
|
},
|
|
287
355
|
UpdateLeaderboardStateReq: () => {
|
|
288
356
|
window.postMessage({ type: 'UpdateLeaderboardState', labels: ['win', 'new'] });
|
|
289
357
|
},
|
|
358
|
+
/*
|
|
359
|
+
* Update tournament games list when switch to game tab in detail page
|
|
360
|
+
*/
|
|
290
361
|
UpdateTournamentsItemRes: (rest) => {
|
|
291
362
|
const tournamentNew = tournamentAdapter(rest.data.item);
|
|
292
363
|
instance.tournamentItem = tournamentNew;
|
|
293
364
|
updateTournamentListByItem(instance, tournamentNew);
|
|
294
365
|
},
|
|
295
|
-
UpdateLeaderboardsRes: (rest) =>
|
|
296
|
-
|
|
297
|
-
|
|
366
|
+
UpdateLeaderboardsRes: (rest) => initPlayerLeaderboard(instance, rest),
|
|
367
|
+
//Parse the join tournament response
|
|
368
|
+
JoinTournamentRes: (rest) => commonJoinRes(instance, rest, true),
|
|
369
|
+
//Parse the unjoin tournament response
|
|
370
|
+
UnjoinTournamentRes: (rest) => commonJoinRes(instance, rest, false),
|
|
371
|
+
//Parse recieved init message when widget is loaded
|
|
298
372
|
TournamentsPageIsReadyRes: (rest) => instance.currentGameId = '' + rest.data.GameId,
|
|
299
373
|
// listen to LeaderboardLiveEvent event, handle update
|
|
300
|
-
LeaderboardLiveEvent: (rest) =>
|
|
301
|
-
|
|
302
|
-
},
|
|
374
|
+
LeaderboardLiveEvent: (rest) => handleLeaderboardLiveEvent(instance, rest),
|
|
375
|
+
LiveLeaderboardUpdate: (rest) => updateLeaderboardInfo(instance, Object.assign(Object.assign({}, rest), { messageType: 'LeaderboardUpdate' })),
|
|
376
|
+
LiveTournamentUpdate: (rest) => updateTournamentInfo(instance, Object.assign(Object.assign({}, rest), { messageType: 'TournamentUpdate' })),
|
|
377
|
+
LiveLeaderboardFinalizeUpdate: (rest) => updatePlayerRewardInfo(instance, Object.assign(Object.assign({}, rest), { messageType: 'PlayerFinalizeUpdate' })),
|
|
303
378
|
};
|
|
304
|
-
return receiver;
|
|
305
379
|
};
|
|
306
380
|
/**
|
|
307
381
|
* Handle LeaderboardLiveEvent update event
|
|
@@ -377,33 +451,45 @@ const handleLeaderboardLiveEvent = (instance, rest) => {
|
|
|
377
451
|
}
|
|
378
452
|
}
|
|
379
453
|
};
|
|
380
|
-
const
|
|
381
|
-
|
|
454
|
+
const clearUnjoinedTournament = (instance, unjoinedTournamentId) => {
|
|
455
|
+
const clearId = setTimeout(() => {
|
|
456
|
+
instance.tournamentList = instance.tournamentList.filter((tournament) => {
|
|
457
|
+
return tournament.id !== unjoinedTournamentId;
|
|
458
|
+
});
|
|
459
|
+
clearTimeout(clearId);
|
|
460
|
+
}, 100);
|
|
382
461
|
};
|
|
383
|
-
const commonJoinRes = (instance, rest) => {
|
|
462
|
+
const commonJoinRes = (instance, rest, isJoinRes) => {
|
|
384
463
|
const { success, data } = rest;
|
|
385
464
|
let tournamentIdx = instance.tournamentList.findIndex((tournament) => tournament.id === (data.tournamentId || data.id || data.bonusCode)), current = instance.tournamentList[tournamentIdx];
|
|
386
465
|
if (tournamentIdx == -1) {
|
|
387
466
|
return;
|
|
388
467
|
}
|
|
389
|
-
current =
|
|
468
|
+
current.isActionJoinPending = false;
|
|
390
469
|
instance.pendingChangeEvent.emit(current);
|
|
391
470
|
if (!success) {
|
|
392
471
|
instance.tournamentList[tournamentIdx] = current;
|
|
393
472
|
instance.tournamentList = [...instance.tournamentList];
|
|
394
|
-
|
|
473
|
+
instance.openDialog(exports.DialogType.error);
|
|
395
474
|
return;
|
|
396
475
|
}
|
|
397
|
-
|
|
398
|
-
|
|
476
|
+
if (isJoinRes) {
|
|
477
|
+
current.isPlayerAcknowledged = true;
|
|
478
|
+
current.order = instance.minOrder--;
|
|
479
|
+
}
|
|
480
|
+
else {
|
|
481
|
+
current.isUnjoined = true;
|
|
482
|
+
clearUnjoinedTournament(instance, data.tournamentId);
|
|
483
|
+
}
|
|
484
|
+
instance.tournamentList[tournamentIdx] = Object.assign({}, current);
|
|
399
485
|
instance.tournamentList = [...instance.tournamentList];
|
|
400
486
|
if (instance.page === exports.LeaderboardPage.item) {
|
|
401
|
-
if (
|
|
402
|
-
instance.
|
|
403
|
-
return;
|
|
487
|
+
if (isJoinRes) {
|
|
488
|
+
instance.tournamentItem = Object.assign({}, current);
|
|
404
489
|
}
|
|
405
490
|
else {
|
|
406
|
-
instance.
|
|
491
|
+
instance.setPage(exports.LeaderboardPage.list);
|
|
492
|
+
return;
|
|
407
493
|
}
|
|
408
494
|
}
|
|
409
495
|
if (instance.nextPage) {
|
|
@@ -411,17 +497,21 @@ const commonJoinRes = (instance, rest) => {
|
|
|
411
497
|
instance.nextPage = undefined;
|
|
412
498
|
}
|
|
413
499
|
};
|
|
414
|
-
const
|
|
500
|
+
const initPlayerLeaderboard = (instance, rest) => {
|
|
415
501
|
instance.leaderboards = leaderboardsAdapter(rest.data);
|
|
416
|
-
instance.
|
|
502
|
+
instance.currentPlayerRank = rest.data.item ? rest.data.item.rank : -1;
|
|
417
503
|
};
|
|
418
504
|
/*
|
|
419
505
|
* update tournament info, include status, name or duration change
|
|
420
506
|
*/
|
|
421
507
|
const updateTournamentListByItem = (instance, tournament) => {
|
|
508
|
+
const newTournament = tournamentAdapter(tournament);
|
|
509
|
+
if (instance.tournamentItem.id === tournament.id) {
|
|
510
|
+
instance.tournamentItem = Object.assign({}, updateTournament(instance.tournamentItem, newTournament));
|
|
511
|
+
}
|
|
422
512
|
instance.tournamentList = instance.tournamentList.map((_tournament) => {
|
|
423
513
|
if (_tournament.id === tournament.id) {
|
|
424
|
-
return
|
|
514
|
+
return Object.assign({}, updateTournament(_tournament, newTournament));
|
|
425
515
|
}
|
|
426
516
|
else {
|
|
427
517
|
return _tournament;
|
|
@@ -432,8 +522,8 @@ const removeTournament = (instance, tournament) => {
|
|
|
432
522
|
instance.tournamentList = instance.tournamentList.filter((_tournament) => _tournament.id !== tournament.id);
|
|
433
523
|
};
|
|
434
524
|
const updateOrAddTournamentToList = (instance, tournament) => {
|
|
435
|
-
const index = instance.tournamentList.findIndex(
|
|
436
|
-
if (index === -1) {
|
|
525
|
+
const index = instance.tournamentList.findIndex(_tournament => _tournament.id === tournament.id);
|
|
526
|
+
if (index === -1) { //not found in list, handle it as new tournament
|
|
437
527
|
instance.tournamentList = [
|
|
438
528
|
tournamentAdapter(tournament),
|
|
439
529
|
...instance.tournamentList
|
|
@@ -444,6 +534,60 @@ const updateOrAddTournamentToList = (instance, tournament) => {
|
|
|
444
534
|
instance.tournamentList = [...instance.tournamentList];
|
|
445
535
|
}
|
|
446
536
|
};
|
|
537
|
+
const updateTournamentInfo = (instance, rest) => {
|
|
538
|
+
try {
|
|
539
|
+
const updateMessageObj = JSON.parse(rest.data.Message);
|
|
540
|
+
updateTournamentListByItem(instance, updateMessageObj);
|
|
541
|
+
}
|
|
542
|
+
catch (e) {
|
|
543
|
+
console.error('Exception when parse Player Tournament Info', e);
|
|
544
|
+
}
|
|
545
|
+
};
|
|
546
|
+
const updatePlayerRewardInfo = (instance, rest) => {
|
|
547
|
+
try {
|
|
548
|
+
const updateMessageObj = JSON.parse(rest.data.Message);
|
|
549
|
+
const assignFailedRewards = updateMessageObj.rewards.filter(item => item.status && item.status !== 'success')
|
|
550
|
+
.map(reward => getRewardNameByType(reward)).join(',');
|
|
551
|
+
const assignedRewards = updateMessageObj.rewards.filter(item => !!item.assigned && item.status === 'success')
|
|
552
|
+
.map(reward => getRewardNameByType(reward)).join(',');
|
|
553
|
+
if (assignFailedRewards.length) {
|
|
554
|
+
instance.gifts = [{ name: null, failedRewards: assignFailedRewards }, ...instance.gifts];
|
|
555
|
+
}
|
|
556
|
+
if (assignedRewards.length) {
|
|
557
|
+
instance.gifts = [{ name: assignedRewards }, ...instance.gifts];
|
|
558
|
+
}
|
|
559
|
+
instance.checkGift();
|
|
560
|
+
}
|
|
561
|
+
catch (e) {
|
|
562
|
+
console.error('Exception when parse Player LeaderboardFinalize info', e);
|
|
563
|
+
}
|
|
564
|
+
};
|
|
565
|
+
const updateLeaderboardInfo = (instance, rest) => {
|
|
566
|
+
var _a;
|
|
567
|
+
try {
|
|
568
|
+
const updateMessageObj = JSON.parse(rest.data.Message);
|
|
569
|
+
const { PlayerLeaderBoard, TournamentId, TournamentLeaderBoardDto } = updateMessageObj;
|
|
570
|
+
//update user rank in UI-bar by parsing PlayerLeaderboard
|
|
571
|
+
if (PlayerLeaderBoard) {
|
|
572
|
+
window.postMessage({ type: 'UpdateLeaderboardState',
|
|
573
|
+
rank: `${PlayerLeaderBoard.rank} / ${TournamentLeaderBoardDto.totalRecords}`,
|
|
574
|
+
detail: {
|
|
575
|
+
playerRank: PlayerLeaderBoard.rank,
|
|
576
|
+
total: TournamentLeaderBoardDto.totalRecords
|
|
577
|
+
}
|
|
578
|
+
});
|
|
579
|
+
}
|
|
580
|
+
if (((_a = instance.tournamentItem) === null || _a === void 0 ? void 0 : _a.id) == TournamentId) {
|
|
581
|
+
initPlayerLeaderboard(instance, { data: {
|
|
582
|
+
item: Object.assign({}, PlayerLeaderBoard),
|
|
583
|
+
items: [...TournamentLeaderBoardDto.players]
|
|
584
|
+
} });
|
|
585
|
+
}
|
|
586
|
+
}
|
|
587
|
+
catch (err) {
|
|
588
|
+
console.error('Exception when parse live update info, ', err);
|
|
589
|
+
}
|
|
590
|
+
};
|
|
447
591
|
|
|
448
592
|
const page = {
|
|
449
593
|
list(instance) {
|
|
@@ -454,7 +598,9 @@ const page = {
|
|
|
454
598
|
}
|
|
455
599
|
const { locale } = instance;
|
|
456
600
|
if (instance.tournamentList.length) {
|
|
457
|
-
return renderWrapperByPageType(index.h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament) => (
|
|
601
|
+
return renderWrapperByPageType(index.h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament, idx) => (
|
|
602
|
+
// @ts-ignore
|
|
603
|
+
index.h("tournament-item", { tid: _tournament.id, key: _tournament.id, tournament: _tournament, style: { 'order': `${_tournament.order || idx}` }, isNew: instance.newIdList.includes(_tournament.id) })))));
|
|
458
604
|
}
|
|
459
605
|
else {
|
|
460
606
|
return renderWrapperByPageType(index.h("div", { class: "NoLeaderboards ScrollBar Row" },
|
|
@@ -510,20 +656,25 @@ function getProgress(startDate, endDate) {
|
|
|
510
656
|
if (new Date().getTime() >= endDate.getTime()) {
|
|
511
657
|
return 100;
|
|
512
658
|
}
|
|
513
|
-
return ((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime()))
|
|
659
|
+
return Math.floor((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime()));
|
|
514
660
|
}
|
|
515
|
-
function getTimeDifference(startDate, endDate) {
|
|
661
|
+
function getTimeDifference(startDate, endDate, progress = 0) {
|
|
516
662
|
const diffMs = Math.abs(endDate.getTime() - startDate.getTime()); // Difference in milliseconds
|
|
517
663
|
const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24)); // Difference in days
|
|
518
664
|
const diffHours = Math.floor((diffMs % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // Remaining hours
|
|
519
665
|
const diffMinutes = Math.floor((diffMs % (1000 * 60 * 60)) / (1000 * 60)); // Remaining minutes
|
|
520
|
-
|
|
666
|
+
const min = progress === 100 ? 0 : diffMinutes === 0 ? 1 : diffMinutes;
|
|
667
|
+
return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(min).padStart(2, '0')}m`;
|
|
521
668
|
}
|
|
522
669
|
|
|
523
670
|
const tab = {
|
|
524
671
|
info(instance) {
|
|
525
672
|
var _a, _b;
|
|
526
673
|
const { locale, tournamentItem: tournament, isShowInfo } = instance;
|
|
674
|
+
const playerRank = getResultPrize((_a = instance.leaderboards) === null || _a === void 0 ? void 0 : _a.find((l) => l.isMe));
|
|
675
|
+
const rewardInfo = !(playerRank === null || playerRank === void 0 ? void 0 : playerRank.place) || (playerRank === null || playerRank === void 0 ? void 0 : playerRank.unqualified)
|
|
676
|
+
? ''
|
|
677
|
+
: localePostprocess(((playerRank === null || playerRank === void 0 ? void 0 : playerRank.prize) ? locale.TipPrize : locale.TipPrizeWithoutReward), playerRank);
|
|
527
678
|
return (index.h("div", { class: "InfoContainer" },
|
|
528
679
|
index.h("tournament-timer", { "is-detail": true, tournament: tournament }),
|
|
529
680
|
index.h("section", { class: "ShowInfo", onClick: () => (instance.isShowInfo = !instance.isShowInfo) },
|
|
@@ -544,15 +695,17 @@ const tab = {
|
|
|
544
695
|
index.h("span", null, tournament.minBetCount))),
|
|
545
696
|
!!tournament.termsUrl && (index.h("div", { class: "TC" },
|
|
546
697
|
index.h("a", { href: tournament.termsUrl, target: "_blank" }, locale.TC))))),
|
|
547
|
-
isTournamentClosed(instance.tournamentItem) && ((
|
|
698
|
+
isTournamentClosed(instance.tournamentItem) && ((_b = instance.leaderboards) === null || _b === void 0 ? void 0 : _b.find((l) => l.isMe)) && (index.h("section", { class: "ResultPrize", innerHTML: rewardInfo })),
|
|
548
699
|
index.h("section", { class: "PrizesContainer" },
|
|
549
700
|
index.h("div", { class: "PrizesHeader" },
|
|
550
701
|
iconReward,
|
|
551
702
|
index.h("span", { class: "PrizesText" }, locale.Prizes)),
|
|
552
|
-
index.h("div", { class: "Prizes" }, tournament.prizes.map((prize
|
|
553
|
-
index
|
|
554
|
-
|
|
555
|
-
|
|
703
|
+
index.h("div", { class: "Prizes" }, tournament.prizes.map((prize) => (index.h("div", { class: "Prize" },
|
|
704
|
+
index.h("span", { class: 'Rank' },
|
|
705
|
+
prize.rank,
|
|
706
|
+
" ",
|
|
707
|
+
prize.count === 1 ? '' : ` - ${(prize.rank + prize.count - 1)}`),
|
|
708
|
+
prize.count === 1 ? locale.Place : locale.Places,
|
|
556
709
|
": ",
|
|
557
710
|
index.h("span", { class: "PrizeText" }, prize.name)))))))));
|
|
558
711
|
},
|
|
@@ -576,6 +729,8 @@ const tab = {
|
|
|
576
729
|
},
|
|
577
730
|
games(instance) {
|
|
578
731
|
var _a;
|
|
732
|
+
if (!instance.tournamentItem.games || !instance.tournamentItem.games.length)
|
|
733
|
+
return index.h("general-animation-loading", null);
|
|
579
734
|
return (index.h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (index.h("div", { class: `Game ${instance.currentGameId == game.id ? 'Current' : ''}`, onClick: () => {
|
|
580
735
|
instance.onGameClick(game);
|
|
581
736
|
} },
|
|
@@ -584,8 +739,9 @@ const tab = {
|
|
|
584
739
|
};
|
|
585
740
|
const getResultPrize = (leaderboard) => {
|
|
586
741
|
return {
|
|
587
|
-
prize: leaderboard.prizeName,
|
|
588
|
-
place: leaderboard.rank
|
|
742
|
+
prize: leaderboard === null || leaderboard === void 0 ? void 0 : leaderboard.prizeName,
|
|
743
|
+
place: leaderboard === null || leaderboard === void 0 ? void 0 : leaderboard.rank,
|
|
744
|
+
unqualified: leaderboard === null || leaderboard === void 0 ? void 0 : leaderboard.unqualified,
|
|
589
745
|
};
|
|
590
746
|
};
|
|
591
747
|
|
|
@@ -617,7 +773,7 @@ const renderCloseBar = (attr) => {
|
|
|
617
773
|
return (index.h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (index.h("div", { class: 'WrapperBar' + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
|
|
618
774
|
};
|
|
619
775
|
|
|
620
|
-
const casinoEngagementSuiteTournamentCss = ".Leaderboards{height:100%;overflow-y:auto;transition:0.5s ease;transition-property:all, transform}.Leaderboards.list,.Leaderboards.item{opacity:0}.Leaderboards.list.Active,.Leaderboards.item.Active{opacity:1}.Leaderboards.list.Hidden,.Leaderboards.item.Hidden{display:none}.Leaderboards .question__tooltip{position:absolute;top:0;left:20px;width:320px;text-align:left;background-color:var(--emw--color-typography, rgba(255, 255, 255, 0.6));border:1px solid var(--emw--color-typography, rgba(255, 255, 255, 0.8));color:var(var(--emw--color-primary, rgb(255, 214, 47)), rgb(255, 214, 47));padding:10px;border-radius:5px;opacity:0;fill-opacity:0.5;transition:opacity 0.3s ease-in-out;z-index:10}.Leaderboards .question__tooltip.visible{opacity:0.8}table.leaderboards{height:auto}.Wrapper{position:relative;min-height:100%;color:var(--emw--color-typography, #FFFFFF);display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));flex-direction:column;border-radius:24px}.Wrapper .TableContentWrapper{scrollbar-width:thin;scrollbar-color:var(--emw--color-background, hsl(254, 8.53%, 54.93%)) transparent}.Wrapper .WrapperContent .TableContentWrapper{height:calc(100vh - 278px);overflow-y:auto}.Wrapper .WrapperContent .Main{height:calc(100vh - 188px)}.Wrapper.Mobile{border-radius:16px}.WrapperContent{padding-bottom:20px;transition:0.5s filter}.WrapperContent.faded{filter:brightness(53.3333333333%);pointer-events:none}.WrapperContent .NoLeaderboards h3.Title{text-align:center}.WrapperContent .NoLeaderboards div.message{color:var(--emw--color-secondary, rgb(187, 185, 195));text-align:left}.Wrapper.Mobile .WrapperBar{padding:20px 8px 8px;margin-bottom:8px}.WrapperBar{display:flex;width:100%;padding:32px 20px 20px;margin-bottom:20px}.WrapperBar .WrapperBarLeft span{position:relative}.WrapperBarLeft,.WrapperBarRight{cursor:pointer;z-index:1}.WrapperBarMiddle{flex-grow:1;text-align:center;font-size:var(--emw--font-size-medium, 16px);line-height:16px;font-weight:500;color:var(--emw--color-secondary, rgb(187, 185, 195))}:host{display:block;font-size:var(--emw--font-size-x-small, 12px);font-family:Inter}.ScrollBar{scrollbar-width:thin;scrollbar-color:var(--emw--color-background, hsl(254, 8.53%, 54.93%)) transparent}.Row{margin:10px 0;padding:0 20px}.Row:first-child{margin:0;padding-top:5px}.LeaderboardsItem{opacity:1;transition:1s opacity ease;position:relative;margin:10px 0;border:1px solid rgb(64, 57, 86);border-radius:16px}.LeaderboardsItem.Unjoined{opacity:0;margin:0;border:0 none;animation:slideOut 1s forwards}.LeaderboardsItem.Hollow{border-color:transparent}.LeaderboardsItem:first-child{margin-top:0}.LeaderboardsItemContainer{padding-top:16px}.ShowInfo{margin:10px 0;padding:0 20px;transition:0.5s all ease}.TimeContainer{margin:10px 0;padding:0 20px;transition:0.5s all ease}.TimeContainer .Time{display:flex;justify-content:space-between;font-size:var(--emw--font-size-x-small, 12px);align-items:center;color:var(--emw--color-secondary, rgb(187, 185, 195))}.TimeContainer .Time .Running{width:100%;display:flex;flex-direction:row;justify-content:space-between}.TimeContainer .Time button{font-size:var(--emw--font-size-x-small, 12px);height:20px;padding:0}.TimeContainer .Time button::before{inset:inherit;border:0}.TitleContainer{display:flex;justify-content:space-between;margin:10px 0;padding:0 20px;margin-top:0;gap:10px;font-family:Montserrat}.TitleContainer .GradientRoundedButton{width:120px}.TabsContainer{margin:10px 0;padding:0 20px;margin:0 20px;padding:0;border-bottom:1px solid #575757}.Tabs{display:flex;justify-content:space-between;justify-content:start;font-size:var(--emw--font-size-x-small, 12px);margin-bottom:-1px}.Tabs .Tab{text-transform:capitalize}.Tabs>div{padding:10px;color:rgb(102, 97, 120);cursor:pointer}.Tabs>div.active{color:var(--emw--color-typography, #FFF);border-bottom:2px solid var(--emw--color-typography, #FFF)}.Title{font-size:var(--emw--font-size-medium, 16px);font-weight:700;line-height:19.5px;text-align:left;word-break:break-word}.TC{margin-top:12px}.TC a{color:rgb(89, 209, 255)}.Criterias{margin:12px 0}.Criterias span{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.ResultPrize{margin:10px 0;padding:0 20px;padding-left:30px;text-align:left}.ResultPrize span{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.InfoContainer{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.ContentScrollContainer{flex:1;display:flex;flex-direction:column;overflow-y:auto;position:relative;height:auto}.ContentScrollContainer.expanded{height:100%;max-height:100%}.PrizesContainer{flex:1;display:flex;flex-direction:column;min-height:100px;max-height:calc(100% - 20px)}.PrizesHeader,.DetailHeader{align-items:center;display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));padding:5px 0;z-index:1;margin:0 20px}.PrizesHeader img,.DetailHeader img{width:12px}.PrizesHeader .PrizesText,.DetailHeader .PrizesText{margin-left:3px;font-weight:600}.DetailHeader{margin:0}.Prizes{margin:10px 0;padding:0 20px;padding-left:30px;text-align:left;flex:1;overflow-y:auto;margin-bottom:0;padding-right:10px;max-height:300px;margin-top:10px}.Prizes::-webkit-scrollbar{width:4px}.Prizes::-webkit-scrollbar-track{background:rgba(0, 0, 0, 0.1);border-radius:2px}.Prizes::-webkit-scrollbar-thumb{background:var(--emw--color-primary, rgb(255, 214, 47));border-radius:2px}.Prizes .Prize{margin:8px 0}.Prizes .Prize .PrizeText{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.InfoContainer section.Info{margin-bottom:12px;text-align:left;padding-left:15px}.InfoContainer section.Info .Criterias,.InfoContainer section.Info .Description{padding-left:15px;margin-top:10px}*{box-sizing:border-box}.Leaderboards{width:100%;text-align:center;border-collapse:collapse}.Leaderboards td{opacity:0.6;padding:12px 5px}.Leaderboards td:first-child{padding-left:20px}.Leaderboards td:last-child{padding-right:20px}.Leaderboards .LeaderboardName{color:var(--emw--color-typography, #FFF);opacity:1}.Leaderboards tr.isMe{background:rgba(0, 0, 0, 0.2);border:1px solid var(--emw--color-primary, rgb(255, 214, 47))}.Leaderboards tr.isMe .LeaderboardRank span{padding:0px 3px;opacity:1;border:1px solid var(--emw--color-primary, rgb(255, 214, 47));border-radius:11px}.Leaderboards tr.isMe td{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:var(--emw--font-weight-semibold, 500)}.LeaderboardLabels{position:absolute;top:-6px;right:18px;display:flex;gap:4px}.LeaderboardLabel{width:30px;height:15px;background:var(--emw--engagement-suite-gradient-golden, linear-gradient(180deg, #FFB801 15.86%, #FEF746 31.36%, #FBFFE0 36.86%, #FFFA60 47.86%, #FF9400 87.36%));border-radius:var(--emw--border-radius-x-small, 2px);display:inline-flex;padding:0 2px;align-items:center;justify-content:center}.LeaderboardLabel span{display:inline-block;text-transform:uppercase;font-size:var(--emw--font-size-3x-small, 7px);line-height:7px;font-weight:var(--emw--font-weight-bold, 700);font-family:var(--emw--font-family-secondary, \"Montserrat\", sans-serif);color:var(--emw--color-background, #1E1638)}.LeaderboardUnstarted{margin:10px 0;padding:0 20px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-medium, 16px)}.Games{margin:10px 0;padding:0 20px;padding:0 20px;display:flex;flex-wrap:wrap;justify-content:start;margin:20px auto}.Games .Game{cursor:pointer;width:25%;display:flex;padding:5px}.Games .Game.Current{cursor:auto;filter:grayscale(10)}.Games .Game:hover{filter:brightness(var(--emw--hover-brightness, 1.25))}.Games .Game.Current:hover{cursor:auto;filter:grayscale(10)}.Games img{width:100%;height:fit-content}dialog{position:absolute;top:calc(50vh - 280px);width:100%;height:max-content;background:transparent;border:0;padding:0;color:var(--emw--color-typography, #FFFFFF);transition:all 0.2s;transition-timing-function:ease-in-out}dialog>div{margin:32px;border-radius:8px;background:var(--emw--color-background, hsl(254, 44%, 15%));border:1px solid hsl(254, 20%, 28%);align-items:center}.DialogContentUnjoin{padding:32px;padding-top:10px;display:flex;gap:10px;flex-direction:column}.DialogContentUnjoinTitle{font-family:Montserrat;font-size:var(--emw--font-size-large, 20px);font-weight:600;line-height:24.38px;text-align:center}.DialogContentUnjoinDescription{color:var(--emw--color-secondary, rgb(187, 185, 195));margin-bottom:30px}.Tip{padding:32px;padding-top:10px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-small, 14px)}.Tip.Error{color:var(--emw--color-error, var(--emw--color-red, #ed0909));font-weight:var(--emw--font-weight-normal, 500)}.PageConfirmContainer{text-align:center;width:80%;margin:0 auto}.PageConfirm{padding:40px 32px;display:flex;flex-direction:column;gap:20px}.PageConfirm .Title{font-size:var(--emw--font-size-large, 20px);text-align:center}.PageConfirm .Description{color:var(--emw--color-secondary, rgb(187, 185, 195));font-weight:400}.PageConfirm .Description span{color:var(--emw--color-typography, #FFF);font-weight:600}.PageConfirmButtonsGroup{width:150px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.GradientRounded{display:block;background:linear-gradient(98.25deg, #FF9400 22.48%, #FEF746 131.02%, #FFE24A 131.9%);color:rgb(30, 22, 56);position:relative;border-radius:16px}.GradientRounded.Hollow{background:rgb(30, 22, 56);color:#FFFFFF}.GradientRounded.Hollow::before{content:\"\";position:absolute;inset:0;border-radius:15px;border:1px solid transparent;background:linear-gradient(98.25deg, #FF9400 22.48%, #FEF746 131.02%, #FFE24A 131.9%) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude}.GradientRoundedButton{border:none;padding:7px;height:32px;width:100%;font-size:var(--emw--font-size-small, 14px);font-weight:700;line-height:17.07px;text-align:center;transition:0.5s opacity;cursor:pointer}.GradientRoundedButton.Pending{cursor:not-allowed;opacity:0.3}.GradientRoundedButton.Hollow span{background:-webkit-linear-gradient(98.25deg, rgb(255, 148, 0) 22.48%, rgb(254, 247, 70) 131.02%, rgb(255, 226, 74) 131.9%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.WrapperUtil .GradientRounded .WrapperBar{margin-bottom:0;padding-bottom:0}.WrapperUtil .GradientRounded .Tip{padding-top:0;padding-bottom:40px}.LeaderboardsItem .LeaderboardsItemContainer .TitleContainer{margin-bottom:16px}@keyframes slideOut{0%{display:block;opacity:1;height:max-content}50%{display:block;opacity:0.5}80%{display:none;opacity:0}100%{display:none;opacity:0;height:0}}";
|
|
776
|
+
const casinoEngagementSuiteTournamentCss = ".Leaderboards{height:100%;overflow-y:auto;transition:0.5s ease;transition-property:all, transform}.Leaderboards.list,.Leaderboards.item{margin-top:5px;opacity:0}.Leaderboards.list.Active,.Leaderboards.item.Active{opacity:1}.Leaderboards.list.Hidden,.Leaderboards.item.Hidden{display:none}.Leaderboards .question__tooltip{position:absolute;top:0;left:20px;width:320px;text-align:left;background-color:var(--emw--color-typography, rgba(255, 255, 255, 0.6));border:1px solid var(--emw--color-typography, rgba(255, 255, 255, 0.8));color:var(var(--emw--color-primary, rgb(255, 214, 47)), rgb(255, 214, 47));padding:10px;border-radius:5px;opacity:0;fill-opacity:0.5;transition:opacity 0.3s ease-in-out;z-index:10}.Leaderboards .question__tooltip.visible{opacity:0.8}table.Leaderboards{height:auto}table.Leaderboards td.LeaderboardName{max-width:180px}table.Leaderboards td.LeaderboardPrize{min-width:220px;text-align:left}.Wrapper{position:relative;min-height:100%;line-height:20px;color:var(--emw--color-typography, #FFFFFF);display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));flex-direction:column;border-radius:24px}.Wrapper .TableContentWrapper{scrollbar-width:thin;scrollbar-color:var(--emw--color-background, hsl(254, 8.53%, 54.93%)) transparent}.Wrapper .WrapperContent .TableContentWrapper{height:calc(100vh - 298px);overflow-y:auto}.Wrapper .WrapperContent .Main{height:calc(100vh - 188px)}.Wrapper .WrapperContent .Main .Leaderboards.ScrollBar.Row{display:flex;flex-direction:column}.Wrapper .WrapperContent .Main .Leaderboards.ScrollBar.Row tournament-item{transition:2s ease-in-out;transform:translate(0) scale(1, 1);opacity:0.99}.Wrapper.Mobile{border-radius:16px}.Wrapper.Mobile .PageConfirmContainer,.Wrapper.Mobile .DialogContentUnjoin{min-width:80%}.Wrapper.Mobile dialog.tip{padding:120px 10px}.Wrapper.Mobile dialog.unjoin .Hollow{margin:5px}.Wrapper.Mobile .GradientRoundedButton{font-size:var(--emw--font-size-medium, 14px)}.WrapperContent{padding-bottom:20px;transition:0.5s filter}.WrapperContent.faded{filter:brightness(53.3333333333%);pointer-events:none}.WrapperContent .NoLeaderboards h3.Title{text-align:center}.WrapperContent .NoLeaderboards div.message{color:var(--emw--color-secondary, rgb(187, 185, 195));text-align:left}.Wrapper.Mobile .WrapperBar{padding:20px 8px 8px;margin-bottom:8px}.Wrapper.Mobile .Tip{padding:0px 30px 32px}.Wrapper.Mobile .TitleContainer .GradientRoundedButton{width:100px}.WrapperBar{display:flex;width:100%;padding:20px 20px}.WrapperBar .WrapperBarLeft span{position:relative}.WrapperBarLeft,.WrapperBarRight{cursor:pointer;z-index:1}.WrapperBarLeft span.EngagementSuiteIcon img,.WrapperBarRight span.EngagementSuiteIcon img{width:24px;height:24px}.WrapperBarMiddle{flex-grow:1;text-align:center;font-size:var(--emw--font-size-medium, 16px);line-height:16px;font-weight:500;color:var(--emw--color-secondary, rgb(187, 185, 195))}:host{display:block;font-size:var(--emw--font-size-x-small, 14px)}.ScrollBar{scrollbar-width:thin;scrollbar-color:var(--emw--color-background, hsl(254, 8.53%, 54.93%)) transparent}.Row{margin:10px 0;padding:0 20px}.Row:first-child{margin:0;padding-top:5px}.LeaderboardsItem{opacity:1;transition:1s opacity ease;position:relative;margin:20px 0;border:1px solid rgb(64, 57, 86);border-radius:6px;padding:12px 0}.LeaderboardsItem.Unjoined{opacity:0;margin:0;border:0 none;animation:slideOut 1s forwards}.LeaderboardsItem.Hollow{border-color:transparent}.LeaderboardsItem:first-child{margin-top:0}.LeaderboardsItemContainer{padding-top:16px}.ShowInfo{margin:10px 0;padding:0 20px;transition:0.5s all ease}.TimeContainer{margin:10px 0;padding:0 20px;transition:0.5s all ease}.TimeContainer .Time{display:flex;justify-content:space-between;font-size:var(--emw--font-size-x-small, 14px);align-items:center;color:var(--emw--color-secondary, rgb(187, 185, 195))}.TimeContainer .Time .Running{width:100%;display:flex;flex-direction:row;justify-content:space-between}.TimeContainer .Time button{font-size:var(--emw--font-size-x-small, 14px);height:20px;padding:0}.TimeContainer .Time button::before{inset:inherit;border:0}.TitleContainer{display:flex;justify-content:space-between;margin:10px 0;padding:0 20px;margin-top:0;gap:10px;font-family:Montserrat}.TitleContainer .GradientRoundedButton{width:120px}.TabsContainer{margin:10px 0;padding:0 20px;margin:0 20px;padding:0;border-bottom:1px solid #575757}.Tabs{display:flex;justify-content:space-between;justify-content:start;font-size:var(--emw--font-size-x-small, 14px);margin-bottom:-1px}.Tabs .Tab{text-transform:capitalize}.Tabs>div{padding:10px;color:rgb(102, 97, 120);cursor:pointer}.Tabs>div.active{color:var(--emw--color-typography, #FFF);border-bottom:2px solid var(--emw--color-typography, #FFF)}.Title{font-size:var(--emw--font-size-large, 20px);font-weight:700;line-height:19.5px;text-align:left;word-break:break-word}.TC{margin-top:14px}.TC a{color:rgb(89, 209, 255)}.Criterias{margin:14px 0}.Criterias span{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.ResultPrize{margin:10px 0;padding:0 20px;padding-left:30px;text-align:left}.ResultPrize span{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.InfoContainer{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.ContentScrollContainer{flex:1;display:flex;flex-direction:column;overflow-y:auto;position:relative;height:auto}.ContentScrollContainer.expanded{height:100%;max-height:100%}.PrizesContainer{flex:1;display:flex;flex-direction:column;min-height:100px;max-height:calc(100% - 20px)}.PrizesHeader,.DetailHeader{align-items:center;display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));padding:5px 0;z-index:1;margin:0 20px}.PrizesHeader img,.DetailHeader img{width:14px}.PrizesHeader .PrizesText,.DetailHeader .PrizesText{margin-left:3px;font-weight:600}.DetailHeader{margin:0}.Prizes{margin:10px 0;padding:0 20px;padding-left:30px;text-align:left;flex:1;overflow-y:auto;margin-bottom:0;padding-right:10px;max-height:300px;margin-top:10px}.Prizes::-webkit-scrollbar{width:4px}.Prizes::-webkit-scrollbar-track{background:rgba(0, 0, 0, 0.1);border-radius:2px}.Prizes::-webkit-scrollbar-thumb{background:var(--emw--color-primary, rgb(255, 214, 47));border-radius:2px}.Prizes .Prize{margin:8px 0}.Prizes .Prize .Rank{margin-right:5px}.Prizes .Prize .PrizeText{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.InfoContainer section.Info{margin-bottom:12px;text-align:left;padding-left:15px}.InfoContainer section.Info .Criterias,.InfoContainer section.Info .Description{padding-left:15px;margin-top:10px}*{box-sizing:border-box}.Leaderboards{width:100%;text-align:center;border-collapse:collapse}.Leaderboards td{opacity:0.6;padding:12px 5px}.Leaderboards td:first-child{padding-left:20px}.Leaderboards td:last-child{padding-right:20px}.Leaderboards .LeaderboardName{color:var(--emw--color-typography, #FFF);opacity:1}.Leaderboards tr.isMe{background:rgba(0, 0, 0, 0.2);border:1px solid var(--emw--color-primary, rgb(255, 214, 47))}.Leaderboards tr.isMe .LeaderboardRank span{padding:0px 3px;opacity:1;border:1px solid var(--emw--color-primary, rgb(255, 214, 47));border-radius:11px}.Leaderboards tr.isMe td{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:var(--emw--font-weight-semibold, 500)}.LeaderboardLabels{position:absolute;top:-6px;right:18px;display:flex;gap:4px}.LeaderboardLabel{width:30px;height:15px;background:var(--emw--engagement-suite-gradient-golden, linear-gradient(180deg, #FFB801 15.86%, #FEF746 31.36%, #FBFFE0 36.86%, #FFFA60 47.86%, #FF9400 87.36%));border-radius:var(--emw--border-radius-x-small, 2px);display:inline-flex;padding:0 2px;align-items:center;justify-content:center}.LeaderboardLabel span{display:inline-block;text-transform:uppercase;font-size:var(--emw--font-size-3x-small, 7px);line-height:7px;font-weight:var(--emw--font-weight-bold, 700);font-family:var(--emw--font-family-secondary, \"Montserrat\", sans-serif);color:var(--emw--color-background, #1E1638)}.LeaderboardUnstarted{margin:10px 0;padding:0 20px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-medium, 16px)}.Games{margin:10px 0;padding:0 20px;padding:0 20px;display:flex;flex-wrap:wrap;justify-content:start;margin:20px auto}.Games .Game{cursor:pointer;width:25%;display:flex;padding:5px}.Games .Game.Current{cursor:auto;filter:grayscale(10)}.Games .Game:hover{filter:brightness(var(--emw--hover-brightness, 1.25))}.Games .Game.Current:hover{cursor:auto;filter:grayscale(10)}.Games img{width:100%;height:fit-content}dialog.tip{position:absolute;align-items:start;padding:120px 90px;line-height:20px;font-size:var(--emw--font-size-small, 16px)}dialog.tip>div{margin:0px}dialog{display:none;position:fixed;left:0;top:0;width:100%;height:100%;background-color:rgba(0, 0, 0, 0.5);justify-content:center;align-items:center;z-index:1;color:var(--emw--color-typography, #FFFFFF);transition:all 0.2s;transition-timing-function:ease-in-out}dialog>div{margin:32px;border-radius:8px;background:var(--emw--color-background, hsl(254, 44%, 15%));border:1px solid hsl(254, 20%, 28%);align-items:center}dialog div.Hollow .WrapperBar{padding:12px}dialog div.Hollow .WrapperBar .WrapperBarRight img{width:20px}dialog div.Hollow .Tip{line-height:20px;padding:0px 60px 32px;font-size:var(--emw--font-size-small, 16px)}dialog[open]{display:flex}.DialogContentUnjoin{padding:32px;padding-top:10px;display:flex;gap:10px;max-width:510px;flex-direction:column}.DialogContentUnjoinTitle{font-family:Montserrat;font-size:var(--emw--font-size-large, 20px);font-weight:600;line-height:24.38px;text-align:center}.DialogContentUnjoinDescription{color:var(--emw--color-secondary, rgb(187, 185, 195));margin-bottom:30px}.Tip{padding:32px;padding-top:0px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-small, 14px)}.Tip.Error{color:var(--emw--color-error, var(--emw--color-red, #ed0909));font-weight:var(--emw--font-weight-normal, 500)}.PageConfirmContainer{text-align:center;width:80%;min-width:450px;max-width:510px;margin:0 auto}.PageConfirm{padding:0px 32px 60px;display:flex;flex-direction:column;gap:20px}.PageConfirm .Title{font-size:var(--emw--font-size-large, 26px);text-align:center}.PageConfirm .Description{color:var(--emw--color-secondary, rgb(187, 185, 195));font-weight:400}.PageConfirm .Description span{color:var(--emw--color-typography, #FFF);font-weight:600}.PageConfirm.Gift{padding:22px 32px 60px}.PageConfirm.Gift .Title{font-size:var(--emw--font-size-large, 30px)}.PageConfirm.Gift .Description{font-size:var(--emw--font-size-medium, 20px)}.PageConfirm.Gift .PageConfirmButtonsGroup .GradientRoundedButton{font-size:var(--emw--font-size-medium, 20px);padding:12px;height:auto}.PageConfirm.Gift .PageConfirmButtonsGroup .GradientRoundedButton.GradientRounded{border-radius:20px}.PageConfirmButtonsGroup{width:150px;margin:20px auto;display:flex;flex-direction:column;gap:10px}.GradientRounded{display:block;background:linear-gradient(98.25deg, #FF9400 22.48%, #FEF746 131.02%, #FFE24A 131.9%);color:rgb(30, 22, 56);position:relative;border-radius:16px}.GradientRounded.Hollow{background:rgb(30, 22, 56);color:#FFFFFF}.GradientRounded.Hollow::before{content:\"\";position:absolute;inset:0;border-radius:15px;border:1px solid transparent;background:linear-gradient(98.25deg, #FF9400 22.48%, #FEF746 131.02%, #FFE24A 131.9%) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude}.GradientRoundedButton{border:none;padding:7px;height:32px;width:100%;font-size:var(--emw--font-size-medium, 16px);font-weight:700;line-height:17.07px;text-align:center;transition:0.5s opacity;cursor:pointer}.GradientRoundedButton.Pending{cursor:not-allowed;opacity:0.3}.GradientRoundedButton.Hollow span{background:-webkit-linear-gradient(98.25deg, rgb(255, 148, 0) 22.48%, rgb(254, 247, 70) 131.02%, rgb(255, 226, 74) 131.9%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.LeaderboardsItem.GradientRounded.Hollow::before{border-radius:7px}.WrapperUtil .GradientRounded .WrapperBar{margin-bottom:0;padding-bottom:0}.WrapperUtil .GradientRounded .Tip{padding-top:0;padding-bottom:40px}.LeaderboardsItem .LeaderboardsItemContainer .TitleContainer{margin-bottom:16px}@keyframes slideOut{0%{display:block;opacity:1;height:max-content}50%{display:block;opacity:0.5}80%{display:none;opacity:0}100%{display:none;opacity:0;height:0}}";
|
|
621
777
|
const CasinoEngagementSuiteTournamentStyle0 = casinoEngagementSuiteTournamentCss;
|
|
622
778
|
|
|
623
779
|
const CasinoEngagementSuiteTournament = class {
|
|
@@ -688,7 +844,14 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
688
844
|
}, 300);
|
|
689
845
|
}
|
|
690
846
|
};
|
|
691
|
-
|
|
847
|
+
if (this.show) {
|
|
848
|
+
this.openDialog(exports.DialogType.gift, this.gifts[0], onClose);
|
|
849
|
+
}
|
|
850
|
+
else {
|
|
851
|
+
//Show 'Win' Label on the left ui-bar,
|
|
852
|
+
this.labels.push('win');
|
|
853
|
+
messageSender.UpdateSuiteBarState(this.labels);
|
|
854
|
+
}
|
|
692
855
|
}
|
|
693
856
|
else {
|
|
694
857
|
this.removeLabel('win');
|
|
@@ -705,9 +868,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
705
868
|
this.showTooltip = false;
|
|
706
869
|
}
|
|
707
870
|
componentDidLoad() {
|
|
708
|
-
this.pageElement.addEventListener('scroll', (event) => {
|
|
709
|
-
this.containerScrollTop = event.target.scrollTop + event.target.clientHeight / 2 - 250;
|
|
710
|
-
});
|
|
711
871
|
messageSender.UpdateTournamentsPageIsReady();
|
|
712
872
|
}
|
|
713
873
|
renderTooltip() {
|
|
@@ -728,7 +888,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
728
888
|
}
|
|
729
889
|
componentDidRender() {
|
|
730
890
|
if (this.page === exports.LeaderboardPage.item && this.tab === Tab.leaderboard) {
|
|
731
|
-
if (this.
|
|
891
|
+
if (this.currentPlayerRank > this.defaultPageSize && !this.scrolledToMyLine) {
|
|
732
892
|
this.scrollToMyRankLine();
|
|
733
893
|
}
|
|
734
894
|
}
|
|
@@ -746,6 +906,11 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
746
906
|
if (tournament.isActionJoinPending)
|
|
747
907
|
return;
|
|
748
908
|
tournament.isActionJoinPending = true;
|
|
909
|
+
//Disable the unjoin button when action in detail page
|
|
910
|
+
if (this.page === exports.LeaderboardPage.item) {
|
|
911
|
+
this.tournamentItem.isActionJoinPending = true;
|
|
912
|
+
this.tournamentItem = Object.assign({}, this.tournamentItem);
|
|
913
|
+
}
|
|
749
914
|
this.pendingChangeEvent.emit(tournament);
|
|
750
915
|
try {
|
|
751
916
|
if (tournament.isPlayerAcknowledged) {
|
|
@@ -767,7 +932,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
767
932
|
if (!this.tournamentItem) {
|
|
768
933
|
messageSender.UpdateTournamentsItemReq(metaData.tournament);
|
|
769
934
|
}
|
|
770
|
-
if (
|
|
935
|
+
if (isTournamentEnded(this.tournamentItem)) {
|
|
771
936
|
messageSender.UpdateLeaderboardsReq(this.tournamentItem);
|
|
772
937
|
}
|
|
773
938
|
this.tab = Tab.info;
|
|
@@ -789,21 +954,27 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
789
954
|
};
|
|
790
955
|
return (index.h(index.Host, null, index.h("general-styling-wrapper", { clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
|
|
791
956
|
// @ts-ignore
|
|
792
|
-
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), index.h("div", { class: `Wrapper ${this.device}` }, index.h("div", { class: classnames('WrapperContent', { faded: this.dialog.isOpen }) }, renderCloseBar({
|
|
957
|
+
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), index.h("div", { class: `Wrapper ${this.device} ${this.orientation}` }, index.h("div", { class: classnames('WrapperContent', { faded: this.dialog.isOpen, page: this.page }) }, this.page && renderCloseBar({
|
|
793
958
|
left: this.page === exports.LeaderboardPage.list
|
|
794
|
-
? index.h("span", { onClick: this.openDialog.bind(this, exports.DialogType.tip) }, iconQuestion)
|
|
795
|
-
: index.h("span", { onClick: this.setPage.bind(this, exports.LeaderboardPage.list) }, iconBack),
|
|
959
|
+
? index.h("span", { class: 'EngagementSuiteIcon', onClick: this.openDialog.bind(this, exports.DialogType.tip) }, iconQuestion)
|
|
960
|
+
: index.h("span", { class: 'EngagementSuiteIcon', onClick: this.setPage.bind(this, exports.LeaderboardPage.list) }, iconBack),
|
|
796
961
|
middle: this.locale.Leaderboards,
|
|
797
|
-
right: index.h("span", { onClick: () => this.close.emit() }, iconClose)
|
|
962
|
+
right: index.h("span", { class: 'EngagementSuiteIcon', onClick: () => this.close.emit() }, iconClose)
|
|
798
963
|
}), index.h("div", { class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), this.page === exports.LeaderboardPage.item &&
|
|
799
|
-
index.h("div", { class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())), index.h("div", { class: "WrapperUtil" }, index.h("dialog", {
|
|
800
|
-
right: index.h("span", { onClick: () => this.closeDialog() }, iconClose)
|
|
964
|
+
index.h("div", { class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())), index.h("div", { class: "WrapperUtil" }, index.h("dialog", { class: `${this.dialog.type}`, open: this.dialog.isOpen }, index.h("div", { class: `Hollow ${this.dialog.type === 'gift' ? 'GradientRounded' : ''}` }, renderCloseBar({
|
|
965
|
+
right: index.h("span", { class: 'EngagementSuiteIcon', onClick: () => this.closeDialog() }, iconClose)
|
|
801
966
|
}), this.dialog.isOpen && renderDialogContent()))))));
|
|
802
967
|
}
|
|
803
968
|
openDialog(type, data = undefined, onClose = undefined) {
|
|
804
969
|
this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: true, onClose,
|
|
805
970
|
type,
|
|
806
971
|
data });
|
|
972
|
+
if (type === exports.DialogType.error || type === exports.DialogType.tip) {
|
|
973
|
+
const timerId = setTimeout(() => {
|
|
974
|
+
this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: false });
|
|
975
|
+
clearInterval(timerId);
|
|
976
|
+
}, this.tipsHideDelay);
|
|
977
|
+
}
|
|
807
978
|
}
|
|
808
979
|
closeDialog() {
|
|
809
980
|
var _a;
|
|
@@ -815,10 +986,14 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
815
986
|
this.close = index.createEvent(this, "close", 7);
|
|
816
987
|
this.tournamentTimer = index.createEvent(this, "tournamentTimer", 7);
|
|
817
988
|
this.pendingChangeEvent = index.createEvent(this, "pendingChangeEvent", 7);
|
|
989
|
+
/**
|
|
990
|
+
* Use to move the new acknowleged tournament to top
|
|
991
|
+
*/
|
|
992
|
+
this.minOrder = -1;
|
|
818
993
|
this.gifts = [];
|
|
819
994
|
this.labels = [];
|
|
820
995
|
this.showTooltip = false;
|
|
821
|
-
this.
|
|
996
|
+
this.defaultPageSize = DEFAULT_PAGE_SIZE;
|
|
822
997
|
this.scrolledToMyLine = false;
|
|
823
998
|
this.language = 'en';
|
|
824
999
|
this.show = false;
|
|
@@ -826,7 +1001,9 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
826
1001
|
this.clientStylingUrl = '';
|
|
827
1002
|
this.translationUrl = '';
|
|
828
1003
|
this.device = 'Mobile';
|
|
1004
|
+
this.orientation = 'Landscape';
|
|
829
1005
|
this.leaderboardsInit = undefined;
|
|
1006
|
+
this.tipsHideDelay = 3 * 1000;
|
|
830
1007
|
this.tab = Tab.info;
|
|
831
1008
|
this.locale = TRANSLATIONS;
|
|
832
1009
|
this.tournamentItem = undefined;
|
|
@@ -866,5 +1043,5 @@ exports.classnames = classnames;
|
|
|
866
1043
|
exports.formatDate = formatDate;
|
|
867
1044
|
exports.getProgress = getProgress;
|
|
868
1045
|
exports.getTimeDifference = getTimeDifference;
|
|
869
|
-
exports.
|
|
1046
|
+
exports.isTournamentEnded = isTournamentEnded;
|
|
870
1047
|
exports.renderGradientRoundedButton = renderGradientRoundedButton;
|