@trudb/tru-common-lib 0.1.535 → 0.1.537

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.
@@ -47,9 +47,12 @@ export class TruToolbarDropdown {
47
47
  return option !== undefined;
48
48
  });
49
49
  if (parsedOptions.length) {
50
+ if (this.selectAllLabel === 'Select All')
51
+ this.selectAllOption.select();
50
52
  this.selectAllLabel = 'Deselect All';
51
53
  }
52
54
  else {
55
+ this.selectAllOption.deselect();
53
56
  this.selectAllLabel = 'Select All';
54
57
  }
55
58
  };
@@ -95,4 +98,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.5", ngImpor
95
98
  type: ViewChild,
96
99
  args: ['selectAllOption']
97
100
  }] } });
98
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-toolbar-dropdown.js","sourceRoot":"","sources":["../../../../../../../projects/tru-common-lib/src/lib/components/toolbar/dropdown/tru-toolbar-dropdown.ts","../../../../../../../projects/tru-common-lib/src/lib/components/toolbar/dropdown/tru-toolbar-dropdown.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnInit, Output, SimpleChanges, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { MatOption, MatSelect, MatSelectChange } from '@angular/material/select';\r\nimport { ITruToolbarDropdownOption } from '../classes/tru-toolbar-dropdown-option';\r\n\r\n@Component({\r\n  selector: 'tru-toolbar-dropdown',\r\n  templateUrl: './tru-toolbar-dropdown.html',\r\n  styleUrls: ['../tru-toolbar.css', './tru-toolbar-dropdown.css'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TruToolbarDropdown implements OnInit, AfterViewInit {\r\n  @Input() config: [] | null = null;\r\n  @Input() options: Array<ITruToolbarDropdownOption> | null = [];\r\n  @Input() tooltip: string = '';\r\n  @Input() multiple: boolean = false;\r\n  @Input() filterable: boolean = false;\r\n  @Input() filterTooltip: string = '';\r\n  @Input() width: number = 115;\r\n  @Input() selectedOption!: ITruToolbarDropdownOption;\r\n  @Output() selectedOptionChange = new EventEmitter<ITruToolbarDropdownOption>();\r\n  @Input() disabled!: boolean;\r\n  @Output() selectionChange = new EventEmitter<Array<ITruToolbarDropdownOption> | null>();\r\n\r\n  @ViewChild('select') select!: MatSelect;\r\n  @ViewChild('selectAllOption') private selectAllOption!: MatOption;\r\n\r\n  filteredOptions: Array<ITruToolbarDropdownOption> | null = [];\r\n  selectedOptions: Array<ITruToolbarDropdownOption> = [];\r\n  selectAllLabel: string = 'Select All';\r\n\r\n  constructor() {\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    \r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.filteredOptions = this.options;\r\n  }\r\n\r\n  toggleSelectAll = () => {\r\n    if (this.selectAllOption.selected) {\r\n      this.select.options.forEach((item: MatOption) => item.select());\r\n    } else {\r\n      this.select.options.forEach((item: MatOption) => item.deselect());\r\n    }\r\n  }\r\n\r\n  onSelectionChange = (event: MatSelectChange) => {\r\n    this.selectedOptionChange.emit(event.source.value);\r\n    this.selectionChange.emit(event.value);\r\n    let parsedOptions = event.value.filter((option: Array<ITruToolbarDropdownOption>) => {\r\n      return option !== undefined;\r\n    });\r\n\r\n    if (parsedOptions.length) {\r\n      this.selectAllLabel = 'Deselect All';\r\n    } else {\r\n      this.selectAllLabel = 'Select All';\r\n    }\r\n  }\r\n\r\n  onFilterChange = (event: any) => {\r\n    const searchInput = event.target.value.toLowerCase();\r\n    this.filteredOptions = this.options!.filter((option: ITruToolbarDropdownOption) => {\r\n      const label = option.label.toLowerCase();\r\n      return label.includes(searchInput);\r\n    });\r\n  }\r\n}\r\n","<mat-form-field>\r\n  @if (multiple) {\r\n  <mat-select #select\r\n              [(ngModel)]=\"selectedOption\"\r\n              [disabled]=\"disabled\"\r\n              [placeholder]=\"tooltip\"\r\n              (selectionChange)=\"onSelectionChange($event)\"\r\n              [style.width.px]=\"width\"\r\n              tru-mat-select-panel\r\n              multiple>\r\n    <input matInput\r\n           *ngIf=\"filterable\"\r\n           [placeholder]=\"filterTooltip\"\r\n           (input)=\"onFilterChange($event)\"\r\n           type=\"text\"\r\n           autocomplete=\"off\" />\r\n    <mat-option #selectAllOption *ngIf=\"filteredOptions!.length\" (click)=\"toggleSelectAll()\">{{selectAllLabel}}</mat-option>\r\n    <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n      {{option.label}}\r\n    </mat-option>\r\n  </mat-select>\r\n  } @else {\r\n  <mat-select [(ngModel)]=\"selectedOption\"\r\n              [disabled]=\"disabled\"\r\n              [placeholder]=\"tooltip\"\r\n              (selectionChange)=\"onSelectionChange($event)\"\r\n              [style.width.px]=\"width\"\r\n              [hideSingleSelectionIndicator]=\"true\"\r\n              tru-mat-select-panel>\r\n    <input matInput\r\n           *ngIf=\"filterable\"\r\n           [placeholder]=\"filterTooltip\"\r\n           (input)=\"onFilterChange($event)\"\r\n           type=\"text\"\r\n           autocomplete=\"off\" />\r\n    <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n      {{option.label}}\r\n    </mat-option>\r\n  </mat-select>\r\n  }\r\n</mat-form-field>\r\n\r\n"]}
101
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tru-toolbar-dropdown.js","sourceRoot":"","sources":["../../../../../../../projects/tru-common-lib/src/lib/components/toolbar/dropdown/tru-toolbar-dropdown.ts","../../../../../../../projects/tru-common-lib/src/lib/components/toolbar/dropdown/tru-toolbar-dropdown.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, EventEmitter, Input, OnInit, Output, SimpleChanges, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { MatOption, MatSelect, MatSelectChange } from '@angular/material/select';\r\nimport { ITruToolbarDropdownOption } from '../classes/tru-toolbar-dropdown-option';\r\n\r\n@Component({\r\n  selector: 'tru-toolbar-dropdown',\r\n  templateUrl: './tru-toolbar-dropdown.html',\r\n  styleUrls: ['../tru-toolbar.css', './tru-toolbar-dropdown.css'],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class TruToolbarDropdown implements OnInit, AfterViewInit {\r\n  @Input() config: [] | null = null;\r\n  @Input() options: Array<ITruToolbarDropdownOption> | null = [];\r\n  @Input() tooltip: string = '';\r\n  @Input() multiple: boolean = false;\r\n  @Input() filterable: boolean = false;\r\n  @Input() filterTooltip: string = '';\r\n  @Input() width: number = 115;\r\n  @Input() selectedOption!: ITruToolbarDropdownOption;\r\n  @Output() selectedOptionChange = new EventEmitter<ITruToolbarDropdownOption>();\r\n  @Input() disabled!: boolean;\r\n  @Output() selectionChange = new EventEmitter<Array<ITruToolbarDropdownOption> | null>();\r\n\r\n  @ViewChild('select') select!: MatSelect;\r\n  @ViewChild('selectAllOption') private selectAllOption!: MatOption;\r\n\r\n  filteredOptions: Array<ITruToolbarDropdownOption> | null = [];\r\n  selectedOptions: Array<ITruToolbarDropdownOption> = [];\r\n  selectAllLabel: string = 'Select All';\r\n\r\n  constructor() {\r\n\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    \r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.filteredOptions = this.options;\r\n  }\r\n\r\n  toggleSelectAll = () => {\r\n    if (this.selectAllOption.selected) {\r\n      this.select.options.forEach((item: MatOption) => item.select());\r\n    } else {\r\n      this.select.options.forEach((item: MatOption) => item.deselect());\r\n    }\r\n  }\r\n\r\n  onSelectionChange = (event: MatSelectChange) => {\r\n    this.selectedOptionChange.emit(event.source.value);\r\n    this.selectionChange.emit(event.value);\r\n    let parsedOptions = event.value.filter((option: Array<ITruToolbarDropdownOption>) => {\r\n      return option !== undefined;\r\n    });\r\n\r\n    if (parsedOptions.length) {\r\n      if (this.selectAllLabel === 'Select All')\r\n        this.selectAllOption.select();\r\n      this.selectAllLabel = 'Deselect All';\r\n    } else {\r\n      this.selectAllOption.deselect();\r\n      this.selectAllLabel = 'Select All';\r\n    }\r\n  }\r\n\r\n  onFilterChange = (event: any) => {\r\n    const searchInput = event.target.value.toLowerCase();\r\n    this.filteredOptions = this.options!.filter((option: ITruToolbarDropdownOption) => {\r\n      const label = option.label.toLowerCase();\r\n      return label.includes(searchInput);\r\n    });\r\n  }\r\n}\r\n","<mat-form-field>\r\n  @if (multiple) {\r\n  <mat-select #select\r\n              [(ngModel)]=\"selectedOption\"\r\n              [disabled]=\"disabled\"\r\n              [placeholder]=\"tooltip\"\r\n              (selectionChange)=\"onSelectionChange($event)\"\r\n              [style.width.px]=\"width\"\r\n              tru-mat-select-panel\r\n              multiple>\r\n    <input matInput\r\n           *ngIf=\"filterable\"\r\n           [placeholder]=\"filterTooltip\"\r\n           (input)=\"onFilterChange($event)\"\r\n           type=\"text\"\r\n           autocomplete=\"off\" />\r\n    <mat-option #selectAllOption *ngIf=\"filteredOptions!.length\" (click)=\"toggleSelectAll()\">{{selectAllLabel}}</mat-option>\r\n    <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n      {{option.label}}\r\n    </mat-option>\r\n  </mat-select>\r\n  } @else {\r\n  <mat-select [(ngModel)]=\"selectedOption\"\r\n              [disabled]=\"disabled\"\r\n              [placeholder]=\"tooltip\"\r\n              (selectionChange)=\"onSelectionChange($event)\"\r\n              [style.width.px]=\"width\"\r\n              [hideSingleSelectionIndicator]=\"true\"\r\n              tru-mat-select-panel>\r\n    <input matInput\r\n           *ngIf=\"filterable\"\r\n           [placeholder]=\"filterTooltip\"\r\n           (input)=\"onFilterChange($event)\"\r\n           type=\"text\"\r\n           autocomplete=\"off\" />\r\n    <mat-option *ngFor=\"let option of filteredOptions\" [value]=\"option\">\r\n      {{option.label}}\r\n    </mat-option>\r\n  </mat-select>\r\n  }\r\n</mat-form-field>\r\n\r\n"]}
@@ -4003,9 +4003,12 @@ class TruToolbarDropdown {
4003
4003
  return option !== undefined;
4004
4004
  });
4005
4005
  if (parsedOptions.length) {
4006
+ if (this.selectAllLabel === 'Select All')
4007
+ this.selectAllOption.select();
4006
4008
  this.selectAllLabel = 'Deselect All';
4007
4009
  }
4008
4010
  else {
4011
+ this.selectAllOption.deselect();
4009
4012
  this.selectAllLabel = 'Select All';
4010
4013
  }
4011
4014
  };