@tilde-nlp/ngx-common 6.0.34 → 6.0.36
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/filter-bar/filter-bar.component.mjs +2 -1
- package/esm2022/lib/filter-bar/models/filter-bar-settings.model.mjs +1 -1
- package/esm2022/lib/multi-functional-table/multi-functional-table.component.mjs +14 -11
- package/fesm2022/tilde-nlp-ngx-common.mjs +10 -7
- package/fesm2022/tilde-nlp-ngx-common.mjs.map +1 -1
- package/lib/filter-bar/models/filter-bar-settings.model.d.ts +4 -6
- package/package.json +1 -1
|
@@ -322,6 +322,7 @@ export class FilterBarComponent {
|
|
|
322
322
|
control.setValue(newArray);
|
|
323
323
|
}
|
|
324
324
|
removeAllFilters() {
|
|
325
|
+
this.settings.searchInput = '';
|
|
325
326
|
this.settings.filters?.forEach((filter) => {
|
|
326
327
|
const valuesArray = this.filterFormGroupValue[filter.fieldName];
|
|
327
328
|
while (valuesArray.length > 0) {
|
|
@@ -412,4 +413,4 @@ export class FilterBarComponent {
|
|
|
412
413
|
type: Output
|
|
413
414
|
}] }); })();
|
|
414
415
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FilterBarComponent, { className: "FilterBarComponent", filePath: "lib\\filter-bar\\filter-bar.component.ts", lineNumber: 16 }); })();
|
|
415
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilter, FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { MatSelectChange } from '@angular/material/select';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @ViewChildren('optionSearchInput') optionSearchInputs!: ElementRef[];\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  filters: FilterBarChangeEvent = {\r\n    input: '',\r\n    filters: {},\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n  get currentFilters() {\r\n    return this.settings?.splittedFilters?.length ? this.settings.splittedFilters[this.activeFilterIndex] : this.settings?.filters;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n  \r\n    this.activeFilterIndex = 0;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeAllFilters();\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  focusOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder || filter.selectedValues?.length) {\r\n      return;\r\n    }\r\n\r\n    this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement.focus();\r\n\r\n    if (filter.maxPanelWidth === '' && filter.search.placeholder) {\r\n      this.setPanelWidth(filter);\r\n    }\r\n  }\r\n\r\n  clearOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder) {\r\n      return;\r\n    }\r\n\r\n    const input = this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement;\r\n\r\n    if (input) {\r\n      input.value = '';\r\n    }\r\n\r\n    filter.search.searchCriteria = '';\r\n    this.filterOptions(null, filter);\r\n  }\r\n\r\n  filterOptions(event: KeyboardEvent | null, filter: FilterBarFilter) {\r\n    const target = event?.target as HTMLTextAreaElement;\r\n    filter.search!.searchCriteria = target?.value ?? '';\r\n    this.settings.filters?.forEach((item) => {\r\n      if (item.fieldName === filter.fieldName && item.search) {\r\n        item.search.filteredValues = filter.values.filter((value) => {\r\n          const valueKey = item.translated ? value.key : this.translate.instant(value.key);\r\n          const matchesSearch = valueKey.toLowerCase().includes(target?.value?.toLowerCase() ?? '');\r\n          const isSelected = filter.selectedValues?.some((selectedValue) => selectedValue.key === value.key);\r\n          value.isSelected = isSelected ?? false;\r\n          value.matchesSearchCriteria = matchesSearch ?? false;\r\n          return matchesSearch || isSelected;\r\n        })\r\n      }\r\n    });\r\n  }\r\n\r\n  selectEvent(event: MatSelectChange, filter: FilterBarFilter) {\r\n    const settingFilter = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    settingFilter.selectedValues = event.value;\r\n  }\r\n\r\n  setPanelWidth(filter: FilterBarFilter): void {\r\n    // We must save panel width, so filtering does not affect it`s size.\r\n    const selectPanel = document.querySelector('.cdk-overlay-pane') as HTMLElement;\r\n    const selectPanelWidth = selectPanel.clientWidth as number;\r\n    const filterObj = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    filterObj.maxPanelWidth = selectPanelWidth;\r\n    selectPanel.style.minWidth = `${selectPanelWidth}px`;\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.splittedFilters?.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === 0) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  removeAllFilters() {\r\n    this.settings.filters?.forEach((filter) => {\r\n      const valuesArray = this.filterFormGroupValue[filter.fieldName];\r\n      while (valuesArray.length > 0) {\r\n        this.removeFilter(filter.fieldName, 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper?.nativeElement) {\r\n      const minFilterWidth = 100;\r\n  \r\n      if (this.settings?.filters?.length) {\r\n        const containerWidth = this.filterWrapper.nativeElement.clientWidth;\r\n  \r\n        // Calculate the total width needed for all filters\r\n        const totalWidthNeeded = this.settings.filters.length * minFilterWidth;\r\n  \r\n        // If all filters can fit within the container, no need to split\r\n        if (totalWidthNeeded <= containerWidth) {\r\n          this.activeFilterIndex = 0;\r\n          this.settings.splittedFilters = [];\r\n          this.filterOverflow = false;\r\n          return;\r\n        }\r\n  \r\n        // Calculate how many filters can fit per row based on the container width\r\n        const filtersPerRow = Math.floor(containerWidth / minFilterWidth);\r\n  \r\n        // Determine how many groups are needed\r\n        const groupCount = Math.ceil(this.settings.filters.length / filtersPerRow);\r\n\r\n        if (groupCount < this.activeFilterIndex + 1) {\r\n          this.activeFilterIndex = 0;\r\n        }\r\n  \r\n        // Calculate group size based on the number of groups\r\n        const groupSize = Math.ceil(this.settings.filters.length / groupCount);\r\n  \r\n        // Split filters into the calculated number of groups\r\n        const newSplittedFilters: FilterBarFilter[][] = [];\r\n        for (let i = 0; i < this.settings.filters.length; i += groupSize) {\r\n          newSplittedFilters.push(this.settings.filters.slice(i, i + groupSize));\r\n        }\r\n  \r\n        this.settings.splittedFilters = newSplittedFilters;\r\n        this.filterOverflow = true;\r\n      }\r\n    }\r\n  }\r\n  \r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: '',\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n      <ng-container *ngFor=\"let filter of currentFilters; let i = index\">\r\n        <button [class.filter-active]=\"filter.selectedValues?.length\" class=\"select-trigger-btn\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"select.open()\">\r\n          <div class=\"select-trigger-btn-label\">\r\n            <span>{{filter.title | translate}}</span>\r\n            <span *ngIf=\"filter.selectedValues?.length\" class=\"selected-count\">({{filter.selectedValues?.length}})</span>\r\n            <mat-icon>{{ select.panelOpen ? \"keyboard_arrow_up\" : \"keyboard_arrow_down\" }}</mat-icon>\r\n          </div>\r\n\r\n          <mat-select\r\n            multiple \r\n            #select\r\n            [panelClass]=\"'filter-panel'\"\r\n            [panelWidth]=\"filter?.maxPanelWidth ?? 'auto'\" \r\n            [formControlName]=\"filter.fieldName\" \r\n            (openedChange)=\"$event === true ? focusOptionSearchInput(filter, i) : clearOptionSearchInput(filter, i)\"\r\n            (selectionChange)=\"selectEvent($event, filter)\" \r\n          >\r\n            <ng-container *ngIf=\"filter?.search?.placeholder\">\r\n              <input #optionSearchInput class=\"option-search-input\" [class.hidden]=\"filter.values!.length < 10\" type=\"text\" [placeholder]=\"filter.search?.placeholder ?? '' | translate\" (keyup)=\"filterOptions($event, filter)\" (keydown)=\"$event.stopPropagation()\">\r\n            </ng-container>\r\n          \r\n            <ng-container *ngIf=\"filter.values.length\">\r\n              <ng-container *ngIf=\"filter.translated; else sortedValuesByProperty\">\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortAlphabetically:'key'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    {{ filter.disableTitleCase ? value.key : (value.key | titlecase) }}\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-container>\r\n              \r\n              <ng-template #sortedValuesByProperty>\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortTranslationsByProperty:'key':'value'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    <ng-container *ngIf=\"!filter.disableTitleCase; else defaultCase\">\r\n                    {{ value.key | translate : { default: value.value | titlecase } }}\r\n                    </ng-container>\r\n    \r\n                    <ng-template #defaultCase>\r\n                      {{ value.key | translate : { default: value.value } }} \r\n                    </ng-template>\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-template>\r\n            </ng-container>\r\n          </mat-select>\r\n        </button>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n  <ng-container *ngIf=\"filterOverflow\">\r\n    <div class=\"filter-arrows\">\r\n      <button mat-icon-button (click)=\"switchLeft()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_left\r\n        </span>\r\n      </button>\r\n      <button mat-icon-button (click)=\"switchRight()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_right\r\n        </span>\r\n      </button>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
416
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-bar.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.ts","../../../../../projects/ngx-common/src/lib/filter-bar/filter-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, HostListener, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport { FilterBarFilter, FilterBarFilterItem } from './models';\r\nimport { FilterBarChangeEvent } from './models/filter-bar-change-event.model';\r\nimport { FilterBarSettings } from './models/filter-bar-settings.model';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { MatSelectChange } from '@angular/material/select';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-filter-bar',\r\n  templateUrl: './filter-bar.component.html',\r\n  styleUrls: ['./filter-bar.component.scss']\r\n})\r\nexport class FilterBarComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  @ViewChild(\"filterWrapper\") filterWrapper!: ElementRef;\r\n  @ViewChildren('optionSearchInput') optionSearchInputs!: ElementRef[];\r\n  @HostListener('window:resize', [])\r\n  onResize() {\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Input() settings!: FilterBarSettings;\r\n  @Input() set filterRowVisible(value: boolean) {\r\n    this._filterRowVisible = value;\r\n    this.cdref.detectChanges();\r\n    this.checkOverflow();\r\n  }\r\n\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n\r\n  private _inputText = \"\";\r\n  private _filterRowVisible!: boolean;\r\n  private formChangesSubscription!: Subscription;\r\n\r\n  readonly filterFormGroup = new FormGroup({});\r\n  readonly form = new FormGroup({\r\n    filters: this.filterFormGroup\r\n  });\r\n\r\n  filters: FilterBarChangeEvent = {\r\n    input: '',\r\n    filters: {},\r\n  };\r\n\r\n  filterOverflow = false;\r\n  activeFilterIndex = 0;\r\n\r\n  // getter for cleaner template html\r\n  get filterFormGroupValue(): { [key: string]: FilterBarFilterItem[] } {\r\n    return this.filterFormGroup.value;\r\n  }\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  get filterRowVisible() { return this._filterRowVisible; }\r\n  get inputText() {\r\n    return this._inputText;\r\n  }\r\n  get outputFilterKeyAndValue() {\r\n    return this.settings?.outputFilterKeyAndValue;\r\n  }\r\n  get currentFilters() {\r\n    return this.settings?.splittedFilters?.length ? this.settings.splittedFilters[this.activeFilterIndex] : this.settings?.filters;\r\n  }\r\n\r\n  // eslint-disable-next-line @typescript-eslint/adjacent-overload-signatures\r\n  set inputText(value) {\r\n    this._inputText = value;\r\n    this.filters.input = this._inputText;\r\n    this.emitFilters();\r\n  }\r\n\r\n  constructor(private cdref: ChangeDetectorRef, private translate: TranslateService) { }\r\n\r\n  ngOnInit() {\r\n    this.settings.filters?.forEach((field) => {\r\n      this.filterFormGroup.addControl(field.fieldName, new FormControl([]));\r\n    })\r\n\r\n    this.subscribeToFormValueChanges();\r\n  \r\n    this.activeFilterIndex = 0;\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.checkOverflow();\r\n    this.cdref.detectChanges();\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.removeAllFilters();\r\n    this.formChangesSubscription.unsubscribe();\r\n  }\r\n\r\n  focusOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder || filter.selectedValues?.length) {\r\n      return;\r\n    }\r\n\r\n    this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement.focus();\r\n\r\n    if (filter.maxPanelWidth === '' && filter.search.placeholder) {\r\n      this.setPanelWidth(filter);\r\n    }\r\n  }\r\n\r\n  clearOptionSearchInput(filter: FilterBarFilter, index: number): void {\r\n    if (!filter.search?.placeholder) {\r\n      return;\r\n    }\r\n\r\n    const input = this.optionSearchInputs.find((_item, i) => i === index)?.nativeElement;\r\n\r\n    if (input) {\r\n      input.value = '';\r\n    }\r\n\r\n    filter.search.searchCriteria = '';\r\n    this.filterOptions(null, filter);\r\n  }\r\n\r\n  filterOptions(event: KeyboardEvent | null, filter: FilterBarFilter) {\r\n    const target = event?.target as HTMLTextAreaElement;\r\n    filter.search!.searchCriteria = target?.value ?? '';\r\n    this.settings.filters?.forEach((item) => {\r\n      if (item.fieldName === filter.fieldName && item.search) {\r\n        item.search.filteredValues = filter.values.filter((value) => {\r\n          const valueKey = item.translated ? value.key : this.translate.instant(value.key);\r\n          const matchesSearch = valueKey.toLowerCase().includes(target?.value?.toLowerCase() ?? '');\r\n          const isSelected = filter.selectedValues?.some((selectedValue) => selectedValue.key === value.key);\r\n          value.isSelected = isSelected ?? false;\r\n          value.matchesSearchCriteria = matchesSearch ?? false;\r\n          return matchesSearch || isSelected;\r\n        })\r\n      }\r\n    });\r\n  }\r\n\r\n  selectEvent(event: MatSelectChange, filter: FilterBarFilter) {\r\n    const settingFilter = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    settingFilter.selectedValues = event.value;\r\n  }\r\n\r\n  setPanelWidth(filter: FilterBarFilter): void {\r\n    // We must save panel width, so filtering does not affect it`s size.\r\n    const selectPanel = document.querySelector('.cdk-overlay-pane') as HTMLElement;\r\n    const selectPanelWidth = selectPanel.clientWidth as number;\r\n    const filterObj = this.settings.filters?.find((item) => item.fieldName === filter.fieldName) as FilterBarFilter;\r\n    filterObj.maxPanelWidth = selectPanelWidth;\r\n    selectPanel.style.minWidth = `${selectPanelWidth}px`;\r\n  }\r\n\r\n  emitFilters() {\r\n    this.filterBarChange.next(this.filters);\r\n  }\r\n\r\n  switchRight() {\r\n    if (this.settings?.splittedFilters?.length === this.activeFilterIndex + 1) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex += 1;\r\n  }\r\n\r\n  switchLeft() {\r\n    if (this.activeFilterIndex === 0) {\r\n      return;\r\n    }\r\n    this.activeFilterIndex -= 1;\r\n  }\r\n\r\n  removeFilter(key: string, ix: number) {\r\n    const control = this.filterFormGroup.get(key);\r\n\r\n    if (!control) {\r\n      return;\r\n    }\r\n\r\n    const newArray = control.value as [];\r\n    newArray.splice(ix, 1);\r\n    control.setValue(newArray);\r\n  }\r\n\r\n  removeAllFilters() {\r\n    this.settings.searchInput = '';\r\n    this.settings.filters?.forEach((filter) => {\r\n      const valuesArray = this.filterFormGroupValue[filter.fieldName];\r\n      while (valuesArray.length > 0) {\r\n        this.removeFilter(filter.fieldName, 0);\r\n      }\r\n    });\r\n  }\r\n\r\n  private checkOverflow() {\r\n    if (this.filterWrapper?.nativeElement) {\r\n      const minFilterWidth = 100;\r\n  \r\n      if (this.settings?.filters?.length) {\r\n        const containerWidth = this.filterWrapper.nativeElement.clientWidth;\r\n  \r\n        // Calculate the total width needed for all filters\r\n        const totalWidthNeeded = this.settings.filters.length * minFilterWidth;\r\n  \r\n        // If all filters can fit within the container, no need to split\r\n        if (totalWidthNeeded <= containerWidth) {\r\n          this.activeFilterIndex = 0;\r\n          this.settings.splittedFilters = [];\r\n          this.filterOverflow = false;\r\n          return;\r\n        }\r\n  \r\n        // Calculate how many filters can fit per row based on the container width\r\n        const filtersPerRow = Math.floor(containerWidth / minFilterWidth);\r\n  \r\n        // Determine how many groups are needed\r\n        const groupCount = Math.ceil(this.settings.filters.length / filtersPerRow);\r\n\r\n        if (groupCount < this.activeFilterIndex + 1) {\r\n          this.activeFilterIndex = 0;\r\n        }\r\n  \r\n        // Calculate group size based on the number of groups\r\n        const groupSize = Math.ceil(this.settings.filters.length / groupCount);\r\n  \r\n        // Split filters into the calculated number of groups\r\n        const newSplittedFilters: FilterBarFilter[][] = [];\r\n        for (let i = 0; i < this.settings.filters.length; i += groupSize) {\r\n          newSplittedFilters.push(this.settings.filters.slice(i, i + groupSize));\r\n        }\r\n  \r\n        this.settings.splittedFilters = newSplittedFilters;\r\n        this.filterOverflow = true;\r\n      }\r\n    }\r\n  }\r\n  \r\n  private subscribeToFormValueChanges() {\r\n    this.formChangesSubscription = this.form.valueChanges.subscribe(() => {\r\n      this.filters = {\r\n        input: '',\r\n        filters: {}\r\n      };\r\n\r\n      for (const filterKey in this.form.value.filters) {\r\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n        const filter: FilterBarFilterItem[] = (this.form.value.filters as any)[filterKey] as FilterBarFilterItem[];\r\n        this.filters.filters[filterKey] = filter.map((item) => this.outputFilterKeyAndValue ? item : item.value)\r\n      }\r\n      this.emitFilters();\r\n    })\r\n  }\r\n}\r\n","<div class=\"filter-row\" *ngIf=\"filterRowVisible\">\r\n  <div fxLayout=\"row\" class=\"filter-wrapper\" #filterWrapper [formGroup]=\"form\">\r\n    <ng-container [formGroup]=\"filterFormGroup\">\r\n      <ng-container *ngFor=\"let filter of currentFilters; let i = index\">\r\n        <button [class.filter-active]=\"filter.selectedValues?.length\" class=\"select-trigger-btn\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"select.open()\">\r\n          <div class=\"select-trigger-btn-label\">\r\n            <span>{{filter.title | translate}}</span>\r\n            <span *ngIf=\"filter.selectedValues?.length\" class=\"selected-count\">({{filter.selectedValues?.length}})</span>\r\n            <mat-icon>{{ select.panelOpen ? \"keyboard_arrow_up\" : \"keyboard_arrow_down\" }}</mat-icon>\r\n          </div>\r\n\r\n          <mat-select\r\n            multiple \r\n            #select\r\n            [panelClass]=\"'filter-panel'\"\r\n            [panelWidth]=\"filter?.maxPanelWidth ?? 'auto'\" \r\n            [formControlName]=\"filter.fieldName\" \r\n            (openedChange)=\"$event === true ? focusOptionSearchInput(filter, i) : clearOptionSearchInput(filter, i)\"\r\n            (selectionChange)=\"selectEvent($event, filter)\" \r\n          >\r\n            <ng-container *ngIf=\"filter?.search?.placeholder\">\r\n              <input #optionSearchInput class=\"option-search-input\" [class.hidden]=\"filter.values!.length < 10\" type=\"text\" [placeholder]=\"filter.search?.placeholder ?? '' | translate\" (keyup)=\"filterOptions($event, filter)\" (keydown)=\"$event.stopPropagation()\">\r\n            </ng-container>\r\n          \r\n            <ng-container *ngIf=\"filter.values.length\">\r\n              <ng-container *ngIf=\"filter.translated; else sortedValuesByProperty\">\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortAlphabetically:'key'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    {{ filter.disableTitleCase ? value.key : (value.key | titlecase) }}\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-container>\r\n              \r\n              <ng-template #sortedValuesByProperty>\r\n                <ng-container *ngFor=\"let value of (filter.search?.filteredValues ?? filter.values) | sortTranslationsByProperty:'key':'value'\">\r\n                  <mat-option [class.hidden]=\"filter.search?.searchCriteria && value.isSelected && !value.matchesSearchCriteria\" class=\"filter-option\" [disabled]=\"filter.singleSelection?.selected && filter.singleSelection?.value !== value.value\" [value]=\"value\">\r\n                    <ng-container *ngIf=\"!filter.disableTitleCase; else defaultCase\">\r\n                    {{ value.key | translate : { default: value.value | titlecase } }}\r\n                    </ng-container>\r\n    \r\n                    <ng-template #defaultCase>\r\n                      {{ value.key | translate : { default: value.value } }} \r\n                    </ng-template>\r\n                  </mat-option>\r\n                </ng-container>\r\n              </ng-template>\r\n            </ng-container>\r\n          </mat-select>\r\n        </button>\r\n      </ng-container>\r\n    </ng-container>\r\n  </div>\r\n  <ng-container *ngIf=\"filterOverflow\">\r\n    <div class=\"filter-arrows\">\r\n      <button mat-icon-button (click)=\"switchLeft()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_left\r\n        </span>\r\n      </button>\r\n      <button mat-icon-button (click)=\"switchRight()\">\r\n        <span class=\"material-icons-outlined\">\r\n          chevron_right\r\n        </span>\r\n      </button>\r\n    </div>\r\n  </ng-container>\r\n</div>\r\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJhci1zZXR0aW5ncy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9maWx0ZXItYmFyL21vZGVscy9maWx0ZXItYmFyLXNldHRpbmdzLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJCYXJGaWx0ZXIgfSBmcm9tIFwiLi9maWx0ZXItYmFyLWZpbHRlci5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJCYXJTZXR0aW5ncyB7XHJcbiAgLyoqIFNob3cvaGlkZSBzZWFyY2ggaW5wdXQuIEVuYWJsZWQgYnkgZGVmYXVsdC4gKi9cclxuICBoaWRlU2VhcmNoPzogYm9vbGVhbjtcclxuICAvKiogU2hvdy9oaWRlIHNlYXJjaCBpbnB1dCBjbGVhciBidXR0b24uIERpc2FibGVkIGJ5IGRlZmF1bHQuICovXHJcbiAgc2hvd1NlYXJjaENsZWFyQnV0dG9uPzogYm9vbGVhbjtcclxuICAvKiogVG9nZ2xlIG91dHB1dCBmaWx0ZXIgaXRlbSBiZXR3ZWVuIHZhbHVlLCBhbmQgb2JqZWN0IHdpdGgga2V5IGFuZCB2YWx1ZSBmaWVsZHMuIFZhbHVlIGJ5IGRlZmF1bHQuICovXHJcbiAgb3V0cHV0RmlsdGVyS2V5QW5kVmFsdWU/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsdGVyLWJhci1zZXR0aW5ncy5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9maWx0ZXItYmFyL21vZGVscy9maWx0ZXItYmFyLXNldHRpbmdzLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGaWx0ZXJCYXJGaWx0ZXIgfSBmcm9tIFwiLi9maWx0ZXItYmFyLWZpbHRlci5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBGaWx0ZXJCYXJTZXR0aW5ncyB7XHJcbiAgLyoqIFNob3cvaGlkZSBzZWFyY2ggaW5wdXQuIEVuYWJsZWQgYnkgZGVmYXVsdC4gKi9cclxuICBoaWRlU2VhcmNoPzogYm9vbGVhbjtcclxuICAvKiogU2hvdy9oaWRlIHNlYXJjaCBpbnB1dCBjbGVhciBidXR0b24uIERpc2FibGVkIGJ5IGRlZmF1bHQuICovXHJcbiAgc2hvd1NlYXJjaENsZWFyQnV0dG9uPzogYm9vbGVhbjtcclxuICAvKiogVG9nZ2xlIG91dHB1dCBmaWx0ZXIgaXRlbSBiZXR3ZWVuIHZhbHVlLCBhbmQgb2JqZWN0IHdpdGgga2V5IGFuZCB2YWx1ZSBmaWVsZHMuIFZhbHVlIGJ5IGRlZmF1bHQuICovXHJcbiAgb3V0cHV0RmlsdGVyS2V5QW5kVmFsdWU/OiBib29sZWFuO1xyXG4gIC8qKiBUaXRsZSBmb3Igc2VhcmNoIGlucHV0IGZpZWxkLiBEZWZhdWx0IHZhbHVlOiBGSUxURVJfQkFSLlNFQVJDSCAqL1xyXG4gIHNlYXJjaFRpdGxlPzogc3RyaW5nO1xyXG4gIC8qKiBXaWxkIHNlYXJjaCBlbnRlcmVkIGNyaXRlcmlhLiAqL1xyXG4gIHNlYXJjaElucHV0Pzogc3RyaW5nO1xyXG4gIC8qKiBTZWFyY2ggdG9vbHRpcCwgc2hvd24gYWZ0ZXIgaW5wdXQgZmllbGQgZm9yIGljb24gKi9cclxuICBzZWFyY2hUb29sdGlwPzogc3RyaW5nO1xyXG4gIGhpZGVUb29sdGlwPzogYm9vbGVhbjtcclxuICBmaWx0ZXJzPzogRmlsdGVyQmFyRmlsdGVyW107XHJcbiAgc3BsaXR0ZWRGaWx0ZXJzPzogRmlsdGVyQmFyRmlsdGVyW11bXTtcclxufVxyXG4iXX0=
|
|
@@ -18,9 +18,10 @@ import * as i7 from "@angular/material/checkbox";
|
|
|
18
18
|
import * as i8 from "@angular/forms";
|
|
19
19
|
import * as i9 from "../filter-bar/filter-bar.component";
|
|
20
20
|
import * as i10 from "@ngbracket/ngx-layout/flex";
|
|
21
|
-
import * as i11 from "@
|
|
22
|
-
import * as i12 from "
|
|
23
|
-
import * as i13 from "
|
|
21
|
+
import * as i11 from "@ngbracket/ngx-layout/extended";
|
|
22
|
+
import * as i12 from "@angular/material/tooltip";
|
|
23
|
+
import * as i13 from "../status-display/status-display.component";
|
|
24
|
+
import * as i14 from "@angular/material/icon";
|
|
24
25
|
const _c0 = ["tableContainer"];
|
|
25
26
|
const _c1 = ["filterBar"];
|
|
26
27
|
const _c2 = [[["", "additionalActions", ""]], [["", "batchActions", ""]], "*"];
|
|
@@ -233,7 +234,7 @@ export class MultiFunctionalTableComponent {
|
|
|
233
234
|
this.searchTooltip = this.config.filter?.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';
|
|
234
235
|
this.searchTitle = this.config.filter?.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';
|
|
235
236
|
this.showSearch = !this.config.filter?.settings?.hideSearch;
|
|
236
|
-
this.showSearchClearButton = this.config.filter?.settings?.showSearchClearButton ??
|
|
237
|
+
this.showSearchClearButton = this.config.filter?.settings?.showSearchClearButton ?? true;
|
|
237
238
|
this.hideSearchTooltip = !this.config.filter?.settings?.hideTooltip;
|
|
238
239
|
}
|
|
239
240
|
ngAfterContentInit() {
|
|
@@ -249,6 +250,7 @@ export class MultiFunctionalTableComponent {
|
|
|
249
250
|
//#endregion
|
|
250
251
|
search(event) {
|
|
251
252
|
const input = event.target?.value;
|
|
253
|
+
this.config.filter.settings.searchInput = input;
|
|
252
254
|
this.filterBarChange.emit({ ...this.filters, input });
|
|
253
255
|
}
|
|
254
256
|
updateDisplayColumns(initial = false) {
|
|
@@ -478,7 +480,7 @@ export class MultiFunctionalTableComponent {
|
|
|
478
480
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tableContainer = _t.first);
|
|
479
481
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.filterBar = _t.first);
|
|
480
482
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tableElementRef = _t.first);
|
|
481
|
-
} }, inputs: { config: "config", highlightedElements: "highlightedElements", trackByFn: "trackByFn", highlightedErrorElements: "highlightedErrorElements", selection: "selection", isRowCheckboxAlwaysVisible: "isRowCheckboxAlwaysVisible", disablePreselectedItems: "disablePreselectedItems" }, outputs: { filterBarChange: "filterBarChange", exported: "exported", selectionChange: "selectionChange" }, ngContentSelectors: _c3, decls: 31, vars:
|
|
483
|
+
} }, inputs: { config: "config", highlightedElements: "highlightedElements", trackByFn: "trackByFn", highlightedErrorElements: "highlightedErrorElements", selection: "selection", isRowCheckboxAlwaysVisible: "isRowCheckboxAlwaysVisible", disablePreselectedItems: "disablePreselectedItems" }, outputs: { filterBarChange: "filterBarChange", exported: "exported", selectionChange: "selectionChange" }, ngContentSelectors: _c3, decls: 31, vars: 21, consts: [["tableContainer", ""], ["table", ""], ["columnMenu", "matMenu"], ["wildSearch", ""], ["filterBar", ""], ["fxLayout", "column", "fxLayoutGap", "0.75rem", 3, "ngClass.lt-md"], ["fxLayout", "row", "fxLayout.lt-md", "column", "fxLayoutGap.lt-md", "0.75rem"], ["fxFlex", "", "fxLayout.lt-md", "column", "fxLayoutGap", "0.75rem", "fxLayoutAlign", "start center", "fxLayoutAlign.lt-md", "start start", 1, "action-row"], ["class", "export-data", "mat-stroked-button", "", "color", "primary-accent-darker", 3, "click", 4, "ngIf"], ["fxFlex", "", "fxLayoutGap", "0.5rem", "fxLayoutAlign", "start center", 4, "ngIf"], ["fxLayout", "row", "fxLayoutAlign", "start center", "class", "wild-search-wrapper", 4, "ngIf"], [3, "filterRowVisible", "settings", "filterBarChange", 4, "ngIf"], [1, "table-overflow", 3, "mousedown", "mouseup", "mouseleave", "mousemove"], ["mat-table", "", 3, "dataSource", "trackBy"], [3, "matColumnDef"], ["class", "row-select", "mat-header-cell", "", "disable-export", "", 4, "matHeaderCellDef"], ["class", "row-select", "mat-cell", "", "disable-export", "", 4, "matCellDef"], ["mat-header-row", "", 4, "matHeaderRowDef", "matHeaderRowDefSticky"], ["mat-row", "", 3, "row-clickable", "highlight-error", "highlight", "click", "mouseover", "mouseleave", 4, "matRowDef", "matRowDefColumns"], [4, "ngIf"], [1, "column-select-menu", 3, "click"], [4, "ngFor", "ngForOf"], [1, "column-select-save"], ["mat-flat-button", "", "color", "primary-accent-darker", 3, "click"], ["mat-stroked-button", "", "color", "primary-accent-darker", 1, "export-data", 3, "click"], [1, "material-icons-outlined"], ["fxFlex", "", "fxLayoutGap", "0.5rem", "fxLayoutAlign", "start center"], ["mat-stroked-button", "", "color", "primary-accent-darker", 3, "click"], [1, "material-icons"], ["class", "clear-filters-wrapper", 4, "ngIf"], [1, "clear-filters-wrapper"], ["mat-icon-button", "", 3, "click"], ["fxLayout", "row", "fxLayoutAlign", "start center", 1, "wild-search-wrapper"], [3, "matTooltip"], ["type", "text", 3, "keyup", "placeholder"], ["mat-icon-button", "", "class", "wild-search-clear-btn", 3, "click", 4, "ngIf"], ["mat-icon-button", "", 1, "wild-search-clear-btn", 3, "click"], [3, "filterBarChange", "filterRowVisible", "settings"], ["mat-header-cell", "", "disable-export", "", 1, "row-select"], [3, "change", "matTooltip", "disabled", "checked", "indeterminate"], ["mat-cell", "", "disable-export", "", 1, "row-select"], [3, "matTooltip", "disabled", "checked", "click", "change", 4, "ngIf"], [3, "click", "change", "matTooltip", "disabled", "checked"], ["mat-header-row", ""], ["mat-row", "", 3, "click", "mouseover", "mouseleave"], [1, "column-selector-wrapper"], ["mat-icon-button", "", "color", "primary-accent-darker", 1, "column-selector", 3, "matMenuTriggerFor"], [4, "matNoDataRow"], ["colspan", "99"], [3, "config"], [3, "ngModelChange", "ngModel"]], template: function MultiFunctionalTableComponent_Template(rf, ctx) { if (rf & 1) {
|
|
482
484
|
const _r1 = i0.ɵɵgetCurrentView();
|
|
483
485
|
i0.ɵɵprojectionDef(_c2);
|
|
484
486
|
i0.ɵɵelementStart(0, "div", 5)(1, "div", 6)(2, "div", 7);
|
|
@@ -511,7 +513,8 @@ export class MultiFunctionalTableComponent {
|
|
|
511
513
|
i0.ɵɵpipe(30, "translate");
|
|
512
514
|
i0.ɵɵelementEnd()()()();
|
|
513
515
|
} if (rf & 2) {
|
|
514
|
-
let
|
|
516
|
+
let tmp_14_0;
|
|
517
|
+
i0.ɵɵproperty("ngClass.lt-md", "mobile");
|
|
515
518
|
i0.ɵɵadvance(3);
|
|
516
519
|
i0.ɵɵproperty("ngIf", ctx.exportActive);
|
|
517
520
|
i0.ɵɵadvance();
|
|
@@ -527,7 +530,7 @@ export class MultiFunctionalTableComponent {
|
|
|
527
530
|
i0.ɵɵadvance(3);
|
|
528
531
|
i0.ɵɵproperty("matColumnDef", ctx.batchColumnName);
|
|
529
532
|
i0.ɵɵadvance(3);
|
|
530
|
-
i0.ɵɵproperty("matHeaderRowDef", ctx.displayColumns)("matHeaderRowDefSticky", (
|
|
533
|
+
i0.ɵɵproperty("matHeaderRowDef", ctx.displayColumns)("matHeaderRowDefSticky", (tmp_14_0 = ctx.config == null ? null : ctx.config.stickyHeader) !== null && tmp_14_0 !== undefined ? tmp_14_0 : false);
|
|
531
534
|
i0.ɵɵadvance();
|
|
532
535
|
i0.ɵɵproperty("matRowDefColumns", ctx.displayColumns);
|
|
533
536
|
i0.ɵɵadvance();
|
|
@@ -537,12 +540,12 @@ export class MultiFunctionalTableComponent {
|
|
|
537
540
|
i0.ɵɵadvance(4);
|
|
538
541
|
i0.ɵɵproperty("ngForOf", ctx.configurableColumns);
|
|
539
542
|
i0.ɵɵadvance(3);
|
|
540
|
-
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(30,
|
|
541
|
-
} }, dependencies: [i3.NgForOf, i3.NgIf, i4.MatTable, i4.MatHeaderCellDef, i4.MatHeaderRowDef, i4.MatColumnDef, i4.MatCellDef, i4.MatRowDef, i4.MatHeaderCell, i4.MatCell, i4.MatHeaderRow, i4.MatRow, i4.MatNoDataRow, i5.MatButton, i5.MatIconButton, i6.MatMenu, i6.MatMenuTrigger, i7.MatCheckbox, i8.NgControlStatus, i8.NgModel, i9.FilterBarComponent, i10.DefaultLayoutDirective, i10.DefaultLayoutGapDirective, i10.DefaultLayoutAlignDirective, i10.DefaultFlexDirective, i11.
|
|
543
|
+
i0.ɵɵtextInterpolate(i0.ɵɵpipeBind1(30, 19, "MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT_SAVE"));
|
|
544
|
+
} }, dependencies: [i3.NgForOf, i3.NgIf, i4.MatTable, i4.MatHeaderCellDef, i4.MatHeaderRowDef, i4.MatColumnDef, i4.MatCellDef, i4.MatRowDef, i4.MatHeaderCell, i4.MatCell, i4.MatHeaderRow, i4.MatRow, i4.MatNoDataRow, i5.MatButton, i5.MatIconButton, i6.MatMenu, i6.MatMenuTrigger, i7.MatCheckbox, i8.NgControlStatus, i8.NgModel, i9.FilterBarComponent, i10.DefaultLayoutDirective, i10.DefaultLayoutGapDirective, i10.DefaultLayoutAlignDirective, i10.DefaultFlexDirective, i11.DefaultClassDirective, i12.MatTooltip, i13.StatusDisplayComponent, i14.MatIcon, i2.TranslatePipe], styles: ["[_nghost-%COMP%] th, [_nghost-%COMP%] tr{white-space:nowrap}[_nghost-%COMP%] td:not(:first-of-type){padding-right:10px!important}[_nghost-%COMP%] tr.mat-mdc-row:hover, [_nghost-%COMP%] tr.mat-mdc-row.highlight{background-color:var(--base-95)}[_nghost-%COMP%] tr.mat-mdc-row.highlight-error{background-color:var(--warning-light)}[_nghost-%COMP%] .export-data .mdc-button__label{display:flex;align-items:center}[_nghost-%COMP%] .mat-mdc-cell, [_nghost-%COMP%] .mat-mdc-header-cell, [_nghost-%COMP%] .mdc-data-table__row:last-child{border-bottom-color:var(--base-70)}[_nghost-%COMP%] .mdc-data-table__row:last-child{border-bottom-width:1px;border-bottom-style:solid}[_nghost-%COMP%] .mdc-data-table__cell:nth-child(2), [_nghost-%COMP%] .mdc-data-table__header-cell:nth-child(2){padding:0 16px 0 10px}[_nghost-%COMP%] td+.cdk-column-columnSelect{display:none}[_nghost-%COMP%] .clear-filters-wrapper .mat-mdc-icon-button, [_nghost-%COMP%] .clear-filters-wrapper .mat-mdc-icon-button .mat-mdc-button-touch-target{height:36px!important;width:36px!important}[_nghost-%COMP%] .clear-filters-wrapper mat-icon{margin-top:-2px;margin-left:-2px}[_nghost-%COMP%] .filter-active{background-color:var(--neutral-95)}table[_ngcontent-%COMP%]{width:100%}.wild-search-wrapper[_ngcontent-%COMP%]{position:relative;padding:5px 10px;border-radius:4px;border:1px solid var(--neutral-50);margin:0 8px}.wild-search-wrapper[_ngcontent-%COMP%] input[_ngcontent-%COMP%]{margin-right:30px}.wild-search-wrapper[_ngcontent-%COMP%] .wild-search-clear-btn[_ngcontent-%COMP%]{position:absolute;right:3px}.wild-search-wrapper[_ngcontent-%COMP%] .mat-mdc-icon-button[_ngcontent-%COMP%], .wild-search-wrapper[_ngcontent-%COMP%] .mat-mdc-icon-button[_ngcontent-%COMP%] .mat-mdc-button-touch-target[_ngcontent-%COMP%]{height:33px!important;width:33px!important}.wild-search-wrapper[_ngcontent-%COMP%] .mat-mdc-icon-button[_ngcontent-%COMP%] mat-icon[_ngcontent-%COMP%], .wild-search-wrapper[_ngcontent-%COMP%] .mat-mdc-icon-button[_ngcontent-%COMP%] .material-icons[_ngcontent-%COMP%], .wild-search-wrapper[_ngcontent-%COMP%] .mat-mdc-icon-button[_ngcontent-%COMP%] .material-icons-outlined[_ngcontent-%COMP%]{top:5px!important;left:5px!important}.mobile[_ngcontent-%COMP%] .wild-search-wrapper[_ngcontent-%COMP%]{margin:0}.column-selector-wrapper[_ngcontent-%COMP%]{display:flex;justify-content:end}.column-select-menu[_ngcontent-%COMP%]{padding:8px 18px 8px 8px}.column-select-save[_ngcontent-%COMP%]{padding-left:8px;padding-top:8px}.column-select-save[_ngcontent-%COMP%] button[_ngcontent-%COMP%]{width:100%}.row-clickable[_ngcontent-%COMP%]{cursor:pointer}.row-clickable[_ngcontent-%COMP%]:active{background-color:var(--base-70)!important}.material-icons[_ngcontent-%COMP%], .material-icons-outlined[_ngcontent-%COMP%]{margin-right:.5rem}.table-action-button[_ngcontent-%COMP%]{margin-bottom:1rem}th.mat-mdc-header-cell[_ngcontent-%COMP%]:first-of-type, td.mat-mdc-cell[_ngcontent-%COMP%]:first-of-type, td.mat-mdc-footer-cell[_ngcontent-%COMP%]:first-of-type{padding:0 0 0 10px}.row-select[_ngcontent-%COMP%]{width:0}.table-overflow[_ngcontent-%COMP%]{overflow-x:auto}.table-dragable[_ngcontent-%COMP%]{cursor:grab;-webkit-user-select:none;user-select:none}.table-dragable[_ngcontent-%COMP%]:active{cursor:grabbing}.table-sticky-header[_ngcontent-%COMP%]{max-height:70vh}"] }); }
|
|
542
545
|
}
|
|
543
546
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(MultiFunctionalTableComponent, [{
|
|
544
547
|
type: Component,
|
|
545
|
-
args: [{ selector: 'tld-multi-functional-table', template: "<div fxLayout=\"column\" fxLayoutGap=\"0.75rem\">\r\n\r\n <div fxLayout=\"row\" fxLayout.lt-md=\"column\" fxLayoutGap.lt-md=\"0.75rem\">\r\n <div fxFlex fxLayout.lt-md=\"column\" fxLayoutGap=\"0.75rem\" fxLayoutAlign=\"start center\" fxLayoutAlign.lt-md=\"start start\" class=\"action-row\">\r\n <button class=\"export-data\" mat-stroked-button color=\"primary-accent-darker\" *ngIf=\"exportActive\" (click)=\"export()\">\r\n <span class=\"material-icons-outlined\">cloud_download</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n </button>\r\n\r\n <div *ngIf=\"filterActive && showFilterToggle\" fxFlex fxLayoutGap=\"0.5rem\" fxLayoutAlign=\"start center\">\r\n <button [class.filter-active]=\"filterBarVisible\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"toggleFilterBar()\">\r\n <span class=\"material-icons\">filter_list</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n </button>\r\n \r\n <div *ngIf=\"showFilterReset\" class=\"clear-filters-wrapper\">\r\n <button mat-icon-button (click)=\"clearFilters()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"showSearch\" fxLayout=\"row\" fxLayoutAlign=\"start center\" class=\"wild-search-wrapper\">\r\n <mat-icon [matTooltip]=\"hideSearchTooltip ? '' : searchTooltip | translate\">search</mat-icon>\r\n <input #wildSearch type=\"text\" [placeholder]=\"searchTitle | translate\" (keyup)=\"search($event)\">\r\n <button *ngIf=\"showSearchClearButton\" mat-icon-button class=\"wild-search-clear-btn\" (click)=\"wildSearch.value = ''; search({ target: { value: '' } })\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n\r\n <ng-content select=\"[additionalActions]\"></ng-content>\r\n </div>\r\n\r\n <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" #filterBar [filterRowVisible]=\"filterBarVisible\" [settings]=\"config.filter.settings\"\r\n (filterBarChange)=\"filtersChanged($event)\">\r\n </tld-filter-bar>\r\n\r\n <ng-content select=\"[batchActions]\"></ng-content>\r\n\r\n <div \r\n #tableContainer\r\n class=\"table-overflow\"\r\n [class.table-sticky-header]=\"config?.stickyHeader\"\r\n [class.table-dragable]=\"tableOverflow\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (mouseup)=\"onMouseUp()\"\r\n (mouseleave)=\"onMouseUp()\"\r\n (mousemove)=\"onMouseMove($event)\"\r\n >\r\n <table #table mat-table [dataSource]=\"config.dataSource\" [trackBy]=\"trackByFn\">\r\n <ng-content></ng-content>\r\n <ng-container [matColumnDef]=\"batchColumnName\">\r\n <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n </mat-checkbox>\r\n </th>\r\n <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n <mat-checkbox \r\n [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" \r\n [disabled]=\"config.batchConfig!.checkBoxesDisabled || (preselectedItems.includes(element) && disablePreselectedItems)\" (click)=\"$event.stopPropagation()\"\r\n (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n </mat-checkbox>\r\n </td>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"displayColumns; sticky: config?.stickyHeader ?? false\"></tr>\r\n <tr \r\n mat-row \r\n *matRowDef=\"let row; \r\n columns: displayColumns\" \r\n (click)=\"config?.rowClickCallback && !config?.disableRowClick(row) ? config?.rowClickCallback(row) : null\"\r\n (mouseover)=\"hoveredRow = row\" \r\n (mouseleave)=\"hoveredRow = null\" \r\n [class.row-clickable]=\"config?.rowClickCallback && !config?.disableRowClick(row)\" \r\n [class.highlight-error]=\"highlightErrorElement(row)\" \r\n [class.highlight]=\"row === hoveredRow || highlightElement(row)\">\r\n </tr>\r\n \r\n <ng-container [matColumnDef]=\"columnSelectColumnName\">\r\n <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n <div class=\"column-selector-wrapper\">\r\n <button class=\"column-selector\" mat-icon-button color=\"primary-accent-darker\" [matMenuTriggerFor]=\"columnMenu\">\r\n <span class=\"material-icons\">more_vert</span>\r\n </button>\r\n </div>\r\n </th>\r\n <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n </td>\r\n </ng-container>\r\n <ng-container *ngIf=\"noDataRowActive\">\r\n <tr *matNoDataRow>\r\n <!-- add random number to make sure it takes full width -->\r\n <td colspan=\"99\">\r\n <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n</div>\r\n\r\n<mat-menu #columnMenu=\"matMenu\">\r\n <div class=\"column-select-menu\" (click)=\"$event.stopPropagation()\">\r\n <div *ngFor=\"let column of configurableColumns\">\r\n <mat-checkbox [(ngModel)]=\"column.selected\">\r\n {{column.displayName | translate}}\r\n </mat-checkbox>\r\n </div>\r\n\r\n <div class=\"column-select-save\">\r\n <button mat-flat-button color=\"primary-accent-darker\" (click)=\"updateDisplayColumns()\">{{ \"MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT_SAVE\" | translate }}</button>\r\n </div>\r\n </div>\r\n</mat-menu>\r\n", styles: [":host ::ng-deep th,:host ::ng-deep tr{white-space:nowrap}:host ::ng-deep td:not(:first-of-type){padding-right:10px!important}:host ::ng-deep tr.mat-mdc-row:hover,:host ::ng-deep tr.mat-mdc-row.highlight{background-color:var(--base-95)}:host ::ng-deep tr.mat-mdc-row.highlight-error{background-color:var(--warning-light)}:host ::ng-deep .export-data .mdc-button__label{display:flex;align-items:center}:host ::ng-deep .mat-mdc-cell,:host ::ng-deep .mat-mdc-header-cell,:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-color:var(--base-70)}:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-width:1px;border-bottom-style:solid}:host ::ng-deep .mdc-data-table__cell:nth-child(2),:host ::ng-deep .mdc-data-table__header-cell:nth-child(2){padding:0 16px 0 10px}:host ::ng-deep td+.cdk-column-columnSelect{display:none}:host ::ng-deep .clear-filters-wrapper .mat-mdc-icon-button,:host ::ng-deep .clear-filters-wrapper .mat-mdc-icon-button .mat-mdc-button-touch-target{height:36px!important;width:36px!important}:host ::ng-deep .clear-filters-wrapper mat-icon{margin-top:-2px;margin-left:-2px}:host ::ng-deep .filter-active{background-color:var(--neutral-95)}table{width:100%}.wild-search-wrapper{position:relative;padding:5px 10px;border-radius:4px;border:1px solid var(--neutral-50);margin:0 8px}.wild-search-wrapper input{margin-right:30px}.wild-search-wrapper .wild-search-clear-btn{position:absolute;right:3px}.wild-search-wrapper .mat-mdc-icon-button,.wild-search-wrapper .mat-mdc-icon-button .mat-mdc-button-touch-target{height:33px!important;width:33px!important}.wild-search-wrapper .mat-mdc-icon-button mat-icon,.wild-search-wrapper .mat-mdc-icon-button .material-icons,.wild-search-wrapper .mat-mdc-icon-button .material-icons-outlined{top:5px!important;left:5px!important}.column-selector-wrapper{display:flex;justify-content:end}.column-select-menu{padding:8px 18px 8px 8px}.column-select-save{padding-left:8px;padding-top:8px}.column-select-save button{width:100%}.row-clickable{cursor:pointer}.row-clickable:active{background-color:var(--base-70)!important}.material-icons,.material-icons-outlined{margin-right:.5rem}.table-action-button{margin-bottom:1rem}th.mat-mdc-header-cell:first-of-type,td.mat-mdc-cell:first-of-type,td.mat-mdc-footer-cell:first-of-type{padding:0 0 0 10px}.row-select{width:0}.table-overflow{overflow-x:auto}.table-dragable{cursor:grab;-webkit-user-select:none;user-select:none}.table-dragable:active{cursor:grabbing}.table-sticky-header{max-height:70vh}\n"] }]
|
|
548
|
+
args: [{ selector: 'tld-multi-functional-table', template: "<div [ngClass.lt-md]=\"'mobile'\" fxLayout=\"column\" fxLayoutGap=\"0.75rem\">\r\n\r\n <div fxLayout=\"row\" fxLayout.lt-md=\"column\" fxLayoutGap.lt-md=\"0.75rem\">\r\n <div fxFlex fxLayout.lt-md=\"column\" fxLayoutGap=\"0.75rem\" fxLayoutAlign=\"start center\" fxLayoutAlign.lt-md=\"start start\" class=\"action-row\">\r\n <button class=\"export-data\" mat-stroked-button color=\"primary-accent-darker\" *ngIf=\"exportActive\" (click)=\"export()\">\r\n <span class=\"material-icons-outlined\">cloud_download</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n </button>\r\n\r\n <div *ngIf=\"filterActive && showFilterToggle\" fxFlex fxLayoutGap=\"0.5rem\" fxLayoutAlign=\"start center\">\r\n <button [class.filter-active]=\"filterBarVisible\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"toggleFilterBar()\">\r\n <span class=\"material-icons\">filter_list</span>\r\n <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n </button>\r\n \r\n <div *ngIf=\"showFilterReset\" class=\"clear-filters-wrapper\">\r\n <button mat-icon-button (click)=\"clearFilters()\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"showSearch\" fxLayout=\"row\" fxLayoutAlign=\"start center\" class=\"wild-search-wrapper\">\r\n <mat-icon [matTooltip]=\"hideSearchTooltip ? '' : searchTooltip | translate\">search</mat-icon>\r\n <input #wildSearch type=\"text\" [placeholder]=\"searchTitle | translate\" (keyup)=\"search($event)\">\r\n <button *ngIf=\"showSearchClearButton\" mat-icon-button class=\"wild-search-clear-btn\" (click)=\"wildSearch.value = ''; search({ target: { value: '' } })\">\r\n <mat-icon>close</mat-icon>\r\n </button>\r\n </div>\r\n\r\n <ng-content select=\"[additionalActions]\"></ng-content>\r\n </div>\r\n\r\n <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" #filterBar [filterRowVisible]=\"filterBarVisible\" [settings]=\"config.filter.settings\"\r\n (filterBarChange)=\"filtersChanged($event)\">\r\n </tld-filter-bar>\r\n\r\n <ng-content select=\"[batchActions]\"></ng-content>\r\n\r\n <div \r\n #tableContainer\r\n class=\"table-overflow\"\r\n [class.table-sticky-header]=\"config?.stickyHeader\"\r\n [class.table-dragable]=\"tableOverflow\"\r\n (mousedown)=\"onMouseDown($event)\"\r\n (mouseup)=\"onMouseUp()\"\r\n (mouseleave)=\"onMouseUp()\"\r\n (mousemove)=\"onMouseMove($event)\"\r\n >\r\n <table #table mat-table [dataSource]=\"config.dataSource\" [trackBy]=\"trackByFn\">\r\n <ng-content></ng-content>\r\n <ng-container [matColumnDef]=\"batchColumnName\">\r\n <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n </mat-checkbox>\r\n </th>\r\n <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n <mat-checkbox \r\n [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" \r\n [disabled]=\"config.batchConfig!.checkBoxesDisabled || (preselectedItems.includes(element) && disablePreselectedItems)\" (click)=\"$event.stopPropagation()\"\r\n (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n </mat-checkbox>\r\n </td>\r\n </ng-container>\r\n <tr mat-header-row *matHeaderRowDef=\"displayColumns; sticky: config?.stickyHeader ?? false\"></tr>\r\n <tr \r\n mat-row \r\n *matRowDef=\"let row; \r\n columns: displayColumns\" \r\n (click)=\"config?.rowClickCallback && !config?.disableRowClick(row) ? config?.rowClickCallback(row) : null\"\r\n (mouseover)=\"hoveredRow = row\" \r\n (mouseleave)=\"hoveredRow = null\" \r\n [class.row-clickable]=\"config?.rowClickCallback && !config?.disableRowClick(row)\" \r\n [class.highlight-error]=\"highlightErrorElement(row)\" \r\n [class.highlight]=\"row === hoveredRow || highlightElement(row)\">\r\n </tr>\r\n \r\n <ng-container [matColumnDef]=\"columnSelectColumnName\">\r\n <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n <div class=\"column-selector-wrapper\">\r\n <button class=\"column-selector\" mat-icon-button color=\"primary-accent-darker\" [matMenuTriggerFor]=\"columnMenu\">\r\n <span class=\"material-icons\">more_vert</span>\r\n </button>\r\n </div>\r\n </th>\r\n <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n </td>\r\n </ng-container>\r\n <ng-container *ngIf=\"noDataRowActive\">\r\n <tr *matNoDataRow>\r\n <!-- add random number to make sure it takes full width -->\r\n <td colspan=\"99\">\r\n <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n </td>\r\n </tr>\r\n </ng-container>\r\n </table>\r\n </div>\r\n</div>\r\n\r\n<mat-menu #columnMenu=\"matMenu\">\r\n <div class=\"column-select-menu\" (click)=\"$event.stopPropagation()\">\r\n <div *ngFor=\"let column of configurableColumns\">\r\n <mat-checkbox [(ngModel)]=\"column.selected\">\r\n {{column.displayName | translate}}\r\n </mat-checkbox>\r\n </div>\r\n\r\n <div class=\"column-select-save\">\r\n <button mat-flat-button color=\"primary-accent-darker\" (click)=\"updateDisplayColumns()\">{{ \"MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT_SAVE\" | translate }}</button>\r\n </div>\r\n </div>\r\n</mat-menu>\r\n", styles: [":host ::ng-deep th,:host ::ng-deep tr{white-space:nowrap}:host ::ng-deep td:not(:first-of-type){padding-right:10px!important}:host ::ng-deep tr.mat-mdc-row:hover,:host ::ng-deep tr.mat-mdc-row.highlight{background-color:var(--base-95)}:host ::ng-deep tr.mat-mdc-row.highlight-error{background-color:var(--warning-light)}:host ::ng-deep .export-data .mdc-button__label{display:flex;align-items:center}:host ::ng-deep .mat-mdc-cell,:host ::ng-deep .mat-mdc-header-cell,:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-color:var(--base-70)}:host ::ng-deep .mdc-data-table__row:last-child{border-bottom-width:1px;border-bottom-style:solid}:host ::ng-deep .mdc-data-table__cell:nth-child(2),:host ::ng-deep .mdc-data-table__header-cell:nth-child(2){padding:0 16px 0 10px}:host ::ng-deep td+.cdk-column-columnSelect{display:none}:host ::ng-deep .clear-filters-wrapper .mat-mdc-icon-button,:host ::ng-deep .clear-filters-wrapper .mat-mdc-icon-button .mat-mdc-button-touch-target{height:36px!important;width:36px!important}:host ::ng-deep .clear-filters-wrapper mat-icon{margin-top:-2px;margin-left:-2px}:host ::ng-deep .filter-active{background-color:var(--neutral-95)}table{width:100%}.wild-search-wrapper{position:relative;padding:5px 10px;border-radius:4px;border:1px solid var(--neutral-50);margin:0 8px}.wild-search-wrapper input{margin-right:30px}.wild-search-wrapper .wild-search-clear-btn{position:absolute;right:3px}.wild-search-wrapper .mat-mdc-icon-button,.wild-search-wrapper .mat-mdc-icon-button .mat-mdc-button-touch-target{height:33px!important;width:33px!important}.wild-search-wrapper .mat-mdc-icon-button mat-icon,.wild-search-wrapper .mat-mdc-icon-button .material-icons,.wild-search-wrapper .mat-mdc-icon-button .material-icons-outlined{top:5px!important;left:5px!important}.mobile .wild-search-wrapper{margin:0}.column-selector-wrapper{display:flex;justify-content:end}.column-select-menu{padding:8px 18px 8px 8px}.column-select-save{padding-left:8px;padding-top:8px}.column-select-save button{width:100%}.row-clickable{cursor:pointer}.row-clickable:active{background-color:var(--base-70)!important}.material-icons,.material-icons-outlined{margin-right:.5rem}.table-action-button{margin-bottom:1rem}th.mat-mdc-header-cell:first-of-type,td.mat-mdc-cell:first-of-type,td.mat-mdc-footer-cell:first-of-type{padding:0 0 0 10px}.row-select{width:0}.table-overflow{overflow-x:auto}.table-dragable{cursor:grab;-webkit-user-select:none;user-select:none}.table-dragable:active{cursor:grabbing}.table-sticky-header{max-height:70vh}\n"] }]
|
|
546
549
|
}], () => [{ type: i1.DOMService }, { type: i2.TranslateService }], { config: [{
|
|
547
550
|
type: Input
|
|
548
551
|
}], highlightedElements: [{
|
|
@@ -592,4 +595,4 @@ export class MultiFunctionalTableComponent {
|
|
|
592
595
|
args: [MatTable, { read: ElementRef }]
|
|
593
596
|
}] }); })();
|
|
594
597
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(MultiFunctionalTableComponent, { className: "MultiFunctionalTableComponent", filePath: "lib\\multi-functional-table\\multi-functional-table.component.ts", lineNumber: 25 }); })();
|
|
595
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-functional-table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.ts","../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\r\nimport { AfterContentInit, AfterViewInit, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChild } from '@angular/core';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatColumnDef, MatHeaderRowDef, MatNoDataRow, MatRowDef, MatTable } from '@angular/material/table';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { map, Observable, take } from 'rxjs';\r\nimport { FilterBarChangeEvent } from '../filter-bar/models/filter-bar-change-event.model';\r\nimport { HtmlElementParseHelper } from '../helpers';\r\nimport { SaveFileHelper } from '../helpers/save-file.helper';\r\nimport { DOMService } from '../services';\r\nimport { DISABLE_EXPORT_ATTRIBUTE_NAME } from './constants/disable-export-attribute-name.const';\r\nimport { ExportFormat } from './models';\r\nimport { ColumnConfig } from './models/column-config.model';\r\nimport { MultiFunctionalTableConfig } from './models/multi-functional-table-config.model';\r\nimport { SelectedColumnLocalStorageConfig } from './models/selected-column-local-storage-config.model';\r\nimport { StatusDisplayConfig } from '../status-display/models/status-display-config.model';\r\nimport { FilterBarComponent } from '../filter-bar';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-multi-functional-table',\r\n  templateUrl: './multi-functional-table.component.html',\r\n  styleUrls: ['./multi-functional-table.component.scss']\r\n})\r\nexport class MultiFunctionalTableComponent<T> implements OnInit, AfterContentInit, AfterViewInit {\r\n  readonly matSelection = new SelectionModel<T>(true, []);\r\n\r\n  @Input() config!: MultiFunctionalTableConfig<T>;\r\n  @Input() highlightedElements!: T[];\r\n  @Input() trackByFn!: (ix: number, row: T) => string | number;\r\n  @Input() highlightedErrorElements!: T[];\r\n  @Input() set selection(value: T[]) {\r\n    this.matSelection.setSelection(...(value ?? []));\r\n  }\r\n\r\n  // Set this to false if you want to display checkboxes only on row hover.\r\n  @Input() isRowCheckboxAlwaysVisible = true;\r\n\r\n  @Input() disablePreselectedItems = false;\r\n\r\n  //#region Output properties\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n  @Output() exported: EventEmitter<T[]> = new EventEmitter<T[]>();\r\n  @Output() selectionChange: Observable<T[]> = this.matSelection.changed.asObservable().pipe(map(() => { return this.matSelection.selected; }));\r\n  //#endregion\r\n\r\n  // #region Properties for mat table wrapper\r\n  @ContentChildren(MatHeaderRowDef) headerRowDefs!: QueryList<MatHeaderRowDef>;\r\n  @ContentChildren(MatRowDef, { descendants: true }) rowDefs!: QueryList<MatRowDef<T>>;\r\n  @ContentChildren(MatColumnDef) columnDefs!: QueryList<MatColumnDef>;\r\n  @ContentChild(MatNoDataRow) noDataRow!: MatNoDataRow;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<T>;\r\n  @ViewChild(MatSort) sort!: MatSort;\r\n\r\n  @ViewChild('tableContainer') tableContainer!: ElementRef<HTMLElement>;\r\n  @ViewChild('filterBar') filterBar!: FilterBarComponent;\r\n  //#endregion\r\n\r\n  @ViewChild(MatTable, { read: ElementRef }) tableElementRef!: ElementRef<HTMLElement>;\r\n\r\n  preselectedItems!: T[];\r\n\r\n  get ignoreAttributeName() { return DISABLE_EXPORT_ATTRIBUTE_NAME }\r\n  displayColumns!: string[];\r\n\r\n  columnSelectActive!: boolean;\r\n  exportActive!: boolean;\r\n  noDataRowActive!: boolean;\r\n\r\n  filters!: FilterBarChangeEvent;\r\n  filterBarVisible!: boolean;\r\n\r\n  hideSearchTooltip!: boolean;\r\n  showSearch!: boolean;\r\n  showSearchClearButton!: boolean;\r\n  searchTitle!: string;\r\n  searchTooltip!: string;\r\n\r\n  noDataRowConfig!: StatusDisplayConfig;\r\n  noDataRowIcon = \"manage_search\";\r\n\r\n  configurableColumns!: ColumnConfig[];\r\n  batchSelectedEnabled!: boolean;\r\n\r\n  // is used in html to display batch checkbox on hovered row\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  hoveredRow: any;\r\n\r\n  // properties for overflow scrolling with mouse click\r\n  tableOverflow!: boolean;\r\n  private scrollMovement!: number | null;\r\n  private isDragging = false;\r\n  private startX = 0;\r\n  private startY = 0;\r\n  private scrollLeft = 0;\r\n  private scrollTop = 0;\r\n\r\n  get filterActive() { return this.config.filter?.enabled; }\r\n  get showFilterToggle() { return !this.config.filter?.hideFilterToggle; }\r\n\r\n  get showFilterReset() { return this.config.filter?.settings.filters?.find(filter => filter.selectedValues?.length) }\r\n\r\n  private localStorageValue!: SelectedColumnLocalStorageConfig;\r\n  readonly batchColumnName = \"batch\";\r\n  readonly columnSelectColumnName = \"columnSelect\";\r\n\r\n  constructor(private readonly domService: DOMService,\r\n    private readonly translateService: TranslateService) { }\r\n\r\n  //#region Angular lifecycle hooks\r\n  ngOnInit(): void {\r\n    this.readFromLocalStorage();\r\n    this.setFilterVisibility();\r\n    this.setColumnSelectProperties();\r\n    this.setExportProperties();\r\n    this.setNoDataRowProperties();\r\n    this.preselectedItems = this.matSelection.selected;\r\n    this.searchTooltip = this.config.filter?.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';\r\n    this.searchTitle = this.config.filter?.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';\r\n    this.showSearch = !this.config.filter?.settings?.hideSearch;\r\n    this.showSearchClearButton = this.config.filter?.settings?.showSearchClearButton ?? false;\r\n    this.hideSearchTooltip = !this.config.filter?.settings?.hideTooltip;\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.columnDefs.forEach(columnDef => this.table.addColumnDef(columnDef));\r\n    this.rowDefs.forEach(rowDef => this.table.addRowDef(rowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.table.setNoDataRow(this.noDataRow);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.config.dataSource.sort = this.sort;\r\n  }\r\n  //#endregion\r\n\r\n  search(event: { target: { value: string } } | KeyboardEvent): void {\r\n    const input = (event.target as HTMLInputElement)?.value;\r\n    this.filterBarChange.emit({ ...this.filters, input });    \r\n  }\r\n\r\n  updateDisplayColumns(initial = false) {\r\n    this.batchSelectedEnabled = this.config.batchConfig?.enabled ? true : false;\r\n    const allColumns = this.config.columnSelect?.columns ?? [];\r\n    this.displayColumns = [];\r\n    this.configurableColumns = allColumns.filter(column => !column.notConfigurable);\r\n\r\n    if (this.batchSelectedEnabled) {\r\n      this.displayColumns.push(this.batchColumnName);\r\n    }\r\n\r\n    if (!allColumns.length) {\r\n      return;\r\n    }\r\n\r\n    const localStorageValue = this.localStorageValue ?? {};\r\n    if (!localStorageValue.columns) {\r\n      localStorageValue.columns = {};\r\n    }\r\n\r\n    allColumns.forEach((column) => {\r\n      if (initial) {\r\n        column.selected = localStorageValue.columns?.[column.name] ?? column.selected;\r\n      } else {\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        localStorageValue.columns![column.name] = column.selected;\r\n      }\r\n      \r\n      if (column.selected) {\r\n        this.displayColumns.push(column.name);\r\n      }\r\n    })\r\n\r\n    if (this.columnSelectActive) {\r\n      this.displayColumns.push(this.columnSelectColumnName);\r\n    }\r\n\r\n    if (!initial) {\r\n      this.updateLocalStorage(localStorageValue);\r\n    }\r\n  }\r\n\r\n  toggleFilterBar() {\r\n    const localstorageObject = this.localStorageValue ?? {};\r\n    if (!localstorageObject.filter) {\r\n      localstorageObject.filter = {};\r\n    }\r\n\r\n    this.filterBarVisible = !this.filterBarVisible;\r\n    localstorageObject.filter.visible = this.filterBarVisible;\r\n    this.updateLocalStorage(localstorageObject);\r\n  }\r\n\r\n  filtersChanged(filters: FilterBarChangeEvent) {\r\n    this.filters = filters;\r\n    this.filterBarChange.emit(this.filters);\r\n  }\r\n\r\n  clearFilters() {\r\n    this.config.filter?.settings.filters?.forEach((filter) => {\r\n      filter.selectedValues = [];\r\n    })\r\n\r\n    this.filterBar.removeAllFilters();\r\n  }\r\n\r\n  export() {\r\n    this.config.dataSource.connect().pipe(take(1)).subscribe((data) => {\r\n      this.exported.emit(data);\r\n    })\r\n\r\n    if (this.config.export?.fileOptions) {\r\n      this.exportToFile()\r\n    }\r\n  }\r\n\r\n  highlightElement(element: T) {\r\n    return this.highlightedElements?.includes(element);\r\n  }\r\n\r\n  highlightErrorElement(element: T) {\r\n    return this.highlightedErrorElements?.includes(element);\r\n  }\r\n\r\n  //#region Methods for batch selection\r\n  isAllSelected() {\r\n    const numSelected = this.matSelection.selected.length;\r\n    const numRows = this.config.dataSource.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  toggleAllRowSelection() {\r\n    if (this.isAllSelected()) {\r\n      if (this.disablePreselectedItems) {\r\n        // deselect only those items which were not already preselected\r\n        this.matSelection.deselect(\r\n          ...this.matSelection.selected.filter(elm => !this.preselectedItems.map(elm => elm).includes(elm))\r\n        );\r\n        return;\r\n      }\r\n      else {\r\n        this.matSelection.clear();\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.matSelection.select(...this.config.dataSource.data);\r\n  }\r\n\r\n  toggleElementSelection(element: T) {\r\n    this.matSelection.toggle(element);\r\n  }\r\n\r\n  onMouseDown(event: MouseEvent) {\r\n    this.isDragging = true;\r\n    this.startX = event.pageX - this.tableContainer.nativeElement.offsetLeft;\r\n    this.startY = event.pageY - this.tableContainer.nativeElement.offsetTop;\r\n    this.scrollLeft = this.tableContainer.nativeElement.scrollLeft;\r\n    this.scrollTop = this.tableContainer.nativeElement.scrollTop;\r\n\r\n    // canceling any previous animation frame\r\n    if (this.scrollMovement !== null) {\r\n      cancelAnimationFrame(this.scrollMovement);\r\n    }\r\n  }\r\n  \r\n  onMouseMove(event: MouseEvent) {\r\n    this.checkTableOverflow();\r\n\r\n    if (!this.isDragging) {\r\n      return;\r\n    }\r\n\r\n     // using requestAnimationFrame for smoother updates\r\n     if (this.scrollMovement === null) {\r\n      this.scrollMovement = requestAnimationFrame(() => {\r\n        if (!this.tableOverflow) {\r\n          return;\r\n        }\r\n        \r\n        const x = event.pageX - this.tableContainer.nativeElement.offsetLeft;\r\n        const y = event.pageY - this.tableContainer.nativeElement.offsetTop;\r\n\r\n        // calculating the differences in movement\r\n        const walkX = (x - this.startX) * 2;\r\n        const walkY = (y - this.startY) * 2;\r\n\r\n        // updating scroll positions\r\n        this.tableContainer.nativeElement.scrollLeft = this.scrollLeft - walkX;\r\n        this.tableContainer.nativeElement.scrollTop = this.scrollTop - walkY;\r\n\r\n        this.scrollMovement = null;\r\n      });\r\n    }\r\n  }\r\n  \r\n  onMouseUp() {\r\n    this.isDragging = false;\r\n\r\n    // canceling any pending animation\r\n    if (this.scrollMovement !== null) {\r\n      cancelAnimationFrame(this.scrollMovement);\r\n      this.scrollMovement = null;\r\n    }\r\n  }\r\n  //#endregion\r\n\r\n  private checkTableOverflow(): void {\r\n    // when data is available we should check once for table overflow\r\n    // when there wasnt overflow, but width of the table became bigger, then we are reseting tableOverflow variable\r\n    // same for when there was overflow, but size of the table is same as container, so overflow is gone and we reseting tableOverflow variable again\r\n    if ((this.config.dataSource.data.length &&  this.tableOverflow === undefined) ||\r\n      (!this.tableOverflow && this.tableContainer.nativeElement.clientWidth <  this.tableElementRef.nativeElement.clientWidth) ||\r\n      (this.tableOverflow && this.tableContainer.nativeElement.clientWidth === this.tableElementRef.nativeElement.clientWidth)) {\r\n\r\n        if (this.tableContainer.nativeElement.clientWidth < this.tableElementRef.nativeElement.clientWidth) {\r\n          this.tableOverflow = true;\r\n        } else {\r\n          this.tableOverflow = false;\r\n        }\r\n    }\r\n  }\r\n\r\n  private exportToFile() {\r\n    if (!this.config.export?.fileOptions?.saveToFile) {\r\n      return;\r\n    }\r\n\r\n    let fileString = \"\";\r\n    let extension!: ExportFormat;\r\n    switch (this.config.export.fileOptions.format) {\r\n      case ExportFormat.CSV:\r\n      default:\r\n        extension = ExportFormat.CSV;\r\n        fileString = HtmlElementParseHelper.tableAsCsv(this.tableElementRef.nativeElement, this.ignoreAttributeName);\r\n        break;\r\n    }\r\n    const translatedFileName = this.translateService.instant(this.config.export.fileOptions.fileName);\r\n    SaveFileHelper.saveFile(fileString, `${translatedFileName}.${extension}`);\r\n  }\r\n\r\n  private updateLocalStorage(newValue: SelectedColumnLocalStorageConfig) {\r\n    this.localStorageValue = newValue;\r\n    if (this.config.localStorageKey && newValue) {\r\n      this.domService.localStorage?.setItem(this.config.localStorageKey, JSON.stringify(newValue));\r\n    }\r\n  }\r\n  private readFromLocalStorage() {\r\n    if (this.config.localStorageKey) {\r\n      try {\r\n        const localStorageString = this.domService.localStorage?.getItem(this.config.localStorageKey);\r\n        if (localStorageString) {\r\n          this.localStorageValue = JSON.parse(localStorageString);\r\n        }\r\n      }\r\n      // eslint-disable-next-line no-empty\r\n      catch {\r\n      }\r\n    }\r\n  }\r\n\r\n  private setColumnSelectProperties() {\r\n    this.columnSelectActive = this.config.columnSelect?.enabled ? true : false;\r\n    this.updateDisplayColumns(true);\r\n  }\r\n\r\n  private setFilterVisibility() {\r\n    this.filterBarVisible = this.localStorageValue?.filter?.visible ?? this.config?.filter?.visible ?? false;\r\n  }\r\n\r\n  private setNoDataRowProperties() {\r\n    if (this.config.noDataRow) {\r\n      this.noDataRowActive = true;\r\n      this.noDataRowConfig = this.config.noDataRow;\r\n      this.noDataRowConfig.icon = this.config.noDataRow?.icon ?? this.noDataRowIcon;\r\n    }\r\n  }\r\n\r\n  private setExportProperties() {\r\n    if (this.config.export?.enabled) {\r\n      this.exportActive = true;\r\n    }\r\n  }\r\n}\r\n","<div fxLayout=\"column\" fxLayoutGap=\"0.75rem\">\r\n\r\n  <div fxLayout=\"row\" fxLayout.lt-md=\"column\" fxLayoutGap.lt-md=\"0.75rem\">\r\n    <div fxFlex fxLayout.lt-md=\"column\" fxLayoutGap=\"0.75rem\" fxLayoutAlign=\"start center\" fxLayoutAlign.lt-md=\"start start\" class=\"action-row\">\r\n      <button class=\"export-data\" mat-stroked-button color=\"primary-accent-darker\" *ngIf=\"exportActive\" (click)=\"export()\">\r\n        <span class=\"material-icons-outlined\">cloud_download</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n      </button>\r\n\r\n      <div *ngIf=\"filterActive && showFilterToggle\" fxFlex fxLayoutGap=\"0.5rem\" fxLayoutAlign=\"start center\">\r\n        <button [class.filter-active]=\"filterBarVisible\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"toggleFilterBar()\">\r\n          <span class=\"material-icons\">filter_list</span>\r\n          <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n        </button>\r\n  \r\n        <div *ngIf=\"showFilterReset\" class=\"clear-filters-wrapper\">\r\n          <button mat-icon-button (click)=\"clearFilters()\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"showSearch\" fxLayout=\"row\" fxLayoutAlign=\"start center\" class=\"wild-search-wrapper\">\r\n      <mat-icon [matTooltip]=\"hideSearchTooltip ? '' : searchTooltip | translate\">search</mat-icon>\r\n      <input #wildSearch type=\"text\" [placeholder]=\"searchTitle | translate\" (keyup)=\"search($event)\">\r\n      <button *ngIf=\"showSearchClearButton\" mat-icon-button class=\"wild-search-clear-btn\" (click)=\"wildSearch.value = ''; search({ target: { value: '' } })\">\r\n        <mat-icon>close</mat-icon>\r\n      </button>\r\n    </div>\r\n\r\n    <ng-content select=\"[additionalActions]\"></ng-content>\r\n  </div>\r\n\r\n  <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" #filterBar [filterRowVisible]=\"filterBarVisible\" [settings]=\"config.filter.settings\"\r\n    (filterBarChange)=\"filtersChanged($event)\">\r\n  </tld-filter-bar>\r\n\r\n  <ng-content select=\"[batchActions]\"></ng-content>\r\n\r\n  <div \r\n    #tableContainer\r\n    class=\"table-overflow\"\r\n    [class.table-sticky-header]=\"config?.stickyHeader\"\r\n    [class.table-dragable]=\"tableOverflow\"\r\n    (mousedown)=\"onMouseDown($event)\"\r\n    (mouseup)=\"onMouseUp()\"\r\n    (mouseleave)=\"onMouseUp()\"\r\n    (mousemove)=\"onMouseMove($event)\"\r\n  >\r\n    <table #table mat-table [dataSource]=\"config.dataSource\" [trackBy]=\"trackByFn\">\r\n      <ng-content></ng-content>\r\n      <ng-container [matColumnDef]=\"batchColumnName\">\r\n        <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n          <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n            [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n            [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n          </mat-checkbox>\r\n        </th>\r\n        <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n          <mat-checkbox \r\n            [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" \r\n            [disabled]=\"config.batchConfig!.checkBoxesDisabled || (preselectedItems.includes(element) && disablePreselectedItems)\" (click)=\"$event.stopPropagation()\"\r\n            (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n          </mat-checkbox>\r\n        </td>\r\n      </ng-container>\r\n      <tr mat-header-row *matHeaderRowDef=\"displayColumns; sticky: config?.stickyHeader ?? false\"></tr>\r\n      <tr \r\n        mat-row \r\n        *matRowDef=\"let row; \r\n        columns: displayColumns\" \r\n        (click)=\"config?.rowClickCallback && !config?.disableRowClick(row) ? config?.rowClickCallback(row) : null\"\r\n        (mouseover)=\"hoveredRow = row\" \r\n        (mouseleave)=\"hoveredRow = null\" \r\n        [class.row-clickable]=\"config?.rowClickCallback && !config?.disableRowClick(row)\" \r\n        [class.highlight-error]=\"highlightErrorElement(row)\" \r\n        [class.highlight]=\"row === hoveredRow || highlightElement(row)\">\r\n      </tr>\r\n      \r\n      <ng-container [matColumnDef]=\"columnSelectColumnName\">\r\n        <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n          <div class=\"column-selector-wrapper\">\r\n            <button class=\"column-selector\" mat-icon-button color=\"primary-accent-darker\" [matMenuTriggerFor]=\"columnMenu\">\r\n              <span class=\"material-icons\">more_vert</span>\r\n            </button>\r\n          </div>\r\n        </th>\r\n        <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n        </td>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"noDataRowActive\">\r\n        <tr *matNoDataRow>\r\n          <!-- add random number to make sure it takes full width -->\r\n          <td colspan=\"99\">\r\n            <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n          </td>\r\n        </tr>\r\n      </ng-container>\r\n    </table>\r\n  </div>\r\n</div>\r\n\r\n<mat-menu #columnMenu=\"matMenu\">\r\n  <div class=\"column-select-menu\" (click)=\"$event.stopPropagation()\">\r\n    <div *ngFor=\"let column of configurableColumns\">\r\n      <mat-checkbox [(ngModel)]=\"column.selected\">\r\n        {{column.displayName | translate}}\r\n      </mat-checkbox>\r\n    </div>\r\n\r\n    <div class=\"column-select-save\">\r\n      <button mat-flat-button color=\"primary-accent-darker\" (click)=\"updateDisplayColumns()\">{{ \"MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT_SAVE\" | translate }}</button>\r\n    </div>\r\n  </div>\r\n</mat-menu>\r\n"]}
|
|
598
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-functional-table.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.ts","../../../../../projects/ngx-common/src/lib/multi-functional-table/multi-functional-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import { SelectionModel } from '@angular/cdk/collections';\r\nimport { AfterContentInit, AfterViewInit, Component, ContentChild, ContentChildren, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChild } from '@angular/core';\r\nimport { MatSort } from '@angular/material/sort';\r\nimport { MatColumnDef, MatHeaderRowDef, MatNoDataRow, MatRowDef, MatTable } from '@angular/material/table';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { map, Observable, take } from 'rxjs';\r\nimport { FilterBarChangeEvent } from '../filter-bar/models/filter-bar-change-event.model';\r\nimport { HtmlElementParseHelper } from '../helpers';\r\nimport { SaveFileHelper } from '../helpers/save-file.helper';\r\nimport { DOMService } from '../services';\r\nimport { DISABLE_EXPORT_ATTRIBUTE_NAME } from './constants/disable-export-attribute-name.const';\r\nimport { ExportFormat } from './models';\r\nimport { ColumnConfig } from './models/column-config.model';\r\nimport { MultiFunctionalTableConfig } from './models/multi-functional-table-config.model';\r\nimport { SelectedColumnLocalStorageConfig } from './models/selected-column-local-storage-config.model';\r\nimport { StatusDisplayConfig } from '../status-display/models/status-display-config.model';\r\nimport { FilterBarComponent } from '../filter-bar';\r\n\r\n@Component({\r\n  // eslint-disable-next-line @angular-eslint/component-selector\r\n  selector: 'tld-multi-functional-table',\r\n  templateUrl: './multi-functional-table.component.html',\r\n  styleUrls: ['./multi-functional-table.component.scss']\r\n})\r\nexport class MultiFunctionalTableComponent<T> implements OnInit, AfterContentInit, AfterViewInit {\r\n  readonly matSelection = new SelectionModel<T>(true, []);\r\n\r\n  @Input() config!: MultiFunctionalTableConfig<T>;\r\n  @Input() highlightedElements!: T[];\r\n  @Input() trackByFn!: (ix: number, row: T) => string | number;\r\n  @Input() highlightedErrorElements!: T[];\r\n  @Input() set selection(value: T[]) {\r\n    this.matSelection.setSelection(...(value ?? []));\r\n  }\r\n\r\n  // Set this to false if you want to display checkboxes only on row hover.\r\n  @Input() isRowCheckboxAlwaysVisible = true;\r\n\r\n  @Input() disablePreselectedItems = false;\r\n\r\n  //#region Output properties\r\n  @Output() filterBarChange: EventEmitter<FilterBarChangeEvent> = new EventEmitter<FilterBarChangeEvent>();\r\n  @Output() exported: EventEmitter<T[]> = new EventEmitter<T[]>();\r\n  @Output() selectionChange: Observable<T[]> = this.matSelection.changed.asObservable().pipe(map(() => { return this.matSelection.selected; }));\r\n  //#endregion\r\n\r\n  // #region Properties for mat table wrapper\r\n  @ContentChildren(MatHeaderRowDef) headerRowDefs!: QueryList<MatHeaderRowDef>;\r\n  @ContentChildren(MatRowDef, { descendants: true }) rowDefs!: QueryList<MatRowDef<T>>;\r\n  @ContentChildren(MatColumnDef) columnDefs!: QueryList<MatColumnDef>;\r\n  @ContentChild(MatNoDataRow) noDataRow!: MatNoDataRow;\r\n\r\n  @ViewChild(MatTable, { static: true }) table!: MatTable<T>;\r\n  @ViewChild(MatSort) sort!: MatSort;\r\n\r\n  @ViewChild('tableContainer') tableContainer!: ElementRef<HTMLElement>;\r\n  @ViewChild('filterBar') filterBar!: FilterBarComponent;\r\n  //#endregion\r\n\r\n  @ViewChild(MatTable, { read: ElementRef }) tableElementRef!: ElementRef<HTMLElement>;\r\n\r\n  preselectedItems!: T[];\r\n\r\n  get ignoreAttributeName() { return DISABLE_EXPORT_ATTRIBUTE_NAME }\r\n  displayColumns!: string[];\r\n\r\n  columnSelectActive!: boolean;\r\n  exportActive!: boolean;\r\n  noDataRowActive!: boolean;\r\n\r\n  filters!: FilterBarChangeEvent;\r\n  filterBarVisible!: boolean;\r\n\r\n  hideSearchTooltip!: boolean;\r\n  showSearch!: boolean;\r\n  showSearchClearButton!: boolean;\r\n  searchTitle!: string;\r\n  searchTooltip!: string;\r\n\r\n  noDataRowConfig!: StatusDisplayConfig;\r\n  noDataRowIcon = \"manage_search\";\r\n\r\n  configurableColumns!: ColumnConfig[];\r\n  batchSelectedEnabled!: boolean;\r\n\r\n  // is used in html to display batch checkbox on hovered row\r\n  // eslint-disable-next-line @typescript-eslint/no-explicit-any\r\n  hoveredRow: any;\r\n\r\n  // properties for overflow scrolling with mouse click\r\n  tableOverflow!: boolean;\r\n  private scrollMovement!: number | null;\r\n  private isDragging = false;\r\n  private startX = 0;\r\n  private startY = 0;\r\n  private scrollLeft = 0;\r\n  private scrollTop = 0;\r\n\r\n  get filterActive() { return this.config.filter?.enabled; }\r\n  get showFilterToggle() { return !this.config.filter?.hideFilterToggle; }\r\n\r\n  get showFilterReset() { return this.config.filter?.settings.filters?.find(filter => filter.selectedValues?.length) }\r\n\r\n  private localStorageValue!: SelectedColumnLocalStorageConfig;\r\n  readonly batchColumnName = \"batch\";\r\n  readonly columnSelectColumnName = \"columnSelect\";\r\n\r\n  constructor(private readonly domService: DOMService,\r\n    private readonly translateService: TranslateService) { }\r\n\r\n  //#region Angular lifecycle hooks\r\n  ngOnInit(): void {\r\n    this.readFromLocalStorage();\r\n    this.setFilterVisibility();\r\n    this.setColumnSelectProperties();\r\n    this.setExportProperties();\r\n    this.setNoDataRowProperties();\r\n    this.preselectedItems = this.matSelection.selected;\r\n    this.searchTooltip = this.config.filter?.settings?.searchTooltip ?? 'FILTER_BAR.SEARCH_TOOLTIP';\r\n    this.searchTitle = this.config.filter?.settings?.searchTitle ?? 'FILTER_BAR.SEARCH';\r\n    this.showSearch = !this.config.filter?.settings?.hideSearch;\r\n    this.showSearchClearButton = this.config.filter?.settings?.showSearchClearButton ?? true;\r\n    this.hideSearchTooltip = !this.config.filter?.settings?.hideTooltip;\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.columnDefs.forEach(columnDef => this.table.addColumnDef(columnDef));\r\n    this.rowDefs.forEach(rowDef => this.table.addRowDef(rowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.headerRowDefs.forEach(headerRowDef => this.table.addHeaderRowDef(headerRowDef));\r\n    this.table.setNoDataRow(this.noDataRow);\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.config.dataSource.sort = this.sort;\r\n  }\r\n  //#endregion\r\n\r\n  search(event: { target: { value: string } } | KeyboardEvent): void {\r\n    const input = (event.target as HTMLInputElement)?.value;\r\n    this.config.filter!.settings.searchInput = input;\r\n    this.filterBarChange.emit({ ...this.filters, input });    \r\n  }\r\n\r\n  updateDisplayColumns(initial = false) {\r\n    this.batchSelectedEnabled = this.config.batchConfig?.enabled ? true : false;\r\n    const allColumns = this.config.columnSelect?.columns ?? [];\r\n    this.displayColumns = [];\r\n    this.configurableColumns = allColumns.filter(column => !column.notConfigurable);\r\n\r\n    if (this.batchSelectedEnabled) {\r\n      this.displayColumns.push(this.batchColumnName);\r\n    }\r\n\r\n    if (!allColumns.length) {\r\n      return;\r\n    }\r\n\r\n    const localStorageValue = this.localStorageValue ?? {};\r\n    if (!localStorageValue.columns) {\r\n      localStorageValue.columns = {};\r\n    }\r\n\r\n    allColumns.forEach((column) => {\r\n      if (initial) {\r\n        column.selected = localStorageValue.columns?.[column.name] ?? column.selected;\r\n      } else {\r\n        // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\r\n        localStorageValue.columns![column.name] = column.selected;\r\n      }\r\n      \r\n      if (column.selected) {\r\n        this.displayColumns.push(column.name);\r\n      }\r\n    })\r\n\r\n    if (this.columnSelectActive) {\r\n      this.displayColumns.push(this.columnSelectColumnName);\r\n    }\r\n\r\n    if (!initial) {\r\n      this.updateLocalStorage(localStorageValue);\r\n    }\r\n  }\r\n\r\n  toggleFilterBar() {\r\n    const localstorageObject = this.localStorageValue ?? {};\r\n    if (!localstorageObject.filter) {\r\n      localstorageObject.filter = {};\r\n    }\r\n\r\n    this.filterBarVisible = !this.filterBarVisible;\r\n    localstorageObject.filter.visible = this.filterBarVisible;\r\n    this.updateLocalStorage(localstorageObject);\r\n  }\r\n\r\n  filtersChanged(filters: FilterBarChangeEvent) {\r\n    this.filters = filters;\r\n    this.filterBarChange.emit(this.filters);\r\n  }\r\n\r\n  clearFilters() {\r\n    this.config.filter?.settings.filters?.forEach((filter) => {\r\n      filter.selectedValues = [];\r\n    })\r\n\r\n    this.filterBar.removeAllFilters();\r\n  }\r\n\r\n  export() {\r\n    this.config.dataSource.connect().pipe(take(1)).subscribe((data) => {\r\n      this.exported.emit(data);\r\n    })\r\n\r\n    if (this.config.export?.fileOptions) {\r\n      this.exportToFile()\r\n    }\r\n  }\r\n\r\n  highlightElement(element: T) {\r\n    return this.highlightedElements?.includes(element);\r\n  }\r\n\r\n  highlightErrorElement(element: T) {\r\n    return this.highlightedErrorElements?.includes(element);\r\n  }\r\n\r\n  //#region Methods for batch selection\r\n  isAllSelected() {\r\n    const numSelected = this.matSelection.selected.length;\r\n    const numRows = this.config.dataSource.data.length;\r\n    return numSelected === numRows;\r\n  }\r\n\r\n  toggleAllRowSelection() {\r\n    if (this.isAllSelected()) {\r\n      if (this.disablePreselectedItems) {\r\n        // deselect only those items which were not already preselected\r\n        this.matSelection.deselect(\r\n          ...this.matSelection.selected.filter(elm => !this.preselectedItems.map(elm => elm).includes(elm))\r\n        );\r\n        return;\r\n      }\r\n      else {\r\n        this.matSelection.clear();\r\n        return;\r\n      }\r\n    }\r\n\r\n    this.matSelection.select(...this.config.dataSource.data);\r\n  }\r\n\r\n  toggleElementSelection(element: T) {\r\n    this.matSelection.toggle(element);\r\n  }\r\n\r\n  onMouseDown(event: MouseEvent) {\r\n    this.isDragging = true;\r\n    this.startX = event.pageX - this.tableContainer.nativeElement.offsetLeft;\r\n    this.startY = event.pageY - this.tableContainer.nativeElement.offsetTop;\r\n    this.scrollLeft = this.tableContainer.nativeElement.scrollLeft;\r\n    this.scrollTop = this.tableContainer.nativeElement.scrollTop;\r\n\r\n    // canceling any previous animation frame\r\n    if (this.scrollMovement !== null) {\r\n      cancelAnimationFrame(this.scrollMovement);\r\n    }\r\n  }\r\n  \r\n  onMouseMove(event: MouseEvent) {\r\n    this.checkTableOverflow();\r\n\r\n    if (!this.isDragging) {\r\n      return;\r\n    }\r\n\r\n     // using requestAnimationFrame for smoother updates\r\n     if (this.scrollMovement === null) {\r\n      this.scrollMovement = requestAnimationFrame(() => {\r\n        if (!this.tableOverflow) {\r\n          return;\r\n        }\r\n        \r\n        const x = event.pageX - this.tableContainer.nativeElement.offsetLeft;\r\n        const y = event.pageY - this.tableContainer.nativeElement.offsetTop;\r\n\r\n        // calculating the differences in movement\r\n        const walkX = (x - this.startX) * 2;\r\n        const walkY = (y - this.startY) * 2;\r\n\r\n        // updating scroll positions\r\n        this.tableContainer.nativeElement.scrollLeft = this.scrollLeft - walkX;\r\n        this.tableContainer.nativeElement.scrollTop = this.scrollTop - walkY;\r\n\r\n        this.scrollMovement = null;\r\n      });\r\n    }\r\n  }\r\n  \r\n  onMouseUp() {\r\n    this.isDragging = false;\r\n\r\n    // canceling any pending animation\r\n    if (this.scrollMovement !== null) {\r\n      cancelAnimationFrame(this.scrollMovement);\r\n      this.scrollMovement = null;\r\n    }\r\n  }\r\n  //#endregion\r\n\r\n  private checkTableOverflow(): void {\r\n    // when data is available we should check once for table overflow\r\n    // when there wasnt overflow, but width of the table became bigger, then we are reseting tableOverflow variable\r\n    // same for when there was overflow, but size of the table is same as container, so overflow is gone and we reseting tableOverflow variable again\r\n    if ((this.config.dataSource.data.length &&  this.tableOverflow === undefined) ||\r\n      (!this.tableOverflow && this.tableContainer.nativeElement.clientWidth <  this.tableElementRef.nativeElement.clientWidth) ||\r\n      (this.tableOverflow && this.tableContainer.nativeElement.clientWidth === this.tableElementRef.nativeElement.clientWidth)) {\r\n\r\n        if (this.tableContainer.nativeElement.clientWidth < this.tableElementRef.nativeElement.clientWidth) {\r\n          this.tableOverflow = true;\r\n        } else {\r\n          this.tableOverflow = false;\r\n        }\r\n    }\r\n  }\r\n\r\n  private exportToFile() {\r\n    if (!this.config.export?.fileOptions?.saveToFile) {\r\n      return;\r\n    }\r\n\r\n    let fileString = \"\";\r\n    let extension!: ExportFormat;\r\n    switch (this.config.export.fileOptions.format) {\r\n      case ExportFormat.CSV:\r\n      default:\r\n        extension = ExportFormat.CSV;\r\n        fileString = HtmlElementParseHelper.tableAsCsv(this.tableElementRef.nativeElement, this.ignoreAttributeName);\r\n        break;\r\n    }\r\n    const translatedFileName = this.translateService.instant(this.config.export.fileOptions.fileName);\r\n    SaveFileHelper.saveFile(fileString, `${translatedFileName}.${extension}`);\r\n  }\r\n\r\n  private updateLocalStorage(newValue: SelectedColumnLocalStorageConfig) {\r\n    this.localStorageValue = newValue;\r\n    if (this.config.localStorageKey && newValue) {\r\n      this.domService.localStorage?.setItem(this.config.localStorageKey, JSON.stringify(newValue));\r\n    }\r\n  }\r\n  private readFromLocalStorage() {\r\n    if (this.config.localStorageKey) {\r\n      try {\r\n        const localStorageString = this.domService.localStorage?.getItem(this.config.localStorageKey);\r\n        if (localStorageString) {\r\n          this.localStorageValue = JSON.parse(localStorageString);\r\n        }\r\n      }\r\n      // eslint-disable-next-line no-empty\r\n      catch {\r\n      }\r\n    }\r\n  }\r\n\r\n  private setColumnSelectProperties() {\r\n    this.columnSelectActive = this.config.columnSelect?.enabled ? true : false;\r\n    this.updateDisplayColumns(true);\r\n  }\r\n\r\n  private setFilterVisibility() {\r\n    this.filterBarVisible = this.localStorageValue?.filter?.visible ?? this.config?.filter?.visible ?? false;\r\n  }\r\n\r\n  private setNoDataRowProperties() {\r\n    if (this.config.noDataRow) {\r\n      this.noDataRowActive = true;\r\n      this.noDataRowConfig = this.config.noDataRow;\r\n      this.noDataRowConfig.icon = this.config.noDataRow?.icon ?? this.noDataRowIcon;\r\n    }\r\n  }\r\n\r\n  private setExportProperties() {\r\n    if (this.config.export?.enabled) {\r\n      this.exportActive = true;\r\n    }\r\n  }\r\n}\r\n","<div [ngClass.lt-md]=\"'mobile'\" fxLayout=\"column\" fxLayoutGap=\"0.75rem\">\r\n\r\n  <div fxLayout=\"row\" fxLayout.lt-md=\"column\" fxLayoutGap.lt-md=\"0.75rem\">\r\n    <div fxFlex fxLayout.lt-md=\"column\" fxLayoutGap=\"0.75rem\" fxLayoutAlign=\"start center\" fxLayoutAlign.lt-md=\"start start\" class=\"action-row\">\r\n      <button class=\"export-data\" mat-stroked-button color=\"primary-accent-darker\" *ngIf=\"exportActive\" (click)=\"export()\">\r\n        <span class=\"material-icons-outlined\">cloud_download</span>\r\n        <span>{{'MULTI_FUNCTIONAL_TABLE.EXPORT' | translate}}</span>\r\n      </button>\r\n\r\n      <div *ngIf=\"filterActive && showFilterToggle\" fxFlex fxLayoutGap=\"0.5rem\" fxLayoutAlign=\"start center\">\r\n        <button [class.filter-active]=\"filterBarVisible\" mat-stroked-button color=\"primary-accent-darker\" (click)=\"toggleFilterBar()\">\r\n          <span class=\"material-icons\">filter_list</span>\r\n          <span>{{'MULTI_FUNCTIONAL_TABLE.FILTER_TOGGLE' | translate}}</span>\r\n        </button>\r\n  \r\n        <div *ngIf=\"showFilterReset\" class=\"clear-filters-wrapper\">\r\n          <button mat-icon-button (click)=\"clearFilters()\">\r\n            <mat-icon>close</mat-icon>\r\n          </button>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n    <div *ngIf=\"showSearch\" fxLayout=\"row\" fxLayoutAlign=\"start center\" class=\"wild-search-wrapper\">\r\n      <mat-icon [matTooltip]=\"hideSearchTooltip ? '' : searchTooltip | translate\">search</mat-icon>\r\n      <input #wildSearch type=\"text\" [placeholder]=\"searchTitle | translate\" (keyup)=\"search($event)\">\r\n      <button *ngIf=\"showSearchClearButton\" mat-icon-button class=\"wild-search-clear-btn\" (click)=\"wildSearch.value = ''; search({ target: { value: '' } })\">\r\n        <mat-icon>close</mat-icon>\r\n      </button>\r\n    </div>\r\n\r\n    <ng-content select=\"[additionalActions]\"></ng-content>\r\n  </div>\r\n\r\n  <tld-filter-bar *ngIf=\"config.filter && config.filter.enabled\" #filterBar [filterRowVisible]=\"filterBarVisible\" [settings]=\"config.filter.settings\"\r\n    (filterBarChange)=\"filtersChanged($event)\">\r\n  </tld-filter-bar>\r\n\r\n  <ng-content select=\"[batchActions]\"></ng-content>\r\n\r\n  <div \r\n    #tableContainer\r\n    class=\"table-overflow\"\r\n    [class.table-sticky-header]=\"config?.stickyHeader\"\r\n    [class.table-dragable]=\"tableOverflow\"\r\n    (mousedown)=\"onMouseDown($event)\"\r\n    (mouseup)=\"onMouseUp()\"\r\n    (mouseleave)=\"onMouseUp()\"\r\n    (mousemove)=\"onMouseMove($event)\"\r\n  >\r\n    <table #table mat-table [dataSource]=\"config.dataSource\" [trackBy]=\"trackByFn\">\r\n      <ng-content></ng-content>\r\n      <ng-container [matColumnDef]=\"batchColumnName\">\r\n        <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n          <mat-checkbox [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT_ALL' | translate\" [disabled]=\"config.batchConfig!.checkBoxesDisabled\" (change)=\"toggleAllRowSelection()\"\r\n            [checked]=\"matSelection.hasValue() && isAllSelected()\"\r\n            [indeterminate]=\"matSelection.hasValue() && !isAllSelected()\">\r\n          </mat-checkbox>\r\n        </th>\r\n        <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n          <mat-checkbox \r\n            [matTooltip]=\"'MULTI_FUNCTIONAL_TABLE.SELECT' | translate\" *ngIf=\"isRowCheckboxAlwaysVisible || hoveredRow === element || matSelection.isSelected(element)\" \r\n            [disabled]=\"config.batchConfig!.checkBoxesDisabled || (preselectedItems.includes(element) && disablePreselectedItems)\" (click)=\"$event.stopPropagation()\"\r\n            (change)=\"toggleElementSelection(element)\" [checked]=\"matSelection.isSelected(element)\">\r\n          </mat-checkbox>\r\n        </td>\r\n      </ng-container>\r\n      <tr mat-header-row *matHeaderRowDef=\"displayColumns; sticky: config?.stickyHeader ?? false\"></tr>\r\n      <tr \r\n        mat-row \r\n        *matRowDef=\"let row; \r\n        columns: displayColumns\" \r\n        (click)=\"config?.rowClickCallback && !config?.disableRowClick(row) ? config?.rowClickCallback(row) : null\"\r\n        (mouseover)=\"hoveredRow = row\" \r\n        (mouseleave)=\"hoveredRow = null\" \r\n        [class.row-clickable]=\"config?.rowClickCallback && !config?.disableRowClick(row)\" \r\n        [class.highlight-error]=\"highlightErrorElement(row)\" \r\n        [class.highlight]=\"row === hoveredRow || highlightElement(row)\">\r\n      </tr>\r\n      \r\n      <ng-container [matColumnDef]=\"columnSelectColumnName\">\r\n        <th class=\"row-select\" mat-header-cell *matHeaderCellDef disable-export>\r\n          <div class=\"column-selector-wrapper\">\r\n            <button class=\"column-selector\" mat-icon-button color=\"primary-accent-darker\" [matMenuTriggerFor]=\"columnMenu\">\r\n              <span class=\"material-icons\">more_vert</span>\r\n            </button>\r\n          </div>\r\n        </th>\r\n        <td class=\"row-select\" mat-cell *matCellDef=\"let element\" disable-export>\r\n        </td>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"noDataRowActive\">\r\n        <tr *matNoDataRow>\r\n          <!-- add random number to make sure it takes full width -->\r\n          <td colspan=\"99\">\r\n            <lib-status-display [config]=\"noDataRowConfig\"></lib-status-display>\r\n          </td>\r\n        </tr>\r\n      </ng-container>\r\n    </table>\r\n  </div>\r\n</div>\r\n\r\n<mat-menu #columnMenu=\"matMenu\">\r\n  <div class=\"column-select-menu\" (click)=\"$event.stopPropagation()\">\r\n    <div *ngFor=\"let column of configurableColumns\">\r\n      <mat-checkbox [(ngModel)]=\"column.selected\">\r\n        {{column.displayName | translate}}\r\n      </mat-checkbox>\r\n    </div>\r\n\r\n    <div class=\"column-select-save\">\r\n      <button mat-flat-button color=\"primary-accent-darker\" (click)=\"updateDisplayColumns()\">{{ \"MULTI_FUNCTIONAL_TABLE.COLUMN_SELECT_SAVE\" | translate }}</button>\r\n    </div>\r\n  </div>\r\n</mat-menu>\r\n"]}
|