UNPKG

igniteui-angular

Version:

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

325 lines • 35.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ChangeDetectionStrategy, Input, ChangeDetectorRef, ViewChild, TemplateRef, ViewChildren, QueryList, ElementRef } from '@angular/core'; import { IgxColumnComponent } from '../../column.component'; import { IgxFilteringService, ExpressionUI } from '../grid-filtering.service'; import { FilteringLogic } from '../../../data-operations/filtering-expression.interface'; import { DataType } from '../../../data-operations/data-util'; import { IgxStringFilteringOperand, IgxBooleanFilteringOperand, IgxNumberFilteringOperand, IgxDateFilteringOperand } from '../../../data-operations/filtering-condition'; import { IgxToggleDirective } from '../../../directives/toggle/toggle.directive'; import { ConnectedPositioningStrategy, VerticalAlignment, HorizontalAlignment, IgxOverlayService, AbsoluteScrollStrategy } from '../../../services/index'; import { IgxExcelStyleDefaultExpressionComponent } from './excel-style-default-expression.component'; import { IgxExcelStyleDateExpressionComponent } from './excel-style-date-expression.component'; /** * @hidden */ export class IgxExcelStyleCustomDialogComponent { /** * @param {?} cdr */ constructor(cdr) { this.cdr = cdr; this.expressionsList = new Array(); this._customDialogPositionSettings = { verticalDirection: VerticalAlignment.Middle, horizontalDirection: HorizontalAlignment.Center, horizontalStartPoint: HorizontalAlignment.Center, verticalStartPoint: VerticalAlignment.Middle }; this._customDialogOverlaySettings = { closeOnOutsideClick: true, modal: false, positionStrategy: new ConnectedPositioningStrategy(this._customDialogPositionSettings), scrollStrategy: new AbsoluteScrollStrategy() }; } /** * @return {?} */ ngAfterViewInit() { this._customDialogOverlaySettings.outlet = this.grid.outlet; } /** * @return {?} */ get template() { if (this.column.dataType === DataType.Date) { return this.dateExpressionTemplate; } return this.defaultExpressionTemplate; } /** * @return {?} */ get grid() { return this.filteringService.grid; } /** * @return {?} */ onCustomDialogOpening() { if (this.selectedOperator) { this.createInitialExpressionUIElement(); } } /** * @return {?} */ onCustomDialogOpened() { if (this.expressionComponents.first) { this.expressionComponents.first.focus(); } } /** * @return {?} */ open() { this._customDialogOverlaySettings.positionStrategy.settings.target = this.grid.rootGrid ? this.grid.rootGrid.nativeElement : this.grid.nativeElement; this.toggle.open(this._customDialogOverlaySettings); } /** * @return {?} */ onClearButtonClick() { this.filteringService.clearFilter(this.column.field); this.createInitialExpressionUIElement(); this.cdr.detectChanges(); } /** * @return {?} */ closeDialog() { if (this.overlayComponentId) { this.overlayService.hide(this.overlayComponentId); } } /** * @return {?} */ onApplyButtonClick() { this.expressionsList = this.expressionsList.filter(element => element.expression.condition && (element.expression.searchVal || element.expression.searchVal === 0 || element.expression.condition.isUnary)); if (this.expressionsList.length > 0) { this.expressionsList[0].beforeOperator = null; this.expressionsList[this.expressionsList.length - 1].afterOperator = null; } this.filteringService.filterInternal(this.column.field, this.expressionsList); this.closeDialog(); } /** * @return {?} */ onAddButtonClick() { /** @type {?} */ const exprUI = new ExpressionUI(); exprUI.expression = { condition: null, fieldName: this.column.field, ignoreCase: this.column.filteringIgnoreCase, searchVal: null }; this.expressionsList[this.expressionsList.length - 1].afterOperator = FilteringLogic.And; exprUI.beforeOperator = this.expressionsList[this.expressionsList.length - 1].afterOperator; this.expressionsList.push(exprUI); this.markChildrenForCheck(); this.scrollToBottom(); } /** * @param {?} event * @return {?} */ onExpressionRemoved(event) { /** @type {?} */ const indexToRemove = this.expressionsList.indexOf(event); if (indexToRemove === 0 && this.expressionsList.length > 1) { this.expressionsList[1].beforeOperator = null; } else if (indexToRemove === this.expressionsList.length - 1) { this.expressionsList[indexToRemove - 1].afterOperator = null; } else { this.expressionsList[indexToRemove - 1].afterOperator = this.expressionsList[indexToRemove + 1].beforeOperator; this.expressionsList[0].beforeOperator = null; this.expressionsList[this.expressionsList.length - 1].afterOperator = null; } this.expressionsList.splice(indexToRemove, 1); this.cdr.detectChanges(); this.markChildrenForCheck(); } /** * @param {?} event * @return {?} */ onLogicOperatorChanged(event) { /** @type {?} */ const index = this.expressionsList.indexOf(event.target); event.target.afterOperator = event.newValue; if (index + 1 < this.expressionsList.length) { this.expressionsList[index + 1].beforeOperator = event.newValue; } } /** * @param {?} eventArgs * @return {?} */ onKeyDown(eventArgs) { eventArgs.stopPropagation(); } /** * @param {?} eventArgs * @return {?} */ onApplyButtonKeyDown(eventArgs) { if (eventArgs.key === "Tab" /* TAB */ && !eventArgs.shiftKey) { eventArgs.stopPropagation(); eventArgs.preventDefault(); } } /** * @private * @param {?} conditionName * @return {?} */ createCondition(conditionName) { switch (this.column.dataType) { case DataType.Boolean: return IgxBooleanFilteringOperand.instance().condition(conditionName); case DataType.Number: return IgxNumberFilteringOperand.instance().condition(conditionName); case DataType.Date: return IgxDateFilteringOperand.instance().condition(conditionName); default: return IgxStringFilteringOperand.instance().condition(conditionName); } } /** * @private * @return {?} */ markChildrenForCheck() { this.expressionComponents.forEach(x => x.cdr.markForCheck()); this.expressionDateComponents.forEach(x => x.cdr.markForCheck()); } /** * @private * @return {?} */ createInitialExpressionUIElement() { this.expressionsList = []; /** @type {?} */ const firstExprUI = new ExpressionUI(); firstExprUI.expression = { condition: this.createCondition(this.selectedOperator), fieldName: this.column.field, ignoreCase: this.column.filteringIgnoreCase, searchVal: null }; firstExprUI.afterOperator = FilteringLogic.And; this.expressionsList.push(firstExprUI); /** @type {?} */ const secondExprUI = new ExpressionUI(); secondExprUI.expression = { condition: null, fieldName: this.column.field, ignoreCase: this.column.filteringIgnoreCase, searchVal: null }; secondExprUI.beforeOperator = FilteringLogic.And; this.expressionsList.push(secondExprUI); } /** * @private * @return {?} */ scrollToBottom() { requestAnimationFrame(() => { this.expressionsContainer.nativeElement.scrollTop = this.expressionsContainer.nativeElement.scrollHeight; }); } } IgxExcelStyleCustomDialogComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, selector: 'igx-excel-style-custom-dialog', template: "<article #toggle igxToggle\n class=\"igx-excel-filter__secondary\"\n (keydown)=\"onKeyDown($event)\"\n (onOpening)=\"onCustomDialogOpening()\"\n (onOpened)=\"onCustomDialogOpened()\">\n <header class=\"igx-excel-filter__secondary-header\">\n <h4 class=\"igx-typography__h6\">\n {{ grid.resourceStrings.igx_grid_excel_custom_dialog_header }}{{ column.header || column.field }}\n </h4>\n </header>\n\n <article #expressionsContainer class=\"igx-excel-filter__secondary-main\">\n <ng-container *ngIf=\"column.dataType === 'date'\">\n <igx-excel-style-date-expression *ngFor=\"let expression of expressionsList;\"\n class=\"igx-excel-filter__condition\"\n [expressionUI]=\"expression\"\n [column]=\"column\"\n [grid]=\"grid\"\n [expressionsList]=\"expressionsList\"\n (onExpressionRemoved)=\"onExpressionRemoved($event)\"\n (onLogicOperatorChanged)=\"onLogicOperatorChanged($event)\">\n </igx-excel-style-date-expression>\n </ng-container>\n\n <ng-container *ngIf=\"column.dataType !== 'date'\">\n <igx-excel-style-default-expression *ngFor=\"let expression of expressionsList;\"\n class=\"igx-excel-filter__condition\"\n [expressionUI]=\"expression\"\n [column]=\"column\"\n [grid]=\"grid\"\n [expressionsList]=\"expressionsList\"\n (onExpressionRemoved)=\"onExpressionRemoved($event)\"\n (onLogicOperatorChanged)=\"onLogicOperatorChanged($event)\">\n </igx-excel-style-default-expression>\n </ng-container>\n\n <button igxButton\n class=\"igx-excel-filter__add-filter\"\n (click)=\"onAddButtonClick()\">\n <igx-icon>add</igx-icon>\n <span>{{ grid.resourceStrings.igx_grid_excel_custom_dialog_add }}</span>\n </button>\n </article>\n\n <footer class=\"igx-excel-filter__secondary-footer\">\n <button igxButton (click)=\"onClearButtonClick()\">{{ grid.resourceStrings.igx_grid_excel_custom_dialog_clear }}</button>\n\n <div>\n <button igxButton (click)=\"closeDialog()\">{{ grid.resourceStrings.igx_grid_excel_cancel }}</button>\n <button igxButton=\"raised\" (click)=\"onApplyButtonClick()\" (keydown)=\"onApplyButtonKeyDown($event)\">\n {{ grid.resourceStrings.igx_grid_excel_apply }}\n </button>\n </div>\n </footer>\n</article>\n" }] } ]; /** @nocollapse */ IgxExcelStyleCustomDialogComponent.ctorParameters = () => [ { type: ChangeDetectorRef } ]; IgxExcelStyleCustomDialogComponent.propDecorators = { expressionsList: [{ type: Input }], column: [{ type: Input }], selectedOperator: [{ type: Input }], filteringService: [{ type: Input }], overlayComponentId: [{ type: Input }], overlayService: [{ type: Input }], expressionComponents: [{ type: ViewChildren, args: [IgxExcelStyleDefaultExpressionComponent,] }], expressionDateComponents: [{ type: ViewChildren, args: [IgxExcelStyleDateExpressionComponent,] }], toggle: [{ type: ViewChild, args: ['toggle', { read: IgxToggleDirective },] }], defaultExpressionTemplate: [{ type: ViewChild, args: ['defaultExpressionTemplate', { read: TemplateRef },] }], dateExpressionTemplate: [{ type: ViewChild, args: ['dateExpressionTemplate', { read: TemplateRef },] }], expressionsContainer: [{ type: ViewChild, args: ['expressionsContainer',] }] }; if (false) { /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.expressionsList; /** * @type {?} * @private */ IgxExcelStyleCustomDialogComponent.prototype._customDialogPositionSettings; /** * @type {?} * @private */ IgxExcelStyleCustomDialogComponent.prototype._customDialogOverlaySettings; /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.column; /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.selectedOperator; /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.filteringService; /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.overlayComponentId; /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.overlayService; /** * @type {?} * @private */ IgxExcelStyleCustomDialogComponent.prototype.expressionComponents; /** * @type {?} * @private */ IgxExcelStyleCustomDialogComponent.prototype.expressionDateComponents; /** @type {?} */ IgxExcelStyleCustomDialogComponent.prototype.toggle; /** * @type {?} * @protected */ IgxExcelStyleCustomDialogComponent.prototype.defaultExpressionTemplate; /** * @type {?} * @protected */ IgxExcelStyleCustomDialogComponent.prototype.dateExpressionTemplate; /** * @type {?} * @protected */ IgxExcelStyleCustomDialogComponent.prototype.expressionsContainer; /** * @type {?} * @private */ IgxExcelStyleCustomDialogComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-style-custom-dialog.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/filtering/excel-style/excel-style-custom-dialog.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    Input,\n    ChangeDetectorRef,\n    ViewChild,\n    AfterViewInit,\n    TemplateRef,\n    ViewChildren,\n    QueryList,\n    ElementRef\n} from '@angular/core';\nimport { IgxColumnComponent } from '../../column.component';\nimport { IgxFilteringService, ExpressionUI } from '../grid-filtering.service';\nimport { FilteringLogic } from '../../../data-operations/filtering-expression.interface';\nimport { DataType } from '../../../data-operations/data-util';\nimport {\n    IgxStringFilteringOperand,\n    IgxBooleanFilteringOperand,\n    IgxNumberFilteringOperand,\n    IgxDateFilteringOperand\n} from '../../../data-operations/filtering-condition';\nimport { IgxToggleDirective } from '../../../directives/toggle/toggle.directive';\nimport {\n    ConnectedPositioningStrategy,\n    OverlaySettings,\n    VerticalAlignment,\n    PositionSettings,\n    HorizontalAlignment,\n    IgxOverlayService,\n    AbsoluteScrollStrategy\n} from '../../../services/index';\nimport { ILogicOperatorChangedArgs, IgxExcelStyleDefaultExpressionComponent } from './excel-style-default-expression.component';\nimport { KEYS } from '../../../core/utils';\nimport { IgxExcelStyleDateExpressionComponent } from './excel-style-date-expression.component';\n\n/**\n * @hidden\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-excel-style-custom-dialog',\n    templateUrl: './excel-style-custom-dialog.component.html'\n})\nexport class IgxExcelStyleCustomDialogComponent implements AfterViewInit {\n\n    @Input()\n    public expressionsList = new Array<ExpressionUI>();\n\n    private _customDialogPositionSettings: PositionSettings = {\n        verticalDirection: VerticalAlignment.Middle,\n        horizontalDirection: HorizontalAlignment.Center,\n        horizontalStartPoint: HorizontalAlignment.Center,\n        verticalStartPoint: VerticalAlignment.Middle\n    };\n\n    private _customDialogOverlaySettings: OverlaySettings = {\n        closeOnOutsideClick: true,\n        modal: false,\n        positionStrategy: new ConnectedPositioningStrategy(this._customDialogPositionSettings),\n        scrollStrategy: new AbsoluteScrollStrategy()\n    };\n\n    @Input()\n    public column: IgxColumnComponent;\n\n    @Input()\n    public selectedOperator: string;\n\n    @Input()\n    public filteringService: IgxFilteringService;\n\n    @Input()\n    public overlayComponentId: string;\n\n    @Input()\n    public overlayService: IgxOverlayService;\n\n    @ViewChildren(IgxExcelStyleDefaultExpressionComponent)\n    private expressionComponents: QueryList<IgxExcelStyleDefaultExpressionComponent>;\n\n    @ViewChildren(IgxExcelStyleDateExpressionComponent)\n    private expressionDateComponents: QueryList<IgxExcelStyleDateExpressionComponent>;\n\n    @ViewChild('toggle', { read: IgxToggleDirective })\n    public toggle: IgxToggleDirective;\n\n    @ViewChild('defaultExpressionTemplate', { read: TemplateRef })\n    protected defaultExpressionTemplate: TemplateRef<any>;\n\n    @ViewChild('dateExpressionTemplate', { read: TemplateRef })\n    protected dateExpressionTemplate: TemplateRef<any>;\n\n    @ViewChild('expressionsContainer')\n    protected expressionsContainer: ElementRef;\n\n    constructor(private cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit(): void {\n        this._customDialogOverlaySettings.outlet = this.grid.outlet;\n    }\n\n    get template(): TemplateRef<any> {\n        if (this.column.dataType === DataType.Date) {\n            return this.dateExpressionTemplate;\n        }\n\n        return this.defaultExpressionTemplate;\n    }\n\n    get grid(): any {\n        return this.filteringService.grid;\n    }\n\n    public onCustomDialogOpening() {\n        if (this.selectedOperator) {\n            this.createInitialExpressionUIElement();\n        }\n    }\n\n    public onCustomDialogOpened() {\n        if (this.expressionComponents.first) {\n            this.expressionComponents.first.focus();\n        }\n    }\n\n    public open() {\n        this._customDialogOverlaySettings.positionStrategy.settings.target =\n            this.grid.rootGrid ? this.grid.rootGrid.nativeElement : this.grid.nativeElement;\n        this.toggle.open(this._customDialogOverlaySettings);\n    }\n\n    public onClearButtonClick() {\n        this.filteringService.clearFilter(this.column.field);\n        this.createInitialExpressionUIElement();\n        this.cdr.detectChanges();\n    }\n\n    public closeDialog() {\n        if (this.overlayComponentId) {\n            this.overlayService.hide(this.overlayComponentId);\n        }\n    }\n\n    public onApplyButtonClick() {\n        this.expressionsList = this.expressionsList.filter(\n            element => element.expression.condition &&\n            (element.expression.searchVal || element.expression.searchVal === 0 || element.expression.condition.isUnary));\n\n        if (this.expressionsList.length > 0) {\n            this.expressionsList[0].beforeOperator = null;\n            this.expressionsList[this.expressionsList.length - 1].afterOperator = null;\n        }\n\n        this.filteringService.filterInternal(this.column.field, this.expressionsList);\n        this.closeDialog();\n    }\n\n    public onAddButtonClick() {\n        const exprUI = new ExpressionUI();\n        exprUI.expression = {\n            condition: null,\n            fieldName: this.column.field,\n            ignoreCase: this.column.filteringIgnoreCase,\n            searchVal: null\n        };\n\n        this.expressionsList[this.expressionsList.length - 1].afterOperator = FilteringLogic.And;\n        exprUI.beforeOperator = this.expressionsList[this.expressionsList.length - 1].afterOperator;\n\n        this.expressionsList.push(exprUI);\n\n        this.markChildrenForCheck();\n        this.scrollToBottom();\n    }\n\n    public onExpressionRemoved(event: ExpressionUI) {\n        const indexToRemove = this.expressionsList.indexOf(event);\n\n        if (indexToRemove === 0 && this.expressionsList.length > 1) {\n            this.expressionsList[1].beforeOperator = null;\n        } else if (indexToRemove === this.expressionsList.length - 1) {\n            this.expressionsList[indexToRemove - 1].afterOperator = null;\n        } else {\n            this.expressionsList[indexToRemove - 1].afterOperator = this.expressionsList[indexToRemove + 1].beforeOperator;\n            this.expressionsList[0].beforeOperator = null;\n            this.expressionsList[this.expressionsList.length - 1].afterOperator = null;\n        }\n\n        this.expressionsList.splice(indexToRemove, 1);\n\n        this.cdr.detectChanges();\n\n        this.markChildrenForCheck();\n    }\n\n    public onLogicOperatorChanged(event: ILogicOperatorChangedArgs) {\n        const index = this.expressionsList.indexOf(event.target);\n        event.target.afterOperator = event.newValue;\n        if (index + 1 < this.expressionsList.length) {\n            this.expressionsList[index + 1].beforeOperator = event.newValue;\n        }\n    }\n\n    public onKeyDown(eventArgs) {\n        eventArgs.stopPropagation();\n    }\n\n    public onApplyButtonKeyDown(eventArgs) {\n        if (eventArgs.key === KEYS.TAB && !eventArgs.shiftKey) {\n            eventArgs.stopPropagation();\n            eventArgs.preventDefault();\n        }\n    }\n\n    private createCondition(conditionName: string) {\n        switch (this.column.dataType) {\n            case DataType.Boolean:\n                return IgxBooleanFilteringOperand.instance().condition(conditionName);\n            case DataType.Number:\n                return IgxNumberFilteringOperand.instance().condition(conditionName);\n            case DataType.Date:\n                return IgxDateFilteringOperand.instance().condition(conditionName);\n            default:\n                return IgxStringFilteringOperand.instance().condition(conditionName);\n        }\n    }\n\n    private markChildrenForCheck() {\n        this.expressionComponents.forEach(x => x.cdr.markForCheck());\n        this.expressionDateComponents.forEach(x => x.cdr.markForCheck());\n    }\n\n    private createInitialExpressionUIElement() {\n        this.expressionsList = [];\n        const firstExprUI = new ExpressionUI();\n\n        firstExprUI.expression = {\n            condition: this.createCondition(this.selectedOperator),\n            fieldName: this.column.field,\n            ignoreCase: this.column.filteringIgnoreCase,\n            searchVal: null\n        };\n        firstExprUI.afterOperator = FilteringLogic.And;\n\n        this.expressionsList.push(firstExprUI);\n\n        const secondExprUI = new ExpressionUI();\n        secondExprUI.expression = {\n            condition: null,\n            fieldName: this.column.field,\n            ignoreCase: this.column.filteringIgnoreCase,\n            searchVal: null\n        };\n\n        secondExprUI.beforeOperator = FilteringLogic.And;\n\n        this.expressionsList.push(secondExprUI);\n    }\n\n    private scrollToBottom() {\n        requestAnimationFrame(() => {\n            this.expressionsContainer.nativeElement.scrollTop = this.expressionsContainer.nativeElement.scrollHeight;\n        });\n    }\n}\n"]}