@everymatrix/lottery-game-page 0.0.9 → 0.0.13

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 (55) hide show
  1. package/dist/cjs/helper-accordion.cjs.entry.js +88 -0
  2. package/dist/cjs/{helper-accordion_13.cjs.entry.js → helper-filters_2.cjs.entry.js} +21 -1023
  3. package/dist/cjs/helper-modal.cjs.entry.js +44 -0
  4. package/dist/cjs/helper-tab.cjs.entry.js +33 -0
  5. package/dist/cjs/helper-tabs.cjs.entry.js +38 -0
  6. package/dist/cjs/loader.cjs.js +1 -1
  7. package/dist/cjs/lottery-bullet_2.cjs.entry.js +202 -0
  8. package/dist/cjs/lottery-draw-results-history.cjs.entry.js +124 -0
  9. package/dist/cjs/lottery-game-details.cjs.entry.js +19 -0
  10. package/dist/cjs/lottery-game-page.cjs.entry.js +299 -0
  11. package/dist/cjs/lottery-game-page.cjs.js +1 -1
  12. package/dist/cjs/lottery-ticket-controller.cjs.entry.js +69 -0
  13. package/dist/cjs/lottery-ticket.cjs.entry.js +146 -0
  14. package/dist/collection/collection-manifest.json +7 -1
  15. package/dist/components/helper-accordion2.js +1 -0
  16. package/dist/components/helper-filters2.js +1 -0
  17. package/dist/components/helper-modal2.js +1 -0
  18. package/dist/components/helper-pagination.js +1 -0
  19. package/dist/components/helper-tab2.js +1 -0
  20. package/dist/components/helper-tabs2.js +1 -0
  21. package/dist/components/lottery-bullet2.js +1 -0
  22. package/dist/components/lottery-draw-results-history2.js +1 -0
  23. package/dist/components/lottery-draw-results2.js +1 -0
  24. package/dist/components/lottery-game-details2.js +1 -0
  25. package/dist/components/lottery-game-page.js +1 -0
  26. package/dist/components/lottery-grid2.js +1 -0
  27. package/dist/components/lottery-ticket-controller2.js +1 -0
  28. package/dist/components/lottery-ticket2.js +1 -0
  29. package/dist/esm/helper-accordion.entry.js +84 -0
  30. package/dist/esm/{helper-accordion_13.entry.js → helper-filters_2.entry.js} +23 -1014
  31. package/dist/esm/helper-modal.entry.js +40 -0
  32. package/dist/esm/helper-tab.entry.js +29 -0
  33. package/dist/esm/helper-tabs.entry.js +34 -0
  34. package/dist/esm/loader.js +1 -1
  35. package/dist/esm/lottery-bullet_2.entry.js +197 -0
  36. package/dist/esm/lottery-draw-results-history.entry.js +120 -0
  37. package/dist/esm/lottery-game-details.entry.js +15 -0
  38. package/dist/esm/lottery-game-page.entry.js +295 -0
  39. package/dist/esm/lottery-game-page.js +1 -1
  40. package/dist/esm/lottery-ticket-controller.entry.js +65 -0
  41. package/dist/esm/lottery-ticket.entry.js +142 -0
  42. package/dist/lottery-game-page/lottery-game-page.esm.js +1 -1
  43. package/dist/lottery-game-page/p-010895a3.entry.js +1 -0
  44. package/dist/lottery-game-page/p-09f983c6.entry.js +1 -0
  45. package/dist/lottery-game-page/p-0c7ada78.entry.js +1 -0
  46. package/dist/lottery-game-page/p-2932d2a7.entry.js +1 -0
  47. package/dist/lottery-game-page/p-48831184.entry.js +1 -0
  48. package/dist/lottery-game-page/p-50298d2c.entry.js +1 -0
  49. package/dist/lottery-game-page/p-6736fa79.entry.js +1 -0
  50. package/dist/lottery-game-page/p-88f81126.entry.js +1 -0
  51. package/dist/lottery-game-page/{p-49bd2864.entry.js → p-95b37270.entry.js} +105 -105
  52. package/dist/lottery-game-page/p-a1dd3eb2.entry.js +1 -0
  53. package/dist/lottery-game-page/p-caf09eaf.entry.js +1 -0
  54. package/dist/stencil.config.js +9 -5
  55. package/package.json +1 -1
