@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.
Files changed (23) hide show
  1. package/dist/casino-challenges-container/casino-challenges-container-c6332600.js +1 -0
  2. package/dist/casino-challenges-container/casino-challenges-container.entry.js +1 -1
  3. package/dist/casino-challenges-container/casino-challenges-container.esm.js +1 -1
  4. package/dist/casino-challenges-container/index.esm.js +1 -1
  5. package/dist/cjs/{casino-challenges-container-54a20dee.js → casino-challenges-container-f2c3603f.js} +67 -4
  6. package/dist/cjs/casino-challenges-container.cjs.entry.js +2 -1
  7. package/dist/cjs/casino-challenges-container.cjs.js +1 -1
  8. package/dist/cjs/index.cjs.js +2 -1
  9. package/dist/cjs/loader.cjs.js +1 -1
  10. package/dist/collection/components/casino-challenges-container/casino-challenges-container.css +15 -2
  11. package/dist/collection/components/casino-challenges-container/casino-challenges-container.js +144 -3
  12. package/dist/collection/utils/locale.utils.js +2 -1
  13. package/dist/collection/utils/types.js +40 -0
  14. package/dist/esm/{casino-challenges-container-affc90f5.js → casino-challenges-container-c6332600.js} +67 -4
  15. package/dist/esm/casino-challenges-container.entry.js +2 -1
  16. package/dist/esm/casino-challenges-container.js +1 -1
  17. package/dist/esm/index.js +2 -1
  18. package/dist/esm/loader.js +1 -1
  19. package/dist/types/components/casino-challenges-container/casino-challenges-container.d.ts +30 -0
  20. package/dist/types/components.d.ts +32 -0
  21. package/dist/types/utils/types.d.ts +130 -0
  22. package/package.json +1 -1
  23. 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-affc90f5.js";import"./index-9c823353.js";
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-affc90f5.js";import"./index-9c823353.js";
1
+ export{C as CasinoChallengesContainer}from"./casino-challenges-container-c6332600.js";import"./index-9c823353.js";import"@everymatrix/casino-challenges-list";
@@ -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, #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}";
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
- return (index.h("div", { key: 'ef5356a1bc2a1635d75938d6b03e6dc48979b573', ref: (el) => (this.stylingContainer = el) }, index.h("div", { key: 'a1edaaab07df252238186c9e7f0159609b057af3', class: "challenges" }, index.h("div", { key: '096e945c0b7f27b4fbf05886fc3b5816b4e1fe1c', class: "challenges__header" }, index.h("h1", { key: '76e80c1468aba0ea370486c9cd3cc68f70fa0a19', class: "challenges__title" }, index.h("img", { key: '47603b0b6e7f771c91cd06d6338564450022cef7', src: titleIconSvg, alt: "icon" }), translate('title', this.language)), index.h("div", { key: '43495b2ed368dfb187610bc87d53edbe884c1edb', 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 })))))))));
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-54a20dee.js');
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;
@@ -2,8 +2,9 @@
2
2
 
3
3
  Object.defineProperty(exports, '__esModule', { value: true });
4
4
 
5
- const casinoChallengesContainer = require('./casino-challenges-container-54a20dee.js');
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
 
@@ -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;
@@ -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, #C8D6CE);
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, #FFFFFF);
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;
@@ -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
- return (h("div", { key: 'ef5356a1bc2a1635d75938d6b03e6dc48979b573', ref: (el) => (this.stylingContainer = el) }, h("div", { key: 'a1edaaab07df252238186c9e7f0159609b057af3', class: "challenges" }, h("div", { key: '096e945c0b7f27b4fbf05886fc3b5816b4e1fe1c', class: "challenges__header" }, h("h1", { key: '76e80c1468aba0ea370486c9cd3cc68f70fa0a19', class: "challenges__title" }, h("img", { key: '47603b0b6e7f771c91cd06d6338564450022cef7', src: titleIcon, alt: "icon" }), translate('title', this.language)), h("div", { key: '43495b2ed368dfb187610bc87d53edbe884c1edb', 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 })))))))));
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() {
@@ -1,7 +1,8 @@
1
1
  const DEFAULT_LANGUAGE = 'en';
2
2
  const TRANSLATIONS = {
3
3
  en: {
4
- title: 'Challenges'
4
+ title: 'Challenges',
5
+ empty: 'No Challenges'
5
6
  },
6
7
  ro: {},
7
8
  fr: {},
@@ -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 = {}));
@@ -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, #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}";
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
- return (h("div", { key: 'ef5356a1bc2a1635d75938d6b03e6dc48979b573', ref: (el) => (this.stylingContainer = el) }, h("div", { key: 'a1edaaab07df252238186c9e7f0159609b057af3', class: "challenges" }, h("div", { key: '096e945c0b7f27b4fbf05886fc3b5816b4e1fe1c', class: "challenges__header" }, h("h1", { key: '76e80c1468aba0ea370486c9cd3cc68f70fa0a19', class: "challenges__title" }, h("img", { key: '47603b0b6e7f771c91cd06d6338564450022cef7', src: titleIconSvg, alt: "icon" }), translate('title', this.language)), h("div", { key: '43495b2ed368dfb187610bc87d53edbe884c1edb', 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 })))))))));
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"],
@@ -1,2 +1,3 @@
1
- export { C as casino_challenges_container } from './casino-challenges-container-affc90f5.js';
1
+ export { C as casino_challenges_container } from './casino-challenges-container-c6332600.js';
2
2
  import './index-9c823353.js';
3
+ import '@everymatrix/casino-challenges-list';
@@ -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
@@ -1,2 +1,3 @@
1
- export { C as CasinoChallengesContainer } from './casino-challenges-container-affc90f5.js';
1
+ export { C as CasinoChallengesContainer } from './casino-challenges-container-c6332600.js';
2
2
  import './index-9c823353.js';
3
+ import '@everymatrix/casino-challenges-list';
@@ -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,6 +1,6 @@
1
1
  {
2
2
  "name": "@everymatrix/casino-challenges-container",
3
- "version": "0.0.1",
3
+ "version": "0.0.3",
4
4
  "main": "./dist/index.cjs.js",
5
5
  "module": "./dist/index.js",
6
6
  "es2015": "./dist/esm/index.mjs",
@@ -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}