@everymatrix/casino-challenges-container 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (59) hide show
  1. package/dist/casino-challenges-container/app-globals-0f993ce5.js +1 -0
  2. package/dist/casino-challenges-container/casino-challenges-container-affc90f5.js +1 -0
  3. package/dist/casino-challenges-container/casino-challenges-container.entry.js +1 -0
  4. package/dist/casino-challenges-container/casino-challenges-container.esm.js +1 -0
  5. package/dist/casino-challenges-container/index-9c823353.js +2 -0
  6. package/dist/casino-challenges-container/index.esm.js +1 -0
  7. package/dist/cjs/app-globals-3a1e7e63.js +5 -0
  8. package/dist/cjs/casino-challenges-container-54a20dee.js +166 -0
  9. package/dist/cjs/casino-challenges-container.cjs.entry.js +10 -0
  10. package/dist/cjs/casino-challenges-container.cjs.js +25 -0
  11. package/dist/cjs/index-cf89b5da.js +1197 -0
  12. package/dist/cjs/index.cjs.js +10 -0
  13. package/dist/cjs/loader.cjs.js +15 -0
  14. package/dist/collection/assets/notification.svg +20 -0
  15. package/dist/collection/assets/title-icon.svg +1 -0
  16. package/dist/collection/collection-manifest.json +12 -0
  17. package/dist/collection/components/casino-challenges-container/casino-challenges-container.css +73 -0
  18. package/dist/collection/components/casino-challenges-container/casino-challenges-container.js +177 -0
  19. package/dist/collection/components/casino-challenges-container/index.js +1 -0
  20. package/dist/collection/index.js +1 -0
  21. package/dist/collection/utils/locale.utils.js +36 -0
  22. package/dist/collection/utils/utils.js +3 -0
  23. package/dist/esm/app-globals-0f993ce5.js +3 -0
  24. package/dist/esm/casino-challenges-container-affc90f5.js +164 -0
  25. package/dist/esm/casino-challenges-container.entry.js +2 -0
  26. package/dist/esm/casino-challenges-container.js +20 -0
  27. package/dist/esm/index-9c823353.js +1171 -0
  28. package/dist/esm/index.js +2 -0
  29. package/dist/esm/loader.js +11 -0
  30. package/dist/index.cjs.js +1 -0
  31. package/dist/index.js +1 -0
  32. package/dist/stencil.config.dev.js +19 -0
  33. package/dist/stencil.config.js +19 -0
  34. package/dist/storybook/main.js +43 -0
  35. package/dist/storybook/preview.js +9 -0
  36. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/libs/common/src/storybook/storybook-utils.d.ts +39 -0
  37. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/packages/stencil/casino-challenges-container/stencil.config.d.ts +2 -0
  38. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/packages/stencil/casino-challenges-container/stencil.config.dev.d.ts +2 -0
  39. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/packages/stencil/casino-challenges-container/storybook/main.d.ts +3 -0
  40. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/packages/stencil/casino-challenges-container/storybook/preview.d.ts +70 -0
  41. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/tools/plugins/index.d.ts +4 -0
  42. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/tools/plugins/lazy-load-chunk-plugin.d.ts +12 -0
  43. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/tools/plugins/stencil-clean-deps-plugin.d.ts +5 -0
  44. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/tools/plugins/vite-chunk-plugin.d.ts +6 -0
  45. package/dist/types/builds/emfe-widgets/widgets-monorepo/packages/stencil/casino-challenges-container/.stencil/tools/plugins/vite-clean-deps-plugin.d.ts +4 -0
  46. package/dist/types/components/casino-challenges-container/casino-challenges-container.d.ts +35 -0
  47. package/dist/types/components/casino-challenges-container/index.d.ts +1 -0
  48. package/dist/types/components.d.ts +77 -0
  49. package/dist/types/index.d.ts +1 -0
  50. package/dist/types/stencil-public-runtime.d.ts +1674 -0
  51. package/dist/types/utils/locale.utils.d.ts +3 -0
  52. package/dist/types/utils/utils.d.ts +1 -0
  53. package/loader/cdn.js +1 -0
  54. package/loader/index.cjs.js +1 -0
  55. package/loader/index.d.ts +24 -0
  56. package/loader/index.es2017.js +1 -0
  57. package/loader/index.js +2 -0
  58. package/loader/package.json +11 -0
  59. package/package.json +27 -0
