@everymatrix/casino-engagement-suite-tournament 1.63.3 → 1.64.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.
- package/dist/casino-engagement-suite-tournament/casino-engagement-suite-tournament.esm.js +1 -1
- package/dist/casino-engagement-suite-tournament/index.esm.js +1 -1
- package/dist/casino-engagement-suite-tournament/p-edcd56d0.js +15 -0
- package/dist/casino-engagement-suite-tournament/{p-d24f1017.entry.js → p-fcfced34.entry.js} +1 -1
- package/dist/cjs/casino-engagement-suite-progress-bar_6.cjs.entry.js +11 -10
- package/dist/cjs/{casino-engagement-suite-tournament-785dd5cc.js → casino-engagement-suite-tournament-95aedc10.js} +244 -67
- package/dist/cjs/casino-engagement-suite-tournament.cjs.js +1 -1
- package/dist/cjs/index.cjs.js +1 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/assets/back.svg +3 -0
- package/dist/collection/assets/iconTrophy.svg +12 -0
- package/dist/collection/assets/iconWarn.svg +15 -0
- package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.css +123 -26
- package/dist/collection/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.js +71 -14
- package/dist/collection/shared/TournamentDurationTimer.js +9 -9
- package/dist/collection/shared/TournamentItem.js +20 -2
- package/dist/collection/shared/TournamentItemTitle.js +3 -3
- package/dist/collection/shared/icons.js +6 -2
- package/dist/collection/shared/renders.dialog.js +10 -3
- package/dist/collection/shared/renders.page.js +3 -1
- package/dist/collection/shared/renders.tab.js +10 -3
- package/dist/collection/utils/api.apdater.js +14 -0
- package/dist/collection/utils/bussiness.js +28 -2
- package/dist/collection/utils/message.js +104 -27
- package/dist/collection/utils/translations.js +8 -5
- package/dist/collection/utils/types.js +8 -0
- package/dist/collection/utils/util.date.js +4 -3
- package/dist/collection/utils/utils.js +5 -2
- package/dist/esm/casino-engagement-suite-progress-bar_6.entry.js +12 -11
- package/dist/esm/{casino-engagement-suite-tournament-3be75bd2.js → casino-engagement-suite-tournament-61d378cd.js} +244 -67
- package/dist/esm/casino-engagement-suite-tournament.js +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/loader.js +1 -1
- package/dist/types/components/casino-engagement-suite-tournament/casino-engagement-suite-tournament.d.ts +20 -3
- package/dist/types/components.d.ts +18 -0
- package/dist/types/shared/TournamentItem.d.ts +7 -1
- package/dist/types/shared/TournamentItemTitle.d.ts +6 -1
- package/dist/types/shared/icons.d.ts +1 -0
- package/dist/types/utils/api.apdater.d.ts +3 -0
- package/dist/types/utils/bussiness.d.ts +10 -1
- package/dist/types/utils/message.d.ts +3 -0
- package/dist/types/utils/translations.d.ts +6 -1
- package/dist/types/utils/types.d.ts +9 -0
- package/dist/types/utils/util.date.d.ts +2 -2
- package/dist/types/utils/utils.d.ts +1 -0
- package/package.json +1 -1
- package/dist/casino-engagement-suite-tournament/p-f478f260.js +0 -15
|
@@ -44,16 +44,19 @@ const localePostprocess = (translationText, props) => {
|
|
|
44
44
|
});
|
|
45
45
|
return translationText;
|
|
46
46
|
};
|
|
47
|
-
const TRANSLATIONS = Object.assign(Object.assign(Object.assign({ Join: 'Join', Unjoin: 'Unjoin' }, Tab), Time), { TC: 'Terms & Conditions', ScoreCriteria: 'Score Criteria', MinimumBetCriteria: 'Minimum bet criteria', Place: 'place', Prizes: 'Rewards', LeaderboardDetails: 'Leaderboard Details', UnjoinDialog: {
|
|
47
|
+
const TRANSLATIONS = Object.assign(Object.assign(Object.assign({ Join: 'Join', Unjoin: 'Unjoin' }, Tab), Time), { TC: 'Terms & Conditions', ScoreCriteria: 'Score Criteria', MinimumBetCriteria: 'Minimum bet criteria', Place: 'place', Places: 'places', Prizes: 'Rewards', LeaderboardDetails: 'Leaderboard Details', UnjoinDialog: {
|
|
48
48
|
Title: 'Quit Leaderboard?',
|
|
49
49
|
Description: 'Any progress on the current Leaderboard won’t be kept and you can not rejoin the Leaderboard any more. <br /><br />Would you still like to quit?',
|
|
50
50
|
ButtonYes: 'Yes, I want to quit leaderboard',
|
|
51
51
|
ButtonNo: 'No, Stay on the leaderboard'
|
|
52
52
|
}, WinDialog: {
|
|
53
|
-
|
|
54
|
-
Description: 'You won <span>{
|
|
55
|
-
ButtonContinue: 'Continue'
|
|
56
|
-
|
|
53
|
+
Title: 'Congratulations!',
|
|
54
|
+
Description: 'You won <span>{rewards}</span>!',
|
|
55
|
+
ButtonContinue: 'Continue',
|
|
56
|
+
FailedTitle: 'Reward cannot be issued',
|
|
57
|
+
FailedDescription: 'Please contact support.',
|
|
58
|
+
FailedButtonContinue: 'Ok, continue',
|
|
59
|
+
}, 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>', TipPrizeWithoutReward: 'You took <span>{place}</span> place</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.' });
|
|
57
60
|
|
|
58
61
|
const classnames = (...args) => {
|
|
59
62
|
let classnameArray = ['Tab'];
|
|
@@ -74,8 +77,7 @@ const classnames = (...args) => {
|
|
|
74
77
|
return classnameArray.join(' ');
|
|
75
78
|
};
|
|
76
79
|
const getNewItems = (newList, oldList, getCondition) => {
|
|
77
|
-
|
|
78
|
-
return newItems;
|
|
80
|
+
return newList.filter(newItem => !oldList.some(oldItem => getCondition(newItem, oldItem)));
|
|
79
81
|
};
|
|
80
82
|
/**
|
|
81
83
|
* Truncate number to specified decimal places (without rounding)
|
|
@@ -118,6 +120,14 @@ var TournamentState;
|
|
|
118
120
|
TournamentState["Closed"] = "Closed";
|
|
119
121
|
TournamentState["Closing"] = "Closing";
|
|
120
122
|
})(TournamentState || (TournamentState = {}));
|
|
123
|
+
var RewardType;
|
|
124
|
+
(function (RewardType) {
|
|
125
|
+
RewardType["FreeSpin"] = "FreeSpin";
|
|
126
|
+
RewardType["Mission"] = "Challenge";
|
|
127
|
+
RewardType["Leaderboard"] = "TournamentTicket";
|
|
128
|
+
RewardType["Custom"] = "Custom";
|
|
129
|
+
RewardType["LuckyWheel"] = "PrizeEngine";
|
|
130
|
+
})(RewardType || (RewardType = {}));
|
|
121
131
|
var DialogType;
|
|
122
132
|
(function (DialogType) {
|
|
123
133
|
DialogType["unjoin"] = "unjoin";
|
|
@@ -126,6 +136,7 @@ var DialogType;
|
|
|
126
136
|
DialogType["error"] = "error";
|
|
127
137
|
})(DialogType || (DialogType = {}));
|
|
128
138
|
|
|
139
|
+
const DEFAULT_PAGE_SIZE = 12;
|
|
129
140
|
const getMaxRankStr = (playerLeaderboards) => {
|
|
130
141
|
let bestRank = null;
|
|
131
142
|
(playerLeaderboards || []).map((playerLeaderboard) => {
|
|
@@ -136,23 +147,55 @@ const getMaxRankStr = (playerLeaderboards) => {
|
|
|
136
147
|
}
|
|
137
148
|
bestRank = !bestRank || ((_a = bestRank.leaderBoard) === null || _a === void 0 ? void 0 : _a.rank) > rank ? playerLeaderboard : bestRank;
|
|
138
149
|
});
|
|
139
|
-
return
|
|
150
|
+
return {
|
|
151
|
+
rank: bestRank ? `${bestRank.leaderBoard.rank} / ${bestRank.endRank}` : '-',
|
|
152
|
+
detail: bestRank ? {
|
|
153
|
+
playerRank: bestRank.leaderBoard.rank,
|
|
154
|
+
total: bestRank.endRank
|
|
155
|
+
} : null
|
|
156
|
+
};
|
|
140
157
|
};
|
|
141
158
|
const isTournamentClosed = (tournament) => {
|
|
159
|
+
return [TournamentState.Closed].includes(tournament.state);
|
|
160
|
+
};
|
|
161
|
+
const isTournamentEnded = (tournament) => {
|
|
142
162
|
return [TournamentState.Closed, TournamentState.Closing].includes(tournament.state);
|
|
143
163
|
};
|
|
164
|
+
const getRewardNameByType = (reward) => {
|
|
165
|
+
switch (reward.type) {
|
|
166
|
+
case RewardType.FreeSpin:
|
|
167
|
+
return reward.campaignName;
|
|
168
|
+
case RewardType.Mission:
|
|
169
|
+
return reward.challengeName;
|
|
170
|
+
case RewardType.Leaderboard:
|
|
171
|
+
return reward.ticketProgramName;
|
|
172
|
+
case RewardType.LuckyWheel:
|
|
173
|
+
return reward.prizeEngineProgramName;
|
|
174
|
+
case RewardType.Custom:
|
|
175
|
+
return reward.value;
|
|
176
|
+
default:
|
|
177
|
+
return reward.name;
|
|
178
|
+
}
|
|
179
|
+
};
|
|
144
180
|
|
|
145
181
|
const rewardSvg = '';
|
|
146
182
|
|
|
183
|
+
const iconTrophySvg = '';
|
|
184
|
+
|
|
185
|
+
const iconWarnSvg = '';
|
|
186
|
+
|
|
147
187
|
const helpSvg = '';
|
|
148
188
|
|
|
189
|
+
const backSvg = '';
|
|
190
|
+
|
|
149
191
|
const iconClose = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/close.svg" });
|
|
150
192
|
const iconQuestion = h("img", { src: helpSvg, alt: "question", class: "Question" });
|
|
151
193
|
const iconEyeOpen = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-open.svg" });
|
|
152
194
|
const iconEyeClose = h("img", { src: "https://static.everymatrix.com/gic/img/engagement-suite/eye-closed.svg" });
|
|
153
|
-
const iconBack = h("img", { src: "
|
|
195
|
+
const iconBack = h("img", { src: backSvg, alt: "Back", class: "Back" });
|
|
154
196
|
const iconReward = h("img", { src: rewardSvg, alt: "reward", class: "Reward" });
|
|
155
|
-
const iconTrophy = h("img", { src: "
|
|
197
|
+
const iconTrophy = h("img", { src: iconTrophySvg, alt: "iconTrophy", class: "Trophy" });
|
|
198
|
+
const iconWarn = h("img", { src: iconWarnSvg, alt: "Reward Assign Failed", class: "Warn" });
|
|
156
199
|
|
|
157
200
|
const renderGradientRoundedButton = (_a) => {
|
|
158
201
|
var { statedClasses, innerHTML } = _a, props = __rest(_a, ["statedClasses", "innerHTML"]);
|
|
@@ -167,6 +210,7 @@ const renderGradientRoundedButton = (_a) => {
|
|
|
167
210
|
var GradientButton;
|
|
168
211
|
(function (GradientButton) {
|
|
169
212
|
GradientButton["normal"] = "normal";
|
|
213
|
+
GradientButton["okContinue"] = "okContinue";
|
|
170
214
|
GradientButton["unjoinYes"] = "unjoinYes";
|
|
171
215
|
GradientButton["unjoinNo"] = "unjoinNo";
|
|
172
216
|
})(GradientButton || (GradientButton = {}));
|
|
@@ -176,6 +220,9 @@ const renderButton = (instance, buttonType, isActionJoinPending = false) => {
|
|
|
176
220
|
normal: {
|
|
177
221
|
innerHTML: locale.WinDialog.ButtonContinue
|
|
178
222
|
},
|
|
223
|
+
okContinue: {
|
|
224
|
+
innerHTML: locale.WinDialog.FailedButtonContinue
|
|
225
|
+
},
|
|
179
226
|
unjoinYes: {
|
|
180
227
|
onClick: () => instance.actionJoin(instance.dialog.data),
|
|
181
228
|
innerHTML: locale.UnjoinDialog.ButtonYes
|
|
@@ -200,14 +247,20 @@ const renderButton = (instance, buttonType, isActionJoinPending = false) => {
|
|
|
200
247
|
};
|
|
201
248
|
const dialog = {
|
|
202
249
|
gift(instance) {
|
|
203
|
-
const { name:
|
|
250
|
+
const { name: rewards, failedRewards } = instance.gifts[0];
|
|
204
251
|
const { locale } = instance;
|
|
205
|
-
return (h("div", { class: "PageConfirmContainer" },
|
|
206
|
-
h("div", { class: "PageConfirm" },
|
|
252
|
+
return (h("div", { class: "PageConfirmContainer" }, !!rewards ?
|
|
253
|
+
h("div", { class: "PageConfirm Gift" },
|
|
207
254
|
h("div", null, iconTrophy),
|
|
208
|
-
h("div", { class: "Title" }, locale.WinDialog.
|
|
209
|
-
h("div", { class: "Description", innerHTML: localePostprocess(locale.WinDialog.Description, {
|
|
210
|
-
h("div", { class: "PageConfirmButtonsGroup" }, renderButton(instance, GradientButton.normal)))
|
|
255
|
+
h("div", { class: "Title" }, locale.WinDialog.Title),
|
|
256
|
+
h("div", { class: "Description", innerHTML: localePostprocess(locale.WinDialog.Description, { rewards }) }),
|
|
257
|
+
h("div", { class: "PageConfirmButtonsGroup" }, renderButton(instance, GradientButton.normal)))
|
|
258
|
+
:
|
|
259
|
+
h("div", { class: "PageConfirm Gift" },
|
|
260
|
+
h("div", null, iconWarn),
|
|
261
|
+
h("div", { class: "Title", innerHTML: localePostprocess(locale.WinDialog.FailedTitle, { failedRewards }) }),
|
|
262
|
+
h("div", { class: "Description" }, locale.WinDialog.FailedDescription),
|
|
263
|
+
h("div", { class: "PageConfirmButtonsGroup" }, renderButton(instance, GradientButton.okContinue)))));
|
|
211
264
|
},
|
|
212
265
|
unjoin(instance) {
|
|
213
266
|
const { locale } = instance;
|
|
@@ -240,6 +293,20 @@ const tournamentAdapter = (tournamentApi) => {
|
|
|
240
293
|
});
|
|
241
294
|
return tournament;
|
|
242
295
|
};
|
|
296
|
+
const updateTournament = (target, source) => {
|
|
297
|
+
const keysTime = [
|
|
298
|
+
'startTime',
|
|
299
|
+
'endTime',
|
|
300
|
+
'closeTime',
|
|
301
|
+
'exhibitionStartTime',
|
|
302
|
+
'exhibitionEndTime', 'state',
|
|
303
|
+
'prizes', 'minBetCount', 'scoreCriteria', 'termsUrl'
|
|
304
|
+
];
|
|
305
|
+
keysTime.forEach((key) => {
|
|
306
|
+
target[key] = source[key];
|
|
307
|
+
});
|
|
308
|
+
return Object.assign({}, target);
|
|
309
|
+
};
|
|
243
310
|
const leaderboardsAdapter = (leaderboardRes) => {
|
|
244
311
|
let { item, items: leaderboards } = leaderboardRes;
|
|
245
312
|
if (!item) {
|
|
@@ -278,28 +345,35 @@ const messageSender = {
|
|
|
278
345
|
GameClickReq: (game) => window.postMessage({ type: 'EngagementSuiteGameRedirect', data: { Slug: game.slug } }),
|
|
279
346
|
};
|
|
280
347
|
const messageReceiver = (instance) => {
|
|
281
|
-
|
|
348
|
+
return {
|
|
282
349
|
UpdateLeaderboardsPlayerRes: (rest) => {
|
|
283
|
-
|
|
350
|
+
const { rank, detail } = (getMaxRankStr(rest.data.items));
|
|
351
|
+
window.postMessage({ type: 'UpdateLeaderboardState', rank, detail });
|
|
284
352
|
},
|
|
285
353
|
UpdateLeaderboardStateReq: () => {
|
|
286
354
|
window.postMessage({ type: 'UpdateLeaderboardState', labels: ['win', 'new'] });
|
|
287
355
|
},
|
|
356
|
+
/*
|
|
357
|
+
* Update tournament games list when switch to game tab in detail page
|
|
358
|
+
*/
|
|
288
359
|
UpdateTournamentsItemRes: (rest) => {
|
|
289
360
|
const tournamentNew = tournamentAdapter(rest.data.item);
|
|
290
361
|
instance.tournamentItem = tournamentNew;
|
|
291
362
|
updateTournamentListByItem(instance, tournamentNew);
|
|
292
363
|
},
|
|
293
|
-
UpdateLeaderboardsRes: (rest) =>
|
|
294
|
-
|
|
295
|
-
|
|
364
|
+
UpdateLeaderboardsRes: (rest) => initPlayerLeaderboard(instance, rest),
|
|
365
|
+
//Parse the join tournament response
|
|
366
|
+
JoinTournamentRes: (rest) => commonJoinRes(instance, rest, true),
|
|
367
|
+
//Parse the unjoin tournament response
|
|
368
|
+
UnjoinTournamentRes: (rest) => commonJoinRes(instance, rest, false),
|
|
369
|
+
//Parse recieved init message when widget is loaded
|
|
296
370
|
TournamentsPageIsReadyRes: (rest) => instance.currentGameId = '' + rest.data.GameId,
|
|
297
371
|
// listen to LeaderboardLiveEvent event, handle update
|
|
298
|
-
LeaderboardLiveEvent: (rest) =>
|
|
299
|
-
|
|
300
|
-
},
|
|
372
|
+
LeaderboardLiveEvent: (rest) => handleLeaderboardLiveEvent(instance, rest),
|
|
373
|
+
LiveLeaderboardUpdate: (rest) => updateLeaderboardInfo(instance, Object.assign(Object.assign({}, rest), { messageType: 'LeaderboardUpdate' })),
|
|
374
|
+
LiveTournamentUpdate: (rest) => updateTournamentInfo(instance, Object.assign(Object.assign({}, rest), { messageType: 'TournamentUpdate' })),
|
|
375
|
+
LiveLeaderboardFinalizeUpdate: (rest) => updatePlayerRewardInfo(instance, Object.assign(Object.assign({}, rest), { messageType: 'PlayerFinalizeUpdate' })),
|
|
301
376
|
};
|
|
302
|
-
return receiver;
|
|
303
377
|
};
|
|
304
378
|
/**
|
|
305
379
|
* Handle LeaderboardLiveEvent update event
|
|
@@ -375,33 +449,45 @@ const handleLeaderboardLiveEvent = (instance, rest) => {
|
|
|
375
449
|
}
|
|
376
450
|
}
|
|
377
451
|
};
|
|
378
|
-
const
|
|
379
|
-
|
|
452
|
+
const clearUnjoinedTournament = (instance, unjoinedTournamentId) => {
|
|
453
|
+
const clearId = setTimeout(() => {
|
|
454
|
+
instance.tournamentList = instance.tournamentList.filter((tournament) => {
|
|
455
|
+
return tournament.id !== unjoinedTournamentId;
|
|
456
|
+
});
|
|
457
|
+
clearTimeout(clearId);
|
|
458
|
+
}, 100);
|
|
380
459
|
};
|
|
381
|
-
const commonJoinRes = (instance, rest) => {
|
|
460
|
+
const commonJoinRes = (instance, rest, isJoinRes) => {
|
|
382
461
|
const { success, data } = rest;
|
|
383
462
|
let tournamentIdx = instance.tournamentList.findIndex((tournament) => tournament.id === (data.tournamentId || data.id || data.bonusCode)), current = instance.tournamentList[tournamentIdx];
|
|
384
463
|
if (tournamentIdx == -1) {
|
|
385
464
|
return;
|
|
386
465
|
}
|
|
387
|
-
current =
|
|
466
|
+
current.isActionJoinPending = false;
|
|
388
467
|
instance.pendingChangeEvent.emit(current);
|
|
389
468
|
if (!success) {
|
|
390
469
|
instance.tournamentList[tournamentIdx] = current;
|
|
391
470
|
instance.tournamentList = [...instance.tournamentList];
|
|
392
|
-
|
|
471
|
+
instance.openDialog(DialogType.error);
|
|
393
472
|
return;
|
|
394
473
|
}
|
|
395
|
-
|
|
396
|
-
|
|
474
|
+
if (isJoinRes) {
|
|
475
|
+
current.isPlayerAcknowledged = true;
|
|
476
|
+
current.order = instance.minOrder--;
|
|
477
|
+
}
|
|
478
|
+
else {
|
|
479
|
+
current.isUnjoined = true;
|
|
480
|
+
clearUnjoinedTournament(instance, data.tournamentId);
|
|
481
|
+
}
|
|
482
|
+
instance.tournamentList[tournamentIdx] = Object.assign({}, current);
|
|
397
483
|
instance.tournamentList = [...instance.tournamentList];
|
|
398
484
|
if (instance.page === LeaderboardPage.item) {
|
|
399
|
-
if (
|
|
400
|
-
instance.
|
|
401
|
-
return;
|
|
485
|
+
if (isJoinRes) {
|
|
486
|
+
instance.tournamentItem = Object.assign({}, current);
|
|
402
487
|
}
|
|
403
488
|
else {
|
|
404
|
-
instance.
|
|
489
|
+
instance.setPage(LeaderboardPage.list);
|
|
490
|
+
return;
|
|
405
491
|
}
|
|
406
492
|
}
|
|
407
493
|
if (instance.nextPage) {
|
|
@@ -409,17 +495,21 @@ const commonJoinRes = (instance, rest) => {
|
|
|
409
495
|
instance.nextPage = undefined;
|
|
410
496
|
}
|
|
411
497
|
};
|
|
412
|
-
const
|
|
498
|
+
const initPlayerLeaderboard = (instance, rest) => {
|
|
413
499
|
instance.leaderboards = leaderboardsAdapter(rest.data);
|
|
414
|
-
instance.
|
|
500
|
+
instance.currentPlayerRank = rest.data.item ? rest.data.item.rank : -1;
|
|
415
501
|
};
|
|
416
502
|
/*
|
|
417
503
|
* update tournament info, include status, name or duration change
|
|
418
504
|
*/
|
|
419
505
|
const updateTournamentListByItem = (instance, tournament) => {
|
|
506
|
+
const newTournament = tournamentAdapter(tournament);
|
|
507
|
+
if (instance.tournamentItem.id === tournament.id) {
|
|
508
|
+
instance.tournamentItem = Object.assign({}, updateTournament(instance.tournamentItem, newTournament));
|
|
509
|
+
}
|
|
420
510
|
instance.tournamentList = instance.tournamentList.map((_tournament) => {
|
|
421
511
|
if (_tournament.id === tournament.id) {
|
|
422
|
-
return
|
|
512
|
+
return Object.assign({}, updateTournament(_tournament, newTournament));
|
|
423
513
|
}
|
|
424
514
|
else {
|
|
425
515
|
return _tournament;
|
|
@@ -430,8 +520,8 @@ const removeTournament = (instance, tournament) => {
|
|
|
430
520
|
instance.tournamentList = instance.tournamentList.filter((_tournament) => _tournament.id !== tournament.id);
|
|
431
521
|
};
|
|
432
522
|
const updateOrAddTournamentToList = (instance, tournament) => {
|
|
433
|
-
const index = instance.tournamentList.findIndex(
|
|
434
|
-
if (index === -1) {
|
|
523
|
+
const index = instance.tournamentList.findIndex(_tournament => _tournament.id === tournament.id);
|
|
524
|
+
if (index === -1) { //not found in list, handle it as new tournament
|
|
435
525
|
instance.tournamentList = [
|
|
436
526
|
tournamentAdapter(tournament),
|
|
437
527
|
...instance.tournamentList
|
|
@@ -442,6 +532,60 @@ const updateOrAddTournamentToList = (instance, tournament) => {
|
|
|
442
532
|
instance.tournamentList = [...instance.tournamentList];
|
|
443
533
|
}
|
|
444
534
|
};
|
|
535
|
+
const updateTournamentInfo = (instance, rest) => {
|
|
536
|
+
try {
|
|
537
|
+
const updateMessageObj = JSON.parse(rest.data.Message);
|
|
538
|
+
updateTournamentListByItem(instance, updateMessageObj);
|
|
539
|
+
}
|
|
540
|
+
catch (e) {
|
|
541
|
+
console.error('Exception when parse Player Tournament Info', e);
|
|
542
|
+
}
|
|
543
|
+
};
|
|
544
|
+
const updatePlayerRewardInfo = (instance, rest) => {
|
|
545
|
+
try {
|
|
546
|
+
const updateMessageObj = JSON.parse(rest.data.Message);
|
|
547
|
+
const assignFailedRewards = updateMessageObj.rewards.filter(item => item.status && item.status !== 'success')
|
|
548
|
+
.map(reward => getRewardNameByType(reward)).join(',');
|
|
549
|
+
const assignedRewards = updateMessageObj.rewards.filter(item => !!item.assigned && item.status === 'success')
|
|
550
|
+
.map(reward => getRewardNameByType(reward)).join(',');
|
|
551
|
+
if (assignFailedRewards.length) {
|
|
552
|
+
instance.gifts = [{ name: null, failedRewards: assignFailedRewards }, ...instance.gifts];
|
|
553
|
+
}
|
|
554
|
+
if (assignedRewards.length) {
|
|
555
|
+
instance.gifts = [{ name: assignedRewards }, ...instance.gifts];
|
|
556
|
+
}
|
|
557
|
+
instance.checkGift();
|
|
558
|
+
}
|
|
559
|
+
catch (e) {
|
|
560
|
+
console.error('Exception when parse Player LeaderboardFinalize info', e);
|
|
561
|
+
}
|
|
562
|
+
};
|
|
563
|
+
const updateLeaderboardInfo = (instance, rest) => {
|
|
564
|
+
var _a;
|
|
565
|
+
try {
|
|
566
|
+
const updateMessageObj = JSON.parse(rest.data.Message);
|
|
567
|
+
const { PlayerLeaderBoard, TournamentId, TournamentLeaderBoardDto } = updateMessageObj;
|
|
568
|
+
//update user rank in UI-bar by parsing PlayerLeaderboard
|
|
569
|
+
if (PlayerLeaderBoard) {
|
|
570
|
+
window.postMessage({ type: 'UpdateLeaderboardState',
|
|
571
|
+
rank: `${PlayerLeaderBoard.rank} / ${TournamentLeaderBoardDto.totalRecords}`,
|
|
572
|
+
detail: {
|
|
573
|
+
playerRank: PlayerLeaderBoard.rank,
|
|
574
|
+
total: TournamentLeaderBoardDto.totalRecords
|
|
575
|
+
}
|
|
576
|
+
});
|
|
577
|
+
}
|
|
578
|
+
if (((_a = instance.tournamentItem) === null || _a === void 0 ? void 0 : _a.id) == TournamentId) {
|
|
579
|
+
initPlayerLeaderboard(instance, { data: {
|
|
580
|
+
item: Object.assign({}, PlayerLeaderBoard),
|
|
581
|
+
items: [...TournamentLeaderBoardDto.players]
|
|
582
|
+
} });
|
|
583
|
+
}
|
|
584
|
+
}
|
|
585
|
+
catch (err) {
|
|
586
|
+
console.error('Exception when parse live update info, ', err);
|
|
587
|
+
}
|
|
588
|
+
};
|
|
445
589
|
|
|
446
590
|
const page = {
|
|
447
591
|
list(instance) {
|
|
@@ -452,7 +596,9 @@ const page = {
|
|
|
452
596
|
}
|
|
453
597
|
const { locale } = instance;
|
|
454
598
|
if (instance.tournamentList.length) {
|
|
455
|
-
return renderWrapperByPageType(h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament) => (
|
|
599
|
+
return renderWrapperByPageType(h("div", { class: "Leaderboards ScrollBar Row" }, instance.tournamentList.map((_tournament, idx) => (
|
|
600
|
+
// @ts-ignore
|
|
601
|
+
h("tournament-item", { tid: _tournament.id, key: _tournament.id, tournament: _tournament, style: { 'order': `${_tournament.order || idx}` }, isNew: instance.newIdList.includes(_tournament.id) })))));
|
|
456
602
|
}
|
|
457
603
|
else {
|
|
458
604
|
return renderWrapperByPageType(h("div", { class: "NoLeaderboards ScrollBar Row" },
|
|
@@ -508,20 +654,25 @@ function getProgress(startDate, endDate) {
|
|
|
508
654
|
if (new Date().getTime() >= endDate.getTime()) {
|
|
509
655
|
return 100;
|
|
510
656
|
}
|
|
511
|
-
return ((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime()))
|
|
657
|
+
return Math.floor((100 * (new Date().getTime() - startDate.getTime())) / (endDate.getTime() - startDate.getTime()));
|
|
512
658
|
}
|
|
513
|
-
function getTimeDifference(startDate, endDate) {
|
|
659
|
+
function getTimeDifference(startDate, endDate, progress = 0) {
|
|
514
660
|
const diffMs = Math.abs(endDate.getTime() - startDate.getTime()); // Difference in milliseconds
|
|
515
661
|
const diffDays = Math.floor(diffMs / (1000 * 60 * 60 * 24)); // Difference in days
|
|
516
662
|
const diffHours = Math.floor((diffMs % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)); // Remaining hours
|
|
517
663
|
const diffMinutes = Math.floor((diffMs % (1000 * 60 * 60)) / (1000 * 60)); // Remaining minutes
|
|
518
|
-
|
|
664
|
+
const min = progress === 100 ? 0 : diffMinutes === 0 ? 1 : diffMinutes;
|
|
665
|
+
return `${String(diffDays).padStart(2, '0')}d:${String(diffHours).padStart(2, '0')}h:${String(min).padStart(2, '0')}m`;
|
|
519
666
|
}
|
|
520
667
|
|
|
521
668
|
const tab = {
|
|
522
669
|
info(instance) {
|
|
523
670
|
var _a, _b;
|
|
524
671
|
const { locale, tournamentItem: tournament, isShowInfo } = instance;
|
|
672
|
+
const playerRank = getResultPrize((_a = instance.leaderboards) === null || _a === void 0 ? void 0 : _a.find((l) => l.isMe));
|
|
673
|
+
const rewardInfo = !(playerRank === null || playerRank === void 0 ? void 0 : playerRank.place) || (playerRank === null || playerRank === void 0 ? void 0 : playerRank.unqualified)
|
|
674
|
+
? ''
|
|
675
|
+
: localePostprocess(((playerRank === null || playerRank === void 0 ? void 0 : playerRank.prize) ? locale.TipPrize : locale.TipPrizeWithoutReward), playerRank);
|
|
525
676
|
return (h("div", { class: "InfoContainer" },
|
|
526
677
|
h("tournament-timer", { "is-detail": true, tournament: tournament }),
|
|
527
678
|
h("section", { class: "ShowInfo", onClick: () => (instance.isShowInfo = !instance.isShowInfo) },
|
|
@@ -542,15 +693,17 @@ const tab = {
|
|
|
542
693
|
h("span", null, tournament.minBetCount))),
|
|
543
694
|
!!tournament.termsUrl && (h("div", { class: "TC" },
|
|
544
695
|
h("a", { href: tournament.termsUrl, target: "_blank" }, locale.TC))))),
|
|
545
|
-
isTournamentClosed(instance.tournamentItem) && ((
|
|
696
|
+
isTournamentClosed(instance.tournamentItem) && ((_b = instance.leaderboards) === null || _b === void 0 ? void 0 : _b.find((l) => l.isMe)) && (h("section", { class: "ResultPrize", innerHTML: rewardInfo })),
|
|
546
697
|
h("section", { class: "PrizesContainer" },
|
|
547
698
|
h("div", { class: "PrizesHeader" },
|
|
548
699
|
iconReward,
|
|
549
700
|
h("span", { class: "PrizesText" }, locale.Prizes)),
|
|
550
|
-
h("div", { class: "Prizes" }, tournament.prizes.map((prize
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
701
|
+
h("div", { class: "Prizes" }, tournament.prizes.map((prize) => (h("div", { class: "Prize" },
|
|
702
|
+
h("span", { class: 'Rank' },
|
|
703
|
+
prize.rank,
|
|
704
|
+
" ",
|
|
705
|
+
prize.count === 1 ? '' : ` - ${(prize.rank + prize.count - 1)}`),
|
|
706
|
+
prize.count === 1 ? locale.Place : locale.Places,
|
|
554
707
|
": ",
|
|
555
708
|
h("span", { class: "PrizeText" }, prize.name)))))))));
|
|
556
709
|
},
|
|
@@ -574,6 +727,8 @@ const tab = {
|
|
|
574
727
|
},
|
|
575
728
|
games(instance) {
|
|
576
729
|
var _a;
|
|
730
|
+
if (!instance.tournamentItem.games || !instance.tournamentItem.games.length)
|
|
731
|
+
return h("general-animation-loading", null);
|
|
577
732
|
return (h("div", { class: "Games" }, (_a = instance.tournamentItem.games) === null || _a === void 0 ? void 0 : _a.map((game) => (h("div", { class: `Game ${instance.currentGameId == game.id ? 'Current' : ''}`, onClick: () => {
|
|
578
733
|
instance.onGameClick(game);
|
|
579
734
|
} },
|
|
@@ -582,8 +737,9 @@ const tab = {
|
|
|
582
737
|
};
|
|
583
738
|
const getResultPrize = (leaderboard) => {
|
|
584
739
|
return {
|
|
585
|
-
prize: leaderboard.prizeName,
|
|
586
|
-
place: leaderboard.rank
|
|
740
|
+
prize: leaderboard === null || leaderboard === void 0 ? void 0 : leaderboard.prizeName,
|
|
741
|
+
place: leaderboard === null || leaderboard === void 0 ? void 0 : leaderboard.rank,
|
|
742
|
+
unqualified: leaderboard === null || leaderboard === void 0 ? void 0 : leaderboard.unqualified,
|
|
587
743
|
};
|
|
588
744
|
};
|
|
589
745
|
|
|
@@ -615,7 +771,7 @@ const renderCloseBar = (attr) => {
|
|
|
615
771
|
return (h("div", { class: "WrapperBar" }, Object.keys(slots).map(slotKey => (h("div", { class: 'WrapperBar' + getFirstLetterUppercase(slotKey) }, slots[slotKey] || '')))));
|
|
616
772
|
};
|
|
617
773
|
|
|
618
|
-
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}}";
|
|
774
|
+
const casinoEngagementSuiteTournamentCss = ".Leaderboards{height:100%;overflow-y:auto;transition:0.5s ease;transition-property:all, transform}.Leaderboards.list,.Leaderboards.item{margin-top:5px;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}table.Leaderboards td.LeaderboardName{max-width:180px}table.Leaderboards td.LeaderboardPrize{min-width:220px;text-align:left}.Wrapper{position:relative;min-height:100%;line-height:20px;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 - 298px);overflow-y:auto}.Wrapper .WrapperContent .Main{height:calc(100vh - 188px)}.Wrapper .WrapperContent .Main .Leaderboards.ScrollBar.Row{display:flex;flex-direction:column}.Wrapper .WrapperContent .Main .Leaderboards.ScrollBar.Row tournament-item{transition:2s ease-in-out;transform:translate(0) scale(1, 1);opacity:0.99}.Wrapper.Mobile{border-radius:16px}.Wrapper.Mobile .PageConfirmContainer,.Wrapper.Mobile .DialogContentUnjoin{min-width:80%}.Wrapper.Mobile dialog.tip{padding:120px 10px}.Wrapper.Mobile dialog.unjoin .Hollow{margin:5px}.Wrapper.Mobile .GradientRoundedButton{font-size:var(--emw--font-size-medium, 14px)}.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}.Wrapper.Mobile .Tip{padding:0px 30px 32px}.Wrapper.Mobile .TitleContainer .GradientRoundedButton{width:100px}.WrapperBar{display:flex;width:100%;padding:20px 20px}.WrapperBar .WrapperBarLeft span{position:relative}.WrapperBarLeft,.WrapperBarRight{cursor:pointer;z-index:1}.WrapperBarLeft span.EngagementSuiteIcon img,.WrapperBarRight span.EngagementSuiteIcon img{width:24px;height:24px}.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, 14px)}.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:20px 0;border:1px solid rgb(64, 57, 86);border-radius:6px;padding:12px 0}.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, 14px);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, 14px);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, 14px);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-large, 20px);font-weight:700;line-height:19.5px;text-align:left;word-break:break-word}.TC{margin-top:14px}.TC a{color:rgb(89, 209, 255)}.Criterias{margin:14px 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:14px}.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 .Rank{margin-right:5px}.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.tip{position:absolute;align-items:start;padding:120px 90px;line-height:20px;font-size:var(--emw--font-size-small, 16px)}dialog.tip>div{margin:0px}dialog{display:none;position:fixed;left:0;top:0;width:100%;height:100%;background-color:rgba(0, 0, 0, 0.5);justify-content:center;align-items:center;z-index:1;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}dialog div.Hollow .WrapperBar{padding:12px}dialog div.Hollow .WrapperBar .WrapperBarRight img{width:20px}dialog div.Hollow .Tip{line-height:20px;padding:0px 60px 32px;font-size:var(--emw--font-size-small, 16px)}dialog[open]{display:flex}.DialogContentUnjoin{padding:32px;padding-top:10px;display:flex;gap:10px;max-width:510px;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:0px;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%;min-width:450px;max-width:510px;margin:0 auto}.PageConfirm{padding:0px 32px 60px;display:flex;flex-direction:column;gap:20px}.PageConfirm .Title{font-size:var(--emw--font-size-large, 26px);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}.PageConfirm.Gift{padding:22px 32px 60px}.PageConfirm.Gift .Title{font-size:var(--emw--font-size-large, 30px)}.PageConfirm.Gift .Description{font-size:var(--emw--font-size-medium, 20px)}.PageConfirm.Gift .PageConfirmButtonsGroup .GradientRoundedButton{font-size:var(--emw--font-size-medium, 20px);padding:12px;height:auto}.PageConfirm.Gift .PageConfirmButtonsGroup .GradientRoundedButton.GradientRounded{border-radius:20px}.PageConfirmButtonsGroup{width:150px;margin:20px 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-medium, 16px);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}.LeaderboardsItem.GradientRounded.Hollow::before{border-radius:7px}.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}}";
|
|
619
775
|
const CasinoEngagementSuiteTournamentStyle0 = casinoEngagementSuiteTournamentCss;
|
|
620
776
|
|
|
621
777
|
const CasinoEngagementSuiteTournament = class {
|
|
@@ -686,7 +842,14 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
686
842
|
}, 300);
|
|
687
843
|
}
|
|
688
844
|
};
|
|
689
|
-
|
|
845
|
+
if (this.show) {
|
|
846
|
+
this.openDialog(DialogType.gift, this.gifts[0], onClose);
|
|
847
|
+
}
|
|
848
|
+
else {
|
|
849
|
+
//Show 'Win' Label on the left ui-bar,
|
|
850
|
+
this.labels.push('win');
|
|
851
|
+
messageSender.UpdateSuiteBarState(this.labels);
|
|
852
|
+
}
|
|
690
853
|
}
|
|
691
854
|
else {
|
|
692
855
|
this.removeLabel('win');
|
|
@@ -703,9 +866,6 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
703
866
|
this.showTooltip = false;
|
|
704
867
|
}
|
|
705
868
|
componentDidLoad() {
|
|
706
|
-
this.pageElement.addEventListener('scroll', (event) => {
|
|
707
|
-
this.containerScrollTop = event.target.scrollTop + event.target.clientHeight / 2 - 250;
|
|
708
|
-
});
|
|
709
869
|
messageSender.UpdateTournamentsPageIsReady();
|
|
710
870
|
}
|
|
711
871
|
renderTooltip() {
|
|
@@ -726,7 +886,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
726
886
|
}
|
|
727
887
|
componentDidRender() {
|
|
728
888
|
if (this.page === LeaderboardPage.item && this.tab === Tab.leaderboard) {
|
|
729
|
-
if (this.
|
|
889
|
+
if (this.currentPlayerRank > this.defaultPageSize && !this.scrolledToMyLine) {
|
|
730
890
|
this.scrollToMyRankLine();
|
|
731
891
|
}
|
|
732
892
|
}
|
|
@@ -744,6 +904,11 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
744
904
|
if (tournament.isActionJoinPending)
|
|
745
905
|
return;
|
|
746
906
|
tournament.isActionJoinPending = true;
|
|
907
|
+
//Disable the unjoin button when action in detail page
|
|
908
|
+
if (this.page === LeaderboardPage.item) {
|
|
909
|
+
this.tournamentItem.isActionJoinPending = true;
|
|
910
|
+
this.tournamentItem = Object.assign({}, this.tournamentItem);
|
|
911
|
+
}
|
|
747
912
|
this.pendingChangeEvent.emit(tournament);
|
|
748
913
|
try {
|
|
749
914
|
if (tournament.isPlayerAcknowledged) {
|
|
@@ -765,7 +930,7 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
765
930
|
if (!this.tournamentItem) {
|
|
766
931
|
messageSender.UpdateTournamentsItemReq(metaData.tournament);
|
|
767
932
|
}
|
|
768
|
-
if (
|
|
933
|
+
if (isTournamentEnded(this.tournamentItem)) {
|
|
769
934
|
messageSender.UpdateLeaderboardsReq(this.tournamentItem);
|
|
770
935
|
}
|
|
771
936
|
this.tab = Tab.info;
|
|
@@ -787,21 +952,27 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
787
952
|
};
|
|
788
953
|
return (h(Host, null, h("general-styling-wrapper", { clientStylingUrl: this.clientStylingUrl, clientStyling: this.clientStyling,
|
|
789
954
|
// @ts-ignore
|
|
790
|
-
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), h("div", { class: `Wrapper ${this.device}` }, h("div", { class: classnames('WrapperContent', { faded: this.dialog.isOpen }) }, renderCloseBar({
|
|
955
|
+
targetTranslations: TRANSLATIONS, translationUrl: this.translationUrl }), h("div", { class: `Wrapper ${this.device} ${this.orientation}` }, h("div", { class: classnames('WrapperContent', { faded: this.dialog.isOpen, page: this.page }) }, this.page && renderCloseBar({
|
|
791
956
|
left: this.page === LeaderboardPage.list
|
|
792
|
-
? h("span", { onClick: this.openDialog.bind(this, DialogType.tip) }, iconQuestion)
|
|
793
|
-
: h("span", { onClick: this.setPage.bind(this, LeaderboardPage.list) }, iconBack),
|
|
957
|
+
? h("span", { class: 'EngagementSuiteIcon', onClick: this.openDialog.bind(this, DialogType.tip) }, iconQuestion)
|
|
958
|
+
: h("span", { class: 'EngagementSuiteIcon', onClick: this.setPage.bind(this, LeaderboardPage.list) }, iconBack),
|
|
794
959
|
middle: this.locale.Leaderboards,
|
|
795
|
-
right: h("span", { onClick: () => this.close.emit() }, iconClose)
|
|
960
|
+
right: h("span", { class: 'EngagementSuiteIcon', onClick: () => this.close.emit() }, iconClose)
|
|
796
961
|
}), h("div", { class: `Leaderboards ${this.page} ${this.page === 'list' ? 'Active' : 'Hidden'}`, ref: el => this.pageElement = el }, this.renders.page.list()), this.page === LeaderboardPage.item &&
|
|
797
|
-
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", {
|
|
798
|
-
right: h("span", { onClick: () => this.closeDialog() }, iconClose)
|
|
962
|
+
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", { class: `${this.dialog.type}`, open: this.dialog.isOpen }, h("div", { class: `Hollow ${this.dialog.type === 'gift' ? 'GradientRounded' : ''}` }, renderCloseBar({
|
|
963
|
+
right: h("span", { class: 'EngagementSuiteIcon', onClick: () => this.closeDialog() }, iconClose)
|
|
799
964
|
}), this.dialog.isOpen && renderDialogContent()))))));
|
|
800
965
|
}
|
|
801
966
|
openDialog(type, data = undefined, onClose = undefined) {
|
|
802
967
|
this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: true, onClose,
|
|
803
968
|
type,
|
|
804
969
|
data });
|
|
970
|
+
if (type === DialogType.error || type === DialogType.tip) {
|
|
971
|
+
const timerId = setTimeout(() => {
|
|
972
|
+
this.dialog = Object.assign(Object.assign({}, this.dialog), { isOpen: false });
|
|
973
|
+
clearInterval(timerId);
|
|
974
|
+
}, this.tipsHideDelay);
|
|
975
|
+
}
|
|
805
976
|
}
|
|
806
977
|
closeDialog() {
|
|
807
978
|
var _a;
|
|
@@ -813,10 +984,14 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
813
984
|
this.close = createEvent(this, "close", 7);
|
|
814
985
|
this.tournamentTimer = createEvent(this, "tournamentTimer", 7);
|
|
815
986
|
this.pendingChangeEvent = createEvent(this, "pendingChangeEvent", 7);
|
|
987
|
+
/**
|
|
988
|
+
* Use to move the new acknowleged tournament to top
|
|
989
|
+
*/
|
|
990
|
+
this.minOrder = -1;
|
|
816
991
|
this.gifts = [];
|
|
817
992
|
this.labels = [];
|
|
818
993
|
this.showTooltip = false;
|
|
819
|
-
this.
|
|
994
|
+
this.defaultPageSize = DEFAULT_PAGE_SIZE;
|
|
820
995
|
this.scrolledToMyLine = false;
|
|
821
996
|
this.language = 'en';
|
|
822
997
|
this.show = false;
|
|
@@ -824,7 +999,9 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
824
999
|
this.clientStylingUrl = '';
|
|
825
1000
|
this.translationUrl = '';
|
|
826
1001
|
this.device = 'Mobile';
|
|
1002
|
+
this.orientation = 'Landscape';
|
|
827
1003
|
this.leaderboardsInit = undefined;
|
|
1004
|
+
this.tipsHideDelay = 3 * 1000;
|
|
828
1005
|
this.tab = Tab.info;
|
|
829
1006
|
this.locale = TRANSLATIONS;
|
|
830
1007
|
this.tournamentItem = undefined;
|
|
@@ -858,4 +1035,4 @@ const CasinoEngagementSuiteTournament = class {
|
|
|
858
1035
|
};
|
|
859
1036
|
CasinoEngagementSuiteTournament.style = CasinoEngagementSuiteTournamentStyle0;
|
|
860
1037
|
|
|
861
|
-
export { CasinoEngagementSuiteTournament as C, DialogType as D, LeaderboardPage as L, TRANSLATIONS as T,
|
|
1038
|
+
export { CasinoEngagementSuiteTournament as C, DialogType as D, LeaderboardPage as L, TRANSLATIONS as T, getTimeDifference as a, classnames as c, formatDate as f, getProgress as g, isTournamentEnded as i, renderGradientRoundedButton as r };
|