tango-app-ui-shared 3.0.20-dev → 3.0.21-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/common/filters/filters.component.mjs +37 -45
- package/esm2022/lib/modules/layout/toolbar/client-settings/client-settings.component.mjs +26 -11
- package/esm2022/lib/modules/layout/toolbar/date-single-select/date-single-select.component.mjs +2 -1
- package/esm2022/lib/modules/layout/toolbar/single-store/single-store.component.mjs +2 -1
- package/fesm2022/tango-app-ui-shared.mjs +63 -54
- package/fesm2022/tango-app-ui-shared.mjs.map +1 -1
- package/lib/modules/common/filters/filters.component.d.ts +9 -5
- package/lib/modules/layout/toolbar/client-settings/client-settings.component.d.ts +2 -2
- package/package.json +1 -1
|
@@ -57,6 +57,7 @@ export class SingleStoreComponent {
|
|
|
57
57
|
this.selectedDateRange.startDate = this.dayjs().format('YYYY-MM-DD');
|
|
58
58
|
this.selectedDateRange.endDate = this.dayjs().format('YYYY-MM-DD');
|
|
59
59
|
this.selectedFilters.date = this.selectedDateRange;
|
|
60
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
60
61
|
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
61
62
|
this.cd.detectChanges();
|
|
62
63
|
}
|
|
@@ -117,4 +118,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImpor
|
|
|
117
118
|
type: Component,
|
|
118
119
|
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"] }]
|
|
119
120
|
}], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.GlobalStateService }, { type: i0.ChangeDetectorRef }] });
|
|
120
|
-
//# 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\nimport  dayjs from 'dayjs';\r\nimport 'dayjs/locale/en';\r\nimport { GlobalStateService } from \"../../../../services/global-state.service\";\r\nimport { AuthService } from \"../../../../services/auth.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          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              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.gs.dataRangeValue.next(this.selectedFilters);\r\n              this.cd.detectChanges();\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  }\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      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    }\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}\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}\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"]}
|
|
121
|
+
//# 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\nimport  dayjs from 'dayjs';\r\nimport 'dayjs/locale/en';\r\nimport { GlobalStateService } from \"../../../../services/global-state.service\";\r\nimport { AuthService } from \"../../../../services/auth.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          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              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.gs.dataRangeValue.next(this.selectedFilters);\r\n              this.cd.detectChanges();\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            localStorage.setItem(\r\n              \"header-filters\",\r\n              JSON.stringify(this.selectedFilters)\r\n            );\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  }\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      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    }\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}\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}\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"]}
|
|
@@ -2091,24 +2091,39 @@ class ClientSettingsComponent {
|
|
|
2091
2091
|
next: (e) => {
|
|
2092
2092
|
if (e) {
|
|
2093
2093
|
this.clientList = e.data.result;
|
|
2094
|
-
|
|
2095
|
-
|
|
2096
|
-
|
|
2097
|
-
|
|
2098
|
-
|
|
2099
|
-
|
|
2100
|
-
|
|
2101
|
-
|
|
2102
|
-
|
|
2094
|
+
if ("header-filters" in localStorage) {
|
|
2095
|
+
const headerFilters = JSON.parse(localStorage.getItem("header-filters") || "{}");
|
|
2096
|
+
this.cd.detectChanges();
|
|
2097
|
+
if (headerFilters.client) {
|
|
2098
|
+
this.clientList.find((obj) => {
|
|
2099
|
+
if (obj.clientId === headerFilters.client) {
|
|
2100
|
+
this.selectedClient = obj;
|
|
2101
|
+
}
|
|
2102
|
+
});
|
|
2103
|
+
}
|
|
2104
|
+
else {
|
|
2105
|
+
this.selectedClient = this.clientList[0];
|
|
2106
|
+
this.selectedFilters.client = headerFilters.client;
|
|
2107
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
2108
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2109
|
+
this.cd.detectChanges();
|
|
2110
|
+
}
|
|
2103
2111
|
}
|
|
2104
2112
|
else {
|
|
2105
2113
|
this.selectedClient = this.clientList[0];
|
|
2106
|
-
this.selectedFilters.client =
|
|
2114
|
+
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2107
2115
|
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
2108
2116
|
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2109
2117
|
this.cd.detectChanges();
|
|
2110
2118
|
}
|
|
2111
2119
|
}
|
|
2120
|
+
else {
|
|
2121
|
+
this.selectedClient = this.clientList[0];
|
|
2122
|
+
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2123
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
2124
|
+
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2125
|
+
this.cd.detectChanges();
|
|
2126
|
+
}
|
|
2112
2127
|
},
|
|
2113
2128
|
});
|
|
2114
2129
|
}
|
|
@@ -2265,6 +2280,7 @@ class DateSingleSelectComponent {
|
|
|
2265
2280
|
this.dayjs().format("YYYY-MM-DD");
|
|
2266
2281
|
this.selectedDateRange.endDate = this.dayjs().format("YYYY-MM-DD");
|
|
2267
2282
|
this.selectedFilters.client = this.selectedClient.clientId;
|
|
2283
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
2268
2284
|
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2269
2285
|
this.cd.detectChanges();
|
|
2270
2286
|
}
|
|
@@ -2392,6 +2408,7 @@ class SingleStoreComponent {
|
|
|
2392
2408
|
this.selectedDateRange.startDate = this.dayjs().format('YYYY-MM-DD');
|
|
2393
2409
|
this.selectedDateRange.endDate = this.dayjs().format('YYYY-MM-DD');
|
|
2394
2410
|
this.selectedFilters.date = this.selectedDateRange;
|
|
2411
|
+
localStorage.setItem("header-filters", JSON.stringify(this.selectedFilters));
|
|
2395
2412
|
this.gs.dataRangeValue.next(this.selectedFilters);
|
|
2396
2413
|
this.cd.detectChanges();
|
|
2397
2414
|
}
|
|
@@ -3366,18 +3383,19 @@ class FiltersComponent {
|
|
|
3366
3383
|
dataObject = [];
|
|
3367
3384
|
appliedFilters = new EventEmitter();
|
|
3368
3385
|
Opendropdown = false;
|
|
3369
|
-
permission = [
|
|
3370
|
-
{ group: 'Super Admin', description: 'Lorem ipsum dolor sit amet, consectetur ' },
|
|
3371
|
-
{ group: 'Admin', description: 'Lorem ipsum dolor sit amet, consectetur ' },
|
|
3372
|
-
{ group: 'User', description: 'Lorem ipsum dolor sit amet, consectetur ' },
|
|
3373
|
-
];
|
|
3374
3386
|
showdropdown;
|
|
3375
3387
|
selectedValues = [];
|
|
3388
|
+
searchTerms = [];
|
|
3376
3389
|
selectedValuesArray = [];
|
|
3377
3390
|
searchValue;
|
|
3391
|
+
selectedItem;
|
|
3392
|
+
dropDown = false;
|
|
3378
3393
|
dummyArray = [];
|
|
3379
3394
|
noFilter = false;
|
|
3380
3395
|
responseArray = [];
|
|
3396
|
+
productModule;
|
|
3397
|
+
product;
|
|
3398
|
+
selectedProductCount;
|
|
3381
3399
|
constructor(elementRef, renderer, router) {
|
|
3382
3400
|
this.elementRef = elementRef;
|
|
3383
3401
|
this.renderer = renderer;
|
|
@@ -3398,6 +3416,18 @@ class FiltersComponent {
|
|
|
3398
3416
|
this.dummyArray = JSON.parse(JSON.stringify(this.dataObject));
|
|
3399
3417
|
this.responseArray = JSON.parse(JSON.stringify(this.dataObject));
|
|
3400
3418
|
}
|
|
3419
|
+
selectItem(event, index, subIndex) {
|
|
3420
|
+
this.selectedValuesArray[index] = this.dataObject[index].Issues[subIndex];
|
|
3421
|
+
}
|
|
3422
|
+
openDropdown(event, index) {
|
|
3423
|
+
event.stopPropagation();
|
|
3424
|
+
this.dataObject.forEach((item, i) => {
|
|
3425
|
+
if (i !== index) {
|
|
3426
|
+
item.isOpen = false; // Close other dropdowns
|
|
3427
|
+
}
|
|
3428
|
+
});
|
|
3429
|
+
this.dataObject[index].isOpen = !this.dataObject[index].isOpen;
|
|
3430
|
+
}
|
|
3401
3431
|
opendropdown(e) {
|
|
3402
3432
|
console.log(687);
|
|
3403
3433
|
e.stopPropagation();
|
|
@@ -3411,42 +3441,34 @@ class FiltersComponent {
|
|
|
3411
3441
|
}
|
|
3412
3442
|
});
|
|
3413
3443
|
this.dataObject[index].isOpen = !this.dataObject[index].isOpen;
|
|
3414
|
-
// if (this.dataObject[index].isOpen) {
|
|
3415
|
-
// document.addEventListener('click', this.clickOutsideDropdownContent.bind(this, index));
|
|
3416
|
-
// } else {
|
|
3417
|
-
// document.removeEventListener('click', this.clickOutsideDropdownContent.bind(this, index));
|
|
3418
|
-
// }
|
|
3419
3444
|
}
|
|
3420
|
-
|
|
3421
|
-
// if (!this.elementRef.nativeElement.contains(event.target as Node)) {
|
|
3422
|
-
// this.dataObject[index].isOpen = false;
|
|
3423
|
-
// document.removeEventListener('click', this.clickOutsideDropdownContent.bind(this, index));
|
|
3424
|
-
// }
|
|
3425
|
-
// }
|
|
3426
|
-
toggleCheckbox(issue, index) {
|
|
3445
|
+
toggleCheckbox(event, issue, index, subIndex) {
|
|
3427
3446
|
const currentIssues = this.dataObject[index].Issues;
|
|
3428
3447
|
this.selectedValuesArray[index] = this.selectedValuesArray[index] || [];
|
|
3429
3448
|
const selectedValues = this.selectedValuesArray[index]; // Retrieve selected values array for the current dropdown index
|
|
3449
|
+
console.log('selectedValues', selectedValues);
|
|
3430
3450
|
if (issue === 'Select All') {
|
|
3431
|
-
const
|
|
3432
|
-
|
|
3433
|
-
|
|
3434
|
-
|
|
3451
|
+
const checkedState = event.target.checked;
|
|
3452
|
+
this.dataObject[index].Issues.forEach((item) => {
|
|
3453
|
+
item.checked = checkedState;
|
|
3454
|
+
});
|
|
3455
|
+
if (checkedState) {
|
|
3456
|
+
this.selectedValuesArray[index] = currentIssues.slice(); // Copy all items
|
|
3435
3457
|
}
|
|
3436
3458
|
else {
|
|
3437
|
-
//
|
|
3438
|
-
this.selectedValuesArray[index] = [...currentIssues];
|
|
3459
|
+
this.selectedValuesArray[index] = []; // Deselect all items
|
|
3439
3460
|
}
|
|
3440
3461
|
}
|
|
3441
3462
|
else {
|
|
3442
|
-
|
|
3443
|
-
|
|
3463
|
+
this.dataObject[index].Issues[subIndex].checked = event.target.checked;
|
|
3464
|
+
let checkedData = this.dataObject[index].Issues[subIndex];
|
|
3465
|
+
if (this.dataObject[index].Issues[subIndex].checked) {
|
|
3466
|
+
this.selectedValuesArray[index].push(checkedData);
|
|
3444
3467
|
}
|
|
3445
3468
|
else {
|
|
3446
|
-
this.selectedValuesArray[index].
|
|
3469
|
+
this.selectedValuesArray[index] = this.selectedValuesArray[index].filter((el) => el?.checked === true);
|
|
3447
3470
|
}
|
|
3448
3471
|
}
|
|
3449
|
-
// Update "Select All" checkbox status based on selected values
|
|
3450
3472
|
const selectAllId = `selectall${index}`;
|
|
3451
3473
|
const selectAllElement = document.getElementById(selectAllId);
|
|
3452
3474
|
if (selectAllElement) {
|
|
@@ -3467,7 +3489,8 @@ class FiltersComponent {
|
|
|
3467
3489
|
this.Opendropdown = false;
|
|
3468
3490
|
}
|
|
3469
3491
|
searchData(event, i) {
|
|
3470
|
-
const
|
|
3492
|
+
const searchTerm = event.target.value.trim(); // Trim whitespace
|
|
3493
|
+
const filteredIssues = this.dummyArray[i].Issues.filter((item) => new RegExp(searchTerm, 'i').test(item.text));
|
|
3471
3494
|
this.dataObject[i].Issues = filteredIssues;
|
|
3472
3495
|
if (filteredIssues.length) {
|
|
3473
3496
|
this.noFilter = false;
|
|
@@ -3477,32 +3500,18 @@ class FiltersComponent {
|
|
|
3477
3500
|
}
|
|
3478
3501
|
}
|
|
3479
3502
|
Apply() {
|
|
3480
|
-
for (let i = 0; i < this.selectedValuesArray.length; i++) {
|
|
3481
|
-
const selectedValues = this.selectedValuesArray[i];
|
|
3482
|
-
const issues = this.dataObject[i].Issues;
|
|
3483
|
-
if (selectedValues) {
|
|
3484
|
-
this.selectedValuesArray[i] = selectedValues.map((selectedId) => {
|
|
3485
|
-
const issue = issues.find((issueItem) => issueItem.text === selectedId);
|
|
3486
|
-
return issue ? issue : ''; // Get the text corresponding to the id
|
|
3487
|
-
});
|
|
3488
|
-
}
|
|
3489
|
-
}
|
|
3490
3503
|
this.Opendropdown = false;
|
|
3491
|
-
this.selectedValuesArray.forEach((item, index) => {
|
|
3492
|
-
item = item.map((ele) => ele.id);
|
|
3493
|
-
this.selectedValuesArray[index] = item;
|
|
3494
|
-
});
|
|
3495
3504
|
this.responseArray.forEach((item, index) => {
|
|
3496
3505
|
item.Issues = this.selectedValuesArray[index] ? this.selectedValuesArray[index] : [];
|
|
3497
3506
|
});
|
|
3498
3507
|
this.appliedFilters.emit(this.responseArray);
|
|
3499
3508
|
}
|
|
3500
3509
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FiltersComponent, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1$1.Router }], target: i0.ɵɵFactoryTarget.Component });
|
|
3501
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FiltersComponent, selector: "lib-filters", inputs: { dataObject: "dataObject" }, outputs: { appliedFilters: "appliedFilters" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"position-relative\">\r\n
|
|
3510
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: FiltersComponent, selector: "lib-filters", inputs: { dataObject: "dataObject" }, outputs: { appliedFilters: "appliedFilters" }, host: { listeners: { "document:click": "onClick($event)" } }, ngImport: i0, template: "<div class=\"position-relative\">\r\n \r\n <button type=\"button\" (click)=\"opendropdown($event)\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg\r\n class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Filter</span> </button>\r\n <div class=\"card p-5 dropdown1 position-absolute\" *ngIf=\"Opendropdown\">\r\n <span class=\"dropdown-title\">Filter Options</span>\r\n <div class=\"w-100 border border-gray mt-3\"></div>\r\n <div class=\"py-3\" *ngFor=\"let item of dataObject; let i = index\">\r\n <div *ngIf=\"item.type !== 'single'\">\r\n <div class=\"dropdown form-select position-relative d-flex justify-content-between\" (click)=\"Dropdown(item.Description,i,$event)\">\r\n <!-- <span class=\"\">{{ selectedValuesArray[i]?.length !== null && selectedValuesArray[i]?.length !== undefined ? selectedValuesArray[i]?.length + ' ' + item.Description.split(' ').pop() + ' Selected' : item.Description }}</span> -->\r\n <span>{{item.Description}}</span> <span *ngIf=\"selectedValuesArray[i]?.length !== null && selectedValuesArray[i]?.length !== undefined && selectedValuesArray[i]?.length !== 0\" class=\"badge badge-light-default\">{{selectedValuesArray[i]?.length}}</span>\r\n </div>\r\n <div *ngIf=\"item.isOpen\" class=\"dropdown-content position-absolute w-100\">\r\n <div class=\"form-check d-flex align-items-center py-3 pt-3 ps-0\">\r\n <input class=\"form-check-input\" type=\"checkbox\" value=\"Select All\" id=\"selectall{{i}}\" [checked]=\"selectedValuesArray[i]?.length === item.Issues.length\"\r\n (change)=\"toggleCheckbox($event,'Select All', i,0)\">\r\n <label class=\"form-check-label px-2\" for=\"selectall{{i}}\">\r\n Select All\r\n </label>\r\n </div>\r\n \r\n <div class=\"border border-gray mt-3 \"></div>\r\n \r\n <div class=\"mt-3 d-flex align-items-center\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3 mt-2\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </span>\r\n <input type=\"text\" [(ngModel)]=\"dataObject[i].selectedValue\" (input)=\"searchData($event,i)\" [id]=\"i\" class=\"form-control searchinput ps-14 py-2 me-2 mt-2\"\r\n placeholder=\"Search\" autocomplete=\"off\" />\r\n </div>\r\n \r\n <div *ngFor=\"let issue of item.Issues;let j=index\" class=\"form-check d-flex align-items-center py-3 pt-3 ps-0 mt-2\">\r\n <input class=\"form-check-input\" type=\"checkbox\" [value]=\"issue.text\" id=\"option{{issue.text}}\" [checked]=\"issue.checked\"\r\n (change)=\"toggleCheckbox($event,issue.text,i,j)\">\r\n <label class=\"form-check-label px-2\" for=\"option{{issue.text}}\">\r\n {{ issue.text }}\r\n </label>\r\n </div>\r\n <div class=\"mt-5 d-flex justify-content-center\">\r\n <span class=\"form-check-label\" *ngIf=\"noFilter\"> No filters available</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"item.type === 'single'\" class=\"position-relative w-100\">\r\n <button type=\"button\" (click)=\"openDropdown($event,i)\"\r\n class=\"btn btn-default w-100 btn-outline btn-outline-default rounded-3 text-nowrap border-val d-flex justify-content-between\"> {{selectedValuesArray[i]?.text ? selectedValuesArray[i]?.text : item.Description}}\r\n <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M5 7.5L10 12.5L15 7.5\" stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </button>\r\n <div *ngIf=\"item.isOpen\" class=\"card py-1 w-100 dropdown-single position-absolute z-1 top-50px end-0\">\r\n <ul *ngFor=\"let item of item.Issues; let j = index\" class=\"list-unstyled\">\r\n <li [ngClass]=\"selectedValuesArray[i]?.text == item.text ? 'active' : ''\" class=\"camera px-5 items fw-semibold cursor-pointer py-2\" (click)=\"selectItem($event,i,j)\">{{item.text}}</li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div role=\"group\" class=\"d-flex justify-content-between\">\r\n <button class=\"btn btn-outline w-100 me-2\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-100 ms-2\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n </div>\r\n</div>", styles: [".dropdown1{position:absolute;top:70px;min-width:270px!important}.dropdown1 .dropdown-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.dropdown1 .dropdown{position:relative;display:inline-block}.dropdown1 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.dropdown1 .dropdown-content{width:90%!important;z-index:1;padding:10px;background-color:#fff;border-radius:8px;box-shadow:0 8px 16px #0003;height:200px;overflow:auto}.dropdown1 .dropdown-content label{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px;text-transform:capitalize}.dropdown1 .items:hover,.dropdown1 .tems.focus,.dropdown1 .items.active,.dropdown1 .camera.focus-visible{background:var(--Gray-50, #F9FAFB)}.dropdown1 .dropdown-content a{color:#000;padding:12px 16px;text-decoration:none;display:block}.dropdown1 .dropdown button{padding:10px;font-size:16px;cursor:pointer}.dropdown1 input[type=checkbox]{width:16px!important;height:16px!important;margin:-3px 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}.dropdown1 input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}.dropdown1 input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }] });
|
|
3502
3511
|
}
|
|
3503
3512
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: FiltersComponent, decorators: [{
|
|
3504
3513
|
type: Component,
|
|
3505
|
-
args: [{ selector: 'lib-filters', template: "<div class=\"position-relative\">\r\n
|
|
3514
|
+
args: [{ selector: 'lib-filters', template: "<div class=\"position-relative\">\r\n \r\n <button type=\"button\" (click)=\"opendropdown($event)\"\r\n class=\"btn btn-default mx-2 btn-outline btn-outline-default rounded-3 text-nowrap border-val\"><svg\r\n class=\"pl-3\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\r\n <path d=\"M5 10H15M2.5 5H17.5M7.5 15H12.5\" stroke=\"#344054\" stroke-width=\"2\"\r\n stroke-linecap=\"round\" stroke-linejoin=\"round\" />\r\n </svg>\r\n <span class=\"ms-2\">Filter</span> </button>\r\n <div class=\"card p-5 dropdown1 position-absolute\" *ngIf=\"Opendropdown\">\r\n <span class=\"dropdown-title\">Filter Options</span>\r\n <div class=\"w-100 border border-gray mt-3\"></div>\r\n <div class=\"py-3\" *ngFor=\"let item of dataObject; let i = index\">\r\n <div *ngIf=\"item.type !== 'single'\">\r\n <div class=\"dropdown form-select position-relative d-flex justify-content-between\" (click)=\"Dropdown(item.Description,i,$event)\">\r\n <!-- <span class=\"\">{{ selectedValuesArray[i]?.length !== null && selectedValuesArray[i]?.length !== undefined ? selectedValuesArray[i]?.length + ' ' + item.Description.split(' ').pop() + ' Selected' : item.Description }}</span> -->\r\n <span>{{item.Description}}</span> <span *ngIf=\"selectedValuesArray[i]?.length !== null && selectedValuesArray[i]?.length !== undefined && selectedValuesArray[i]?.length !== 0\" class=\"badge badge-light-default\">{{selectedValuesArray[i]?.length}}</span>\r\n </div>\r\n <div *ngIf=\"item.isOpen\" class=\"dropdown-content position-absolute w-100\">\r\n <div class=\"form-check d-flex align-items-center py-3 pt-3 ps-0\">\r\n <input class=\"form-check-input\" type=\"checkbox\" value=\"Select All\" id=\"selectall{{i}}\" [checked]=\"selectedValuesArray[i]?.length === item.Issues.length\"\r\n (change)=\"toggleCheckbox($event,'Select All', i,0)\">\r\n <label class=\"form-check-label px-2\" for=\"selectall{{i}}\">\r\n Select All\r\n </label>\r\n </div>\r\n \r\n <div class=\"border border-gray mt-3 \"></div>\r\n \r\n <div class=\"mt-3 d-flex align-items-center\">\r\n <span class=\"svg-icon svg-icon-1 position-absolute ms-3 mt-2\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"16\" height=\"17\" viewBox=\"0 0 16 17\" fill=\"none\">\r\n <path d=\"M14 14.5L11.1 11.6M12.6667 7.83333C12.6667 10.7789 10.2789 13.1667 7.33333 13.1667C4.38781 13.1667 2 10.7789 2 7.83333C2 4.88781 4.38781 2.5 7.33333 2.5C10.2789 2.5 12.6667 4.88781 12.6667 7.83333Z\" stroke=\"#667085\" stroke-width=\"1.3\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg>\r\n </span>\r\n <input type=\"text\" [(ngModel)]=\"dataObject[i].selectedValue\" (input)=\"searchData($event,i)\" [id]=\"i\" class=\"form-control searchinput ps-14 py-2 me-2 mt-2\"\r\n placeholder=\"Search\" autocomplete=\"off\" />\r\n </div>\r\n \r\n <div *ngFor=\"let issue of item.Issues;let j=index\" class=\"form-check d-flex align-items-center py-3 pt-3 ps-0 mt-2\">\r\n <input class=\"form-check-input\" type=\"checkbox\" [value]=\"issue.text\" id=\"option{{issue.text}}\" [checked]=\"issue.checked\"\r\n (change)=\"toggleCheckbox($event,issue.text,i,j)\">\r\n <label class=\"form-check-label px-2\" for=\"option{{issue.text}}\">\r\n {{ issue.text }}\r\n </label>\r\n </div>\r\n <div class=\"mt-5 d-flex justify-content-center\">\r\n <span class=\"form-check-label\" *ngIf=\"noFilter\"> No filters available</span>\r\n </div>\r\n </div>\r\n </div>\r\n <div *ngIf=\"item.type === 'single'\" class=\"position-relative w-100\">\r\n <button type=\"button\" (click)=\"openDropdown($event,i)\"\r\n class=\"btn btn-default w-100 btn-outline btn-outline-default rounded-3 text-nowrap border-val d-flex justify-content-between\"> {{selectedValuesArray[i]?.text ? selectedValuesArray[i]?.text : item.Description}}\r\n <span><svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 20 20\" fill=\"none\">\r\n <path d=\"M5 7.5L10 12.5L15 7.5\" stroke=\"#667085\" stroke-width=\"1.66667\" stroke-linecap=\"round\" stroke-linejoin=\"round\"/>\r\n </svg></span>\r\n </button>\r\n <div *ngIf=\"item.isOpen\" class=\"card py-1 w-100 dropdown-single position-absolute z-1 top-50px end-0\">\r\n <ul *ngFor=\"let item of item.Issues; let j = index\" class=\"list-unstyled\">\r\n <li [ngClass]=\"selectedValuesArray[i]?.text == item.text ? 'active' : ''\" class=\"camera px-5 items fw-semibold cursor-pointer py-2\" (click)=\"selectItem($event,i,j)\">{{item.text}}</li>\r\n </ul>\r\n </div>\r\n </div>\r\n </div>\r\n <div role=\"group\" class=\"d-flex justify-content-between\">\r\n <button class=\"btn btn-outline w-100 me-2\" (click)=\"Reset()\"> Reset </button>\r\n <button class=\"btn btn-primary w-100 ms-2\" (click)=\"Apply()\">Apply</button>\r\n </div>\r\n </div>\r\n</div>", styles: [".dropdown1{position:absolute;top:70px;min-width:270px!important}.dropdown1 .dropdown-title{color:var(--Gray-900, #101828);font-size:16px;font-weight:600;line-height:24px}.dropdown1 .dropdown{position:relative;display:inline-block}.dropdown1 .dropdown span{color:var(--Gray-700, #344054);font-size:14px;font-weight:600;line-height:20px}.dropdown1 .dropdown-content{width:90%!important;z-index:1;padding:10px;background-color:#fff;border-radius:8px;box-shadow:0 8px 16px #0003;height:200px;overflow:auto}.dropdown1 .dropdown-content label{color:var(--Gray-700, #344054);font-size:14px;font-weight:500;line-height:20px;text-transform:capitalize}.dropdown1 .items:hover,.dropdown1 .tems.focus,.dropdown1 .items.active,.dropdown1 .camera.focus-visible{background:var(--Gray-50, #F9FAFB)}.dropdown1 .dropdown-content a{color:#000;padding:12px 16px;text-decoration:none;display:block}.dropdown1 .dropdown button{padding:10px;font-size:16px;cursor:pointer}.dropdown1 input[type=checkbox]{width:16px!important;height:16px!important;margin:-3px 5px;border-radius:4px!important;-webkit-appearance:none;-moz-appearance:none;-o-appearance:none;appearance:none;outline:1px solid var(--gray-300, #D0D5DD);box-shadow:none;font-size:.8em;text-align:center;line-height:1em;background:#fff}.dropdown1 input[type=checkbox]:checked{outline:1px solid var(--primary-600, #00A3FF);background-color:var(--primary-50, #EAF8FF)}.dropdown1 input[type=checkbox]:checked:after{content:\"\";transform:rotate(45deg);border-bottom:2px solid #00A3FF;border-right:2px solid #00A3FF;display:inline-block;width:.2em;padding-left:0;padding-top:9px;padding-right:4px}\n"] }]
|
|
3506
3515
|
}], ctorParameters: () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1$1.Router }], propDecorators: { dataObject: [{
|
|
3507
3516
|
type: Input
|
|
3508
3517
|
}], appliedFilters: [{
|