tango-app-ui-shared 3.0.5 → 3.0.6

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 (28) hide show
  1. package/esm2022/lib/interceptors/http-auth-interceptor.mjs +17 -5
  2. package/esm2022/lib/modules/common/custom-select/custom-select.component.mjs +2 -2
  3. package/esm2022/lib/modules/common/pagination/pagination.component.mjs +2 -2
  4. package/esm2022/lib/modules/layout/layout.module.mjs +12 -3
  5. package/esm2022/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.mjs +19 -8
  6. package/esm2022/lib/modules/layout/sidebar/sidebar.component.mjs +4 -3
  7. package/esm2022/lib/modules/layout/toolbar/classic/classic.component.mjs +103 -79
  8. package/esm2022/lib/modules/layout/toolbar/client-settings/client-settings.component.mjs +38 -9
  9. package/esm2022/lib/modules/layout/toolbar/date-single-select/date-single-select.component.mjs +140 -0
  10. package/esm2022/lib/modules/layout/toolbar/datepicker/datepicker.component.mjs +106 -0
  11. package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +141 -0
  12. package/esm2022/lib/modules/layout/toolbar/toolbar.component.mjs +91 -30
  13. package/esm2022/lib/routes/route-wraper-modules/ticket-wrapper.module.mjs +1 -1
  14. package/esm2022/lib/services/auth.service.mjs +8 -1
  15. package/fesm2022/tango-app-ui-shared-ticket-wrapper.module-BLrWsK0B.mjs.map +1 -1
  16. package/fesm2022/tango-app-ui-shared.mjs +1038 -535
  17. package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
  18. package/lib/interceptors/http-auth-interceptor.d.ts +4 -1
  19. package/lib/modules/layout/layout.module.d.ts +13 -10
  20. package/lib/modules/layout/sidebar/sidebar-footer/sidebar-footer.component.d.ts +6 -1
  21. package/lib/modules/layout/toolbar/classic/classic.component.d.ts +9 -8
  22. package/lib/modules/layout/toolbar/client-settings/client-settings.component.d.ts +3 -2
  23. package/lib/modules/layout/toolbar/date-single-select/date-single-select.component.d.ts +25 -0
  24. package/lib/modules/layout/toolbar/datepicker/datepicker.component.d.ts +25 -0
  25. package/lib/modules/layout/toolbar/single-store/single-store.component.d.ts +25 -0
  26. package/lib/modules/layout/toolbar/toolbar.component.d.ts +15 -6
  27. package/lib/services/auth.service.d.ts +2 -0
  28. package/package.json +1 -1
@@ -1,7 +1,7 @@
1
1
  import { Component } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
- import * as i1 from "../../../../services/auth.service";
4
- import * as i2 from "../../../../services/global-state.service";
3
+ import * as i1 from "projects/tango-app-shared/src/lib/services/auth.service";
4
+ import * as i2 from "projects/tango-app-shared/src/lib/services/global-state.service";
5
5
  import * as i3 from "../../../common/custom-select/custom-select.component";
6
6
  export class ClientSettingsComponent {
7
7
  auth;
@@ -9,6 +9,13 @@ export class ClientSettingsComponent {
9
9
  cd;
10
10
  clientList = [];
11
11
  selectedClient;
12
+ selectedFilters = {
13
+ client: null,
14
+ clients: [],
15
+ store: null,
16
+ stores: [],
17
+ date: null,
18
+ };
12
19
  constructor(auth, gs, cd) {
13
20
  this.auth = auth;
14
21
  this.gs = gs;
@@ -17,22 +24,44 @@ export class ClientSettingsComponent {
17
24
  next: (e) => {
18
25
  if (e) {
19
26
  this.clientList = e.data.result;
20
- this.selectedClient = this.clientList[0];
21
- this.gs.selectedClient.next(this.selectedClient);
22
- this.cd.detectChanges();
27
+ if ("header-filters" in localStorage) {
28
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
29
+ this.cd.detectChanges();
30
+ if (headerFilters.client) {
31
+ this.clientList.find((obj) => {
32
+ if (obj.clientId === headerFilters.client) {
33
+ this.selectedClient = obj;
34
+ }
35
+ });
36
+ }
37
+ else {
38
+ this.selectedClient = this.clientList[0];
39
+ this.gs.selectedClient.next(this.selectedClient);
40
+ this.cd.detectChanges();
41
+ }
42
+ this.selectedFilters.client = headerFilters.client;
43
+ this.gs.dataRangeValue.next(this.selectedFilters);
44
+ }
23
45
  }
24
- }
46
+ else {
47
+ }
48
+ },
25
49
  });
26
50
  }
27
51
  onClientSelect(event) {
28
52
  this.selectedClient = event;
29
53
  this.gs.selectedClient.next(this.selectedClient);
54
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
55
+ this.selectedFilters = headerFilters;
56
+ this.selectedFilters.client = this.selectedClient.clientId;
57
+ this.gs.dataRangeValue.next(this.selectedFilters);
58
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
30
59
  }
31
60
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ClientSettingsComponent, deps: [{ token: i1.AuthService }, { token: i2.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
32
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: ClientSettingsComponent, selector: "lib-client-settings", ngImport: i0, template: " <div class=\"wrapper\" >\r\n <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'brandName'\" [disabled]=\"false\" [idField]=\"'_id'\"\r\n (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n </div>\r\n", styles: [".wrapper{min-width:200px}\n"], dependencies: [{ kind: "component", type: i3.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }] });
61
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: ClientSettingsComponent, selector: "lib-client-settings", ngImport: i0, template: " <div class=\"wrapper\" >\r\n <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n </div>\r\n", styles: [".wrapper{min-width:200px}\n"], dependencies: [{ kind: "component", type: i3.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }] });
33
62
  }
