tango-app-ui-shared 3.0.70-dev → 3.0.71-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.
@@ -75,6 +75,12 @@ export class FiltersComponent {
75
75
  this.dataObject[index].isOpen = !this.dataObject[index].isOpen;
76
76
  }
77
77
  toggleCheckbox(event, issue, index, subIndex) {
78
+ if (!this.selectedValuesArray.length) {
79
+ this.dataObject.forEach((item) => {
80
+ let selectedList = item?.Issues.filter((data) => data?.checked);
81
+ this.selectedValuesArray.push(selectedList);
82
+ });
83
+ }
78
84
  const currentIssues = this.dataObject[index].Issues;
79
85
  this.selectedValuesArray[index] = this.selectedValuesArray[index];
80
86
  const selectedValues = this.selectedValuesArray[index]; // Retrieve selected values array for the current dropdown index
@@ -170,4 +176,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
170
176
  type: HostListener,
171
177
  args: ['document:click', ['$event']]
172
178
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-app-shared/src/lib/modules/common/filters/filters.component.ts","../../../../../../../projects/tango-app-shared/src/lib/modules/common/filters/filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, Renderer2,ChangeDetectorRef } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\n \r\n@Component({\r\n  selector: 'lib-filters',\r\n  templateUrl: './filters.component.html',\r\n  styleUrl: './filters.component.scss'\r\n})\r\nexport class FiltersComponent implements OnInit {\r\n  @Input() dataObject: any[] = [];\r\n  @Output() appliedFilters = new EventEmitter()\r\n  Opendropdown: boolean = false;\r\n \r\n  showdropdown: any;\r\n  selectedValues: string[] = [];\r\n  searchTerms: string[] = [];\r\n  selectedValuesArray: any[] = [];\r\n  searchValue:any;\r\n  selectedItem:any;\r\n  dropDown: boolean = false;\r\n  dummyArray:any[] = [];\r\n  noFilter:boolean = false;\r\n  responseArray:any[] = []\r\n  productModule: any;\r\n  product: any;\r\n  selectedProductCount: string;\r\n  constructor(private elementRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    private router: Router,\r\n  private cd:ChangeDetectorRef) {\r\n     }\r\n \r\n  @HostListener('document:click', ['$event'])\r\n  onClick (event: MouseEvent) {\r\n    const\r\n      target = event.target as HTMLElement;\r\n    if(!target.closest('.dropdown1')) {\r\n      this.Opendropdown = false;\r\n    }\r\n    if(!target.closest('.dropdown-content')){\r\n      this.dataObject.forEach((item: any, i: any) => {\r\n          item.isOpen = false;\r\n        }\r\n      );\r\n    }\r\n  }\r\n \r\n  ngOnInit() {\r\n    this.dataObject.forEach((item:any)=>{\r\n      let selectedList = item?.Issues.filter((data:any)=> data?.checked)\r\n      this.selectedValuesArray.push(selectedList)\r\n    })\r\n    this.dummyArray = JSON.parse(JSON.stringify(this.dataObject))\r\n    this.responseArray = JSON.parse(JSON.stringify(this.dataObject))\r\n  }\r\n \r\n  selectItem(event:any,index:any,subIndex:any){\r\n    this.selectedValuesArray[index] = this.dataObject[index].Issues[subIndex];\r\n  }\r\n\r\n  openDropdown(event:MouseEvent,index:any){\r\n    event.stopPropagation();\r\n    this.dataObject.forEach((item: any, i: any) => {\r\n      if (i !== index) {\r\n        item.isOpen = false; // Close other dropdowns\r\n      }\r\n    });\r\n    this.dataObject[index].isOpen = !this.dataObject[index].isOpen;\r\n  }\r\n \r\n \r\n  opendropdown(e:MouseEvent) {\r\n    e.stopPropagation();\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n \r\n  Dropdown(value: any, index: number,event:MouseEvent) {\r\n    event.stopPropagation();\r\n    this.dataObject.forEach((item: any, i: any) => {\r\n      if (i !== index) {\r\n        item.isOpen = false; // Close other dropdowns\r\n      }\r\n    });\r\n    this.dataObject[index].isOpen = !this.dataObject[index].isOpen;\r\n  }\r\n \r\n  toggleCheckbox(event: any, issue: any, index: number, subIndex: number) {\r\n    const currentIssues = this.dataObject[index].Issues;\r\n    this.selectedValuesArray[index] = this.selectedValuesArray[index];\r\n    const selectedValues = this.selectedValuesArray[index]; // Retrieve selected values array for the current dropdown index\r\n    if (issue === 'Select All') {\r\n      const checkedState = event.target.checked;\r\n      this.dataObject[index].Issues.forEach((item: any) => {\r\n        item.checked = checkedState;\r\n      });\r\n\r\n      if (checkedState) {\r\n        this.selectedValuesArray[index] = currentIssues.slice(); // Copy all items\r\n      } else {\r\n        this.selectedValuesArray[index] = []; // Deselect all items\r\n      }\r\n    } else {\r\n      this.dataObject[index].Issues[subIndex].checked = event.target.checked;\r\n      let checkedData = this.dataObject[index].Issues[subIndex];\r\n      \r\n      if(this.dataObject[index].Issues[subIndex].checked){\r\n        this.selectedValuesArray[index].push(checkedData)\r\n      }\r\n      else{\r\n        this.selectedValuesArray[index] = this.selectedValuesArray[index].filter((el:any)=>\r\n          el?.checked === true && el?.text != issue\r\n      )\r\n      }  \r\n\r\n    }\r\n\r\n    const selectAllId = `selectall${index}`;\r\n    const selectAllElement = document.getElementById(selectAllId) as HTMLInputElement;\r\n    if (selectAllElement) {\r\n      selectAllElement.checked = selectedValues.length === currentIssues.length;\r\n    }\r\n \r\n    // Update checkboxes based on selected values\r\n    currentIssues.forEach((item: string) => {\r\n      const isChecked = this.selectedValuesArray[index].includes(item);\r\n      const checkboxId = `option${item}`;\r\n      const checkboxElement = document.getElementById(checkboxId) as HTMLInputElement;\r\n      if (checkboxElement) {\r\n        checkboxElement.checked = isChecked;\r\n      }\r\n    });\r\n   \r\n  }\r\n  Reset() {\r\n    this.selectedValuesArray.forEach((item:any) => {\r\n      if(item?.length){item.forEach((data:any)=>{data.checked = false;})\r\n      }\r\n    })\r\n    this.selectedValuesArray = [];\r\n    this.Opendropdown = false;\r\n    this.responseArray.forEach((item:any,index:any)=>{\r\n      item.Issues = this.selectedValuesArray[index] ? this.selectedValuesArray[index] :[]\r\n   })\r\n   this.appliedFilters.emit(this.responseArray)\r\n  }\r\n  searchData(event:any,i:any){\r\n    const searchTerm = event.target.value.trim(); // Trim whitespace\r\n    const filteredIssues = this.dummyArray[i].Issues.filter((item:any) =>  {\r\n      let findChecked = this.selectedValuesArray[i].find((issue:any) => issue.text == item.text );\r\n      if(findChecked) {\r\n        item.checked = findChecked?.checked ? findChecked?.checked : false;\r\n      }\r\n      else {\r\n        item.checked = false;\r\n      }\r\n      return new RegExp(searchTerm,'i').test(item.text);\r\n    });\r\n    this.dataObject[i].Issues = filteredIssues;\r\n    if(filteredIssues.length){\r\n      this.noFilter = false;\r\n    }else{\r\n      this.noFilter = true;\r\n    }\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  Apply() {\r\n    this.Opendropdown = false;\r\n    this.responseArray.forEach((item:any,index:any)=>{\r\n      item.Issues = this.selectedValuesArray[index] ? this.selectedValuesArray[index] :[]\r\n   })\r\n   this.appliedFilters.emit(this.responseArray)\r\n  }\r\n}\r\n ","<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 z-1 end-0\" style=\"z-index: 1 !important;\" *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>"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filters.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-app-shared/src/lib/modules/common/filters/filters.component.ts","../../../../../../../projects/tango-app-shared/src/lib/modules/common/filters/filters.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, HostListener, Input, OnInit, Output, Renderer2,ChangeDetectorRef } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\n \r\n@Component({\r\n  selector: 'lib-filters',\r\n  templateUrl: './filters.component.html',\r\n  styleUrl: './filters.component.scss'\r\n})\r\nexport class FiltersComponent implements OnInit {\r\n  @Input() dataObject: any[] = [];\r\n  @Output() appliedFilters = new EventEmitter()\r\n  Opendropdown: boolean = false;\r\n \r\n  showdropdown: any;\r\n  selectedValues: string[] = [];\r\n  searchTerms: string[] = [];\r\n  selectedValuesArray: any[] = [];\r\n  searchValue:any;\r\n  selectedItem:any;\r\n  dropDown: boolean = false;\r\n  dummyArray:any[] = [];\r\n  noFilter:boolean = false;\r\n  responseArray:any[] = []\r\n  productModule: any;\r\n  product: any;\r\n  selectedProductCount: string;\r\n  constructor(private elementRef: ElementRef,\r\n    private renderer: Renderer2,\r\n    private router: Router,\r\n  private cd:ChangeDetectorRef) {\r\n     }\r\n \r\n  @HostListener('document:click', ['$event'])\r\n  onClick (event: MouseEvent) {\r\n    const\r\n      target = event.target as HTMLElement;\r\n    if(!target.closest('.dropdown1')) {\r\n      this.Opendropdown = false;\r\n    }\r\n    if(!target.closest('.dropdown-content')){\r\n      this.dataObject.forEach((item: any, i: any) => {\r\n          item.isOpen = false;\r\n        }\r\n      );\r\n    }\r\n  }\r\n \r\n  ngOnInit() {\r\n    this.dataObject.forEach((item:any)=>{\r\n      let selectedList = item?.Issues.filter((data:any)=> data?.checked)\r\n      this.selectedValuesArray.push(selectedList)\r\n    })\r\n    this.dummyArray = JSON.parse(JSON.stringify(this.dataObject))\r\n    this.responseArray = JSON.parse(JSON.stringify(this.dataObject))\r\n  }\r\n \r\n  selectItem(event:any,index:any,subIndex:any){\r\n    this.selectedValuesArray[index] = this.dataObject[index].Issues[subIndex];\r\n  }\r\n\r\n  openDropdown(event:MouseEvent,index:any){\r\n    event.stopPropagation();\r\n    this.dataObject.forEach((item: any, i: any) => {\r\n      if (i !== index) {\r\n        item.isOpen = false; // Close other dropdowns\r\n      }\r\n    });\r\n    this.dataObject[index].isOpen = !this.dataObject[index].isOpen;\r\n  }\r\n \r\n \r\n  opendropdown(e:MouseEvent) {\r\n    e.stopPropagation();\r\n    this.Opendropdown = !this.Opendropdown;\r\n  }\r\n \r\n  Dropdown(value: any, index: number,event:MouseEvent) {\r\n    event.stopPropagation();\r\n    this.dataObject.forEach((item: any, i: any) => {\r\n      if (i !== index) {\r\n        item.isOpen = false; // Close other dropdowns\r\n      }\r\n    });\r\n    this.dataObject[index].isOpen = !this.dataObject[index].isOpen;\r\n  }\r\n \r\n  toggleCheckbox(event: any, issue: any, index: number, subIndex: number) {\r\n    if(!this.selectedValuesArray.length) {\r\n      this.dataObject.forEach((item:any)=>{\r\n        let selectedList = item?.Issues.filter((data:any)=> data?.checked)\r\n        this.selectedValuesArray.push(selectedList)\r\n      })\r\n    }\r\n    const currentIssues = this.dataObject[index].Issues;\r\n    this.selectedValuesArray[index] = this.selectedValuesArray[index];\r\n    const selectedValues = this.selectedValuesArray[index]; // Retrieve selected values array for the current dropdown index\r\n    if (issue === 'Select All') {\r\n      const checkedState = event.target.checked;\r\n      this.dataObject[index].Issues.forEach((item: any) => {\r\n        item.checked = checkedState;\r\n      });\r\n\r\n      if (checkedState) {\r\n        this.selectedValuesArray[index] = currentIssues.slice(); // Copy all items\r\n      } else {\r\n        this.selectedValuesArray[index] = []; // Deselect all items\r\n      }\r\n    } else {\r\n      this.dataObject[index].Issues[subIndex].checked = event.target.checked;\r\n      let checkedData = this.dataObject[index].Issues[subIndex];\r\n      \r\n      if(this.dataObject[index].Issues[subIndex].checked){\r\n        this.selectedValuesArray[index].push(checkedData)\r\n      }\r\n      else{\r\n        this.selectedValuesArray[index] = this.selectedValuesArray[index].filter((el:any)=>\r\n          el?.checked === true && el?.text != issue\r\n      )\r\n      }  \r\n\r\n    }\r\n\r\n    const selectAllId = `selectall${index}`;\r\n    const selectAllElement = document.getElementById(selectAllId) as HTMLInputElement;\r\n    if (selectAllElement) {\r\n      selectAllElement.checked = selectedValues.length === currentIssues.length;\r\n    }\r\n \r\n    // Update checkboxes based on selected values\r\n    currentIssues.forEach((item: string) => {\r\n      const isChecked = this.selectedValuesArray[index].includes(item);\r\n      const checkboxId = `option${item}`;\r\n      const checkboxElement = document.getElementById(checkboxId) as HTMLInputElement;\r\n      if (checkboxElement) {\r\n        checkboxElement.checked = isChecked;\r\n      }\r\n    });\r\n   \r\n  }\r\n  Reset() {\r\n    this.selectedValuesArray.forEach((item:any) => {\r\n      if(item?.length){item.forEach((data:any)=>{data.checked = false;})\r\n      }\r\n    })\r\n    this.selectedValuesArray = [];\r\n    this.Opendropdown = false;\r\n    this.responseArray.forEach((item:any,index:any)=>{\r\n      item.Issues = this.selectedValuesArray[index] ? this.selectedValuesArray[index] :[]\r\n   })\r\n   this.appliedFilters.emit(this.responseArray)\r\n  }\r\n  searchData(event:any,i:any){\r\n    const searchTerm = event.target.value.trim(); // Trim whitespace\r\n    const filteredIssues = this.dummyArray[i].Issues.filter((item:any) =>  {\r\n      let findChecked = this.selectedValuesArray[i].find((issue:any) => issue.text == item.text );\r\n      if(findChecked) {\r\n        item.checked = findChecked?.checked ? findChecked?.checked : false;\r\n      }\r\n      else {\r\n        item.checked = false;\r\n      }\r\n      return new RegExp(searchTerm,'i').test(item.text);\r\n    });\r\n    this.dataObject[i].Issues = filteredIssues;\r\n    if(filteredIssues.length){\r\n      this.noFilter = false;\r\n    }else{\r\n      this.noFilter = true;\r\n    }\r\n    this.cd.detectChanges();\r\n  }\r\n\r\n  Apply() {\r\n    this.Opendropdown = false;\r\n    this.responseArray.forEach((item:any,index:any)=>{\r\n      item.Issues = this.selectedValuesArray[index] ? this.selectedValuesArray[index] :[]\r\n   })\r\n   this.appliedFilters.emit(this.responseArray)\r\n  }\r\n}\r\n ","<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 z-1 end-0\" style=\"z-index: 1 !important;\" *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>"]}
@@ -4260,6 +4260,12 @@ class FiltersComponent {
4260
4260
  this.dataObject[index].isOpen = !this.dataObject[index].isOpen;
4261
4261
  }
4262
4262
  toggleCheckbox(event, issue, index, subIndex) {
4263
+ if (!this.selectedValuesArray.length) {
4264
+ this.dataObject.forEach((item) => {
4265
+ let selectedList = item?.Issues.filter((data) => data?.checked);
4266
+ this.selectedValuesArray.push(selectedList);
4267
+ });
4268
+ }
4263
4269
  const currentIssues = this.dataObject[index].Issues;
4264
4270
  this.selectedValuesArray[index] = this.selectedValuesArray[index];
4265
4271
  const selectedValues = this.selectedValuesArray[index]; // Retrieve selected values array for the current dropdown index