tango-app-ui-analyse-trax 3.7.9 → 3.7.11

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.
@@ -48,6 +48,7 @@ export class GroupSelectComponent {
48
48
  initializeItems() {
49
49
  this.filteredValues = this.items.map((item) => ({ ...item }));
50
50
  this.updateSelectedValues();
51
+ this.cd.detectChanges();
51
52
  }
52
53
  updateSelectedValues() {
53
54
  this.selectedValues?.forEach((selectedItem) => {
@@ -56,6 +57,7 @@ export class GroupSelectComponent {
56
57
  item.isSelected = true;
57
58
  }
58
59
  });
60
+ this.cd.detectChanges();
59
61
  }
60
62
  openDropdown(event) {
61
63
  this.authService.dropDownTrigger.next(this.instanceId);
@@ -152,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
152
154
  }], selected: [{
153
155
  type: Output
154
156
  }] } });
155
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/group-select/group-select.component.ts","../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/group-select/group-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EyeTestAuditService } from '../services/eye-test-audit.service';\r\n\r\n@Component({\r\n  selector: 'lib-group-select',\r\n  templateUrl: './group-select.component.html',\r\n  styleUrl: './group-select.component.scss'\r\n})\r\nexport class GroupSelectComponent implements OnInit,OnChanges {\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if (!target.closest('.dropdown')) {\r\n      this.showDropdown = false;\r\n    }\r\n  }\r\n \r\n  @Input() items: any\r\n  @Input() searchField: string\r\n  @Input() multi: boolean\r\n  @Input() idField: string\r\n  @Input() selectedValues: any = []\r\n  @Input() disabled: boolean | undefined\r\n  @Input() label: string\r\n  @Output() selected = new EventEmitter<any>()\r\n  filteredValues: any = []\r\n  showDropdown: boolean\r\n  searchValue: string\r\n  instanceId: any;\r\n \r\n \r\n  constructor(private cd: ChangeDetectorRef, private authService:EyeTestAuditService) { }\r\n  ngOnInit(): void {\r\n    this.instanceId = crypto.randomUUID();\r\n    this.authService.dropDownTrigger.subscribe((e)=>{           \r\n      if(e !== this.instanceId){        \r\n        this.showDropdown = false\r\n        this.cd.detectChanges()\r\n      }\r\n    })\r\n  }\r\n \r\n  ngOnChanges(changes: SimpleChanges): void {\r\n \r\n    if (changes['items'] && this.items?.length) {\r\n      this.initializeItems();\r\n    }\r\n    if (changes['selectedValues'] && Array.isArray(changes['selectedValues']?.currentValue) && changes['selectedValues']?.currentValue?.length > 0 && changes['selectedValues']?.currentValue[0]) {            \r\n      this.updateSelectedValues();\r\n    }\r\n  }\r\n \r\n  initializeItems() {\r\n    this.filteredValues = this.items.map((item: any) => ({ ...item }));\r\n    this.updateSelectedValues()\r\n  }\r\n \r\n  updateSelectedValues() {    \r\n    this.selectedValues?.forEach((selectedItem: any) => {\r\n      const item = this.filteredValues?.find((filteredItem: any) => filteredItem?.[this.idField] === selectedItem?.[this.idField]);\r\n      if (item) {\r\n        item.isSelected = true;\r\n      }\r\n    });\r\n   \r\n  }\r\n \r\n  openDropdown(event: any) {\r\n    this.authService.dropDownTrigger.next(this.instanceId)\r\n    event.stopPropagation();\r\n    this.showDropdown = !this.showDropdown;\r\n  }\r\n \r\n  onInput(event: any) {\r\n    if (!event.target.value) {\r\n      this.filteredValues = [...this.items];\r\n    } else {\r\n      const searchTerm = event.target.value.toLowerCase();\r\n      this.filteredValues = this.items.filter((item: any) =>\r\n        item[this.searchField].toLowerCase().includes(searchTerm)\r\n      );\r\n    }\r\n    this.updateSelectedValues();\r\n    this.cd.detectChanges();\r\n  }\r\n \r\n  onSelect(event: any, item: any) {    \r\n    if (this.multi) {\r\n      if (event.currentTarget.checked) {\r\n        this.selectedValues.push(item );        \r\n      } else {\r\n        this.selectedValues = this.selectedValues.filter((elem: any) => elem[this.idField] !== item[this.idField]);\r\n      }\r\n    } else {\r\n      this.selectedValues = [{ ...item }];\r\n      this.filteredValues.forEach((element:any) => {\r\n        if(element[this.idField] !== item[this.idField]){\r\n          element.isSelected = false\r\n        }\r\n      });\r\n      this.showDropdown = false;\r\n    }\r\n \r\n    const valuesToEmit = this.selectedValues.map((value: any) => {\r\n      const selectedItem = { ...value };\r\n      delete selectedItem.isSelected;\r\n      return selectedItem;\r\n    });\r\n \r\n    this.cd.detectChanges();\r\n    this.emitSelectedValues(valuesToEmit);\r\n \r\n  }\r\n \r\n  onSelectAll(event: any) {\r\n    const selectAll = event.currentTarget.checked;\r\n    this.filteredValues.forEach((item: any) => item.isSelected = selectAll);\r\n \r\n    if (selectAll) {\r\n      this.selectedValues = [...this.filteredValues];\r\n    } else {\r\n      this.selectedValues = [];\r\n    }\r\n \r\n    const valuesToEmit = this.selectedValues.map((value: any) => {\r\n      const { isSelected, ...selectedItem } = value;\r\n      return selectedItem;\r\n    });\r\n \r\n    this.cd.detectChanges();\r\n    this.emitSelectedValues(valuesToEmit);\r\n  }\r\n \r\n \r\n  emitSelectedValues(values: any[]) {\r\n    if (this.multi) {\r\n      this.selected.emit(values);\r\n    } else {\r\n      this.selected.emit(values[0]);\r\n    }\r\n  }\r\n \r\n  checkIfAllSelected() {\r\n    return this.filteredValues.every((item: any) => item.isSelected);\r\n  }\r\n}\r\n","<div class=\"outer-container\">\r\n    <div [ngClass]=\"disabled ? 'disable-input':''\"  (click)=\"openDropdown($event)\"  class=\"form-select\">\r\n    <ng-container *ngIf=\"multi\" >\r\n    <span *ngIf=\"selectedValues?.length\" class=\"select-value w-50 mx-2\"> <img class=\"me-2\" alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[0]?.[searchField]}}</span> \r\n    <!-- <span *ngIf=\"selectedValues?.length > 1\" class=\"select-value mx-2\"><img class=\"me-2\"  alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[1]?.[searchField]}}</span>  -->\r\n    <span class=\"select-value mx-2\" *ngIf=\"selectedValues?.length > 1\">+{{selectedValues?.length -1}}</span> {{label}}    \r\n    </ng-container>\r\n    <ng-container *ngIf=\"!multi\" >\r\n        {{selectedValues?.[0]?.[searchField]}}\r\n    </ng-container>\r\n    </div>\r\n    <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-container dropdown\" >\r\n        <div class=\"w-100 input-wrapper\">\r\n        <input [(ngModel)]=\"searchValue\" placeholder=\"Search\"  (input)=\"onInput($event)\" type=\"text\">  \r\n        <svg class=\"search-icon\" 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        </div>\r\n        <ul>\r\n            <li *ngIf=\"multi && filteredValues?.length\">\r\n                <label class=\"form-check\" [for]=\"instanceId\" >\r\n                    <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n                    [id]=\"instanceId\">\r\n                    <span class=\"form-check-label\" >\r\n                        Select All\r\n                    </span>\r\n                </label>\r\n            </li>\r\n            <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n                <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi  ? '': 'ps-0'\" class=\"form-check\">\r\n                    <input [ngClass]=\"multi  ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n                        [id]=\"item[idField] + instanceId\">\r\n                    <span class=\"form-check-label\" >\r\n                        {{item[searchField]}}\r\n                    </span>\r\n                </label>\r\n            </li>\r\n            <li *ngIf=\"!filteredValues?.length\" >\r\n                <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n            </li>\r\n        </ul>  \r\n    </div>  \r\n   \r\n</div>"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/group-select/group-select.component.ts","../../../../../../../projects/tango-analyse-trax/src/lib/components/eye-test-audit/group-select/group-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, HostListener, Input, OnChanges, OnInit, Output, SimpleChanges } from '@angular/core';\r\nimport { EyeTestAuditService } from '../services/eye-test-audit.service';\r\n\r\n@Component({\r\n  selector: 'lib-group-select',\r\n  templateUrl: './group-select.component.html',\r\n  styleUrl: './group-select.component.scss'\r\n})\r\nexport class GroupSelectComponent implements OnInit,OnChanges {\r\n  @HostListener('document:click', ['$event'])\r\n  onClick(event: MouseEvent) {\r\n    const target = event.target as HTMLElement;\r\n    if (!target.closest('.dropdown')) {\r\n      this.showDropdown = false;\r\n    }\r\n  }\r\n \r\n  @Input() items: any\r\n  @Input() searchField: string\r\n  @Input() multi: boolean\r\n  @Input() idField: string\r\n  @Input() selectedValues: any = []\r\n  @Input() disabled: boolean | undefined\r\n  @Input() label: string\r\n  @Output() selected = new EventEmitter<any>()\r\n  filteredValues: any = []\r\n  showDropdown: boolean\r\n  searchValue: string\r\n  instanceId: any;\r\n \r\n \r\n  constructor(private cd: ChangeDetectorRef, private authService:EyeTestAuditService) { }\r\n  ngOnInit(): void {\r\n    this.instanceId = crypto.randomUUID();\r\n    this.authService.dropDownTrigger.subscribe((e)=>{           \r\n      if(e !== this.instanceId){        \r\n        this.showDropdown = false\r\n        this.cd.detectChanges()\r\n      }\r\n    })\r\n  }\r\n \r\n  ngOnChanges(changes: SimpleChanges): void {\r\n \r\n    if (changes['items'] && this.items?.length) {\r\n      this.initializeItems();\r\n    }\r\n    if (changes['selectedValues'] && Array.isArray(changes['selectedValues']?.currentValue) && changes['selectedValues']?.currentValue?.length > 0 && changes['selectedValues']?.currentValue[0]) {            \r\n      this.updateSelectedValues();\r\n    }\r\n  }\r\n \r\n  initializeItems() {\r\n    this.filteredValues = this.items.map((item: any) => ({ ...item }));\r\n    this.updateSelectedValues()\r\n     this.cd.detectChanges();\r\n  }\r\n \r\n  updateSelectedValues() {    \r\n    this.selectedValues?.forEach((selectedItem: any) => {\r\n      const item = this.filteredValues?.find((filteredItem: any) => filteredItem?.[this.idField] === selectedItem?.[this.idField]);\r\n      if (item) {\r\n        item.isSelected = true;\r\n      }\r\n    });\r\n    this.cd.detectChanges();\r\n  }\r\n \r\n  openDropdown(event: any) {\r\n    this.authService.dropDownTrigger.next(this.instanceId)\r\n    event.stopPropagation();\r\n    this.showDropdown = !this.showDropdown;\r\n  }\r\n \r\n  onInput(event: any) {\r\n    if (!event.target.value) {\r\n      this.filteredValues = [...this.items];\r\n    } else {\r\n      const searchTerm = event.target.value.toLowerCase();\r\n      this.filteredValues = this.items.filter((item: any) =>\r\n        item[this.searchField].toLowerCase().includes(searchTerm)\r\n      );\r\n    }\r\n    this.updateSelectedValues();\r\n    this.cd.detectChanges();\r\n  }\r\n \r\n  onSelect(event: any, item: any) {    \r\n    if (this.multi) {\r\n      if (event.currentTarget.checked) {\r\n        this.selectedValues.push(item );        \r\n      } else {\r\n        this.selectedValues = this.selectedValues.filter((elem: any) => elem[this.idField] !== item[this.idField]);\r\n      }\r\n    } else {\r\n      this.selectedValues = [{ ...item }];\r\n      this.filteredValues.forEach((element:any) => {\r\n        if(element[this.idField] !== item[this.idField]){\r\n          element.isSelected = false\r\n        }\r\n      });\r\n      this.showDropdown = false;\r\n    }\r\n \r\n    const valuesToEmit = this.selectedValues.map((value: any) => {\r\n      const selectedItem = { ...value };\r\n      delete selectedItem.isSelected;\r\n      return selectedItem;\r\n    });\r\n \r\n    this.cd.detectChanges();\r\n    this.emitSelectedValues(valuesToEmit);\r\n \r\n  }\r\n \r\n  onSelectAll(event: any) {\r\n    const selectAll = event.currentTarget.checked;\r\n    this.filteredValues.forEach((item: any) => item.isSelected = selectAll);\r\n \r\n    if (selectAll) {\r\n      this.selectedValues = [...this.filteredValues];\r\n    } else {\r\n      this.selectedValues = [];\r\n    }\r\n \r\n    const valuesToEmit = this.selectedValues.map((value: any) => {\r\n      const { isSelected, ...selectedItem } = value;\r\n      return selectedItem;\r\n    });\r\n \r\n    this.cd.detectChanges();\r\n    this.emitSelectedValues(valuesToEmit);\r\n  }\r\n \r\n \r\n  emitSelectedValues(values: any[]) {\r\n    if (this.multi) {\r\n      this.selected.emit(values);\r\n    } else {\r\n      this.selected.emit(values[0]);\r\n    }\r\n  }\r\n \r\n  checkIfAllSelected() {\r\n    return this.filteredValues.every((item: any) => item.isSelected);\r\n  }\r\n}\r\n","<div class=\"outer-container\">\r\n    <div [ngClass]=\"disabled ? 'disable-input':''\"  (click)=\"openDropdown($event)\"  class=\"form-select\">\r\n    <ng-container *ngIf=\"multi\" >\r\n    <span *ngIf=\"selectedValues?.length\" class=\"select-value w-50 mx-2\"> <img class=\"me-2\" alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[0]?.[searchField]}}</span> \r\n    <!-- <span *ngIf=\"selectedValues?.length > 1\" class=\"select-value mx-2\"><img class=\"me-2\"  alt=\"Pic\" src=\"./assets/tango/Image/users-teams.svg\">{{selectedValues?.[1]?.[searchField]}}</span>  -->\r\n    <span class=\"select-value mx-2\" *ngIf=\"selectedValues?.length > 1\">+{{selectedValues?.length -1}}</span> {{label}}    \r\n    </ng-container>\r\n    <ng-container *ngIf=\"!multi\" >\r\n        {{selectedValues?.[0]?.[searchField]}}\r\n    </ng-container>\r\n    </div>\r\n    <div [ngClass]=\"showDropdown ? '' : 'd-none'\" class=\"input-container dropdown\" >\r\n        <div class=\"w-100 input-wrapper\">\r\n        <input [(ngModel)]=\"searchValue\" placeholder=\"Search\"  (input)=\"onInput($event)\" type=\"text\">  \r\n        <svg class=\"search-icon\" 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        </div>\r\n        <ul>\r\n            <li *ngIf=\"multi && filteredValues?.length\">\r\n                <label class=\"form-check\" [for]=\"instanceId\" >\r\n                    <input (change)=\"onSelectAll($event)\" [checked]=\"checkIfAllSelected()\" class=\"form-check-input me-3\" type=\"checkbox\"\r\n                    [id]=\"instanceId\">\r\n                    <span class=\"form-check-label\" >\r\n                        Select All\r\n                    </span>\r\n                </label>\r\n            </li>\r\n            <li *ngFor=\"let item of filteredValues\" [ngClass]=\"item.isSelected && !multi ? 'selected' : ''\" >\r\n                <label [for]=\"item[idField] + instanceId\" [ngClass]=\"multi  ? '': 'ps-0'\" class=\"form-check\">\r\n                    <input [ngClass]=\"multi  ? '': 'd-none'\" (change)=\"onSelect($event, item)\" [(ngModel)]=\"item.isSelected\" class=\"form-check-input me-3\" type=\"checkbox\" value=\"\"\r\n                        [id]=\"item[idField] + instanceId\">\r\n                    <span class=\"form-check-label\" >\r\n                        {{item[searchField]}}\r\n                    </span>\r\n                </label>\r\n            </li>\r\n            <li *ngIf=\"!filteredValues?.length\" >\r\n                <span class=\"d-flex align-items-center justify-content-center\" >No data found</span>\r\n            </li>\r\n        </ul>  \r\n    </div>  \r\n   \r\n</div>"]}