@@ -0,0 +1,40 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-be84da79.js';
2
+
3
+ /**
4
+ * @name isMobile
5
+ * @description A method that returns if the browser used to access the app is from a mobile device or not
6
+ * @param {String} userAgent window.navigator.userAgent
7
+ * @returns {Boolean} true or false
8
+ */
9
+ const isMobile = (userAgent) => {
10
+ return !!(userAgent.toLowerCase().match(/android/i) ||
11
+ userAgent.toLowerCase().match(/blackberry|bb/i) ||
12
+ userAgent.toLowerCase().match(/iphone|ipad|ipod/i) ||
13
+ userAgent.toLowerCase().match(/windows phone|windows mobile|iemobile|wpdesktop/i));
14
+ };
15
+
16
+ const helperModalCss = ":host{display:block}.HelperModalWrapper{position:fixed;left:0;top:0;width:100%;height:100%;background:rgba(0, 0, 0, 0.7);opacity:0;visibility:hidden;transform:scale(1.1);transition:visibility 0s linear 0.25s, opacity 0.25s 0s, transform 0.25s;z-index:1}.HelperModalVisible{opacity:1;visibility:visible;transform:scale(1);transition:visibility 0s linear 0s, opacity 0.25s 0s, transform 0.25s}.HelperModalContent{position:relative;border:solid 1px #848e97;box-shadow:2px 2px 2px rgba(0, 0, 0, 0.007);font-size:14px;padding:10px 10px 5px 10px;background-color:#fff;position:absolute;top:50%;left:50%;transform:translate(-50%, -50%);border-radius:4px;width:600px;max-height:600px;overflow-y:scroll}.HelperModalMobileContent{background:#FFF;top:50%;left:50%;transform:translate(-50%, -50%);border-radius:4px;width:80%;max-height:350px}.HelperModalClose{cursor:pointer;position:absolute;top:15px;right:15px;font-size:20px;color:#000}.HelperModalMobileClose{position:absolute;top:15px;right:15px;font-size:20px;color:#000}";
17
+
18
+ const HelperModal = class {
19
+ constructor(hostRef) {
20
+ registerInstance(this, hostRef);
21
+ this.cancel = createEvent(this, "modalCloseEvent", 7);
22
+ /**
23
+ * Toggles if the helper is visible or not
24
+ */
25
+ this.visible = true;
26
+ this.userAgent = window.navigator.userAgent;
27
+ }
28
+ handleHelperModalClose() {
29
+ this.visible = false;
30
+ this.cancel.emit();
31
+ }
32
+ ;
33
+ render() {
34
+ return ((this.visible &&
35
+ h("div", { class: this.visible ? "HelperModalWrapper HelperModalVisible" : "HelperModalWrapper" }, h("div", { class: "HelperModalWrapper HelperModalVisible" }, h("div", { class: "HelperModalContent" + (isMobile(this.userAgent) ? ' HelperModalMobileContent' : '') }, h("span", { class: "HelperModalClose" + (isMobile(this.userAgent) ? ' HelperModalMobileClose' : ''), onClick: this.handleHelperModalClose.bind(this) }, "X"), h("slot", null))))));
36
+ }
37
+ };
38
+ HelperModal.style = helperModalCss;
39
+
40
+ export { HelperModal as helper_modal };
@@ -0,0 +1,29 @@
1
+ import { r as registerInstance, h } from './index-be84da79.js';
2
+
3
+ const helperTabCss = ":host{display:block}";
4
+
5
+ const HelperTab = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * Selected index
10
+ */
11
+ this.selectedIndex = 0;
12
+ }
13
+ /**
14
+ * Endpoing for CMS
15
+ */
16
+ connectedCallback() {
17
+ /**
18
+ * fetch(cmsEndpoint + / + / + selectedIndex)
19
+ */
20
+ }
21
+ render() {
22
+ return [
23
+ h("div", null, "Reference site about Lorem Ipsum, giving information on its origins, as well as a random Lipsum generator.", this.selectedIndex + 1)
24
+ ];
25
+ }
26
+ };
27
+ HelperTab.style = helperTabCss;
28
+
29
+ export { HelperTab as helper_tab };
@@ -0,0 +1,34 @@
1
+ import { r as registerInstance, h, g as getElement } from './index-be84da79.js';
2
+
3
+ const helperTabsCss = "@import url(\"https://fonts.googleapis.com/css2?family=Roboto:wght@100&display=swap\");:host{display:block;font-family:\"Roboto\", sans-serif}.Tabs{display:flex;gap:10px;overflow-x:auto}.TabButton{cursor:pointer;width:auto;border-radius:4px;padding:8px 15px;margin:5px 0 10px;border:1px solid #009993;background:#FFF;color:#000;font-size:12px;transition:all 0.2s linear;text-align:center;letter-spacing:0;white-space:nowrap}.TabButton:hover{background:#F1F1F1}.TabButton.Active{background:#009993;color:#FFF}";
4
+
5
+ const HelperTabs = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ /**
9
+ * Tell me if it is disabled
10
+ */
11
+ this.disabled = false;
12
+ /**
13
+ * Tell me what tab is selected
14
+ */
15
+ this.selected = false;
16
+ /**
17
+ * Default selected index
18
+ */
19
+ this.selectedIndex = 0;
20
+ /**
21
+ * Tabs details
22
+ */
23
+ this.tabs = [{ label: 'Draw Details' }, { label: 'Winnings' }, { label: 'How to Play' }, { label: 'Game Odds' }, { label: 'FAQs' }];
24
+ }
25
+ connectedCallback() {
26
+ }
27
+ render() {
28
+ return (h("div", null, h("div", { class: "Tabs" }, this.tabs.map((tab, index) => h("button", { class: 'TabButton' + (this.selectedIndex == index ? ' Active' : ''), onClick: () => this.selectedIndex = index }, tab.label))), h("div", null, h("helper-tab", { selectedIndex: this.selectedIndex }))));
29
+ }
30
+ get host() { return getElement(this); }
31
+ };
32
+ HelperTabs.style = helperTabsCss;
33
+
34
+ export { HelperTabs as helper_tabs };
@@ -10,7 +10,7 @@ const patchEsm = () => {
10
10
  const defineCustomElements = (win, options) => {
11
11
  if (typeof window === 'undefined') return Promise.resolve();
12
12
  return patchEsm().then(() => {
13
- return bootstrapLazy([["helper-pagination",[[1,"helper-pagination",{"firstPage":[1540,"first-page"],"previousPage":[1540,"previous-page"],"offset":[1538],"limit":[1538],"total":[1538],"language":[1],"offsetInt":[32],"lastPage":[32],"limitInt":[32],"totalInt":[32],"pagesArray":[32],"endInt":[32]}]]],["helper-accordion_13",[[1,"lottery-game-page",{"endpoint":[1],"gameId":[1,"game-id"],"playerId":[2,"player-id"],"sessionId":[1,"session-id"],"language":[1],"autoPick":[4,"auto-pick"],"resetButton":[4,"reset-button"],"tickets":[32],"tabIndex":[32],"hasErrors":[32],"totalAmount":[32],"successVisible":[32],"deleteVisible":[32],"deleteEventData":[32],"daysRemaining":[32],"hoursRemaining":[32],"minutesRemaining":[32],"secondsRemaining":[32],"latestDraw":[32],"totalWinningsAmount":[32],"nextDate":[32]},[[0,"ticketCompleted","gridFilledHandler"],[0,"gridDirty","gridDirtyHandler"],[0,"deleteTicket","deleteTicketHandler"],[0,"modalCloseEvent","modalCloseEvent"],[0,"stakeChange","stakeChangeHandler"],[0,"multiplierChange","multiplierChangeHandler"]]],[1,"lottery-draw-results-history",{"endpoint":[1],"gameId":[1,"game-id"],"numberOfResults":[2,"number-of-results"],"language":[1],"drawData":[32],"displayAllDrawsResults":[32],"showQuickFilters":[32],"winningDataSetsData":[32]},[[0,"filterSelection","filtersHandler"],[0,"filterSelectionReset","clearFiltersHandler"]]],[1,"lottery-ticket-controller",{"endpoint":[1],"ticketId":[2,"ticket-id"],"ticketDescription":[1,"ticket-description"],"gameId":[1,"game-id"],"postMessage":[4,"post-message"],"eventName":[1,"event-name"],"collapsed":[4],"numberOfGrids":[2,"number-of-grids"],"last":[4],"language":[1],"autoPick":[4,"auto-pick"],"resetButton":[4,"reset-button"]},[[0,"helperAccordionAction","helperAccordionActionHandler"]]],[1,"lottery-game-details"],[1,"lottery-draw-results",{"endpoint":[1],"gameId":[1,"game-id"],"language":[1],"playerId":[1,"player-id"],"drawMode":[4,"draw-mode"],"drawId":[1,"draw-id"],"gameName":[1,"game-name"],"multiplier":[32],"ticketData":[32],"isLoading":[32],"drawResults":[32],"rules":[32],"toggleDrawer":[32],"hasErrors":[32],"errorText":[32]}],[1,"lottery-ticket",{"endpoint":[1],"gameId":[1,"game-id"],"numberOfGrids":[2,"number-of-grids"],"multipleDraws":[4,"multiple-draws"],"ticketId":[2,"ticket-id"],"resetButton":[4,"reset-button"],"autoPick":[4,"auto-pick"],"language":[1],"multiplier":[32],"numberOfDraws":[32],"isLoading":[32],"hasErrors":[32],"ticketDone":[32]},[[0,"gridFilled","gridFilledHandler"]]],[1,"helper-filters",{"showFilterId":[4,"show-filter-id"],"activateTicketSearch":[4,"activate-ticket-search"],"gameId":[1,"game-id"],"playerId":[1,"player-id"],"session":[1],"postMessage":[4,"post-message"],"language":[1],"showFilterModal":[32],"showClearButton":[32],"filterData":[32],"filterDataReset":[32]},[[0,"modalCloseEvent","modalCloseEvent"]]],[1,"helper-tabs",{"disabled":[4],"label":[1],"selected":[4],"cmsEndpoint":[1,"cms-endpoint"],"selectedIndex":[1538,"selected-index"],"tabs":[16]}],[1,"helper-accordion",{"headerTitle":[1,"header-title"],"headerSubtitle":[1,"header-subtitle"],"description":[1],"footer":[4],"deleteTab":[4,"delete-tab"],"postMessage":[4,"post-message"],"eventName":[1,"event-name"],"collapsed":[4],"language":[1],"showContent":[32]}],[1,"helper-modal",{"titleModal":[1,"title-modal"],"visible":[1540]}],[1,"helper-tab",{"selectedIndex":[2,"selected-index"],"cmsEndpoint":[1,"cms-endpoint"]}],[1,"lottery-grid",{"ticketId":[2,"ticket-id"],"totalNumbers":[2,"total-numbers"],"gameId":[1,"game-id"],"maximumAllowed":[2,"maximum-allowed"],"minimumAllowed":[2,"minimum-allowed"],"selectable":[4],"selectedNumbers":[1,"selected-numbers"],"displaySelected":[4,"display-selected"],"language":[1],"gridIndex":[2,"grid-index"],"numbers":[32]},[[0,"lotteryBulletSelection","lotteryBulletSelectionHandler"],[4,"resetSelection","resetSelectionHandler"],[4,"autoSelection","autoSelectionHandler"]]],[1,"lottery-bullet",{"value":[1],"selectable":[4],"isSelected":[4,"is-selected"]}]]]], options);
13
+ return bootstrapLazy([["lottery-game-page",[[1,"lottery-game-page",{"endpoint":[1],"gameId":[1,"game-id"],"playerId":[2,"player-id"],"sessionId":[1,"session-id"],"language":[1],"autoPick":[4,"auto-pick"],"resetButton":[4,"reset-button"],"tickets":[32],"tabIndex":[32],"hasErrors":[32],"totalAmount":[32],"successVisible":[32],"deleteVisible":[32],"deleteEventData":[32],"daysRemaining":[32],"hoursRemaining":[32],"minutesRemaining":[32],"secondsRemaining":[32],"latestDraw":[32],"totalWinningsAmount":[32],"nextDate":[32]},[[0,"ticketCompleted","gridFilledHandler"],[0,"gridDirty","gridDirtyHandler"],[0,"deleteTicket","deleteTicketHandler"],[0,"modalCloseEvent","modalCloseEvent"],[0,"stakeChange","stakeChangeHandler"],[0,"multiplierChange","multiplierChangeHandler"]]]]],["helper-pagination",[[1,"helper-pagination",{"firstPage":[1540,"first-page"],"previousPage":[1540,"previous-page"],"offset":[1538],"limit":[1538],"total":[1538],"language":[1],"offsetInt":[32],"lastPage":[32],"limitInt":[32],"totalInt":[32],"pagesArray":[32],"endInt":[32]}]]],["lottery-bullet_2",[[1,"lottery-grid",{"ticketId":[2,"ticket-id"],"totalNumbers":[2,"total-numbers"],"gameId":[1,"game-id"],"maximumAllowed":[2,"maximum-allowed"],"minimumAllowed":[2,"minimum-allowed"],"selectable":[4],"selectedNumbers":[1,"selected-numbers"],"displaySelected":[4,"display-selected"],"language":[1],"gridIndex":[2,"grid-index"],"numbers":[32]},[[0,"lotteryBulletSelection","lotteryBulletSelectionHandler"],[4,"resetSelection","resetSelectionHandler"],[4,"autoSelection","autoSelectionHandler"]]],[1,"lottery-bullet",{"value":[1],"selectable":[4],"isSelected":[4,"is-selected"]}]]],["helper-filters_2",[[1,"lottery-draw-results",{"endpoint":[1],"gameId":[1,"game-id"],"language":[1],"playerId":[1,"player-id"],"drawMode":[4,"draw-mode"],"drawId":[1,"draw-id"],"gameName":[1,"game-name"],"multiplier":[32],"ticketData":[32],"isLoading":[32],"drawResults":[32],"rules":[32],"toggleDrawer":[32],"hasErrors":[32],"errorText":[32]}],[1,"helper-filters",{"showFilterId":[4,"show-filter-id"],"activateTicketSearch":[4,"activate-ticket-search"],"gameId":[1,"game-id"],"playerId":[1,"player-id"],"session":[1],"postMessage":[4,"post-message"],"language":[1],"showFilterModal":[32],"showClearButton":[32],"filterData":[32],"filterDataReset":[32]},[[0,"modalCloseEvent","modalCloseEvent"]]]]],["lottery-draw-results-history",[[1,"lottery-draw-results-history",{"endpoint":[1],"gameId":[1,"game-id"],"numberOfResults":[2,"number-of-results"],"language":[1],"drawData":[32],"displayAllDrawsResults":[32],"showQuickFilters":[32],"winningDataSetsData":[32]},[[0,"filterSelection","filtersHandler"],[0,"filterSelectionReset","clearFiltersHandler"]]]]],["lottery-ticket",[[1,"lottery-ticket",{"endpoint":[1],"gameId":[1,"game-id"],"numberOfGrids":[2,"number-of-grids"],"multipleDraws":[4,"multiple-draws"],"ticketId":[2,"ticket-id"],"resetButton":[4,"reset-button"],"autoPick":[4,"auto-pick"],"language":[1],"multiplier":[32],"numberOfDraws":[32],"isLoading":[32],"hasErrors":[32],"ticketDone":[32]},[[0,"gridFilled","gridFilledHandler"]]]]],["lottery-ticket-controller",[[1,"lottery-ticket-controller",{"endpoint":[1],"ticketId":[2,"ticket-id"],"ticketDescription":[1,"ticket-description"],"gameId":[1,"game-id"],"postMessage":[4,"post-message"],"eventName":[1,"event-name"],"collapsed":[4],"numberOfGrids":[2,"number-of-grids"],"last":[4],"language":[1],"autoPick":[4,"auto-pick"],"resetButton":[4,"reset-button"]},[[0,"helperAccordionAction","helperAccordionActionHandler"]]]]],["helper-tabs",[[1,"helper-tabs",{"disabled":[4],"label":[1],"selected":[4],"cmsEndpoint":[1,"cms-endpoint"],"selectedIndex":[1538,"selected-index"],"tabs":[16]}]]],["helper-accordion",[[1,"helper-accordion",{"headerTitle":[1,"header-title"],"headerSubtitle":[1,"header-subtitle"],"description":[1],"footer":[4],"deleteTab":[4,"delete-tab"],"postMessage":[4,"post-message"],"eventName":[1,"event-name"],"collapsed":[4],"language":[1],"showContent":[32]}]]],["helper-tab",[[1,"helper-tab",{"selectedIndex":[2,"selected-index"],"cmsEndpoint":[1,"cms-endpoint"]}]]],["lottery-game-details",[[1,"lottery-game-details"]]],["helper-modal",[[1,"helper-modal",{"titleModal":[1,"title-modal"],"visible":[1540]}]]]], options);
14
14
  });
15
15
  };
16
16
 
@@ -0,0 +1,197 @@
1
+ import { r as registerInstance, c as createEvent, h } from './index-be84da79.js';
2
+
3
+ const lotteryBulletCss = "@import url(\"https://fonts.googleapis.com/css2?family=Roboto:wght@100&display=swap\");:host{display:block;font-family:\"Roboto\", sans-serif}.Circle{cursor:pointer;color:#000000;display:block;background:#FFF;border:solid 2px #00958f;height:20px;width:20px;border-radius:50%;margin:0;display:flex;align-items:center;justify-content:center;user-select:none;font-size:12px;font-weight:600;position:relative}.Circle:hover{background:#aee4e2}.Circle.Selected{color:#ffffff;background:#9EC258;background:-webkit-radial-gradient(top, #00958f, #004D4A);background:-moz-radial-gradient(top, #00958f, #004D4A);background:radial-gradient(to bottom, #00958f, #004D4A);border:solid 2px #00958f}.Circle.Disabled{color:#707070;background:#D4D4D4;border:solid 2px #707070;cursor:default}.Circle.DisabledSelected{color:#ffffff;background:#9EC258;background:-webkit-radial-gradient(top, #00958f, #004D4A);background:-moz-radial-gradient(top, #00958f, #004D4A);background:radial-gradient(to bottom, #00958f, #004D4A);border:solid 2px #707070;cursor:default}";
4
+
5
+ const LotteryBullet = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ this.bulletEvent = createEvent(this, "lotteryBulletSelection", 7);
9
+ /**
10
+ * Value of the bullet
11
+ */
12
+ this.value = '0';
13
+ /**
14
+ * Marks if the bullet should be selectable
15
+ */
16
+ this.selectable = true;
17
+ /**
18
+ * Marks if the bullet should be selected
19
+ */
20
+ this.isSelected = false;
21
+ this.select = () => {
22
+ if (this.selectable) {
23
+ this.isSelected = !this.isSelected;
24
+ this.bulletEvent.emit({
25
+ value: this.value,
26
+ selected: this.isSelected
27
+ });
28
+ }
29
+ };
30
+ }
31
+ render() {
32
+ return (h("div", { class: 'Circle ' + (this.selectable ? '' : 'Disabled') + (this.isSelected ? 'Selected' : ''), onClick: () => this.select() }, this.value));
33
+ }
34
+ };
35
+ LotteryBullet.style = lotteryBulletCss;
36
+
37
+ const lotteryGridCss = "@import url(\"https://fonts.googleapis.com/css2?family=Roboto:wght@100&display=swap\");:host{display:block;font-family:\"Roboto\", sans-serif}.GridContainer{display:flex;flex-direction:column;max-width:350px}.Grid{margin-top:10px 0 10px 0;display:flex;flex-direction:row;flex-wrap:wrap;gap:10px}";
38
+
39
+ const LotteryGrid = class {
40
+ constructor(hostRef) {
41
+ registerInstance(this, hostRef);
42
+ this.gridFilledEvent = createEvent(this, "gridFilled", 7);
43
+ this.gridDirtyEvent = createEvent(this, "gridDirty", 7);
44
+ /**
45
+ * Number of bullets of grid
46
+ */
47
+ this.totalNumbers = 0;
48
+ /**
49
+ * Number of maximum bullets that can be selected
50
+ */
51
+ this.maximumAllowed = 0;
52
+ /**
53
+ * Minimum allowed of bullets
54
+ */
55
+ this.minimumAllowed = 1;
56
+ /**
57
+ * Allows the user to select numbers on the grid
58
+ */
59
+ this.selectable = true;
60
+ /**
61
+ * Numbers that should be showed as selected on the grid (as a string of those numbers e.g. '1,2,3,4,5,6')
62
+ */
63
+ this.selectedNumbers = '';
64
+ /**
65
+ * Show only selected numbers
66
+ */
67
+ this.displaySelected = false;
68
+ /**
69
+ * Language
70
+ */
71
+ this.language = 'en';
72
+ this.numbers = [];
73
+ this.selectedCounter = 0;
74
+ }
75
+ connectedCallback() {
76
+ let selected = [];
77
+ if (this.selectedNumbers.length > 0) {
78
+ selected = this.selectedNumbers.split(',');
79
+ this.selectedCounter = selected.length;
80
+ }
81
+ if (this.displaySelected) {
82
+ selected.forEach((item) => {
83
+ this.numbers.push({
84
+ number: item,
85
+ selected: true,
86
+ selectable: this.selectable
87
+ });
88
+ });
89
+ }
90
+ else {
91
+ [...Array(this.totalNumbers).keys()]
92
+ .map(number => (number + 1).toString())
93
+ .forEach((number) => {
94
+ this.numbers.push({
95
+ number,
96
+ selected: selected.indexOf(number) >= 0 ? true : false,
97
+ selectable: this.selectedCounter == this.maximumAllowed ? false : this.selectable
98
+ });
99
+ });
100
+ }
101
+ }
102
+ lotteryBulletSelectionHandler(event) {
103
+ this.numbers = this.numbers.map((item) => {
104
+ if (item.number == event.detail.value) {
105
+ return {
106
+ number: item.number,
107
+ selected: event.detail.selected,
108
+ selectable: item.selectable
109
+ };
110
+ }
111
+ return {
112
+ number: item.number,
113
+ selected: item.selected,
114
+ selectable: item.selectable
115
+ };
116
+ });
117
+ if (event.detail.selected) {
118
+ this.selectedCounter += 1;
119
+ if (this.selectedCounter == this.maximumAllowed) {
120
+ this.numbers = this.numbers.map((item) => {
121
+ return {
122
+ number: item.number,
123
+ selected: item.selected,
124
+ selectable: item.selected ? true : false
125
+ };
126
+ });
127
+ this.gridFilledEvent.emit({
128
+ id: this.ticketId,
129
+ index: this.gridIndex,
130
+ selectedNumbers: this.numbers.filter((item) => item.selected).map((item) => item.number)
131
+ });
132
+ }
133
+ }
134
+ else {
135
+ if (this.selectedCounter == this.maximumAllowed) {
136
+ this.numbers = this.numbers.map((item) => {
137
+ return {
138
+ number: item.number,
139
+ selected: item.selected,
140
+ selectable: true
141
+ };
142
+ });
143
+ this.gridDirtyEvent.emit({
144
+ id: this.ticketId,
145
+ index: this.gridIndex,
146
+ selectedNumbers: this.numbers.filter((item) => item.selected).map((item) => item.number)
147
+ });
148
+ }
149
+ this.selectedCounter -= 1;
150
+ }
151
+ }
152
+ async resetSelectionHandler(event) {
153
+ if (event.detail && event.detail == this.ticketId) {
154
+ this.selectedCounter = 0;
155
+ this.numbers = this.numbers.map((item) => {
156
+ return {
157
+ number: item.number,
158
+ selected: false,
159
+ selectable: this.selectable
160
+ };
161
+ });
162
+ this.gridDirtyEvent.emit({
163
+ id: this.ticketId,
164
+ index: this.gridIndex,
165
+ selectedNumbers: this.numbers.filter((item) => item.selected).map((item) => item.number)
166
+ });
167
+ }
168
+ }
169
+ async autoSelectionHandler(event) {
170
+ if (event.detail && event.detail == this.ticketId) {
171
+ this.resetSelectionHandler(event);
172
+ let array = [...Array(this.totalNumbers).keys()]
173
+ .map(number => number + 1)
174
+ .sort(() => 0.5 - Math.random());
175
+ array = array.slice(0, this.minimumAllowed);
176
+ this.numbers = this.numbers.map((item) => {
177
+ return {
178
+ number: item.number,
179
+ selected: array.indexOf(parseInt(item.number, 10)) >= 0 ? true : false,
180
+ selectable: array.indexOf(parseInt(item.number, 10)) >= 0 ? true : false,
181
+ };
182
+ });
183
+ this.gridFilledEvent.emit({
184
+ id: this.ticketId,
185
+ index: this.gridIndex,
186
+ selectedNumbers: this.numbers.filter((item) => item.selected).map((item) => item.number)
187
+ });
188
+ this.selectedCounter = this.maximumAllowed;
189
+ }
190
+ }
191
+ render() {
192
+ return (h("div", { class: "GridContainer" }, h("div", { class: "Grid" }, this.numbers.map((item) => h("div", null, h("lottery-bullet", { value: item.number, selectable: item.selectable, "is-selected": item.selected }))))));
193
+ }
194
+ };
195
+ LotteryGrid.style = lotteryGridCss;
196
+
197
+ export { LotteryBullet as lottery_bullet, LotteryGrid as lottery_grid };
@@ -0,0 +1,120 @@
1
+ import { r as registerInstance, h } from './index-be84da79.js';
2
+
3
+ const DEFAULT_LANGUAGE = 'en';
4
+ const SUPPORTED_LANGUAGES = ['ro', 'en'];
5
+ const TRANSLATIONS = {
6
+ en: {
7
+ drawResultsHeader: 'Draw results history',
8
+ drawId: 'Draw ID',
9
+ drawDate: 'Draw Date',
10
+ drawNumbersGridA: 'Draw numbers Grid A',
11
+ viewAllResults: 'View All',
12
+ lastFiveDraws: 'Last 5 Draws',
13
+ lastTenDraws: 'Last 10 Draws',
14
+ lastFifteenDraws: 'Last 15 Draws'
15
+ },
16
+ ro: {
17
+ drawResultsHeader: 'Draw results history',
18
+ drawId: 'Draw ID',
19
+ drawDate: 'Draw Date',
20
+ drawNumbersGridA: 'Draw numbers Grid A',
21
+ viewAllResults: 'View All',
22
+ lastFiveDraws: 'Last 5 Draws',
23
+ lastTenDraws: 'Last 10 Draws',
24
+ lastFifteenDraws: 'Last 15 Draws'
25
+ },
26
+ };
27
+ const translate = (key, customLang) => {
28
+ const lang = customLang;
29
+ return TRANSLATIONS[lang !== undefined && SUPPORTED_LANGUAGES.includes(lang) ? lang : DEFAULT_LANGUAGE][key];
30
+ };
31
+
32
+ const lotteryDrawResultsHistoryCss = "@import url(\"https://fonts.googleapis.com/css2?family=Roboto:wght@100&display=swap\");:host{display:block;font-family:\"Roboto\", sans-serif}.GridBanner{background-color:#009993;background-repeat:no-repeat;background-position:center;color:#111;padding:0 20px 30px}.GridBanner .BannerButtonsWrapper{display:flex;justify-content:space-between;padding-top:16px}.GridBanner .BannerButtonsWrapper .BannerBackButton,.GridBanner .BannerButtonsWrapper .BannerLobbyButton{background:#fff;border:1px solid #009993;border-radius:4px;padding:7px 15px;font-size:12px;text-transform:uppercase;width:80px}.GridBanner .HistoryGridBannerArea{padding-top:30px}.HistoryGridBannerArea{display:flex;flex-direction:column;align-items:center}.BannerText{font-size:14px;font-weight:300}.BannerCountdown{font-size:22px;display:flex;gap:20px}.DrawResultsSection{max-width:500px;margin:0 auto}.HistoryGridWrapper{padding:0 15px}.HistoryGrid{border:1px solid #009993;border-radius:5px}.DrawResultsHeader{color:#009993;padding:15px;text-align:center}.DrawResultsHeader h4{text-transform:uppercase;font-size:16px;font-weight:600;margin:0}.DrawNumbersGrid{padding:10px 50px}.DrawNumbersGrid p{margin:0 0 10px 0;font-size:14px}.BulletContainer{margin-bottom:20px}.DrawResultTop{background-color:#009993;padding:10px;text-align:center;color:#fff;padding:0 50px;display:flex;justify-content:center;gap:40px}.ViewAllResults{display:block;padding:10px 40px;margin:40px auto;border:0;border-radius:5px;background-color:#009993;color:#fff;outline:none}.FilterSection{display:flex;justify-content:space-between;padding:10px 0 25px}.FilterSection .FilterResultsContainer{display:flex;gap:5px}.FilterSection .QuickFilterButton{cursor:pointer;width:max-content;border-radius:4px;border:1px solid #00958f;background:#FFF;color:#000;font-size:12px;transition:all 0.2s linear;text-align:center;letter-spacing:0}.FilterSection .QuickFilterButton:hover{background:#F1F1F1}.FilterSection helper-filters{margin-left:auto}";
33
+
34
+ const LotteryDrawResultsHistory = class {
35
+ constructor(hostRef) {
36
+ registerInstance(this, hostRef);
37
+ /**
38
+ * The number of results to be displayed
39
+ */
40
+ this.numberOfResults = 3;
41
+ /**
42
+ *Language
43
+ */
44
+ this.language = 'en';
45
+ this.drawData = [];
46
+ this.displayAllDrawsResults = true;
47
+ this.showQuickFilters = true;
48
+ this.winningDataSetsData = [''];
49
+ this.getDrawsData = () => {
50
+ let url = new URL(`${this.endpoint}/games/${this.gameId}`);
51
+ fetch(url.href)
52
+ .then((res) => {
53
+ if (res.status >= 300) {
54
+ throw new Error('There was an error while fetching the data');
55
+ }
56
+ return res.json();
57
+ })
58
+ .then((data) => {
59
+ console.log("getDrawsData ", data);
60
+ // filter out incomplete data sets for draws
61
+ this.winningDataSetsData = data.draws.filter(draw => draw.winningNumbers);
62
+ this.drawData = this.winningDataSetsData;
63
+ console.log('this.drawData', this.drawData);
64
+ });
65
+ };
66
+ this.filterResults = (resultsNumber) => {
67
+ this.numberOfResults = resultsNumber;
68
+ this.displayAllDrawsResults = true;
69
+ };
70
+ this.getDrawResults = (drawID) => {
71
+ let url = new URL(`${this.endpoint}/games/${this.gameId}/draws/${drawID}`);
72
+ let drawOptions = {
73
+ method: "GET",
74
+ headers: {
75
+ 'Content-Type': "application/json",
76
+ 'Accept': 'application/json',
77
+ },
78
+ };
79
+ fetch(url.href, drawOptions)
80
+ .then((response) => {
81
+ return response.json();
82
+ })
83
+ .then((data) => {
84
+ console.log("getDrawResults ", data);
85
+ this.drawData = [data];
86
+ });
87
+ };
88
+ this.viewAllResults = () => {
89
+ this.numberOfResults = this.drawData.length;
90
+ this.displayAllDrawsResults = false;
91
+ window.scrollTo({ top: 0, behavior: 'smooth' });
92
+ };
93
+ }
94
+ // Filters events
95
+ filtersHandler(event) {
96
+ var _a;
97
+ this.getDrawResults((_a = event.detail) === null || _a === void 0 ? void 0 : _a.drawTicketId);
98
+ this.showQuickFilters = false;
99
+ }
100
+ clearFiltersHandler() {
101
+ this.drawData = this.winningDataSetsData;
102
+ this.showQuickFilters = true;
103
+ }
104
+ connectedCallback() {
105
+ this.getDrawsData();
106
+ }
107
+ disconnectedCallback() {
108
+ clearInterval(this.interval);
109
+ }
110
+ render() {
111
+ let gridHeader = h("div", { class: "DrawResultsHeader" }, this.displayAllDrawsResults ? h("h4", null, translate('drawResultsHeader', this.language)) :
112
+ h("div", { class: "DrawResultsHeaderContent" }, h("div", { class: "FilterSection" }, this.showQuickFilters &&
113
+ h("div", { class: "FilterResultsContainer" }, h("button", { class: "QuickFilterButton", onClick: () => this.filterResults(5) }, translate('lastFiveDraws', this.language)), h("button", { class: "QuickFilterButton", onClick: () => this.filterResults(10) }, translate('lastTenDraws', this.language)), h("button", { class: "QuickFilterButton", onClick: () => this.filterResults(15) }, translate('lastFifteenDraws', this.language))), h("helper-filters", { "show-filter-id": "true", "activate-ticket-search": "false", "game-id": "3797", "player-id": "2323" })), h("h4", null, "All draws results history")));
114
+ let gridContent = h("div", { class: "HistoryGridWrapper" }, h("div", { class: "HistoryGrid" }, this.drawData.map((item) => h("lottery-draw-results", { endpoint: this.endpoint, "game-id": this.gameId, "draw-id": item.id, "draw-mode": true })).reverse().slice(0, this.numberOfResults)));
115
+ return h("section", { class: "GridWrapper" }, h("div", { class: "DrawResultsSection" }, h("div", { class: "DrawResultsArea" }, gridHeader, gridContent, this.displayAllDrawsResults && h("button", { class: "ViewAllResults", onClick: this.viewAllResults }, "View All"))));
116
+ }
117
+ };
118
+ LotteryDrawResultsHistory.style = lotteryDrawResultsHistoryCss;
119
+
120
+ export { LotteryDrawResultsHistory as lottery_draw_results_history };
@@ -0,0 +1,15 @@
1
+ import { r as registerInstance, h } from './index-be84da79.js';
2
+
3
+ const lotteryGameDetailsCss = ":host{display:block}";
4
+
5
+ const LotteryGameDetails = class {
6
+ constructor(hostRef) {
7
+ registerInstance(this, hostRef);
8
+ }
9
+ render() {
10
+ return (h("div", null, h("helper-accordion", { "header-title": "Game Details", collapsed: false }, h("div", { slot: "accordionContent" }, h("helper-tabs", null)))));
11
+ }
12
+ };
13
+ LotteryGameDetails.style = lotteryGameDetailsCss;
14
+
15
+ export { LotteryGameDetails as lottery_game_details };