@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
305 lines • 37.5 kB
JavaScript
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":"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","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"]}