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