@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
315 lines • 31 kB
JavaScript
import { __decorate, __metadata, __values } from "tslib";
import { Component, HostBinding, Input, ViewChild, QueryList, ViewChildren, forwardRef, ChangeDetectionStrategy, ChangeDetectorRef, DoCheck, ElementRef, HostListener } from '@angular/core';
import { IgxColumnComponent } from '../columns/column.component';
import { IgxFilteringService } from '../filtering/grid-filtering.service';
import { GridBaseAPIService } from '../api.service';
import { IgxColumnResizingService } from '../resizing/resizing.service';
import { IgxGridHeaderComponent } from './grid-header.component';
import { IgxGridFilteringCellComponent } from '../filtering/base/grid-filtering-cell.component';
import { isIE } from '../../core/utils';
var Z_INDEX = 9999;
/**
* @hidden
*/
var IgxGridHeaderGroupComponent = /** @class */ (function () {
function IgxGridHeaderGroupComponent(cdr, gridAPI, element, colResizingService, filteringService) {
this.cdr = cdr;
this.gridAPI = gridAPI;
this.element = element;
this.colResizingService = colResizingService;
this.filteringService = filteringService;
}
IgxGridHeaderGroupComponent_1 = IgxGridHeaderGroupComponent;
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "gridRowSpan", {
get: function () {
return this.column.gridRowSpan;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "gridColumnSpan", {
get: function () {
return this.column.gridColumnSpan;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "rowEnd", {
get: function () {
return this.column.rowEnd;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "colEnd", {
get: function () {
return this.column.colEnd;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "rowStart", {
get: function () {
return this.column.rowStart;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "colStart", {
get: function () {
return this.column.colStart;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "width", {
/**
* Gets the width of the header group.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
return this.grid.getHeaderGroupWidth(this.column);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "styleClasses", {
/**
* Gets the style classes of the header group.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
var e_1, _a;
var defaultClasses = [
'igx-grid__thead-item',
this.column.headerGroupClasses
];
var classList = {
'igx-grid__th--pinned': this.isPinned,
'igx-grid__th--pinned-last': this.isLastPinned,
'igx-grid__drag-col-header': this.isHeaderDragged,
'igx-grid__th--filtering': this.isFiltered
};
try {
for (var _b = __values(Object.keys(classList)), _c = _b.next(); !_c.done; _c = _b.next()) {
var className = _c.value;
if (classList[className]) {
defaultClasses.push(className);
}
}
}
catch (e_1_1) { e_1 = { error: e_1_1 }; }
finally {
try {
if (_c && !_c.done && (_a = _b.return)) _a.call(_b);
}
finally { if (e_1) throw e_1.error; }
}
return defaultClasses.join(' ');
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "zIndex", {
/**
* @hidden
*/
get: function () {
if (!this.column.pinned) {
return null;
}
return Z_INDEX - this.grid.pinnedColumns.indexOf(this.column);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "grid", {
/**
* Gets the grid of the header group.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
return this.gridAPI.grid;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "isFiltered", {
/**
* Gets whether the header group belongs to a column that is filtered.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
return this.filteringService.filteredColumn === this.column;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "isLastPinned", {
/**
* Gets whether the header group is stored in the last column in the pinned area.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
return !this.grid.hasColumnLayouts ? this.column.isLastPinned : false;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "groupDisplayStyle", {
get: function () {
return this.grid.hasColumnLayouts && this.column.children && !isIE() ? 'flex' : '';
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "isPinned", {
/**
* Gets whether the header group is stored in a pinned column.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
return this.column.pinned;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "isHeaderDragged", {
/**
* Gets whether the header group belongs to a column that is moved.
* @memberof IgxGridHeaderGroupComponent
*/
get: function () {
return this.grid.draggedColumn === this.column;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "hasLastPinnedChildColumn", {
/**
* @hidden
*/
get: function () {
return this.column.allChildren.some(function (child) { return child.isLastPinned; });
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "height", {
/**
* @hidden
*/
get: function () {
return this.element.nativeElement.getBoundingClientRect().height;
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
IgxGridHeaderGroupComponent.prototype.onMouseDown = function (event) {
// hack for preventing text selection in IE and Edge while dragging the resizer
event.preventDefault();
};
IgxGridHeaderGroupComponent.prototype.ngDoCheck = function () {
this.cdr.markForCheck();
};
var IgxGridHeaderGroupComponent_1;
IgxGridHeaderGroupComponent.ctorParameters = function () { return [
{ type: ChangeDetectorRef },
{ type: GridBaseAPIService },
{ type: ElementRef },
{ type: IgxColumnResizingService },
{ type: IgxFilteringService }
]; };
__decorate([
HostBinding('style.-ms-grid-row-span'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "gridRowSpan", null);
__decorate([
HostBinding('style.-ms-grid-column-span'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "gridColumnSpan", null);
__decorate([
HostBinding('style.grid-row-end'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "rowEnd", null);
__decorate([
HostBinding('style.grid-column-end'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "colEnd", null);
__decorate([
HostBinding('style.-ms-grid-row'),
HostBinding('style.grid-row-start'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "rowStart", null);
__decorate([
HostBinding('style.-ms-grid-column'),
HostBinding('style.grid-column-start'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "colStart", null);
__decorate([
Input(),
__metadata("design:type", IgxColumnComponent)
], IgxGridHeaderGroupComponent.prototype, "column", void 0);
__decorate([
Input(),
__metadata("design:type", String)
], IgxGridHeaderGroupComponent.prototype, "gridID", void 0);
__decorate([
ViewChild(IgxGridHeaderComponent),
__metadata("design:type", IgxGridHeaderComponent)
], IgxGridHeaderGroupComponent.prototype, "headerCell", void 0);
__decorate([
ViewChild(IgxGridFilteringCellComponent),
__metadata("design:type", IgxGridFilteringCellComponent)
], IgxGridHeaderGroupComponent.prototype, "filterCell", void 0);
__decorate([
ViewChildren(forwardRef(function () { return IgxGridHeaderGroupComponent_1; }), { read: IgxGridHeaderGroupComponent_1 }),
__metadata("design:type", QueryList)
], IgxGridHeaderGroupComponent.prototype, "children", void 0);
__decorate([
HostBinding('class'),
__metadata("design:type", String),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "styleClasses", null);
__decorate([
HostBinding('style.z-index'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "zIndex", null);
__decorate([
HostBinding('style.display'),
__metadata("design:type", String),
__metadata("design:paramtypes", [])
], IgxGridHeaderGroupComponent.prototype, "groupDisplayStyle", null);
__decorate([
HostListener('mousedown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [Object]),
__metadata("design:returntype", void 0)
], IgxGridHeaderGroupComponent.prototype, "onMouseDown", null);
IgxGridHeaderGroupComponent = IgxGridHeaderGroupComponent_1 = __decorate([
Component({
changeDetection: ChangeDetectionStrategy.OnPush,
preserveWhitespaces: false,
selector: 'igx-grid-header-group',
template: "<ng-container *ngIf=\"grid.hasColumnLayouts && column.columnGroup\">\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-left\"></span>\n <div class=\"igx-grid__thead-group igx-grid__mrl-block\"\n [ngClass]=\"{'igx-grid__th--pinned-last': hasLastPinnedChildColumn}\"\n [ngStyle]=\"{'grid-template-rows':column.getGridTemplate(true, false),\n 'grid-template-columns':column.getGridTemplate(false, false),\n '-ms-grid-rows':column.getGridTemplate(true, true),\n '-ms-grid-columns':column.getGridTemplate(false, true)}\">\n <ng-container *ngFor=\"let child of column.children\" >\n <igx-grid-header-group *ngIf=\"!child.hidden\" class=\"igx-grid__thead-subgroup\"\n [column]=\"child\"\n [gridID]=\"child.gridID\"\n [igxColumnMovingDrag]=\"child\"\n [ghostHost]=\"grid.outletDirective.nativeElement\"\n [attr.droppable]=\"true\"\n [igxColumnMovingDrop]=\"child\">\n </igx-grid-header-group>\n </ng-container>\n </div>\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-right\"></span>\n</ng-container>\n\n\n<ng-template #defaultColumn>\n <span class=\"igx-grid__th-group-title\" [attr.title]=\"column.header\">{{column.header}}</span>\n</ng-template>\n\n<ng-template #defaultCollapseIndicator>\n <igx-icon [attr.draggable]=\"false\" >\n {{column.expanded ? 'expand_more' : 'chevron_right'}} </igx-icon>\n</ng-template>\n\n<ng-container *ngIf=\"!grid.hasColumnLayouts && column.columnGroup\">\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-left\"></span>\n <div class=\"igx-grid__thead-title\"\n role=\"columnheader\"\n [attr.aria-label]=\"column.header || column.field\"\n [attr.aria-expanded]=\"column.expanded\"\n tabindex=\"0\"\n [ngClass]=\"{'igx-grid__th--pinned-last': hasLastPinnedChildColumn, 'igx-grid__th--collapsible': column.collapsible}\"\n [igxColumnMovingDrag]=\"column\"\n [ghostHost]=\"grid.outletDirective.nativeElement\"\n [attr.droppable]=\"true\"\n [igxColumnMovingDrop]=\"column\">\n <ng-container *ngIf=\"column.collapsible\">\n <div class=\"igx-grid__th-expander\" (click)=\"column.expanded = !column.expanded\">\n <ng-container\n *ngTemplateOutlet=\"column.collapsibleIndicatorTemplate ? column.collapsibleIndicatorTemplate : defaultCollapseIndicator; context: {$implicit: column, column: column}\">\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngTemplateOutlet=\"column.headerTemplate ? column.headerTemplate : defaultColumn; context: { $implicit: column, column: column}\">\n </ng-container>\n </div>\n <div class=\"igx-grid__thead-group\">\n <ng-container *ngFor=\"let child of column.children\">\n <igx-grid-header-group *ngIf=\"!child.hidden\" class=\"igx-grid__thead-subgroup\"\n [column]=\"child\"\n [gridID]=\"child.grid.id\"\n [style.min-width]=\"grid.getHeaderGroupWidth(child)\"\n [style.flex-basis]=\"grid.getHeaderGroupWidth(child)\">\n </igx-grid-header-group>\n </ng-container>\n </div>\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-right\"></span>\n</ng-container>\n\n<ng-container *ngIf=\"!column.columnGroup\">\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-left\"></span>\n <igx-grid-header [igxColumnMovingDrag]=\"column\" [ghostHost]=\"grid.outletDirective.nativeElement\" [attr.droppable]=\"true\" [igxColumnMovingDrop]=\"column\" [gridID]=\"column.grid.id\" [column]=\"column\"></igx-grid-header>\n <igx-grid-filtering-cell *ngIf=\"grid.allowFiltering && grid.filterMode == 'quickFilter'\" [column]=\"column\" [attr.draggable]=\"false\"></igx-grid-filtering-cell>\n <span *ngIf=\"!column.columnGroup && column.resizable\" class=\"igx-grid__th-resize-handle\"\n [igxResizeHandle]=\"column\"\n [attr.draggable]=\"false\"\n [style.cursor]=\"colResizingService.resizeCursor\">\n </span>\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-right\"></span>\n</ng-container>\n"
}),
__metadata("design:paramtypes", [ChangeDetectorRef,
GridBaseAPIService,
ElementRef,
IgxColumnResizingService,
IgxFilteringService])
], IgxGridHeaderGroupComponent);
return IgxGridHeaderGroupComponent;
}());
export { IgxGridHeaderGroupComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-header-group.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/headers/grid-header-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    HostBinding,\n    Input,\n    ViewChild,\n    QueryList,\n    ViewChildren,\n    forwardRef,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    DoCheck,\n    ElementRef,\n    HostListener\n} from '@angular/core';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { IgxFilteringService } from '../filtering/grid-filtering.service';\nimport { GridBaseAPIService } from '../api.service';\nimport { IgxGridBaseDirective } from '../grid-base.directive';\nimport { IgxColumnResizingService } from '../resizing/resizing.service';\nimport { IgxGridHeaderComponent } from './grid-header.component';\nimport { IgxGridFilteringCellComponent } from '../filtering/base/grid-filtering-cell.component';\nimport { isIE } from '../../core/utils';\nimport { GridType } from '../common/grid.interface';\n\nconst Z_INDEX = 9999;\n\n/**\n * @hidden\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-grid-header-group',\n    templateUrl: './grid-header-group.component.html'\n})\nexport class IgxGridHeaderGroupComponent implements DoCheck {\n\n    @HostBinding('style.-ms-grid-row-span')\n    get gridRowSpan(): number {\n        return this.column.gridRowSpan;\n    }\n\n    @HostBinding('style.-ms-grid-column-span')\n    get gridColumnSpan(): number {\n        return this.column.gridColumnSpan;\n    }\n\n\n    @HostBinding('style.grid-row-end')\n    get rowEnd(): number {\n        return this.column.rowEnd;\n    }\n\n    @HostBinding('style.grid-column-end')\n    get colEnd(): number {\n        return this.column.colEnd;\n    }\n\n    @HostBinding('style.-ms-grid-row')\n    @HostBinding('style.grid-row-start')\n    get rowStart(): number {\n        return this.column.rowStart;\n    }\n\n    @HostBinding('style.-ms-grid-column')\n    @HostBinding('style.grid-column-start')\n    get colStart(): number {\n        return this.column.colStart;\n    }\n\n    /**\n     * Gets the column of the header group.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    @Input()\n    public column: IgxColumnComponent;\n\n    /**\n     * Gets the `id` of the grid in which the header group is stored.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    @Input()\n    public gridID: string;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(IgxGridHeaderComponent)\n    public headerCell: IgxGridHeaderComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChild(IgxGridFilteringCellComponent)\n    public filterCell: IgxGridFilteringCellComponent;\n\n    /**\n     * @hidden\n     */\n    @ViewChildren(forwardRef(() => IgxGridHeaderGroupComponent), { read: IgxGridHeaderGroupComponent })\n    public children: QueryList<IgxGridHeaderGroupComponent>;\n\n    /**\n     * Gets the width of the header group.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    get width() {\n        return this.grid.getHeaderGroupWidth(this.column);\n    }\n\n    /**\n     * Gets the style classes of the header group.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    @HostBinding('class')\n    get styleClasses(): string {\n        const defaultClasses = [\n            'igx-grid__thead-item',\n            this.column.headerGroupClasses\n        ];\n\n        const classList = {\n            'igx-grid__th--pinned': this.isPinned,\n            'igx-grid__th--pinned-last': this.isLastPinned,\n            'igx-grid__drag-col-header': this.isHeaderDragged,\n            'igx-grid__th--filtering': this.isFiltered\n        };\n\n        for (const className of Object.keys(classList)) {\n            if (classList[className]) {\n                defaultClasses.push(className);\n            }\n        }\n        return defaultClasses.join(' ');\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('style.z-index')\n    get zIndex() {\n        if (!this.column.pinned) {\n            return null;\n        }\n        return Z_INDEX - this.grid.pinnedColumns.indexOf(this.column);\n    }\n\n    /**\n     * Gets the grid of the header group.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    get grid(): any {\n        return this.gridAPI.grid;\n    }\n\n    /**\n     * Gets whether the header group belongs to a column that is filtered.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    get isFiltered(): boolean {\n        return this.filteringService.filteredColumn === this.column;\n    }\n\n    /**\n     * Gets whether the header group is stored in the last column in the pinned area.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    get isLastPinned(): boolean {\n        return !this.grid.hasColumnLayouts ? this.column.isLastPinned : false;\n    }\n\n    @HostBinding('style.display')\n    get groupDisplayStyle(): string {\n        return this.grid.hasColumnLayouts && this.column.children && !isIE() ? 'flex' : '';\n    }\n\n    /**\n     * Gets whether the header group is stored in a pinned column.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    get isPinned(): boolean {\n        return this.column.pinned;\n    }\n\n    /**\n     * Gets whether the header group belongs to a column that is moved.\n     * @memberof IgxGridHeaderGroupComponent\n     */\n    get isHeaderDragged(): boolean {\n        return this.grid.draggedColumn ===  this.column;\n    }\n\n    /**\n     * @hidden\n     */\n    get hasLastPinnedChildColumn(): boolean {\n        return this.column.allChildren.some(child => child.isLastPinned);\n    }\n\n    /**\n     * @hidden\n     */\n    get height() {\n        return this.element.nativeElement.getBoundingClientRect().height;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostListener('mousedown', ['$event'])\n    public onMouseDown(event): void {\n        // hack for preventing text selection in IE and Edge while dragging the resizer\n        event.preventDefault();\n    }\n\n    public ngDoCheck() {\n        this.cdr.markForCheck();\n    }\n\n    constructor(private cdr: ChangeDetectorRef,\n                public gridAPI: GridBaseAPIService<IgxGridBaseDirective & GridType>,\n                public element: ElementRef,\n                public colResizingService: IgxColumnResizingService,\n                public filteringService: IgxFilteringService) { }\n}\n"]}