UNPKG

igniteui-angular

Version:

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

318 lines • 30.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ChangeDetectionStrategy, Input, Output, EventEmitter, ChangeDetectorRef, ViewChild } from '@angular/core'; import { IgxColumnComponent } from '../../column.component'; import { ExpressionUI } from '../grid-filtering.service'; import { IgxButtonGroupComponent } from '../../../buttonGroup/buttonGroup.component'; import { IgxDropDownComponent } from '../../../drop-down/index'; import { IgxInputGroupComponent, IgxInputDirective } from '../../../input-group/index'; import { DataType } from '../../../data-operations/data-util'; import { ConnectedPositioningStrategy, CloseScrollStrategy } from '../../../services/index'; /** * @hidden * @record */ export function ILogicOperatorChangedArgs() { } if (false) { /** @type {?} */ ILogicOperatorChangedArgs.prototype.target; /** @type {?} */ ILogicOperatorChangedArgs.prototype.newValue; } /** * @hidden */ export class IgxExcelStyleDefaultExpressionComponent { /** * @param {?} cdr */ constructor(cdr) { this.cdr = cdr; this._dropDownOverlaySettings = { closeOnOutsideClick: true, modal: false, positionStrategy: new ConnectedPositioningStrategy(), scrollStrategy: new CloseScrollStrategy() }; this.onExpressionRemoved = new EventEmitter(); this.onLogicOperatorChanged = new EventEmitter(); } /** * @protected * @return {?} */ get inputValuesElement() { return this.inputValuesDirective; } /** * @return {?} */ get isLast() { return this.expressionsList[this.expressionsList.length - 1] === this.expressionUI; } /** * @return {?} */ get isSingle() { return this.expressionsList.length === 1; } /** * @return {?} */ get inputConditionsPlaceholder() { return this.grid.resourceStrings['igx_grid_filter_condition_placeholder']; } /** * @return {?} */ get inputValuePlaceholder() { return this.grid.resourceStrings['igx_grid_filter_row_placeholder']; } /** * @return {?} */ get type() { switch (this.column.dataType) { case DataType.Number: return 'number'; default: return 'text'; } } /** * @return {?} */ ngAfterViewInit() { this._dropDownOverlaySettings.outlet = this.column.grid.outletDirective; this._dropDownOverlaySettings.positionStrategy.settings.target = this.inputGroupConditions.element.nativeElement; } /** * @return {?} */ focus() { // use requestAnimationFrame to focus the values input because when initializing the component // datepicker's input group is not yet fully initialized requestAnimationFrame(() => this.inputValuesElement.focus()); } /** * @param {?} conditionName * @return {?} */ isConditionSelected(conditionName) { return this.expressionUI.expression.condition && this.expressionUI.expression.condition.name === conditionName; } /** * @param {?} condition * @return {?} */ getConditionName(condition) { return condition ? this.translateCondition(condition.name) : null; } /** * @return {?} */ getInputWidth() { return this.inputGroupConditions.element.nativeElement.offsetWidth + 'px'; } /** * @return {?} */ get conditions() { return this.column.filters.conditionList(); } /** * @param {?} value * @return {?} */ translateCondition(value) { return this.grid.resourceStrings[`igx_grid_filter_${this.getCondition(value).name}`] || value; } /** * @return {?} */ getIconName() { if (this.column.dataType === DataType.Boolean && this.expressionUI.expression.condition === null) { return this.getCondition(this.conditions[0]).iconName; } else if (!this.expressionUI.expression.condition) { return 'filter_list'; } else { return this.expressionUI.expression.condition.iconName; } } /** * @return {?} */ toggleCustomDialogDropDown() { this.dropdownConditions.toggle(this._dropDownOverlaySettings); } /** * @param {?} value * @return {?} */ getCondition(value) { return this.column.filters.condition(value); } /** * @param {?} eventArgs * @return {?} */ onConditionsChanged(eventArgs) { /** @type {?} */ const value = ((/** @type {?} */ (eventArgs.newSelection))).value; this.expressionUI.expression.condition = this.getCondition(value); this.focus(); } /** * @param {?} value * @return {?} */ isValueSelected(value) { if (this.expressionUI.expression.searchVal) { return this.expressionUI.expression.searchVal === value; } else { return false; } } /** * @param {?} eventArgs * @return {?} */ onValuesInput(eventArgs) { this.expressionUI.expression.searchVal = this.transformValue(eventArgs.target.value); } /** * @param {?} eventArgs * @param {?} buttonIndex * @return {?} */ onLogicOperatorButtonClicked(eventArgs, buttonIndex) { if (this.logicOperatorButtonGroup.selectedButtons.length === 0) { eventArgs.stopPropagation(); this.logicOperatorButtonGroup.selectButton(buttonIndex); } else { this.onLogicOperatorChanged.emit({ target: this.expressionUI, newValue: (/** @type {?} */ (buttonIndex)) }); } } /** * @param {?} eventArgs * @param {?} buttonIndex * @return {?} */ onLogicOperatorKeyDown(eventArgs, buttonIndex) { if (eventArgs.key === "Enter" /* ENTER */) { this.logicOperatorButtonGroup.selectButton(buttonIndex); this.onLogicOperatorChanged.emit({ target: this.expressionUI, newValue: (/** @type {?} */ (buttonIndex)) }); } } /** * @return {?} */ onRemoveButtonClick() { this.onExpressionRemoved.emit(this.expressionUI); } /** * @param {?} eventArgs * @return {?} */ onInputConditionsKeyDown(eventArgs) { if (eventArgs.altKey && (eventArgs.key === "ArrowDown" /* DOWN_ARROW */ || eventArgs.key === "Down" /* DOWN_ARROW_IE */)) { this.toggleCustomDialogDropDown(); } if (eventArgs.key === "Tab" /* TAB */ && eventArgs.shiftKey && this.expressionsList[0] === this.expressionUI) { eventArgs.preventDefault(); } event.stopPropagation(); } /** * @private * @param {?} value * @return {?} */ transformValue(value) { if (this.column.dataType === DataType.Number) { value = parseFloat(value); } else if (this.column.dataType === DataType.Boolean) { value = Boolean(value); } return value; } } IgxExcelStyleDefaultExpressionComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, selector: 'igx-excel-style-default-expression', template: "<igx-drop-down\n #dropdownConditions\n [maxHeight]=\"'200px'\"\n [width]=\"getInputWidth()\"\n (onSelection)=\"onConditionsChanged($event)\">\n <igx-drop-down-item *ngFor=\"let condition of conditions\" [value]=\"condition\" [selected]=\"isConditionSelected(condition)\">\n <igx-icon fontSet=\"filtering-icons\" [name]=\"getCondition(condition).iconName\"></igx-icon>\n <span>{{ translateCondition(condition) }}</span>\n </igx-drop-down-item>\n</igx-drop-down>\n\n<igx-input-group\n #inputGroupConditions\n (click)=\"toggleCustomDialogDropDown()\"\n type=\"box\"\n [displayDensity]=\"'compact'\"\n [supressInputAutofocus]=\"true\">\n\n <igx-prefix>\n <igx-icon *ngIf=\"expressionUI.expression.condition\" fontSet=\"filtering-icons\" [name]=\"getIconName()\"></igx-icon>\n <igx-icon *ngIf=\"!expressionUI.expression.condition\">filter_list</igx-icon>\n </igx-prefix>\n\n <input\n igxInput\n (keydown)=\"onInputConditionsKeyDown($event)\"\n [igxDropDownItemNavigation]=\"dropdownConditions\"\n tabindex=\"0\"\n [placeholder]=\"inputConditionsPlaceholder\"\n autocomplete=\"off\"\n [value]=\"getConditionName(expressionUI.expression.condition)\"\n [readonly]=\"true\"\n />\n</igx-input-group>\n\n<igx-input-group #inputGroupValues type=\"box\" [displayDensity]=\"'compact'\" [supressInputAutofocus]=\"true\">\n <input\n #inputValues\n igxInput\n [type]=\"type\"\n tabindex=\"0\"\n [placeholder]=\"inputValuePlaceholder\"\n [disabled]=\"expressionUI.expression.condition && expressionUI.expression.condition.isUnary\"\n autocomplete=\"off\"\n [value]=\"expressionUI.expression.searchVal\"\n (input)=\"onValuesInput($event)\"\n />\n</igx-input-group>\n\n<button (click)=\"onRemoveButtonClick()\" igxButton=\"icon\" *ngIf=\"!isSingle\">\n <igx-icon>cancel</igx-icon>\n</button>\n\n<igx-buttongroup #logicOperatorButtonGroup\n *ngIf=\"!isLast\"\n [multiSelection]=\"false\">\n <span igxButton\n tabindex=\"0\"\n #andButton\n (keydown)=\"onLogicOperatorKeyDown($event, 0)\"\n [selected]=\"expressionUI.afterOperator === 0\"\n type=\"button\"\n (click)=\"onLogicOperatorButtonClicked($event, 0)\">\n {{ grid.resourceStrings.igx_grid_filter_operator_and }}\n </span>\n\n <span igxButton\n tabindex=\"0\"\n #orButton\n (keydown)=\"onLogicOperatorKeyDown($event, 1)\"\n [selected]=\"expressionUI.afterOperator === 1\"\n type=\"button\"\n (click)=\"onLogicOperatorButtonClicked($event, 1)\">\n {{ grid.resourceStrings.igx_grid_filter_operator_or }}\n </span>\n</igx-buttongroup>\n" }] } ]; /** @nocollapse */ IgxExcelStyleDefaultExpressionComponent.ctorParameters = () => [ { type: ChangeDetectorRef } ]; IgxExcelStyleDefaultExpressionComponent.propDecorators = { column: [{ type: Input }], expressionUI: [{ type: Input }], expressionsList: [{ type: Input }], grid: [{ type: Input }], onExpressionRemoved: [{ type: Output }], onLogicOperatorChanged: [{ type: Output }], inputGroupConditions: [{ type: ViewChild, args: ['inputGroupConditions', { read: IgxInputGroupComponent },] }], inputValuesDirective: [{ type: ViewChild, args: ['inputValues', { read: IgxInputDirective },] }], dropdownConditions: [{ type: ViewChild, args: ['dropdownConditions', { read: IgxDropDownComponent },] }], logicOperatorButtonGroup: [{ type: ViewChild, args: ['logicOperatorButtonGroup', { read: IgxButtonGroupComponent },] }] }; if (false) { /** * @type {?} * @private */ IgxExcelStyleDefaultExpressionComponent.prototype._dropDownOverlaySettings; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.column; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.expressionUI; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.expressionsList; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.grid; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.onExpressionRemoved; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.onLogicOperatorChanged; /** * @type {?} * @protected */ IgxExcelStyleDefaultExpressionComponent.prototype.inputGroupConditions; /** * @type {?} * @protected */ IgxExcelStyleDefaultExpressionComponent.prototype.inputValuesDirective; /** * @type {?} * @protected */ IgxExcelStyleDefaultExpressionComponent.prototype.dropdownConditions; /** * @type {?} * @protected */ IgxExcelStyleDefaultExpressionComponent.prototype.logicOperatorButtonGroup; /** @type {?} */ IgxExcelStyleDefaultExpressionComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"excel-style-default-expression.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/filtering/excel-style/excel-style-default-expression.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Component,\n    ChangeDetectionStrategy,\n    AfterViewInit,\n    Input,\n    Output,\n    EventEmitter,\n    ChangeDetectorRef,\n    ViewChild\n} from '@angular/core';\nimport { IgxColumnComponent } from '../../column.component';\nimport { ExpressionUI } from '../grid-filtering.service';\nimport { IgxButtonGroupComponent } from '../../../buttonGroup/buttonGroup.component';\nimport { IgxDropDownItemComponent, IgxDropDownComponent } from '../../../drop-down/index';\nimport { IgxInputGroupComponent, IgxInputDirective } from '../../../input-group/index';\nimport { DataType } from '../../../data-operations/data-util';\nimport { IFilteringOperation } from '../../../data-operations/filtering-condition';\nimport { OverlaySettings, ConnectedPositioningStrategy, CloseScrollStrategy } from '../../../services/index';\nimport { KEYS } from '../../../core/utils';\nimport { FilteringLogic } from '../../../data-operations/filtering-expression.interface';\n\n/**\n * @hidden\n */\nexport interface ILogicOperatorChangedArgs {\n    target: ExpressionUI;\n    newValue: FilteringLogic;\n}\n\n/**\n * @hidden\n */\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-excel-style-default-expression',\n    templateUrl: './excel-style-default-expression.component.html'\n})\nexport class IgxExcelStyleDefaultExpressionComponent implements AfterViewInit {\n\n    private _dropDownOverlaySettings: OverlaySettings = {\n        closeOnOutsideClick: true,\n        modal: false,\n        positionStrategy: new ConnectedPositioningStrategy(),\n        scrollStrategy: new CloseScrollStrategy()\n    };\n\n    @Input()\n    public column: IgxColumnComponent;\n\n    @Input()\n    public expressionUI: ExpressionUI;\n\n    @Input()\n    public expressionsList: Array<ExpressionUI>;\n\n    @Input()\n    public grid: any;\n\n    @Output()\n    public onExpressionRemoved = new EventEmitter<ExpressionUI>();\n\n    @Output()\n    public onLogicOperatorChanged = new EventEmitter<ILogicOperatorChangedArgs>();\n\n    @ViewChild('inputGroupConditions', { read: IgxInputGroupComponent })\n    protected inputGroupConditions: IgxInputGroupComponent;\n\n    @ViewChild('inputValues', { read: IgxInputDirective })\n    protected inputValuesDirective: IgxInputDirective;\n\n    @ViewChild('dropdownConditions', { read: IgxDropDownComponent })\n    protected dropdownConditions: IgxDropDownComponent;\n\n    @ViewChild('logicOperatorButtonGroup', { read: IgxButtonGroupComponent })\n    protected logicOperatorButtonGroup: IgxButtonGroupComponent;\n\n    protected get inputValuesElement() {\n        return this.inputValuesDirective;\n    }\n\n    get isLast(): boolean {\n        return this.expressionsList[this.expressionsList.length - 1] === this.expressionUI;\n    }\n\n    get isSingle(): boolean {\n        return this.expressionsList.length === 1;\n    }\n\n    get inputConditionsPlaceholder(): string {\n        return this.grid.resourceStrings['igx_grid_filter_condition_placeholder'];\n    }\n\n    get inputValuePlaceholder(): string {\n        return this.grid.resourceStrings['igx_grid_filter_row_placeholder'];\n    }\n\n    get type() {\n        switch (this.column.dataType) {\n            case DataType.Number:\n                return 'number';\n            default:\n                return 'text';\n        }\n    }\n\n    constructor(public cdr: ChangeDetectorRef) {}\n\n    ngAfterViewInit(): void {\n        this._dropDownOverlaySettings.outlet = this.column.grid.outletDirective;\n        this._dropDownOverlaySettings.positionStrategy.settings.target = this.inputGroupConditions.element.nativeElement;\n    }\n\n    public focus() {\n        // use requestAnimationFrame to focus the values input because when initializing the component\n        // datepicker's input group is not yet fully initialized\n        requestAnimationFrame(() => this.inputValuesElement.focus());\n    }\n\n    public isConditionSelected(conditionName: string): boolean {\n        return this.expressionUI.expression.condition && this.expressionUI.expression.condition.name === conditionName;\n    }\n\n    public getConditionName(condition: IFilteringOperation) {\n        return condition ? this.translateCondition(condition.name) : null;\n    }\n\n    public getInputWidth() {\n        return this.inputGroupConditions.element.nativeElement.offsetWidth + 'px';\n    }\n\n    get conditions() {\n        return this.column.filters.conditionList();\n    }\n\n    public translateCondition(value: string): string {\n        return this.grid.resourceStrings[`igx_grid_filter_${this.getCondition(value).name}`] || value;\n    }\n\n    public getIconName(): string {\n        if (this.column.dataType === DataType.Boolean && this.expressionUI.expression.condition === null) {\n            return this.getCondition(this.conditions[0]).iconName;\n        } else if (!this.expressionUI.expression.condition) {\n            return 'filter_list';\n        } else {\n            return this.expressionUI.expression.condition.iconName;\n        }\n    }\n\n    public toggleCustomDialogDropDown() {\n        this.dropdownConditions.toggle(this._dropDownOverlaySettings);\n    }\n\n    public getCondition(value: string): IFilteringOperation {\n        return this.column.filters.condition(value);\n    }\n\n    public onConditionsChanged(eventArgs: any) {\n        const value = (eventArgs.newSelection as IgxDropDownItemComponent).value;\n        this.expressionUI.expression.condition = this.getCondition(value);\n\n        this.focus();\n    }\n\n    public isValueSelected(value: string): boolean {\n        if (this.expressionUI.expression.searchVal) {\n            return this.expressionUI.expression.searchVal === value;\n        } else {\n            return false;\n        }\n    }\n\n    public onValuesInput(eventArgs) {\n        this.expressionUI.expression.searchVal = this.transformValue(eventArgs.target.value);\n    }\n\n    public onLogicOperatorButtonClicked(eventArgs, buttonIndex: number) {\n        if (this.logicOperatorButtonGroup.selectedButtons.length === 0) {\n            eventArgs.stopPropagation();\n            this.logicOperatorButtonGroup.selectButton(buttonIndex);\n        } else {\n            this.onLogicOperatorChanged.emit({\n                target: this.expressionUI,\n                newValue: buttonIndex as FilteringLogic\n            });\n        }\n    }\n\n    public onLogicOperatorKeyDown(eventArgs, buttonIndex: number) {\n        if (eventArgs.key === KEYS.ENTER) {\n            this.logicOperatorButtonGroup.selectButton(buttonIndex);\n            this.onLogicOperatorChanged.emit({\n                target: this.expressionUI,\n                newValue: buttonIndex as FilteringLogic\n            });\n        }\n    }\n\n    public onRemoveButtonClick() {\n        this.onExpressionRemoved.emit(this.expressionUI);\n    }\n\n    public onInputConditionsKeyDown(eventArgs) {\n        if (eventArgs.altKey && (eventArgs.key === KEYS.DOWN_ARROW || eventArgs.key === KEYS.DOWN_ARROW_IE)) {\n            this.toggleCustomDialogDropDown();\n        }\n\n        if (eventArgs.key === KEYS.TAB && eventArgs.shiftKey && this.expressionsList[0] === this.expressionUI) {\n            eventArgs.preventDefault();\n        }\n\n        event.stopPropagation();\n    }\n\n    private transformValue(value): any {\n        if (this.column.dataType === DataType.Number) {\n            value = parseFloat(value);\n        } else if (this.column.dataType === DataType.Boolean) {\n            value = Boolean(value);\n        }\n\n        return value;\n    }\n}\n"]}