@everymatrix/casino-engagement-suite-tournament 1.63.0 → 1.63.1

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 (35) 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-d24f1017.entry.js +1 -0
  4. package/dist/casino-engagement-suite-tournament/p-f478f260.js +15 -0
  5. package/dist/cjs/casino-engagement-suite-progress-bar_6.cjs.entry.js +110 -112
  6. package/dist/cjs/{casino-engagement-suite-tournament-1f1275c4.js → casino-engagement-suite-tournament-785dd5cc.js} +31 -56
  7. package/dist/cjs/casino-engagement-suite-tournament.cjs.js +1 -1
  8. package/dist/cjs/index.cjs.js +1 -1
  9. package/dist/cjs/loader.cjs.js +1 -1
  10. package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.css +6 -1
  11. package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.js +26 -6
  12. package/dist/collection/shared/TournamentDurationTimer.js +45 -24
  13. package/dist/collection/shared/TournamentItem.js +10 -20
  14. package/dist/collection/shared/TournamentItemTitle.js +9 -7
  15. package/dist/collection/shared/renders.page.js +2 -2
  16. package/dist/collection/shared/renders.tab.js +1 -2
  17. package/dist/collection/utils/bussiness.js +6 -18
  18. package/dist/collection/utils/message.js +11 -7
  19. package/dist/esm/casino-engagement-suite-progress-bar_6.entry.js +109 -111
  20. package/dist/esm/{casino-engagement-suite-tournament-54c513f1.js → casino-engagement-suite-tournament-3be75bd2.js} +28 -54
  21. package/dist/esm/casino-engagement-suite-tournament.js +1 -1
  22. package/dist/esm/index.js +1 -1
  23. package/dist/esm/loader.js +1 -1
  24. package/dist/types/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.d.ts +1 -0
  25. package/dist/types/components.d.ts +45 -41
  26. package/dist/types/shared/TournamentDurationTimer.d.ts +3 -2
  27. package/dist/types/shared/TournamentItem.d.ts +1 -2
  28. package/dist/types/shared/TournamentItemTitle.d.ts +1 -1
  29. package/dist/types/utils/bussiness.d.ts +1 -1
  30. package/dist/types/utils/message.d.ts +1 -1
  31. package/package.json +1 -1
  32. package/dist/casino-engagement-suite-tournament/p-14ab3c1a.entry.js +0 -1
  33. package/dist/casino-engagement-suite-tournament/p-5f051654.js +0 -15
  34. package/dist/collection/shared/renders.util.js +0 -16
  35. package/dist/types/shared/renders.util.d.ts +0 -2
@@ -113,13 +113,13 @@ exports.LeaderboardPage = void 0;
113
113
  LeaderboardPage["list"] = "list";
114
114
  LeaderboardPage["item"] = "item";
115
115
  })(exports.LeaderboardPage || (exports.LeaderboardPage = {}));
116
- exports.TournamentState = void 0;
116
+ var TournamentState;
117
117
  (function (TournamentState) {
118
118
  TournamentState["Running"] = "Running";
119
119
  TournamentState["Unstarted"] = "Unstarted";
120
120
  TournamentState["Closed"] = "Closed";
121
121
  TournamentState["Closing"] = "Closing";
122
- })(exports.TournamentState || (exports.TournamentState = {}));
122
+ })(TournamentState || (TournamentState = {}));
123
123
  exports.DialogType = void 0;
124
124
  (function (DialogType) {
125
125
  DialogType["unjoin"] = "unjoin";
@@ -128,32 +128,20 @@ exports.DialogType = void 0;
128
128
  DialogType["error"] = "error";
129
129
  })(exports.DialogType || (exports.DialogType = {}));
130
130
 
