@everymatrix/casino-engagement-suite-tournament 1.60.1 → 1.61.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) 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-10e1f844.entry.js → p-2dd35709.entry.js} +1 -1
  4. package/dist/casino-engagement-suite-tournament/p-2de8ee45.js +15 -0
  5. package/dist/casino-engagement-suite-tournament/{p-7dd52ef4.js → p-bfca9e2a.js} +2 -2
  6. package/dist/cjs/casino-engagement-suite-progress-bar_3.cjs.entry.js +2 -2
  7. package/dist/cjs/{casino-engagement-suite-tournament-9276045b.js → casino-engagement-suite-tournament-49cebf14.js} +163 -55
  8. package/dist/cjs/casino-engagement-suite-tournament.cjs.js +2 -2
  9. package/dist/cjs/{index-9b5a5304.js → index-982cd594.js} +5 -1
  10. package/dist/cjs/index.cjs.js +2 -2
  11. package/dist/cjs/loader.cjs.js +2 -2
  12. package/dist/collection/assets/reward.svg +11 -0
  13. package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.css +135 -32
  14. package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.js +67 -9
  15. package/dist/collection/shared/icons.js +2 -1
  16. package/dist/collection/shared/renders.dialog.js +2 -2
  17. package/dist/collection/shared/renders.page.js +11 -9
  18. package/dist/collection/shared/renders.tab.js +4 -2
  19. package/dist/collection/shared/renders.util.js +3 -4
  20. package/dist/collection/utils/api.apdater.js +1 -1
  21. package/dist/collection/utils/bussiness.js +15 -0
  22. package/dist/collection/utils/message.js +37 -20
  23. package/dist/collection/utils/translations.js +1 -1
  24. package/dist/collection/utils/types.js +1 -0
  25. package/dist/collection/utils/utils.js +38 -1
  26. package/dist/esm/casino-engagement-suite-progress-bar_3.entry.js +2 -2
  27. package/dist/esm/{casino-engagement-suite-tournament-e9186545.js → casino-engagement-suite-tournament-bd7c9cdd.js} +163 -55
  28. package/dist/esm/casino-engagement-suite-tournament.js +3 -3
  29. package/dist/esm/{index-e8e1e68e.js → index-ac437a77.js} +5 -1
  30. package/dist/esm/index.js +2 -2
  31. package/dist/esm/loader.js +3 -3
  32. package/dist/types/Users/adrian.pripon/Documents/Work/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/packages/stencil/casino-engagement-suite-tournament/stencil.config.d.ts +2 -0
  33. package/dist/types/Users/adrian.pripon/Documents/Work/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/packages/stencil/casino-engagement-suite-tournament/stencil.config.dev.d.ts +2 -0
  34. package/dist/types/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.d.ts +24 -9
  35. package/dist/types/utils/api.apdater.d.ts +3 -1
  36. package/dist/types/utils/bussiness.d.ts +15 -1
  37. package/dist/types/utils/message.d.ts +4 -1
  38. package/dist/types/utils/translations.d.ts +2 -0
  39. package/dist/types/utils/types.d.ts +21 -3
  40. package/dist/types/utils/utils.d.ts +6 -0
  41. package/package.json +1 -1
  42. package/dist/casino-engagement-suite-tournament/p-94a5935e.js +0 -15
  43. package/dist/types/Users/maria.bumbar/Desktop/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/packages/stencil/casino-engagement-suite-tournament/stencil.config.d.ts +0 -2
  44. package/dist/types/Users/maria.bumbar/Desktop/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/packages/stencil/casino-engagement-suite-tournament/stencil.config.dev.d.ts +0 -2
  45. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/libs/common/src/storybook/storybook-utils.d.ts +0 -0
  46. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/packages/stencil/casino-engagement-suite-tournament/storybook/main.d.ts +0 -0
  47. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/packages/stencil/casino-engagement-suite-tournament/storybook/preview.d.ts +0 -0
  48. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/tools/plugins/index.d.ts +0 -0
  49. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/tools/plugins/stencil-clean-deps-plugin.d.ts +0 -0
  50. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/tools/plugins/vite-chunk-plugin.d.ts +0 -0
  51. /package/dist/types/Users/{maria.bumbar/Desktop → adrian.pripon/Documents/Work}/widgets-monorepo/packages/stencil/casino-engagement-suite-tournament/.stencil/tools/plugins/vite-clean-deps-plugin.d.ts +0 -0
@@ -1,4 +1,4 @@
1
- import { h, H as Host, r as registerInstance, c as createEvent } from './index-e8e1e68e.js';
1
+ import { h, H as Host, r as registerInstance, c as createEvent } from './index-ac437a77.js';
2
2
  import '@everymatrix/general-animation-loading/dist';
3
3
 
