tango-app-ui-shared 3.0.13-dev → 3.0.15-dev
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/modules/layout/toolbar/classic/classic.component.mjs +16 -7
- package/esm2022/lib/modules/layout/toolbar/client-settings/client-settings.component.mjs +4 -4
- package/esm2022/lib/modules/layout/toolbar/date-single-select/date-single-select.component.mjs +6 -6
- package/esm2022/lib/modules/layout/toolbar/datepicker/datepicker.component.mjs +2 -2
- package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +40 -51
- package/esm2022/lib/services/auth.service.mjs +3 -3
- package/esm2022/lib/services/global-state.service.mjs +3 -6
- package/fesm2022/tango-app-ui-shared.mjs +67 -72
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/services/auth.service.d.ts +1 -1
- package/lib/services/global-state.service.d.ts +2 -3
- package/package.json +1 -1
|
@@ -27,60 +27,49 @@ export class SingleStoreComponent {
|
|
|
27
27
|
this.auth = auth;
|
|
28
28
|
this.gs = gs;
|
|
29
29
|
this.cd = cd;
|
|
30
|
-
this.auth.getStores().subscribe({
|
|
31
|
-
next: (e) => {
|
|
32
|
-
if (e) {
|
|
33
|
-
this.storeList = e.data.result;
|
|
34
|
-
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
35
|
-
this.cd.detectChanges();
|
|
36
|
-
if (headerFilters.store) {
|
|
37
|
-
this.storeList.find((obj) => {
|
|
38
|
-
if (obj.storeId === headerFilters.store) {
|
|
39
|
-
this.selectedClient = obj;
|
|
40
|
-
this.gs.apply(this.selectedFilters);
|
|
41
|
-
this.cd.detectChanges();
|
|
42
|
-
}
|
|
43
|
-
});
|
|
44
|
-
}
|
|
45
|
-
else {
|
|
46
|
-
this.selectedClient = this.storeList[0];
|
|
47
|
-
this.selectedFilters.store = this.selectedClient.storeId;
|
|
48
|
-
// console.log(this.selectedFilters)
|
|
49
|
-
this.gs.apply(this.selectedFilters);
|
|
50
|
-
this.cd.detectChanges();
|
|
51
|
-
}
|
|
52
|
-
}
|
|
53
|
-
},
|
|
54
|
-
});
|
|
55
30
|
}
|
|
56
31
|
ngOnInit() {
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
this.
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
32
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
33
|
+
if (headerFilters?.client) {
|
|
34
|
+
this.auth.getStores(headerFilters?.client).subscribe({
|
|
35
|
+
next: (e) => {
|
|
36
|
+
if (e) {
|
|
37
|
+
this.storeList = e.data.result;
|
|
38
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
39
|
+
this.cd.detectChanges();
|
|
40
|
+
if (headerFilters.store) {
|
|
41
|
+
this.storeList.find((obj) => {
|
|
42
|
+
if (obj.storeId === headerFilters.store) {
|
|
43
|
+
this.selectedClient = obj;
|
|
44
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
45
|
+
}
|
|
46
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
47
|
+
this.selectedFilters.store = headerFilters.store;
|
|
48
|
+
this.selectedFilters.client = headerFilters.client;
|
|
49
|
+
this.selectedFilters.clients = [headerFilters.clients];
|
|
50
|
+
this.selectedFilters.date = headerFilters.date;
|
|
51
|
+
this.selectedDateRange.startDate = headerFilters.date.startDate;
|
|
52
|
+
this.selectedDateRange.endDate = headerFilters.date.endDate;
|
|
53
|
+
this.cd.detectChanges();
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
this.selectedClient = this.storeList[0];
|
|
58
|
+
this.selectedFilters.store = this.selectedClient.storeId;
|
|
59
|
+
this.selectedDateRange.startDate = this.dayjs().format('YYYY-MM-DD');
|
|
60
|
+
this.selectedDateRange.endDate = this.dayjs().format('YYYY-MM-DD');
|
|
61
|
+
this.selectedFilters.date = this.selectedDateRange;
|
|
62
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
63
|
+
this.cd.detectChanges();
|
|
64
|
+
}
|
|
64
65
|
}
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
this.gs.apply(this.selectedFilters);
|
|
68
|
-
this.selectedFilters.store = headerFilters.store;
|
|
69
|
-
this.selectedFilters.client = headerFilters.client;
|
|
70
|
-
this.selectedFilters.clients = [headerFilters.clients];
|
|
71
|
-
this.selectedFilters.date = headerFilters.date;
|
|
72
|
-
this.selectedDateRange.startDate = headerFilters.date.startDate;
|
|
73
|
-
this.selectedDateRange.endDate = headerFilters.date.endDate;
|
|
74
|
-
this.cd.detectChanges();
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
this.selectedDateRange.startDate = this.dayjs().format('MM-DD-YYYY');
|
|
78
|
-
this.selectedDateRange.endDate = this.dayjs().format('MM-DD-YYYY');
|
|
66
|
+
},
|
|
67
|
+
});
|
|
79
68
|
}
|
|
80
69
|
}
|
|
81
70
|
onClientSelect(event) {
|
|
82
71
|
this.selectedClient = event;
|
|
83
|
-
this.gs.
|
|
72
|
+
this.gs.selectedClient.next(this.selectedClient);
|
|
84
73
|
}
|
|
85
74
|
ranges = {
|
|
86
75
|
'Today': [this.dayjs(), this.dayjs()],
|
|
@@ -105,8 +94,8 @@ export class SingleStoreComponent {
|
|
|
105
94
|
if (event && event.startDate && event.endDate) {
|
|
106
95
|
if (this.dayjs(event.startDate).isValid() && this.dayjs(event.endDate).isValid()) {
|
|
107
96
|
// Dates are valid, proceed with formatting
|
|
108
|
-
this.selectedDateRange.startDate = this.dayjs(event.startDate).utc().format('
|
|
109
|
-
this.selectedDateRange.endDate = this.dayjs(event.endDate).utc().format('
|
|
97
|
+
this.selectedDateRange.startDate = this.dayjs(event.startDate).utc().format('YYYY-MM-DD');
|
|
98
|
+
this.selectedDateRange.endDate = this.dayjs(event.endDate).utc().format('YYYY-MM-DD');
|
|
110
99
|
}
|
|
111
100
|
else {
|
|
112
101
|
// Dates are not valid, handle the scenario accordingly
|
|
@@ -133,7 +122,7 @@ export class SingleStoreComponent {
|
|
|
133
122
|
this.selectedFilters = headerFilters;
|
|
134
123
|
this.selectedFilters.store = this.selectedClient.storeId;
|
|
135
124
|
this.selectedFilters.date = this.selectedDateRange;
|
|
136
|
-
this.gs.
|
|
125
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
137
126
|
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
138
127
|
this.cd.detectChanges();
|
|
139
128
|
}
|
|
@@ -144,4 +133,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
144
133
|
type: Component,
|
|
145
134
|
args: [{ selector: 'lib-single-store', template: "<div class=\"wrapper mx-2\" >\r\n <lib-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\" [disabled]=\"false\" [idField]=\"'storeId'\"\r\n (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n\r\n \r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path\r\n d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n </span>\r\n <input class=\"fx-date-range form-control ps-14\" type=\"text\" matInput ngxDaterangepickerMd [drops]=\"'down'\"\r\n [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [alwaysShowCalendars]=\"false\"\r\n [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\" [(ngModel)]=\"selectedDateRange\"\r\n [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n (datesUpdated)=\"datechange($event)\" name=\"daterange\" />\r\n</div>\r\n\r\n<div class=\"btn btn-primary ms-2\" (click)=\"Apply()\">Apply</div>\r\n", styles: [".daterangepicker{display:block!important;top:153.85px!important;left:900px!important;right:0}.form-control{color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600;line-height:20px;text-transform:capitalize}::ng-deep .applyBtn{display:none!important}:host::ng-deep .md-drppicker .btn{line-height:10px!important}:host::ng-deep .daterangepicker-input+.ngx-daterangepicker-material .applyBtn{display:none}:host::ng-deep .md-drppicker.drops-down-right.ltr.double.show-ranges.shown{top:65px!important;left:-470px!important;height:400px!important}:host::ng-deep .md-drppicker .btn{border-radius:8px!important;border:1px solid var(--Primary-600, #00A3FF)!important;background:var(--Primary-600, #00A3FF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--White, #FFF)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize}:host::ng-deep .md-drppicker .ranges ul li button{padding:12px 16px;width:160px;color:var(--Gray-700, #344054);font-size:14px;font-weight:400;line-height:20px;background:none;border:none;text-align:left;cursor:pointer}:host::ng-deep .md-drppicker td.active,:host::ng-deep .md-drppicker td.active:hover{background-color:#029cf4!important;border-radius:20px!important;color:var(--White, #FFF)!important;text-align:center!important;font-size:14px!important;font-weight:500!important;line-height:20px}:host::ng-deep .md-drppicker.ltr .ranges{float:left;margin-top:10px!important}:host::ng-deep .md-drppicker td.in-range{background:var(--Primary-50, #EAF8FF)}:host::ng-deep .md-drppicker .ranges ul li button.active{background:var(--Primary-50, #EAF8FF)!important;border-radius:8px!important;color:var(--Primary-700, #009BF3);font-size:14px!important;font-weight:500!important;line-height:20px!important}:host::ng-deep table th,:host::ng-deep table td{width:40px!important;height:40px!important;padding:10px 8px!important}:host::ng-deep .md-drppicker td.available.prev,:host::ng-deep .md-drppicker th.available.prev{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep .md-drppicker td.available.next,:host::ng-deep .md-drppicker th.available.next{background-image:url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgeG1sbnM6eGxpbms9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkveGxpbmsiIHg9IjBweCIgeT0iMHB4Ig0KCSB2aWV3Qm94PSIwIDAgMy43IDYiIGVuYWJsZS1iYWNrZ3JvdW5kPSJuZXcgMCAwIDMuNyA2IiB4bWw6c3BhY2U9InByZXNlcnZlIj4NCjxnPg0KCTxwYXRoIGQ9Ik0zLjcsMC43TDEuNCwzbDIuMywyLjNMMyw2TDAsM2wzLTNMMy43LDAuN3oiLz4NCjwvZz4NCjwvc3ZnPg0K)!important;background-repeat:no-repeat!important;background-size:.5em!important;background-position:center!important}:host::ng-deep table th{border-bottom:0px solid var(--Gray-200, #EAECF0)!important;background:transparent!important;color:var(--Gray-700, #344054)!important;text-align:center;font-size:16px!important;font-weight:500!important;line-height:24px}:host::ng-deep .md-drppicker td.available.invalid-date{text-decoration:line-through;pointer-events:none;color:#a9a9a9}:host::ng-deep .md-drppicker td.available.today:not(.invalid-date){text-decoration:unset;pointer-events:unset;color:unset}:host::ng-deep .md-drppicker .btn.btn-default{border-radius:8px!important;border:1px solid var(--Gray-300, #D0D5DD)!important;background:var(--White, #FFF)!important;box-shadow:0 1px 2px #1018280d!important;color:var(--Gray-700, #344054)!important;font-size:14px!important;font-weight:600!important;line-height:20px;text-transform:capitalize;margin-right:10px!important}.wrapper{min-width:200px}.btn-primary{line-height:18px!important}\n"] }]
|
|
146
135
|
}], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }] });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-store.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/single-store/single-store.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/single-store/single-store.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\n\r\nimport { AuthService } from '../../../../services/auth.service';\r\nimport  dayjs from 'dayjs';\r\nimport 'dayjs/locale/en';\r\nimport { GlobalStateService } from '../../../../services/global-state.service';\r\n\r\n@Component({\r\n  selector: 'lib-single-store',\r\n  templateUrl: './single-store.component.html',\r\n  styleUrl: './single-store.component.scss'\r\n})\r\nexport class SingleStoreComponent implements OnInit {\r\n  dayjs = dayjs\r\n  isCustomDate: (m: dayjs.Dayjs) => false | \"invalid-date\";\r\n  selectedDateRange: any = {};\r\n  storeList:any = []\r\n  selectedClient:any\r\n  selectedFilters: any = {\r\n    client: null,\r\n    clients: [],\r\n    store: null,\r\n    stores: [],\r\n    date: null,\r\n\r\n  };\r\n  constructor(private auth:AuthService, private gs:GlobalStateService, private cd:ChangeDetectorRef){\r\n    this.auth.getStores().subscribe({\r\n      next: (e) => {\r\n        if (e) {\r\n          this.storeList = e.data.result;\r\n          const headerFilters: any = JSON.parse(\r\n            localStorage.getItem(\"header-filters\") || \"{}\"\r\n          );\r\n          this.cd.detectChanges();\r\n          if (headerFilters.store) {\r\n            this.storeList.find((obj: any) => {\r\n              if (obj.storeId === headerFilters.store) {\r\n                this.selectedClient = obj;\r\n                this.gs.apply(this.selectedFilters);\r\n                this.cd.detectChanges();\r\n              }\r\n            });\r\n          } else {\r\n            this.selectedClient = this.storeList[0];\r\n            this.selectedFilters.store =  this.selectedClient.storeId;\r\n            // console.log(this.selectedFilters)\r\n            this.gs.apply(this.selectedFilters);\r\n            this.cd.detectChanges();\r\n          }\r\n        }\r\n      },\r\n    });\r\n  }\r\n  ngOnInit(): void {\r\n\r\n    if (\"header-filters\" in localStorage) {\r\n     \r\n      const headerFilters: any = JSON.parse(\r\n        localStorage.getItem('header-filters') || '{}'\r\n      );\r\n      this.cd.detectChanges()\r\n    if(headerFilters.store){\r\n      this.storeList.find((obj: any) => {\r\n        if (obj.storeId === headerFilters.store) {\r\n          this.selectedClient = obj;\r\n        \r\n        }\r\n      });\r\n    }\r\n    \r\n      this.gs.apply(this.selectedFilters);\r\n      this.selectedFilters.store =  headerFilters.store;\r\n      this.selectedFilters.client =  headerFilters.client;\r\n      this.selectedFilters.clients =  [headerFilters.clients];  \r\n      this.selectedFilters.date =  headerFilters.date;  \r\n      this.selectedDateRange.startDate = headerFilters.date.startDate;\r\n      this.selectedDateRange.endDate = headerFilters.date.endDate;\r\n      this.cd.detectChanges();\r\n    } else {\r\n     \r\n      this.selectedDateRange.startDate = this.dayjs().format('MM-DD-YYYY');\r\n      this.selectedDateRange.endDate = this.dayjs().format('MM-DD-YYYY');\r\n    }\r\n    \r\n  }\r\n  onClientSelect(event:any){\r\n    this.selectedClient = event\r\n    this.gs.apply(this.selectedClient)\r\n \r\n  }\r\n\r\n  ranges: any = {\r\n    'Today': [this.dayjs(), this.dayjs()],\r\n    'Yesterday': [this.dayjs().subtract(1, 'days'), this.dayjs().subtract(1, 'days')],\r\n    'This Week': [this.dayjs().subtract(6, 'days'), this.dayjs()],\r\n    'Last Week': [this.dayjs().subtract(14, 'days').startOf('days'), this.dayjs().subtract(8, 'days').endOf('days')],\r\n    'This Month': [this.dayjs().startOf('month'), this.dayjs().endOf('month')],\r\n    'Last Month': [\r\n      this.dayjs().subtract(1, 'month').startOf('month'),\r\n      this.dayjs().subtract(1, 'month').endOf('month')\r\n    ]\r\n  };\r\n\r\n  onStartDateChange(event:any){\r\n    if(this.dayjs(event.startDate).isValid()){\r\n      this.isCustomDate = (m: dayjs.Dayjs) => {        \r\n      const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(90, 'days')) ;\r\n      return isValidDate ? 'invalid-date' : false;\r\n  }\r\n}\r\n}\r\n\r\ndatechange(event: any) {\r\n  if (event && event.startDate && event.endDate) {\r\n    if (this.dayjs(event.startDate).isValid() && this.dayjs(event.endDate).isValid()) {\r\n      // Dates are valid, proceed with formatting\r\n      this.selectedDateRange.startDate = this.dayjs(event.startDate).utc().format('DD-MM-YYYY');\r\n      this.selectedDateRange.endDate = this.dayjs(event.endDate).utc().format('DD-MM-YYYY');\r\n    } else {\r\n      // Dates are not valid, handle the scenario accordingly\r\n      console.error('Invalid dates provided:', event.startDate, event.endDate);\r\n      // If you want to fallback to stored filters when the dates are invalid, you can keep the existing logic\r\n      // const storedFilters = JSON.parse(localStorage.getItem('dateRangeFilters') || '{}');\r\n      // if (storedFilters.startDate && storedFilters.endDate) {\r\n      //   this.selectedDateRange.startDate = dayjs(storedFilters.startDate).format('DD-MM-YYYY');\r\n      //   this.selectedDateRange.endDate = dayjs(storedFilters.endDate).format('DD-MM-YYYY');\r\n      // }\r\n    }\r\n  } else {\r\n    const headerFilters: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    this.selectedFilters.date = headerFilters.date;\r\n  }\r\n  this.selectedFilters.date =this.selectedDateRange\r\n  // this.globalService.sendData(JSON.stringify(this.selectedFilters.date));\r\n  // localStorage.setItem('dateRangeFilters', JSON.stringify(this.selectedDateRange));\r\n  // this.globalService.sendData(this.selectedDateRange);\r\n}\r\n\r\nApply() {\r\n  const headerFilters: any = JSON.parse(\r\n    localStorage.getItem(\"header-filters\") || \"{}\"\r\n  );\r\n  this.selectedFilters = headerFilters;\r\n  this.selectedFilters.store = this.selectedClient.storeId;\r\n  this.selectedFilters.date = this.selectedDateRange;\r\n  this.gs.apply(this.selectedFilters);\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  this.cd.detectChanges();\r\n}\r\n}\r\n","<div class=\"wrapper mx-2\" >\r\n    <lib-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\" [disabled]=\"false\" [idField]=\"'storeId'\"\r\n        (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n\r\n        \r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path\r\n                d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </span>\r\n    <input class=\"fx-date-range form-control ps-14\" type=\"text\" matInput ngxDaterangepickerMd [drops]=\"'down'\"\r\n        [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [alwaysShowCalendars]=\"false\"\r\n        [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\" [(ngModel)]=\"selectedDateRange\"\r\n        [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n        (datesUpdated)=\"datechange($event)\" name=\"daterange\" />\r\n</div>\r\n\r\n<div class=\"btn btn-primary ms-2\" (click)=\"Apply()\">Apply</div>\r\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-store.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/single-store/single-store.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/single-store/single-store.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\n\r\nimport { AuthService } from '../../../../services/auth.service';\r\nimport  dayjs from 'dayjs';\r\nimport 'dayjs/locale/en';\r\nimport { GlobalStateService } from '../../../../services/global-state.service';\r\n\r\n@Component({\r\n  selector: 'lib-single-store',\r\n  templateUrl: './single-store.component.html',\r\n  styleUrl: './single-store.component.scss'\r\n})\r\nexport class SingleStoreComponent implements OnInit {\r\n  dayjs = dayjs\r\n  isCustomDate: (m: dayjs.Dayjs) => false | \"invalid-date\";\r\n  selectedDateRange: any = {};\r\n  storeList:any = []\r\n  selectedClient:any\r\n  selectedFilters: any = {\r\n    client: null,\r\n    clients: [],\r\n    store: null,\r\n    stores: [],\r\n    date: null,\r\n\r\n  };\r\n  constructor(private auth:AuthService, private gs:GlobalStateService, private cd:ChangeDetectorRef){\r\n \r\n  }\r\n  ngOnInit(): void {\r\n    const headerFilters: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    if(headerFilters?.client){\r\n    this.auth.getStores(headerFilters?.client).subscribe({\r\n      next: (e) => {\r\n        if (e) {\r\n          this.storeList = e.data.result;\r\n          const headerFilters: any = JSON.parse(\r\n            localStorage.getItem(\"header-filters\") || \"{}\"\r\n          );\r\n          this.cd.detectChanges();\r\n          if (headerFilters.store) {\r\n            this.storeList.find((obj: any) => {\r\n              if (obj.storeId === headerFilters.store) {\r\n                this.selectedClient = obj;\r\n                this.gs.dataRangeValue.next(this.selectedFilters);\r\n                \r\n              }\r\n              this.gs.dataRangeValue.next(this.selectedFilters);\r\n              this.selectedFilters.store =  headerFilters.store;\r\n              this.selectedFilters.client =  headerFilters.client;\r\n              this.selectedFilters.clients =  [headerFilters.clients];  \r\n              this.selectedFilters.date =  headerFilters.date;  \r\n              this.selectedDateRange.startDate = headerFilters.date.startDate;\r\n              this.selectedDateRange.endDate = headerFilters.date.endDate;\r\n              this.cd.detectChanges();\r\n            });\r\n           \r\n          } else {\r\n            this.selectedClient = this.storeList[0];\r\n            this.selectedFilters.store =  this.selectedClient.storeId; \r\n            this.selectedDateRange.startDate = this.dayjs().format('YYYY-MM-DD');\r\n            this.selectedDateRange.endDate = this.dayjs().format('YYYY-MM-DD');\r\n            this.selectedFilters.date =  this.selectedDateRange;\r\n            this.gs.dataRangeValue.next(this.selectedFilters);\r\n            this.cd.detectChanges();\r\n          }\r\n        }\r\n      },\r\n    });\r\n  }\r\n  }\r\n  onClientSelect(event:any){\r\n    this.selectedClient = event\r\n    this.gs.selectedClient.next(this.selectedClient)\r\n \r\n  }\r\n\r\n  ranges: any = {\r\n    'Today': [this.dayjs(), this.dayjs()],\r\n    'Yesterday': [this.dayjs().subtract(1, 'days'), this.dayjs().subtract(1, 'days')],\r\n    'This Week': [this.dayjs().subtract(6, 'days'), this.dayjs()],\r\n    'Last Week': [this.dayjs().subtract(14, 'days').startOf('days'), this.dayjs().subtract(8, 'days').endOf('days')],\r\n    'This Month': [this.dayjs().startOf('month'), this.dayjs().endOf('month')],\r\n    'Last Month': [\r\n      this.dayjs().subtract(1, 'month').startOf('month'),\r\n      this.dayjs().subtract(1, 'month').endOf('month')\r\n    ]\r\n  };\r\n\r\n  onStartDateChange(event:any){\r\n    if(this.dayjs(event.startDate).isValid()){\r\n      this.isCustomDate = (m: dayjs.Dayjs) => {        \r\n      const isValidDate = m > this.dayjs() || m > this.dayjs(event.startDate.add(90, 'days')) ;\r\n      return isValidDate ? 'invalid-date' : false;\r\n  }\r\n}\r\n}\r\n\r\ndatechange(event: any) {\r\n  if (event && event.startDate && event.endDate) {\r\n    if (this.dayjs(event.startDate).isValid() && this.dayjs(event.endDate).isValid()) {\r\n      // Dates are valid, proceed with formatting\r\n      this.selectedDateRange.startDate = this.dayjs(event.startDate).utc().format('YYYY-MM-DD');\r\n      this.selectedDateRange.endDate = this.dayjs(event.endDate).utc().format('YYYY-MM-DD');\r\n    } else {\r\n      // Dates are not valid, handle the scenario accordingly\r\n      console.error('Invalid dates provided:', event.startDate, event.endDate);\r\n      // If you want to fallback to stored filters when the dates are invalid, you can keep the existing logic\r\n      // const storedFilters = JSON.parse(localStorage.getItem('dateRangeFilters') || '{}');\r\n      // if (storedFilters.startDate && storedFilters.endDate) {\r\n      //   this.selectedDateRange.startDate = dayjs(storedFilters.startDate).format('DD-MM-YYYY');\r\n      //   this.selectedDateRange.endDate = dayjs(storedFilters.endDate).format('DD-MM-YYYY');\r\n      // }\r\n    }\r\n  } else {\r\n    const headerFilters: any = JSON.parse(\r\n      localStorage.getItem(\"header-filters\") || \"{}\"\r\n    );\r\n    this.selectedFilters.date = headerFilters.date;\r\n  }\r\n  this.selectedFilters.date =this.selectedDateRange\r\n  // this.globalService.sendData(JSON.stringify(this.selectedFilters.date));\r\n  // localStorage.setItem('dateRangeFilters', JSON.stringify(this.selectedDateRange));\r\n  // this.globalService.sendData(this.selectedDateRange);\r\n}\r\n\r\nApply() {\r\n  const headerFilters: any = JSON.parse(\r\n    localStorage.getItem(\"header-filters\") || \"{}\"\r\n  );\r\n  this.selectedFilters = headerFilters;\r\n  this.selectedFilters.store = this.selectedClient.storeId;\r\n  this.selectedFilters.date = this.selectedDateRange;\r\n  this.gs.dataRangeValue.next(this.selectedFilters);\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  this.cd.detectChanges();\r\n}\r\n}\r\n","<div class=\"wrapper mx-2\" >\r\n    <lib-select [items]=\"storeList\" [multi]=\"false\" [searchField]=\"'storeName'\" [disabled]=\"false\" [idField]=\"'storeId'\"\r\n        (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n\r\n        \r\n</div>\r\n<div class=\"d-flex align-items-center position-relative my-1\">\r\n    <span class=\"svg-icon svg-icon-1 position-absolute ms-3\">\r\n        <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n            <path\r\n                d=\"M13.3333 1.66663V4.99996M6.66667 1.66663V4.99996M2.5 8.33329H17.5M4.16667 3.33329H15.8333C16.7538 3.33329 17.5 4.07948 17.5 4.99996V16.6666C17.5 17.5871 16.7538 18.3333 15.8333 18.3333H4.16667C3.24619 18.3333 2.5 17.5871 2.5 16.6666V4.99996C2.5 4.07948 3.24619 3.33329 4.16667 3.33329Z\"\r\n                stroke=\"#344054\" stroke-width=\"1.67\" stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n        </svg>\r\n    </span>\r\n    <input class=\"fx-date-range form-control ps-14\" type=\"text\" matInput ngxDaterangepickerMd [drops]=\"'down'\"\r\n        [opens]=\"'right'\" [ranges]=\"ranges\" [showCustomRangeLabel]=\"true\" [alwaysShowCalendars]=\"false\"\r\n        [keepCalendarOpeningWithRange]=\"true\" [showCancel]=\"true\" autocomplete=\"off\" [(ngModel)]=\"selectedDateRange\"\r\n        [locale]=\"{ format: 'DD-MM-YYYY', firstDay: 1, monthNames: ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'] }\"\r\n        (datesUpdated)=\"datechange($event)\" name=\"daterange\" />\r\n</div>\r\n\r\n<div class=\"btn btn-primary ms-2\" (click)=\"Apply()\">Apply</div>\r\n"]}
|
|
@@ -34,8 +34,8 @@ export class AuthService {
|
|
|
34
34
|
return this.http.get(`${this.clientApiUrl}/get-clients`, {})
|
|
35
35
|
.pipe(map((response) => response), catchError(this.handleError));
|
|
36
36
|
}
|
|
37
|
-
getStores() {
|
|
38
|
-
return this.http.get(`https://devtangoretail-api.tangoeye.ai/v3/store/get-stores?clientId
|
|
37
|
+
getStores(id) {
|
|
38
|
+
return this.http.get(`https://devtangoretail-api.tangoeye.ai/v3/store/get-stores?clientId=${id}`, {})
|
|
39
39
|
.pipe(map((response) => response), catchError(this.handleError));
|
|
40
40
|
}
|
|
41
41
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AuthService, deps: [{ token: i1.Router }, { token: i2.GlobalStateService }, { token: i3.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -47,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
47
47
|
providedIn: 'root'
|
|
48
48
|
}]
|
|
49
49
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.GlobalStateService }, { type: i3.HttpClient }] });
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL3NlcnZpY2VzL2F1dGguc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFBRSxVQUFVLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7Ozs7QUFRbkQsTUFBTSxPQUFPLFdBQVc7SUFJRjtJQUFzQjtJQUE4QjtJQUh4RSxZQUFZLENBQU07SUFDbEIscUJBQXFCLENBQVM7SUFFOUIsWUFBb0IsTUFBYSxFQUFTLEVBQXFCLEVBQVMsSUFBZTtRQUFuRSxXQUFNLEdBQU4sTUFBTSxDQUFPO1FBQVMsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFBUyxTQUFJLEdBQUosSUFBSSxDQUFXO1FBQ3JGLElBQUksQ0FBQyxFQUFFLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLEdBQUcsRUFBQyxFQUFFO1lBQ3JDLElBQUcsR0FBRyxFQUFDO2dCQUNOLElBQUksQ0FBQyxZQUFZLEdBQUksR0FBRyxDQUFDLFlBQVksQ0FBQztnQkFDdEMsSUFBSSxDQUFDLHFCQUFxQixHQUFHLEdBQUcsR0FBRyxDQUFDLFVBQVUsSUFBSSxHQUFHLENBQUMsWUFBWSxFQUFFLENBQUM7YUFDckU7UUFDRixDQUFDLENBQUMsQ0FBQTtJQUFDLENBQUM7SUFFSixXQUFXLENBQUMsR0FBUTtRQUNuQixPQUFPLFVBQVUsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakMsQ0FBQztJQUNDLE1BQU07UUFDSixZQUFZLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ3BELElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUMsYUFBYSxDQUFDLEVBQUU7WUFDcEMsV0FBVyxFQUFFLEVBQUU7U0FDaEIsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVELFVBQVU7UUFDUixPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLEdBQUcsSUFBSSxDQUFDLFlBQVksY0FBYyxFQUFFLEVBQzFELENBQUM7YUFDRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBYSxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFDbEMsVUFBVSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFDRCxTQUFTLENBQUMsRUFBTTtRQUNkLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsdUVBQXVFLEVBQUUsRUFBRSxFQUFFLEVBQ25HLENBQUM7YUFDRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBYSxFQUFFLEVBQUUsQ0FBQyxRQUFRLENBQUMsRUFDbEMsVUFBVSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7dUdBakNVLFdBQVc7MkdBQVgsV0FBVyxjQUZWLE1BQU07OzJGQUVQLFdBQVc7a0JBSHZCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBIdHRwQ2xpZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBjYXRjaEVycm9yLCBtYXAsIHRocm93RXJyb3IgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuLy8gaW1wb3J0IHsgR2xvYmFsU3RhdGVTZXJ2aWNlIH0gZnJvbSAndGFuZ28tYXBwLXVpLXNoYXJlZCc7XHJcbmltcG9ydCB7IEdsb2JhbFN0YXRlU2VydmljZSB9IGZyb20gJy4vZ2xvYmFsLXN0YXRlLnNlcnZpY2UnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQXV0aFNlcnZpY2Uge1xyXG4gIGNsaWVudEFwaVVybDogYW55O1xyXG4gIGF1dGhsb2NhbFN0b3JhZ2VUb2tlbjogc3RyaW5nO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJvdXRlcjpSb3V0ZXIscHJpdmF0ZSBnczpHbG9iYWxTdGF0ZVNlcnZpY2UscHJpdmF0ZSBodHRwOkh0dHBDbGllbnQpIHsgIFxyXG4gICAgdGhpcy5ncy5lbnZpcm9ubWVudC5zdWJzY3JpYmUoKGVudik9PntcclxuICAgIGlmKGVudil7XHJcbiAgICAgdGhpcy5jbGllbnRBcGlVcmwgPSAgZW52LmNsaWVudEFwaVVybDtcclxuICAgICB0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbiA9IGAke2Vudi5hcHBWZXJzaW9ufS0ke2Vudi5VU0VSREFUQV9LRVl9YDtcclxuICAgIH1cclxuICAgfSkgfVxyXG4gICBcclxuICAgaGFuZGxlRXJyb3IocmVzOiBhbnkpIHtcclxuICAgIHJldHVybiB0aHJvd0Vycm9yKHJlcy5lcnJvcik7XHJcbn1cclxuICBsb2dvdXQoKSB7XHJcbiAgICBsb2NhbFN0b3JhZ2UucmVtb3ZlSXRlbSh0aGlzLmF1dGhsb2NhbFN0b3JhZ2VUb2tlbik7XHJcbiAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbJy9hdXRoL2xvZ2luJ10sIHtcclxuICAgICAgcXVlcnlQYXJhbXM6IHt9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBnZXRDbGllbnRzKCl7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldChgJHt0aGlzLmNsaWVudEFwaVVybH0vZ2V0LWNsaWVudHNgLCB7XHJcbiAgfSlcclxuICAgICAgLnBpcGUobWFwKChyZXNwb25zZTogYW55KSA9PiByZXNwb25zZSksXHJcbiAgICAgICAgICBjYXRjaEVycm9yKHRoaXMuaGFuZGxlRXJyb3IpKTtcclxuICB9XHJcbiAgZ2V0U3RvcmVzKGlkOmFueSl7XHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldChgaHR0cHM6Ly9kZXZ0YW5nb3JldGFpbC1hcGkudGFuZ29leWUuYWkvdjMvc3RvcmUvZ2V0LXN0b3Jlcz9jbGllbnRJZD0ke2lkfWAsIHtcclxuICB9KVxyXG4gICAgICAucGlwZShtYXAoKHJlc3BvbnNlOiBhbnkpID0+IHJlc3BvbnNlKSxcclxuICAgICAgICAgIGNhdGNoRXJyb3IodGhpcy5oYW5kbGVFcnJvcikpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -1,14 +1,11 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
|
-
import { BehaviorSubject
|
|
2
|
+
import { BehaviorSubject } from 'rxjs';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class GlobalStateService {
|
|
5
5
|
userData = new BehaviorSubject(null);
|
|
6
6
|
environment = new BehaviorSubject(null);
|
|
7
|
-
dataRangeValue = new
|
|
7
|
+
dataRangeValue = new BehaviorSubject(null);
|
|
8
8
|
selectedClient = new BehaviorSubject(null);
|
|
9
|
-
apply(options) {
|
|
10
|
-
this.dataRangeValue.next(options);
|
|
11
|
-
}
|
|
12
9
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: GlobalStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
13
10
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: GlobalStateService, providedIn: 'root' });
|
|
14
11
|
}
|
|
@@ -18,4 +15,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
18
15
|
providedIn: 'root'
|
|
19
16
|
}]
|
|
20
17
|
}] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
18
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2xvYmFsLXN0YXRlLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy90YW5nby1hcHAtc2hhcmVkL3NyYy9saWIvc2VydmljZXMvZ2xvYmFsLXN0YXRlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFXLE1BQU0sTUFBTSxDQUFDOztBQU1oRCxNQUFNLE9BQU8sa0JBQWtCO0lBQzdCLFFBQVEsR0FBRyxJQUFJLGVBQWUsQ0FBb0IsSUFBSSxDQUFDLENBQUE7SUFDdkQsV0FBVyxHQUFHLElBQUksZUFBZSxDQUFNLElBQUksQ0FBQyxDQUFBO0lBQzVDLGNBQWMsR0FBRyxJQUFJLGVBQWUsQ0FBTSxJQUFJLENBQUMsQ0FBQztJQUNoRCxjQUFjLEdBQUcsSUFBSSxlQUFlLENBQU0sSUFBSSxDQUFDLENBQUM7dUdBSnJDLGtCQUFrQjsyR0FBbEIsa0JBQWtCLGNBRmpCLE1BQU07OzJGQUVQLGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJlaGF2aW9yU3ViamVjdCwgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBzYW1wbGVUeXBlIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9nbG9iYWwtc3RhdGUnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgR2xvYmFsU3RhdGVTZXJ2aWNlIHtcclxuICB1c2VyRGF0YSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8c2FtcGxlVHlwZSB8IG51bGw+KG51bGwpXHJcbiAgZW52aXJvbm1lbnQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGFueT4obnVsbClcclxuICBkYXRhUmFuZ2VWYWx1ZSA9IG5ldyBCZWhhdmlvclN1YmplY3Q8YW55PihudWxsKTtcclxuICBzZWxlY3RlZENsaWVudCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8YW55PihudWxsKTtcclxuXHJcbi8vICAgYXBwbHkob3B0aW9uczogYW55KTogdm9pZCB7XHJcbi8vICAgICB0aGlzLmRhdGFSYW5nZVZhbHVlLm5leHQob3B0aW9ucyk7XHJcbi8vIH1cclxufVxyXG4iXX0=
|
|
@@ -8,7 +8,7 @@ import * as i2 from '@angular/common';
|
|
|
8
8
|
import { CommonModule } from '@angular/common';
|
|
9
9
|
import { filter } from 'rxjs/operators';
|
|
10
10
|
import * as i3 from '@angular/platform-browser';
|
|
11
|
-
import { BehaviorSubject,
|
|
11
|
+
import { BehaviorSubject, throwError, map, catchError } from 'rxjs';
|
|
12
12
|
import dayjs from 'dayjs';
|
|
13
13
|
import 'dayjs/locale/en';
|
|
14
14
|
import utc from 'dayjs/plugin/utc';
|
|
@@ -1542,11 +1542,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
1542
1542
|
class GlobalStateService {
|
|
1543
1543
|
userData = new BehaviorSubject(null);
|
|
1544
1544
|
environment = new BehaviorSubject(null);
|
|
1545
|
-
dataRangeValue = new
|
|
1545
|
+
dataRangeValue = new BehaviorSubject(null);
|
|
1546
1546
|
selectedClient = new BehaviorSubject(null);
|
|
1547
|
-
apply(options) {
|
|
1548
|
-
this.dataRangeValue.next(options);
|
|
1549
|
-
}
|
|
1550
1547
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: GlobalStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1551
1548
|
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: GlobalStateService, providedIn: 'root' });
|
|
1552
1549
|
}
|
|
@@ -1632,8 +1629,8 @@ class AuthService {
|
|
|
1632
1629
|
return this.http.get(`${this.clientApiUrl}/get-clients`, {})
|
|
1633
1630
|
.pipe(map((response) => response), catchError(this.handleError));
|
|
1634
1631
|
}
|
|
1635
|
-
getStores() {
|
|
1636
|
-
return this.http.get(`https://devtangoretail-api.tangoeye.ai/v3/store/get-stores?clientId
|
|
1632
|
+
getStores(id) {
|
|
1633
|
+
return this.http.get(`https://devtangoretail-api.tangoeye.ai/v3/store/get-stores?clientId=${id}`, {})
|
|
1637
1634
|
.pipe(map((response) => response), catchError(this.handleError));
|
|
1638
1635
|
}
|
|
1639
1636
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: AuthService, deps: [{ token: i1$1.Router }, { token: GlobalStateService }, { token: i3$1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -1714,7 +1711,7 @@ class ClassicComponent {
|
|
|
1714
1711
|
this.selectedFilters.clients = currentIssues;
|
|
1715
1712
|
this.selectedFilters.client = headerFilters.client;
|
|
1716
1713
|
// }
|
|
1717
|
-
this.globalService.
|
|
1714
|
+
this.globalService.dataRangeValue.next(this.selectedFilters);
|
|
1718
1715
|
this.cd.detectChanges();
|
|
1719
1716
|
}
|
|
1720
1717
|
else {
|
|
@@ -1722,8 +1719,8 @@ class ClassicComponent {
|
|
|
1722
1719
|
this.toggleCheckbox("Select All", 0);
|
|
1723
1720
|
this.dummyArray = JSON.parse(JSON.stringify(this.dataObject));
|
|
1724
1721
|
this.responseArray = JSON.parse(JSON.stringify(this.dataObject));
|
|
1725
|
-
this.selectedDateRange.startDate = this.dayjs().format("MM-DD
|
|
1726
|
-
this.selectedDateRange.endDate = this.dayjs().format("MM-DD
|
|
1722
|
+
this.selectedDateRange.startDate = this.dayjs().format("YYYY-MM-DD");
|
|
1723
|
+
this.selectedDateRange.endDate = this.dayjs().format("YYYY-MM-DD");
|
|
1727
1724
|
const currentIssues = this.dummyArray[0].Issues.map((item) => item.clientId);
|
|
1728
1725
|
this.selectedFilters.clients = currentIssues;
|
|
1729
1726
|
this.selectedFilters.date = this.selectedDateRange;
|
|
@@ -1858,7 +1855,7 @@ class ClassicComponent {
|
|
|
1858
1855
|
});
|
|
1859
1856
|
}
|
|
1860
1857
|
}
|
|
1861
|
-
this.globalService.
|
|
1858
|
+
this.globalService.dataRangeValue.next(this.selectedFilters);
|
|
1862
1859
|
this.cd.detectChanges();
|
|
1863
1860
|
this.Opendropdown = false;
|
|
1864
1861
|
this.selectedValuesArray.forEach((item, index) => {
|
|
@@ -1904,10 +1901,10 @@ class ClassicComponent {
|
|
|
1904
1901
|
// Dates are valid, proceed with formatting
|
|
1905
1902
|
this.selectedDateRange.startDate = this.dayjs(event.startDate)
|
|
1906
1903
|
.utc()
|
|
1907
|
-
.format("
|
|
1904
|
+
.format("YYYY-MM-DD");
|
|
1908
1905
|
this.selectedDateRange.endDate = this.dayjs(event.endDate)
|
|
1909
1906
|
.utc()
|
|
1910
|
-
.format("
|
|
1907
|
+
.format("YYYY-MM-DD");
|
|
1911
1908
|
console.log(this.selectedDateRange);
|
|
1912
1909
|
}
|
|
1913
1910
|
else {
|
|
@@ -1918,6 +1915,15 @@ class ClassicComponent {
|
|
|
1918
1915
|
else {
|
|
1919
1916
|
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
1920
1917
|
this.selectedFilters.date = headerFilters.date;
|
|
1918
|
+
if (headerFilters.date?.startDate && headerFilters.date?.endDate) {
|
|
1919
|
+
this.selectedDateRange = headerFilters.date;
|
|
1920
|
+
}
|
|
1921
|
+
else {
|
|
1922
|
+
this.selectedDateRange = {
|
|
1923
|
+
startDate: dayjs().format("YYYY-MM-DD"),
|
|
1924
|
+
endDate: dayjs().format("YYYY-MM-DD")
|
|
1925
|
+
};
|
|
1926
|
+
}
|
|
1921
1927
|
}
|
|
1922
1928
|
this.selectedFilters.date = this.selectedDateRange;
|
|
1923
1929
|
this.cd.detectChanges();
|
|
@@ -2098,17 +2104,17 @@ class ClientSettingsComponent {
|
|
|
2098
2104
|
else {
|
|
2099
2105
|
this.selectedClient = this.clientList[0];
|
|
2100
2106
|
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2101
|
-
this.gs.
|
|
2107
|
+
this.gs.selectedClient.next(this.selectedFilters);
|
|
2102
2108
|
this.cd.detectChanges();
|
|
2103
2109
|
}
|
|
2104
2110
|
this.selectedFilters.client = headerFilters.client;
|
|
2105
|
-
this.gs.
|
|
2111
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2106
2112
|
this.cd.detectChanges();
|
|
2107
2113
|
}
|
|
2108
2114
|
else {
|
|
2109
2115
|
this.selectedClient = this.clientList[0];
|
|
2110
2116
|
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2111
|
-
this.gs.
|
|
2117
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2112
2118
|
this.cd.detectChanges();
|
|
2113
2119
|
}
|
|
2114
2120
|
}
|
|
@@ -2218,7 +2224,7 @@ class DatepickerComponent {
|
|
|
2218
2224
|
}
|
|
2219
2225
|
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
2220
2226
|
this.selectedFilters = headerFilters;
|
|
2221
|
-
this.gs.
|
|
2227
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2222
2228
|
this.selectedFilters.date = this.selectedDateRange;
|
|
2223
2229
|
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
2224
2230
|
this.cd.detectChanges();
|
|
@@ -2262,7 +2268,7 @@ class DateSingleSelectComponent {
|
|
|
2262
2268
|
this.clientList.find((obj) => {
|
|
2263
2269
|
if (obj.clientId === headerFilters.client) {
|
|
2264
2270
|
this.selectedClient = obj;
|
|
2265
|
-
this.gs.
|
|
2271
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2266
2272
|
this.cd.detectChanges();
|
|
2267
2273
|
}
|
|
2268
2274
|
});
|
|
@@ -2270,7 +2276,7 @@ class DateSingleSelectComponent {
|
|
|
2270
2276
|
else {
|
|
2271
2277
|
this.selectedClient = this.clientList[0];
|
|
2272
2278
|
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2273
|
-
this.gs.
|
|
2279
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2274
2280
|
this.cd.detectChanges();
|
|
2275
2281
|
}
|
|
2276
2282
|
}
|
|
@@ -2288,7 +2294,7 @@ class DateSingleSelectComponent {
|
|
|
2288
2294
|
}
|
|
2289
2295
|
});
|
|
2290
2296
|
}
|
|
2291
|
-
this.gs.
|
|
2297
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2292
2298
|
this.selectedFilters.client = headerFilters.client;
|
|
2293
2299
|
this.selectedFilters.clients = [headerFilters.clients];
|
|
2294
2300
|
this.selectedFilters.date = headerFilters.date;
|
|
@@ -2302,7 +2308,7 @@ class DateSingleSelectComponent {
|
|
|
2302
2308
|
}
|
|
2303
2309
|
onClientSelect(event) {
|
|
2304
2310
|
this.selectedClient = event;
|
|
2305
|
-
this.gs.
|
|
2311
|
+
this.gs.selectedClient.next(this.selectedClient);
|
|
2306
2312
|
this.cd.detectChanges();
|
|
2307
2313
|
}
|
|
2308
2314
|
ranges = {
|
|
@@ -2357,7 +2363,7 @@ class DateSingleSelectComponent {
|
|
|
2357
2363
|
this.selectedFilters = headerFilters;
|
|
2358
2364
|
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2359
2365
|
this.selectedFilters.date = this.selectedDateRange;
|
|
2360
|
-
this.gs.
|
|
2366
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2361
2367
|
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
2362
2368
|
}
|
|
2363
2369
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DateSingleSelectComponent, deps: [{ token: AuthService }, { token: GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -2388,60 +2394,49 @@ class SingleStoreComponent {
|
|
|
2388
2394
|
this.auth = auth;
|
|
2389
2395
|
this.gs = gs;
|
|
2390
2396
|
this.cd = cd;
|
|
2391
|
-
this.auth.getStores().subscribe({
|
|
2392
|
-
next: (e) => {
|
|
2393
|
-
if (e) {
|
|
2394
|
-
this.storeList = e.data.result;
|
|
2395
|
-
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
2396
|
-
this.cd.detectChanges();
|
|
2397
|
-
if (headerFilters.store) {
|
|
2398
|
-
this.storeList.find((obj) => {
|
|
2399
|
-
if (obj.storeId === headerFilters.store) {
|
|
2400
|
-
this.selectedClient = obj;
|
|
2401
|
-
this.gs.apply(this.selectedFilters);
|
|
2402
|
-
this.cd.detectChanges();
|
|
2403
|
-
}
|
|
2404
|
-
});
|
|
2405
|
-
}
|
|
2406
|
-
else {
|
|
2407
|
-
this.selectedClient = this.storeList[0];
|
|
2408
|
-
this.selectedFilters.store = this.selectedClient.storeId;
|
|
2409
|
-
// console.log(this.selectedFilters)
|
|
2410
|
-
this.gs.apply(this.selectedFilters);
|
|
2411
|
-
this.cd.detectChanges();
|
|
2412
|
-
}
|
|
2413
|
-
}
|
|
2414
|
-
},
|
|
2415
|
-
});
|
|
2416
2397
|
}
|
|
2417
2398
|
ngOnInit() {
|
|
2418
|
-
|
|
2419
|
-
|
|
2420
|
-
this.
|
|
2421
|
-
|
|
2422
|
-
|
|
2423
|
-
|
|
2424
|
-
|
|
2399
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
2400
|
+
if (headerFilters?.client) {
|
|
2401
|
+
this.auth.getStores(headerFilters?.client).subscribe({
|
|
2402
|
+
next: (e) => {
|
|
2403
|
+
if (e) {
|
|
2404
|
+
this.storeList = e.data.result;
|
|
2405
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
2406
|
+
this.cd.detectChanges();
|
|
2407
|
+
if (headerFilters.store) {
|
|
2408
|
+
this.storeList.find((obj) => {
|
|
2409
|
+
if (obj.storeId === headerFilters.store) {
|
|
2410
|
+
this.selectedClient = obj;
|
|
2411
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2412
|
+
}
|
|
2413
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2414
|
+
this.selectedFilters.store = headerFilters.store;
|
|
2415
|
+
this.selectedFilters.client = headerFilters.client;
|
|
2416
|
+
this.selectedFilters.clients = [headerFilters.clients];
|
|
2417
|
+
this.selectedFilters.date = headerFilters.date;
|
|
2418
|
+
this.selectedDateRange.startDate = headerFilters.date.startDate;
|
|
2419
|
+
this.selectedDateRange.endDate = headerFilters.date.endDate;
|
|
2420
|
+
this.cd.detectChanges();
|
|
2421
|
+
});
|
|
2422
|
+
}
|
|
2423
|
+
else {
|
|
2424
|
+
this.selectedClient = this.storeList[0];
|
|
2425
|
+
this.selectedFilters.store = this.selectedClient.storeId;
|
|
2426
|
+
this.selectedDateRange.startDate = this.dayjs().format('YYYY-MM-DD');
|
|
2427
|
+
this.selectedDateRange.endDate = this.dayjs().format('YYYY-MM-DD');
|
|
2428
|
+
this.selectedFilters.date = this.selectedDateRange;
|
|
2429
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2430
|
+
this.cd.detectChanges();
|
|
2431
|
+
}
|
|
2425
2432
|
}
|
|
2426
|
-
}
|
|
2427
|
-
}
|
|
2428
|
-
this.gs.apply(this.selectedFilters);
|
|
2429
|
-
this.selectedFilters.store = headerFilters.store;
|
|
2430
|
-
this.selectedFilters.client = headerFilters.client;
|
|
2431
|
-
this.selectedFilters.clients = [headerFilters.clients];
|
|
2432
|
-
this.selectedFilters.date = headerFilters.date;
|
|
2433
|
-
this.selectedDateRange.startDate = headerFilters.date.startDate;
|
|
2434
|
-
this.selectedDateRange.endDate = headerFilters.date.endDate;
|
|
2435
|
-
this.cd.detectChanges();
|
|
2436
|
-
}
|
|
2437
|
-
else {
|
|
2438
|
-
this.selectedDateRange.startDate = this.dayjs().format('MM-DD-YYYY');
|
|
2439
|
-
this.selectedDateRange.endDate = this.dayjs().format('MM-DD-YYYY');
|
|
2433
|
+
},
|
|
2434
|
+
});
|
|
2440
2435
|
}
|
|
2441
2436
|
}
|
|
2442
2437
|
onClientSelect(event) {
|
|
2443
2438
|
this.selectedClient = event;
|
|
2444
|
-
this.gs.
|
|
2439
|
+
this.gs.selectedClient.next(this.selectedClient);
|
|
2445
2440
|
}
|
|
2446
2441
|
ranges = {
|
|
2447
2442
|
'Today': [this.dayjs(), this.dayjs()],
|
|
@@ -2466,8 +2461,8 @@ class SingleStoreComponent {
|
|
|
2466
2461
|
if (event && event.startDate && event.endDate) {
|
|
2467
2462
|
if (this.dayjs(event.startDate).isValid() && this.dayjs(event.endDate).isValid()) {
|
|
2468
2463
|
// Dates are valid, proceed with formatting
|
|
2469
|
-
this.selectedDateRange.startDate = this.dayjs(event.startDate).utc().format('
|
|
2470
|
-
this.selectedDateRange.endDate = this.dayjs(event.endDate).utc().format('
|
|
2464
|
+
this.selectedDateRange.startDate = this.dayjs(event.startDate).utc().format('YYYY-MM-DD');
|
|
2465
|
+
this.selectedDateRange.endDate = this.dayjs(event.endDate).utc().format('YYYY-MM-DD');
|
|
2471
2466
|
}
|
|
2472
2467
|
else {
|
|
2473
2468
|
// Dates are not valid, handle the scenario accordingly
|
|
@@ -2494,7 +2489,7 @@ class SingleStoreComponent {
|
|
|
2494
2489
|
this.selectedFilters = headerFilters;
|
|
2495
2490
|
this.selectedFilters.store = this.selectedClient.storeId;
|
|
2496
2491
|
this.selectedFilters.date = this.selectedDateRange;
|
|
2497
|
-
this.gs.
|
|
2492
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2498
2493
|
localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
|
|
2499
2494
|
this.cd.detectChanges();
|
|
2500
2495
|
}
|