@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.
Files changed (43) hide show
  1. package/dist/casino-engagement-suite-tournament/casino-engagement-suite-tournament.esm.js +1 -1
  2. package/dist/casino-engagement-suite-tournament/index.esm.js +1 -1
  3. package/dist/casino-engagement-suite-tournament/p-14ab3c1a.entry.js +1 -0
  4. package/dist/casino-engagement-suite-tournament/p-5f051654.js +15 -0
  5. package/dist/casino-engagement-suite-tournament/{p-bfca9e2a.js → p-c6fe0205.js} +1 -1
  6. package/dist/cjs/{casino-engagement-suite-progress-bar_3.cjs.entry.js → casino-engagement-suite-progress-bar_6.cjs.entry.js} +124 -2
  7. package/dist/cjs/{casino-engagement-suite-tournament-bc4edfdf.js → casino-engagement-suite-tournament-1f1275c4.js} +179 -242
  8. package/dist/cjs/casino-engagement-suite-tournament.cjs.js +2 -2
  9. package/dist/cjs/{index-982cd594.js → index-5e98dd13.js} +4 -3
  10. package/dist/cjs/index.cjs.js +2 -2
  11. package/dist/cjs/loader.cjs.js +2 -2
  12. package/dist/collection/assets/help.svg +10 -0
  13. package/dist/collection/collection-manifest.json +4 -1
  14. package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.css +30 -3
  15. package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.js +89 -34
  16. package/dist/collection/shared/TournamentDurationTimer.js +92 -0
  17. package/dist/collection/shared/TournamentItem.js +114 -0
  18. package/dist/collection/shared/TournamentItemTitle.js +124 -0
  19. package/dist/collection/shared/icons.js +2 -1
  20. package/dist/collection/shared/renderBar.js +2 -2
  21. package/dist/collection/shared/renders.page.js +6 -79
  22. package/dist/collection/shared/renders.tab.js +2 -2
  23. package/dist/collection/utils/api.apdater.js +8 -0
  24. package/dist/collection/utils/bussiness.js +0 -25
  25. package/dist/collection/utils/message.js +27 -19
  26. package/dist/collection/utils/util.date.js +3 -0
  27. package/dist/esm/{casino-engagement-suite-progress-bar_3.entry.js → casino-engagement-suite-progress-bar_6.entry.js} +123 -3
  28. package/dist/esm/{casino-engagement-suite-tournament-bc5e0906.js → casino-engagement-suite-tournament-54c513f1.js} +162 -231
  29. package/dist/esm/casino-engagement-suite-tournament.js +3 -3
  30. package/dist/esm/{index-ac437a77.js → index-8b5c4b95.js} +4 -3
  31. package/dist/esm/index.js +2 -2
  32. package/dist/esm/loader.js +3 -3
  33. package/dist/types/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.d.ts +8 -10
  34. package/dist/types/components.d.ts +85 -2
  35. package/dist/types/shared/TournamentDurationTimer.d.ts +15 -0
  36. package/dist/types/shared/TournamentItem.d.ts +46 -0
  37. package/dist/types/shared/TournamentItemTitle.d.ts +47 -0
  38. package/dist/types/utils/bussiness.d.ts +1 -45
  39. package/dist/types/utils/message.d.ts +2 -2
  40. package/dist/types/utils/util.date.d.ts +1 -1
  41. package/package.json +1 -1
  42. package/dist/casino-engagement-suite-tournament/p-67373ab1.entry.js +0 -1
  43. 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-982cd594.js');
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
- var LeaderboardPage;
111
+ exports.LeaderboardPage = void 0;
139
112
  (function (LeaderboardPage) {
140
113
  LeaderboardPage["list"] = "list";
141
114
  LeaderboardPage["item"] = "item";
142
- })(LeaderboardPage || (LeaderboardPage = {}));
143
- var TournamentState;
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
- var DialogType;
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: "https://static.everymatrix.com/gic/img/engagement-suite/help.svg" });
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
- var _a, _b;
362
- return window.postMessage({
363
- type: 'JoinTournamentReq',
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
- current.isActionJoinPending = false;
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 !== -1) {
513
- instance.tournamentList[index] = tournamentAdapter(tournament);
444
+ if (index === -1) {
445
+ instance.tournamentList = [
446
+ tournamentAdapter(tournament),
447
+ ...instance.tournamentList
448
+ ];
514
449
  }
515
450
  else {
516
- instance.tournamentList = instance.tournamentList.concat(tournamentAdapter(tournament));
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
- const onClickListItemChangePage = (tournament) => {
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 renderLeaderboardContainer(instance, index.h("div", { class: "NoLeaderboards Row" },
542
- index.h("h3", { class: 'Title' }, locale.NoLeaderboards),
543
- index.h("div", { class: 'message' }, locale.NoLeaderboardsTip)));
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 renderLeaderboardContainer(instance, [
568
- renderTitleContainer(instance, instance.tournamentItem),
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 renderTitleContainer = (instance, tournament) => {
575
- const { locale } = instance;
576
- const onClickItemJoin = (tournament) => {
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
- const renderLeaderboardContainer = (instance, render) => {
602
- const { dialog: { isOpen } } = instance;
603
- const renderBar = renderCloseBar({
604
- right: index.h("span", { onClick: () => instance.closeDialog() }, iconClose)
605
- });
606
- const renderDialogContent = () => {
607
- switch (instance.dialog.type) {
608
- case DialogType.unjoin:
609
- return instance.renders.dialog.unjoin();
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 (index.h("div", { class: `Wrapper ${instance.device}` },
644
- index.h("div", { class: classnames('WrapperContent', { faded: isOpen }) },
645
- renderCloseBarInLayout(),
646
- index.h("div", { class: "Root" },
647
- index.h("div", { class: "Main" }, render))),
648
- index.h("div", { class: "WrapperUtil" },
649
- index.h("dialog", { open: isOpen, style: { 'top': instance.getContainerScrollTop() + 'px' } },
650
- index.h("div", { class: "GradientRounded Hollow" },
651
- renderBar,
652
- isOpen && renderDialogContent())))));
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: 'DetailHeader' },
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: 'Description' }, tournament.description),
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: 'Game', onClick: () => {
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
- return this.page === LeaderboardPage.list ? this.containerScrollTop : this.detailElement.clientHeight / 2 - 250;
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 && !this.scrolledToMyLine) {
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
- if (page == LeaderboardPage.item) {
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.tab = Tab.info;
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
- return (index.h(index.Host, { key: '5a65900ecb503dd01f8f39774b92a6e95048dbf3' }, index.h("general-styling-wrapper", { key: '58cee35cf4142512e9b49566787b48cbc2761a4a', clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
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", { key: '1848e193e8c61fe6bc9d3e123b7651cb1b97981b', class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), index.h("div", { key: 'f865edc80013565981b76df146e99ebf1d5d4721', class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())));
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;