@everymatrix/casino-challenges-container 0.0.1 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/casino-challenges-container/casino-challenges-container-c6332600.js +1 -0
- package/dist/casino-challenges-container/casino-challenges-container.entry.js +1 -1
- package/dist/casino-challenges-container/casino-challenges-container.esm.js +1 -1
- package/dist/casino-challenges-container/index.esm.js +1 -1
- package/dist/cjs/{casino-challenges-container-54a20dee.js → casino-challenges-container-f2c3603f.js} +67 -4
- package/dist/cjs/casino-challenges-container.cjs.entry.js +2 -1
- package/dist/cjs/casino-challenges-container.cjs.js +1 -1
- package/dist/cjs/index.cjs.js +2 -1
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/components/casino-challenges-container/casino-challenges-container.css +15 -2
- package/dist/collection/components/casino-challenges-container/casino-challenges-container.js +144 -3
- package/dist/collection/utils/locale.utils.js +2 -1
- package/dist/collection/utils/types.js +40 -0
- package/dist/esm/{casino-challenges-container-affc90f5.js → casino-challenges-container-c6332600.js} +67 -4
- package/dist/esm/casino-challenges-container.entry.js +2 -1
- package/dist/esm/casino-challenges-container.js +1 -1
- package/dist/esm/index.js +2 -1
- package/dist/esm/loader.js +1 -1
- package/dist/types/components/casino-challenges-container/casino-challenges-container.d.ts +30 -0
- package/dist/types/components.d.ts +32 -0
- package/dist/types/utils/types.d.ts +130 -0
- package/package.json +1 -1
- package/dist/casino-challenges-container/casino-challenges-container-affc90f5.js +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import{r as V,h as U}from"./index-9c823353.js";import"@everymatrix/casino-challenges-list";function N(V,U){if(V){const N=document.createElement("style");N.innerHTML=U,V.appendChild(N)}}function Z(V,U){const N=new URL(U);fetch(N.href).then((V=>V.text())).then((U=>{const N=document.createElement("style");N.innerHTML=U,V&&V.appendChild(N)})).catch((V=>{console.error("There was an error while trying to load client styling from URL",V)}))}function R(V,U){if(window.emMessageBus){const N=document.createElement("style");window.emMessageBus.subscribe(U,(U=>{N.innerHTML=U,V&&V.appendChild(N)}))}}const d={en:{title:"Challenges",empty:"No Challenges"},ro:{},fr:{},ar:{},hr:{}},l=(V,U)=>d[void 0!==U&&U in d?U:"en"][V],T=class{constructor(U){V(this,U),this.tabs=["Active","Pending","Finished","Code"],this.showNotification=1,this.checkAttrs=()=>(this.endpoint||(this.error="Endpoint is missing! Please provide a valid endpointURL.",this.hasError=!0,console.error(this.error)),this.hasError),this.onLoadMore=()=>{this.pageNumber+=1,this.getChallenges().then((V=>{this.challenges=[...this.challenges,...V.Data],this.total=V.TotalCount}))},this.handleTabClick=V=>()=>{this.activeTabIndex=V,this.challenges=[],this.pageNumber=0,this.total=0,this.loadData()},this.mbSource=void 0,this.clientStyling=void 0,this.clientStylingUrl=void 0,this.translationUrl="",this.language="en",this.endpoint="",this.domain="",this.session="",this.userId="",this.activeTabIndex=0,this.error="",this.hasError=!1,this.challenges=[],this.loading=!1,this.pageNumber=0,this.total=0,this.pageSize=20}handleClientStylingChange(V,U){V!=U&&N(this.stylingContainer,this.clientStyling)}handleClientStylingUrlChange(V,U){V!=U&&Z(this.stylingContainer,this.clientStylingUrl)}handleMbSourceChange(V,U){V!=U&&R(this.stylingContainer,`${this.mbSource}.Style`)}async getChallenges(){if(!this.checkAttrs()){const V=`${this.endpoint}/challenge/${2===this.activeTabIndex?"/PlayerHistory":"/GetChallengesInfo"}`,U=Object.assign(Object.assign({DomainId:this.domain,PlayerLanguage:this.language,PageNumber:this.pageNumber,PageSize:this.pageSize},this.session&&{PlayerSessionId:this.session}),this.userId&&2===this.activeTabIndex&&{UserId:this.userId});return this.loading=!0,fetch(V,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(U)}).then((V=>V.json())).finally((()=>this.loading=!1))}}loadData(){this.getChallenges().then((V=>{(null==V?void 0:V.Success)&&(this.pageNumber=V.PageNumber,this.total=V.TotalCount)}))}componentDidLoad(){this.stylingContainer&&(this.mbSource&&R(this.stylingContainer,`${this.mbSource}.Style`),this.clientStyling&&N(this.stylingContainer,this.clientStyling),this.clientStylingUrl&&Z(this.stylingContainer,this.clientStylingUrl)),this.loadData()}disconnectedCallback(){this.stylingSubscription&&this.stylingSubscription.unsubscribe()}componentWillLoad(){this.translationUrl&&(async V=>{if(V)try{const N=await fetch(V);if(!N.ok)throw new Error(`HTTP error! status: ${N.status}`);const Z=await N.json();U=Z,Object.keys(U).forEach((V=>{for(let N in U[V])d[V][N]=U[V][N]}))}catch(V){console.error("Failed to fetch or parse translations from URL:",V)}var U})(this.translationUrl)}onTimerExpired(V){setTimeout((()=>{this.challenges=this.challenges.filter((U=>U.Id!==V.detail))}),1e4)}render(){var V;return U("div",{key:"af2e5b13351a5b8694258c628f545d6a127e80dc",ref:V=>this.stylingContainer=V},U("div",{key:"91cdbc6a152a8b8c884842370c5509e7f6752074",class:"challenges"},U("div",{key:"d480a88d50cea5789eabb8dcc30233aea7d18d0f",class:"challenges__header"},U("h1",{key:"8cd8787debb4f6f9897291f11c131c4ea1ef1d15",class:"challenges__title"},U("img",{key:"1551482df42aaf36ed5cac7b2834bc276cc5cf52",src:"",alt:"icon"}),l("title",this.language)),this.session&&U("div",{key:"b45e42e56d5abc570b72979490f6e7ff4bf4f1bd",class:"challenges__tabs"},this.tabs.map(((V,N)=>U("div",{class:"challenges__tab "+(N===this.activeTabIndex?"active":""),onClick:this.handleTabClick(N)},V,this.showNotification===N&&U("img",{src:""})))))),U("div",{key:"d1a2a52ff5d26f17e401a7a3707f4153bbbc6290",class:"challenges__content"},0===this.challenges.length&&!this.loading&&U("div",{key:"f0ab8469ac8a795b4d25d925bc1065217398e862",class:"empty"},l("empty",this.language)),3!==this.activeTabIndex&&U("casino-challenges-list",{key:"2f7aaf6e940668be6e15e1cfb81f5d2d063361ef",challenges:this.challenges,onLoadMore:this.onLoadMore,onTimerExpired:this.onTimerExpired,loading:this.loading,hasMore:(null===(V=this.challenges)||void 0===V?void 0:V.length)<this.total,language:this.language}))))}static get watchers(){return{clientStyling:["handleClientStylingChange"],clientStylingUrl:["handleClientStylingUrlChange"],mbSource:["handleMbSourceChange"]}}};T.style=".challenges {\n container-type: inline-size;\n container-name: challenges-container;\n background-color: var(--emw--color-background, #000);\n padding: 16px 12px;\n}\n.challenges__header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n}\n.challenges__title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n color: var(--emw--color-white, #ffffff);\n}\n.challenges__tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #c8d6ce);\n background-color: var(--emw--color-background-secondary, #272727);\n}\n.challenges__tab {\n padding: 10px 16px;\n border-radius: 40px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n cursor: pointer;\n text-align: center;\n width: 95px;\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 4px;\n}\n.challenges__tab.active {\n color: var(--emw--color-white, #ffffff);\n background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);\n}\n.challenges__tab:last-child {\n width: inherit;\n padding: 10px 16px;\n}\n.challenges__content {\n display: flex;\n align-items: center;\n justify-content: center;\n min-height: 300px;\n overflow-y: auto;\n}\n.challenges__empty {\n color: var(--emw--color-white, #ffffff);\n}\n@container challenges-container (max-width: 800px) {\n .challenges__header {\n margin: 0 0 16px;\n flex-wrap: wrap;\n row-gap: 12px;\n }\n .challenges__title {\n width: 100%;\n font-size: var(--emw--font-size-large, 20px);\n }\n .challenges__title img {\n height: 32px;\n }\n .challenges__tabs {\n width: 100%;\n gap: 8px;\n }\n .challenges__tab {\n flex: 1;\n padding: 5px 0;\n font-size: var(--emw--font-size-x-small, 12px);\n }\n .challenges__tab:last-child {\n width: inherit;\n padding: 5px 0;\n }\n}";export{T as C}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export{C as casino_challenges_container}from"./casino-challenges-container-
|
|
1
|
+
export{C as casino_challenges_container}from"./casino-challenges-container-c6332600.js";import"./index-9c823353.js";import"@everymatrix/casino-challenges-list";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{p as n,b as e}from"./index-9c823353.js";export{s as setNonce}from"./index-9c823353.js";import{g as l}from"./app-globals-0f993ce5.js";(()=>{const e=import.meta.url,l={};return""!==e&&(l.resourcesUrl=new URL(".",e).href),n(l)})().then((async n=>(await l(),e([["casino-challenges-container",[[1,"casino-challenges-container",{mbSource:[513,"mb-source"],clientStyling:[513,"client-styling"],clientStylingUrl:[513,"client-styling-url"],translationUrl:[513,"translation-url"],language:[513],activeTabIndex:[32]},null,{clientStyling:["handleClientStylingChange"],clientStylingUrl:["handleClientStylingUrlChange"],mbSource:["handleMbSourceChange"]}]]]],n))));
|
|
1
|
+
import{p as n,b as e}from"./index-9c823353.js";export{s as setNonce}from"./index-9c823353.js";import{g as l}from"./app-globals-0f993ce5.js";(()=>{const e=import.meta.url,l={};return""!==e&&(l.resourcesUrl=new URL(".",e).href),n(l)})().then((async n=>(await l(),e([["casino-challenges-container",[[1,"casino-challenges-container",{mbSource:[513,"mb-source"],clientStyling:[513,"client-styling"],clientStylingUrl:[513,"client-styling-url"],translationUrl:[513,"translation-url"],language:[513],endpoint:[513],domain:[513],session:[513],userId:[513,"user-id"],activeTabIndex:[32],error:[32],hasError:[32],challenges:[32],loading:[32],pageNumber:[32],total:[32],pageSize:[32]},null,{clientStyling:["handleClientStylingChange"],clientStylingUrl:["handleClientStylingUrlChange"],mbSource:["handleMbSourceChange"]}]]]],n))));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
export{C as CasinoChallengesContainer}from"./casino-challenges-container-
|
|
1
|
+
export{C as CasinoChallengesContainer}from"./casino-challenges-container-c6332600.js";import"./index-9c823353.js";import"@everymatrix/casino-challenges-list";
|
package/dist/cjs/{casino-challenges-container-54a20dee.js → casino-challenges-container-f2c3603f.js}
RENAMED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
3
|
const index = require('./index-cf89b5da.js');
|
|
4
|
+
require('@everymatrix/casino-challenges-list');
|
|
4
5
|
|
|
5
6
|
/**
|
|
6
7
|
* @name setClientStyling
|
|
@@ -62,7 +63,8 @@ function setStreamStyling(stylingContainer, domain, subscription) {
|
|
|
62
63
|
const DEFAULT_LANGUAGE = 'en';
|
|
63
64
|
const TRANSLATIONS = {
|
|
64
65
|
en: {
|
|
65
|
-
title: 'Challenges'
|
|
66
|
+
title: 'Challenges',
|
|
67
|
+
empty: 'No Challenges'
|
|
66
68
|
},
|
|
67
69
|
ro: {},
|
|
68
70
|
fr: {},
|
|
@@ -100,24 +102,53 @@ const titleIconSvg = '
|
|
|
100
102
|
|
|
101
103
|
const notificationSvg = '';
|
|
102
104
|
|
|
103
|
-
const casinoChallengesContainerCss = ".challenges {\n container-type: inline-size;\n container-name: challenges-container;\n}\n.challenges__header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n}\n.challenges__title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.challenges__tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #
|
|
105
|
+
const casinoChallengesContainerCss = ".challenges {\n container-type: inline-size;\n container-name: challenges-container;\n background-color: var(--emw--color-background, #000);\n padding: 16px 12px;\n}\n.challenges__header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n}\n.challenges__title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n color: var(--emw--color-white, #ffffff);\n}\n.challenges__tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #c8d6ce);\n background-color: var(--emw--color-background-secondary, #272727);\n}\n.challenges__tab {\n padding: 10px 16px;\n border-radius: 40px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n cursor: pointer;\n text-align: center;\n width: 95px;\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 4px;\n}\n.challenges__tab.active {\n color: var(--emw--color-white, #ffffff);\n background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);\n}\n.challenges__tab:last-child {\n width: inherit;\n padding: 10px 16px;\n}\n.challenges__content {\n display: flex;\n align-items: center;\n justify-content: center;\n min-height: 300px;\n overflow-y: auto;\n}\n.challenges__empty {\n color: var(--emw--color-white, #ffffff);\n}\n@container challenges-container (max-width: 800px) {\n .challenges__header {\n margin: 0 0 16px;\n flex-wrap: wrap;\n row-gap: 12px;\n }\n .challenges__title {\n width: 100%;\n font-size: var(--emw--font-size-large, 20px);\n }\n .challenges__title img {\n height: 32px;\n }\n .challenges__tabs {\n width: 100%;\n gap: 8px;\n }\n .challenges__tab {\n flex: 1;\n padding: 5px 0;\n font-size: var(--emw--font-size-x-small, 12px);\n }\n .challenges__tab:last-child {\n width: inherit;\n padding: 5px 0;\n }\n}";
|
|
104
106
|
const CasinoChallengesContainerStyle0 = casinoChallengesContainerCss;
|
|
105
107
|
|
|
106
108
|
const CasinoChallengesContainer = class {
|
|
107
109
|
constructor(hostRef) {
|
|
108
110
|
index.registerInstance(this, hostRef);
|
|
109
|
-
// todo: connect with api
|
|
110
111
|
this.tabs = ['Active', 'Pending', 'Finished', 'Code'];
|
|
111
112
|
this.showNotification = 1;
|
|
113
|
+
this.checkAttrs = () => {
|
|
114
|
+
if (!this.endpoint) {
|
|
115
|
+
this.error = 'Endpoint is missing! Please provide a valid endpointURL.';
|
|
116
|
+
this.hasError = true;
|
|
117
|
+
console.error(this.error);
|
|
118
|
+
}
|
|
119
|
+
return this.hasError;
|
|
120
|
+
};
|
|
121
|
+
this.onLoadMore = () => {
|
|
122
|
+
this.pageNumber += 1;
|
|
123
|
+
this.getChallenges().then((res) => {
|
|
124
|
+
this.challenges = [...this.challenges, ...res.Data];
|
|
125
|
+
this.total = res.TotalCount;
|
|
126
|
+
});
|
|
127
|
+
};
|
|
112
128
|
this.handleTabClick = (index) => () => {
|
|
113
129
|
this.activeTabIndex = index;
|
|
130
|
+
this.challenges = [];
|
|
131
|
+
this.pageNumber = 0;
|
|
132
|
+
this.total = 0;
|
|
133
|
+
this.loadData();
|
|
114
134
|
};
|
|
115
135
|
this.mbSource = undefined;
|
|
116
136
|
this.clientStyling = undefined;
|
|
117
137
|
this.clientStylingUrl = undefined;
|
|
118
138
|
this.translationUrl = '';
|
|
119
139
|
this.language = 'en';
|
|
140
|
+
this.endpoint = '';
|
|
141
|
+
this.domain = '';
|
|
142
|
+
this.session = '';
|
|
143
|
+
this.userId = '';
|
|
120
144
|
this.activeTabIndex = 0;
|
|
145
|
+
this.error = '';
|
|
146
|
+
this.hasError = false;
|
|
147
|
+
this.challenges = [];
|
|
148
|
+
this.loading = false;
|
|
149
|
+
this.pageNumber = 0;
|
|
150
|
+
this.total = 0;
|
|
151
|
+
this.pageSize = 20;
|
|
121
152
|
}
|
|
122
153
|
handleClientStylingChange(newValue, oldValue) {
|
|
123
154
|
if (newValue != oldValue) {
|
|
@@ -134,6 +165,31 @@ const CasinoChallengesContainer = class {
|
|
|
134
165
|
setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
|
|
135
166
|
}
|
|
136
167
|
}
|
|
168
|
+
async getChallenges() {
|
|
169
|
+
if (!this.checkAttrs()) {
|
|
170
|
+
const path = this.activeTabIndex === 2 ? '/PlayerHistory' : '/GetChallengesInfo';
|
|
171
|
+
const url = `${this.endpoint}/challenge/${path}`;
|
|
172
|
+
const body = Object.assign(Object.assign({ DomainId: this.domain, PlayerLanguage: this.language, PageNumber: this.pageNumber, PageSize: this.pageSize }, (this.session && { PlayerSessionId: this.session })), (this.userId && this.activeTabIndex === 2 && { UserId: this.userId }));
|
|
173
|
+
this.loading = true;
|
|
174
|
+
return fetch(url, {
|
|
175
|
+
method: 'POST',
|
|
176
|
+
headers: {
|
|
177
|
+
'Content-Type': 'application/json'
|
|
178
|
+
},
|
|
179
|
+
body: JSON.stringify(body)
|
|
180
|
+
})
|
|
181
|
+
.then((res) => res.json())
|
|
182
|
+
.finally(() => (this.loading = false));
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
loadData() {
|
|
186
|
+
this.getChallenges().then((res) => {
|
|
187
|
+
if (res === null || res === void 0 ? void 0 : res.Success) {
|
|
188
|
+
this.pageNumber = res.PageNumber;
|
|
189
|
+
this.total = res.TotalCount;
|
|
190
|
+
}
|
|
191
|
+
});
|
|
192
|
+
}
|
|
137
193
|
componentDidLoad() {
|
|
138
194
|
if (this.stylingContainer) {
|
|
139
195
|
if (this.mbSource)
|
|
@@ -143,6 +199,7 @@ const CasinoChallengesContainer = class {
|
|
|
143
199
|
if (this.clientStylingUrl)
|
|
144
200
|
setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
|
|
145
201
|
}
|
|
202
|
+
this.loadData();
|
|
146
203
|
}
|
|
147
204
|
disconnectedCallback() {
|
|
148
205
|
this.stylingSubscription && this.stylingSubscription.unsubscribe();
|
|
@@ -152,8 +209,14 @@ const CasinoChallengesContainer = class {
|
|
|
152
209
|
resolveTranslationUrl(this.translationUrl);
|
|
153
210
|
}
|
|
154
211
|
}
|
|
212
|
+
onTimerExpired(e) {
|
|
213
|
+
setTimeout(() => {
|
|
214
|
+
this.challenges = this.challenges.filter((challenge) => challenge.Id !== e.detail);
|
|
215
|
+
}, 10000);
|
|
216
|
+
}
|
|
155
217
|
render() {
|
|
156
|
-
|
|
218
|
+
var _a;
|
|
219
|
+
return (index.h("div", { key: 'af2e5b13351a5b8694258c628f545d6a127e80dc', ref: (el) => (this.stylingContainer = el) }, index.h("div", { key: '91cdbc6a152a8b8c884842370c5509e7f6752074', class: "challenges" }, index.h("div", { key: 'd480a88d50cea5789eabb8dcc30233aea7d18d0f', class: "challenges__header" }, index.h("h1", { key: '8cd8787debb4f6f9897291f11c131c4ea1ef1d15', class: "challenges__title" }, index.h("img", { key: '1551482df42aaf36ed5cac7b2834bc276cc5cf52', src: titleIconSvg, alt: "icon" }), translate('title', this.language)), this.session && (index.h("div", { key: 'b45e42e56d5abc570b72979490f6e7ff4bf4f1bd', class: "challenges__tabs" }, this.tabs.map((label, index$1) => (index.h("div", { class: `challenges__tab ${index$1 === this.activeTabIndex ? 'active' : ''}`, onClick: this.handleTabClick(index$1) }, label, this.showNotification === index$1 && index.h("img", { src: notificationSvg }))))))), index.h("div", { key: 'd1a2a52ff5d26f17e401a7a3707f4153bbbc6290', class: "challenges__content" }, this.challenges.length === 0 && !this.loading && (index.h("div", { key: 'f0ab8469ac8a795b4d25d925bc1065217398e862', class: "empty" }, translate('empty', this.language))), this.activeTabIndex !== 3 && (index.h("casino-challenges-list", { key: '2f7aaf6e940668be6e15e1cfb81f5d2d063361ef', challenges: this.challenges, onLoadMore: this.onLoadMore, onTimerExpired: this.onTimerExpired, loading: this.loading, hasMore: ((_a = this.challenges) === null || _a === void 0 ? void 0 : _a.length) < this.total, language: this.language }))))));
|
|
157
220
|
}
|
|
158
221
|
static get watchers() { return {
|
|
159
222
|
"clientStyling": ["handleClientStylingChange"],
|
|
@@ -2,8 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const casinoChallengesContainer = require('./casino-challenges-container-
|
|
5
|
+
const casinoChallengesContainer = require('./casino-challenges-container-f2c3603f.js');
|
|
6
6
|
require('./index-cf89b5da.js');
|
|
7
|
+
require('@everymatrix/casino-challenges-list');
|
|
7
8
|
|
|
8
9
|
|
|
9
10
|
|
|
@@ -19,7 +19,7 @@ var patchBrowser = () => {
|
|
|
19
19
|
|
|
20
20
|
patchBrowser().then(async (options) => {
|
|
21
21
|
await appGlobals.globalScripts();
|
|
22
|
-
return index.bootstrapLazy([["casino-challenges-container.cjs",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"activeTabIndex":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
22
|
+
return index.bootstrapLazy([["casino-challenges-container.cjs",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"endpoint":[513],"domain":[513],"session":[513],"userId":[513,"user-id"],"activeTabIndex":[32],"error":[32],"hasError":[32],"challenges":[32],"loading":[32],"pageNumber":[32],"total":[32],"pageSize":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
23
23
|
});
|
|
24
24
|
|
|
25
25
|
exports.setNonce = index.setNonce;
|
package/dist/cjs/index.cjs.js
CHANGED
|
@@ -2,8 +2,9 @@
|
|
|
2
2
|
|
|
3
3
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
4
|
|
|
5
|
-
const casinoChallengesContainer = require('./casino-challenges-container-
|
|
5
|
+
const casinoChallengesContainer = require('./casino-challenges-container-f2c3603f.js');
|
|
6
6
|
require('./index-cf89b5da.js');
|
|
7
|
+
require('@everymatrix/casino-challenges-list');
|
|
7
8
|
|
|
8
9
|
|
|
9
10
|
|
package/dist/cjs/loader.cjs.js
CHANGED
|
@@ -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-challenges-container.cjs",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"activeTabIndex":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
11
|
+
return index.bootstrapLazy([["casino-challenges-container.cjs",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"endpoint":[513],"domain":[513],"session":[513],"userId":[513,"user-id"],"activeTabIndex":[32],"error":[32],"hasError":[32],"challenges":[32],"loading":[32],"pageNumber":[32],"total":[32],"pageSize":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
12
12
|
};
|
|
13
13
|
|
|
14
14
|
exports.setNonce = index.setNonce;
|
package/dist/collection/components/casino-challenges-container/casino-challenges-container.css
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
.challenges {
|
|
2
2
|
container-type: inline-size;
|
|
3
3
|
container-name: challenges-container;
|
|
4
|
+
background-color: var(--emw--color-background, #000);
|
|
5
|
+
padding: 16px 12px;
|
|
4
6
|
}
|
|
5
7
|
.challenges__header {
|
|
6
8
|
margin: 0 0 32px;
|
|
@@ -14,13 +16,14 @@
|
|
|
14
16
|
align-items: center;
|
|
15
17
|
font-size: var(--emw--font-size-x-large, 24px);
|
|
16
18
|
font-weight: var(--emw--font-weight-bold, 700);
|
|
19
|
+
color: var(--emw--color-white, #ffffff);
|
|
17
20
|
}
|
|
18
21
|
.challenges__tabs {
|
|
19
22
|
display: flex;
|
|
20
23
|
gap: 12px;
|
|
21
24
|
border-radius: 48px;
|
|
22
25
|
padding: 6px;
|
|
23
|
-
color: var(--emw--color-gray-150, #
|
|
26
|
+
color: var(--emw--color-gray-150, #c8d6ce);
|
|
24
27
|
background-color: var(--emw--color-background-secondary, #272727);
|
|
25
28
|
}
|
|
26
29
|
.challenges__tab {
|
|
@@ -37,13 +40,23 @@
|
|
|
37
40
|
gap: 4px;
|
|
38
41
|
}
|
|
39
42
|
.challenges__tab.active {
|
|
40
|
-
color: var(--emw--color-white, #
|
|
43
|
+
color: var(--emw--color-white, #ffffff);
|
|
41
44
|
background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);
|
|
42
45
|
}
|
|
43
46
|
.challenges__tab:last-child {
|
|
44
47
|
width: inherit;
|
|
45
48
|
padding: 10px 16px;
|
|
46
49
|
}
|
|
50
|
+
.challenges__content {
|
|
51
|
+
display: flex;
|
|
52
|
+
align-items: center;
|
|
53
|
+
justify-content: center;
|
|
54
|
+
min-height: 300px;
|
|
55
|
+
overflow-y: auto;
|
|
56
|
+
}
|
|
57
|
+
.challenges__empty {
|
|
58
|
+
color: var(--emw--color-white, #ffffff);
|
|
59
|
+
}
|
|
47
60
|
@container challenges-container (max-width: 800px) {
|
|
48
61
|
.challenges__header {
|
|
49
62
|
margin: 0 0 16px;
|
package/dist/collection/components/casino-challenges-container/casino-challenges-container.js
CHANGED
|
@@ -3,20 +3,50 @@ import { setClientStyling, setClientStylingURL, setStreamStyling } from "../../.
|
|
|
3
3
|
import { resolveTranslationUrl, translate } from "../../utils/locale.utils";
|
|
4
4
|
import titleIcon from "../../assets/title-icon.svg";
|
|
5
5
|
import notificationIcon from "../../assets/notification.svg";
|
|
6
|
+
import "@everymatrix/casino-challenges-list";
|
|
6
7
|
export class CasinoChallengesContainer {
|
|
7
8
|
constructor() {
|
|
8
|
-
// todo: connect with api
|
|
9
9
|
this.tabs = ['Active', 'Pending', 'Finished', 'Code'];
|
|
10
10
|
this.showNotification = 1;
|
|
11
|
+
this.checkAttrs = () => {
|
|
12
|
+
if (!this.endpoint) {
|
|
13
|
+
this.error = 'Endpoint is missing! Please provide a valid endpointURL.';
|
|
14
|
+
this.hasError = true;
|
|
15
|
+
console.error(this.error);
|
|
16
|
+
}
|
|
17
|
+
return this.hasError;
|
|
18
|
+
};
|
|
19
|
+
this.onLoadMore = () => {
|
|
20
|
+
this.pageNumber += 1;
|
|
21
|
+
this.getChallenges().then((res) => {
|
|
22
|
+
this.challenges = [...this.challenges, ...res.Data];
|
|
23
|
+
this.total = res.TotalCount;
|
|
24
|
+
});
|
|
25
|
+
};
|
|
11
26
|
this.handleTabClick = (index) => () => {
|
|
12
27
|
this.activeTabIndex = index;
|
|
28
|
+
this.challenges = [];
|
|
29
|
+
this.pageNumber = 0;
|
|
30
|
+
this.total = 0;
|
|
31
|
+
this.loadData();
|
|
13
32
|
};
|
|
14
33
|
this.mbSource = undefined;
|
|
15
34
|
this.clientStyling = undefined;
|
|
16
35
|
this.clientStylingUrl = undefined;
|
|
17
36
|
this.translationUrl = '';
|
|
18
37
|
this.language = 'en';
|
|
38
|
+
this.endpoint = '';
|
|
39
|
+
this.domain = '';
|
|
40
|
+
this.session = '';
|
|
41
|
+
this.userId = '';
|
|
19
42
|
this.activeTabIndex = 0;
|
|
43
|
+
this.error = '';
|
|
44
|
+
this.hasError = false;
|
|
45
|
+
this.challenges = [];
|
|
46
|
+
this.loading = false;
|
|
47
|
+
this.pageNumber = 0;
|
|
48
|
+
this.total = 0;
|
|
49
|
+
this.pageSize = 20;
|
|
20
50
|
}
|
|
21
51
|
handleClientStylingChange(newValue, oldValue) {
|
|
22
52
|
if (newValue != oldValue) {
|
|
@@ -33,6 +63,31 @@ export class CasinoChallengesContainer {
|
|
|
33
63
|
setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`, this.stylingSubscription);
|
|
34
64
|
}
|
|
35
65
|
}
|
|
66
|
+
async getChallenges() {
|
|
67
|
+
if (!this.checkAttrs()) {
|
|
68
|
+
const path = this.activeTabIndex === 2 ? '/PlayerHistory' : '/GetChallengesInfo';
|
|
69
|
+
const url = `${this.endpoint}/challenge/${path}`;
|
|
70
|
+
const body = Object.assign(Object.assign({ DomainId: this.domain, PlayerLanguage: this.language, PageNumber: this.pageNumber, PageSize: this.pageSize }, (this.session && { PlayerSessionId: this.session })), (this.userId && this.activeTabIndex === 2 && { UserId: this.userId }));
|
|
71
|
+
this.loading = true;
|
|
72
|
+
return fetch(url, {
|
|
73
|
+
method: 'POST',
|
|
74
|
+
headers: {
|
|
75
|
+
'Content-Type': 'application/json'
|
|
76
|
+
},
|
|
77
|
+
body: JSON.stringify(body)
|
|
78
|
+
})
|
|
79
|
+
.then((res) => res.json())
|
|
80
|
+
.finally(() => (this.loading = false));
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
loadData() {
|
|
84
|
+
this.getChallenges().then((res) => {
|
|
85
|
+
if (res === null || res === void 0 ? void 0 : res.Success) {
|
|
86
|
+
this.pageNumber = res.PageNumber;
|
|
87
|
+
this.total = res.TotalCount;
|
|
88
|
+
}
|
|
89
|
+
});
|
|
90
|
+
}
|
|
36
91
|
componentDidLoad() {
|
|
37
92
|
if (this.stylingContainer) {
|
|
38
93
|
if (this.mbSource)
|
|
@@ -42,6 +97,7 @@ export class CasinoChallengesContainer {
|
|
|
42
97
|
if (this.clientStylingUrl)
|
|
43
98
|
setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
|
|
44
99
|
}
|
|
100
|
+
this.loadData();
|
|
45
101
|
}
|
|
46
102
|
disconnectedCallback() {
|
|
47
103
|
this.stylingSubscription && this.stylingSubscription.unsubscribe();
|
|
@@ -51,8 +107,14 @@ export class CasinoChallengesContainer {
|
|
|
51
107
|
resolveTranslationUrl(this.translationUrl);
|
|
52
108
|
}
|
|
53
109
|
}
|
|
110
|
+
onTimerExpired(e) {
|
|
111
|
+
setTimeout(() => {
|
|
112
|
+
this.challenges = this.challenges.filter((challenge) => challenge.Id !== e.detail);
|
|
113
|
+
}, 10000);
|
|
114
|
+
}
|
|
54
115
|
render() {
|
|
55
|
-
|
|
116
|
+
var _a;
|
|
117
|
+
return (h("div", { key: 'af2e5b13351a5b8694258c628f545d6a127e80dc', ref: (el) => (this.stylingContainer = el) }, h("div", { key: '91cdbc6a152a8b8c884842370c5509e7f6752074', class: "challenges" }, h("div", { key: 'd480a88d50cea5789eabb8dcc30233aea7d18d0f', class: "challenges__header" }, h("h1", { key: '8cd8787debb4f6f9897291f11c131c4ea1ef1d15', class: "challenges__title" }, h("img", { key: '1551482df42aaf36ed5cac7b2834bc276cc5cf52', src: titleIcon, alt: "icon" }), translate('title', this.language)), this.session && (h("div", { key: 'b45e42e56d5abc570b72979490f6e7ff4bf4f1bd', class: "challenges__tabs" }, this.tabs.map((label, index) => (h("div", { class: `challenges__tab ${index === this.activeTabIndex ? 'active' : ''}`, onClick: this.handleTabClick(index) }, label, this.showNotification === index && h("img", { src: notificationIcon }))))))), h("div", { key: 'd1a2a52ff5d26f17e401a7a3707f4153bbbc6290', class: "challenges__content" }, this.challenges.length === 0 && !this.loading && (h("div", { key: 'f0ab8469ac8a795b4d25d925bc1065217398e862', class: "empty" }, translate('empty', this.language))), this.activeTabIndex !== 3 && (h("casino-challenges-list", { key: '2f7aaf6e940668be6e15e1cfb81f5d2d063361ef', challenges: this.challenges, onLoadMore: this.onLoadMore, onTimerExpired: this.onTimerExpired, loading: this.loading, hasMore: ((_a = this.challenges) === null || _a === void 0 ? void 0 : _a.length) < this.total, language: this.language }))))));
|
|
56
118
|
}
|
|
57
119
|
static get is() { return "casino-challenges-container"; }
|
|
58
120
|
static get encapsulation() { return "shadow"; }
|
|
@@ -154,12 +216,91 @@ export class CasinoChallengesContainer {
|
|
|
154
216
|
"attribute": "language",
|
|
155
217
|
"reflect": true,
|
|
156
218
|
"defaultValue": "'en'"
|
|
219
|
+
},
|
|
220
|
+
"endpoint": {
|
|
221
|
+
"type": "string",
|
|
222
|
+
"mutable": false,
|
|
223
|
+
"complexType": {
|
|
224
|
+
"original": "string",
|
|
225
|
+
"resolved": "string",
|
|
226
|
+
"references": {}
|
|
227
|
+
},
|
|
228
|
+
"required": false,
|
|
229
|
+
"optional": false,
|
|
230
|
+
"docs": {
|
|
231
|
+
"tags": [],
|
|
232
|
+
"text": "Client endpoint to fetch data"
|
|
233
|
+
},
|
|
234
|
+
"attribute": "endpoint",
|
|
235
|
+
"reflect": true,
|
|
236
|
+
"defaultValue": "''"
|
|
237
|
+
},
|
|
238
|
+
"domain": {
|
|
239
|
+
"type": "string",
|
|
240
|
+
"mutable": false,
|
|
241
|
+
"complexType": {
|
|
242
|
+
"original": "string",
|
|
243
|
+
"resolved": "string",
|
|
244
|
+
"references": {}
|
|
245
|
+
},
|
|
246
|
+
"required": false,
|
|
247
|
+
"optional": false,
|
|
248
|
+
"docs": {
|
|
249
|
+
"tags": [],
|
|
250
|
+
"text": "Client endpoint to fetch data"
|
|
251
|
+
},
|
|
252
|
+
"attribute": "domain",
|
|
253
|
+
"reflect": true,
|
|
254
|
+
"defaultValue": "''"
|
|
255
|
+
},
|
|
256
|
+
"session": {
|
|
257
|
+
"type": "string",
|
|
258
|
+
"mutable": false,
|
|
259
|
+
"complexType": {
|
|
260
|
+
"original": "string",
|
|
261
|
+
"resolved": "string",
|
|
262
|
+
"references": {}
|
|
263
|
+
},
|
|
264
|
+
"required": false,
|
|
265
|
+
"optional": false,
|
|
266
|
+
"docs": {
|
|
267
|
+
"tags": [],
|
|
268
|
+
"text": "session"
|
|
269
|
+
},
|
|
270
|
+
"attribute": "session",
|
|
271
|
+
"reflect": true,
|
|
272
|
+
"defaultValue": "''"
|
|
273
|
+
},
|
|
274
|
+
"userId": {
|
|
275
|
+
"type": "string",
|
|
276
|
+
"mutable": false,
|
|
277
|
+
"complexType": {
|
|
278
|
+
"original": "string",
|
|
279
|
+
"resolved": "string",
|
|
280
|
+
"references": {}
|
|
281
|
+
},
|
|
282
|
+
"required": false,
|
|
283
|
+
"optional": false,
|
|
284
|
+
"docs": {
|
|
285
|
+
"tags": [],
|
|
286
|
+
"text": "userId"
|
|
287
|
+
},
|
|
288
|
+
"attribute": "user-id",
|
|
289
|
+
"reflect": true,
|
|
290
|
+
"defaultValue": "''"
|
|
157
291
|
}
|
|
158
292
|
};
|
|
159
293
|
}
|
|
160
294
|
static get states() {
|
|
161
295
|
return {
|
|
162
|
-
"activeTabIndex": {}
|
|
296
|
+
"activeTabIndex": {},
|
|
297
|
+
"error": {},
|
|
298
|
+
"hasError": {},
|
|
299
|
+
"challenges": {},
|
|
300
|
+
"loading": {},
|
|
301
|
+
"pageNumber": {},
|
|
302
|
+
"total": {},
|
|
303
|
+
"pageSize": {}
|
|
163
304
|
};
|
|
164
305
|
}
|
|
165
306
|
static get watchers() {
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
export var EChallengeLevelTargetType;
|
|
2
|
+
(function (EChallengeLevelTargetType) {
|
|
3
|
+
EChallengeLevelTargetType[EChallengeLevelTargetType["Accumulative"] = 0] = "Accumulative";
|
|
4
|
+
EChallengeLevelTargetType[EChallengeLevelTargetType["SingleBet"] = 1] = "SingleBet";
|
|
5
|
+
EChallengeLevelTargetType[EChallengeLevelTargetType["MultipleOneBetSize"] = 2] = "MultipleOneBetSize";
|
|
6
|
+
})(EChallengeLevelTargetType || (EChallengeLevelTargetType = {}));
|
|
7
|
+
export var EChallengeRecurrenceType;
|
|
8
|
+
(function (EChallengeRecurrenceType) {
|
|
9
|
+
EChallengeRecurrenceType[EChallengeRecurrenceType["Single"] = 0] = "Single";
|
|
10
|
+
EChallengeRecurrenceType[EChallengeRecurrenceType["Daily"] = 1] = "Daily";
|
|
11
|
+
EChallengeRecurrenceType[EChallengeRecurrenceType["Weekly"] = 2] = "Weekly";
|
|
12
|
+
EChallengeRecurrenceType[EChallengeRecurrenceType["Monthly"] = 3] = "Monthly";
|
|
13
|
+
})(EChallengeRecurrenceType || (EChallengeRecurrenceType = {}));
|
|
14
|
+
export var EChallengeRewardType;
|
|
15
|
+
(function (EChallengeRewardType) {
|
|
16
|
+
EChallengeRewardType[EChallengeRewardType["FreeSpins"] = 0] = "FreeSpins";
|
|
17
|
+
EChallengeRewardType[EChallengeRewardType["LuckyWheel"] = 1] = "LuckyWheel";
|
|
18
|
+
EChallengeRewardType[EChallengeRewardType["Leaderboard"] = 2] = "Leaderboard";
|
|
19
|
+
EChallengeRewardType[EChallengeRewardType["Challenge"] = 3] = "Challenge";
|
|
20
|
+
EChallengeRewardType[EChallengeRewardType["Custom"] = 4] = "Custom";
|
|
21
|
+
})(EChallengeRewardType || (EChallengeRewardType = {}));
|
|
22
|
+
export var EChallengeStatus;
|
|
23
|
+
(function (EChallengeStatus) {
|
|
24
|
+
EChallengeStatus[EChallengeStatus["Setup"] = 0] = "Setup";
|
|
25
|
+
EChallengeStatus[EChallengeStatus["Active"] = 1] = "Active";
|
|
26
|
+
EChallengeStatus[EChallengeStatus["Paused"] = 2] = "Paused";
|
|
27
|
+
EChallengeStatus[EChallengeStatus["Closed"] = 3] = "Closed";
|
|
28
|
+
EChallengeStatus[EChallengeStatus["Deleted"] = 4] = "Deleted";
|
|
29
|
+
})(EChallengeStatus || (EChallengeStatus = {}));
|
|
30
|
+
export var EChallengeTriggerType;
|
|
31
|
+
(function (EChallengeTriggerType) {
|
|
32
|
+
EChallengeTriggerType[EChallengeTriggerType["GameLaunch"] = 0] = "GameLaunch";
|
|
33
|
+
EChallengeTriggerType[EChallengeTriggerType["Reward"] = 1] = "Reward";
|
|
34
|
+
EChallengeTriggerType[EChallengeTriggerType["Manual"] = 2] = "Manual";
|
|
35
|
+
})(EChallengeTriggerType || (EChallengeTriggerType = {}));
|
|
36
|
+
export var EChallengeValidityType;
|
|
37
|
+
(function (EChallengeValidityType) {
|
|
38
|
+
EChallengeValidityType[EChallengeValidityType["Period"] = 0] = "Period";
|
|
39
|
+
EChallengeValidityType[EChallengeValidityType["Date"] = 1] = "Date";
|
|
40
|
+
})(EChallengeValidityType || (EChallengeValidityType = {}));
|
package/dist/esm/{casino-challenges-container-affc90f5.js → casino-challenges-container-c6332600.js}
RENAMED
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { r as registerInstance, h } from './index-9c823353.js';
|
|
2
|
+
import '@everymatrix/casino-challenges-list';
|
|
2
3
|
|
|
3
4
|
/**
|
|
4
5
|
* @name setClientStyling
|
|
@@ -60,7 +61,8 @@ function setStreamStyling(stylingContainer, domain, subscription) {
|
|
|
60
61
|
const DEFAULT_LANGUAGE = 'en';
|
|
61
62
|
const TRANSLATIONS = {
|
|
62
63
|
en: {
|
|
63
|
-
title: 'Challenges'
|
|
64
|
+
title: 'Challenges',
|
|
65
|
+
empty: 'No Challenges'
|
|
64
66
|
},
|
|
65
67
|
ro: {},
|
|
66
68
|
fr: {},
|
|
@@ -98,24 +100,53 @@ const titleIconSvg = '
|
|
|
98
100
|
|
|
99
101
|
const notificationSvg = '';
|
|
100
102
|
|
|
101
|
-
const casinoChallengesContainerCss = ".challenges {\n container-type: inline-size;\n container-name: challenges-container;\n}\n.challenges__header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n}\n.challenges__title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.challenges__tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #
|
|
103
|
+
const casinoChallengesContainerCss = ".challenges {\n container-type: inline-size;\n container-name: challenges-container;\n background-color: var(--emw--color-background, #000);\n padding: 16px 12px;\n}\n.challenges__header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n}\n.challenges__title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n color: var(--emw--color-white, #ffffff);\n}\n.challenges__tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #c8d6ce);\n background-color: var(--emw--color-background-secondary, #272727);\n}\n.challenges__tab {\n padding: 10px 16px;\n border-radius: 40px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n cursor: pointer;\n text-align: center;\n width: 95px;\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 4px;\n}\n.challenges__tab.active {\n color: var(--emw--color-white, #ffffff);\n background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);\n}\n.challenges__tab:last-child {\n width: inherit;\n padding: 10px 16px;\n}\n.challenges__content {\n display: flex;\n align-items: center;\n justify-content: center;\n min-height: 300px;\n overflow-y: auto;\n}\n.challenges__empty {\n color: var(--emw--color-white, #ffffff);\n}\n@container challenges-container (max-width: 800px) {\n .challenges__header {\n margin: 0 0 16px;\n flex-wrap: wrap;\n row-gap: 12px;\n }\n .challenges__title {\n width: 100%;\n font-size: var(--emw--font-size-large, 20px);\n }\n .challenges__title img {\n height: 32px;\n }\n .challenges__tabs {\n width: 100%;\n gap: 8px;\n }\n .challenges__tab {\n flex: 1;\n padding: 5px 0;\n font-size: var(--emw--font-size-x-small, 12px);\n }\n .challenges__tab:last-child {\n width: inherit;\n padding: 5px 0;\n }\n}";
|
|
102
104
|
const CasinoChallengesContainerStyle0 = casinoChallengesContainerCss;
|
|
103
105
|
|
|
104
106
|
const CasinoChallengesContainer = class {
|
|
105
107
|
constructor(hostRef) {
|
|
106
108
|
registerInstance(this, hostRef);
|
|
107
|
-
// todo: connect with api
|
|
108
109
|
this.tabs = ['Active', 'Pending', 'Finished', 'Code'];
|
|
109
110
|
this.showNotification = 1;
|
|
111
|
+
this.checkAttrs = () => {
|
|
112
|
+
if (!this.endpoint) {
|
|
113
|
+
this.error = 'Endpoint is missing! Please provide a valid endpointURL.';
|
|
114
|
+
this.hasError = true;
|
|
115
|
+
console.error(this.error);
|
|
116
|
+
}
|
|
117
|
+
return this.hasError;
|
|
118
|
+
};
|
|
119
|
+
this.onLoadMore = () => {
|
|
120
|
+
this.pageNumber += 1;
|
|
121
|
+
this.getChallenges().then((res) => {
|
|
122
|
+
this.challenges = [...this.challenges, ...res.Data];
|
|
123
|
+
this.total = res.TotalCount;
|
|
124
|
+
});
|
|
125
|
+
};
|
|
110
126
|
this.handleTabClick = (index) => () => {
|
|
111
127
|
this.activeTabIndex = index;
|
|
128
|
+
this.challenges = [];
|
|
129
|
+
this.pageNumber = 0;
|
|
130
|
+
this.total = 0;
|
|
131
|
+
this.loadData();
|
|
112
132
|
};
|
|
113
133
|
this.mbSource = undefined;
|
|
114
134
|
this.clientStyling = undefined;
|
|
115
135
|
this.clientStylingUrl = undefined;
|
|
116
136
|
this.translationUrl = '';
|
|
117
137
|
this.language = 'en';
|
|
138
|
+
this.endpoint = '';
|
|
139
|
+
this.domain = '';
|
|
140
|
+
this.session = '';
|
|
141
|
+
this.userId = '';
|
|
118
142
|
this.activeTabIndex = 0;
|
|
143
|
+
this.error = '';
|
|
144
|
+
this.hasError = false;
|
|
145
|
+
this.challenges = [];
|
|
146
|
+
this.loading = false;
|
|
147
|
+
this.pageNumber = 0;
|
|
148
|
+
this.total = 0;
|
|
149
|
+
this.pageSize = 20;
|
|
119
150
|
}
|
|
120
151
|
handleClientStylingChange(newValue, oldValue) {
|
|
121
152
|
if (newValue != oldValue) {
|
|
@@ -132,6 +163,31 @@ const CasinoChallengesContainer = class {
|
|
|
132
163
|
setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
|
|
133
164
|
}
|
|
134
165
|
}
|
|
166
|
+
async getChallenges() {
|
|
167
|
+
if (!this.checkAttrs()) {
|
|
168
|
+
const path = this.activeTabIndex === 2 ? '/PlayerHistory' : '/GetChallengesInfo';
|
|
169
|
+
const url = `${this.endpoint}/challenge/${path}`;
|
|
170
|
+
const body = Object.assign(Object.assign({ DomainId: this.domain, PlayerLanguage: this.language, PageNumber: this.pageNumber, PageSize: this.pageSize }, (this.session && { PlayerSessionId: this.session })), (this.userId && this.activeTabIndex === 2 && { UserId: this.userId }));
|
|
171
|
+
this.loading = true;
|
|
172
|
+
return fetch(url, {
|
|
173
|
+
method: 'POST',
|
|
174
|
+
headers: {
|
|
175
|
+
'Content-Type': 'application/json'
|
|
176
|
+
},
|
|
177
|
+
body: JSON.stringify(body)
|
|
178
|
+
})
|
|
179
|
+
.then((res) => res.json())
|
|
180
|
+
.finally(() => (this.loading = false));
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
loadData() {
|
|
184
|
+
this.getChallenges().then((res) => {
|
|
185
|
+
if (res === null || res === void 0 ? void 0 : res.Success) {
|
|
186
|
+
this.pageNumber = res.PageNumber;
|
|
187
|
+
this.total = res.TotalCount;
|
|
188
|
+
}
|
|
189
|
+
});
|
|
190
|
+
}
|
|
135
191
|
componentDidLoad() {
|
|
136
192
|
if (this.stylingContainer) {
|
|
137
193
|
if (this.mbSource)
|
|
@@ -141,6 +197,7 @@ const CasinoChallengesContainer = class {
|
|
|
141
197
|
if (this.clientStylingUrl)
|
|
142
198
|
setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
|
|
143
199
|
}
|
|
200
|
+
this.loadData();
|
|
144
201
|
}
|
|
145
202
|
disconnectedCallback() {
|
|
146
203
|
this.stylingSubscription && this.stylingSubscription.unsubscribe();
|
|
@@ -150,8 +207,14 @@ const CasinoChallengesContainer = class {
|
|
|
150
207
|
resolveTranslationUrl(this.translationUrl);
|
|
151
208
|
}
|
|
152
209
|
}
|
|
210
|
+
onTimerExpired(e) {
|
|
211
|
+
setTimeout(() => {
|
|
212
|
+
this.challenges = this.challenges.filter((challenge) => challenge.Id !== e.detail);
|
|
213
|
+
}, 10000);
|
|
214
|
+
}
|
|
153
215
|
render() {
|
|
154
|
-
|
|
216
|
+
var _a;
|
|
217
|
+
return (h("div", { key: 'af2e5b13351a5b8694258c628f545d6a127e80dc', ref: (el) => (this.stylingContainer = el) }, h("div", { key: '91cdbc6a152a8b8c884842370c5509e7f6752074', class: "challenges" }, h("div", { key: 'd480a88d50cea5789eabb8dcc30233aea7d18d0f', class: "challenges__header" }, h("h1", { key: '8cd8787debb4f6f9897291f11c131c4ea1ef1d15', class: "challenges__title" }, h("img", { key: '1551482df42aaf36ed5cac7b2834bc276cc5cf52', src: titleIconSvg, alt: "icon" }), translate('title', this.language)), this.session && (h("div", { key: 'b45e42e56d5abc570b72979490f6e7ff4bf4f1bd', class: "challenges__tabs" }, this.tabs.map((label, index) => (h("div", { class: `challenges__tab ${index === this.activeTabIndex ? 'active' : ''}`, onClick: this.handleTabClick(index) }, label, this.showNotification === index && h("img", { src: notificationSvg }))))))), h("div", { key: 'd1a2a52ff5d26f17e401a7a3707f4153bbbc6290', class: "challenges__content" }, this.challenges.length === 0 && !this.loading && (h("div", { key: 'f0ab8469ac8a795b4d25d925bc1065217398e862', class: "empty" }, translate('empty', this.language))), this.activeTabIndex !== 3 && (h("casino-challenges-list", { key: '2f7aaf6e940668be6e15e1cfb81f5d2d063361ef', challenges: this.challenges, onLoadMore: this.onLoadMore, onTimerExpired: this.onTimerExpired, loading: this.loading, hasMore: ((_a = this.challenges) === null || _a === void 0 ? void 0 : _a.length) < this.total, language: this.language }))))));
|
|
155
218
|
}
|
|
156
219
|
static get watchers() { return {
|
|
157
220
|
"clientStyling": ["handleClientStylingChange"],
|
|
@@ -16,5 +16,5 @@ var patchBrowser = () => {
|
|
|
16
16
|
|
|
17
17
|
patchBrowser().then(async (options) => {
|
|
18
18
|
await globalScripts();
|
|
19
|
-
return bootstrapLazy([["casino-challenges-container",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"activeTabIndex":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
19
|
+
return bootstrapLazy([["casino-challenges-container",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"endpoint":[513],"domain":[513],"session":[513],"userId":[513,"user-id"],"activeTabIndex":[32],"error":[32],"hasError":[32],"challenges":[32],"loading":[32],"pageNumber":[32],"total":[32],"pageSize":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
20
20
|
});
|
package/dist/esm/index.js
CHANGED
package/dist/esm/loader.js
CHANGED
|
@@ -5,7 +5,7 @@ import { g as globalScripts } from './app-globals-0f993ce5.js';
|
|
|
5
5
|
const defineCustomElements = async (win, options) => {
|
|
6
6
|
if (typeof window === 'undefined') return undefined;
|
|
7
7
|
await globalScripts();
|
|
8
|
-
return bootstrapLazy([["casino-challenges-container",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"activeTabIndex":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
8
|
+
return bootstrapLazy([["casino-challenges-container",[[1,"casino-challenges-container",{"mbSource":[513,"mb-source"],"clientStyling":[513,"client-styling"],"clientStylingUrl":[513,"client-styling-url"],"translationUrl":[513,"translation-url"],"language":[513],"endpoint":[513],"domain":[513],"session":[513],"userId":[513,"user-id"],"activeTabIndex":[32],"error":[32],"hasError":[32],"challenges":[32],"loading":[32],"pageNumber":[32],"total":[32],"pageSize":[32]},null,{"clientStyling":["handleClientStylingChange"],"clientStylingUrl":["handleClientStylingUrlChange"],"mbSource":["handleMbSourceChange"]}]]]], options);
|
|
9
9
|
};
|
|
10
10
|
|
|
11
11
|
export { defineCustomElements };
|
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
import { IChallenge } from '../../utils/types';
|
|
2
|
+
import '@everymatrix/casino-challenges-list';
|
|
1
3
|
export declare class CasinoChallengesContainer {
|
|
2
4
|
/**
|
|
3
5
|
* Client custom styling via message bus
|
|
@@ -19,7 +21,30 @@ export declare class CasinoChallengesContainer {
|
|
|
19
21
|
* Client custom language for translation
|
|
20
22
|
*/
|
|
21
23
|
language: string;
|
|
24
|
+
/**
|
|
25
|
+
* Client endpoint to fetch data
|
|
26
|
+
*/
|
|
27
|
+
endpoint: string;
|
|
28
|
+
/**
|
|
29
|
+
* Client endpoint to fetch data
|
|
30
|
+
*/
|
|
31
|
+
domain: string;
|
|
32
|
+
/**
|
|
33
|
+
* session
|
|
34
|
+
*/
|
|
35
|
+
session: string;
|
|
36
|
+
/**
|
|
37
|
+
* userId
|
|
38
|
+
*/
|
|
39
|
+
userId: string;
|
|
22
40
|
activeTabIndex: number;
|
|
41
|
+
error: string;
|
|
42
|
+
hasError: boolean;
|
|
43
|
+
challenges: IChallenge[];
|
|
44
|
+
loading: boolean;
|
|
45
|
+
pageNumber: number;
|
|
46
|
+
total: number;
|
|
47
|
+
pageSize: number;
|
|
23
48
|
private stylingContainer;
|
|
24
49
|
private stylingSubscription;
|
|
25
50
|
private readonly tabs;
|
|
@@ -27,9 +52,14 @@ export declare class CasinoChallengesContainer {
|
|
|
27
52
|
handleClientStylingChange(newValue: any, oldValue: any): void;
|
|
28
53
|
handleClientStylingUrlChange(newValue: any, oldValue: any): void;
|
|
29
54
|
handleMbSourceChange(newValue: any, oldValue: any): void;
|
|
55
|
+
checkAttrs: () => boolean;
|
|
56
|
+
getChallenges(): Promise<any>;
|
|
57
|
+
loadData(): void;
|
|
58
|
+
onLoadMore: () => void;
|
|
30
59
|
componentDidLoad(): void;
|
|
31
60
|
disconnectedCallback(): void;
|
|
32
61
|
componentWillLoad(): void;
|
|
33
62
|
private handleTabClick;
|
|
63
|
+
onTimerExpired(e: CustomEvent): void;
|
|
34
64
|
render(): any;
|
|
35
65
|
}
|
|
@@ -15,6 +15,14 @@ export namespace Components {
|
|
|
15
15
|
* Client custom styling via css file url
|
|
16
16
|
*/
|
|
17
17
|
"clientStylingUrl": string;
|
|
18
|
+
/**
|
|
19
|
+
* Client endpoint to fetch data
|
|
20
|
+
*/
|
|
21
|
+
"domain": string;
|
|
22
|
+
/**
|
|
23
|
+
* Client endpoint to fetch data
|
|
24
|
+
*/
|
|
25
|
+
"endpoint": string;
|
|
18
26
|
/**
|
|
19
27
|
* Client custom language for translation
|
|
20
28
|
*/
|
|
@@ -23,10 +31,18 @@ export namespace Components {
|
|
|
23
31
|
* Client custom styling via message bus
|
|
24
32
|
*/
|
|
25
33
|
"mbSource": string;
|
|
34
|
+
/**
|
|
35
|
+
* session
|
|
36
|
+
*/
|
|
37
|
+
"session": string;
|
|
26
38
|
/**
|
|
27
39
|
* Client custom translation via json file url
|
|
28
40
|
*/
|
|
29
41
|
"translationUrl": string;
|
|
42
|
+
/**
|
|
43
|
+
* userId
|
|
44
|
+
*/
|
|
45
|
+
"userId": string;
|
|
30
46
|
}
|
|
31
47
|
}
|
|
32
48
|
declare global {
|
|
@@ -50,6 +66,14 @@ declare namespace LocalJSX {
|
|
|
50
66
|
* Client custom styling via css file url
|
|
51
67
|
*/
|
|
52
68
|
"clientStylingUrl"?: string;
|
|
69
|
+
/**
|
|
70
|
+
* Client endpoint to fetch data
|
|
71
|
+
*/
|
|
72
|
+
"domain"?: string;
|
|
73
|
+
/**
|
|
74
|
+
* Client endpoint to fetch data
|
|
75
|
+
*/
|
|
76
|
+
"endpoint"?: string;
|
|
53
77
|
/**
|
|
54
78
|
* Client custom language for translation
|
|
55
79
|
*/
|
|
@@ -58,10 +82,18 @@ declare namespace LocalJSX {
|
|
|
58
82
|
* Client custom styling via message bus
|
|
59
83
|
*/
|
|
60
84
|
"mbSource"?: string;
|
|
85
|
+
/**
|
|
86
|
+
* session
|
|
87
|
+
*/
|
|
88
|
+
"session"?: string;
|
|
61
89
|
/**
|
|
62
90
|
* Client custom translation via json file url
|
|
63
91
|
*/
|
|
64
92
|
"translationUrl"?: string;
|
|
93
|
+
/**
|
|
94
|
+
* userId
|
|
95
|
+
*/
|
|
96
|
+
"userId"?: string;
|
|
65
97
|
}
|
|
66
98
|
interface IntrinsicElements {
|
|
67
99
|
"casino-challenges-container": CasinoChallengesContainer;
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
export interface IInfoItem {
|
|
2
|
+
lable: string;
|
|
3
|
+
value: string | number;
|
|
4
|
+
}
|
|
5
|
+
export declare enum EChallengeLevelTargetType {
|
|
6
|
+
Accumulative = 0,
|
|
7
|
+
SingleBet = 1,
|
|
8
|
+
MultipleOneBetSize = 2
|
|
9
|
+
}
|
|
10
|
+
export declare enum EChallengeRecurrenceType {
|
|
11
|
+
Single = 0,
|
|
12
|
+
Daily = 1,
|
|
13
|
+
Weekly = 2,
|
|
14
|
+
Monthly = 3
|
|
15
|
+
}
|
|
16
|
+
export declare enum EChallengeRewardType {
|
|
17
|
+
FreeSpins = 0,
|
|
18
|
+
LuckyWheel = 1,
|
|
19
|
+
Leaderboard = 2,
|
|
20
|
+
Challenge = 3,
|
|
21
|
+
Custom = 4
|
|
22
|
+
}
|
|
23
|
+
export declare enum EChallengeStatus {
|
|
24
|
+
Setup = 0,
|
|
25
|
+
Active = 1,
|
|
26
|
+
Paused = 2,
|
|
27
|
+
Closed = 3,
|
|
28
|
+
Deleted = 4
|
|
29
|
+
}
|
|
30
|
+
export declare enum EChallengeTriggerType {
|
|
31
|
+
GameLaunch = 0,
|
|
32
|
+
Reward = 1,
|
|
33
|
+
Manual = 2
|
|
34
|
+
}
|
|
35
|
+
export declare enum EChallengeValidityType {
|
|
36
|
+
Period = 0,
|
|
37
|
+
Date = 1
|
|
38
|
+
}
|
|
39
|
+
export type ChallengeRecurrenceTypeName = 'Single' | 'Daily' | 'Weekly' | 'Monthly';
|
|
40
|
+
export type ChallengeStatusName = 'Draft' | 'Enabled' | 'Paused' | 'Closed' | 'Deleted';
|
|
41
|
+
export type ChallengeTriggerName = 'GameLaunch' | 'Reward';
|
|
42
|
+
export interface IChallengeLevel {
|
|
43
|
+
Name: string;
|
|
44
|
+
Id?: number;
|
|
45
|
+
OrderNumber: number;
|
|
46
|
+
Target: IChallengeLevelTarget;
|
|
47
|
+
CustomRewardMessage: Record<string, string>;
|
|
48
|
+
Rewards: Array<IChallengeLevelReward>;
|
|
49
|
+
Targets?: string | null;
|
|
50
|
+
}
|
|
51
|
+
export interface IChallengeLevelReward {
|
|
52
|
+
Type: EChallengeRewardType;
|
|
53
|
+
RewardId: number;
|
|
54
|
+
RewardDescription?: string;
|
|
55
|
+
BonusCode?: string | null;
|
|
56
|
+
}
|
|
57
|
+
export interface IChallengeLevelTarget {
|
|
58
|
+
TargetType: number;
|
|
59
|
+
Turnover: number;
|
|
60
|
+
BetCount: number;
|
|
61
|
+
LevelContributionPercent: number;
|
|
62
|
+
BetRange?: Record<string, IChallengeBetRange>;
|
|
63
|
+
}
|
|
64
|
+
export interface IChallengePresentation {
|
|
65
|
+
PresentationName: string;
|
|
66
|
+
Description?: string;
|
|
67
|
+
Url?: string;
|
|
68
|
+
TriggerPopupMessage?: string;
|
|
69
|
+
TooltipMessage?: string;
|
|
70
|
+
}
|
|
71
|
+
export interface ITriggerPeriods {
|
|
72
|
+
DayOfWeek: number;
|
|
73
|
+
StartTime: string;
|
|
74
|
+
EndTime: string;
|
|
75
|
+
}
|
|
76
|
+
export interface IChallengeRecurrence {
|
|
77
|
+
Type: EChallengeRecurrenceType;
|
|
78
|
+
RecurrenceTypeName: ChallengeRecurrenceTypeName;
|
|
79
|
+
MaxParticipationPerPlayer: number;
|
|
80
|
+
TriggerPeriods: ITriggerPeriods[] | null;
|
|
81
|
+
}
|
|
82
|
+
export interface IChallengeValidity {
|
|
83
|
+
Type: number;
|
|
84
|
+
Days: number | null;
|
|
85
|
+
Hours: number;
|
|
86
|
+
Minutes: number;
|
|
87
|
+
ExpirationTime: string;
|
|
88
|
+
}
|
|
89
|
+
export interface IChallengeBetRange {
|
|
90
|
+
MinBet: number;
|
|
91
|
+
MaxBet: number;
|
|
92
|
+
MaxContributionAmount: number;
|
|
93
|
+
}
|
|
94
|
+
export interface IChallenge {
|
|
95
|
+
Status: EChallengeStatus;
|
|
96
|
+
StatusName: ChallengeStatusName;
|
|
97
|
+
Name: string;
|
|
98
|
+
ChallengePresentations?: IChallengePresentation;
|
|
99
|
+
Ins: string;
|
|
100
|
+
Upd: string;
|
|
101
|
+
StartTime: string;
|
|
102
|
+
ExpirationTime: string;
|
|
103
|
+
Validity: IChallengeValidity;
|
|
104
|
+
Recurrence: IChallengeRecurrence;
|
|
105
|
+
SystemCurrency: string;
|
|
106
|
+
AllowedCurrencies: string[] | null;
|
|
107
|
+
Trigger: EChallengeTriggerType;
|
|
108
|
+
TriggerName: ChallengeTriggerName;
|
|
109
|
+
ChallengeLevels: Array<IChallengeLevel>;
|
|
110
|
+
GameCodes: Array<string>;
|
|
111
|
+
IncludedUserIds?: Array<string>;
|
|
112
|
+
ExcludedUserIds?: Array<string>;
|
|
113
|
+
AllowedCountries?: Array<string>;
|
|
114
|
+
DeniedCountries?: Array<string>;
|
|
115
|
+
IncludedUserIdRange?: Array<Record<string, number>>;
|
|
116
|
+
ExcludedUserIdRange?: Array<Record<string, number>>;
|
|
117
|
+
IsPendingTrigger: boolean;
|
|
118
|
+
Id: number;
|
|
119
|
+
DomainId: number;
|
|
120
|
+
Removed: boolean;
|
|
121
|
+
TotalGrantLimit: number;
|
|
122
|
+
IncludedUserRoles?: string[] | null;
|
|
123
|
+
ExcludedUserRoles?: string[] | null;
|
|
124
|
+
}
|
|
125
|
+
export interface IChallengesListData {
|
|
126
|
+
Success: boolean;
|
|
127
|
+
Data: IChallenge[];
|
|
128
|
+
PageNumber: number;
|
|
129
|
+
TotalCount: number;
|
|
130
|
+
}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
import{r as V,h as U}from"./index-9c823353.js";function N(V,U){if(V){const N=document.createElement("style");N.innerHTML=U,V.appendChild(N)}}function Z(V,U){const N=new URL(U);fetch(N.href).then((V=>V.text())).then((U=>{const N=document.createElement("style");N.innerHTML=U,V&&V.appendChild(N)})).catch((V=>{console.error("There was an error while trying to load client styling from URL",V)}))}function R(V,U){if(window.emMessageBus){const N=document.createElement("style");window.emMessageBus.subscribe(U,(U=>{N.innerHTML=U,V&&V.appendChild(N)}))}}const d={en:{title:"Challenges"},ro:{},fr:{},ar:{},hr:{}},l=class{constructor(U){V(this,U),this.tabs=["Active","Pending","Finished","Code"],this.showNotification=1,this.handleTabClick=V=>()=>{this.activeTabIndex=V},this.mbSource=void 0,this.clientStyling=void 0,this.clientStylingUrl=void 0,this.translationUrl="",this.language="en",this.activeTabIndex=0}handleClientStylingChange(V,U){V!=U&&N(this.stylingContainer,this.clientStyling)}handleClientStylingUrlChange(V,U){V!=U&&Z(this.stylingContainer,this.clientStylingUrl)}handleMbSourceChange(V,U){V!=U&&R(this.stylingContainer,`${this.mbSource}.Style`)}componentDidLoad(){this.stylingContainer&&(this.mbSource&&R(this.stylingContainer,`${this.mbSource}.Style`),this.clientStyling&&N(this.stylingContainer,this.clientStyling),this.clientStylingUrl&&Z(this.stylingContainer,this.clientStylingUrl))}disconnectedCallback(){this.stylingSubscription&&this.stylingSubscription.unsubscribe()}componentWillLoad(){this.translationUrl&&(async V=>{if(V)try{const N=await fetch(V);if(!N.ok)throw new Error(`HTTP error! status: ${N.status}`);const Z=await N.json();U=Z,Object.keys(U).forEach((V=>{for(let N in U[V])d[V][N]=U[V][N]}))}catch(V){console.error("Failed to fetch or parse translations from URL:",V)}var U})(this.translationUrl)}render(){return U("div",{key:"ef5356a1bc2a1635d75938d6b03e6dc48979b573",ref:V=>this.stylingContainer=V},U("div",{key:"a1edaaab07df252238186c9e7f0159609b057af3",class:"challenges"},U("div",{key:"096e945c0b7f27b4fbf05886fc3b5816b4e1fe1c",class:"challenges__header"},U("h1",{key:"76e80c1468aba0ea370486c9cd3cc68f70fa0a19",class:"challenges__title"},U("img",{key:"47603b0b6e7f771c91cd06d6338564450022cef7",src:"",alt:"icon"}),d[void 0!==(V=this.language)&&V in d?V:"en"].title),U("div",{key:"43495b2ed368dfb187610bc87d53edbe884c1edb",class:"challenges__tabs"},this.tabs.map(((V,N)=>U("div",{class:"challenges__tab "+(N===this.activeTabIndex?"active":""),onClick:this.handleTabClick(N)},V,this.showNotification===N&&U("img",{src:""}))))))));var V}static get watchers(){return{clientStyling:["handleClientStylingChange"],clientStylingUrl:["handleClientStylingUrlChange"],mbSource:["handleMbSourceChange"]}}};l.style=".challenges {\n container-type: inline-size;\n container-name: challenges-container;\n}\n.challenges__header {\n margin: 0 0 32px;\n display: flex;\n justify-content: space-between;\n}\n.challenges__title {\n margin: 0;\n display: flex;\n gap: 10px;\n align-items: center;\n font-size: var(--emw--font-size-x-large, 24px);\n font-weight: var(--emw--font-weight-bold, 700);\n}\n.challenges__tabs {\n display: flex;\n gap: 12px;\n border-radius: 48px;\n padding: 6px;\n color: var(--emw--color-gray-150, #C8D6CE);\n background-color: var(--emw--color-background-secondary, #272727);\n}\n.challenges__tab {\n padding: 10px 16px;\n border-radius: 40px;\n font-size: var(--emw--font-size-small, 14px);\n font-weight: var(--emw--font-weight-bold, 700);\n cursor: pointer;\n text-align: center;\n width: 95px;\n display: flex;\n justify-content: center;\n align-items: center;\n gap: 4px;\n}\n.challenges__tab.active {\n color: var(--emw--color-white, #FFFFFF);\n background: linear-gradient(90deg, rgb(0, 62, 92) 0%, rgb(17, 59, 33) 100%);\n}\n.challenges__tab:last-child {\n width: inherit;\n padding: 10px 16px;\n}\n@container challenges-container (max-width: 800px) {\n .challenges__header {\n margin: 0 0 16px;\n flex-wrap: wrap;\n row-gap: 12px;\n }\n .challenges__title {\n width: 100%;\n font-size: var(--emw--font-size-large, 20px);\n }\n .challenges__title img {\n height: 32px;\n }\n .challenges__tabs {\n width: 100%;\n gap: 8px;\n }\n .challenges__tab {\n flex: 1;\n padding: 5px 0;\n font-size: var(--emw--font-size-x-small, 12px);\n }\n .challenges__tab:last-child {\n width: inherit;\n padding: 5px 0;\n }\n}";export{l as C}
|