@@ -0,0 +1,164 @@
1
+ import { r as registerInstance, h } from './index-9c823353.js';
2
+
3
+ /**
4
+ * @name setClientStyling
5
+ * @description Method used to create and append to the passed element of the widget a style element with the content received
6
+ * @param {HTMLElement} stylingContainer The reference element of the widget
7
+ * @param {string} clientStyling The style content
8
+ */
9
+ function setClientStyling(stylingContainer, clientStyling) {
10
+ if (stylingContainer) {
11
+ const sheet = document.createElement('style');
12
+ sheet.innerHTML = clientStyling;
13
+ stylingContainer.appendChild(sheet);
14
+ }
15
+ }
16
+
17
+ /**
18
+ * @name setClientStylingURL
19
+ * @description Method used to create and append to the passed element of the widget a style element with the content fetched from a given URL
20
+ * @param {HTMLElement} stylingContainer The reference element of the widget
21
+ * @param {string} clientStylingUrl The URL of the style content
22
+ */
23
+ function setClientStylingURL(stylingContainer, clientStylingUrl) {
24
+ const url = new URL(clientStylingUrl);
25
+
26
+ fetch(url.href)
27
+ .then((res) => res.text())
28
+ .then((data) => {
29
+ const cssFile = document.createElement('style');
30
+ cssFile.innerHTML = data;
31
+ if (stylingContainer) {
32
+ stylingContainer.appendChild(cssFile);
33
+ }
34
+ })
35
+ .catch((err) => {
36
+ console.error('There was an error while trying to load client styling from URL', err);
37
+ });
38
+ }
39
+
40
+ /**
41
+ * @name setStreamLibrary
42
+ * @description Method used to create and append to the passed element of the widget a style element with content fetched from the MessageBus
43
+ * @param {HTMLElement} stylingContainer The highest element of the widget
44
+ * @param {string} domain The domain from where the content should be fetched (e.g. 'Casino.Style', 'App.Style', 'casino-footer.style', etc.)
45
+ * @param {ref} subscription A reference to a variable where the subscription should be saved for unsubscribing when no longer needed
46
+ */
47
+ function setStreamStyling(stylingContainer, domain, subscription) {
48
+ if (window.emMessageBus) {
49
+ const sheet = document.createElement('style');
50
+
51
+ window.emMessageBus.subscribe(domain, (data) => {
52
+ sheet.innerHTML = data;
53
+ if (stylingContainer) {
54
+ stylingContainer.appendChild(sheet);
55
+ }
56
+ });
57
+ }
58
+ }
59
+
60
+ const DEFAULT_LANGUAGE = 'en';
61
+ const TRANSLATIONS = {
62
+ en: {
63
+ title: 'Challenges'
64
+ },
65
+ ro: {},
66
+ fr: {},
67
+ ar: {},
68
+ hr: {}
69
+ };
70
+ const translate = (key, customLang) => {
71
+ const lang = customLang;
72
+ return TRANSLATIONS[lang !== undefined && lang in TRANSLATIONS ? lang : DEFAULT_LANGUAGE][key];
73
+ };
74
+ const getTranslations = (data) => {
75
+ Object.keys(data).forEach((item) => {
76
+ for (let key in data[item]) {
77
+ TRANSLATIONS[item][key] = data[item][key];
78
+ }
79
+ });
80
+ };
81
+ const resolveTranslationUrl = async (translationUrl) => {
82
+ if (translationUrl) {
83
+ try {
84
+ const response = await fetch(translationUrl);
85
+ if (!response.ok) {
86
+ throw new Error(`HTTP error! status: ${response.status}`);
87
+ }
88
+ const translations = await response.json();
89
+ getTranslations(translations);
90
+ }
91
+ catch (error) {
92
+ console.error('Failed to fetch or parse translations from URL:', error);
93
+ }
94
+ }
95
+ };
96
+
97
+ const titleIconSvg = '';
98
+
99
+ const notificationSvg = '';
100
+
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}";
102
+ const CasinoChallengesContainerStyle0 = casinoChallengesContainerCss;
103
+
104
+ const CasinoChallengesContainer = class {
105
+ constructor(hostRef) {
106
+ registerInstance(this, hostRef);
107
+ // todo: connect with api
108
+ this.tabs = ['Active', 'Pending', 'Finished', 'Code'];
109
+ this.showNotification = 1;
110
+ this.handleTabClick = (index) => () => {
111
+ this.activeTabIndex = index;
112
+ };
113
+ this.mbSource = undefined;
114
+ this.clientStyling = undefined;
115
+ this.clientStylingUrl = undefined;
116
+ this.translationUrl = '';
117
+ this.language = 'en';
118
+ this.activeTabIndex = 0;
119
+ }
120
+ handleClientStylingChange(newValue, oldValue) {
121
+ if (newValue != oldValue) {
122
+ setClientStyling(this.stylingContainer, this.clientStyling);
123
+ }
124
+ }
125
+ handleClientStylingUrlChange(newValue, oldValue) {
126
+ if (newValue != oldValue) {
127
+ setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
128
+ }
129
+ }
130
+ handleMbSourceChange(newValue, oldValue) {
131
+ if (newValue != oldValue) {
132
+ setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
133
+ }
134
+ }
135
+ componentDidLoad() {
136
+ if (this.stylingContainer) {
137
+ if (this.mbSource)
138
+ setStreamStyling(this.stylingContainer, `${this.mbSource}.Style`);
139
+ if (this.clientStyling)
140
+ setClientStyling(this.stylingContainer, this.clientStyling);
141
+ if (this.clientStylingUrl)
142
+ setClientStylingURL(this.stylingContainer, this.clientStylingUrl);
143
+ }
144
+ }
145
+ disconnectedCallback() {
146
+ this.stylingSubscription && this.stylingSubscription.unsubscribe();
147
+ }
148
+ componentWillLoad() {
149
+ if (this.translationUrl) {
150
+ resolveTranslationUrl(this.translationUrl);
151
+ }
152
+ }
153
+ 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 })))))))));
155
+ }
156
+ static get watchers() { return {
157
+ "clientStyling": ["handleClientStylingChange"],
158
+ "clientStylingUrl": ["handleClientStylingUrlChange"],
159
+ "mbSource": ["handleMbSourceChange"]
160
+ }; }
161
+ };
162
+ CasinoChallengesContainer.style = CasinoChallengesContainerStyle0;
163
+
164
+ export { CasinoChallengesContainer as C };
@@ -0,0 +1,2 @@
1
+ export { C as casino_challenges_container } from './casino-challenges-container-affc90f5.js';
2
+ import './index-9c823353.js';
@@ -0,0 +1,20 @@
1
+ import { p as promiseResolve, b as bootstrapLazy } from './index-9c823353.js';
2
+ export { s as setNonce } from './index-9c823353.js';
3
+ import { g as globalScripts } from './app-globals-0f993ce5.js';
4
+
5
+ /*
6
+ Stencil Client Patch Browser v4.19.2 | MIT Licensed | https://stenciljs.com
7
+ */
8
+ var patchBrowser = () => {
9
+ const importMeta = import.meta.url;
10
+ const opts = {};
11
+ if (importMeta !== "") {
12
+ opts.resourcesUrl = new URL(".", importMeta).href;
13
+ }
14
+ return promiseResolve(opts);
15
+ };
16
+
17
+ patchBrowser().then(async (options) => {
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);
20
+ });