@alfiob/ng-datatable
Version:
ng-datatable - fully customizable & easy to use datatable library
231 lines (223 loc) • 27.1 kB
JavaScript
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"]}