34
63
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: ClientSettingsComponent, decorators: [{
35
64
  type: Component,
36
- args: [{ selector: 'lib-client-settings', template: " <div class=\"wrapper\" >\r\n <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'brandName'\" [disabled]=\"false\" [idField]=\"'_id'\"\r\n (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n </div>\r\n", styles: [".wrapper{min-width:200px}\n"] }]
65
+ args: [{ selector: 'lib-client-settings', template: " <div class=\"wrapper\" >\r\n <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\r\n (selected)=\"onClientSelect($event)\" [selectedValues]=\"[selectedClient]\"></lib-select>\r\n </div>\r\n", styles: [".wrapper{min-width:200px}\n"] }]
37
66
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }] });
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LXNldHRpbmdzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWFwcC1zaGFyZWQvc3JjL2xpYi9tb2R1bGVzL2xheW91dC90b29sYmFyL2NsaWVudC1zZXR0aW5ncy9jbGllbnQtc2V0dGluZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL21vZHVsZXMvbGF5b3V0L3Rvb2xiYXIvY2xpZW50LXNldHRpbmdzL2NsaWVudC1zZXR0aW5ncy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFTN0QsTUFBTSxPQUFPLHVCQUF1QjtJQUtkO0lBQTBCO0lBQStCO0lBSDdFLFVBQVUsR0FBTyxFQUFFLENBQUE7SUFDbkIsY0FBYyxDQUFJO0lBRWxCLFlBQW9CLElBQWdCLEVBQVUsRUFBcUIsRUFBVSxFQUFvQjtRQUE3RSxTQUFJLEdBQUosSUFBSSxDQUFZO1FBQVUsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFBVSxPQUFFLEdBQUYsRUFBRSxDQUFrQjtRQUMvRixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFNBQVMsQ0FBQztZQUMvQixJQUFJLEVBQUMsQ0FBQyxDQUFDLEVBQUMsRUFBRTtnQkFDUixJQUFHLENBQUMsRUFBQztvQkFDSCxJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFBO29CQUMvQixJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUE7b0JBQ3hDLElBQUksQ0FBQyxFQUFFLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUE7b0JBQ2hELElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxFQUFFLENBQUE7aUJBQ3hCO1lBQ0gsQ0FBQztTQUNGLENBQUMsQ0FBQTtJQUNKLENBQUM7SUFFRCxjQUFjLENBQUMsS0FBUztRQUN0QixJQUFJLENBQUMsY0FBYyxHQUFHLEtBQUssQ0FBQTtRQUMzQixJQUFJLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFBO0lBQ2xELENBQUM7dUdBckJVLHVCQUF1QjsyRkFBdkIsdUJBQXVCLDJEQ1RwQyxnU0FJQTs7MkZES2EsdUJBQXVCO2tCQUxuQyxTQUFTOytCQUNFLHFCQUFxQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBHbG9iYWxTdGF0ZVNlcnZpY2UgfSBmcm9tICcuLi8uLi8uLi8uLi9zZXJ2aWNlcy9nbG9iYWwtc3RhdGUuc2VydmljZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2xpYi1jbGllbnQtc2V0dGluZ3MnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jbGllbnQtc2V0dGluZ3MuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsOiAnLi9jbGllbnQtc2V0dGluZ3MuY29tcG9uZW50LnNjc3MnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDbGllbnRTZXR0aW5nc0NvbXBvbmVudCB7XHJcblxyXG4gIGNsaWVudExpc3Q6YW55ID0gW11cclxuICBzZWxlY3RlZENsaWVudDphbnlcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoOkF1dGhTZXJ2aWNlLCBwcml2YXRlIGdzOkdsb2JhbFN0YXRlU2VydmljZSwgcHJpdmF0ZSBjZDpDaGFuZ2VEZXRlY3RvclJlZil7XHJcbiAgICB0aGlzLmF1dGguZ2V0Q2xpZW50cygpLnN1YnNjcmliZSh7XHJcbiAgICAgIG5leHQ6KGUpPT57XHJcbiAgICAgICAgaWYoZSl7XHJcbiAgICAgICAgICB0aGlzLmNsaWVudExpc3QgPSBlLmRhdGEucmVzdWx0XHJcbiAgICAgICAgICB0aGlzLnNlbGVjdGVkQ2xpZW50ID0gdGhpcy5jbGllbnRMaXN0WzBdXHJcbiAgICAgICAgICB0aGlzLmdzLnNlbGVjdGVkQ2xpZW50Lm5leHQodGhpcy5zZWxlY3RlZENsaWVudClcclxuICAgICAgICAgIHRoaXMuY2QuZGV0ZWN0Q2hhbmdlcygpXHJcbiAgICAgICAgfVxyXG4gICAgICB9XHJcbiAgICB9KVxyXG4gIH1cclxuXHJcbiAgb25DbGllbnRTZWxlY3QoZXZlbnQ6YW55KXtcclxuICAgIHRoaXMuc2VsZWN0ZWRDbGllbnQgPSBldmVudFxyXG4gICAgdGhpcy5ncy5zZWxlY3RlZENsaWVudC5uZXh0KHRoaXMuc2VsZWN0ZWRDbGllbnQpXHJcbiAgfVxyXG5cclxufVxyXG4iLCIgICAgPGRpdiBjbGFzcz1cIndyYXBwZXJcIiA+XHJcbiAgICAgICAgPGxpYi1zZWxlY3QgW2l0ZW1zXT1cImNsaWVudExpc3RcIiBbbXVsdGldPVwiZmFsc2VcIiBbc2VhcmNoRmllbGRdPVwiJ2JyYW5kTmFtZSdcIiBbZGlzYWJsZWRdPVwiZmFsc2VcIiBbaWRGaWVsZF09XCInX2lkJ1wiXHJcbiAgICAgICAgICAgIChzZWxlY3RlZCk9XCJvbkNsaWVudFNlbGVjdCgkZXZlbnQpXCIgW3NlbGVjdGVkVmFsdWVzXT1cIltzZWxlY3RlZENsaWVudF1cIj48L2xpYi1zZWxlY3Q+XHJcbiAgICA8L2Rpdj5cclxuIl19
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpZW50LXNldHRpbmdzLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3RhbmdvLWFwcC1zaGFyZWQvc3JjL2xpYi9tb2R1bGVzL2xheW91dC90b29sYmFyL2NsaWVudC1zZXR0aW5ncy9jbGllbnQtc2V0dGluZ3MuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvdGFuZ28tYXBwLXNoYXJlZC9zcmMvbGliL21vZHVsZXMvbGF5b3V0L3Rvb2xiYXIvY2xpZW50LXNldHRpbmdzL2NsaWVudC1zZXR0aW5ncy5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXFCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFTN0QsTUFBTSxPQUFPLHVCQUF1QjtJQVlkO0lBQTBCO0lBQStCO0lBVjdFLFVBQVUsR0FBTyxFQUFFLENBQUE7SUFDbkIsY0FBYyxDQUFJO0lBQ2xCLGVBQWUsR0FBUTtRQUNyQixNQUFNLEVBQUUsSUFBSTtRQUNaLE9BQU8sRUFBRSxFQUFFO1FBQ1gsS0FBSyxFQUFFLElBQUk7UUFDWCxNQUFNLEVBQUUsRUFBRTtRQUNWLElBQUksRUFBRSxJQUFJO0tBRVgsQ0FBQztJQUNGLFlBQW9CLElBQWdCLEVBQVUsRUFBcUIsRUFBVSxFQUFvQjtRQUE3RSxTQUFJLEdBQUosSUFBSSxDQUFZO1FBQVUsT0FBRSxHQUFGLEVBQUUsQ0FBbUI7UUFBVSxPQUFFLEdBQUYsRUFBRSxDQUFrQjtRQUMvRixJQUFJLENBQUMsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDLFNBQVMsQ0FBQztZQUMvQixJQUFJLEVBQUUsQ0FBQyxDQUFDLEVBQUUsRUFBRTtnQkFDVixJQUFJLENBQUMsRUFBRTtvQkFDTCxJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDO29CQUNoQyxJQUFJLGdCQUFnQixJQUFJLFlBQVksRUFBRTt3QkFDdEMsTUFBTSxhQUFhLEdBQVEsSUFBSSxDQUFDLEtBQUssQ0FDbkMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFJLElBQUksQ0FDL0MsQ0FBQzt3QkFDRixJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxDQUFDO3dCQUN4QixJQUFJLGFBQWEsQ0FBQyxNQUFNLEVBQUU7NEJBQ3hCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsR0FBUSxFQUFFLEVBQUU7Z0NBQ2hDLElBQUksR0FBRyxDQUFDLFFBQVEsS0FBSyxhQUFhLENBQUMsTUFBTSxFQUFFO29DQUN6QyxJQUFJLENBQUMsY0FBYyxHQUFHLEdBQUcsQ0FBQztpQ0FFM0I7NEJBQ0gsQ0FBQyxDQUFDLENBQUM7eUJBQ0o7NkJBQU07NEJBQ0wsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDOzRCQUN6QyxJQUFJLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxDQUFDOzRCQUNqRCxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsRUFBRSxDQUFDO3lCQUN6Qjt3QkFDRCxJQUFJLENBQUMsZUFBZSxDQUFDLE1BQU0sR0FBRyxhQUFhLENBQUMsTUFBTSxDQUFDO3dCQUNuRCxJQUFJLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDO3FCQUNuRDtpQkFDRjtxQkFBSztpQkFDTDtZQUNELENBQUM7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsY0FBYyxDQUFDLEtBQVM7UUFDdEIsSUFBSSxDQUFDLGNBQWMsR0FBRyxLQUFLLENBQUE7UUFDM0IsSUFBSSxDQUFDLEVBQUUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUMsQ0FBQTtRQUNoRCxNQUFNLGFBQWEsR0FBUSxJQUFJLENBQUMsS0FBSyxDQUNuQyxZQUFZLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLElBQUksSUFBSSxDQUMvQyxDQUFDO1FBQ0YsSUFBSSxDQUFDLGVBQWUsR0FBRyxhQUFhLENBQUM7UUFDckMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUM7UUFDM0QsSUFBSSxDQUFDLEVBQUUsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxlQUFlLENBQUMsQ0FBQztRQUNsRCxZQUFZLENBQUMsT0FBTyxDQUFDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUM7SUFDL0UsQ0FBQzt1R0FyRFUsdUJBQXVCOzJGQUF2Qix1QkFBdUIsMkRDVHBDLHNTQUlBOzsyRkRLYSx1QkFBdUI7a0JBTG5DLFNBQVM7K0JBQ0UscUJBQXFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBHbG9iYWxTdGF0ZVNlcnZpY2UgfSBmcm9tICdwcm9qZWN0cy90YW5nby1hcHAtc2hhcmVkL3NyYy9saWIvc2VydmljZXMvZ2xvYmFsLXN0YXRlLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBBdXRoU2VydmljZSB9IGZyb20gJ3Byb2plY3RzL3RhbmdvLWFwcC1zaGFyZWQvc3JjL2xpYi9zZXJ2aWNlcy9hdXRoLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdsaWItY2xpZW50LXNldHRpbmdzJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2xpZW50LXNldHRpbmdzLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybDogJy4vY2xpZW50LXNldHRpbmdzLmNvbXBvbmVudC5zY3NzJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2xpZW50U2V0dGluZ3NDb21wb25lbnQge1xyXG5cclxuICBjbGllbnRMaXN0OmFueSA9IFtdXHJcbiAgc2VsZWN0ZWRDbGllbnQ6YW55XHJcbiAgc2VsZWN0ZWRGaWx0ZXJzOiBhbnkgPSB7XHJcbiAgICBjbGllbnQ6IG51bGwsXHJcbiAgICBjbGllbnRzOiBbXSxcclxuICAgIHN0b3JlOiBudWxsLFxyXG4gICAgc3RvcmVzOiBbXSxcclxuICAgIGRhdGU6IG51bGwsXHJcblxyXG4gIH07XHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBhdXRoOkF1dGhTZXJ2aWNlLCBwcml2YXRlIGdzOkdsb2JhbFN0YXRlU2VydmljZSwgcHJpdmF0ZSBjZDpDaGFuZ2VEZXRlY3RvclJlZil7XHJcbiAgICB0aGlzLmF1dGguZ2V0Q2xpZW50cygpLnN1YnNjcmliZSh7XHJcbiAgICAgIG5leHQ6IChlKSA9PiB7XHJcbiAgICAgICAgaWYgKGUpIHtcclxuICAgICAgICAgIHRoaXMuY2xpZW50TGlzdCA9IGUuZGF0YS5yZXN1bHQ7XHJcbiAgICAgICAgICBpZiAoXCJoZWFkZXItZmlsdGVyc1wiIGluIGxvY2FsU3RvcmFnZSkge1xyXG4gICAgICAgICAgY29uc3QgaGVhZGVyRmlsdGVyczogYW55ID0gSlNPTi5wYXJzZShcclxuICAgICAgICAgICAgbG9jYWxTdG9yYWdlLmdldEl0ZW0oXCJoZWFkZXItZmlsdGVyc1wiKSB8fCBcInt9XCJcclxuICAgICAgICAgICk7XHJcbiAgICAgICAgICB0aGlzLmNkLmRldGVjdENoYW5nZXMoKTtcclxuICAgICAgICAgIGlmIChoZWFkZXJGaWx0ZXJzLmNsaWVudCkge1xyXG4gICAgICAgICAgICB0aGlzLmNsaWVudExpc3QuZmluZCgob2JqOiBhbnkpID0+IHtcclxuICAgICAgICAgICAgICBpZiAob2JqLmNsaWVudElkID09PSBoZWFkZXJGaWx0ZXJzLmNsaWVudCkge1xyXG4gICAgICAgICAgICAgICAgdGhpcy5zZWxlY3RlZENsaWVudCA9IG9iajtcclxuICAgICAgICAgICAgICAgXHJcbiAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICAgIH0gZWxzZSB7XHJcbiAgICAgICAgICAgIHRoaXMuc2VsZWN0ZWRDbGllbnQgPSB0aGlzLmNsaWVudExpc3RbMF07XHJcbiAgICAgICAgICAgIHRoaXMuZ3Muc2VsZWN0ZWRDbGllbnQubmV4dCh0aGlzLnNlbGVjdGVkQ2xpZW50KTtcclxuICAgICAgICAgICAgdGhpcy5jZC5kZXRlY3RDaGFuZ2VzKCk7XHJcbiAgICAgICAgICB9XHJcbiAgICAgICAgICB0aGlzLnNlbGVjdGVkRmlsdGVycy5jbGllbnQgPSBoZWFkZXJGaWx0ZXJzLmNsaWVudDtcclxuICAgICAgICAgIHRoaXMuZ3MuZGF0YVJhbmdlVmFsdWUubmV4dCh0aGlzLnNlbGVjdGVkRmlsdGVycyk7XHJcbiAgICAgICAgfVxyXG4gICAgICB9IGVsc2V7ICAgICAgICBcclxuICAgICAgfVxyXG4gICAgICB9LFxyXG4gICAgfSk7XHJcbiAgfVxyXG5cclxuICBvbkNsaWVudFNlbGVjdChldmVudDphbnkpe1xyXG4gICAgdGhpcy5zZWxlY3RlZENsaWVudCA9IGV2ZW50XHJcbiAgICB0aGlzLmdzLnNlbGVjdGVkQ2xpZW50Lm5leHQodGhpcy5zZWxlY3RlZENsaWVudClcclxuICAgIGNvbnN0IGhlYWRlckZpbHRlcnM6IGFueSA9IEpTT04ucGFyc2UoXHJcbiAgICAgIGxvY2FsU3RvcmFnZS5nZXRJdGVtKFwiaGVhZGVyLWZpbHRlcnNcIikgfHwgXCJ7fVwiXHJcbiAgICApO1xyXG4gICAgdGhpcy5zZWxlY3RlZEZpbHRlcnMgPSBoZWFkZXJGaWx0ZXJzO1xyXG4gICAgdGhpcy5zZWxlY3RlZEZpbHRlcnMuY2xpZW50ID0gdGhpcy5zZWxlY3RlZENsaWVudC5jbGllbnRJZDtcclxuICAgIHRoaXMuZ3MuZGF0YVJhbmdlVmFsdWUubmV4dCh0aGlzLnNlbGVjdGVkRmlsdGVycyk7XHJcbiAgICBsb2NhbFN0b3JhZ2Uuc2V0SXRlbSgnaGVhZGVyLWZpbHRlcnMnLCBKU09OLnN0cmluZ2lmeSh0aGlzLnNlbGVjdGVkRmlsdGVycykpO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiICAgIDxkaXYgY2xhc3M9XCJ3cmFwcGVyXCIgPlxyXG4gICAgICAgIDxsaWItc2VsZWN0IFtpdGVtc109XCJjbGllbnRMaXN0XCIgW211bHRpXT1cImZhbHNlXCIgW3NlYXJjaEZpZWxkXT1cIidjbGllbnROYW1lJ1wiIFtkaXNhYmxlZF09XCJmYWxzZVwiIFtpZEZpZWxkXT1cIidjbGllbnRJZCdcIlxyXG4gICAgICAgICAgICAoc2VsZWN0ZWQpPVwib25DbGllbnRTZWxlY3QoJGV2ZW50KVwiIFtzZWxlY3RlZFZhbHVlc109XCJbc2VsZWN0ZWRDbGllbnRdXCI+PC9saWItc2VsZWN0PlxyXG4gICAgPC9kaXY+XHJcbiJdfQ==
@@ -0,0 +1,140 @@
1
+ import { Component } from '@angular/core';
2
+ import * as dayjs from 'dayjs';
3
+ import 'dayjs/locale/en';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "projects/tango-app-shared/src/lib/services/auth.service";
6
+ import * as i2 from "projects/tango-app-shared/src/lib/services/global-state.service";
7
+ import * as i3 from "../../../common/custom-select/custom-select.component";
8
+ import * as i4 from "@angular/forms";
9
+ import * as i5 from "ngx-daterangepicker-material";
10
+ export class DateSingleSelectComponent {
11
+ auth;
12
+ gs;
13
+ cd;
14
+ isCustomDate;
15
+ selectedDateRange = {};
16
+ clientList = [];
17
+ selectedClient;
18
+ selectedFilters = {
19
+ client: null,
20
+ clients: [],
21
+ store: null,
22
+ stores: [],
23
+ date: null,
24
+ };
25
+ constructor(auth, gs, cd) {
26
+ this.auth = auth;
27
+ this.gs = gs;
28
+ this.cd = cd;
29
+ this.auth.getClients().subscribe({
30
+ next: (e) => {
31
+ if (e) {
32
+ this.clientList = e.data.result;
33
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
34
+ this.cd.detectChanges();
35
+ if (headerFilters.client) {
36
+ this.clientList.find((obj) => {
37
+ if (obj.clientId === headerFilters.client) {
38
+ this.selectedClient = obj;
39
+ this.gs.dataRangeValue.next(this.selectedFilters);
40
+ }
41
+ });
42
+ }
43
+ else {
44
+ this.selectedClient = this.clientList[0];
45
+ this.gs.selectedClient.next(this.selectedClient);
46
+ this.cd.detectChanges();
47
+ }
48
+ }
49
+ },
50
+ });
51
+ }
52
+ ngOnInit() {
53
+ if ("header-filters" in localStorage) {
54
+ const headerFilters = JSON.parse(localStorage.getItem('header-filters') || '{}');
55
+ this.cd.detectChanges();
56
+ if (headerFilters.client) {
57
+ this.clientList.find((obj) => {
58
+ if (obj.clientId === headerFilters.client) {
59
+ this.selectedClient = obj;
60
+ }
61
+ });
62
+ }
63
+ this.gs.dataRangeValue.next(this.selectedFilters);
64
+ this.selectedFilters.client = headerFilters.client;
65
+ this.selectedFilters.clients = [headerFilters.clients];
66
+ this.selectedFilters.date = headerFilters.date;
67
+ this.selectedDateRange.startDate = headerFilters.date.startDate;
68
+ this.selectedDateRange.endDate = headerFilters.date.endDate;
69
+ }
70
+ else {
71
+ this.selectedDateRange.startDate = dayjs().format('MM-DD-YYYY');
72
+ this.selectedDateRange.endDate = dayjs().format('MM-DD-YYYY');
73
+ }
74
+ }
75
+ onClientSelect(event) {
76
+ this.selectedClient = event;
77
+ this.gs.selectedClient.next(this.selectedClient);
78
+ }
79
+ ranges = {
80
+ 'Today': [dayjs(), dayjs()],
81
+ 'Yesterday': [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],
82
+ 'This Week': [dayjs().subtract(6, 'days'), dayjs()],
83
+ 'Last Week': [dayjs().subtract(14, 'days').startOf('days'), dayjs().subtract(8, 'days').endOf('days')],
84
+ 'This Month': [dayjs().startOf('month'), dayjs().endOf('month')],
85
+ 'Last Month': [
86
+ dayjs().subtract(1, 'month').startOf('month'),
87
+ dayjs().subtract(1, 'month').endOf('month')
88
+ ]
89
+ };
90
+ onStartDateChange(event) {
91
+ if (dayjs(event.startDate).isValid()) {
92
+ this.isCustomDate = (m) => {
93
+ const isValidDate = m > dayjs() || m > dayjs(event.startDate.add(90, 'days'));
94
+ return isValidDate ? 'invalid-date' : false;
95
+ };
96
+ }
97
+ }
98
+ datechange(event) {
99
+ if (event && event.startDate && event.endDate) {
100
+ if (dayjs(event.startDate).isValid() && dayjs(event.endDate).isValid()) {
101
+ // Dates are valid, proceed with formatting
102
+ this.selectedDateRange.startDate = dayjs(event.startDate).utc().format('DD-MM-YYYY');
103
+ this.selectedDateRange.endDate = dayjs(event.endDate).utc().format('DD-MM-YYYY');
104
+ }
105
+ else {
106
+ // Dates are not valid, handle the scenario accordingly
107
+ console.error('Invalid dates provided:', event.startDate, event.endDate);
108
+ // If you want to fallback to stored filters when the dates are invalid, you can keep the existing logic
109
+ // const storedFilters = JSON.parse(localStorage.getItem('dateRangeFilters') || '{}');
110
+ // if (storedFilters.startDate && storedFilters.endDate) {
111
+ // this.selectedDateRange.startDate = dayjs(storedFilters.startDate).format('DD-MM-YYYY');
112
+ // this.selectedDateRange.endDate = dayjs(storedFilters.endDate).format('DD-MM-YYYY');
113
+ // }
114
+ }
115
+ }
116
+ else {
117
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
118
+ this.selectedFilters.date = headerFilters.date;
119
+ }
120
+ this.selectedFilters.date = this.selectedDateRange;
121
+ // this.globalService.sendData(JSON.stringify(this.selectedFilters.date));
122
+ // localStorage.setItem('dateRangeFilters', JSON.stringify(this.selectedDateRange));
123
+ // this.globalService.sendData(this.selectedDateRange);
124
+ }
125
+ Apply() {
126
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
127
+ this.selectedFilters = headerFilters;
128
+ this.selectedFilters.client = this.selectedClient.clientId;
129
+ this.selectedFilters.date = this.selectedDateRange;
130
+ this.gs.dataRangeValue.next(this.selectedFilters);
131
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
132
+ }
133
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DateSingleSelectComponent, deps: [{ token: i1.AuthService }, { token: i2.GlobalStateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
134
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: DateSingleSelectComponent, selector: "lib-date-single-select", ngImport: i0, template: "<div class=\"wrapper mx-2\" >\r\n <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\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}\n"], dependencies: [{ kind: "component", type: i3.CustomSelectComponent, selector: "lib-select", inputs: ["items", "searchField", "multi", "idField", "selectedValues", "disabled", "label"], outputs: ["selected"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.DaterangepickerDirective, selector: "input[ngxDaterangepickerMd]", inputs: ["minDate", "maxDate", "autoApply", "alwaysShowCalendars", "showCustomRangeLabel", "linkedCalendars", "dateLimit", "singleDatePicker", "showWeekNumbers", "showISOWeekNumbers", "showDropdowns", "isInvalidDate", "isCustomDate", "isTooltipDate", "showClearButton", "customRangeDirection", "ranges", "opens", "drops", "firstMonthDayClass", "lastMonthDayClass", "emptyWeekRowClass", "emptyWeekColumnClass", "firstDayOfNextMonthClass", "lastDayOfPreviousMonthClass", "keepCalendarOpeningWithRange", "showRangeLabelOnInput", "showCancel", "lockStartDate", "timePicker", "timePicker24Hour", "timePickerIncrement", "timePickerSeconds", "closeOnAutoApply", "endKeyHolder", "startKey", "locale", "endKey"], outputs: ["change", "rangeClicked", "datesUpdated", "startDateChanged", "endDateChanged", "clearClicked"] }] });
135
+ }
136
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DateSingleSelectComponent, decorators: [{
137
+ type: Component,
138
+ args: [{ selector: 'lib-date-single-select', template: "<div class=\"wrapper mx-2\" >\r\n <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\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}\n"] }]
139
+ }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }] });
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-single-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/date-single-select/date-single-select.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/date-single-select/date-single-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnInit } from '@angular/core';\r\nimport { GlobalStateService } from 'projects/tango-app-shared/src/lib/services/global-state.service';\r\nimport { AuthService } from 'projects/tango-app-shared/src/lib/services/auth.service';\r\nimport * as dayjs from 'dayjs';\r\nimport 'dayjs/locale/en';\r\n@Component({\r\n  selector: 'lib-date-single-select',\r\n  templateUrl: './date-single-select.component.html',\r\n  styleUrl: './date-single-select.component.scss'\r\n})\r\nexport class DateSingleSelectComponent implements OnInit {\r\n  isCustomDate: (m: dayjs.Dayjs) => false | \"invalid-date\";\r\n  selectedDateRange: any = {};\r\n  clientList: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.getClients().subscribe({\r\n      next: (e) => {\r\n        if (e) {\r\n          this.clientList = 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.client) {\r\n            this.clientList.find((obj: any) => {\r\n              if (obj.clientId === headerFilters.client) {\r\n                this.selectedClient = obj;\r\n                this.gs.dataRangeValue.next(this.selectedFilters);\r\n              }\r\n            });\r\n          } else {\r\n            this.selectedClient = this.clientList[0];\r\n            this.gs.selectedClient.next(this.selectedClient);\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.client){\r\n      this.clientList.find((obj: any) => {\r\n        if (obj.clientId === headerFilters.client) {\r\n          this.selectedClient = obj;\r\n        \r\n        }\r\n      });\r\n    }\r\n    \r\n      this.gs.dataRangeValue.next(this.selectedFilters);\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    } else {\r\n     \r\n      this.selectedDateRange.startDate = dayjs().format('MM-DD-YYYY');\r\n      this.selectedDateRange.endDate = 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.selectedClient.next(this.selectedClient)\r\n \r\n  }\r\n\r\n  ranges: any = {\r\n    'Today': [dayjs(), dayjs()],\r\n    'Yesterday': [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],\r\n    'This Week': [dayjs().subtract(6, 'days'), dayjs()],\r\n    'Last Week': [dayjs().subtract(14, 'days').startOf('days'), dayjs().subtract(8, 'days').endOf('days')],\r\n    'This Month': [dayjs().startOf('month'), dayjs().endOf('month')],\r\n    'Last Month': [\r\n      dayjs().subtract(1, 'month').startOf('month'),\r\n      dayjs().subtract(1, 'month').endOf('month')\r\n    ]\r\n  };\r\n\r\n  onStartDateChange(event:any){\r\n    if(dayjs(event.startDate).isValid()){\r\n      this.isCustomDate = (m: dayjs.Dayjs) => {        \r\n      const isValidDate = m > dayjs() || m > 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 (dayjs(event.startDate).isValid() && dayjs(event.endDate).isValid()) {\r\n      // Dates are valid, proceed with formatting\r\n      this.selectedDateRange.startDate = dayjs(event.startDate).utc().format('DD-MM-YYYY');\r\n      this.selectedDateRange.endDate = 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.client = this.selectedClient.clientId;\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}\r\n}\r\n","<div class=\"wrapper mx-2\" >\r\n    <lib-select [items]=\"clientList\" [multi]=\"false\" [searchField]=\"'clientName'\" [disabled]=\"false\" [idField]=\"'clientId'\"\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"]}
@@ -0,0 +1,106 @@
1
+ import { Component } from '@angular/core';
2
+ import * as dayjs from 'dayjs';
3
+ import 'dayjs/locale/en';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "tango-app-ui-metronics";
6
+ import * as i2 from "projects/tango-app-shared/src/lib/services/global-state.service";
7
+ import * as i3 from "projects/tango-app-shared/src/lib/services/auth.service";
8
+ import * as i4 from "@angular/forms";
9
+ import * as i5 from "ngx-daterangepicker-material";
10
+ export class DatepickerComponent {
11
+ layout;
12
+ gs;
13
+ service;
14
+ cd;
15
+ unsubscribe = [];
16
+ isCustomDate;
17
+ selectedDateRange = {};
18
+ selectedFilters = {
19
+ client: null,
20
+ clients: [],
21
+ store: null,
22
+ stores: [],
23
+ date: null,
24
+ };
25
+ constructor(layout, gs, service, cd) {
26
+ this.layout = layout;
27
+ this.gs = gs;
28
+ this.service = service;
29
+ this.cd = cd;
30
+ }
31
+ ngOnDestroy() {
32
+ this.unsubscribe.forEach((sb) => sb.unsubscribe());
33
+ }
34
+ ngOnInit() {
35
+ if ("header-filters" in localStorage) {
36
+ const headerFilters = JSON.parse(localStorage.getItem('header-filters') || '{}');
37
+ // if (headerFilters.date) {
38
+ this.selectedFilters.date = headerFilters.date;
39
+ this.selectedDateRange.startDate = headerFilters.date.startDate;
40
+ this.selectedDateRange.endDate = headerFilters.date.endDate;
41
+ // this.gs.dataRangeValue.next(this.selectedFilters);
42
+ this.cd.detectChanges();
43
+ // }
44
+ }
45
+ else {
46
+ this.selectedDateRange.startDate = dayjs().format("MM-DD-YYYY");
47
+ this.selectedDateRange.endDate = dayjs().format("MM-DD-YYYY");
48
+ }
49
+ }
50
+ ranges = {
51
+ 'Today': [dayjs(), dayjs()],
52
+ 'Yesterday': [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],
53
+ 'This Week': [dayjs().subtract(6, 'days'), dayjs()],
54
+ 'Last Week': [dayjs().subtract(14, 'days').startOf('days'), dayjs().subtract(8, 'days').endOf('days')],
55
+ 'This Month': [dayjs().startOf('month'), dayjs().endOf('month')],
56
+ 'Last Month': [
57
+ dayjs().subtract(1, 'month').startOf('month'),
58
+ dayjs().subtract(1, 'month').endOf('month')
59
+ ]
60
+ };
61
+ onStartDateChange(event) {
62
+ if (dayjs(event.startDate).isValid()) {
63
+ this.isCustomDate = (m) => {
64
+ const isValidDate = m > dayjs() || m > dayjs(event.startDate.add(90, 'days'));
65
+ return isValidDate ? 'invalid-date' : false;
66
+ };
67
+ }
68
+ }
69
+ datechange(event) {
70
+ // debugger
71
+ if (event && event.startDate && event.endDate) {
72
+ if (dayjs(event.startDate).isValid() && dayjs(event.endDate).isValid()) {
73
+ // Dates are valid, proceed with formatting
74
+ this.selectedDateRange.startDate = dayjs(event.startDate).utc().format('DD-MM-YYYY');
75
+ this.selectedDateRange.endDate = dayjs(event.endDate).utc().format('DD-MM-YYYY');
76
+ }
77
+ else {
78
+ // Dates are not valid, handle the scenario accordingly
79
+ console.error('Invalid dates provided:', event.startDate, event.endDate);
80
+ // If you want to fallback to stored filters when the dates are invalid, you can keep the existing logic
81
+ const storedFilters = JSON.parse(localStorage.getItem('header-filters') || '{}');
82
+ if (storedFilters.startDate && storedFilters.endDate) {
83
+ this.selectedDateRange.startDate = dayjs(storedFilters.startDate).format('DD-MM-YYYY');
84
+ this.selectedDateRange.endDate = dayjs(storedFilters.endDate).format('DD-MM-YYYY');
85
+ }
86
+ }
87
+ }
88
+ else {
89
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
90
+ this.selectedFilters.date = headerFilters.date;
91
+ }
92
+ const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
93
+ this.selectedFilters = headerFilters;
94
+ this.gs.dataRangeValue.next(this.selectedFilters);
95
+ this.selectedFilters.date = this.selectedDateRange;
96
+ localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));
97
+ // this.globalService.sendData(this.selectedDateRange);
98
+ }
99
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DatepickerComponent, deps: [{ token: i1.LayoutService }, { token: i2.GlobalStateService }, { token: i3.AuthService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
100
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: DatepickerComponent, selector: "lib-datepicker", ngImport: i0, template: "<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>", 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}\n"], dependencies: [{ kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i5.DaterangepickerDirective, selector: "input[ngxDaterangepickerMd]", inputs: ["minDate", "maxDate", "autoApply", "alwaysShowCalendars", "showCustomRangeLabel", "linkedCalendars", "dateLimit", "singleDatePicker", "showWeekNumbers", "showISOWeekNumbers", "showDropdowns", "isInvalidDate", "isCustomDate", "isTooltipDate", "showClearButton", "customRangeDirection", "ranges", "opens", "drops", "firstMonthDayClass", "lastMonthDayClass", "emptyWeekRowClass", "emptyWeekColumnClass", "firstDayOfNextMonthClass", "lastDayOfPreviousMonthClass", "keepCalendarOpeningWithRange", "showRangeLabelOnInput", "showCancel", "lockStartDate", "timePicker", "timePicker24Hour", "timePickerIncrement", "timePickerSeconds", "closeOnAutoApply", "endKeyHolder", "startKey", "locale", "endKey"], outputs: ["change", "rangeClicked", "datesUpdated", "startDateChanged", "endDateChanged", "clearClicked"] }] });
101
+ }
102
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: DatepickerComponent, decorators: [{
103
+ type: Component,
104
+ args: [{ selector: 'lib-datepicker', template: "<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>", 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}\n"] }]
105
+ }], ctorParameters: () => [{ type: i1.LayoutService }, { type: i2.GlobalStateService }, { type: i3.AuthService }, { type: i0.ChangeDetectorRef }] });
106
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.component.js","sourceRoot":"","sources":["../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/datepicker/datepicker.component.ts","../../../../../../../../projects/tango-app-shared/src/lib/modules/layout/toolbar/datepicker/datepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, Component, OnDestroy, OnInit } from '@angular/core';\r\nimport * as dayjs from 'dayjs';\r\nimport 'dayjs/locale/en';\r\nimport utc from 'dayjs/plugin/utc';\r\nimport timezone from 'dayjs/plugin/timezone';\r\nimport { GlobalStateService } from 'projects/tango-app-shared/src/lib/services/global-state.service';\r\nimport { LayoutService } from 'tango-app-ui-metronics';\r\nimport { AuthService } from 'projects/tango-app-shared/src/lib/services/auth.service';\r\nimport { Subscription } from 'rxjs';\r\n@Component({\r\n  selector: 'lib-datepicker',\r\n  templateUrl: './datepicker.component.html',\r\n  styleUrl: './datepicker.component.scss'\r\n})\r\nexport class DatepickerComponent implements OnDestroy,OnInit {\r\n  private unsubscribe: Subscription[] = [];\r\n  isCustomDate: (m: dayjs.Dayjs) => false | \"invalid-date\";\r\n  selectedDateRange: 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 layout: LayoutService,private gs: GlobalStateService,private service:AuthService,private cd:ChangeDetectorRef) {}\r\n\r\n  ngOnDestroy() {\r\n    this.unsubscribe.forEach((sb) => sb.unsubscribe());\r\n  }\r\n\r\n  ngOnInit(): void {\r\n   if(\"header-filters\" in localStorage){\r\n      const headerFilters: any = JSON.parse(\r\n        localStorage.getItem('header-filters') || '{}'\r\n      );\r\n     \r\n      // if (headerFilters.date) {\r\n    \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.gs.dataRangeValue.next(this.selectedFilters);\r\n        this.cd.detectChanges()\r\n    // } \r\n    }  else{\r\n      this.selectedDateRange.startDate = dayjs().format(\"MM-DD-YYYY\");\r\n      this.selectedDateRange.endDate = dayjs().format(\"MM-DD-YYYY\");\r\n    }\r\n  }\r\n\r\n  ranges: any = {\r\n    'Today': [dayjs(), dayjs()],\r\n    'Yesterday': [dayjs().subtract(1, 'days'), dayjs().subtract(1, 'days')],\r\n    'This Week': [dayjs().subtract(6, 'days'), dayjs()],\r\n    'Last Week': [dayjs().subtract(14, 'days').startOf('days'), dayjs().subtract(8, 'days').endOf('days')],\r\n    'This Month': [dayjs().startOf('month'), dayjs().endOf('month')],\r\n    'Last Month': [\r\n      dayjs().subtract(1, 'month').startOf('month'),\r\n      dayjs().subtract(1, 'month').endOf('month')\r\n    ]\r\n  };\r\n\r\n  onStartDateChange(event:any){\r\n    if(dayjs(event.startDate).isValid()){\r\n      this.isCustomDate = (m: dayjs.Dayjs) => {        \r\n      const isValidDate = m > dayjs() || m > 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  // debugger\r\n  if (event && event.startDate && event.endDate) {\r\n    if (dayjs(event.startDate).isValid() && dayjs(event.endDate).isValid()) {\r\n      // Dates are valid, proceed with formatting\r\n      this.selectedDateRange.startDate = dayjs(event.startDate).utc().format('DD-MM-YYYY');\r\n      this.selectedDateRange.endDate = 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('header-filters') || '{}');\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  const headerFilters: any = JSON.parse(\r\n    localStorage.getItem(\"header-filters\") || \"{}\"\r\n    \r\n  );\r\n  this.selectedFilters = headerFilters;\r\n  this.gs.dataRangeValue.next(this.selectedFilters);\r\n  this.selectedFilters.date = this.selectedDateRange;\r\n  localStorage.setItem('header-filters', JSON.stringify(this.selectedFilters));\r\n  // this.globalService.sendData(this.selectedDateRange);\r\n}\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n\r\n}\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>"]}