4
4
  /*! *****************************************************************************
@@ -54,10 +54,10 @@ const TRANSLATIONS = Object.assign(Object.assign(Object.assign({ Join: 'Join', U
54
54
  Tile: 'Congratulations!',
55
55
  Description: 'You won <span>{tournamentName}</span>!',
56
56
  ButtonContinue: 'Continue'
57
- }, NoLeaderboards: 'No Leaderboards yet', NoLeaderboardsTip: 'Try winning tickets to Leaderboards as rewards or launching other booster games', Leaderboards: 'Leaderboards', TipPrize: 'You took <span>{place}</span> place and win <span>{prize}</span>', Tip: 'Competition where your real money bets contribute towards the leaderboard score calculation to win the leaderboard reward.', TournamentNotStarted: 'The leaderboard is not started yet. <br> It will start in {startTime}.', BeOne: 'No winners for the time being. Be one of them!' });
57
+ }, NoLeaderboards: 'No Leaderboards yet', NoLeaderboardsTip: 'Try winning tickets to Leaderboards as rewards or launching other booster games', Leaderboards: 'Leaderboards', TipPrize: 'You took <span>{place}</span> place and win <span>{prize}</span>', Tip: 'Competition where your real money bets contribute towards the leaderboard score calculation to win the leaderboard reward.', TournamentNotStarted: 'The leaderboard is not started yet. <br> It will start in {startTime}.', BeOne: 'No winners for the time being. Be one of them!', FailedToJoin: 'Oops! some unexpected error happened, please try it again.', FailedToUnjoin: 'Oops! some unexpected error happened, please try it again.' });
58
58
 
59
59
  const classnames = (...args) => {
60
- let classnameArray = [];
60
+ let classnameArray = ['Tab'];
61
61
  args.map((arg) => {
62
62
  switch (typeof arg) {
63
63
  case 'string':
@@ -106,6 +106,33 @@ const truncateNumber = (value, decimals, isInteger = false) => {
106
106
  // Return string representation with fixed decimals to preserve trailing zeros
107
107
  return truncated.toFixed(decimals);
108
108
  };
109
+ const getDevice = () => {
110
+ let userAgent = window.navigator.userAgent;
111
+ if (userAgent.toLowerCase().match(/android/i)) {
112
+ return 'Android';
113
+ }
114
+ if (userAgent.toLowerCase().match(/iphone/i)) {
115
+ return 'iPhone';
116
+ }
117
+ if (userAgent.toLowerCase().match(/ipad|ipod/i)) {
118
+ return 'iPad';
119
+ }
120
+ return 'PC';
121
+ };
122
+ const getDevicePlatform = () => {
123
+ const device = getDevice();
124
+ if (device) {
125
+ if (device === 'PC') {
126
+ return 'dk';
127
+ }
128
+ else if (device === 'iPad' || device === 'iPhone') {
129
+ return 'ios';
130
+ }
131
+ else {
132
+ return 'mtWeb';
133
+ }
134
+ }
135
+ };
109
136
 
110
137
  var LeaderboardPage;
111
138
  (function (LeaderboardPage) {
@@ -124,6 +151,7 @@ var DialogType;
124
151
  DialogType["unjoin"] = "unjoin";
125
152
  DialogType["tip"] = "tip";
126
153
  DialogType["gift"] = "gift";
154
+ DialogType["error"] = "error";
127
155
  })(DialogType || (DialogType = {}));
128
156
 
129
157
  const getMaxRankStr = (list) => {
@@ -154,12 +182,14 @@ const isTournamentClosed = (tournament) => {
154
182
  return [TournamentState.Closed, TournamentState.Closing].includes(tournament.state);
155
183
  };
156
184
 
185
+ const rewardSvg = '';
186
+
157
187
  const iconClose = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/close.svg" });
158
188
  const iconQuestion = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/help.svg" });
159
189
  const iconEyeOpen = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-open.svg" });
160
190
  const iconEyeClose = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-closed.svg" });
161
191
  const iconBack = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/back.svg" });
162
- const iconReward = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/reward.svg" });
192
+ const iconReward = h("img", { src: rewardSvg, alt: "reward", class: "Reward" });
163
193
  const iconTrophy = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/cup-congras.svg" });
164
194
 
165
195
  const renderGradientRoundedButton = (_a) => {
@@ -178,7 +208,7 @@ var GradientButton;
178
208
  GradientButton["unjoinYes"] = "unjoinYes";
179
209
  GradientButton["unjoinNo"] = "unjoinNo";
180
210
  })(GradientButton || (GradientButton = {}));
181
- const renderButton = (instance, buttonType) => {
211
+ const renderButton = (instance, buttonType, isActionJoinPending = false) => {
182
212
  const { locale } = instance;
183
213
  const buttonCollector = {
184
214
  normal: {
@@ -197,7 +227,7 @@ const renderButton = (instance, buttonType) => {
197
227
  };
198
228
  const props = buttonCollector[buttonType];
199
229
  return renderGradientRoundedButton({
200
- statedClasses: Object.assign({ isPending: instance.isActionJoinPending }, props.statedClasses),
230
+ statedClasses: Object.assign({ isPending: isActionJoinPending }, props.statedClasses),
201
231
  onClick: () => {
202
232
  var _a;
203
233
  (_a = props.onClick) === null || _a === void 0 ? void 0 : _a.call();
@@ -254,7 +284,7 @@ const leaderboardsAdapter = (leaderboardRes) => {
254
284
  return leaderboards;
255
285
  }
256
286
  return leaderboards.map((leaderboard) => {
257
- if (item && item.userID === leaderboard.userID) {
287
+ if ((item === null || item === void 0 ? void 0 : item.userId) && item.userId === leaderboard.userId) {
258
288
  return Object.assign(Object.assign({}, leaderboard), { isMe: true });
259
289
  }
260
290
  else {
@@ -303,26 +333,42 @@ const renderTimeBar = (tournament) => {
303
333
  return (h("section", { class: "TimeContainer" },
304
334
  h("div", { class: "Time" }, tournament.state === 'Running'
305
335
  ? [
306
- h("div", null, getTimeDifference(new Date(), tournament.endTime)),
307
- h("div", null, renderGradientRoundedButton({
308
- statedClasses: {
309
- isHollow: true,
310
- isPendding: false
311
- },
312
- innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
313
- }))
336
+ h("div", { class: 'Running' },
337
+ h("div", null, getTimeDifference(new Date(), tournament.endTime)),
338
+ ",",
339
+ h("div", null, renderGradientRoundedButton({
340
+ statedClasses: {
341
+ isHollow: true,
342
+ isPendding: false
343
+ },
344
+ innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
345
+ })))
314
346
  ]
315
- : [h("div", null, formatDate(tournament.startTime)), h("div", null, formatDate(tournament.endTime))]),
347
+ : [h("div", { class: 'NotRunning' }, formatDate(tournament.startTime)), h("div", null, formatDate(tournament.endTime))]),
316
348
  h("casino-engagement-suite-progress-bar", { value: Number(getProgress(tournament.startTime, tournament.endTime)), "hide-percent": true })));
317
349
  };
318
350
 
319
351
  const messageSender = {
352
+ InitTournamentList: (queryParams) => {
353
+ window.postMessage(Object.assign({ type: 'InitTournamentList' }, queryParams));
354
+ },
355
+ post: (options) => {
356
+ window.postMessage(Object.assign({}, options));
357
+ },
320
358
  UpdateSuiteBarState: (labels) => window.postMessage({ type: 'UpdateLeaderboardState', labels }),
321
- JoinTournamentReq: (tournament) => { var _a, _b; return window.postMessage({ type: 'JoinTournamentReq', bonusCode: (_b = (_a = tournament.wallets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.code }); },
359
+ JoinTournamentReq: (tournament) => {
360
+ var _a, _b;
361
+ return window.postMessage({
362
+ type: 'JoinTournamentReq',
363
+ id: tournament.id,
364
+ bonusCode: tournament.id || ((_b = (_a = tournament.wallets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.code)
365
+ });
366
+ },
322
367
  UnjoinTournamentReq: (tournament) => window.postMessage({ type: 'UnjoinTournamentReq', id: tournament.id }),
323
368
  UpdateTournamentsItemReq: (tournament) => window.postMessage({ type: 'UpdateTournamentsItemReq', id: tournament.id }),
324
369
  UpdateLeaderboardsReq: (tournament, query) => window.postMessage({ type: 'UpdateLeaderboardsReq', id: tournament.id, query }),
325
- UpdateLeaderboardsPlayerReq: () => window.postMessage({ type: 'UpdateLeaderboardsPlayerReq' })
370
+ UpdateLeaderboardsPlayerReq: () => window.postMessage({ type: 'UpdateLeaderboardsPlayerReq' }),
371
+ GameClickReq: (game) => window.postMessage({ type: 'EngagementSuiteGameRedirect', data: { Slug: game.slug } }),
326
372
  };
327
373
  const messageReceiver = (instance) => {
328
374
  const receiver = {
@@ -338,15 +384,13 @@ const messageReceiver = (instance) => {
338
384
  instance.tournamentItem = tournamentNew;
339
385
  updateTournamentListByItem(instance, tournamentNew);
340
386
  },
341
- UpdateLeaderboardsRes: (rest) => {
342
- instance.leaderboards = leaderboardsAdapter(rest.data);
343
- },
387
+ UpdateLeaderboardsRes: (rest) => processLeaderboardTableData(instance, rest),
344
388
  JoinTournamentRes: (rest) => commonJoinRes(instance, rest),
345
389
  UnjoinTournamentRes: (rest) => commonJoinRes(instance, rest),
346
390
  // listen to LeaderboardLiveEvent event, handle update
347
391
  LeaderboardLiveEvent: (rest) => {
348
392
  handleLeaderboardLiveEvent(instance, rest);
349
- }
393
+ },
350
394
  };
351
395
  return receiver;
352
396
  };
@@ -424,25 +468,30 @@ const handleLeaderboardLiveEvent = (instance, rest) => {
424
468
  }
425
469
  }
426
470
  };
471
+ const showErrorMessage = (instance, type) => {
472
+ instance.dialog = Object.assign(Object.assign({}, instance.dialog), { isOpen: true, type });
473
+ };
427
474
  const commonJoinRes = (instance, rest) => {
428
- const { success } = rest;
429
- if (success) {
430
- instance.tournamentItem = Object.assign(Object.assign({}, instance.tournamentItem), { isPlayerAcknowledged: !!!instance.tournamentItem.isPlayerAcknowledged });
431
- switch (instance.page) {
432
- case LeaderboardPage.item: {
433
- break;
434
- }
435
- case LeaderboardPage.list: {
436
- updateTournamentListByItem(instance, instance.tournamentItem);
437
- break;
438
- }
439
- }
475
+ const { success, data } = rest;
476
+ let tournamentIdx = instance.tournamentList.findIndex((tournament) => tournament.id === (data.tournamentId || data.id || data.bonusCode)), current = instance.tournamentList[tournamentIdx];
477
+ current.isActionJoinPending = false;
478
+ if (!success) {
479
+ instance.tournamentList[tournamentIdx] = current;
480
+ instance.tournamentList = [...instance.tournamentList];
481
+ showErrorMessage(instance, DialogType.error);
482
+ return;
440
483
  }
484
+ current = Object.assign(Object.assign({}, current), { isUnjoined: current.isPlayerAcknowledged ? true : false, isPlayerAcknowledged: !!!current.isPlayerAcknowledged });
485
+ instance.tournamentList[tournamentIdx] = current;
486
+ instance.tournamentList = [...instance.tournamentList];
441
487
  if (instance.nextPage) {
442
488
  instance.setPage(instance.nextPage);
443
489
  instance.nextPage = undefined;
444
490
  }
445
- instance.isActionJoinPending = false;
491
+ };
492
+ const processLeaderboardTableData = (instance, rest) => {
493
+ instance.leaderboards = leaderboardsAdapter(rest.data);
494
+ instance.currentPlyerRank = rest.data.item ? rest.data.item.rank : -1;
446
495
  };
447
496
  const updateTournamentListByItem = (instance, tournament) => {
448
497
  instance.tournamentList = instance.tournamentList.map((_tournament) => {
@@ -470,7 +519,7 @@ const updateOrAddTournamentToList = (instance, tournament) => {
470
519
  const page = {
471
520
  list(instance) {
472
521
  var _a;
473
- if (!instance.tournamentList) {
522
+ if (!(instance === null || instance === void 0 ? void 0 : instance.tournamentList)) {
474
523
  instance.tournamentList = (_a = instance.leaderboardsInit) === null || _a === void 0 ? void 0 : _a.map((item) => tournamentAdapter(item));
475
524
  return h("general-animation-loading", null);
476
525
  }
@@ -480,7 +529,7 @@ const page = {
480
529
  instance.setPage(LeaderboardPage.item, { tournament });
481
530
  instance.newIdList = instance.newIdList.filter((id) => id !== tournament.id);
482
531
  };
483
- return renderLeaderboardContainer(instance, h("div", { class: "Leaderboards Row" }, instance.tournamentList.map((_tournament) => (h("div", { class: classnames('LeaderboardsItem', _tournament.isPlayerAcknowledged ? ' GradientRounded Hollow' : ''), onClick: () => onClickListItemChangePage(_tournament) },
532
+ 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) },
484
533
  h("div", { class: "LeaderboardsItemContainer" },
485
534
  renderTitleContainer(instance, _tournament),
486
535
  renderTimeBar(_tournament)),
@@ -489,8 +538,8 @@ const page = {
489
538
  }
490
539
  else {
491
540
  return renderLeaderboardContainer(instance, h("div", { class: "NoLeaderboards Row" },
492
- h("div", null, locale.NoLeaderboards),
493
- h("div", null, locale.NoLeaderboardsTip)));
541
+ h("h3", { class: 'Title' }, locale.NoLeaderboards),
542
+ h("div", { class: 'message' }, locale.NoLeaderboardsTip)));
494
543
  }
495
544
  },
496
545
  item(instance) {
@@ -517,7 +566,7 @@ const page = {
517
566
  return renderLeaderboardContainer(instance, [
518
567
  renderTitleContainer(instance, instance.tournamentItem),
519
568
  renderTabs(),
520
- instance.renders.tab[instance.tab]()
569
+ h("div", { class: `TableContentWrapper ${instance.tab}` }, instance.renders.tab[instance.tab]())
521
570
  ]);
522
571
  }
523
572
  };
@@ -537,11 +586,11 @@ const renderTitleContainer = (instance, tournament) => {
537
586
  tournament.state !== TournamentState.Closed && (h("div", null, renderGradientRoundedButton({
538
587
  statedClasses: {
539
588
  isHollow: tournament.isPlayerAcknowledged,
540
- isPending: instance.isActionJoinPending
589
+ isPending: tournament.isActionJoinPending
541
590
  },
542
591
  onClick: (e) => {
543
592
  e.stopPropagation();
544
- if (!instance.isActionJoinPending) {
593
+ if (!tournament.isActionJoinPending) {
545
594
  onClickItemJoin(tournament);
546
595
  }
547
596
  },
@@ -556,9 +605,11 @@ const renderLeaderboardContainer = (instance, render) => {
556
605
  const renderDialogContent = () => {
557
606
  switch (instance.dialog.type) {
558
607
  case DialogType.unjoin:
559
- return instance.renders.dialog.unjoin(); //renderDialogContentUnjoin()
608
+ return instance.renders.dialog.unjoin();
560
609
  case DialogType.tip:
561
610
  return h("div", { class: "Tip" }, instance.locale.Tip);
611
+ case DialogType.error:
612
+ return h("div", { class: "Tip Error" }, instance.locale.FailedToJoin);
562
613
  case DialogType.gift:
563
614
  return instance.renders.dialog.gift();
564
615
  }
@@ -568,7 +619,9 @@ const renderLeaderboardContainer = (instance, render) => {
568
619
  switch (page) {
569
620
  case LeaderboardPage.list:
570
621
  return {
571
- left: h("span", { onClick: () => instance.openDialog(DialogType.tip) }, iconQuestion),
622
+ left: h("span", { onClick: () => instance.openDialog(DialogType.tip), onMouseEnter: () => { instance.showTooltip = true; }, onMouseLeave: () => { instance.showTooltip = false; }, ref: (el) => instance.tooltipIconReference = el },
623
+ iconQuestion,
624
+ instance.renderTooltip()),
572
625
  middle: locale.Leaderboards
573
626
  };
574
627
  case LeaderboardPage.item:
@@ -592,7 +645,7 @@ const renderLeaderboardContainer = (instance, render) => {
592
645
  h("div", { class: "Root" },
593
646
  h("div", { class: "Main" }, render))),
594
647
  h("div", { class: "WrapperUtil" },
595
- h("dialog", { open: isOpen },
648
+ h("dialog", { open: isOpen, style: { 'top': instance.getContainerScrollTop() + 'px' } },
596
649
  h("div", { class: "GradientRounded Hollow" },
597
650
  renderBar,
598
651
  isOpen && renderDialogContent())))));
@@ -605,12 +658,12 @@ const tab = {
605
658
  return (h("div", { class: "InfoContainer" },
606
659
  renderTimeBar(tournament),
607
660
  h("section", { class: "ShowInfo", onClick: () => (instance.isShowInfo = !instance.isShowInfo) },
608
- h("p", null,
609
- h("span", null, isShowInfo ? iconEyeClose : iconEyeOpen),
661
+ h("div", { class: 'DetailHeader' },
662
+ h("span", null, isShowInfo ? iconEyeOpen : iconEyeClose),
610
663
  h("span", null, locale.LeaderboardDetails))),
611
664
  h("div", { class: `ContentScrollContainer ${isShowInfo ? 'expanded' : ''}` },
612
665
  isShowInfo && (h("section", { class: "Info" },
613
- h("div", null, tournament.description),
666
+ h("div", { class: 'Description' }, tournament.description),
614
667
  h("div", { class: "Criterias" },
615
668
  h("div", null,
616
669
  locale.ScoreCriteria,
@@ -654,7 +707,9 @@ const tab = {
654
707
  },
655
708
  games(instance) {
656
709
  var _a;
657
- return (h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (h("div", null,
710
+ return (h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (h("div", { class: 'Game', onClick: () => {
711
+ instance.onGameClick(game);
712
+ } },
658
713
  h("img", { src: game.defaultThumbnail, alt: "" }))))));
659
714
  }
660
715
  };
@@ -671,7 +726,7 @@ const renders = {
671
726
  tab
672
727
  };
673
728
 
674
- const casinoEngagementSuiteTournamentCss = ".Wrapper{height:100%;position:relative;color:var(--emw--color-typography, #FFFFFF);display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));flex-direction:column;border-radius:24px;overflow-y:auto}.Wrapper.Mobile{border-radius:16px}.WrapperContent{padding-bottom:20px;transition:0.5s filter}.WrapperContent.faded{filter:brightness(53.3333333333%)}.Wrapper.Mobile .WrapperBar{padding:20px 8px 8px;margin-bottom:8px}.WrapperBar{display:flex;width:100%;padding:32px 20px 20px;margin-bottom:20px}.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:24px 0;padding:0 20px}.Row:first-child{margin:0}.LeaderboardsItem{position:relative;margin:10px 0;border:1px solid rgb(64, 57, 86);border-radius:16px}.LeaderboardsItem.Hollow{border-color:transparent}.LeaderboardsItem:first-child{margin-top:0}.LeaderboardsItemContainer{padding-top:16px}.Info{margin:24px 0;padding:0 20px}.TimeContainer{margin:24px 0;padding:0 20px}.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}.ShowInfo{margin:24px 0;padding:0 20px;cursor:pointer;color:rgb(102, 97, 120)}.ShowInfo p{display:flex;gap:4px}.TitleContainer{display:flex;justify-content:space-between;margin:24px 0;padding:0 20px;margin-top:0;gap:10px;font-family:Montserrat}.TitleContainer .GradientRoundedButton{width:120px}.TabsContainer{margin:24px 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>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:24px 0;padding:0 20px}.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{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{width:12px}.PrizesHeader .PrizesText{margin-left:3px;font-weight:600}.Prizes{margin:24px 0;padding:0 20px;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}*{box-sizing:border-box}.Leaderboards{width:100%;text-align:center;border-collapse:collapse}.Leaderboards td{opacity:0.6;padding:20px 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)}.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:#FFD029;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:24px 0;padding:0 20px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-medium, 16px)}.Games{margin:24px 0;padding:0 20px;display:flex;flex-wrap:wrap;justify-content:space-evenly;gap:4px 7.25px}.Games img{width:60px}dialog{position:absolute;top:30px;width:100%;height:100%;background:transparent;border:0;padding:0;color:var(--emw--color-typography, #FFFFFF)}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)}.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}";
729
+ 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}}";
675
730
  const CasinoEngagementSuiteTournamentStyle0 = casinoEngagementSuiteTournamentCss;
676
731
 
677
732
  const CasinoEngagementSuiteTournament = class {
@@ -739,17 +794,57 @@ const CasinoEngagementSuiteTournament = class {
739
794
  this.removeLabel('win');
740
795
  }
741
796
  }
797
+ getContainerScrollTop() {
798
+ return this.page === LeaderboardPage.list ? this.containerScrollTop : this.detailElement.clientHeight / 2 - 250;
799
+ }
800
+ handleClickOutside(event) {
801
+ if (event.composedPath()[0] === this.tooltipIconReference)
802
+ return;
803
+ if (event.composedPath()[0] !== this.tooltipReference)
804
+ this.showTooltip = false;
805
+ }
806
+ componentDidLoad() {
807
+ this.pageElement.addEventListener('scroll', (event) => {
808
+ this.containerScrollTop = event.target.scrollTop + event.target.clientHeight / 2 - 250;
809
+ });
810
+ }
811
+ renderTooltip() {
812
+ if (this.showTooltip) {
813
+ return (h("div", { class: `question__tooltip ${this.showTooltip ? 'visible' : ''}`, ref: (el) => this.tooltipReference = el, innerHTML: this.locale.Tip }));
814
+ }
815
+ return null;
816
+ }
742
817
  connectedCallback() {
743
818
  this.setTimeInterval();
744
819
  messageSender.UpdateLeaderboardsPlayerReq();
745
820
  }
821
+ scrollToMyRankLine() {
822
+ if (!this.detailElement.querySelectorAll('.isMe').length) {
823
+ return;
824
+ }
825
+ (this.detailElement.querySelectorAll('.TableContentWrapper.leaderboard')[0]).scrollTo({ top: this.detailElement.querySelectorAll('.isMe')[0].offsetTop, behavior: 'smooth' });
826
+ this.scrolledToMyLine = true;
827
+ }
828
+ componentDidRender() {
829
+ if (this.page === LeaderboardPage.item && this.tab === Tab.leaderboard && !this.scrolledToMyLine) {
830
+ if (this.currentPlyerRank > this.maxPlyerRank) {
831
+ this.scrollToMyRankLine();
832
+ }
833
+ }
834
+ else {
835
+ this.scrolledToMyLine = false;
836
+ }
837
+ }
746
838
  disconnectedCallback() {
747
839
  clearInterval(this.timeHolder);
748
840
  }
841
+ onGameClick(game) {
842
+ messageSender.GameClickReq(game);
843
+ }
749
844
  actionJoin(tournament) {
750
- if (this.isActionJoinPending)
845
+ if (tournament.isActionJoinPending)
751
846
  return;
752
- this.isActionJoinPending = true;
847
+ tournament.isActionJoinPending = true;
753
848
  try {
754
849
  if (tournament.isPlayerAcknowledged) {
755
850
  messageSender.UnjoinTournamentReq(tournament);
@@ -767,6 +862,17 @@ const CasinoEngagementSuiteTournament = class {
767
862
  if (page == LeaderboardPage.item) {
768
863
  this.tournamentItem = metaData.tournament;
769
864
  if (!this.tournamentItem) {
865
+ messageSender.post({
866
+ type: 'GetTournamentGamesById',
867
+ pathParams: { id: metaData.tournament.id },
868
+ payload: {
869
+ expand: 'games',
870
+ pagination: 'games(limit=50,offset=0)',
871
+ fields: 'games(id,name,thumbnail,launchUrl)',
872
+ platform: getDevicePlatform(),
873
+ language: this.language
874
+ }
875
+ });
770
876
  messageSender.UpdateTournamentsItemReq(metaData.tournament);
771
877
  }
772
878
  if (isTournamentClosed(this.tournamentItem)) {
@@ -777,9 +883,9 @@ const CasinoEngagementSuiteTournament = class {
777
883
  this.page = page;
778
884
  }
779
885
  render() {
780
- return (h(Host, { key: 'b070d8a83bcd801d5daeb4edfe87ad0159da4e7c' }, h("general-styling-wrapper", { key: '7454fdab7ee55ab95a39adb3c8b51aed0b78f534', clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
886
+ return (h(Host, { key: '5a65900ecb503dd01f8f39774b92a6e95048dbf3' }, h("general-styling-wrapper", { key: '58cee35cf4142512e9b49566787b48cbc2761a4a', clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
781
887
  // @ts-ignore
782
- targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), this.renders.page[this.page]()));
888
+ 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())));
783
889
  }
784
890
  openDialog(type, data = undefined, onClose = undefined) {
785
891
  this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: true, onClose,
@@ -796,6 +902,9 @@ const CasinoEngagementSuiteTournament = class {
796
902
  this.close = createEvent(this, "close", 7);
797
903
  this.gifts = [];
798
904
  this.labels = [];
905
+ this.showTooltip = false;
906
+ this.maxPlyerRank = 30;
907
+ this.scrolledToMyLine = false;
799
908
  this.language = 'en';
800
909
  this.show = false;
801
910
  this.clientStyling = '';
@@ -808,7 +917,6 @@ const CasinoEngagementSuiteTournament = class {
808
917
  this.tournamentItem = undefined;
809
918
  this.tournamentList = undefined;
810
919
  this.leaderboards = [];
811
- this.isActionJoinPending = false;
812
920
  this.isDialogOpen = false;
813
921
  this.isShowInfo = false;
814
922
  this.page = LeaderboardPage.list;
@@ -1,5 +1,5 @@
1
- import { p as promiseResolve, b as bootstrapLazy } from './index-e8e1e68e.js';
2
- export { s as setNonce } from './index-e8e1e68e.js';
1
+ import { p as promiseResolve, b as bootstrapLazy } from './index-ac437a77.js';
2
+ export { s as setNonce } from './index-ac437a77.js';
3
3
  import { g as globalScripts } from './app-globals-0f993ce5.js';
4
4
 
5
5
  /*
@@ -16,5 +16,5 @@ var patchBrowser = () => {
16
16
 
17
17
  patchBrowser().then(async (options) => {
18
18
  await globalScripts();
19
- return bootstrapLazy([["casino-engagement-suite-progress-bar_3",[[1,"casino-engagement-suite-tournament",{"language":[1],"show":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"device":[1],"leaderboardsInit":[16],"tab":[32],"locale":[32],"tournamentItem":[32],"tournamentList":[32],"leaderboards":[32],"isActionJoinPending":[32],"isDialogOpen":[32],"isShowInfo":[32],"page":[32],"tournamentInDialog":[32],"dialog":[32],"time":[32],"newIdList":[32]},[[8,"message","handleEvent"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[1,"casino-engagement-suite-progress-bar",{"value":[2],"disabled":[4],"hidePercent":[4,"hide-percent"],"indeterminate":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"limitStylingAppends":[32]}],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}]]]], options);
19
+ return bootstrapLazy([["casino-engagement-suite-progress-bar_3",[[1,"casino-engagement-suite-tournament",{"language":[1],"show":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"device":[1],"leaderboardsInit":[16],"tab":[32],"locale":[32],"tournamentItem":[32],"tournamentList":[32],"leaderboards":[32],"isDialogOpen":[32],"isShowInfo":[32],"page":[32],"tournamentInDialog":[32],"dialog":[32],"time":[32],"newIdList":[32]},[[8,"message","handleEvent"],[4,"click","handleClickOutside"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[1,"casino-engagement-suite-progress-bar",{"value":[2],"disabled":[4],"hidePercent":[4,"hide-percent"],"indeterminate":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"limitStylingAppends":[32]}],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}]]]], options);
20
20
  });
@@ -1,5 +1,5 @@
1
1
  const NAMESPACE = 'casino-engagement-suite-tournament';
2
- const BUILD = /* casino-engagement-suite-tournament */ { allRenderFn: true, appendChildSlotFix: false, asyncLoading: true, asyncQueue: false, attachStyles: true, cloneNodeFix: false, cmpDidLoad: false, cmpDidRender: true, cmpDidUnload: false, cmpDidUpdate: false, cmpShouldUpdate: false, cmpWillLoad: true, cmpWillRender: false, cmpWillUpdate: false, connectedCallback: true, constructableCSS: true, cssAnnotations: true, devTools: false, disconnectedCallback: true, element: false, event: true, experimentalScopedSlotChanges: false, experimentalSlotFixes: false, formAssociated: false, hasRenderFn: true, hostListener: true, hostListenerTarget: true, hostListenerTargetBody: false, hostListenerTargetDocument: false, hostListenerTargetParent: false, hostListenerTargetWindow: true, hotModuleReplacement: false, hydrateClientSide: false, hydrateServerSide: false, hydratedAttribute: false, hydratedClass: true, hydratedSelectorName: "hydrated", initializeNextTick: false, invisiblePrehydration: true, isDebug: false, isDev: false, isTesting: false, lazyLoad: true, lifecycle: true, lifecycleDOMEvents: false, member: true, method: false, mode: false, observeAttribute: true, profile: false, prop: true, propBoolean: true, propMutable: false, propNumber: true, propString: true, reflect: true, scoped: false, scopedSlotTextContentFix: false, scriptDataOpts: false, shadowDelegatesFocus: false, shadowDom: true, slot: true, slotChildNodesFix: false, slotRelocation: true, state: true, style: true, svg: false, taskQueue: true, transformTagName: false, updatable: true, vdomAttribute: true, vdomClass: true, vdomFunctional: false, vdomKey: true, vdomListener: true, vdomPropOrAttr: true, vdomRef: true, vdomRender: true, vdomStyle: true, vdomText: true, vdomXlink: true, watchCallback: true };
2
+ const BUILD = /* casino-engagement-suite-tournament */ { allRenderFn: true, appendChildSlotFix: false, asyncLoading: true, asyncQueue: false, attachStyles: true, cloneNodeFix: false, cmpDidLoad: true, cmpDidRender: true, cmpDidUnload: false, cmpDidUpdate: false, cmpShouldUpdate: false, cmpWillLoad: true, cmpWillRender: false, cmpWillUpdate: false, connectedCallback: true, constructableCSS: true, cssAnnotations: true, devTools: false, disconnectedCallback: true, element: false, event: true, experimentalScopedSlotChanges: false, experimentalSlotFixes: false, formAssociated: false, hasRenderFn: true, hostListener: true, hostListenerTarget: true, hostListenerTargetBody: false, hostListenerTargetDocument: true, hostListenerTargetParent: false, hostListenerTargetWindow: true, hotModuleReplacement: false, hydrateClientSide: false, hydrateServerSide: false, hydratedAttribute: false, hydratedClass: true, hydratedSelectorName: "hydrated", initializeNextTick: false, invisiblePrehydration: true, isDebug: false, isDev: false, isTesting: false, lazyLoad: true, lifecycle: true, lifecycleDOMEvents: false, member: true, method: false, mode: false, observeAttribute: true, profile: false, prop: true, propBoolean: true, propMutable: false, propNumber: true, propString: true, reflect: true, scoped: false, scopedSlotTextContentFix: false, scriptDataOpts: false, shadowDelegatesFocus: false, shadowDom: true, slot: true, slotChildNodesFix: false, slotRelocation: true, state: true, style: true, svg: false, taskQueue: true, transformTagName: false, updatable: true, vdomAttribute: true, vdomClass: true, vdomFunctional: false, vdomKey: true, vdomListener: true, vdomPropOrAttr: true, vdomRef: true, vdomRender: true, vdomStyle: true, vdomText: true, vdomXlink: true, watchCallback: true };
3
3
 
