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