@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.
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,4 +1,4 @@
1
- import { h, H as Host, r as registerInstance, c as createEvent } from './index-ac437a77.js';
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: "https://static.everymatrix.com/gic/img/engagement-suite/help.svg" });
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
- var _a, _b;
360
- return window.postMessage({
361
- type: 'JoinTournamentReq',
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
- current.isActionJoinPending = false;
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 !== -1) {
511
- instance.tournamentList[index] = tournamentAdapter(tournament);
442
+ if (index === -1) {
443
+ instance.tournamentList = [
444
+ tournamentAdapter(tournament),
445
+ ...instance.tournamentList
446
+ ];
512
447
  }
513
448
  else {
514
- instance.tournamentList = instance.tournamentList.concat(tournamentAdapter(tournament));
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
- const onClickListItemChangePage = (tournament) => {
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 renderLeaderboardContainer(instance, h("div", { class: "NoLeaderboards Row" },
540
- h("h3", { class: 'Title' }, locale.NoLeaderboards),
541
- h("div", { class: 'message' }, locale.NoLeaderboardsTip)));
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 renderLeaderboardContainer(instance, [
566
- renderTitleContainer(instance, instance.tournamentItem),
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 renderTitleContainer = (instance, tournament) => {
573
- const { locale } = instance;
574
- const onClickItemJoin = (tournament) => {
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
- const renderLeaderboardContainer = (instance, render) => {
600
- const { dialog: { isOpen } } = instance;
601
- const renderBar = renderCloseBar({
602
- right: h("span", { onClick: () => instance.closeDialog() }, iconClose)
603
- });
604
- const renderDialogContent = () => {
605
- switch (instance.dialog.type) {
606
- case DialogType.unjoin:
607
- return instance.renders.dialog.unjoin();
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 (h("div", { class: `Wrapper ${instance.device}` },
642
- h("div", { class: classnames('WrapperContent', { faded: isOpen }) },
643
- renderCloseBarInLayout(),
644
- h("div", { class: "Root" },
645
- h("div", { class: "Main" }, render))),
646
- h("div", { class: "WrapperUtil" },
647
- h("dialog", { open: isOpen, style: { 'top': instance.getContainerScrollTop() + 'px' } },
648
- h("div", { class: "GradientRounded Hollow" },
649
- renderBar,
650
- isOpen && renderDialogContent())))));
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: 'DetailHeader' },
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: 'Description' }, tournament.description),
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: 'Game', onClick: () => {
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
- return this.page === LeaderboardPage.list ? this.containerScrollTop : this.detailElement.clientHeight / 2 - 250;
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 && !this.scrolledToMyLine) {
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
- if (page == LeaderboardPage.item) {
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.tab = Tab.info;
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
- return (h(Host, { key: '5a65900ecb503dd01f8f39774b92a6e95048dbf3' }, h("general-styling-wrapper", { key: '58cee35cf4142512e9b49566787b48cbc2761a4a', clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
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", { key: '1848e193e8c61fe6bc9d3e123b7651cb1b97981b', class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), h("div", { key: 'f865edc80013565981b76df146e99ebf1d5d4721', class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())));
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 };