4
4
  /*
5
5
  Stencil Client Platform v4.19.2 | MIT Licensed | https://stenciljs.com
@@ -1110,6 +1110,9 @@ var postUpdateComponent = (hostRef) => {
1110
1110
  {
1111
1111
  addHydratedFlag(elm);
1112
1112
  }
1113
+ {
1114
+ safeCall(instance, "componentDidLoad");
1115
+ }
1113
1116
  endPostUpdate();
1114
1117
  {
1115
1118
  hostRef.$onReadyResolve$(elm);
@@ -1558,6 +1561,7 @@ var hostListenerProxy = (hostRef, methodName) => (ev) => {
1558
1561
  }
1559
1562
  };
1560
1563
  var getHostListenerTarget = (elm, flags) => {
1564
+ if (flags & 4 /* TargetDocument */) return doc;
1561
1565
  if (flags & 8 /* TargetWindow */) return win;
1562
1566
  return elm;
1563
1567
  };
package/dist/esm/index.js CHANGED
@@ -1,3 +1,3 @@
1
- export { C as CasinoEngagementSuiteTournament } from './casino-engagement-suite-tournament-e9186545.js';
2
- import './index-e8e1e68e.js';
1
+ export { C as CasinoEngagementSuiteTournament } from './casino-engagement-suite-tournament-bd7c9cdd.js';
2
+ import './index-ac437a77.js';
3
3
  import '@everymatrix/general-animation-loading/dist';
