UNPKG

@alfiob/ng-datatable

Version:

ng-datatable - fully customizable & easy to use datatable library

231 lines (223 loc) 27.1 kB
import { Component, Input, Output, EventEmitter, ViewChild } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/common"; import * as i2 from "@angular/forms"; import * as i3 from "./column-filter"; import * as i4 from "./icon-check"; import * as i5 from "./icon-dash"; import * as i6 from "./icon-filter"; export class ColumnHeaderComponent { constructor(viewContainerRef) { this.viewContainerRef = viewContainerRef; this.selectAll = new EventEmitter(); this.sortChange = new EventEmitter(); this.filterChange = new EventEmitter(); this.isOpenFilter = null; } ngOnInit() { this.viewContainerRef.createEmbeddedView(this.template); this.checkboxChange(); } checkboxChange() { if (this.selectedAll) { this.selectedAll.nativeElement.indeterminate = this.checkAll !== 0 ? !this.checkAll : false; this.selectedAll.nativeElement.checked = this.checkAll; } } toggleFilterMenu(col) { if (col) { if (this.isOpenFilter === col.field) { this.isOpenFilter = null; } else { this.isOpenFilter = col.field; } } else { this.isOpenFilter = null; } } } ColumnHeaderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ColumnHeaderComponent, deps: [{ token: i0.ViewContainerRef }], target: i0.ɵɵFactoryTarget.Component }); ColumnHeaderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ColumnHeaderComponent, selector: "column-header", inputs: { all: "all", isFooter: "isFooter", checkAll: "checkAll" }, outputs: { selectAll: "selectAll", sortChange: "sortChange", filterChange: "filterChange" }, viewQueries: [{ propertyName: "template", first: true, predicate: ["template"], descendants: true, static: true }, { propertyName: "selectedAll", first: true, predicate: ["selectedAll"], descendants: true }], ngImport: i0, template: ` <ng-template #template> <tr> <th *ngIf="all.hasCheckbox" [class]="'bh-w-px'" [ngClass]="{ 'bh-sticky bh-bg-blue-light bh-z-[1]': all.stickyHeader || all.stickyFirstColumn, 'bh-top-0': all.stickyHeader, 'bh-left-0': all.stickyFirstColumn }" > <div class="bh-checkbox"> <input #selectedAll type="checkbox" (click)="selectAll.emit(selectedAll.checked); $event.stopPropagation()" /> <div> <icon-check class="check"></icon-check> <icon-dash class="intermediate"></icon-dash> </div> </div> </th> <ng-container *ngFor="let col of all.columns; let j = index"> <th *ngIf="!col.hide" [ngStyle]="{ 'width': col.width, 'min-width': col.minWidth, 'max-width': col.maxWidth }" [class]="'bh-select-none bh-z-[1]'" [ngClass]="[ all.sortable && col.sort ? 'bh-cursor-pointer' : '', j === 0 && all.stickyFirstColumn ? 'bh-sticky bh-left-0 bh-bg-blue-light' : '', all.hasCheckbox && j === 0 && all.stickyFirstColumn ? 'bh-left-[52px]' : '' ]" [style]="{ width: col.width, 'min-width': col.minWidth, 'max-width': col.maxWidth }" > <div class="bh-flex bh-items-center" [ngClass]="[col.headerClass ? col.headerClass : '']" (click)="all.sortable && col.sort && sortChange.emit(col.field)"> {{ col.title }} <span *ngIf="all.sortable && col.sort" class="bh-ml-3 bh-sort bh-flex bh-items-center" [ngClass]="[all.sortColumn, all.sortDirection]"> <svg width="16" height="16" viewBox="0 0 14 14" fill="none"> <polygon points="3.11,6.25 10.89,6.25 7,1.75" fill="currentColor" class="bh-text-black/20" [ngClass]="[all.sortColumn === col.field && all.sortDirection === 'asc' ? '!bh-text-primary' : '']" ></polygon> <polygon points="7,12.25 10.89,7.75 3.11,7.75" fill="currentColor" class="bh-text-black/20" [ngClass]="[all.sortColumn === col.field && all.sortDirection === 'desc' ? '!bh-text-primary' : '']" ></polygon> </svg> </span> </div> <ng-container *ngIf="all.columnFilter && !isFooter"> <div *ngIf="col.filter" class="bh-filter bh-relative"> <input *ngIf="col.type === 'string'" [(ngModel)]="col.value" type="text" class="bh-form-control" (keyup)="filterChange.emit()" /> <input *ngIf="col.type === 'number'" [(ngModel)]="col.value" type="number" class="bh-form-control" (keyup)="filterChange.emit()" /> <input *ngIf="col.type === 'date'" [(ngModel)]="col.value" type="date" class="bh-form-control" (change)="filterChange.emit()" /> <select *ngIf="col.type === 'bool'" [(ngModel)]="col.value" class="bh-form-control" (change)="filterChange.emit()" (click)="isOpenFilter = null"> <option [ngValue]="undefined">All</option> <option [ngValue]="true">True</option> <option [ngValue]="false">False</option> </select> <button *ngIf="col.type !== 'bool'" type="button" (click)="toggleFilterMenu(col); $event.stopPropagation()"> <icon-filter class="bh-w-4"></icon-filter> </button> <column-filter [ngClass]="{ 'bh-hidden': isOpenFilter !== col.field }" [column]="col" (close)="toggleFilterMenu()" (filterChange)="filterChange.emit()" ></column-filter> </div> </ng-container> </th> </ng-container> </tr> </ng-template> `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i2.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", 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]" }, { kind: "directive", type: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.ColumnFilterComponent, selector: "column-filter", inputs: ["column"], outputs: ["close", "filterChange"] }, { kind: "component", type: i4.IconCheckComponent, selector: "icon-check", inputs: ["class"] }, { kind: "component", type: i5.IconDashComponent, selector: "icon-dash", inputs: ["class"] }, { kind: "component", type: i6.IconFilterComponent, selector: "icon-filter", inputs: ["class"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ColumnHeaderComponent, decorators: [{ type: Component, args: [{ selector: 'column-header', template: ` <ng-template #template> <tr> <th *ngIf="all.hasCheckbox" [class]="'bh-w-px'" [ngClass]="{ 'bh-sticky bh-bg-blue-light bh-z-[1]': all.stickyHeader || all.stickyFirstColumn, 'bh-top-0': all.stickyHeader, 'bh-left-0': all.stickyFirstColumn }" > <div class="bh-checkbox"> <input #selectedAll type="checkbox" (click)="selectAll.emit(selectedAll.checked); $event.stopPropagation()" /> <div> <icon-check class="check"></icon-check> <icon-dash class="intermediate"></icon-dash> </div> </div> </th> <ng-container *ngFor="let col of all.columns; let j = index"> <th *ngIf="!col.hide" [ngStyle]="{ 'width': col.width, 'min-width': col.minWidth, 'max-width': col.maxWidth }" [class]="'bh-select-none bh-z-[1]'" [ngClass]="[ all.sortable && col.sort ? 'bh-cursor-pointer' : '', j === 0 && all.stickyFirstColumn ? 'bh-sticky bh-left-0 bh-bg-blue-light' : '', all.hasCheckbox && j === 0 && all.stickyFirstColumn ? 'bh-left-[52px]' : '' ]" [style]="{ width: col.width, 'min-width': col.minWidth, 'max-width': col.maxWidth }" > <div class="bh-flex bh-items-center" [ngClass]="[col.headerClass ? col.headerClass : '']" (click)="all.sortable && col.sort && sortChange.emit(col.field)"> {{ col.title }} <span *ngIf="all.sortable && col.sort" class="bh-ml-3 bh-sort bh-flex bh-items-center" [ngClass]="[all.sortColumn, all.sortDirection]"> <svg width="16" height="16" viewBox="0 0 14 14" fill="none"> <polygon points="3.11,6.25 10.89,6.25 7,1.75" fill="currentColor" class="bh-text-black/20" [ngClass]="[all.sortColumn === col.field && all.sortDirection === 'asc' ? '!bh-text-primary' : '']" ></polygon> <polygon points="7,12.25 10.89,7.75 3.11,7.75" fill="currentColor" class="bh-text-black/20" [ngClass]="[all.sortColumn === col.field && all.sortDirection === 'desc' ? '!bh-text-primary' : '']" ></polygon> </svg> </span> </div> <ng-container *ngIf="all.columnFilter && !isFooter"> <div *ngIf="col.filter" class="bh-filter bh-relative"> <input *ngIf="col.type === 'string'" [(ngModel)]="col.value" type="text" class="bh-form-control" (keyup)="filterChange.emit()" /> <input *ngIf="col.type === 'number'" [(ngModel)]="col.value" type="number" class="bh-form-control" (keyup)="filterChange.emit()" /> <input *ngIf="col.type === 'date'" [(ngModel)]="col.value" type="date" class="bh-form-control" (change)="filterChange.emit()" /> <select *ngIf="col.type === 'bool'" [(ngModel)]="col.value" class="bh-form-control" (change)="filterChange.emit()" (click)="isOpenFilter = null"> <option [ngValue]="undefined">All</option> <option [ngValue]="true">True</option> <option [ngValue]="false">False</option> </select> <button *ngIf="col.type !== 'bool'" type="button" (click)="toggleFilterMenu(col); $event.stopPropagation()"> <icon-filter class="bh-w-4"></icon-filter> </button> <column-filter [ngClass]="{ 'bh-hidden': isOpenFilter !== col.field }" [column]="col" (close)="toggleFilterMenu()" (filterChange)="filterChange.emit()" ></column-filter> </div> </ng-container> </th> </ng-container> </tr> </ng-template> `, }] }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }]; }, propDecorators: { template: [{ type: ViewChild, args: ['template', { static: true }] }], selectedAll: [{ type: ViewChild, args: ['selectedAll'] }], all: [{ type: Input }], isFooter: [{ type: Input }], checkAll: [{ type: Input }], selectAll: [{ type: Output, args: ['selectAll'] }], sortChange: [{ type: Output, args: ['sortChange'] }], filterChange: [{ type: Output, args: ['filterChange'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-header.js","sourceRoot":"","sources":["../../../../lib/column-header.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,SAAS,EAAoB,MAAM,eAAe,CAAC;;;;;;;;AAuFpG,MAAM,OAAO,qBAAqB;IAc9B,YAAoB,gBAAkC;QAAlC,qBAAgB,GAAhB,gBAAgB,CAAkB;QANjC,cAAS,GAAsB,IAAI,YAAY,EAAO,CAAC;QACtD,eAAU,GAAsB,IAAI,YAAY,EAAO,CAAC;QACtD,iBAAY,GAAsB,IAAI,YAAY,EAAO,CAAC;QAElF,iBAAY,GAAQ,IAAI,CAAC;IAEgC,CAAC;IAE1D,QAAQ;QACJ,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QACxD,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAED,cAAc;QACV,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,aAAa,GAAG,IAAI,CAAC,QAAQ,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC;YAC5F,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC;SAC1D;IACL,CAAC;IAED,gBAAgB,CAAC,GAAY;QACzB,IAAI,GAAG,EAAE;YACL,IAAI,IAAI,CAAC,YAAY,KAAK,GAAG,CAAC,KAAK,EAAE;gBACjC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;aAC5B;iBAAM;gBACH,IAAI,CAAC,YAAY,GAAG,GAAG,CAAC,KAAK,CAAC;aACjC;SACJ;aAAM;YACH,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;SAC5B;IACL,CAAC;;mHAtCQ,qBAAqB;uGAArB,qBAAqB,uaAlFpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgFT;4FAEQ,qBAAqB;kBApFjC,SAAS;mBAAC;oBACP,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAgFT;iBACJ;uGAE4C,QAAQ;sBAAhD,SAAS;uBAAC,UAAU,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBACb,WAAW;sBAApC,SAAS;uBAAC,aAAa;gBAEf,GAAG;sBAAX,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBAEe,SAAS;sBAA7B,MAAM;uBAAC,WAAW;gBACG,UAAU;sBAA/B,MAAM;uBAAC,YAAY;gBACI,YAAY;sBAAnC,MAAM;uBAAC,cAAc","sourcesContent":["import { Component, Input, Output, EventEmitter, ViewChild, ViewContainerRef } from '@angular/core';\r\nimport { colDef } from './modals';\r\n\r\n@Component({\r\n    selector: 'column-header',\r\n    template: `\r\n        <ng-template #template>\r\n            <tr>\r\n                <th\r\n                    *ngIf=\"all.hasCheckbox\"\r\n                    [class]=\"'bh-w-px'\"\r\n                    [ngClass]=\"{\r\n                        'bh-sticky bh-bg-blue-light bh-z-[1]': all.stickyHeader || all.stickyFirstColumn,\r\n                        'bh-top-0': all.stickyHeader,\r\n                        'bh-left-0': all.stickyFirstColumn\r\n                    }\"\r\n                >\r\n                    <div class=\"bh-checkbox\">\r\n                        <input #selectedAll type=\"checkbox\" (click)=\"selectAll.emit(selectedAll.checked); $event.stopPropagation()\" />\r\n                        <div>\r\n                            <icon-check class=\"check\"></icon-check>\r\n                            <icon-dash class=\"intermediate\"></icon-dash>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n\r\n                <ng-container *ngFor=\"let col of all.columns; let j = index\">\r\n                    <th\r\n                        *ngIf=\"!col.hide\"\r\n                        [ngStyle]=\"{ 'width': col.width, 'min-width': col.minWidth, 'max-width': col.maxWidth }\"\r\n                        [class]=\"'bh-select-none bh-z-[1]'\"\r\n                        [ngClass]=\"[\r\n                            all.sortable && col.sort ? 'bh-cursor-pointer' : '',\r\n                            j === 0 && all.stickyFirstColumn ? 'bh-sticky bh-left-0 bh-bg-blue-light' : '',\r\n                            all.hasCheckbox && j === 0 && all.stickyFirstColumn ? 'bh-left-[52px]' : ''\r\n                        ]\"\r\n                        [style]=\"{ width: col.width, 'min-width': col.minWidth, 'max-width': col.maxWidth }\"\r\n                    >\r\n                        <div class=\"bh-flex bh-items-center\" [ngClass]=\"[col.headerClass ? col.headerClass : '']\" (click)=\"all.sortable && col.sort && sortChange.emit(col.field)\">\r\n                            {{ col.title }}\r\n                            <span *ngIf=\"all.sortable && col.sort\" class=\"bh-ml-3 bh-sort bh-flex bh-items-center\" [ngClass]=\"[all.sortColumn, all.sortDirection]\">\r\n                                <svg width=\"16\" height=\"16\" viewBox=\"0 0 14 14\" fill=\"none\">\r\n                                    <polygon\r\n                                        points=\"3.11,6.25 10.89,6.25 7,1.75\"\r\n                                        fill=\"currentColor\"\r\n                                        class=\"bh-text-black/20\"\r\n                                        [ngClass]=\"[all.sortColumn === col.field && all.sortDirection === 'asc' ? '!bh-text-primary' : '']\"\r\n                                    ></polygon>\r\n                                    <polygon\r\n                                        points=\"7,12.25 10.89,7.75 3.11,7.75\"\r\n                                        fill=\"currentColor\"\r\n                                        class=\"bh-text-black/20\"\r\n                                        [ngClass]=\"[all.sortColumn === col.field && all.sortDirection === 'desc' ? '!bh-text-primary' : '']\"\r\n                                    ></polygon>\r\n                                </svg>\r\n                            </span>\r\n                        </div>\r\n\r\n                        <ng-container *ngIf=\"all.columnFilter && !isFooter\">\r\n                            <div *ngIf=\"col.filter\" class=\"bh-filter bh-relative\">\r\n                                <input *ngIf=\"col.type === 'string'\" [(ngModel)]=\"col.value\" type=\"text\" class=\"bh-form-control\" (keyup)=\"filterChange.emit()\" />\r\n                                <input *ngIf=\"col.type === 'number'\" [(ngModel)]=\"col.value\" type=\"number\" class=\"bh-form-control\" (keyup)=\"filterChange.emit()\" />\r\n                                <input *ngIf=\"col.type === 'date'\" [(ngModel)]=\"col.value\" type=\"date\" class=\"bh-form-control\" (change)=\"filterChange.emit()\" />\r\n                                <select *ngIf=\"col.type === 'bool'\" [(ngModel)]=\"col.value\" class=\"bh-form-control\" (change)=\"filterChange.emit()\" (click)=\"isOpenFilter = null\">\r\n                                    <option [ngValue]=\"undefined\">All</option>\r\n                                    <option [ngValue]=\"true\">True</option>\r\n                                    <option [ngValue]=\"false\">False</option>\r\n                                </select>\r\n\r\n                                <button *ngIf=\"col.type !== 'bool'\" type=\"button\" (click)=\"toggleFilterMenu(col); $event.stopPropagation()\">\r\n                                    <icon-filter class=\"bh-w-4\"></icon-filter>\r\n                                </button>\r\n\r\n                                <column-filter\r\n                                    [ngClass]=\"{ 'bh-hidden': isOpenFilter !== col.field }\"\r\n                                    [column]=\"col\"\r\n                                    (close)=\"toggleFilterMenu()\"\r\n                                    (filterChange)=\"filterChange.emit()\"\r\n                                ></column-filter>\r\n                            </div>\r\n                        </ng-container>\r\n                    </th>\r\n                </ng-container>\r\n            </tr>\r\n        </ng-template>\r\n    `,\r\n})\r\nexport class ColumnHeaderComponent {\r\n    @ViewChild('template', { static: true }) template: any;\r\n    @ViewChild('selectedAll') selectedAll: any;\r\n\r\n    @Input() all: any;\r\n    @Input() isFooter: any;\r\n    @Input() checkAll: any;\r\n\r\n    @Output('selectAll') selectAll: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output('sortChange') sortChange: EventEmitter<any> = new EventEmitter<any>();\r\n    @Output('filterChange') filterChange: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    isOpenFilter: any = null;\r\n\r\n    constructor(private viewContainerRef: ViewContainerRef) {}\r\n\r\n    ngOnInit() {\r\n        this.viewContainerRef.createEmbeddedView(this.template);\r\n        this.checkboxChange();\r\n    }\r\n\r\n    checkboxChange() {\r\n        if (this.selectedAll) {\r\n            this.selectedAll.nativeElement.indeterminate = this.checkAll !== 0 ? !this.checkAll : false;\r\n            this.selectedAll.nativeElement.checked = this.checkAll;\r\n        }\r\n    }\r\n\r\n    toggleFilterMenu(col?: colDef) {\r\n        if (col) {\r\n            if (this.isOpenFilter === col.field) {\r\n                this.isOpenFilter = null;\r\n            } else {\r\n                this.isOpenFilter = col.field;\r\n            }\r\n        } else {\r\n            this.isOpenFilter = null;\r\n        }\r\n    }\r\n}\r\n"]}