ngx-advanced-material-table
Version:
Advanced Angular Material Table component, along with many features such as filter and display/hide columns
94 lines • 23.6 kB
JavaScript
import { Component, Inject } from '@angular/core';
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
import { ColumnType, } from '../../interfaces/column-definition.interface';
import { Value } from '../../helpers/values.helper';
import { DialogActionType } from '../../interfaces/enums/dialog-action.enum';
import * as i0 from "@angular/core";
import * as i1 from "@angular/material/dialog";
import * as i2 from "@angular/forms";
import * as i3 from "@angular/material/button";
import * as i4 from "@angular/material/icon";
import * as i5 from "@angular/material/form-field";
import * as i6 from "@angular/cdk/scrolling";
import * as i7 from "@angular/material/checkbox";
import * as i8 from "@angular/material/button-toggle";
import * as i9 from "@angular/material/input";
import * as i10 from "@angular/common";
import * as i11 from "../../pipes/filter.pipe";
export class FilterColumnsComponent {
constructor(dialogRef, fb, context) {
this.dialogRef = dialogRef;
this.fb = fb;
this.context = context;
this.searchFiltersValue = '';
this.distinctColumnValues = [];
this.cancelResponse = { action: DialogActionType.Cancel };
this.columnType = ColumnType;
this.selectedColumn = this.context.selectedColumn;
this.distinctColumnValues = this.sortColumns(this.context.distinctData);
this.initialSortingDirection = this.selectedColumn.SortDirection;
this.filterForm = this.fb.group({
SearchFilters: [''],
});
}
ngOnInit() {
this.filterForm.controls.SearchFilters.valueChanges.subscribe(() => this.onSearchFiltersValueChanged());
}
onSearchFiltersValueChanged() {
this.searchFiltersValue = this.filterForm.controls.SearchFilters.value;
}
onSelectFilter(change) {
this.distinctColumnValues.forEach((x) => {
if (x.name === change.source.value) {
x.checked = change.checked;
}
});
}
onSortingValueChange(value) {
if (this.selectedColumn.SortDirection === value) {
this.selectedColumn.SortDirection = undefined;
}
else {
this.selectedColumn.SortDirection = value;
}
}
onApplyFiltersButton() {
this.selectedColumn.FilterValues = [];
this.selectedColumn.FilterValues = this.distinctColumnValues.filter((x) => x.checked === true).map((x) => x.name);
const response = {
action: DialogActionType.Ok,
sortingHasChanged: this.initialSortingDirection !== this.selectedColumn.SortDirection,
selectedColumn: this.selectedColumn,
};
this.dialogRef.close(response);
}
sortColumns(columns) {
if (columns.length === 0) {
return [];
}
if (columns[0].name instanceof Date) {
columns.sort((a, b) => (a.name > b.name ? 1 : -1));
}
else if (Value.isNumber(columns[0].name)) {
columns.sort((a, b) => a.name - b.name);
}
else if (Value.isString(columns[0].name)) {
columns.sort((a, b) => a.name.localeCompare(b.name));
}
return columns;
}
}
FilterColumnsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.12", ngImport: i0, type: FilterColumnsComponent, deps: [{ token: i1.MatDialogRef }, { token: i2.FormBuilder }, { token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
FilterColumnsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.12", type: FilterColumnsComponent, selector: "filter-columns", ngImport: i0, template: "<div class=\"filter-columns\">\n <button mat-icon-button class=\"close-icon\" [mat-dialog-close]=\"cancelResponse\">\n <mat-icon>close</mat-icon>\n </button>\n\n <h3 mat-dialog-title i18n=\"@@filter-columns-label-filterRowsHeading\">Filter rows</h3>\n\n <mat-dialog-content>\n <form id=\"formFilterRoutesPlanning\" role=\"form\" [formGroup]=\"filterForm\">\n <mat-form-field>\n <mat-label i18n=\"@@formControl-label-filterGrid\">Search filters</mat-label>\n <input matInput type=\"text\" formControlName=\"SearchFilters\" id=\"FilterString\" />\n </mat-form-field>\n </form>\n\n <cdk-virtual-scroll-viewport itemSize=\"15\" class=\"filter-column-viewport\">\n <span *ngIf=\"distinctColumnValues.length === 0\" i18n=\"@@routeplanning-filter-column-no-values\">No available values</span>\n\n <div\n class=\"filter-column-item\"\n *cdkVirtualFor=\"let value of distinctColumnValues | filterCriteria: searchFiltersValue; let i = index\"\n >\n <mat-checkbox [value]=\"value.name\" [checked]=\"value.checked\" (change)=\"onSelectFilter($event)\">\n <span> {{ value.displayedName }}</span>\n </mat-checkbox>\n </div>\n </cdk-virtual-scroll-viewport>\n\n <mat-button-toggle-group name=\"sortDirection\" value=\"{{ selectedColumn.SortDirection }}\">\n <mat-button-toggle id=\"filter-columns-sort-ascending\" value=\"asc\" (change)=\"onSortingValueChange($event.value)\">\n <span i18n=\"@@filterColumns-btn-ascsort\">Ascending</span>\n <mat-icon>arrow_upward</mat-icon>\n </mat-button-toggle>\n <mat-button-toggle id=\"filter-columns-sort-descending\" value=\"desc\" (change)=\"onSortingValueChange($event.value)\">\n <span i18n=\"@@filterColumns-btn-descsort\">Descending</span>\n <mat-icon>arrow_downward</mat-icon>\n </mat-button-toggle>\n </mat-button-toggle-group>\n </mat-dialog-content>\n\n <mat-dialog-actions>\n <button mat-raised-button id=\"filter-columns-close\" [mat-dialog-close]=\"cancelResponse\">\n <span i18n=\"@@action-btn-cancel\">Cancel</span>\n </button>\n <button mat-raised-button id=\"filter-columns-filter\" (click)=\"onApplyFiltersButton()\" color=\"accent\">\n <span i18n=\"@@action-btn-filter\">Filter</span>\n </button>\n </mat-dialog-actions>\n</div>\n", styles: [".filter-columns{position:relative!important}.filter-columns .close-icon{position:absolute;top:-20px;right:-20px}.filter-columns mat-form-field{width:100%}.filter-columns .filter-column-viewport{height:13em;border:1px solid lightgray}.filter-columns .filter-column-item{height:25px;padding:.2em .5em}.filter-columns mat-button-toggle-group{margin-top:16px;width:100%}.filter-columns mat-button-toggle-group mat-button-toggle{flex:1 1 auto}.filter-columns mat-dialog-actions button{flex:1 1 auto}\n"], components: [{ type: i3.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.MatFormField, selector: "mat-form-field", inputs: ["color", "floatLabel", "appearance", "hideRequiredMarker", "hintLabel"], exportAs: ["matFormField"] }, { type: i6.CdkVirtualScrollViewport, selector: "cdk-virtual-scroll-viewport", inputs: ["orientation", "appendOnly"], outputs: ["scrolledIndexChange"] }, { type: i7.MatCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex", "aria-label", "aria-labelledby", "id", "labelPosition", "name", "required", "checked", "disabled", "indeterminate", "aria-describedby", "value"], outputs: ["change", "indeterminateChange"], exportAs: ["matCheckbox"] }, { type: i8.MatButtonToggle, selector: "mat-button-toggle", inputs: ["disableRipple", "aria-labelledby", "tabIndex", "appearance", "checked", "disabled", "id", "name", "aria-label", "value"], outputs: ["change"], exportAs: ["matButtonToggle"] }], directives: [{ type: i1.MatDialogClose, selector: "[mat-dialog-close], [matDialogClose]", inputs: ["type", "mat-dialog-close", "aria-label", "matDialogClose"], exportAs: ["matDialogClose"] }, { type: i1.MatDialogTitle, selector: "[mat-dialog-title], [matDialogTitle]", inputs: ["id"], exportAs: ["matDialogTitle"] }, { type: i1.MatDialogContent, selector: "[mat-dialog-content], mat-dialog-content, [matDialogContent]" }, { type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.MatLabel, selector: "mat-label" }, { type: i9.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["id", "disabled", "required", "type", "value", "readonly", "placeholder", "errorStateMatcher", "aria-describedby"], exportAs: ["matInput"] }, { type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i2.FormControlName, selector: "[formControlName]", inputs: ["disabled", "formControlName", "ngModel"], outputs: ["ngModelChange"] }, { type: i6.CdkFixedSizeVirtualScroll, selector: "cdk-virtual-scroll-viewport[itemSize]", inputs: ["itemSize", "minBufferPx", "maxBufferPx"] }, { type: i10.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.CdkVirtualForOf, selector: "[cdkVirtualFor][cdkVirtualForOf]", inputs: ["cdkVirtualForOf", "cdkVirtualForTrackBy", "cdkVirtualForTemplate", "cdkVirtualForTemplateCacheSize"] }, { type: i8.MatButtonToggleGroup, selector: "mat-button-toggle-group", inputs: ["appearance", "name", "vertical", "value", "multiple", "disabled"], outputs: ["valueChange", "change"], exportAs: ["matButtonToggleGroup"] }, { type: i1.MatDialogActions, selector: "[mat-dialog-actions], mat-dialog-actions, [matDialogActions]" }], pipes: { "filterCriteria": i11.FilterColumnValuesPipe } });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.12", ngImport: i0, type: FilterColumnsComponent, decorators: [{
type: Component,
args: [{
selector: 'filter-columns',
templateUrl: './filter-columns.component.html',
styleUrls: ['./filter-columns.component.scss'],
}]
}], ctorParameters: function () { return [{ type: i1.MatDialogRef }, { type: i2.FormBuilder }, { type: undefined, decorators: [{
type: Inject,
args: [MAT_DIALOG_DATA]
}] }]; } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-columns.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-advanced-material-table/src/lib/components/filter-columns/filter-columns.component.ts","../../../../../../projects/ngx-advanced-material-table/src/lib/components/filter-columns/filter-columns.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Inject } from '@angular/core';\nimport { FormGroup, FormBuilder } from '@angular/forms';\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\nimport { MatCheckboxChange } from '@angular/material/checkbox';\nimport {\n    IColumnDefinition,\n    ColumnType,\n    IDistinctColumns,\n    IFilterColumnsResponse,\n    IFilterColumnsData,\n} from '../../interfaces/column-definition.interface';\nimport { Value } from '../../helpers/values.helper';\nimport { DialogActionType } from '../../interfaces/enums/dialog-action.enum';\n\n@Component({\n    selector: 'filter-columns',\n    templateUrl: './filter-columns.component.html',\n    styleUrls: ['./filter-columns.component.scss'],\n})\nexport class FilterColumnsComponent implements OnInit {\n    filterForm: FormGroup;\n    searchFiltersValue: string = '';\n    selectedColumn: IColumnDefinition;\n    initialSortingDirection?: 'asc' | 'desc';\n    distinctColumnValues: IDistinctColumns[] = [];\n    cancelResponse: IFilterColumnsResponse = { action: DialogActionType.Cancel };\n    columnType = ColumnType;\n\n    constructor(\n        public dialogRef: MatDialogRef<FilterColumnsComponent>,\n        private fb: FormBuilder,\n        @Inject(MAT_DIALOG_DATA) public context: IFilterColumnsData\n    ) {\n        this.selectedColumn = this.context.selectedColumn;\n        this.distinctColumnValues = this.sortColumns(this.context.distinctData);\n        this.initialSortingDirection = this.selectedColumn.SortDirection;\n        this.filterForm = this.fb.group({\n            SearchFilters: [''],\n        });\n    }\n\n    ngOnInit(): void {\n        this.filterForm.controls.SearchFilters.valueChanges.subscribe(() => this.onSearchFiltersValueChanged());\n    }\n\n    onSearchFiltersValueChanged(): void {\n        this.searchFiltersValue = this.filterForm.controls.SearchFilters.value;\n    }\n\n    onSelectFilter(change: MatCheckboxChange) {\n        this.distinctColumnValues.forEach((x) => {\n            if (x.name === change.source.value) {\n                x.checked = change.checked;\n            }\n        });\n    }\n\n    onSortingValueChange(value: 'asc' | 'desc') {\n        if (this.selectedColumn.SortDirection === value) {\n            this.selectedColumn.SortDirection = undefined;\n        } else {\n            this.selectedColumn.SortDirection = value;\n        }\n    }\n\n    onApplyFiltersButton(): void {\n        this.selectedColumn.FilterValues = [];\n        this.selectedColumn.FilterValues = this.distinctColumnValues.filter((x) => x.checked === true).map((x) => x.name);\n\n        const response: IFilterColumnsResponse = {\n            action: DialogActionType.Ok,\n            sortingHasChanged: this.initialSortingDirection !== this.selectedColumn.SortDirection,\n            selectedColumn: this.selectedColumn,\n        };\n\n        this.dialogRef.close(response);\n    }\n\n    private sortColumns(columns: IDistinctColumns[]): IDistinctColumns[] {\n        if (columns.length === 0) {\n            return [];\n        }\n\n        if (columns[0].name instanceof Date) {\n            columns.sort((a, b) => (a.name > b.name ? 1 : -1));\n        } else if (Value.isNumber(columns[0].name)) {\n            columns.sort((a, b) => (a.name as number) - (b.name as number));\n        } else if (Value.isString(columns[0].name)) {\n            columns.sort((a, b) => (a.name as string).localeCompare(b.name as string));\n        }\n\n        return columns;\n    }\n}\n","<div class=\"filter-columns\">\n    <button mat-icon-button class=\"close-icon\" [mat-dialog-close]=\"cancelResponse\">\n        <mat-icon>close</mat-icon>\n    </button>\n\n    <h3 mat-dialog-title i18n=\"@@filter-columns-label-filterRowsHeading\">Filter rows</h3>\n\n    <mat-dialog-content>\n        <form id=\"formFilterRoutesPlanning\" role=\"form\" [formGroup]=\"filterForm\">\n            <mat-form-field>\n                <mat-label i18n=\"@@formControl-label-filterGrid\">Search filters</mat-label>\n                <input matInput type=\"text\" formControlName=\"SearchFilters\" id=\"FilterString\" />\n            </mat-form-field>\n        </form>\n\n        <cdk-virtual-scroll-viewport itemSize=\"15\" class=\"filter-column-viewport\">\n            <span *ngIf=\"distinctColumnValues.length === 0\" i18n=\"@@routeplanning-filter-column-no-values\">No available values</span>\n\n            <div\n                class=\"filter-column-item\"\n                *cdkVirtualFor=\"let value of distinctColumnValues | filterCriteria: searchFiltersValue; let i = index\"\n            >\n                <mat-checkbox [value]=\"value.name\" [checked]=\"value.checked\" (change)=\"onSelectFilter($event)\">\n                    <span> {{ value.displayedName }}</span>\n                </mat-checkbox>\n            </div>\n        </cdk-virtual-scroll-viewport>\n\n        <mat-button-toggle-group name=\"sortDirection\" value=\"{{ selectedColumn.SortDirection }}\">\n            <mat-button-toggle id=\"filter-columns-sort-ascending\" value=\"asc\" (change)=\"onSortingValueChange($event.value)\">\n                <span i18n=\"@@filterColumns-btn-ascsort\">Ascending</span>\n                <mat-icon>arrow_upward</mat-icon>\n            </mat-button-toggle>\n            <mat-button-toggle id=\"filter-columns-sort-descending\" value=\"desc\" (change)=\"onSortingValueChange($event.value)\">\n                <span i18n=\"@@filterColumns-btn-descsort\">Descending</span>\n                <mat-icon>arrow_downward</mat-icon>\n            </mat-button-toggle>\n        </mat-button-toggle-group>\n    </mat-dialog-content>\n\n    <mat-dialog-actions>\n        <button mat-raised-button id=\"filter-columns-close\" [mat-dialog-close]=\"cancelResponse\">\n            <span i18n=\"@@action-btn-cancel\">Cancel</span>\n        </button>\n        <button mat-raised-button id=\"filter-columns-filter\" (click)=\"onApplyFiltersButton()\" color=\"accent\">\n            <span i18n=\"@@action-btn-filter\">Filter</span>\n        </button>\n    </mat-dialog-actions>\n</div>\n"]}