131
- const getMaxRankStr = (list) => {
132
- let itemHaveMaxRank;
133
- list.map((item) => {
131
+ const getMaxRankStr = (playerLeaderboards) => {
132
+ let bestRank = null;
133
+ (playerLeaderboards || []).map((playerLeaderboard) => {
134
134
  var _a;
135
- const rank = (_a = item.leaderBoard) === null || _a === void 0 ? void 0 : _a.rank;
135
+ const { leaderBoard: { rank } } = playerLeaderboard;
136
136
  if (!rank) {
137
137
  return;
138
138
  }
139
- if (!itemHaveMaxRank) {
140
- itemHaveMaxRank = item;
141
- return;
142
- }
143
- else {
144
- if (rank < itemHaveMaxRank.leaderBoard.rank) {
145
- itemHaveMaxRank = item;
146
- }
147
- }
139
+ bestRank = !bestRank || ((_a = bestRank.leaderBoard) === null || _a === void 0 ? void 0 : _a.rank) > rank ? playerLeaderboard : bestRank;
148
140
  });
149
- if (!itemHaveMaxRank) {
150
- return '-';
151
- }
152
- const maxRankStr = `${itemHaveMaxRank.leaderBoard.rank} / ${itemHaveMaxRank.endRank}`;
153
- return maxRankStr;
141
+ return bestRank ? `${bestRank.leaderBoard.rank} / ${bestRank.endRank}` : '-';
154
142
  };
155
143
  const isTournamentClosed = (tournament) => {
156
- return [exports.TournamentState.Closed, exports.TournamentState.Closing].includes(tournament.state);
144
+ return [TournamentState.Closed, TournamentState.Closing].includes(tournament.state);
157
145
  };
158
146
 
159
147
  const rewardSvg = '';
@@ -279,10 +267,11 @@ const leaderboardsAdapter = (leaderboardRes) => {
279
267
 
280
268
  const messageSender = {
281
269
  UpdateSuiteBarState: (labels) => window.postMessage({ type: 'UpdateLeaderboardState', labels }),
282
- JoinTournamentReq: (tournament) => window.postMessage({
283
- type: 'JoinTournamentReq',
284
- id: tournament.id,
285
- }),
270
+ JoinTournamentReq: (tournament) => {
271
+ var _a, _b;
272
+ return window.postMessage({ type: 'JoinTournamentReq', id: tournament.id,
273
+ bonusCode: tournament.id || ((_b = (_a = tournament.wallets) === null || _a === void 0 ? void 0 : _a[0]) === null || _b === void 0 ? void 0 : _b.code) });
274
+ },
286
275
  UnjoinTournamentReq: (tournament) => window.postMessage({ type: 'UnjoinTournamentReq', id: tournament.id }),
287
276
  UpdateTournamentsItemReq: (tournament) => window.postMessage({ type: 'UpdateTournamentsItemReq', id: tournament.id }),
288
277
  UpdateLeaderboardsReq: (tournament, query) => window.postMessage({ type: 'UpdateLeaderboardsReq', id: tournament.id, query }),
@@ -293,8 +282,7 @@ const messageSender = {
293
282
  const messageReceiver = (instance) => {
294
283
  const receiver = {
295
284
  UpdateLeaderboardsPlayerRes: (rest) => {
296
- const rankStr = getMaxRankStr(rest.data.items);
297
- window.postMessage({ type: 'UpdateLeaderboardState', rank: rankStr });
285
+ window.postMessage({ type: 'UpdateLeaderboardState', rank: getMaxRankStr(rest.data.items) });
298
286
  },
299
287
  UpdateLeaderboardStateReq: () => {
300
288
  window.postMessage({ type: 'UpdateLeaderboardState', labels: ['win', 'new'] });
@@ -307,7 +295,7 @@ const messageReceiver = (instance) => {
307
295
  UpdateLeaderboardsRes: (rest) => processLeaderboardTableData(instance, rest),
308
296
  JoinTournamentRes: (rest) => commonJoinRes(instance, rest),
309
297
  UnjoinTournamentRes: (rest) => commonJoinRes(instance, rest),
310
- TournamentsPageIsReadyRes: (rest) => instance.currentGameId = rest.data.GameId,
298
+ TournamentsPageIsReadyRes: (rest) => instance.currentGameId = '' + rest.data.GameId,
311
299
  // listen to LeaderboardLiveEvent event, handle update
312
300
  LeaderboardLiveEvent: (rest) => {
313
301
  handleLeaderboardLiveEvent(instance, rest);
@@ -399,6 +387,7 @@ const commonJoinRes = (instance, rest) => {
399
387
  return;
400
388
  }
401
389
  current = Object.assign(Object.assign({}, current), { isActionJoinPending: false });
390
+ instance.pendingChangeEvent.emit(current);
402
391
  if (!success) {
403
392
  instance.tournamentList[tournamentIdx] = current;
404
393
  instance.tournamentList = [...instance.tournamentList];
@@ -426,6 +415,9 @@ const processLeaderboardTableData = (instance, rest) => {
426
415
  instance.leaderboards = leaderboardsAdapter(rest.data);
427
416
  instance.currentPlyerRank = rest.data.item ? rest.data.item.rank : -1;
428
417
  };
418
+ /*
419
+ * update tournament info, include status, name or duration change
420
+ */
429
421
  const updateTournamentListByItem = (instance, tournament) => {
430
422
  instance.tournamentList = instance.tournamentList.map((_tournament) => {
431
423
  if (_tournament.id === tournament.id) {
@@ -462,7 +454,7 @@ const page = {
462
454
  }
463
455
  const { locale } = instance;
464
456
  if (instance.tournamentList.length) {
465
- return renderWrapperByPageType(index.h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament) => (index.h("casino-engagement-suite-tournament-item", { tournament: _tournament, isNew: instance.newIdList.includes(_tournament.id) })))));
457
+ return renderWrapperByPageType(index.h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament) => (index.h("tournament-item", { tournament: _tournament, isNew: instance.newIdList.includes(_tournament.id) })))));
466
458
  }
467
459
  else {
468
460
  return renderWrapperByPageType(index.h("div", { class: "NoLeaderboards ScrollBar Row" },
@@ -492,7 +484,7 @@ const page = {
492
484
  onClick: () => onClickTab(_tab) }, locale[_tab]))))));
493
485
  };
494
486
  return renderWrapperByPageType([
495
- index.h("casino-engagement-suite-tournament-item-title", { tournament: instance.tournamentItem }),
487
+ index.h("tournament-item-title", { tournament: instance.tournamentItem }),
496
488
  renderTabs(),
497
489
  index.h("div", { class: `TableContentWrapper ${instance.tab}` }, instance.renders.tab[instance.tab]())
498
490
  ]);
@@ -528,31 +520,12 @@ function getTimeDifference(startDate, endDate) {
528
520
  return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(diffMinutes).padStart(2, '0')}m`;
529
521
  }
530
522
 
531
- const renderTimeBar = (tournament) => {
532
- return (index.h("section", { class: "TimeContainer" },
533
- index.h("div", { class: "Time" }, tournament.state === 'Running'
534
- ? [
535
- index.h("div", { class: 'Running' },
536
- index.h("div", null, getTimeDifference(new Date(), tournament.endTime)),
537
- ",",
538
- index.h("div", null, renderGradientRoundedButton({
539
- statedClasses: {
540
- isHollow: true,
541
- isPendding: false
542
- },
543
- innerHTML: `${getProgress(tournament.startTime, tournament.endTime)}%`
544
- })))
545
- ]
546
- : [index.h("div", { class: 'NotRunning' }, formatDate(tournament.startTime)), index.h("div", null, formatDate(tournament.endTime))]),
547
- index.h("casino-engagement-suite-progress-bar", { value: Number(getProgress(tournament.startTime, tournament.endTime)), "hide-percent": true })));
548
- };
549
-
550
523
  const tab = {
551
524
  info(instance) {
552
525
  var _a, _b;
553
526
  const { locale, tournamentItem: tournament, isShowInfo } = instance;
554
527
  return (index.h("div", { class: "InfoContainer" },
555
- renderTimeBar(tournament),
528
+ index.h("tournament-timer", { "is-detail": true, tournament: tournament }),
556
529
  index.h("section", { class: "ShowInfo", onClick: () => (instance.isShowInfo = !instance.isShowInfo) },
557
530
  index.h("div", { class: "DetailHeader" },
558
531
  index.h("span", null, isShowInfo ? iconEyeOpen : iconEyeClose),
@@ -644,7 +617,7 @@ const renderCloseBar = (attr) => {
644
617
  return (index.h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (index.h("div", { class: 'WrapperBar' + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
645
618
  };
646
619
 
647
- const casinoEngagementSuiteTournamentCss = ".Leaderboards{height:100%;overflow-y:auto;transition:0.5s ease;transition-property:all, transform}.Leaderboards.list,.Leaderboards.item{opacity:0}.Leaderboards.list.Active,.Leaderboards.item.Active{opacity:1}.Leaderboards.list.Hidden,.Leaderboards.item.Hidden{display:none}.Leaderboards .question__tooltip{position:absolute;top:0;left:20px;width:320px;text-align:left;background-color:var(--emw--color-typography, rgba(255, 255, 255, 0.6));border:1px solid var(--emw--color-typography, rgba(255, 255, 255, 0.8));color:var(var(--emw--color-primary, rgb(255, 214, 47)), rgb(255, 214, 47));padding:10px;border-radius:5px;opacity:0;fill-opacity:0.5;transition:opacity 0.3s ease-in-out;z-index:10}.Leaderboards .question__tooltip.visible{opacity:0.8}.Wrapper{position:relative;min-height:100%;color:var(--emw--color-typography, #FFFFFF);display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));flex-direction:column;border-radius:24px}.Wrapper .TableContentWrapper{scrollbar-width:thin;scrollbar-color:var(--emw--color-background, hsl(254, 8.53%, 54.93%)) transparent}.Wrapper .WrapperContent .TableContentWrapper{height:calc(100vh - 278px);overflow-y:auto}.Wrapper .WrapperContent .Main{height:calc(100vh - 188px)}.Wrapper.Mobile{border-radius:16px}.WrapperContent{padding-bottom:20px;transition:0.5s filter}.WrapperContent.faded{filter:brightness(53.3333333333%)}.WrapperContent .NoLeaderboards h3.Title{text-align:center}.WrapperContent .NoLeaderboards div.message{color:var(--emw--color-secondary, rgb(187, 185, 195));text-align:left}.Wrapper.Mobile .WrapperBar{padding:20px 8px 8px;margin-bottom:8px}.WrapperBar{display:flex;width:100%;padding:32px 20px 20px;margin-bottom:20px}.WrapperBar .WrapperBarLeft span{position:relative}.WrapperBarLeft,.WrapperBarRight{cursor:pointer;z-index:1}.WrapperBarMiddle{flex-grow:1;text-align:center;font-size:var(--emw--font-size-medium, 16px);line-height:16px;font-weight:500;color:var(--emw--color-secondary, rgb(187, 185, 195))}:host{display:block;font-size:var(--emw--font-size-x-small, 12px);font-family:Inter}.ScrollBar{scrollbar-width:thin;scrollbar-color:var(--emw--color-background, hsl(254, 8.53%, 54.93%)) transparent}.Row{margin:10px 0;padding:0 20px}.Row:first-child{margin:0;padding-top:5px}.LeaderboardsItem{opacity:1;transition:1s opacity ease;position:relative;margin:10px 0;border:1px solid rgb(64, 57, 86);border-radius:16px}.LeaderboardsItem.Unjoined{opacity:0;margin:0;border:0 none;animation:slideOut 1s forwards}.LeaderboardsItem.Hollow{border-color:transparent}.LeaderboardsItem:first-child{margin-top:0}.LeaderboardsItemContainer{padding-top:16px}.ShowInfo{margin:10px 0;padding:0 20px;transition:0.5s all ease}.TimeContainer{margin:10px 0;padding:0 20px;transition:0.5s all ease}.TimeContainer .Time{display:flex;justify-content:space-between;font-size:var(--emw--font-size-x-small, 12px);align-items:center;color:var(--emw--color-secondary, rgb(187, 185, 195))}.TimeContainer .Time .Running{width:100%;display:flex;flex-direction:row;justify-content:space-between}.TimeContainer .Time button{font-size:var(--emw--font-size-x-small, 12px);height:20px;padding:0}.TimeContainer .Time button::before{inset:inherit;border:0}.TitleContainer{display:flex;justify-content:space-between;margin:10px 0;padding:0 20px;margin-top:0;gap:10px;font-family:Montserrat}.TitleContainer .GradientRoundedButton{width:120px}.TabsContainer{margin:10px 0;padding:0 20px;margin:0 20px;padding:0;border-bottom:1px solid #575757}.Tabs{display:flex;justify-content:space-between;justify-content:start;font-size:var(--emw--font-size-x-small, 12px);margin-bottom:-1px}.Tabs .Tab{text-transform:capitalize}.Tabs>div{padding:10px;color:rgb(102, 97, 120);cursor:pointer}.Tabs>div.active{color:var(--emw--color-typography, #FFF);border-bottom:2px solid var(--emw--color-typography, #FFF)}.Title{font-size:var(--emw--font-size-medium, 16px);font-weight:700;line-height:19.5px;text-align:left;word-break:break-word}.TC{margin-top:12px}.TC a{color:rgb(89, 209, 255)}.Criterias{margin:12px 0}.Criterias span{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.ResultPrize{margin:10px 0;padding:0 20px;padding-left:30px;text-align:left}.ResultPrize span{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.InfoContainer{flex:1;display:flex;flex-direction:column;position:relative;overflow:hidden}.ContentScrollContainer{flex:1;display:flex;flex-direction:column;overflow-y:auto;position:relative;height:auto}.ContentScrollContainer.expanded{height:100%;max-height:100%}.PrizesContainer{flex:1;display:flex;flex-direction:column;min-height:100px;max-height:calc(100% - 20px)}.PrizesHeader,.DetailHeader{align-items:center;display:flex;background-color:var(--emw--color-background, hsl(254, 44%, 15%));padding:5px 0;z-index:1;margin:0 20px}.PrizesHeader img,.DetailHeader img{width:12px}.PrizesHeader .PrizesText,.DetailHeader .PrizesText{margin-left:3px;font-weight:600}.DetailHeader{margin:0}.Prizes{margin:10px 0;padding:0 20px;padding-left:30px;text-align:left;flex:1;overflow-y:auto;margin-bottom:0;padding-right:10px;max-height:300px;margin-top:10px}.Prizes::-webkit-scrollbar{width:4px}.Prizes::-webkit-scrollbar-track{background:rgba(0, 0, 0, 0.1);border-radius:2px}.Prizes::-webkit-scrollbar-thumb{background:var(--emw--color-primary, rgb(255, 214, 47));border-radius:2px}.Prizes .Prize{margin:8px 0}.Prizes .Prize .PrizeText{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:400}.InfoContainer section.Info{margin-bottom:12px;text-align:left;padding-left:15px}.InfoContainer section.Info .Criterias,.InfoContainer section.Info .Description{padding-left:15px;margin-top:10px}*{box-sizing:border-box}.Leaderboards{width:100%;text-align:center;border-collapse:collapse}.Leaderboards td{opacity:0.6;padding:12px 5px}.Leaderboards td:first-child{padding-left:20px}.Leaderboards td:last-child{padding-right:20px}.Leaderboards .LeaderboardName{color:var(--emw--color-typography, #FFF);opacity:1}.Leaderboards tr.isMe{background:rgba(0, 0, 0, 0.2);border:1px solid var(--emw--color-primary, rgb(255, 214, 47))}.Leaderboards tr.isMe .LeaderboardRank span{padding:0px 3px;opacity:1;border:1px solid var(--emw--color-primary, rgb(255, 214, 47));border-radius:11px}.Leaderboards tr.isMe td{color:var(--emw--color-primary, rgb(255, 214, 47));font-weight:var(--emw--font-weight-semibold, 500)}.LeaderboardLabels{position:absolute;top:-6px;right:18px;display:flex;gap:4px}.LeaderboardLabel{width:30px;height:15px;background:var(--emw--engagement-suite-gradient-golden, linear-gradient(180deg, #FFB801 15.86%, #FEF746 31.36%, #FBFFE0 36.86%, #FFFA60 47.86%, #FF9400 87.36%));border-radius:var(--emw--border-radius-x-small, 2px);display:inline-flex;padding:0 2px;align-items:center;justify-content:center}.LeaderboardLabel span{display:inline-block;text-transform:uppercase;font-size:var(--emw--font-size-3x-small, 7px);line-height:7px;font-weight:var(--emw--font-weight-bold, 700);font-family:var(--emw--font-family-secondary, \"Montserrat\", sans-serif);color:var(--emw--color-background, #1E1638)}.LeaderboardUnstarted{margin:10px 0;padding:0 20px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-medium, 16px)}.Games{margin:10px 0;padding:0 20px;padding:0 20px;display:flex;flex-wrap:wrap;justify-content:start;margin:20px auto}.Games .Game{cursor:pointer;width:25%;display:flex;padding:5px}.Games .Game.Current{cursor:auto;filter:grayscale(10)}.Games .Game:hover{filter:brightness(var(--emw--hover-brightness, 1.25))}.Games .Game.Current:hover{cursor:auto;filter:grayscale(10)}.Games img{width:100%;height:fit-content}dialog{position:absolute;top:30px;width:100%;height:max-content;background:transparent;border:0;padding:0;color:var(--emw--color-typography, #FFFFFF);transition:all 0.2s;transition-timing-function:ease-in-out}dialog>div{margin:32px;border-radius:8px;background:var(--emw--color-background, hsl(254, 44%, 15%));border:1px solid hsl(254, 20%, 28%);align-items:center}.DialogContentUnjoin{padding:32px;padding-top:10px;display:flex;gap:10px;flex-direction:column}.DialogContentUnjoinTitle{font-family:Montserrat;font-size:var(--emw--font-size-large, 20px);font-weight:600;line-height:24.38px;text-align:center}.DialogContentUnjoinDescription{color:var(--emw--color-secondary, rgb(187, 185, 195));margin-bottom:30px}.Tip{padding:32px;padding-top:10px;color:var(--emw--color-secondary, rgb(187, 185, 195));font-size:var(--emw--font-size-small, 14px)}.Tip.Error{color:var(--emw--color-error, var(--emw--color-red, #ed0909));font-weight:var(--emw--font-weight-normal, 500)}.PageConfirmContainer{text-align:center;width:80%;margin:0 auto}.PageConfirm{padding:40px 32px;display:flex;flex-direction:column;gap:20px}.PageConfirm .Title{font-size:var(--emw--font-size-large, 20px);text-align:center}.PageConfirm .Description{color:var(--emw--color-secondary, rgb(187, 185, 195));font-weight:400}.PageConfirm .Description span{color:var(--emw--color-typography, #FFF);font-weight:600}.PageConfirmButtonsGroup{width:150px;margin:0 auto;display:flex;flex-direction:column;gap:10px}.GradientRounded{display:block;background:linear-gradient(98.25deg, #FF9400 22.48%, #FEF746 131.02%, #FFE24A 131.9%);color:rgb(30, 22, 56);position:relative;border-radius:16px}.GradientRounded.Hollow{background:rgb(30, 22, 56);color:#FFFFFF}.GradientRounded.Hollow::before{content:\"\";position:absolute;inset:0;border-radius:15px;border:1px solid transparent;background:linear-gradient(98.25deg, #FF9400 22.48%, #FEF746 131.02%, #FFE24A 131.9%) border-box;-webkit-mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);-webkit-mask-composite:destination-out;mask-composite:exclude}.GradientRoundedButton{border:none;padding:7px;height:32px;width:100%;font-size:var(--emw--font-size-small, 14px);font-weight:700;line-height:17.07px;text-align:center;transition:0.5s opacity;cursor:pointer}.GradientRoundedButton.Pending{cursor:not-allowed;opacity:0.3}.GradientRoundedButton.Hollow span{background:-webkit-linear-gradient(98.25deg, rgb(255, 148, 0) 22.48%, rgb(254, 247, 70) 131.02%, rgb(255, 226, 74) 131.9%);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.WrapperUtil .GradientRounded .WrapperBar{margin-bottom:0;padding-bottom:0}.WrapperUtil .GradientRounded .Tip{padding-top:0;padding-bottom:40px}.LeaderboardsItem .LeaderboardsItemContainer .TitleContainer{margin-bottom:16px}@keyframes slideOut{0%{display:block;opacity:1;height:max-content}50%{display:block;opacity:0.5}80%{display:none;opacity:0}100%{display:none;opacity:0;height:0}}";
620
+ 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}table.leaderboards{height:auto}.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%);pointer-events:none}.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:calc(50vh - 280px);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}}";
648
621
  const CasinoEngagementSuiteTournamentStyle0 = casinoEngagementSuiteTournamentCss;
649
622
 
650
623
  const CasinoEngagementSuiteTournament = class {
@@ -764,7 +737,7 @@ const CasinoEngagementSuiteTournament = class {
764
737
  }
765
738
  }
766
739
  onGameClick(game) {
767
- if (game.id === this.currentGameId) {
740
+ if (game.id == this.currentGameId) {
768
741
  return;
769
742
  }
770
743
  messageSender.GameClickReq(game);
@@ -772,6 +745,8 @@ const CasinoEngagementSuiteTournament = class {
772
745
  actionJoin(tournament) {
773
746
  if (tournament.isActionJoinPending)
774
747
  return;
748
+ tournament.isActionJoinPending = true;
749
+ this.pendingChangeEvent.emit(tournament);
775
750
  try {
776
751
  if (tournament.isPlayerAcknowledged) {
777
752
  messageSender.UnjoinTournamentReq(tournament);
@@ -782,11 +757,9 @@ const CasinoEngagementSuiteTournament = class {
782
757
  }
783
758
  catch (e) {
784
759
  console.log('error', e);
785
- return;
786
760
  }
787
761
  }
788
762
  setPage(page, metaData) {
789
- var _a;
790
763
  this.page = page;
791
764
  if (page === exports.LeaderboardPage.item) {
792
765
  this.isShowInfo = false;
@@ -799,7 +772,7 @@ const CasinoEngagementSuiteTournament = class {
799
772
  }
800
773
  this.tab = Tab.info;
801
774
  }
802
- this.tournamentTimer.emit({ page, tournamentId: (_a = this.tournamentItem) === null || _a === void 0 ? void 0 : _a.id });
775
+ this.tournamentTimer.emit({ page });
803
776
  }
804
777
  render() {
805
778
  const renderDialogContent = () => {
@@ -823,7 +796,7 @@ const CasinoEngagementSuiteTournament = class {
823
796
  middle: this.locale.Leaderboards,
824
797
  right: index.h("span", { onClick: () => this.close.emit() }, iconClose)
825
798
  }), index.h("div", { class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), this.page === exports.LeaderboardPage.item &&
826
- index.h("div", { class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())), index.h("div", { class: "WrapperUtil" }, index.h("dialog", { open: this.dialog.isOpen, style: { 'top': this.getContainerScrollTop() + 'px' } }, index.h("div", { class: "GradientRounded Hollow" }, renderCloseBar({
799
+ index.h("div", { class: `Leaderboards ${this.page} ${this.page === 'item' ? 'Active' : 'Hidden'} `, ref: el => this.detailElement = el }, this.renders.page.item())), index.h("div", { class: "WrapperUtil" }, index.h("dialog", { open: this.dialog.isOpen, style: { 'top': this.getContainerScrollTop() + 'px' } }, index.h("div", { class: "Hollow" }, renderCloseBar({
827
800
  right: index.h("span", { onClick: () => this.closeDialog() }, iconClose)
828
801
  }), this.dialog.isOpen && renderDialogContent()))))));
829
802
  }
@@ -841,6 +814,7 @@ const CasinoEngagementSuiteTournament = class {
841
814
  index.registerInstance(this, hostRef);
842
815
  this.close = index.createEvent(this, "close", 7);
843
816
  this.tournamentTimer = index.createEvent(this, "tournamentTimer", 7);
817
+ this.pendingChangeEvent = index.createEvent(this, "pendingChangeEvent", 7);
844
818
  this.gifts = [];
845
819
  this.labels = [];
846
820
  this.showTooltip = false;
@@ -892,4 +866,5 @@ exports.classnames = classnames;
892
866
  exports.formatDate = formatDate;
893
867
  exports.getProgress = getProgress;
894
868
  exports.getTimeDifference = getTimeDifference;
869
+ exports.isTournamentClosed = isTournamentClosed;
895
870
  exports.renderGradientRoundedButton = renderGradientRoundedButton;
@@ -19,7 +19,7 @@ var patchBrowser = () => {
19
19
 
20
20
  patchBrowser().then(async (options) => {
21
21
  await appGlobals.globalScripts();
22
- return index.bootstrapLazy([["casino-engagement-suite-progress-bar_6.cjs",[[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],"newIdList":[32]},[[8,"message","handleEvent"],[16,"clickToTournamentDetail","handleClickToTournamentDetail"],[16,"joinTournamentEvent","handleJoinTournamentEvent"],[16,"unjoinTournamentEvent","handleUnjoinTournamentEvent"],[4,"click","handleClickOutside"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[0,"casino-engagement-suite-tournament-item",{"tournament":[16],"isNew":[4,"is-new"],"locale":[32]},[[16,"joinTournamentEvent","handleJoinTournamentEvent"],[16,"unjoinTournamentEvent","handleUnjoinTournamentEvent"]]],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}],[0,"casino-engagement-suite-tournament-timer",{"tournament":[16],"time":[32],"timeHolder":[32],"timeCloak":[32]},[[0,"tournamentTimer","containerPageChangeHandler"]]],[0,"casino-engagement-suite-tournament-item-title",{"tournament":[16],"locale":[32],"isButtonDisabed":[32]},null,{"tournament":["onTournamentChanged"]}],[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]}]]]], options);
22
+ return index.bootstrapLazy([["casino-engagement-suite-progress-bar_6.cjs",[[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],"newIdList":[32]},[[8,"message","handleEvent"],[16,"clickToTournamentDetail","handleClickToTournamentDetail"],[16,"joinTournamentEvent","handleJoinTournamentEvent"],[16,"unjoinTournamentConfirmEvent","handleUnjoinTournamentEvent"],[4,"click","handleClickOutside"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[0,"tournament-item",{"tournament":[16],"isNew":[4,"is-new"],"locale":[32]},[[16,"pendingChangeEvent","onTournamentUpdateEvent"]]],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}],[0,"tournament-timer",{"tournament":[16],"isDetail":[4,"is-detail"],"timeHolder":[32],"timeClock":[32],"lastTimeDiff":[32],"lastProgress":[32]},[[16,"tournamentTimer","containerPageChangeHandler"]]],[0,"tournament-item-title",{"tournament":[16],"locale":[32],"isButtonDisabed":[32]},null,{"tournament":["onTournamentChanged"]}],[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]}]]]], options);
23
23
  });
24
24
 
25
25
  exports.setNonce = index.setNonce;
@@ -2,7 +2,7 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const casinoEngagementSuiteTournament = require('./casino-engagement-suite-tournament-1f1275c4.js');
5
+ const casinoEngagementSuiteTournament = require('./casino-engagement-suite-tournament-785dd5cc.js');
6
6
  require('./index-5e98dd13.js');
7
7
 
8
8
 
@@ -8,7 +8,7 @@ const appGlobals = require('./app-globals-3a1e7e63.js');
8
8
  const defineCustomElements = async (win, options) => {
9
9
  if (typeof window === 'undefined') return undefined;
10
10
  await appGlobals.globalScripts();
11
- return index.bootstrapLazy([["casino-engagement-suite-progress-bar_6.cjs",[[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],"newIdList":[32]},[[8,"message","handleEvent"],[16,"clickToTournamentDetail","handleClickToTournamentDetail"],[16,"joinTournamentEvent","handleJoinTournamentEvent"],[16,"unjoinTournamentEvent","handleUnjoinTournamentEvent"],[4,"click","handleClickOutside"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[0,"casino-engagement-suite-tournament-item",{"tournament":[16],"isNew":[4,"is-new"],"locale":[32]},[[16,"joinTournamentEvent","handleJoinTournamentEvent"],[16,"unjoinTournamentEvent","handleUnjoinTournamentEvent"]]],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}],[0,"casino-engagement-suite-tournament-timer",{"tournament":[16],"time":[32],"timeHolder":[32],"timeCloak":[32]},[[0,"tournamentTimer","containerPageChangeHandler"]]],[0,"casino-engagement-suite-tournament-item-title",{"tournament":[16],"locale":[32],"isButtonDisabed":[32]},null,{"tournament":["onTournamentChanged"]}],[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]}]]]], options);
11
+ return index.bootstrapLazy([["casino-engagement-suite-progress-bar_6.cjs",[[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],"newIdList":[32]},[[8,"message","handleEvent"],[16,"clickToTournamentDetail","handleClickToTournamentDetail"],[16,"joinTournamentEvent","handleJoinTournamentEvent"],[16,"unjoinTournamentConfirmEvent","handleUnjoinTournamentEvent"],[4,"click","handleClickOutside"]],{"newIdList":["checkNewIdList"],"tournamentList":["syncBarState"],"show":["showPropWatcher"]}],[0,"tournament-item",{"tournament":[16],"isNew":[4,"is-new"],"locale":[32]},[[16,"pendingChangeEvent","onTournamentUpdateEvent"]]],[4,"general-styling-wrapper",{"clientStyling":[1,"client-styling"],"clientStylingUrl":[1,"client-styling-url"],"translationUrl":[1,"translation-url"],"targetTranslations":[16]}],[0,"tournament-timer",{"tournament":[16],"isDetail":[4,"is-detail"],"timeHolder":[32],"timeClock":[32],"lastTimeDiff":[32],"lastProgress":[32]},[[16,"tournamentTimer","containerPageChangeHandler"]]],[0,"tournament-item-title",{"tournament":[16],"locale":[32],"isButtonDisabed":[32]},null,{"tournament":["onTournamentChanged"]}],[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]}]]]], options);
12
12
  };
13
13
 
14
14
  exports.setNonce = index.setNonce;
@@ -33,6 +33,10 @@
33
33
  opacity: 0.8;
34
34
  }
35
35
 
36
+ table.leaderboards {
37
+ height: auto;
38
+ }
39
+
36
40
  .Wrapper {
37
41
  position: relative;
38
42
  min-height: 100%;
@@ -63,6 +67,7 @@
63
67
  }
64
68
  .WrapperContent.faded {
65
69
  filter: brightness(53.3333333333%);
70
+ pointer-events: none;
66
71
  }
67
72
  .WrapperContent .NoLeaderboards h3.Title {
68
73
  text-align: center;
@@ -452,7 +457,7 @@
452
457
 
453
458
  dialog {
454
459
  position: absolute;
455
- top: 30px;
460
+ top: calc(50vh - 280px);
456
461
  width: 100%;
457
462
  height: max-content;
458
463
  background: transparent;
@@ -128,7 +128,7 @@ export class CasinoEngagementSuiteTournament {
128
128
  }
129
129
  }
130
130
  onGameClick(game) {
131
- if (game.id === this.currentGameId) {
131
+ if (game.id == this.currentGameId) {
132
132
  return;
133
133
  }
134
134
  messageSender.GameClickReq(game);
@@ -136,6 +136,8 @@ export class CasinoEngagementSuiteTournament {
136
136
  actionJoin(tournament) {
137
137
  if (tournament.isActionJoinPending)
138
138
  return;
139
+ tournament.isActionJoinPending = true;
140
+ this.pendingChangeEvent.emit(tournament);
139
141
  try {
140
142
  if (tournament.isPlayerAcknowledged) {
141
143
  messageSender.UnjoinTournamentReq(tournament);
@@ -146,11 +148,9 @@ export class CasinoEngagementSuiteTournament {
146
148
  }
147
149
  catch (e) {
148
150
  console.log('error', e);
149
- return;
150
151
  }
151
152
  }
152
153
  setPage(page, metaData) {
153
- var _a;
154
154
  this.page = page;
155
155
  if (page === LeaderboardPage.item) {
156
156
  this.isShowInfo = false;
@@ -163,7 +163,7 @@ export class CasinoEngagementSuiteTournament {
163
163
  }
164
164
  this.tab = Tab.info;
165
165
  }
166
- this.tournamentTimer.emit({ page, tournamentId: (_a = this.tournamentItem) === null || _a === void 0 ? void 0 : _a.id });
166
+ this.tournamentTimer.emit({ page });
167
167
  }
168
168
  render() {
169
169
  const renderDialogContent = () => {
@@ -187,7 +187,7 @@ export class CasinoEngagementSuiteTournament {
187
187
  middle: this.locale.Leaderboards,
188
188
  right: h("span", { onClick: () => this.close.emit() }, iconClose)
189
189
  }), h("div", { class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), this.page === LeaderboardPage.item &&
190
- 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({
190
+ 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: "Hollow" }, renderCloseBar({
191
191
  right: h("span", { onClick: () => this.closeDialog() }, iconClose)
192
192
  }), this.dialog.isOpen && renderDialogContent()))))));
193
193
  }
@@ -430,6 +430,26 @@ export class CasinoEngagementSuiteTournament {
430
430
  "resolved": "any",
431
431
  "references": {}
432
432
  }
433
+ }, {
434
+ "method": "pendingChangeEvent",
435
+ "name": "pendingChangeEvent",
436
+ "bubbles": true,
437
+ "cancelable": true,
438
+ "composed": true,
439
+ "docs": {
440
+ "tags": [],
441
+ "text": ""
442
+ },
443
+ "complexType": {
444
+ "original": "Object",
445
+ "resolved": "Object",
446
+ "references": {
447
+ "Object": {
448
+ "location": "global",
449
+ "id": "global::Object"
450
+ }
451
+ }
452
+ }
433
453
  }];
434
454
  }
435
455
  static get watchers() {
@@ -464,7 +484,7 @@ export class CasinoEngagementSuiteTournament {
464
484
  "capture": false,
465
485
  "passive": false
466
486
  }, {
467
- "name": "unjoinTournamentEvent",
487
+ "name": "unjoinTournamentConfirmEvent",
468
488
  "method": "handleUnjoinTournamentEvent",
469
489
  "target": "body",
470
490
  "capture": false,
@@ -1,27 +1,31 @@
1
1
  import { h } from "@stencil/core";
2
2
  import { formatDate, getProgress, getTimeDifference } from "../utils/util.date";
3
3
  import { renderGradientRoundedButton } from "./GradientRoundedButton";
4
- import { LeaderboardPage, TournamentState } from "../utils/types";
4
+ import { LeaderboardPage } from "../utils/types";
5
+ import { isTournamentClosed } from "../utils/bussiness";
5
6
  export class CasinoEngagementSuiteTournamentTimer {
6
7
  constructor() {
7
8
  this.tournament = undefined;
8
- this.time = 0;
9
+ this.isDetail = false;
9
10
  this.timeHolder = undefined;
10
- this.timeCloak = true;
11
+ this.timeClock = true;
12
+ this.lastTimeDiff = undefined;
13
+ this.lastProgress = undefined;
11
14
  }
12
15
  containerPageChangeHandler(event) {
13
- this.timeCloak = event.detail.page === LeaderboardPage.list ||
14
- event.detail.page === LeaderboardPage.item && this.tournament.id === event.detail.tournamentId;
16
+ this.timeClock = (event.detail.page === LeaderboardPage.list && !this.isDetail) ||
17
+ (event.detail.page === LeaderboardPage.item && this.isDetail);
18
+ }
19
+ componentWillLoad() {
20
+ this.lastTimeDiff = getTimeDifference(new Date(), this.tournament.endTime);
21
+ this.lastProgress = getProgress(this.tournament.startTime, this.tournament.endTime);
15
22
  }
16
23
  setTimeInterval() {
17
24
  this.timeHolder = setInterval(() => {
18
- var _a;
19
25
  const timeDifference = getTimeDifference(new Date(), this.tournament.endTime);
20
26
  const progress = getProgress(this.tournament.startTime, this.tournament.endTime);
21
- if (this.timeCloak &&
22
- ![TournamentState.Closed, TournamentState.Closing].includes((_a = this.tournament) === null || _a === void 0 ? void 0 : _a.state) &&
27
+ if (this.timeClock && !isTournamentClosed(this.tournament) &&
23
28
  (timeDifference != this.lastTimeDiff || progress != this.lastProgress)) {
24
- this.time++;
25
29
  this.lastProgress = progress;
26
30
  this.lastTimeDiff = timeDifference;
27
31
  }
@@ -34,19 +38,17 @@ export class CasinoEngagementSuiteTournamentTimer {
34
38
  clearInterval(this.timeHolder);
35
39
  }
36
40
  render() {
37
- return h("section", { key: 'b5d514586445a3acc665fcbbbaa0d139b7b28075', class: "TimeContainer" }, h("div", { key: '2080b18edd157a337d5c7f164d1914e91a95a3f3', class: "Time" }, this.tournament.state === 'Running'
38
- ? [
39
- h("div", { class: "Running" }, h("div", null, this.lastTimeDiff), ",", h("div", null, renderGradientRoundedButton({
40
- statedClasses: {
41
- isHollow: true,
42
- isPendding: false
43
- },
44
- innerHTML: `${getProgress(this.tournament.startTime, this.tournament.endTime)}%`
45
- })))
46
- ]
47
- : [h("div", { class: "NotRunning" }, formatDate(this.tournament.startTime)), h("div", null, formatDate(this.tournament.endTime))]), h("casino-engagement-suite-progress-bar", { key: 'b841cc70a1307f1175f0748644aaaeee9e1094ff', value: Number(this.lastProgress >= 100 ? 100 : this.lastProgress), "hide-percent": true }));
41
+ return h("section", { key: '8fafe729af2bd66b5ac0e980564051069f677531', class: "TimeContainer" }, h("div", { key: '8279572700e24d3f1094809dae6e3b5d1b02c37b', class: "Time" }, this.tournament.state === 'Running'
42
+ ? h("div", { class: "Running" }, h("div", null, this.lastTimeDiff), h("div", null, renderGradientRoundedButton({
43
+ statedClasses: {
44
+ isHollow: true,
45
+ isPendding: false
46
+ },
47
+ innerHTML: `${getProgress(this.tournament.startTime, this.tournament.endTime)}%`
48
+ })))
49
+ : [h("div", { class: "NotRunning" }, formatDate(this.tournament.startTime)), h("div", null, formatDate(this.tournament.endTime))]), h("casino-engagement-suite-progress-bar", { key: 'e475e55b206c802f8df27cb95ac8fe6331578358', indeterminate: false, value: Number(this.lastProgress >= 100 ? 100 : this.lastProgress), "hide-percent": true }));
48
50
  }
49
- static get is() { return "casino-engagement-suite-tournament-timer"; }
51
+ static get is() { return "tournament-timer"; }
50
52
  static get properties() {
51
53
  return {
52
54
  "tournament": {
@@ -70,21 +72,40 @@ export class CasinoEngagementSuiteTournamentTimer {
70
72
  "text": ""
71
73
  },
72
74
  "defaultValue": "undefined"
75
+ },
76
+ "isDetail": {
77
+ "type": "boolean",
78
+ "mutable": false,
79
+ "complexType": {
80
+ "original": "boolean",
81
+ "resolved": "boolean",
82
+ "references": {}
83
+ },
84
+ "required": false,
85
+ "optional": false,
86
+ "docs": {
87
+ "tags": [],
88
+ "text": ""
89
+ },
90
+ "attribute": "is-detail",
91
+ "reflect": false,
92
+ "defaultValue": "false"
73
93
  }
74
94
  };
75
95
  }
76
96
  static get states() {
77
97
  return {
78
- "time": {},
79
98
  "timeHolder": {},
80
- "timeCloak": {}
99
+ "timeClock": {},
100
+ "lastTimeDiff": {},
101
+ "lastProgress": {}
81
102
  };
82
103
  }
83
104
  static get listeners() {
84
105
  return [{
85
106
  "name": "tournamentTimer",
86
107
  "method": "containerPageChangeHandler",
87
- "target": undefined,
108
+ "target": "body",
88
109
  "capture": false,
89
110
  "passive": false
90
111
  }];
@@ -7,24 +7,20 @@ export class CasinoEngagementSuiteTournamentItem {
7
7
  this.isNew = undefined;
8
8
  this.locale = TRANSLATIONS;
9
9
  }
10
- handleJoinTournamentEvent(e) {
11
- if (this.tournament.id === e.detail.id) {
12
- this.tournament = Object.assign(Object.assign({}, this.tournament), { isActionJoinPending: true });
13
- }
14
- }
15
- handleUnjoinTournamentEvent(e) {
16
- if (this.tournament.id === e.detail.id) {
17
- this.tournament = Object.assign(Object.assign({}, this.tournament), { isActionJoinPending: true });
18
- }
19
- }
20
10
  goToDetail() {
21
11
  this.clickToTournamentDetail.emit(this.tournament);
22
12
  }
13
+ onTournamentUpdateEvent(event) {
14
+ const { detail } = event;
15
+ if (detail.id === this.tournament.id) {
16
+ this.tournament = Object.assign({}, detail);
17
+ }
18
+ }
23
19
  render() {
24
20
  const tournament = this.tournament;
25
- return (h("div", { key: 'e507da65532f4608aa96c1ebe2e329d332b9c439', class: classnames('LeaderboardsItem', tournament.isPlayerAcknowledged ? ' GradientRounded Hollow' : '', tournament.isUnjoined ? 'Unjoined' : ''), onClick: this.goToDetail.bind(this) }, h("div", { key: 'dc9bd1777858b2a3a57a3f808f734857db9011ee', class: "LeaderboardsItemContainer" }, h("casino-engagement-suite-tournament-item-title", { key: '14cae37fbc9d0f829b85d507ea0e60c95afc7250', tournament: tournament }), h("casino-engagement-suite-tournament-timer", { key: 'd703d03c146592887ea20bdc1289b446399f0870', tournament: tournament })), h("div", { key: '4f2f422965b47c0103ff5dcef8f28dc507491677', class: "LeaderboardLabels" }, this.isNew && (h("div", { key: '3132e3ac8adec5f9ca85d8c14c91801779d8afbf', class: "LeaderboardLabel" }, h("span", { key: 'c148c5fa597b76ff4f23c06b6b3407c06a96bdb7' }, "new"))))));
21
+ return (h("div", { key: '42aee3b22ede6ac1da748308979258bfcda33d3b', class: classnames('LeaderboardsItem', tournament.isPlayerAcknowledged ? ' GradientRounded Hollow' : '', tournament.isUnjoined ? 'Unjoined' : ''), onClick: this.goToDetail.bind(this) }, h("div", { key: '25078f839d00c4b749bff3036c279afbf9133b96', class: "LeaderboardsItemContainer" }, h("tournament-item-title", { key: 'd34d2101e73044448d909a8f36a842a5081d9265', tournament: tournament }), h("tournament-timer", { key: '3958d497cdc9856660b998d616da68689505b18e', tournament: tournament })), h("div", { key: '940f08d14c35872562eccbb022e3f256bba259ec', class: "LeaderboardLabels" }, this.isNew && (h("div", { key: '3c84b998444eb4e16a13a65db4fb909356f78668', class: "LeaderboardLabel" }, h("span", { key: '5c095eeafbfba21e68cd6afa7699f4e2c9ce4bcd' }, "new"))))));
26
22
  }
27
- static get is() { return "casino-engagement-suite-tournament-item"; }
23
+ static get is() { return "tournament-item"; }
28
24
  static get properties() {
29
25
  return {
30
26
  "tournament": {
@@ -98,14 +94,8 @@ export class CasinoEngagementSuiteTournamentItem {
98
94
  }
99
95
  static get listeners() {
100
96
  return [{
101
- "name": "joinTournamentEvent",
102
- "method": "handleJoinTournamentEvent",
103
- "target": "body",
104
- "capture": false,
105
- "passive": false
106
- }, {
107
- "name": "unjoinTournamentEvent",
108
- "method": "handleUnjoinTournamentEvent",
97
+ "name": "pendingChangeEvent",
98
+ "method": "onTournamentUpdateEvent",
109
99
  "target": "body",
110
100
  "capture": false,
111
101
  "passive": false