@everymatrix/casino-engagement-suite-tournament 1.62.2 → 1.62.4
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,4 +1,4 @@
|
|
|
1
|
-
import { h, H as Host, r as registerInstance, c as createEvent } from './index-
|
|
1
|
+
import { h, H as Host, r as registerInstance, c as createEvent } from './index-8b5c4b95.js';
|
|
2
2
|
|
|
3
3
|
/*! *****************************************************************************
|
|
4
4
|
Copyright (c) Microsoft Corporation.
|
|
@@ -105,33 +105,6 @@ const truncateNumber = (value, decimals, isInteger = false) => {
|
|
|
105
105
|
// Return string representation with fixed decimals to preserve trailing zeros
|
|
106
106
|
return truncated.toFixed(decimals);
|
|
107
107
|
};
|
|
108
|
-
const getDevice = () => {
|
|
109
|
-
let userAgent = window.navigator.userAgent;
|
|
110
|
-
if (userAgent.toLowerCase().match(/android/i)) {
|
|
111
|
-
return 'Android';
|
|
112
|
-
}
|
|
113
|
-
if (userAgent.toLowerCase().match(/iphone/i)) {
|
|
114
|
-
return 'iPhone';
|
|
115
|
-
}
|
|
116
|
-
if (userAgent.toLowerCase().match(/ipad|ipod/i)) {
|
|
117
|
-
return 'iPad';
|
|
118
|
-
}
|
|
119
|
-
return 'PC';
|
|
120
|
-
};
|
|
121
|
-
const getDevicePlatform = () => {
|
|
122
|
-
const device = getDevice();
|
|
123
|
-
if (device) {
|
|
124
|
-
if (device === 'PC') {
|
|
125
|
-
return 'dk';
|
|
126
|
-
}
|
|
127
|
-
else if (device === 'iPad' || device === 'iPhone') {
|
|
128
|
-
return 'ios';
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
return 'mtWeb';
|
|
132
|
-
}
|
|
133
|
-
}
|
|
134
|
-
};
|
|
135
108
|
|
|
136
109
|
var LeaderboardPage;
|
|
137
110
|
(function (LeaderboardPage) {
|
|
@@ -183,8 +156,10 @@ const isTournamentClosed = (tournament) => {
|
|
|
183
156
|
|
|
184
157
|
const rewardSvg = '';
|
|
185
158
|
|
|
159
|
+
const helpSvg = '';
|
|
160
|
+
|
|
186
161
|
const iconClose = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/close.svg" });
|
|
187
|
-
const iconQuestion = h("img", { src: "
|
|
162
|
+
const iconQuestion = h("img", { src: helpSvg, alt: "question", class: "Question" });
|
|
188
163
|
const iconEyeOpen = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-open.svg" });
|
|
189
164
|
const iconEyeClose = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-closed.svg" });
|
|
190
165
|
const iconBack = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/back.svg" });
|
|
@@ -282,6 +257,14 @@ const leaderboardsAdapter = (leaderboardRes) => {
|
|
|
282
257
|
if (!item) {
|
|
283
258
|
return leaderboards;
|
|
284
259
|
}
|
|
260
|
+
// show current player's rank info at first row if there is no player info in list
|
|
261
|
+
const playerRankIndex = leaderboards.findIndex((leaderboard) => {
|
|
262
|
+
return leaderboard.userId === item.userId;
|
|
263
|
+
});
|
|
264
|
+
playerRankIndex === -1 ? leaderboards = [
|
|
265
|
+
item,
|
|
266
|
+
...leaderboards,
|
|
267
|
+
] : {};
|
|
285
268
|
return leaderboards.map((leaderboard) => {
|
|
286
269
|
if ((item === null || item === void 0 ? void 0 : item.userId) && item.userId === leaderboard.userId) {
|
|
287
270
|
return Object.assign(Object.assign({}, leaderboard), { isMe: true });
|
|
@@ -292,80 +275,16 @@ const leaderboardsAdapter = (leaderboardRes) => {
|
|
|
292
275
|
});
|
|
293
276
|
};
|
|
294
277
|
|
|
295
|
-
const renderCloseBar = (attr) => {
|
|
296
|
-
const { left, middle, right } = attr;
|
|
297
|
-
const slots = {
|
|
298
|
-
left,
|
|
299
|
-
middle,
|
|
300
|
-
right,
|
|
301
|
-
};
|
|
302
|
-
const getFirstLetterUppercase = (str) => str
|
|
303
|
-
.split('')
|
|
304
|
-
.map((letter, index) => index === 0 ? letter.toUpperCase() : letter)
|
|
305
|
-
.join('');
|
|
306
|
-
return (h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (h("div", { class: "WrapperBar" + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
|
|
307
|
-
};
|
|
308
|
-
|
|
309
|
-
function formatDate(date) {
|
|
310
|
-
const options = {
|
|
311
|
-
year: 'numeric',
|
|
312
|
-
month: 'long',
|
|
313
|
-
day: 'numeric',
|
|
314
|
-
hour: '2-digit',
|
|
315
|
-
minute: '2-digit',
|
|
316
|
-
hour12: false
|
|
317
|
-
};
|
|
318
|
-
return date.toLocaleDateString('en-US', options).replace(' at', ',');
|
|
319
|
-
}
|
|
320
|
-
function getProgress(startDate, endDate) {
|
|
321
|
-
return ((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime())).toFixed(0);
|
|
322
|
-
}
|
|
323
|
-
function getTimeDifference(startDate, endDate) {
|
|
324
|
-
const diffMs = Math.abs(endDate.getTime() - startDate.getTime()); // Difference in milliseconds
|
|
325
|
-
const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24)); // Difference in days
|
|
326
|
-
const diffHours = Math.floor((diffMs % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // Remaining hours
|
|
327
|
-
const diffMinutes = Math.floor((diffMs % (1000 * 60 * 60)) / (1000 * 60)); // Remaining minutes
|
|
328
|
-
return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(diffMinutes).padStart(2, '0')}m`;
|
|
329
|
-
}
|
|
330
|
-
|
|
331
|
-
const renderTimeBar = (tournament) => {
|
|
332
|
-
return (h("section", { class: "TimeContainer" },
|
|
333
|
-
h("div", { class: "Time" }, tournament.state === 'Running'
|
|
334
|
-
? [
|
|
335
|
-
h("div", { class: 'Running' },
|
|
336
|
-
h("div", null, getTimeDifference(new Date(), tournament.endTime)),
|
|
337
|
-
",",
|
|
338
|
-
h("div", null, renderGradientRoundedButton({
|
|
339
|
-
statedClasses: {
|
|
340
|
-
isHollow: true,
|
|
341
|
-
isPendding: false
|
|
342
|
-
},
|
|
343
|
-
innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
|
|
344
|
-
})))
|
|
345
|
-
]
|
|
346
|
-
: [h("div", { class: 'NotRunning' }, formatDate(tournament.startTime)), h("div", null, formatDate(tournament.endTime))]),
|
|
347
|
-
h("casino-engagement-suite-progress-bar", { value: Number(getProgress(tournament.startTime, tournament.endTime)), "hide-percent": true })));
|
|
348
|
-
};
|
|
349
|
-
|
|
350
278
|
const messageSender = {
|
|
351
|
-
InitTournamentList: (queryParams) => {
|
|
352
|
-
window.postMessage(Object.assign({ type: 'InitTournamentList' }, queryParams));
|
|
353
|
-
},
|
|
354
|
-
post: (options) => {
|
|
355
|
-
window.postMessage(Object.assign({}, options));
|
|
356
|
-
},
|
|
357
279
|
UpdateSuiteBarState: (labels) => window.postMessage({ type: 'UpdateLeaderboardState', labels }),
|
|
358
|
-
JoinTournamentReq: (tournament) => {
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
id: tournament.id,
|
|
363
|
-
bonusCode: tournament.id || ((_b = (_a = tournament.wallets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.code)
|
|
364
|
-
});
|
|
365
|
-
},
|
|
280
|
+
JoinTournamentReq: (tournament) => window.postMessage({
|
|
281
|
+
type: 'JoinTournamentReq',
|
|
282
|
+
id: tournament.id,
|
|
283
|
+
}),
|
|
366
284
|
UnjoinTournamentReq: (tournament) => window.postMessage({ type: 'UnjoinTournamentReq', id: tournament.id }),
|
|
367
285
|
UpdateTournamentsItemReq: (tournament) => window.postMessage({ type: 'UpdateTournamentsItemReq', id: tournament.id }),
|
|
368
286
|
UpdateLeaderboardsReq: (tournament, query) => window.postMessage({ type: 'UpdateLeaderboardsReq', id: tournament.id, query }),
|
|
287
|
+
UpdateTournamentsPageIsReady: () => window.postMessage({ type: 'TournamentsPageIsReady' }),
|
|
369
288
|
UpdateLeaderboardsPlayerReq: () => window.postMessage({ type: 'UpdateLeaderboardsPlayerReq' }),
|
|
370
289
|
GameClickReq: (game) => window.postMessage({ type: 'EngagementSuiteGameRedirect', data: { Slug: game.slug } }),
|
|
371
290
|
};
|
|
@@ -386,6 +305,7 @@ const messageReceiver = (instance) => {
|
|
|
386
305
|
UpdateLeaderboardsRes: (rest) => processLeaderboardTableData(instance, rest),
|
|
387
306
|
JoinTournamentRes: (rest) => commonJoinRes(instance, rest),
|
|
388
307
|
UnjoinTournamentRes: (rest) => commonJoinRes(instance, rest),
|
|
308
|
+
TournamentsPageIsReadyRes: (rest) => instance.currentGameId = rest.data.GameId,
|
|
389
309
|
// listen to LeaderboardLiveEvent event, handle update
|
|
390
310
|
LeaderboardLiveEvent: (rest) => {
|
|
391
311
|
handleLeaderboardLiveEvent(instance, rest);
|
|
@@ -473,7 +393,10 @@ const showErrorMessage = (instance, type) => {
|
|
|
473
393
|
const commonJoinRes = (instance, rest) => {
|
|
474
394
|
const { success, data } = rest;
|
|
475
395
|
let tournamentIdx = instance.tournamentList.findIndex((tournament) => tournament.id === (data.tournamentId || data.id || data.bonusCode)), current = instance.tournamentList[tournamentIdx];
|
|
476
|
-
|
|
396
|
+
if (tournamentIdx == -1) {
|
|
397
|
+
return;
|
|
398
|
+
}
|
|
399
|
+
current = Object.assign(Object.assign({}, current), { isActionJoinPending: false });
|
|
477
400
|
if (!success) {
|
|
478
401
|
instance.tournamentList[tournamentIdx] = current;
|
|
479
402
|
instance.tournamentList = [...instance.tournamentList];
|
|
@@ -483,6 +406,15 @@ const commonJoinRes = (instance, rest) => {
|
|
|
483
406
|
current = Object.assign(Object.assign({}, current), { isUnjoined: current.isPlayerAcknowledged ? true : false, isPlayerAcknowledged: !!!current.isPlayerAcknowledged });
|
|
484
407
|
instance.tournamentList[tournamentIdx] = current;
|
|
485
408
|
instance.tournamentList = [...instance.tournamentList];
|
|
409
|
+
if (instance.page === LeaderboardPage.item) {
|
|
410
|
+
if (current.isUnjoined) {
|
|
411
|
+
instance.setPage(LeaderboardPage.list);
|
|
412
|
+
return;
|
|
413
|
+
}
|
|
414
|
+
else {
|
|
415
|
+
instance.tournamentItem = Object.assign({}, current);
|
|
416
|
+
}
|
|
417
|
+
}
|
|
486
418
|
if (instance.nextPage) {
|
|
487
419
|
instance.setPage(instance.nextPage);
|
|
488
420
|
instance.nextPage = undefined;
|
|
@@ -507,11 +439,15 @@ const removeTournament = (instance, tournament) => {
|
|
|
507
439
|
};
|
|
508
440
|
const updateOrAddTournamentToList = (instance, tournament) => {
|
|
509
441
|
const index = instance.tournamentList.findIndex((_tournament) => _tournament.id === tournament.id);
|
|
510
|
-
if (index
|
|
511
|
-
instance.tournamentList
|
|
442
|
+
if (index === -1) {
|
|
443
|
+
instance.tournamentList = [
|
|
444
|
+
tournamentAdapter(tournament),
|
|
445
|
+
...instance.tournamentList
|
|
446
|
+
];
|
|
512
447
|
}
|
|
513
448
|
else {
|
|
514
|
-
instance.tournamentList =
|
|
449
|
+
instance.tournamentList[index] = tournamentAdapter(tournament);
|
|
450
|
+
instance.tournamentList = [...instance.tournamentList];
|
|
515
451
|
}
|
|
516
452
|
};
|
|
517
453
|
|
|
@@ -524,21 +460,12 @@ const page = {
|
|
|
524
460
|
}
|
|
525
461
|
const { locale } = instance;
|
|
526
462
|
if (instance.tournamentList.length) {
|
|
527
|
-
|
|
528
|
-
instance.setPage(LeaderboardPage.item, { tournament });
|
|
529
|
-
instance.newIdList = instance.newIdList.filter((id) => id !== tournament.id);
|
|
530
|
-
};
|
|
531
|
-
return renderLeaderboardContainer(instance, h("div", { class: 'Leaderboards Row' }, instance.tournamentList.map((_tournament) => (h("div", { class: classnames('LeaderboardsItem', _tournament.isPlayerAcknowledged ? ' GradientRounded Hollow' : '', _tournament.isUnjoined ? 'Unjoined' : ''), onClick: () => onClickListItemChangePage(_tournament) },
|
|
532
|
-
h("div", { class: "LeaderboardsItemContainer" },
|
|
533
|
-
renderTitleContainer(instance, _tournament),
|
|
534
|
-
renderTimeBar(_tournament)),
|
|
535
|
-
h("div", { class: "LeaderboardLabels" }, instance.newIdList.includes(_tournament.id) && (h("div", { class: "LeaderboardLabel" },
|
|
536
|
-
h("span", null, "new")))))))));
|
|
463
|
+
return renderWrapperByPageType(h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament) => (h("casino-engagement-suite-tournament-item", { tournament: _tournament, isNew: instance.newIdList.includes(_tournament.id) })))));
|
|
537
464
|
}
|
|
538
465
|
else {
|
|
539
|
-
return
|
|
540
|
-
h("h3", { class:
|
|
541
|
-
h("div", { class:
|
|
466
|
+
return renderWrapperByPageType(h("div", { class: "NoLeaderboards ScrollBar Row" },
|
|
467
|
+
h("h3", { class: "Title" }, locale.NoLeaderboards),
|
|
468
|
+
h("div", { class: "message" }, locale.NoLeaderboardsTip)));
|
|
542
469
|
}
|
|
543
470
|
},
|
|
544
471
|
item(instance) {
|
|
@@ -562,92 +489,60 @@ const page = {
|
|
|
562
489
|
h("div", { class: "Tabs" }, Object.keys(Tab).map((_tab) => (h("div", { class: classnames({ active: tab === _tab }),
|
|
563
490
|
onClick: () => onClickTab(_tab) }, locale[_tab]))))));
|
|
564
491
|
};
|
|
565
|
-
return
|
|
566
|
-
|
|
492
|
+
return renderWrapperByPageType([
|
|
493
|
+
h("casino-engagement-suite-tournament-item-title", { tournament: instance.tournamentItem }),
|
|
567
494
|
renderTabs(),
|
|
568
495
|
h("div", { class: `TableContentWrapper ${instance.tab}` }, instance.renders.tab[instance.tab]())
|
|
569
496
|
]);
|
|
570
497
|
}
|
|
571
498
|
};
|
|
572
|
-
const
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
if (tournament.isPlayerAcknowledged) {
|
|
576
|
-
instance.openDialog(DialogType.unjoin, tournament);
|
|
577
|
-
}
|
|
578
|
-
else {
|
|
579
|
-
instance.actionJoin(tournament);
|
|
580
|
-
instance.tournamentItem = tournament;
|
|
581
|
-
}
|
|
582
|
-
};
|
|
583
|
-
return (h("div", { class: "TitleContainer" },
|
|
584
|
-
h("div", { class: "Title" }, tournament.nameOrTitle),
|
|
585
|
-
tournament.state !== TournamentState.Closed && (h("div", null, renderGradientRoundedButton({
|
|
586
|
-
statedClasses: {
|
|
587
|
-
isHollow: tournament.isPlayerAcknowledged,
|
|
588
|
-
isPending: tournament.isActionJoinPending
|
|
589
|
-
},
|
|
590
|
-
onClick: (e) => {
|
|
591
|
-
e.stopPropagation();
|
|
592
|
-
if (!tournament.isActionJoinPending) {
|
|
593
|
-
onClickItemJoin(tournament);
|
|
594
|
-
}
|
|
595
|
-
},
|
|
596
|
-
innerHTML: tournament.isPlayerAcknowledged ? locale.Unjoin : locale.Join
|
|
597
|
-
})))));
|
|
499
|
+
const renderWrapperByPageType = (render) => {
|
|
500
|
+
return (h("div", { class: "Root" },
|
|
501
|
+
h("div", { class: "Main" }, render)));
|
|
598
502
|
};
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
const
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
608
|
-
case DialogType.tip:
|
|
609
|
-
return h("div", { class: "Tip" }, instance.locale.Tip);
|
|
610
|
-
case DialogType.error:
|
|
611
|
-
return h("div", { class: "Tip Error" }, instance.locale.FailedToJoin);
|
|
612
|
-
case DialogType.gift:
|
|
613
|
-
return instance.renders.dialog.gift();
|
|
614
|
-
}
|
|
615
|
-
};
|
|
616
|
-
const getWrapperBarData = () => {
|
|
617
|
-
const { page, locale } = instance;
|
|
618
|
-
switch (page) {
|
|
619
|
-
case LeaderboardPage.list:
|
|
620
|
-
return {
|
|
621
|
-
left: h("span", { onClick: () => instance.openDialog(DialogType.tip), onMouseEnter: () => { instance.showTooltip = true; }, onMouseLeave: () => { instance.showTooltip = false; }, ref: (el) => instance.tooltipIconReference = el },
|
|
622
|
-
iconQuestion,
|
|
623
|
-
instance.renderTooltip()),
|
|
624
|
-
middle: locale.Leaderboards
|
|
625
|
-
};
|
|
626
|
-
case LeaderboardPage.item:
|
|
627
|
-
return {
|
|
628
|
-
left: h("span", { onClick: () => instance.setPage(LeaderboardPage.list) }, iconBack),
|
|
629
|
-
middle: locale.Leaderboards
|
|
630
|
-
};
|
|
631
|
-
}
|
|
632
|
-
};
|
|
633
|
-
const renderCloseBarInLayout = () => {
|
|
634
|
-
const { left, middle } = getWrapperBarData();
|
|
635
|
-
return renderCloseBar({
|
|
636
|
-
left,
|
|
637
|
-
middle,
|
|
638
|
-
right: h("span", { onClick: () => instance.close.emit() }, iconClose)
|
|
639
|
-
});
|
|
503
|
+
|
|
504
|
+
function formatDate(date) {
|
|
505
|
+
const options = {
|
|
506
|
+
year: 'numeric',
|
|
507
|
+
month: 'long',
|
|
508
|
+
day: 'numeric',
|
|
509
|
+
hour: '2-digit',
|
|
510
|
+
minute: '2-digit',
|
|
511
|
+
hour12: false
|
|
640
512
|
};
|
|
641
|
-
return (
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
|
|
645
|
-
|
|
646
|
-
|
|
647
|
-
|
|
648
|
-
|
|
649
|
-
|
|
650
|
-
|
|
513
|
+
return date.toLocaleDateString('en-US', options).replace(' at', ',');
|
|
514
|
+
}
|
|
515
|
+
function getProgress(startDate, endDate) {
|
|
516
|
+
if (new Date().getTime() >= endDate.getTime()) {
|
|
517
|
+
return 100;
|
|
518
|
+
}
|
|
519
|
+
return ((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime())).toFixed(0);
|
|
520
|
+
}
|
|
521
|
+
function getTimeDifference(startDate, endDate) {
|
|
522
|
+
const diffMs = Math.abs(endDate.getTime() - startDate.getTime()); // Difference in milliseconds
|
|
523
|
+
const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24)); // Difference in days
|
|
524
|
+
const diffHours = Math.floor((diffMs % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // Remaining hours
|
|
525
|
+
const diffMinutes = Math.floor((diffMs % (1000 * 60 * 60)) / (1000 * 60)); // Remaining minutes
|
|
526
|
+
return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(diffMinutes).padStart(2, '0')}m`;
|
|
527
|
+
}
|
|
528
|
+
|
|
529
|
+
const renderTimeBar = (tournament) => {
|
|
530
|
+
return (h("section", { class: "TimeContainer" },
|
|
531
|
+
h("div", { class: "Time" }, tournament.state === 'Running'
|
|
532
|
+
? [
|
|
533
|
+
h("div", { class: 'Running' },
|
|
534
|
+
h("div", null, getTimeDifference(new Date(), tournament.endTime)),
|
|
535
|
+
",",
|
|
536
|
+
h("div", null, renderGradientRoundedButton({
|
|
537
|
+
statedClasses: {
|
|
538
|
+
isHollow: true,
|
|
539
|
+
isPendding: false
|
|
540
|
+
},
|
|
541
|
+
innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
|
|
542
|
+
})))
|
|
543
|
+
]
|
|
544
|
+
: [h("div", { class: 'NotRunning' }, formatDate(tournament.startTime)), h("div", null, formatDate(tournament.endTime))]),
|
|
545
|
+
h("casino-engagement-suite-progress-bar", { value: Number(getProgress(tournament.startTime, tournament.endTime)), "hide-percent": true })));
|
|
651
546
|
};
|
|
652
547
|
|
|
653
548
|
const tab = {
|
|
@@ -657,12 +552,12 @@ const tab = {
|
|
|
657
552
|
return (h("div", { class: "InfoContainer" },
|
|
658
553
|
renderTimeBar(tournament),
|
|
659
554
|
h("section", { class: "ShowInfo", onClick: () => (instance.isShowInfo = !instance.isShowInfo) },
|
|
660
|
-
h("div", { class:
|
|
555
|
+
h("div", { class: "DetailHeader" },
|
|
661
556
|
h("span", null, isShowInfo ? iconEyeOpen : iconEyeClose),
|
|
662
557
|
h("span", null, locale.LeaderboardDetails))),
|
|
663
558
|
h("div", { class: `ContentScrollContainer ${isShowInfo ? 'expanded' : ''}` },
|
|
664
559
|
isShowInfo && (h("section", { class: "Info" },
|
|
665
|
-
h("div", { class:
|
|
560
|
+
h("div", { class: "Description" }, tournament.description),
|
|
666
561
|
h("div", { class: "Criterias" },
|
|
667
562
|
h("div", null,
|
|
668
563
|
locale.ScoreCriteria,
|
|
@@ -706,7 +601,7 @@ const tab = {
|
|
|
706
601
|
},
|
|
707
602
|
games(instance) {
|
|
708
603
|
var _a;
|
|
709
|
-
return (h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (h("div", { class:
|
|
604
|
+
return (h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (h("div", { class: `Game ${instance.currentGameId == game.id ? 'Current' : ''}`, onClick: () => {
|
|
710
605
|
instance.onGameClick(game);
|
|
711
606
|
} },
|
|
712
607
|
h("img", { src: game.defaultThumbnail, alt: "" }))))));
|
|
@@ -733,7 +628,21 @@ var F=Object.defineProperty,J=Object.defineProperties;var V=Object.getOwnPropert
|
|
|
733
628
|
|
|
734
629
|
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);});}
|
|
735
630
|
|
|
736
|
-
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}}";
|
|
631
|
+
const renderCloseBar = (attr) => {
|
|
632
|
+
const { left, middle, right } = attr;
|
|
633
|
+
const slots = {
|
|
634
|
+
left,
|
|
635
|
+
middle,
|
|
636
|
+
right
|
|
637
|
+
};
|
|
638
|
+
const getFirstLetterUppercase = (str) => str
|
|
639
|
+
.split('')
|
|
640
|
+
.map((letter, index) => index === 0 ? letter.toUpperCase() : letter)
|
|
641
|
+
.join('');
|
|
642
|
+
return (h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (h("div", { class: 'WrapperBar' + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
|
|
643
|
+
};
|
|
644
|
+
|
|
645
|
+
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}}";
|
|
737
646
|
const CasinoEngagementSuiteTournamentStyle0 = casinoEngagementSuiteTournamentCss;
|
|
738
647
|
|
|
739
648
|
const CasinoEngagementSuiteTournament = class {
|
|
@@ -742,6 +651,21 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
742
651
|
const _c = e.data, { type } = _c, rest = __rest(_c, ["type"]);
|
|
743
652
|
(_b = (_a = messageReceiver(this)) === null || _a === void 0 ? void 0 : _a[type]) === null || _b === void 0 ? void 0 : _b.call(null, rest);
|
|
744
653
|
}
|
|
654
|
+
handleClickToTournamentDetail(e) {
|
|
655
|
+
const tournament = e.detail;
|
|
656
|
+
this.setPage(LeaderboardPage.item, { tournament });
|
|
657
|
+
this.newIdList = this.newIdList.filter((id) => id !== tournament.id);
|
|
658
|
+
}
|
|
659
|
+
;
|
|
660
|
+
handleJoinTournamentEvent(e) {
|
|
661
|
+
const tournament = e.detail;
|
|
662
|
+
this.actionJoin(tournament);
|
|
663
|
+
this.tournamentItem = tournament;
|
|
664
|
+
}
|
|
665
|
+
handleUnjoinTournamentEvent(e) {
|
|
666
|
+
const { tournament } = e.detail;
|
|
667
|
+
this.openDialog(DialogType.unjoin, tournament);
|
|
668
|
+
}
|
|
745
669
|
checkNewIdList() {
|
|
746
670
|
if (this.newIdList.length > 0) {
|
|
747
671
|
this.addLabel('new');
|
|
@@ -752,7 +676,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
752
676
|
}
|
|
753
677
|
syncBarState(newTournamentList, oldTournamentList) {
|
|
754
678
|
if (!oldTournamentList) {
|
|
755
|
-
// init
|
|
756
679
|
this.checkNewIdList();
|
|
757
680
|
if (this.gifts.length) {
|
|
758
681
|
this.addLabel('win');
|
|
@@ -779,11 +702,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
779
702
|
this.labels = this.labels.filter((label) => label != tag);
|
|
780
703
|
messageSender.UpdateSuiteBarState(this.labels);
|
|
781
704
|
}
|
|
782
|
-
setTimeInterval() {
|
|
783
|
-
this.timeHolder = setInterval(() => {
|
|
784
|
-
this.time = this.tournamentList || this.tournamentItem ? this.time + 1 : 0;
|
|
785
|
-
}, 1000);
|
|
786
|
-
}
|
|
787
705
|
checkGift() {
|
|
788
706
|
//check gift
|
|
789
707
|
if (this.gifts.length) {
|
|
@@ -802,7 +720,8 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
802
720
|
}
|
|
803
721
|
}
|
|
804
722
|
getContainerScrollTop() {
|
|
805
|
-
|
|
723
|
+
var _a;
|
|
724
|
+
return this.page === LeaderboardPage.list ? this.containerScrollTop : ((_a = this.detailElement) === null || _a === void 0 ? void 0 : _a.clientHeight) / 2 - 250;
|
|
806
725
|
}
|
|
807
726
|
handleClickOutside(event) {
|
|
808
727
|
if (event.composedPath()[0] === this.tooltipIconReference)
|
|
@@ -814,6 +733,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
814
733
|
this.pageElement.addEventListener('scroll', (event) => {
|
|
815
734
|
this.containerScrollTop = event.target.scrollTop + event.target.clientHeight / 2 - 250;
|
|
816
735
|
});
|
|
736
|
+
messageSender.UpdateTournamentsPageIsReady();
|
|
817
737
|
}
|
|
818
738
|
renderTooltip() {
|
|
819
739
|
if (this.showTooltip) {
|
|
@@ -822,7 +742,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
822
742
|
return null;
|
|
823
743
|
}
|
|
824
744
|
connectedCallback() {
|
|
825
|
-
this.setTimeInterval();
|
|
826
745
|
messageSender.UpdateLeaderboardsPlayerReq();
|
|
827
746
|
}
|
|
828
747
|
scrollToMyRankLine() {
|
|
@@ -833,25 +752,24 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
833
752
|
this.scrolledToMyLine = true;
|
|
834
753
|
}
|
|
835
754
|
componentDidRender() {
|
|
836
|
-
if (this.page === LeaderboardPage.item && this.tab === Tab.leaderboard
|
|
837
|
-
if (this.currentPlyerRank > this.maxPlyerRank) {
|
|
755
|
+
if (this.page === LeaderboardPage.item && this.tab === Tab.leaderboard) {
|
|
756
|
+
if (this.currentPlyerRank > this.maxPlyerRank && !this.scrolledToMyLine) {
|
|
838
757
|
this.scrollToMyRankLine();
|
|
839
758
|
}
|
|
840
759
|
}
|
|
841
|
-
else {
|
|
760
|
+
else if (this.page === LeaderboardPage.list) {
|
|
842
761
|
this.scrolledToMyLine = false;
|
|
843
762
|
}
|
|
844
763
|
}
|
|
845
|
-
disconnectedCallback() {
|
|
846
|
-
clearInterval(this.timeHolder);
|
|
847
|
-
}
|
|
848
764
|
onGameClick(game) {
|
|
765
|
+
if (game.id === this.currentGameId) {
|
|
766
|
+
return;
|
|
767
|
+
}
|
|
849
768
|
messageSender.GameClickReq(game);
|
|
850
769
|
}
|
|
851
770
|
actionJoin(tournament) {
|
|
852
771
|
if (tournament.isActionJoinPending)
|
|
853
772
|
return;
|
|
854
|
-
tournament.isActionJoinPending = true;
|
|
855
773
|
try {
|
|
856
774
|
if (tournament.isPlayerAcknowledged) {
|
|
857
775
|
messageSender.UnjoinTournamentReq(tournament);
|
|
@@ -866,33 +784,46 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
866
784
|
}
|
|
867
785
|
}
|
|
868
786
|
setPage(page, metaData) {
|
|
869
|
-
|
|
787
|
+
var _a;
|
|
788
|
+
this.page = page;
|
|
789
|
+
if (page === LeaderboardPage.item) {
|
|
790
|
+
this.isShowInfo = false;
|
|
870
791
|
this.tournamentItem = metaData.tournament;
|
|
871
792
|
if (!this.tournamentItem) {
|
|
872
|
-
messageSender.post({
|
|
873
|
-
type: 'GetTournamentGamesById',
|
|
874
|
-
pathParams: { id: metaData.tournament.id },
|
|
875
|
-
payload: {
|
|
876
|
-
expand: 'games',
|
|
877
|
-
pagination: 'games(limit=50,offset=0)',
|
|
878
|
-
fields: 'games(id,name,thumbnail,launchUrl)',
|
|
879
|
-
platform: getDevicePlatform(),
|
|
880
|
-
language: this.language
|
|
881
|
-
}
|
|
882
|
-
});
|
|
883
793
|
messageSender.UpdateTournamentsItemReq(metaData.tournament);
|
|
884
794
|
}
|
|
885
795
|
if (isTournamentClosed(this.tournamentItem)) {
|
|
886
796
|
messageSender.UpdateLeaderboardsReq(this.tournamentItem);
|
|
887
797
|
}
|
|
798
|
+
this.tab = Tab.info;
|
|
888
799
|
}
|
|
889
|
-
this.
|
|
890
|
-
this.page = page;
|
|
800
|
+
this.tournamentTimer.emit({ page, tournamentId: (_a = this.tournamentItem) === null || _a === void 0 ? void 0 : _a.id });
|
|
891
801
|
}
|
|
892
802
|
render() {
|
|
893
|
-
|
|
803
|
+
const renderDialogContent = () => {
|
|
804
|
+
switch (this.dialog.type) {
|
|
805
|
+
case DialogType.unjoin:
|
|
806
|
+
return this.renders.dialog.unjoin();
|
|
807
|
+
case DialogType.tip:
|
|
808
|
+
return h("div", { class: "Tip" }, this.locale.Tip);
|
|
809
|
+
case DialogType.error:
|
|
810
|
+
return h("div", { class: "Tip Error" }, this.locale.FailedToJoin);
|
|
811
|
+
case DialogType.gift:
|
|
812
|
+
return this.renders.dialog.gift();
|
|
813
|
+
}
|
|
814
|
+
};
|
|
815
|
+
return (h(Host, null, h("general-styling-wrapper", { clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
|
|
894
816
|
// @ts-ignore
|
|
895
|
-
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), h("div", {
|
|
817
|
+
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), h("div", { class: `Wrapper ${this.device}` }, h("div", { class: classnames('WrapperContent', { faded: this.dialog.isOpen }) }, renderCloseBar({
|
|
818
|
+
left: this.page === LeaderboardPage.list
|
|
819
|
+
? h("span", { onClick: this.openDialog.bind(this, DialogType.tip) }, iconQuestion)
|
|
820
|
+
: h("span", { onClick: this.setPage.bind(this, LeaderboardPage.list) }, iconBack),
|
|
821
|
+
middle: this.locale.Leaderboards,
|
|
822
|
+
right: h("span", { onClick: () => this.close.emit() }, iconClose)
|
|
823
|
+
}), h("div", { class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), this.page === LeaderboardPage.item &&
|
|
824
|
+
h("div", { class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())), h("div", { class: "WrapperUtil" }, h("dialog", { open: this.dialog.isOpen, style: { 'top': this.getContainerScrollTop() + 'px' } }, h("div", { class: "GradientRounded Hollow" }, renderCloseBar({
|
|
825
|
+
right: h("span", { onClick: () => this.closeDialog() }, iconClose)
|
|
826
|
+
}), this.dialog.isOpen && renderDialogContent()))))));
|
|
896
827
|
}
|
|
897
828
|
openDialog(type, data = undefined, onClose = undefined) {
|
|
898
829
|
this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: true, onClose,
|
|
@@ -907,6 +838,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
907
838
|
constructor(hostRef) {
|
|
908
839
|
registerInstance(this, hostRef);
|
|
909
840
|
this.close = createEvent(this, "close", 7);
|
|
841
|
+
this.tournamentTimer = createEvent(this, "tournamentTimer", 7);
|
|
910
842
|
this.gifts = [];
|
|
911
843
|
this.labels = [];
|
|
912
844
|
this.showTooltip = false;
|
|
@@ -934,7 +866,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
934
866
|
data: undefined,
|
|
935
867
|
onClose: undefined
|
|
936
868
|
};
|
|
937
|
-
this.time = 0;
|
|
938
869
|
this.newIdList = [];
|
|
939
870
|
// bind all renders
|
|
940
871
|
this.renders = {};
|
|
@@ -953,4 +884,4 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
953
884
|
};
|
|
954
885
|
CasinoEngagementSuiteTournament.style = CasinoEngagementSuiteTournamentStyle0;
|
|
955
886
|
|
|
956
|
-
export { CasinoEngagementSuiteTournament as C };
|
|
887
|
+
export { CasinoEngagementSuiteTournament as C, DialogType as D, LeaderboardPage as L, TRANSLATIONS as T, TournamentState as a, getProgress as b, classnames as c, formatDate as f, getTimeDifference as g, renderGradientRoundedButton as r };
|