@@ -1,11 +1,11 @@
1
- import { b as bootstrapLazy } from './index-e8e1e68e.js';
2
- export { s as setNonce } from './index-e8e1e68e.js';
1
+ import { b as bootstrapLazy } from './index-ac437a77.js';
2
+ export { s as setNonce } from './index-ac437a77.js';
3
3
  import { g as globalScripts } from './app-globals-0f993ce5.js';
4
4
 
5
5
  const defineCustomElements = async (win, options) => {
6
6
  if (typeof window === 'undefined') return undefined;
7
7
  await globalScripts();
8
- return bootstrapLazy([["casino-engagement-suite-progress-bar_3",[[1,"casino-engagement-suite-tournament",{"language":[1],"show":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"device":[1],"leaderboardsInit":[16],"tab":[32],"locale":[32],"tournamentItem":[32],"tournamentList":[32],"leaderboards":[32],"isActionJoinPending":[32],"isDialogOpen":[32],"isShowInfo":[32],"page":[32],"tournamentInDialog":[32],"dialog":[32],"time":[32],"newIdList":[32]},[[8,"message","handleEvent"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[1,"casino-engagement-suite-progress-bar",{"value":[2],"disabled":[4],"hidePercent":[4,"hide-percent"],"indeterminate":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"limitStylingAppends":[32]}],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}]]]], options);
8
+ return bootstrapLazy([["casino-engagement-suite-progress-bar_3",[[1,"casino-engagement-suite-tournament",{"language":[1],"show":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"device":[1],"leaderboardsInit":[16],"tab":[32],"locale":[32],"tournamentItem":[32],"tournamentList":[32],"leaderboards":[32],"isDialogOpen":[32],"isShowInfo":[32],"page":[32],"tournamentInDialog":[32],"dialog":[32],"time":[32],"newIdList":[32]},[[8,"message","handleEvent"],[4,"click","handleClickOutside"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[1,"casino-engagement-suite-progress-bar",{"value":[2],"disabled":[4],"hidePercent":[4,"hide-percent"],"indeterminate":[4],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"limitStylingAppends":[32]}],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}]]]], options);
9
9
  };
10
10
 
11
11
  export { defineCustomElements };
@@ -0,0 +1,2 @@
1
+ import { Config } from '../../../../../../../../../../../../stencil-public-runtime';
2
+ export declare const config: Config;
@@ -0,0 +1,2 @@
1
+ import { Config } from '../../../../../../../../../../../../stencil-public-runtime';
2
+ export declare const config: Config;