@everymatrix/casino-engagement-suite-tournament 1.62.2 → 1.62.3
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-14ab3c1a.entry.js +1 -0
- package/dist/casino-engagement-suite-tournament/p-5f051654.js +15 -0
- package/dist/casino-engagement-suite-tournament/{p-bfca9e2a.js → p-c6fe0205.js} +1 -1
- package/dist/cjs/{casino-engagement-suite-progress-bar_3.cjs.entry.js → casino-engagement-suite-progress-bar_6.cjs.entry.js} +124 -2
- package/dist/cjs/{casino-engagement-suite-tournament-bc4edfdf.js → casino-engagement-suite-tournament-1f1275c4.js} +179 -242
- package/dist/cjs/casino-engagement-suite-tournament.cjs.js +2 -2
- package/dist/cjs/{index-982cd594.js → index-5e98dd13.js} +4 -3
- package/dist/cjs/index.cjs.js +2 -2
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/collection/assets/help.svg +10 -0
- package/dist/collection/collection-manifest.json +4 -1
- package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.css +30 -3
- package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.js +89 -34
- package/dist/collection/shared/TournamentDurationTimer.js +92 -0
- package/dist/collection/shared/TournamentItem.js +114 -0
- package/dist/collection/shared/TournamentItemTitle.js +124 -0
- package/dist/collection/shared/icons.js +2 -1
- package/dist/collection/shared/renderBar.js +2 -2
- package/dist/collection/shared/renders.page.js +6 -79
- package/dist/collection/shared/renders.tab.js +2 -2
- package/dist/collection/utils/api.apdater.js +8 -0
- package/dist/collection/utils/bussiness.js +0 -25
- package/dist/collection/utils/message.js +27 -19
- package/dist/collection/utils/util.date.js +3 -0
- package/dist/esm/{casino-engagement-suite-progress-bar_3.entry.js → casino-engagement-suite-progress-bar_6.entry.js} +123 -3
- package/dist/esm/{casino-engagement-suite-tournament-bc5e0906.js → casino-engagement-suite-tournament-54c513f1.js} +162 -231
- package/dist/esm/casino-engagement-suite-tournament.js +3 -3
- package/dist/esm/{index-ac437a77.js → index-8b5c4b95.js} +4 -3
- package/dist/esm/index.js +2 -2
- package/dist/esm/loader.js +3 -3
- package/dist/types/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.d.ts +8 -10
- package/dist/types/components.d.ts +85 -2
- package/dist/types/shared/TournamentDurationTimer.d.ts +15 -0
- package/dist/types/shared/TournamentItem.d.ts +46 -0
- package/dist/types/shared/TournamentItemTitle.d.ts +47 -0
- package/dist/types/utils/bussiness.d.ts +1 -45
- package/dist/types/utils/message.d.ts +2 -2
- package/dist/types/utils/util.date.d.ts +1 -1
- package/package.json +1 -1
- package/dist/casino-engagement-suite-tournament/p-67373ab1.entry.js +0 -1
- package/dist/casino-engagement-suite-tournament/p-b217e7cc.js +0 -15
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
const index = require('./index-
|
|
3
|
+
const index = require('./index-5e98dd13.js');
|
|
4
4
|
|
|
5
5
|
/*! *****************************************************************************
|
|
6
6
|
Copyright (c) Microsoft Corporation.
|
|
@@ -107,53 +107,26 @@ const truncateNumber = (value, decimals, isInteger = false) => {
|
|
|
107
107
|
// Return string representation with fixed decimals to preserve trailing zeros
|
|
108
108
|
return truncated.toFixed(decimals);
|
|
109
109
|
};
|
|
110
|
-
const getDevice = () => {
|
|
111
|
-
let userAgent = window.navigator.userAgent;
|
|
112
|
-
if (userAgent.toLowerCase().match(/android/i)) {
|
|
113
|
-
return 'Android';
|
|
114
|
-
}
|
|
115
|
-
if (userAgent.toLowerCase().match(/iphone/i)) {
|
|
116
|
-
return 'iPhone';
|
|
117
|
-
}
|
|
118
|
-
if (userAgent.toLowerCase().match(/ipad|ipod/i)) {
|
|
119
|
-
return 'iPad';
|
|
120
|
-
}
|
|
121
|
-
return 'PC';
|
|
122
|
-
};
|
|
123
|
-
const getDevicePlatform = () => {
|
|
124
|
-
const device = getDevice();
|
|
125
|
-
if (device) {
|
|
126
|
-
if (device === 'PC') {
|
|
127
|
-
return 'dk';
|
|
128
|
-
}
|
|
129
|
-
else if (device === 'iPad' || device === 'iPhone') {
|
|
130
|
-
return 'ios';
|
|
131
|
-
}
|
|
132
|
-
else {
|
|
133
|
-
return 'mtWeb';
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
};
|
|
137
110
|
|
|
138
|
-
|
|
111
|
+
exports.LeaderboardPage = void 0;
|
|
139
112
|
(function (LeaderboardPage) {
|
|
140
113
|
LeaderboardPage["list"] = "list";
|
|
141
114
|
LeaderboardPage["item"] = "item";
|
|
142
|
-
})(LeaderboardPage || (LeaderboardPage = {}));
|
|
143
|
-
|
|
115
|
+
})(exports.LeaderboardPage || (exports.LeaderboardPage = {}));
|
|
116
|
+
exports.TournamentState = void 0;
|
|
144
117
|
(function (TournamentState) {
|
|
145
118
|
TournamentState["Running"] = "Running";
|
|
146
119
|
TournamentState["Unstarted"] = "Unstarted";
|
|
147
120
|
TournamentState["Closed"] = "Closed";
|
|
148
121
|
TournamentState["Closing"] = "Closing";
|
|
149
|
-
})(TournamentState || (TournamentState = {}));
|
|
150
|
-
|
|
122
|
+
})(exports.TournamentState || (exports.TournamentState = {}));
|
|
123
|
+
exports.DialogType = void 0;
|
|
151
124
|
(function (DialogType) {
|
|
152
125
|
DialogType["unjoin"] = "unjoin";
|
|
153
126
|
DialogType["tip"] = "tip";
|
|
154
127
|
DialogType["gift"] = "gift";
|
|
155
128
|
DialogType["error"] = "error";
|
|
156
|
-
})(DialogType || (DialogType = {}));
|
|
129
|
+
})(exports.DialogType || (exports.DialogType = {}));
|
|
157
130
|
|
|
158
131
|
const getMaxRankStr = (list) => {
|
|
159
132
|
let itemHaveMaxRank;
|
|
@@ -180,13 +153,15 @@ const getMaxRankStr = (list) => {
|
|
|
180
153
|
return maxRankStr;
|
|
181
154
|
};
|
|
182
155
|
const isTournamentClosed = (tournament) => {
|
|
183
|
-
return [TournamentState.Closed, TournamentState.Closing].includes(tournament.state);
|
|
156
|
+
return [exports.TournamentState.Closed, exports.TournamentState.Closing].includes(tournament.state);
|
|
184
157
|
};
|
|
185
158
|
|
|
186
159
|
const rewardSvg = '';
|
|
187
160
|
|
|
161
|
+
const helpSvg = '';
|
|
162
|
+
|
|
188
163
|
const iconClose = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/close.svg" });
|
|
189
|
-
const iconQuestion = index.h("img", { src: "
|
|
164
|
+
const iconQuestion = index.h("img", { src: helpSvg, alt: "question", class: "Question" });
|
|
190
165
|
const iconEyeOpen = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-open.svg" });
|
|
191
166
|
const iconEyeClose = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-closed.svg" });
|
|
192
167
|
const iconBack = index.h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/back.svg" });
|
|
@@ -284,6 +259,14 @@ const leaderboardsAdapter = (leaderboardRes) => {
|
|
|
284
259
|
if (!item) {
|
|
285
260
|
return leaderboards;
|
|
286
261
|
}
|
|
262
|
+
// show current player's rank info at first row if there is no player info in list
|
|
263
|
+
const playerRankIndex = leaderboards.findIndex((leaderboard) => {
|
|
264
|
+
return leaderboard.userId === item.userId;
|
|
265
|
+
});
|
|
266
|
+
playerRankIndex === -1 ? leaderboards = [
|
|
267
|
+
item,
|
|
268
|
+
...leaderboards,
|
|
269
|
+
] : {};
|
|
287
270
|
return leaderboards.map((leaderboard) => {
|
|
288
271
|
if ((item === null || item === void 0 ? void 0 : item.userId) && item.userId === leaderboard.userId) {
|
|
289
272
|
return Object.assign(Object.assign({}, leaderboard), { isMe: true });
|
|
@@ -294,80 +277,16 @@ const leaderboardsAdapter = (leaderboardRes) => {
|
|
|
294
277
|
});
|
|
295
278
|
};
|
|
296
279
|
|
|
297
|
-
const renderCloseBar = (attr) => {
|
|
298
|
-
const { left, middle, right } = attr;
|
|
299
|
-
const slots = {
|
|
300
|
-
left,
|
|
301
|
-
middle,
|
|
302
|
-
right,
|
|
303
|
-
};
|
|
304
|
-
const getFirstLetterUppercase = (str) => str
|
|
305
|
-
.split('')
|
|
306
|
-
.map((letter, index) => index === 0 ? letter.toUpperCase() : letter)
|
|
307
|
-
.join('');
|
|
308
|
-
return (index.h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (index.h("div", { class: "WrapperBar" + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
|
|
309
|
-
};
|
|
310
|
-
|
|
311
|
-
function formatDate(date) {
|
|
312
|
-
const options = {
|
|
313
|
-
year: 'numeric',
|
|
314
|
-
month: 'long',
|
|
315
|
-
day: 'numeric',
|
|
316
|
-
hour: '2-digit',
|
|
317
|
-
minute: '2-digit',
|
|
318
|
-
hour12: false
|
|
319
|
-
};
|
|
320
|
-
return date.toLocaleDateString('en-US', options).replace(' at', ',');
|
|
321
|
-
}
|
|
322
|
-
function getProgress(startDate, endDate) {
|
|
323
|
-
return ((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime())).toFixed(0);
|
|
324
|
-
}
|
|
325
|
-
function getTimeDifference(startDate, endDate) {
|
|
326
|
-
const diffMs = Math.abs(endDate.getTime() - startDate.getTime()); // Difference in milliseconds
|
|
327
|
-
const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24)); // Difference in days
|
|
328
|
-
const diffHours = Math.floor((diffMs % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // Remaining hours
|
|
329
|
-
const diffMinutes = Math.floor((diffMs % (1000 * 60 * 60)) / (1000 * 60)); // Remaining minutes
|
|
330
|
-
return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(diffMinutes).padStart(2, '0')}m`;
|
|
331
|
-
}
|
|
332
|
-
|
|
333
|
-
const renderTimeBar = (tournament) => {
|
|
334
|
-
return (index.h("section", { class: "TimeContainer" },
|
|
335
|
-
index.h("div", { class: "Time" }, tournament.state === 'Running'
|
|
336
|
-
? [
|
|
337
|
-
index.h("div", { class: 'Running' },
|
|
338
|
-
index.h("div", null, getTimeDifference(new Date(), tournament.endTime)),
|
|
339
|
-
",",
|
|
340
|
-
index.h("div", null, renderGradientRoundedButton({
|
|
341
|
-
statedClasses: {
|
|
342
|
-
isHollow: true,
|
|
343
|
-
isPendding: false
|
|
344
|
-
},
|
|
345
|
-
innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
|
|
346
|
-
})))
|
|
347
|
-
]
|
|
348
|
-
: [index.h("div", { class: 'NotRunning' }, formatDate(tournament.startTime)), index.h("div", null, formatDate(tournament.endTime))]),
|
|
349
|
-
index.h("casino-engagement-suite-progress-bar", { value: Number(getProgress(tournament.startTime, tournament.endTime)), "hide-percent": true })));
|
|
350
|
-
};
|
|
351
|
-
|
|
352
280
|
const messageSender = {
|
|
353
|
-
InitTournamentList: (queryParams) => {
|
|
354
|
-
window.postMessage(Object.assign({ type: 'InitTournamentList' }, queryParams));
|
|
355
|
-
},
|
|
356
|
-
post: (options) => {
|
|
357
|
-
window.postMessage(Object.assign({}, options));
|
|
358
|
-
},
|
|
359
281
|
UpdateSuiteBarState: (labels) => window.postMessage({ type: 'UpdateLeaderboardState', labels }),
|
|
360
|
-
JoinTournamentReq: (tournament) => {
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
id: tournament.id,
|
|
365
|
-
bonusCode: tournament.id || ((_b = (_a = tournament.wallets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.code)
|
|
366
|
-
});
|
|
367
|
-
},
|
|
282
|
+
JoinTournamentReq: (tournament) => window.postMessage({
|
|
283
|
+
type: 'JoinTournamentReq',
|
|
284
|
+
id: tournament.id,
|
|
285
|
+
}),
|
|
368
286
|
UnjoinTournamentReq: (tournament) => window.postMessage({ type: 'UnjoinTournamentReq', id: tournament.id }),
|
|
369
287
|
UpdateTournamentsItemReq: (tournament) => window.postMessage({ type: 'UpdateTournamentsItemReq', id: tournament.id }),
|
|
370
288
|
UpdateLeaderboardsReq: (tournament, query) => window.postMessage({ type: 'UpdateLeaderboardsReq', id: tournament.id, query }),
|
|
289
|
+
UpdateTournamentsPageIsReady: () => window.postMessage({ type: 'TournamentsPageIsReady' }),
|
|
371
290
|
UpdateLeaderboardsPlayerReq: () => window.postMessage({ type: 'UpdateLeaderboardsPlayerReq' }),
|
|
372
291
|
GameClickReq: (game) => window.postMessage({ type: 'EngagementSuiteGameRedirect', data: { Slug: game.slug } }),
|
|
373
292
|
};
|
|
@@ -388,6 +307,7 @@ const messageReceiver = (instance) => {
|
|
|
388
307
|
UpdateLeaderboardsRes: (rest) => processLeaderboardTableData(instance, rest),
|
|
389
308
|
JoinTournamentRes: (rest) => commonJoinRes(instance, rest),
|
|
390
309
|
UnjoinTournamentRes: (rest) => commonJoinRes(instance, rest),
|
|
310
|
+
TournamentsPageIsReadyRes: (rest) => instance.currentGameId = rest.data.GameId,
|
|
391
311
|
// listen to LeaderboardLiveEvent event, handle update
|
|
392
312
|
LeaderboardLiveEvent: (rest) => {
|
|
393
313
|
handleLeaderboardLiveEvent(instance, rest);
|
|
@@ -475,16 +395,28 @@ const showErrorMessage = (instance, type) => {
|
|
|
475
395
|
const commonJoinRes = (instance, rest) => {
|
|
476
396
|
const { success, data } = rest;
|
|
477
397
|
let tournamentIdx = instance.tournamentList.findIndex((tournament) => tournament.id === (data.tournamentId || data.id || data.bonusCode)), current = instance.tournamentList[tournamentIdx];
|
|
478
|
-
|
|
398
|
+
if (tournamentIdx == -1) {
|
|
399
|
+
return;
|
|
400
|
+
}
|
|
401
|
+
current = Object.assign(Object.assign({}, current), { isActionJoinPending: false });
|
|
479
402
|
if (!success) {
|
|
480
403
|
instance.tournamentList[tournamentIdx] = current;
|
|
481
404
|
instance.tournamentList = [...instance.tournamentList];
|
|
482
|
-
showErrorMessage(instance, DialogType.error);
|
|
405
|
+
showErrorMessage(instance, exports.DialogType.error);
|
|
483
406
|
return;
|
|
484
407
|
}
|
|
485
408
|
current = Object.assign(Object.assign({}, current), { isUnjoined: current.isPlayerAcknowledged ? true : false, isPlayerAcknowledged: !!!current.isPlayerAcknowledged });
|
|
486
409
|
instance.tournamentList[tournamentIdx] = current;
|
|
487
410
|
instance.tournamentList = [...instance.tournamentList];
|
|
411
|
+
if (instance.page === exports.LeaderboardPage.item) {
|
|
412
|
+
if (current.isUnjoined) {
|
|
413
|
+
instance.setPage(exports.LeaderboardPage.list);
|
|
414
|
+
return;
|
|
415
|
+
}
|
|
416
|
+
else {
|
|
417
|
+
instance.tournamentItem = Object.assign({}, current);
|
|
418
|
+
}
|
|
419
|
+
}
|
|
488
420
|
if (instance.nextPage) {
|
|
489
421
|
instance.setPage(instance.nextPage);
|
|
490
422
|
instance.nextPage = undefined;
|
|
@@ -509,11 +441,15 @@ const removeTournament = (instance, tournament) => {
|
|
|
509
441
|
};
|
|
510
442
|
const updateOrAddTournamentToList = (instance, tournament) => {
|
|
511
443
|
const index = instance.tournamentList.findIndex((_tournament) => _tournament.id === tournament.id);
|
|
512
|
-
if (index
|
|
513
|
-
instance.tournamentList
|
|
444
|
+
if (index === -1) {
|
|
445
|
+
instance.tournamentList = [
|
|
446
|
+
tournamentAdapter(tournament),
|
|
447
|
+
...instance.tournamentList
|
|
448
|
+
];
|
|
514
449
|
}
|
|
515
450
|
else {
|
|
516
|
-
instance.tournamentList =
|
|
451
|
+
instance.tournamentList[index] = tournamentAdapter(tournament);
|
|
452
|
+
instance.tournamentList = [...instance.tournamentList];
|
|
517
453
|
}
|
|
518
454
|
};
|
|
519
455
|
|
|
@@ -526,21 +462,12 @@ const page = {
|
|
|
526
462
|
}
|
|
527
463
|
const { locale } = instance;
|
|
528
464
|
if (instance.tournamentList.length) {
|
|
529
|
-
|
|
530
|
-
instance.setPage(LeaderboardPage.item, { tournament });
|
|
531
|
-
instance.newIdList = instance.newIdList.filter((id) => id !== tournament.id);
|
|
532
|
-
};
|
|
533
|
-
return renderLeaderboardContainer(instance, index.h("div", { class: 'Leaderboards Row' }, instance.tournamentList.map((_tournament) => (index.h("div", { class: classnames('LeaderboardsItem', _tournament.isPlayerAcknowledged ? ' GradientRounded Hollow' : '', _tournament.isUnjoined ? 'Unjoined' : ''), onClick: () => onClickListItemChangePage(_tournament) },
|
|
534
|
-
index.h("div", { class: "LeaderboardsItemContainer" },
|
|
535
|
-
renderTitleContainer(instance, _tournament),
|
|
536
|
-
renderTimeBar(_tournament)),
|
|
537
|
-
index.h("div", { class: "LeaderboardLabels" }, instance.newIdList.includes(_tournament.id) && (index.h("div", { class: "LeaderboardLabel" },
|
|
538
|
-
index.h("span", null, "new")))))))));
|
|
465
|
+
return renderWrapperByPageType(index.h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament) => (index.h("casino-engagement-suite-tournament-item", { tournament: _tournament, isNew: instance.newIdList.includes(_tournament.id) })))));
|
|
539
466
|
}
|
|
540
467
|
else {
|
|
541
|
-
return
|
|
542
|
-
index.h("h3", { class:
|
|
543
|
-
index.h("div", { class:
|
|
468
|
+
return renderWrapperByPageType(index.h("div", { class: "NoLeaderboards ScrollBar Row" },
|
|
469
|
+
index.h("h3", { class: "Title" }, locale.NoLeaderboards),
|
|
470
|
+
index.h("div", { class: "message" }, locale.NoLeaderboardsTip)));
|
|
544
471
|
}
|
|
545
472
|
},
|
|
546
473
|
item(instance) {
|
|
@@ -564,92 +491,60 @@ const page = {
|
|
|
564
491
|
index.h("div", { class: "Tabs" }, Object.keys(Tab).map((_tab) => (index.h("div", { class: classnames({ active: tab === _tab }),
|
|
565
492
|
onClick: () => onClickTab(_tab) }, locale[_tab]))))));
|
|
566
493
|
};
|
|
567
|
-
return
|
|
568
|
-
|
|
494
|
+
return renderWrapperByPageType([
|
|
495
|
+
index.h("casino-engagement-suite-tournament-item-title", { tournament: instance.tournamentItem }),
|
|
569
496
|
renderTabs(),
|
|
570
497
|
index.h("div", { class: `TableContentWrapper ${instance.tab}` }, instance.renders.tab[instance.tab]())
|
|
571
498
|
]);
|
|
572
499
|
}
|
|
573
500
|
};
|
|
574
|
-
const
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
if (tournament.isPlayerAcknowledged) {
|
|
578
|
-
instance.openDialog(DialogType.unjoin, tournament);
|
|
579
|
-
}
|
|
580
|
-
else {
|
|
581
|
-
instance.actionJoin(tournament);
|
|
582
|
-
instance.tournamentItem = tournament;
|
|
583
|
-
}
|
|
584
|
-
};
|
|
585
|
-
return (index.h("div", { class: "TitleContainer" },
|
|
586
|
-
index.h("div", { class: "Title" }, tournament.nameOrTitle),
|
|
587
|
-
tournament.state !== TournamentState.Closed && (index.h("div", null, renderGradientRoundedButton({
|
|
588
|
-
statedClasses: {
|
|
589
|
-
isHollow: tournament.isPlayerAcknowledged,
|
|
590
|
-
isPending: tournament.isActionJoinPending
|
|
591
|
-
},
|
|
592
|
-
onClick: (e) => {
|
|
593
|
-
e.stopPropagation();
|
|
594
|
-
if (!tournament.isActionJoinPending) {
|
|
595
|
-
onClickItemJoin(tournament);
|
|
596
|
-
}
|
|
597
|
-
},
|
|
598
|
-
innerHTML: tournament.isPlayerAcknowledged ? locale.Unjoin : locale.Join
|
|
599
|
-
})))));
|
|
501
|
+
const renderWrapperByPageType = (render) => {
|
|
502
|
+
return (index.h("div", { class: "Root" },
|
|
503
|
+
index.h("div", { class: "Main" }, render)));
|
|
600
504
|
};
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
const
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
case DialogType.tip:
|
|
611
|
-
return index.h("div", { class: "Tip" }, instance.locale.Tip);
|
|
612
|
-
case DialogType.error:
|
|
613
|
-
return index.h("div", { class: "Tip Error" }, instance.locale.FailedToJoin);
|
|
614
|
-
case DialogType.gift:
|
|
615
|
-
return instance.renders.dialog.gift();
|
|
616
|
-
}
|
|
617
|
-
};
|
|
618
|
-
const getWrapperBarData = () => {
|
|
619
|
-
const { page, locale } = instance;
|
|
620
|
-
switch (page) {
|
|
621
|
-
case LeaderboardPage.list:
|
|
622
|
-
return {
|
|
623
|
-
left: index.h("span", { onClick: () => instance.openDialog(DialogType.tip), onMouseEnter: () => { instance.showTooltip = true; }, onMouseLeave: () => { instance.showTooltip = false; }, ref: (el) => instance.tooltipIconReference = el },
|
|
624
|
-
iconQuestion,
|
|
625
|
-
instance.renderTooltip()),
|
|
626
|
-
middle: locale.Leaderboards
|
|
627
|
-
};
|
|
628
|
-
case LeaderboardPage.item:
|
|
629
|
-
return {
|
|
630
|
-
left: index.h("span", { onClick: () => instance.setPage(LeaderboardPage.list) }, iconBack),
|
|
631
|
-
middle: locale.Leaderboards
|
|
632
|
-
};
|
|
633
|
-
}
|
|
634
|
-
};
|
|
635
|
-
const renderCloseBarInLayout = () => {
|
|
636
|
-
const { left, middle } = getWrapperBarData();
|
|
637
|
-
return renderCloseBar({
|
|
638
|
-
left,
|
|
639
|
-
middle,
|
|
640
|
-
right: index.h("span", { onClick: () => instance.close.emit() }, iconClose)
|
|
641
|
-
});
|
|
505
|
+
|
|
506
|
+
function formatDate(date) {
|
|
507
|
+
const options = {
|
|
508
|
+
year: 'numeric',
|
|
509
|
+
month: 'long',
|
|
510
|
+
day: 'numeric',
|
|
511
|
+
hour: '2-digit',
|
|
512
|
+
minute: '2-digit',
|
|
513
|
+
hour12: false
|
|
642
514
|
};
|
|
643
|
-
return
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
515
|
+
return date.toLocaleDateString('en-US', options).replace(' at', ',');
|
|
516
|
+
}
|
|
517
|
+
function getProgress(startDate, endDate) {
|
|
518
|
+
if (new Date().getTime() >= endDate.getTime()) {
|
|
519
|
+
return 100;
|
|
520
|
+
}
|
|
521
|
+
return ((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime())).toFixed(0);
|
|
522
|
+
}
|
|
523
|
+
function getTimeDifference(startDate, endDate) {
|
|
524
|
+
const diffMs = Math.abs(endDate.getTime() - startDate.getTime()); // Difference in milliseconds
|
|
525
|
+
const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24)); // Difference in days
|
|
526
|
+
const diffHours = Math.floor((diffMs % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // Remaining hours
|
|
527
|
+
const diffMinutes = Math.floor((diffMs % (1000 * 60 * 60)) / (1000 * 60)); // Remaining minutes
|
|
528
|
+
return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(diffMinutes).padStart(2, '0')}m`;
|
|
529
|
+
}
|
|
530
|
+
|
|
531
|
+
const renderTimeBar = (tournament) => {
|
|
532
|
+
return (index.h("section", { class: "TimeContainer" },
|
|
533
|
+
index.h("div", { class: "Time" }, tournament.state === 'Running'
|
|
534
|
+
? [
|
|
535
|
+
index.h("div", { class: 'Running' },
|
|
536
|
+
index.h("div", null, getTimeDifference(new Date(), tournament.endTime)),
|
|
537
|
+
",",
|
|
538
|
+
index.h("div", null, renderGradientRoundedButton({
|
|
539
|
+
statedClasses: {
|
|
540
|
+
isHollow: true,
|
|
541
|
+
isPendding: false
|
|
542
|
+
},
|
|
543
|
+
innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
|
|
544
|
+
})))
|
|
545
|
+
]
|
|
546
|
+
: [index.h("div", { class: 'NotRunning' }, formatDate(tournament.startTime)), index.h("div", null, formatDate(tournament.endTime))]),
|
|
547
|
+
index.h("casino-engagement-suite-progress-bar", { value: Number(getProgress(tournament.startTime, tournament.endTime)), "hide-percent": true })));
|
|
653
548
|
};
|
|
654
549
|
|
|
655
550
|
const tab = {
|
|
@@ -659,12 +554,12 @@ const tab = {
|
|
|
659
554
|
return (index.h("div", { class: "InfoContainer" },
|
|
660
555
|
renderTimeBar(tournament),
|
|
661
556
|
index.h("section", { class: "ShowInfo", onClick: () => (instance.isShowInfo = !instance.isShowInfo) },
|
|
662
|
-
index.h("div", { class:
|
|
557
|
+
index.h("div", { class: "DetailHeader" },
|
|
663
558
|
index.h("span", null, isShowInfo ? iconEyeOpen : iconEyeClose),
|
|
664
559
|
index.h("span", null, locale.LeaderboardDetails))),
|
|
665
560
|
index.h("div", { class: `ContentScrollContainer ${isShowInfo ? 'expanded' : ''}` },
|
|
666
561
|
isShowInfo && (index.h("section", { class: "Info" },
|
|
667
|
-
index.h("div", { class:
|
|
562
|
+
index.h("div", { class: "Description" }, tournament.description),
|
|
668
563
|
index.h("div", { class: "Criterias" },
|
|
669
564
|
index.h("div", null,
|
|
670
565
|
locale.ScoreCriteria,
|
|
@@ -708,7 +603,7 @@ const tab = {
|
|
|
708
603
|
},
|
|
709
604
|
games(instance) {
|
|
710
605
|
var _a;
|
|
711
|
-
return (index.h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (index.h("div", { class:
|
|
606
|
+
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: () => {
|
|
712
607
|
instance.onGameClick(game);
|
|
713
608
|
} },
|
|
714
609
|
index.h("img", { src: game.defaultThumbnail, alt: "" }))))));
|
|
@@ -735,7 +630,21 @@ var F=Object.defineProperty,J=Object.defineProperties;var V=Object.getOwnPropert
|
|
|
735
630
|
|
|
736
631
|
if(typeof window!="undefined"){let n=function(t){return function(...i){try{return t.apply(this,i)}catch(e){if(e instanceof DOMException&&e.message.includes("has already been used with this registry")||e.message.includes("Cannot define multiple custom elements with the same tag name"))return !1;throw e}}};customElements.define=n(customElements.define),Promise.resolve().then(()=>GeneralAnimationLoadingCYLqpfzI).then(({default:t})=>{!customElements.get("general-animation-loading")&&customElements.define("general-animation-loading",t.element);});}
|
|
737
632
|
|
|
738
|
-
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}.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.Mobile{border-radius:16px}.Wrapper.Mobile .WrapperContent .TableContentWrapper{height:calc(100vh - 278px);overflow-y:auto}.WrapperContent{padding-bottom:20px;transition:0.5s filter}.WrapperContent.faded{filter:brightness(53.3333333333%)}.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}.Row{margin:10px 0;padding:0 20px}.Row:first-child{margin:0}.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 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:hover{filter:brightness(var(--emw--hover-brightness, 1.25))}.Games img{width:100%;height:fit-content}dialog{position:absolute;top:30px;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}}";
|
|
633
|
+
const renderCloseBar = (attr) => {
|
|
634
|
+
const { left, middle, right } = attr;
|
|
635
|
+
const slots = {
|
|
636
|
+
left,
|
|
637
|
+
middle,
|
|
638
|
+
right
|
|
639
|
+
};
|
|
640
|
+
const getFirstLetterUppercase = (str) => str
|
|
641
|
+
.split('')
|
|
642
|
+
.map((letter, index) => index === 0 ? letter.toUpperCase() : letter)
|
|
643
|
+
.join('');
|
|
644
|
+
return (index.h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (index.h("div", { class: 'WrapperBar' + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
|
|
645
|
+
};
|
|
646
|
+
|
|
647
|
+
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}.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%)}.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:30px;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}}";
|
|
739
648
|
const CasinoEngagementSuiteTournamentStyle0 = casinoEngagementSuiteTournamentCss;
|
|
740
649
|
|
|
741
650
|
const CasinoEngagementSuiteTournament = class {
|
|
@@ -744,6 +653,21 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
744
653
|
const _c = e.data, { type } = _c, rest = __rest(_c, ["type"]);
|
|
745
654
|
(_b = (_a = messageReceiver(this)) === null || _a === void 0 ? void 0 : _a[type]) === null || _b === void 0 ? void 0 : _b.call(null, rest);
|
|
746
655
|
}
|
|
656
|
+
handleClickToTournamentDetail(e) {
|
|
657
|
+
const tournament = e.detail;
|
|
658
|
+
this.setPage(exports.LeaderboardPage.item, { tournament });
|
|
659
|
+
this.newIdList = this.newIdList.filter((id) => id !== tournament.id);
|
|
660
|
+
}
|
|
661
|
+
;
|
|
662
|
+
handleJoinTournamentEvent(e) {
|
|
663
|
+
const tournament = e.detail;
|
|
664
|
+
this.actionJoin(tournament);
|
|
665
|
+
this.tournamentItem = tournament;
|
|
666
|
+
}
|
|
667
|
+
handleUnjoinTournamentEvent(e) {
|
|
668
|
+
const { tournament } = e.detail;
|
|
669
|
+
this.openDialog(exports.DialogType.unjoin, tournament);
|
|
670
|
+
}
|
|
747
671
|
checkNewIdList() {
|
|
748
672
|
if (this.newIdList.length > 0) {
|
|
749
673
|
this.addLabel('new');
|
|
@@ -754,7 +678,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
754
678
|
}
|
|
755
679
|
syncBarState(newTournamentList, oldTournamentList) {
|
|
756
680
|
if (!oldTournamentList) {
|
|
757
|
-
// init
|
|
758
681
|
this.checkNewIdList();
|
|
759
682
|
if (this.gifts.length) {
|
|
760
683
|
this.addLabel('win');
|
|
@@ -768,7 +691,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
768
691
|
showPropWatcher(newValue, oldValue) {
|
|
769
692
|
if (oldValue == false && newValue == true) {
|
|
770
693
|
this.checkGift();
|
|
771
|
-
this.page = LeaderboardPage.list;
|
|
694
|
+
this.page = exports.LeaderboardPage.list;
|
|
772
695
|
}
|
|
773
696
|
}
|
|
774
697
|
addLabel(tag) {
|
|
@@ -781,30 +704,26 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
781
704
|
this.labels = this.labels.filter((label) => label != tag);
|
|
782
705
|
messageSender.UpdateSuiteBarState(this.labels);
|
|
783
706
|
}
|
|
784
|
-
setTimeInterval() {
|
|
785
|
-
this.timeHolder = setInterval(() => {
|
|
786
|
-
this.time = this.tournamentList || this.tournamentItem ? this.time + 1 : 0;
|
|
787
|
-
}, 1000);
|
|
788
|
-
}
|
|
789
707
|
checkGift() {
|
|
790
708
|
//check gift
|
|
791
709
|
if (this.gifts.length) {
|
|
792
710
|
const onClose = () => {
|
|
793
|
-
if (this.dialog.type === DialogType.gift) {
|
|
711
|
+
if (this.dialog.type === exports.DialogType.gift) {
|
|
794
712
|
this.gifts = this.gifts.slice(1);
|
|
795
713
|
setTimeout(() => {
|
|
796
714
|
this.checkGift();
|
|
797
715
|
}, 300);
|
|
798
716
|
}
|
|
799
717
|
};
|
|
800
|
-
this.openDialog(DialogType.gift, this.gifts[0], onClose);
|
|
718
|
+
this.openDialog(exports.DialogType.gift, this.gifts[0], onClose);
|
|
801
719
|
}
|
|
802
720
|
else {
|
|
803
721
|
this.removeLabel('win');
|
|
804
722
|
}
|
|
805
723
|
}
|
|
806
724
|
getContainerScrollTop() {
|
|
807
|
-
|
|
725
|
+
var _a;
|
|
726
|
+
return this.page === exports.LeaderboardPage.list ? this.containerScrollTop : ((_a = this.detailElement) === null || _a === void 0 ? void 0 : _a.clientHeight) / 2 - 250;
|
|
808
727
|
}
|
|
809
728
|
handleClickOutside(event) {
|
|
810
729
|
if (event.composedPath()[0] === this.tooltipIconReference)
|
|
@@ -816,6 +735,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
816
735
|
this.pageElement.addEventListener('scroll', (event) => {
|
|
817
736
|
this.containerScrollTop = event.target.scrollTop + event.target.clientHeight / 2 - 250;
|
|
818
737
|
});
|
|
738
|
+
messageSender.UpdateTournamentsPageIsReady();
|
|
819
739
|
}
|
|
820
740
|
renderTooltip() {
|
|
821
741
|
if (this.showTooltip) {
|
|
@@ -824,7 +744,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
824
744
|
return null;
|
|
825
745
|
}
|
|
826
746
|
connectedCallback() {
|
|
827
|
-
this.setTimeInterval();
|
|
828
747
|
messageSender.UpdateLeaderboardsPlayerReq();
|
|
829
748
|
}
|
|
830
749
|
scrollToMyRankLine() {
|
|
@@ -835,25 +754,24 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
835
754
|
this.scrolledToMyLine = true;
|
|
836
755
|
}
|
|
837
756
|
componentDidRender() {
|
|
838
|
-
if (this.page === LeaderboardPage.item && this.tab === Tab.leaderboard
|
|
839
|
-
if (this.currentPlyerRank > this.maxPlyerRank) {
|
|
757
|
+
if (this.page === exports.LeaderboardPage.item && this.tab === Tab.leaderboard) {
|
|
758
|
+
if (this.currentPlyerRank > this.maxPlyerRank && !this.scrolledToMyLine) {
|
|
840
759
|
this.scrollToMyRankLine();
|
|
841
760
|
}
|
|
842
761
|
}
|
|
843
|
-
else {
|
|
762
|
+
else if (this.page === exports.LeaderboardPage.list) {
|
|
844
763
|
this.scrolledToMyLine = false;
|
|
845
764
|
}
|
|
846
765
|
}
|
|
847
|
-
disconnectedCallback() {
|
|
848
|
-
clearInterval(this.timeHolder);
|
|
849
|
-
}
|
|
850
766
|
onGameClick(game) {
|
|
767
|
+
if (game.id === this.currentGameId) {
|
|
768
|
+
return;
|
|
769
|
+
}
|
|
851
770
|
messageSender.GameClickReq(game);
|
|
852
771
|
}
|
|
853
772
|
actionJoin(tournament) {
|
|
854
773
|
if (tournament.isActionJoinPending)
|
|
855
774
|
return;
|
|
856
|
-
tournament.isActionJoinPending = true;
|
|
857
775
|
try {
|
|
858
776
|
if (tournament.isPlayerAcknowledged) {
|
|
859
777
|
messageSender.UnjoinTournamentReq(tournament);
|
|
@@ -868,33 +786,46 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
868
786
|
}
|
|
869
787
|
}
|
|
870
788
|
setPage(page, metaData) {
|
|
871
|
-
|
|
789
|
+
var _a;
|
|
790
|
+
this.page = page;
|
|
791
|
+
if (page === exports.LeaderboardPage.item) {
|
|
792
|
+
this.isShowInfo = false;
|
|
872
793
|
this.tournamentItem = metaData.tournament;
|
|
873
794
|
if (!this.tournamentItem) {
|
|
874
|
-
messageSender.post({
|
|
875
|
-
type: 'GetTournamentGamesById',
|
|
876
|
-
pathParams: { id: metaData.tournament.id },
|
|
877
|
-
payload: {
|
|
878
|
-
expand: 'games',
|
|
879
|
-
pagination: 'games(limit=50,offset=0)',
|
|
880
|
-
fields: 'games(id,name,thumbnail,launchUrl)',
|
|
881
|
-
platform: getDevicePlatform(),
|
|
882
|
-
language: this.language
|
|
883
|
-
}
|
|
884
|
-
});
|
|
885
795
|
messageSender.UpdateTournamentsItemReq(metaData.tournament);
|
|
886
796
|
}
|
|
887
797
|
if (isTournamentClosed(this.tournamentItem)) {
|
|
888
798
|
messageSender.UpdateLeaderboardsReq(this.tournamentItem);
|
|
889
799
|
}
|
|
800
|
+
this.tab = Tab.info;
|
|
890
801
|
}
|
|
891
|
-
this.
|
|
892
|
-
this.page = page;
|
|
802
|
+
this.tournamentTimer.emit({ page, tournamentId: (_a = this.tournamentItem) === null || _a === void 0 ? void 0 : _a.id });
|
|
893
803
|
}
|
|
894
804
|
render() {
|
|
895
|
-
|
|
805
|
+
const renderDialogContent = () => {
|
|
806
|
+
switch (this.dialog.type) {
|
|
807
|
+
case exports.DialogType.unjoin:
|
|
808
|
+
return this.renders.dialog.unjoin();
|
|
809
|
+
case exports.DialogType.tip:
|
|
810
|
+
return index.h("div", { class: "Tip" }, this.locale.Tip);
|
|
811
|
+
case exports.DialogType.error:
|
|
812
|
+
return index.h("div", { class: "Tip Error" }, this.locale.FailedToJoin);
|
|
813
|
+
case exports.DialogType.gift:
|
|
814
|
+
return this.renders.dialog.gift();
|
|
815
|
+
}
|
|
816
|
+
};
|
|
817
|
+
return (index.h(index.Host, null, index.h("general-styling-wrapper", { clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
|
|
896
818
|
// @ts-ignore
|
|
897
|
-
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), index.h("div", {
|
|
819
|
+
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), index.h("div", { class: `Wrapper ${this.device}` }, index.h("div", { class: classnames('WrapperContent', { faded: this.dialog.isOpen }) }, renderCloseBar({
|
|
820
|
+
left: this.page === exports.LeaderboardPage.list
|
|
821
|
+
? index.h("span", { onClick: this.openDialog.bind(this, exports.DialogType.tip) }, iconQuestion)
|
|
822
|
+
: index.h("span", { onClick: this.setPage.bind(this, exports.LeaderboardPage.list) }, iconBack),
|
|
823
|
+
middle: this.locale.Leaderboards,
|
|
824
|
+
right: index.h("span", { onClick: () => this.close.emit() }, iconClose)
|
|
825
|
+
}), 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 &&
|
|
826
|
+
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", { open: this.dialog.isOpen, style: { 'top': this.getContainerScrollTop() + 'px' } }, index.h("div", { class: "GradientRounded Hollow" }, renderCloseBar({
|
|
827
|
+
right: index.h("span", { onClick: () => this.closeDialog() }, iconClose)
|
|
828
|
+
}), this.dialog.isOpen && renderDialogContent()))))));
|
|
898
829
|
}
|
|
899
830
|
openDialog(type, data = undefined, onClose = undefined) {
|
|
900
831
|
this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: true, onClose,
|
|
@@ -909,6 +840,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
909
840
|
constructor(hostRef) {
|
|
910
841
|
index.registerInstance(this, hostRef);
|
|
911
842
|
this.close = index.createEvent(this, "close", 7);
|
|
843
|
+
this.tournamentTimer = index.createEvent(this, "tournamentTimer", 7);
|
|
912
844
|
this.gifts = [];
|
|
913
845
|
this.labels = [];
|
|
914
846
|
this.showTooltip = false;
|
|
@@ -928,7 +860,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
928
860
|
this.leaderboards = [];
|
|
929
861
|
this.isDialogOpen = false;
|
|
930
862
|
this.isShowInfo = false;
|
|
931
|
-
this.page = LeaderboardPage.list;
|
|
863
|
+
this.page = exports.LeaderboardPage.list;
|
|
932
864
|
this.tournamentInDialog = undefined;
|
|
933
865
|
this.dialog = {
|
|
934
866
|
isOpen: false,
|
|
@@ -936,7 +868,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
936
868
|
data: undefined,
|
|
937
869
|
onClose: undefined
|
|
938
870
|
};
|
|
939
|
-
this.time = 0;
|
|
940
871
|
this.newIdList = [];
|
|
941
872
|
// bind all renders
|
|
942
873
|
this.renders = {};
|
|
@@ -956,3 +887,9 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
956
887
|
CasinoEngagementSuiteTournament.style = CasinoEngagementSuiteTournamentStyle0;
|
|
957
888
|
|
|
958
889
|
exports.CasinoEngagementSuiteTournament = CasinoEngagementSuiteTournament;
|
|
890
|
+
exports.TRANSLATIONS = TRANSLATIONS;
|
|
891
|
+
exports.classnames = classnames;
|
|
892
|
+
exports.formatDate = formatDate;
|
|
893
|
+
exports.getProgress = getProgress;
|
|
894
|
+
exports.getTimeDifference = getTimeDifference;
|
|
895
|
+
exports.renderGradientRoundedButton = renderGradientRoundedButton;
|