UNPKG

@catull/igniteui-angular

Version:

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

305 lines 37.5 kB
import { __decorate, __metadata, __param, __values } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, DoCheck, ElementRef, HostBinding, HostListener, Input, NgZone, OnInit, Inject, OnDestroy, NgModuleRef } from '@angular/core'; import { DataType } from '../../data-operations/data-util'; import { SortingDirection } from '../../data-operations/sorting-expression.interface'; import { GridBaseAPIService } from '../api.service'; import { IgxColumnComponent } from '../columns/column.component'; import { IgxFilteringService } from '../filtering/grid-filtering.service'; import { IgxColumnResizingService } from '../resizing/resizing.service'; import { IgxOverlayService } from '../../services/overlay/overlay'; import { IgxGridExcelStyleFilteringComponent } from '../filtering/excel-style/grid.excel-style-filtering.component'; import { VerticalAlignment } from '../../services/overlay/utilities'; import { AutoPositionStrategy } from '../../services/overlay/position/auto-position-strategy'; import { useAnimation } from '@angular/animations'; import { filter, takeUntil } from 'rxjs/operators'; import { Subject } from 'rxjs'; import { fadeIn, fadeOut } from '../../animations/main'; import { AbsoluteScrollStrategy } from '../../services/overlay/scroll/absolute-scroll-strategy'; /** * @hidden */ var IgxGridHeaderComponent = /** @class */ (function () { function IgxGridHeaderComponent(gridAPI, colResizingService, cdr, elementRef, zone, _filteringService, _moduleRef, _overlayService) { this.gridAPI = gridAPI; this.colResizingService = colResizingService; this.cdr = cdr; this.elementRef = elementRef; this.zone = zone; this._filteringService = _filteringService; this._moduleRef = _moduleRef; this._overlayService = _overlayService; this._destroy$ = new Subject(); this.hostRole = 'columnheader'; this.tabindex = 0; this.sortDirection = SortingDirection.None; } Object.defineProperty(IgxGridHeaderComponent.prototype, "styleClasses", { get: function () { var e_1, _a; var defaultClasses = [ 'igx-grid__th--fw', this.column.headerClasses ]; var classList = { 'igx-grid__th': !this.column.columnGroup, 'asc': this.ascending, 'desc': this.descending, 'igx-grid__th--number': this.column.dataType === DataType.Number, 'igx-grid__th--sortable': this.column.sortable, 'igx-grid__th--filtrable': this.column.filterable && this.grid.filteringService.isFilterRowVisible, 'igx-grid__th--sorted': this.sorted }; try { for (var _b = __values(Object.keys(classList)), _c = _b.next(); !_c.done; _c = _b.next()) { var klass = _c.value; if (classList[klass]) { defaultClasses.push(klass); } } } 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(IgxGridHeaderComponent.prototype, "height", { get: function () { if (this.grid.hasColumnGroups) { return (this.grid.maxLevelHeaderDepth + 1 - this.column.level) * this.grid.defaultRowHeight / this.grid._baseFontSize; } return null; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderComponent.prototype, "ascending", { get: function () { return this.sortDirection === SortingDirection.Asc; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderComponent.prototype, "descending", { get: function () { return this.sortDirection === SortingDirection.Desc; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderComponent.prototype, "sortingIcon", { get: function () { if (this.sortDirection !== SortingDirection.None) { // arrow_downward and arrow_upward // are material icons ligature strings return this.sortDirection === SortingDirection.Asc ? 'arrow_upward' : 'arrow_downward'; } return 'arrow_upward'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderComponent.prototype, "sorted", { get: function () { return this.sortDirection !== SortingDirection.None; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderComponent.prototype, "filterIconClassName", { get: function () { return this.column.filteringExpressionsTree ? 'igx-excel-filter__icon--filtered' : 'igx-excel-filter__icon'; }, enumerable: true, configurable: true }); Object.defineProperty(IgxGridHeaderComponent.prototype, "headerID", { get: function () { return this.gridID + "_" + this.column.field; }, enumerable: true, configurable: true }); IgxGridHeaderComponent.prototype.ngOnInit = function () { this.initFilteringSettings(); }; IgxGridHeaderComponent.prototype.ngDoCheck = function () { this.getSortDirection(); this.cdr.markForCheck(); }; IgxGridHeaderComponent.prototype.ngOnDestroy = function () { this._destroy$.next(true); this._destroy$.complete(); if (this._componentOverlayId) { this._overlayService.hide(this._componentOverlayId); } }; IgxGridHeaderComponent.prototype.onClick = function (event) { if (!this.colResizingService.isColumnResizing) { event.stopPropagation(); if (this.grid.filteringService.isFilterRowVisible) { if (this.column.filterable && !this.column.columnGroup && !this.grid.filteringService.isFilterComplex(this.column.field)) { this.grid.filteringService.filteredColumn = this.column; } } else if (this.column.sortable) { this.triggerSort(); } } }; IgxGridHeaderComponent.prototype.onFilteringIconClick = function (event) { event.stopPropagation(); this.toggleFilterDropdown(); }; Object.defineProperty(IgxGridHeaderComponent.prototype, "grid", { get: function () { return this.gridAPI.grid; }, enumerable: true, configurable: true }); IgxGridHeaderComponent.prototype.getSortDirection = function () { var _this = this; var expr = this.gridAPI.grid.sortingExpressions.find(function (x) { return x.fieldName === _this.column.field; }); this.sortDirection = expr ? expr.dir : SortingDirection.None; }; IgxGridHeaderComponent.prototype.onSortingIconClick = function (event) { if (this.grid.filteringService.isFilterRowVisible) { event.stopPropagation(); this.triggerSort(); } }; IgxGridHeaderComponent.prototype.triggerSort = function () { var _this = this; var groupingExpr = this.grid.groupingExpressions ? this.grid.groupingExpressions.find(function (expr) { return expr.fieldName === _this.column.field; }) : null; var sortDir = groupingExpr ? this.sortDirection + 1 > SortingDirection.Desc ? SortingDirection.Asc : SortingDirection.Desc : this.sortDirection + 1 > SortingDirection.Desc ? SortingDirection.None : this.sortDirection + 1; this.sortDirection = sortDir; this.grid.sort({ fieldName: this.column.field, dir: this.sortDirection, ignoreCase: this.column.sortingIgnoreCase, strategy: this.column.sortStrategy }); }; IgxGridHeaderComponent.prototype.toggleFilterDropdown = function () { if (!this._componentOverlayId) { var headerTarget = this.elementRef.nativeElement; var filterIconTarget = headerTarget.querySelector('.' + this.filterIconClassName); this._filterMenuOverlaySettings.positionStrategy.settings.target = filterIconTarget; this._filterMenuOverlaySettings.outlet = this.grid.outlet; this._componentOverlayId = this._overlayService.attach(IgxGridExcelStyleFilteringComponent, this._filterMenuOverlaySettings, this._moduleRef); this._overlayService.show(this._componentOverlayId, this._filterMenuOverlaySettings); } }; IgxGridHeaderComponent.prototype.initFilteringSettings = function () { var _this = this; this._filterMenuPositionSettings = { verticalStartPoint: VerticalAlignment.Bottom, openAnimation: useAnimation(fadeIn, { params: { duration: '250ms' } }), closeAnimation: useAnimation(fadeOut, { params: { duration: '200ms' } }) }; this._filterMenuOverlaySettings = { closeOnOutsideClick: true, modal: false, positionStrategy: new AutoPositionStrategy(this._filterMenuPositionSettings), scrollStrategy: new AbsoluteScrollStrategy() }; this._overlayService.onOpening.pipe(filter(function (overlay) { return overlay.id === _this._componentOverlayId; }), takeUntil(this._destroy$)).subscribe(function (eventArgs) { _this.onOverlayOpening(eventArgs); }); this._overlayService.onClosed.pipe(filter(function (overlay) { return overlay.id === _this._componentOverlayId; }), takeUntil(this._destroy$)).subscribe(function () { _this.onOverlayClosed(); }); }; IgxGridHeaderComponent.prototype.onOverlayOpening = function (eventArgs) { var instance = eventArgs.componentRef.instance; if (instance) { instance.initialize(this.column, this._overlayService, eventArgs.id); } }; IgxGridHeaderComponent.prototype.onOverlayClosed = function () { this._componentOverlayId = null; }; IgxGridHeaderComponent.ctorParameters = function () { return [ { type: GridBaseAPIService }, { type: IgxColumnResizingService }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: NgZone }, { type: IgxFilteringService }, { type: NgModuleRef }, { type: IgxOverlayService, decorators: [{ type: Inject, args: [IgxOverlayService,] }] } ]; }; __decorate([ Input(), __metadata("design:type", IgxColumnComponent) ], IgxGridHeaderComponent.prototype, "column", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxGridHeaderComponent.prototype, "gridID", void 0); __decorate([ HostBinding('class'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], IgxGridHeaderComponent.prototype, "styleClasses", null); __decorate([ HostBinding('style.height.rem'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxGridHeaderComponent.prototype, "height", null); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxGridHeaderComponent.prototype, "hostRole", void 0); __decorate([ HostBinding('attr.tabindex'), __metadata("design:type", Object) ], IgxGridHeaderComponent.prototype, "tabindex", void 0); __decorate([ HostBinding('attr.id'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxGridHeaderComponent.prototype, "headerID", null); __decorate([ HostListener('click', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [Object]), __metadata("design:returntype", void 0) ], IgxGridHeaderComponent.prototype, "onClick", null); IgxGridHeaderComponent = __decorate([ Component({ changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, selector: 'igx-grid-header', template: "<ng-template #defaultColumn>\n <span [attr.title]=\"column.header || column.field\">{{ column.header || column.field }}</span>\n</ng-template>\n\n<span class=\"igx-grid__th-title\">\n <ng-container *ngTemplateOutlet=\"column.headerTemplate ? column.headerTemplate : defaultColumn; context: { $implicit: column, column: column}\">\n </ng-container>\n</span>\n<div class=\"igx-grid__th-icons\" *ngIf=\"!column.columnGroup\">\n <igx-icon [attr.draggable]=\"false\"\n class=\"sort-icon\"\n *ngIf=\"column.sortable\"\n (click)=\"onSortingIconClick($event)\">\n {{sortingIcon}}\n </igx-icon>\n\n <igx-icon [ngClass]=\"filterIconClassName\" [attr.draggable]=\"false\" (click)=\"onFilteringIconClick($event)\"\n *ngIf=\"grid.allowFiltering == true && column.filterable && grid.filterMode == 'excelStyleFilter'\">\n filter_list\n </igx-icon>\n</div>\n" }), __param(7, Inject(IgxOverlayService)), __metadata("design:paramtypes", [GridBaseAPIService, IgxColumnResizingService, ChangeDetectorRef, ElementRef, NgZone, IgxFilteringService, NgModuleRef, IgxOverlayService]) ], IgxGridHeaderComponent); return IgxGridHeaderComponent; }()); export { IgxGridHeaderComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-header.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/headers/grid-header.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,OAAO,EACP,UAAU,EACV,WAAW,EACX,YAAY,EACZ,KAAK,EACL,MAAM,EACN,MAAM,EACN,MAAM,EACN,SAAS,EACT,WAAW,EACd,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,QAAQ,EAAE,MAAM,iCAAiC,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,oDAAoD,CAAC;AACtF,OAAO,EAAE,kBAAkB,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,EAAE,kBAAkB,EAAE,MAAM,6BAA6B,CAAC;AACjE,OAAO,EAAE,mBAAmB,EAAE,MAAM,qCAAqC,CAAC;AAE1E,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAC;AACxE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,mCAAmC,EAAE,MAAM,+DAA+D,CAAC;AACpH,OAAO,EAAqC,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACxG,OAAO,EAAE,oBAAoB,EAAE,MAAM,wDAAwD,CAAC;AAC9F,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,sBAAsB,EAAE,MAAM,wDAAwD,CAAC;AAGhG;;GAEG;AAOH;IAoFI,gCACW,OAA4D,EAC5D,kBAA4C,EAC5C,GAAsB,EACtB,UAAsB,EACtB,IAAY,EACX,iBAAsC,EACtC,UAA4B,EACD,eAAkC;QAP9D,YAAO,GAAP,OAAO,CAAqD;QAC5D,uBAAkB,GAAlB,kBAAkB,CAA0B;QAC5C,QAAG,GAAH,GAAG,CAAmB;QACtB,eAAU,GAAV,UAAU,CAAY;QACtB,SAAI,GAAJ,IAAI,CAAQ;QACX,sBAAiB,GAAjB,iBAAiB,CAAqB;QACtC,eAAU,GAAV,UAAU,CAAkB;QACD,oBAAe,GAAf,eAAe,CAAmB;QAvFjE,cAAS,GAAG,IAAI,OAAO,EAAW,CAAC;QAmEpC,aAAQ,GAAG,cAAc,CAAC;QAG1B,aAAQ,GAAG,CAAC,CAAC;QAOV,kBAAa,GAAG,gBAAgB,CAAC,IAAI,CAAC;IAW5C,CAAC;IA/EL,sBAAI,gDAAY;aAAhB;;YACI,IAAM,cAAc,GAAG;gBACnB,kBAAkB;gBAClB,IAAI,CAAC,MAAM,CAAC,aAAa;aAC5B,CAAC;YAEF,IAAM,SAAS,GAAG;gBACd,cAAc,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW;gBACxC,KAAK,EAAE,IAAI,CAAC,SAAS;gBACrB,MAAM,EAAE,IAAI,CAAC,UAAU;gBACvB,sBAAsB,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,KAAK,QAAQ,CAAC,MAAM;gBAChE,wBAAwB,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;gBAC9C,yBAAyB,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB;gBAClG,sBAAsB,EAAE,IAAI,CAAC,MAAM;aACtC,CAAC;;gBAEF,KAAoB,IAAA,KAAA,SAAA,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA,gBAAA,4BAAE;oBAAvC,IAAM,KAAK,WAAA;oBACZ,IAAI,SAAS,CAAC,KAAK,CAAC,EAAE;wBAClB,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBAC9B;iBACJ;;;;;;;;;YACD,OAAO,cAAc,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpC,CAAC;;;OAAA;IAGD,sBAAI,0CAAM;aAAV;YACI,IAAI,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBAC3B,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC;aACzH;YACD,OAAO,IAAI,CAAC;QAChB,CAAC;;;OAAA;IAED,sBAAI,6CAAS;aAAb;YACI,OAAO,IAAI,CAAC,aAAa,KAAK,gBAAgB,CAAC,GAAG,CAAC;QACvD,CAAC;;;OAAA;IAED,sBAAI,8CAAU;aAAd;YACI,OAAO,IAAI,CAAC,aAAa,KAAK,gBAAgB,CAAC,IAAI,CAAC;QACxD,CAAC;;;OAAA;IAED,sBAAI,+CAAW;aAAf;YACI,IAAI,IAAI,CAAC,aAAa,KAAK,gBAAgB,CAAC,IAAI,EAAE;gBAC9C,kCAAkC;gBAClC,sCAAsC;gBACtC,OAAO,IAAI,CAAC,aAAa,KAAK,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,gBAAgB,CAAC;aAC1F;YACD,OAAO,cAAc,CAAC;QAC1B,CAAC;;;OAAA;IAED,sBAAI,0CAAM;aAAV;YACI,OAAO,IAAI,CAAC,aAAa,KAAK,gBAAgB,CAAC,IAAI,CAAC;QACxD,CAAC;;;OAAA;IAED,sBAAI,uDAAmB;aAAvB;YACI,OAAO,IAAI,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAC,CAAC,kCAAkC,CAAC,CAAC,CAAC,wBAAwB,CAAC;QAChH,CAAC;;;OAAA;IASD,sBAAI,4CAAQ;aAAZ;YACI,OAAU,IAAI,CAAC,MAAM,SAAI,IAAI,CAAC,MAAM,CAAC,KAAO,CAAC;QACjD,CAAC;;;OAAA;IAeM,yCAAQ,GAAf;QACI,IAAI,CAAC,qBAAqB,EAAE,CAAC;IACjC,CAAC;IAEM,0CAAS,GAAhB;QACI,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,4CAAW,GAAX;QACI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC1B,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAE1B,IAAI,IAAI,CAAC,mBAAmB,EAAE;YAC1B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;SACvD;IACL,CAAC;IAGM,wCAAO,GAAd,UAAe,KAAK;QAChB,IAAI,CAAC,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE;YAC3C,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE;gBAC/C,IAAI,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,WAAW;oBAClD,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;oBAChE,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,cAAc,GAAG,IAAI,CAAC,MAAM,CAAC;iBAC3D;aACJ;iBAAM,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;gBAC7B,IAAI,CAAC,WAAW,EAAE,CAAC;aACtB;SACJ;IACL,CAAC;IAEM,qDAAoB,GAA3B,UAA4B,KAAK;QAC7B,KAAK,CAAC,eAAe,EAAE,CAAC;QAExB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAChC,CAAC;IAED,sBAAI,wCAAI;aAAR;YACI,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAC7B,CAAC;;;OAAA;IAES,iDAAgB,GAA1B;QAAA,iBAGC;QAFG,IAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,UAAC,CAAC,IAAK,OAAA,CAAC,CAAC,SAAS,KAAK,KAAI,CAAC,MAAM,CAAC,KAAK,EAAjC,CAAiC,CAAC,CAAC;QACjG,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC;IACjE,CAAC;IAEM,mDAAkB,GAAzB,UAA0B,KAAK;QAC3B,IAAI,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,kBAAkB,EAAE;YAC/C,KAAK,CAAC,eAAe,EAAE,CAAC;YACxB,IAAI,CAAC,WAAW,EAAE,CAAC;SACtB;IACL,CAAC;IAEO,4CAAW,GAAnB;QAAA,iBASC;QARG,IAAM,YAAY,GAAG,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAChD,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAC,IAAI,IAAK,OAAA,IAAI,CAAC,SAAS,KAAK,KAAI,CAAC,MAAM,CAAC,KAAK,EAApC,CAAoC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9F,IAAM,OAAO,GAAG,YAAY,CAAC,CAAC;YAC1B,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI;YAC7F,CAAC,CAAC,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;QACtG,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC;QAC7B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,GAAG,EAAE,IAAI,CAAC,aAAa,EAAE,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,iBAAiB;YAC7G,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;IAC9C,CAAC;IAEO,qDAAoB,GAA5B;QACI,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE;YAC3B,IAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;YACnD,IAAM,gBAAgB,GAAG,YAAY,CAAC,aAAa,CAAC,GAAG,GAAG,IAAI,CAAC,mBAAmB,CAAC,CAAC;YAEpF,IAAI,CAAC,0BAA0B,CAAC,gBAAgB,CAAC,QAAQ,CAAC,MAAM,GAAG,gBAAgB,CAAC;YACpF,IAAI,CAAC,0BAA0B,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;YAE1D,IAAI,CAAC,mBAAmB;gBACpB,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,mCAAmC,EAAE,IAAI,CAAC,0BAA0B,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;YACvH,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,IAAI,CAAC,0BAA0B,CAAC,CAAC;SACxF;IACL,CAAC;IAEO,sDAAqB,GAA7B;QAAA,iBAiCC;QAhCG,IAAI,CAAC,2BAA2B,GAAG;YAC/B,kBAAkB,EAAE,iBAAiB,CAAC,MAAM;YAC5C,aAAa,EAAE,YAAY,CAAC,MAAM,EAAE;gBAChC,MAAM,EAAE;oBACJ,QAAQ,EAAE,OAAO;iBACpB;aACJ,CAAC;YACF,cAAc,EAAE,YAAY,CAAC,OAAO,EAAE;gBAClC,MAAM,EAAE;oBACJ,QAAQ,EAAE,OAAO;iBACpB;aACJ,CAAC;SACL,CAAC;QAEF,IAAI,CAAC,0BAA0B,GAAG;YAC9B,mBAAmB,EAAE,IAAI;YACzB,KAAK,EAAE,KAAK;YACZ,gBAAgB,EAAE,IAAI,oBAAoB,CAAC,IAAI,CAAC,2BAA2B,CAAC;YAC5E,cAAc,EAAE,IAAI,sBAAsB,EAAE;SAC/C,CAAC;QAEF,IAAI,CAAC,eAAe,CAAC,SAAS,CAAC,IAAI,CAC/B,MAAM,CAAC,UAAC,OAAO,IAAK,OAAA,OAAO,CAAC,EAAE,KAAK,KAAI,CAAC,mBAAmB,EAAvC,CAAuC,CAAC,EAC5D,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,UAAC,SAAS;YAC3C,KAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,IAAI,CAC9B,MAAM,CAAC,UAAA,OAAO,IAAI,OAAA,OAAO,CAAC,EAAE,KAAK,KAAI,CAAC,mBAAmB,EAAvC,CAAuC,CAAC,EAC1D,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC;YACjC,KAAI,CAAC,eAAe,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACX,CAAC;IAEO,iDAAgB,GAAxB,UAAyB,SAAS;QAC9B,IAAM,QAAQ,GAAG,SAAS,CAAC,YAAY,CAAC,QAA+C,CAAC;QACxF,IAAI,QAAQ,EAAE;YACV,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,eAAe,EAAE,SAAS,CAAC,EAAE,CAAC,CAAC;SACxE;IACL,CAAC;IAEO,gDAAe,GAAvB;QACI,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;IACpC,CAAC;;gBAtImB,kBAAkB;gBACP,wBAAwB;gBACvC,iBAAiB;gBACV,UAAU;gBAChB,MAAM;gBACQ,mBAAmB;gBAC1B,WAAW;gBACqB,iBAAiB,uBAApE,MAAM,SAAC,iBAAiB;;IApF7B;QADC,KAAK,EAAE;kCACO,kBAAkB;0DAAC;IAGlC;QADC,KAAK,EAAE;;0DACc;IAGtB;QADC,WAAW,CAAC,OAAO,CAAC;;;8DAuBpB;IAGD;QADC,WAAW,CAAC,kBAAkB,CAAC;;;wDAM/B;IA4BD;QADC,WAAW,CAAC,WAAW,CAAC;;4DACQ;IAGjC;QADC,WAAW,CAAC,eAAe,CAAC;;4DACT;IAGpB;QADC,WAAW,CAAC,SAAS,CAAC;;;0DAGtB;IAkCD;QADC,YAAY,CAAC,OAAO,EAAE,CAAC,QAAQ,CAAC,CAAC;;;;yDAajC;IA9HQ,sBAAsB;QANlC,SAAS,CAAC;YACP,eAAe,EAAE,uBAAuB,CAAC,MAAM;YAC/C,mBAAmB,EAAE,KAAK;YAC1B,QAAQ,EAAE,iBAAiB;YAC3B,q5BAA2C;SAC9C,CAAC;QA6FO,WAAA,MAAM,CAAC,iBAAiB,CAAC,CAAA;yCAPV,kBAAkB;YACP,wBAAwB;YACvC,iBAAiB;YACV,UAAU;YAChB,MAAM;YACQ,mBAAmB;YAC1B,WAAW;YACqB,iBAAiB;OA5FhE,sBAAsB,CA4NlC;IAAD,6BAAC;CAAA,AA5ND,IA4NC;SA5NY,sBAAsB","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    DoCheck,\n    ElementRef,\n    HostBinding,\n    HostListener,\n    Input,\n    NgZone,\n    OnInit,\n    Inject,\n    OnDestroy,\n    NgModuleRef\n} from '@angular/core';\nimport { DataType } from '../../data-operations/data-util';\nimport { SortingDirection } from '../../data-operations/sorting-expression.interface';\nimport { GridBaseAPIService } from '../api.service';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { IgxFilteringService } from '../filtering/grid-filtering.service';\nimport { IgxGridBaseDirective } from '../grid-base.directive';\nimport { IgxColumnResizingService } from '../resizing/resizing.service';\nimport { IgxOverlayService } from '../../services/overlay/overlay';\nimport { IgxGridExcelStyleFilteringComponent } from '../filtering/excel-style/grid.excel-style-filtering.component';\nimport { OverlaySettings, PositionSettings, VerticalAlignment } from '../../services/overlay/utilities';\nimport { AutoPositionStrategy } from '../../services/overlay/position/auto-position-strategy';\nimport { useAnimation } from '@angular/animations';\nimport { filter, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\nimport { fadeIn, fadeOut } from '../../animations/main';\nimport { AbsoluteScrollStrategy } from '../../services/overlay/scroll/absolute-scroll-strategy';\nimport { GridType } from '../common/grid.interface';\n\n/**\n * @hidden\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-grid-header',\n    templateUrl: './grid-header.component.html'\n})\nexport class IgxGridHeaderComponent implements DoCheck, OnInit, OnDestroy {\n\n    private _componentOverlayId: string;\n    private _filterMenuPositionSettings: PositionSettings;\n    private _filterMenuOverlaySettings: OverlaySettings;\n    private _destroy$ = new Subject<boolean>();\n\n    @Input()\n    public column: IgxColumnComponent;\n\n    @Input()\n    public gridID: string;\n\n    @HostBinding('class')\n    get styleClasses(): string {\n        const defaultClasses = [\n            'igx-grid__th--fw',\n            this.column.headerClasses\n        ];\n\n        const classList = {\n            'igx-grid__th': !this.column.columnGroup,\n            'asc': this.ascending,\n            'desc': this.descending,\n            'igx-grid__th--number': this.column.dataType === DataType.Number,\n            'igx-grid__th--sortable': this.column.sortable,\n            'igx-grid__th--filtrable': this.column.filterable && this.grid.filteringService.isFilterRowVisible,\n            'igx-grid__th--sorted': this.sorted\n        };\n\n        for (const klass of Object.keys(classList)) {\n            if (classList[klass]) {\n                defaultClasses.push(klass);\n            }\n        }\n        return defaultClasses.join(' ');\n    }\n\n    @HostBinding('style.height.rem')\n    get height() {\n        if (this.grid.hasColumnGroups) {\n            return (this.grid.maxLevelHeaderDepth + 1 - this.column.level) * this.grid.defaultRowHeight / this.grid._baseFontSize;\n        }\n        return null;\n    }\n\n    get ascending() {\n        return this.sortDirection === SortingDirection.Asc;\n    }\n\n    get descending() {\n        return this.sortDirection === SortingDirection.Desc;\n    }\n\n    get sortingIcon(): string {\n        if (this.sortDirection !== SortingDirection.None) {\n            // arrow_downward and arrow_upward\n            // are material icons ligature strings\n            return this.sortDirection === SortingDirection.Asc ? 'arrow_upward' : 'arrow_downward';\n        }\n        return 'arrow_upward';\n    }\n\n    get sorted() {\n        return this.sortDirection !== SortingDirection.None;\n    }\n\n    get filterIconClassName() {\n        return this.column.filteringExpressionsTree ? 'igx-excel-filter__icon--filtered' : 'igx-excel-filter__icon';\n    }\n\n    @HostBinding('attr.role')\n    public hostRole = 'columnheader';\n\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    @HostBinding('attr.id')\n    get headerID() {\n        return `${this.gridID}_${this.column.field}`;\n    }\n\n    protected sortDirection = SortingDirection.None;\n\n    constructor(\n        public gridAPI: GridBaseAPIService<IgxGridBaseDirective & GridType>,\n        public colResizingService: IgxColumnResizingService,\n        public cdr: ChangeDetectorRef,\n        public elementRef: ElementRef,\n        public zone: NgZone,\n        private _filteringService: IgxFilteringService,\n        private _moduleRef: NgModuleRef<any>,\n        @Inject(IgxOverlayService) private _overlayService: IgxOverlayService\n    ) { }\n\n    public ngOnInit() {\n        this.initFilteringSettings();\n    }\n\n    public ngDoCheck() {\n        this.getSortDirection();\n        this.cdr.markForCheck();\n    }\n\n    ngOnDestroy(): void {\n        this._destroy$.next(true);\n        this._destroy$.complete();\n\n        if (this._componentOverlayId) {\n            this._overlayService.hide(this._componentOverlayId);\n        }\n    }\n\n    @HostListener('click', ['$event'])\n    public onClick(event) {\n        if (!this.colResizingService.isColumnResizing) {\n            event.stopPropagation();\n            if (this.grid.filteringService.isFilterRowVisible) {\n                if (this.column.filterable && !this.column.columnGroup &&\n                    !this.grid.filteringService.isFilterComplex(this.column.field)) {\n                    this.grid.filteringService.filteredColumn = this.column;\n                }\n            } else if (this.column.sortable) {\n                this.triggerSort();\n            }\n        }\n    }\n\n    public onFilteringIconClick(event) {\n        event.stopPropagation();\n\n        this.toggleFilterDropdown();\n    }\n\n    get grid(): any {\n        return this.gridAPI.grid;\n    }\n\n    protected getSortDirection() {\n        const expr = this.gridAPI.grid.sortingExpressions.find((x) => x.fieldName === this.column.field);\n        this.sortDirection = expr ? expr.dir : SortingDirection.None;\n    }\n\n    public onSortingIconClick(event) {\n        if (this.grid.filteringService.isFilterRowVisible) {\n            event.stopPropagation();\n            this.triggerSort();\n        }\n    }\n\n    private triggerSort() {\n        const groupingExpr = this.grid.groupingExpressions ?\n            this.grid.groupingExpressions.find((expr) => expr.fieldName === this.column.field) : null;\n        const sortDir = groupingExpr ?\n            this.sortDirection + 1 > SortingDirection.Desc ? SortingDirection.Asc : SortingDirection.Desc\n            : this.sortDirection + 1 > SortingDirection.Desc ? SortingDirection.None : this.sortDirection + 1;\n        this.sortDirection = sortDir;\n        this.grid.sort({ fieldName: this.column.field, dir: this.sortDirection, ignoreCase: this.column.sortingIgnoreCase,\n            strategy: this.column.sortStrategy });\n    }\n\n    private toggleFilterDropdown() {\n        if (!this._componentOverlayId) {\n            const headerTarget = this.elementRef.nativeElement;\n            const filterIconTarget = headerTarget.querySelector('.' + this.filterIconClassName);\n\n            this._filterMenuOverlaySettings.positionStrategy.settings.target = filterIconTarget;\n            this._filterMenuOverlaySettings.outlet = this.grid.outlet;\n\n            this._componentOverlayId =\n                this._overlayService.attach(IgxGridExcelStyleFilteringComponent, this._filterMenuOverlaySettings, this._moduleRef);\n            this._overlayService.show(this._componentOverlayId, this._filterMenuOverlaySettings);\n        }\n    }\n\n    private initFilteringSettings() {\n        this._filterMenuPositionSettings = {\n            verticalStartPoint: VerticalAlignment.Bottom,\n            openAnimation: useAnimation(fadeIn, {\n                params: {\n                    duration: '250ms'\n                }\n            }),\n            closeAnimation: useAnimation(fadeOut, {\n                params: {\n                    duration: '200ms'\n                }\n            })\n        };\n\n        this._filterMenuOverlaySettings = {\n            closeOnOutsideClick: true,\n            modal: false,\n            positionStrategy: new AutoPositionStrategy(this._filterMenuPositionSettings),\n            scrollStrategy: new AbsoluteScrollStrategy()\n        };\n\n        this._overlayService.onOpening.pipe(\n            filter((overlay) => overlay.id === this._componentOverlayId),\n            takeUntil(this._destroy$)).subscribe((eventArgs) => {\n                this.onOverlayOpening(eventArgs);\n            });\n\n        this._overlayService.onClosed.pipe(\n            filter(overlay => overlay.id === this._componentOverlayId),\n            takeUntil(this._destroy$)).subscribe(() => {\n                this.onOverlayClosed();\n            });\n    }\n\n    private onOverlayOpening(eventArgs) {\n        const instance = eventArgs.componentRef.instance as IgxGridExcelStyleFilteringComponent;\n        if (instance) {\n            instance.initialize(this.column, this._overlayService, eventArgs.id);\n        }\n    }\n\n    private onOverlayClosed() {\n        this._componentOverlayId = null;\n    }\n}\n"]}