UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

302 lines • 23.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, HostBinding, Input, ViewChild, QueryList, ViewChildren, forwardRef, ChangeDetectionStrategy, ChangeDetectorRef, ElementRef, HostListener } from '@angular/core'; import { IgxColumnComponent } from './column.component'; import { IgxFilteringService } from './filtering/grid-filtering.service'; import { GridBaseAPIService } from './api.service'; import { IgxColumnResizingService } from './grid-column-resizing.service'; import { IgxGridHeaderComponent } from './grid-header.component'; import { IgxGridFilteringCellComponent } from './filtering/grid-filtering-cell.component'; /** @type {?} */ 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; } Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "width", { /** * Gets the width of the header group. * @memberof IgxGridHeaderGroupComponent */ get: /** * Gets the width of the header group. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ 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: /** * Gets the style classes of the header group. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ function () { /** @type {?} */ var defaultClasses = [ 'igx-grid__thead-item', this.column.headerGroupClasses ]; /** @type {?} */ 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 }; Object.entries(classList).forEach(function (_a) { var _b = tslib_1.__read(_a, 2), className = _b[0], value = _b[1]; if (value) { defaultClasses.push(className); } }); return defaultClasses.join(' '); }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "zIndex", { /** * @hidden */ get: /** * @hidden * @return {?} */ 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: /** * Gets the grid of the header group. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ 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: /** * Gets whether the header group belongs to a column that is filtered. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ 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: /** * Gets whether the header group is stored in the last column in the pinned area. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ function () { return this.column.isLastPinned; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "isPinned", { /** * Gets whether the header group is stored in a pinned column. * @memberof IgxGridHeaderGroupComponent */ get: /** * Gets whether the header group is stored in a pinned column. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ 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: /** * Gets whether the header group belongs to a column that is moved. * \@memberof IgxGridHeaderGroupComponent * @return {?} */ function () { return this.grid.draggedColumn === this.column; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "hasLastPinnedChildColumn", { /** * @hidden */ get: /** * @hidden * @return {?} */ function () { return this.column.allChildren.some(function (child) { return child.isLastPinned; }); }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderGroupComponent.prototype, "height", { /** * @hidden */ get: /** * @hidden * @return {?} */ function () { return this.element.nativeElement.getBoundingClientRect().height; }, enumerable: true, configurable: true }); /** * @hidden */ /** * @hidden * @param {?} event * @return {?} */ IgxGridHeaderGroupComponent.prototype.onMouseDown = /** * @hidden * @param {?} event * @return {?} */ function (event) { // hack for preventing text selection in IE and Edge while dragging the resizer event.preventDefault(); }; /** * @return {?} */ IgxGridHeaderGroupComponent.prototype.ngDoCheck = /** * @return {?} */ function () { this.cdr.markForCheck(); }; IgxGridHeaderGroupComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, selector: 'igx-grid-header-group', template: "<ng-container *ngIf=\"column.columnGroup\">\n <span *ngIf=\"grid.hasMovableColumns\" class=\"igx-grid__th-drop-indicator-left\"></span>\n <div class=\"igx-grid__thead-title\"\n [ngClass]=\"{'igx-grid__th--pinned-last': hasLastPinnedChildColumn}\"\n [igxColumnMovingDrag]=\"column\"\n [dragGhostHost]=\"grid.outletDirective.nativeElement\"\n [attr.droppable]=\"true\"\n [igxColumnMovingDrop]=\"column\">{{ column.header }}</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.px]=\"grid.getHeaderGroupWidth(child)\"\n [style.flex-basis.px]=\"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\" [dragGhostHost]=\"grid.igxFilteringOverlayOutlet\" [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" }] } ]; /** @nocollapse */ IgxGridHeaderGroupComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: GridBaseAPIService }, { type: ElementRef }, { type: IgxColumnResizingService }, { type: IgxFilteringService } ]; }; IgxGridHeaderGroupComponent.propDecorators = { column: [{ type: Input }], gridID: [{ type: Input }], headerCell: [{ type: ViewChild, args: [IgxGridHeaderComponent,] }], filterCell: [{ type: ViewChild, args: [IgxGridFilteringCellComponent,] }], children: [{ type: ViewChildren, args: [forwardRef(function () { return IgxGridHeaderGroupComponent; }), { read: IgxGridHeaderGroupComponent },] }], width: [{ type: HostBinding, args: ['style.min-width',] }, { type: HostBinding, args: ['style.flex-basis',] }], styleClasses: [{ type: HostBinding, args: ['class',] }], zIndex: [{ type: HostBinding, args: ['style.z-index',] }], onMouseDown: [{ type: HostListener, args: ['mousedown', ['$event'],] }] }; return IgxGridHeaderGroupComponent; }()); export { IgxGridHeaderGroupComponent }; if (false) { /** * Gets the column of the header group. * \@memberof IgxGridHeaderGroupComponent * @type {?} */ IgxGridHeaderGroupComponent.prototype.column; /** * Gets the `id` of the grid in which the header group is stored. * \@memberof IgxGridHeaderGroupComponent * @type {?} */ IgxGridHeaderGroupComponent.prototype.gridID; /** * @hidden * @type {?} */ IgxGridHeaderGroupComponent.prototype.headerCell; /** * @hidden * @type {?} */ IgxGridHeaderGroupComponent.prototype.filterCell; /** * @hidden * @type {?} */ IgxGridHeaderGroupComponent.prototype.children; /** * @type {?} * @private */ IgxGridHeaderGroupComponent.prototype.cdr; /** @type {?} */ IgxGridHeaderGroupComponent.prototype.gridAPI; /** * @type {?} * @private */ IgxGridHeaderGroupComponent.prototype.element; /** @type {?} */ IgxGridHeaderGroupComponent.prototype.colResizingService; /** @type {?} */ IgxGridHeaderGroupComponent.prototype.filteringService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-header-group.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/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 './column.component';\nimport { IgxFilteringService } from './filtering/grid-filtering.service';\nimport { GridBaseAPIService } from './api.service';\nimport { IgxGridBaseComponent, IGridDataBindable } from './grid-base.component';\nimport { IgxColumnResizingService } from './grid-column-resizing.service';\nimport { IgxGridHeaderComponent } from './grid-header.component';\nimport { IgxGridFilteringCellComponent } from './filtering/grid-filtering-cell.component';\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    /**\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    @HostBinding('style.min-width')\n    @HostBinding('style.flex-basis')\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        Object.entries(classList).forEach(([className, value]) => {\n            if (value) {\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.column.isLastPinned;\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<IgxGridBaseComponent & IGridDataBindable>,\n                private element: ElementRef,\n                public colResizingService: IgxColumnResizingService,\n                public filteringService: IgxFilteringService) { }\n}\n"]}