igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
282 lines • 23.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, HostBinding, HostListener, ChangeDetectionStrategy, ElementRef } from '@angular/core';
import { IgxColumnComponent } from '../column.component';
import { IgxGridSelectionService } from '../../core/grid-selection';
import { SUPPORTED_KEYS } from '../../core/utils';
var IgxSummaryCellComponent = /** @class */ (function () {
function IgxSummaryCellComponent(element, selectionService) {
this.element = element;
this.selectionService = selectionService;
this.firstCellIndentation = 0;
this.hasSummary = false;
this.tabindex = 0;
}
Object.defineProperty(IgxSummaryCellComponent.prototype, "visibleColumnIndex", {
get: /**
* @return {?}
*/
function () {
return this.column.visibleIndex;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSummaryCellComponent.prototype, "describeby", {
get: /**
* @return {?}
*/
function () {
return "Summary_" + this.column.field;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
IgxSummaryCellComponent.prototype.onFocus = /**
* @return {?}
*/
function () {
this.focused = true;
};
/**
* @return {?}
*/
IgxSummaryCellComponent.prototype.onBlur = /**
* @return {?}
*/
function () {
this.focused = false;
};
/**
* @param {?} event
* @return {?}
*/
IgxSummaryCellComponent.prototype.dispatchEvent = /**
* @param {?} event
* @return {?}
*/
function (event) {
// TODO: Refactor
/** @type {?} */
var key = event.key.toLowerCase();
/** @type {?} */
var ctrl = event.ctrlKey;
/** @type {?} */
var shift = event.shiftKey;
if (!SUPPORTED_KEYS.has(key)) {
return;
}
event.stopPropagation();
/** @type {?} */
var args = { targetType: 'summaryCell', target: this, event: event, cancel: false };
this.grid.onGridKeydown.emit(args);
if (args.cancel) {
return;
}
event.preventDefault();
if (!this.isKeySupportedInCell(key, ctrl)) {
return;
}
this.selectionService.keyboardState.shift = shift && !(key === 'tab');
/** @type {?} */
var row = this.getRowElementByIndex(this.rowIndex);
switch (key) {
case 'tab':
if (shift) {
this.grid.navigation.performShiftTabKey(row, this.rowIndex, this.visibleColumnIndex, true);
break;
}
this.grid.navigation.performTab(row, this.rowIndex, this.visibleColumnIndex, true);
break;
case 'arrowleft':
case 'home':
case 'left':
if (ctrl || key === 'home') {
this.grid.navigation.onKeydownHome(this.rowIndex, true);
break;
}
this.grid.navigation.onKeydownArrowLeft(this.nativeElement, this.rowIndex, this.visibleColumnIndex, true);
break;
case 'end':
case 'arrowright':
case 'right':
if (ctrl || key === 'end') {
this.grid.navigation.onKeydownEnd(this.rowIndex, true);
break;
}
this.grid.navigation.onKeydownArrowRight(this.nativeElement, this.rowIndex, this.visibleColumnIndex, true);
break;
case 'arrowup':
case 'up':
this.grid.navigation.navigateUp(row, this.rowIndex, this.visibleColumnIndex);
break;
case 'arrowdown':
case 'down':
this.grid.navigation.navigateDown(row, this.rowIndex, this.visibleColumnIndex);
break;
}
};
Object.defineProperty(IgxSummaryCellComponent.prototype, "width", {
get: /**
* @return {?}
*/
function () {
return this.column.getCellWidth();
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSummaryCellComponent.prototype, "nativeElement", {
get: /**
* @return {?}
*/
function () {
return this.element.nativeElement;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSummaryCellComponent.prototype, "columnDatatype", {
get: /**
* @return {?}
*/
function () {
return this.column.dataType;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSummaryCellComponent.prototype, "itemHeight", {
get: /**
* @return {?}
*/
function () {
return this.column.grid.defaultSummaryHeight;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxSummaryCellComponent.prototype, "grid", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return ((/** @type {?} */ (this.column.grid)));
},
enumerable: true,
configurable: true
});
/**
* @private
* @param {?} rowIndex
* @return {?}
*/
IgxSummaryCellComponent.prototype.getRowElementByIndex = /**
* @private
* @param {?} rowIndex
* @return {?}
*/
function (rowIndex) {
/** @type {?} */
var summaryRows = this.grid.summariesRowList.toArray();
return summaryRows.find(function (sr) { return sr.dataRowIndex === rowIndex; }).nativeElement;
};
/**
* @private
* @param {?} key
* @param {?} ctrl
* @return {?}
*/
IgxSummaryCellComponent.prototype.isKeySupportedInCell = /**
* @private
* @param {?} key
* @param {?} ctrl
* @return {?}
*/
function (key, ctrl) {
if (ctrl) {
return ['arrowup', 'arrowdown', 'up', 'down', 'end', 'home'].indexOf(key) === -1;
}
return ['down', 'up', 'left', 'right', 'arrowdown', 'arrowup', 'arrowleft', 'arrowright', 'home', 'end', 'tab'].indexOf(key) !== -1;
};
/**
* @param {?} summary
* @return {?}
*/
IgxSummaryCellComponent.prototype.translateSummary = /**
* @param {?} summary
* @return {?}
*/
function (summary) {
return this.grid.resourceStrings["igx_grid_summary_" + summary.key] || summary.label;
};
IgxSummaryCellComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
preserveWhitespaces: false,
selector: 'igx-grid-summary-cell',
template: "<ng-container *ngIf=\"hasSummary\">\n <ng-container *ngFor=\"let summary of summaryResults\">\n <div class=\"igx-grid-summary__item\" [style.height.px]=\"itemHeight\">\n\n <ng-container *ngIf=\"visibleColumnIndex === 0 && firstCellIndentation >= 0\">\n <div class=\"igx-grid__tree-cell--padding-level-{{firstCellIndentation}}\"></div>\n\n <div #indicator class=\"igx-grid__tree-grouping-indicator\" style=\"visibility: hidden\">\n <igx-icon fontSet=\"material\">chevron_right</igx-icon>\n </div>\n </ng-container>\n\n <span class=\"igx-grid-summary__label\" title=\"{{ summary.label }}\">{{ translateSummary(summary) }}</span>\n <span class=\"igx-grid-summary__result\" title=\"{{ summary.summaryResult }}\">\n {{ columnDatatype === 'number' ? (summary.summaryResult | igxdecimal: grid.locale) : columnDatatype === 'date' ? (summary.summaryResult | igxdate: grid.locale) : (summary.summaryResult) }}\n </span>\n </div>\n </ng-container>\n</ng-container>\n"
}] }
];
/** @nocollapse */
IgxSummaryCellComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: IgxGridSelectionService }
]; };
IgxSummaryCellComponent.propDecorators = {
summaryResults: [{ type: Input }],
column: [{ type: Input }],
firstCellIndentation: [{ type: Input }],
hasSummary: [{ type: Input }],
density: [{ type: Input }],
rowIndex: [{ type: Input }, { type: HostBinding, args: ['attr.data-rowIndex',] }],
visibleColumnIndex: [{ type: HostBinding, args: ['attr.data-visibleIndex',] }],
tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
describeby: [{ type: HostBinding, args: ['attr.aria-describedby',] }],
focused: [{ type: HostBinding, args: ['class.igx-grid-summary--active',] }],
onFocus: [{ type: HostListener, args: ['focus',] }],
onBlur: [{ type: HostListener, args: ['blur',] }],
dispatchEvent: [{ type: HostListener, args: ['keydown', ['$event'],] }],
width: [{ type: HostBinding, args: ['style.min-width',] }, { type: HostBinding, args: ['style.max-width',] }, { type: HostBinding, args: ['style.flex-basis',] }]
};
return IgxSummaryCellComponent;
}());
export { IgxSummaryCellComponent };
if (false) {
/** @type {?} */
IgxSummaryCellComponent.prototype.summaryResults;
/** @type {?} */
IgxSummaryCellComponent.prototype.column;
/** @type {?} */
IgxSummaryCellComponent.prototype.firstCellIndentation;
/** @type {?} */
IgxSummaryCellComponent.prototype.hasSummary;
/** @type {?} */
IgxSummaryCellComponent.prototype.density;
/** @type {?} */
IgxSummaryCellComponent.prototype.rowIndex;
/** @type {?} */
IgxSummaryCellComponent.prototype.tabindex;
/** @type {?} */
IgxSummaryCellComponent.prototype.focused;
/**
* @type {?}
* @private
*/
IgxSummaryCellComponent.prototype.element;
/**
* @type {?}
* @private
*/
IgxSummaryCellComponent.prototype.selectionService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"summary-cell.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/summaries/summary-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostBinding, HostListener, ChangeDetectionStrategy, ElementRef } from '@angular/core';\nimport { IgxSummaryResult } from './grid-summary';\nimport { IgxColumnComponent } from '../column.component';\nimport { DataType } from '../../data-operations/data-util';\nimport { IgxGridSelectionService } from '../../core/grid-selection';\nimport { SUPPORTED_KEYS } from '../../core/utils';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-grid-summary-cell',\n    templateUrl: './summary-cell.component.html'\n})\nexport class IgxSummaryCellComponent {\n\n    @Input()\n    public summaryResults: IgxSummaryResult[];\n\n    @Input()\n    public column: IgxColumnComponent;\n\n    @Input()\n    public firstCellIndentation = 0;\n\n    @Input()\n    public hasSummary = false;\n\n    @Input()\n    public density;\n\n    constructor(private element: ElementRef, private selectionService: IgxGridSelectionService) {\n    }\n\n    @Input()\n    @HostBinding('attr.data-rowIndex')\n    public rowIndex: number;\n\n    @HostBinding('attr.data-visibleIndex')\n    get visibleColumnIndex(): number {\n        return this.column.visibleIndex;\n    }\n\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    @HostBinding('attr.aria-describedby')\n    public get describeby() {\n        return `Summary_${this.column.field}`;\n    }\n\n    @HostBinding('class.igx-grid-summary--active')\n    public focused: boolean;\n\n    @HostListener('focus')\n    public onFocus() {\n        this.focused = true;\n    }\n\n    @HostListener('blur')\n    public onBlur() {\n        this.focused = false;\n    }\n\n    @HostListener('keydown', ['$event'])\n    dispatchEvent(event: KeyboardEvent) {\n        // TODO: Refactor\n        const key = event.key.toLowerCase();\n        const ctrl = event.ctrlKey;\n        const shift = event.shiftKey;\n\n        if (!SUPPORTED_KEYS.has(key)) {\n            return;\n        }\n        event.stopPropagation();\n        const args = { targetType: 'summaryCell', target: this, event: event, cancel: false };\n        this.grid.onGridKeydown.emit(args);\n        if (args.cancel) {\n            return;\n        }\n        event.preventDefault();\n\n        if (!this.isKeySupportedInCell(key, ctrl)) { return; }\n\n        this.selectionService.keyboardState.shift = shift && !(key === 'tab');\n        const row = this.getRowElementByIndex(this.rowIndex);\n        switch (key) {\n            case 'tab':\n                if (shift) {\n                    this.grid.navigation.performShiftTabKey(row, this.rowIndex, this.visibleColumnIndex, true);\n                    break;\n                }\n                this.grid.navigation.performTab(row, this.rowIndex, this.visibleColumnIndex, true);\n                break;\n            case 'arrowleft':\n            case 'home':\n            case 'left':\n                if (ctrl || key === 'home') {\n                    this.grid.navigation.onKeydownHome(this.rowIndex, true);\n                    break;\n                }\n                this.grid.navigation.onKeydownArrowLeft(this.nativeElement, this.rowIndex, this.visibleColumnIndex, true);\n                break;\n            case 'end':\n            case 'arrowright':\n            case 'right':\n                if (ctrl || key === 'end') {\n                    this.grid.navigation.onKeydownEnd(this.rowIndex, true);\n                    break;\n                }\n                this.grid.navigation.onKeydownArrowRight(this.nativeElement, this.rowIndex, this.visibleColumnIndex, true);\n                break;\n            case 'arrowup':\n            case 'up':\n                this.grid.navigation.navigateUp(row, this.rowIndex, this.visibleColumnIndex);\n                break;\n            case 'arrowdown':\n            case 'down':\n                this.grid.navigation.navigateDown(row, this.rowIndex, this.visibleColumnIndex);\n                break;\n        }\n    }\n\n    @HostBinding('style.min-width')\n    @HostBinding('style.max-width')\n    @HostBinding('style.flex-basis')\n    get width() {\n        return this.column.getCellWidth();\n    }\n\n    get nativeElement(): any {\n        return this.element.nativeElement;\n    }\n\n    get columnDatatype(): DataType {\n        return this.column.dataType;\n    }\n\n    get itemHeight() {\n        return this.column.grid.defaultSummaryHeight;\n    }\n\n    /**\n    * @hidden\n    */\n    public get grid() {\n        return (this.column.grid as any);\n    }\n\n    private getRowElementByIndex(rowIndex) {\n        const summaryRows = this.grid.summariesRowList.toArray();\n        return summaryRows.find((sr) => sr.dataRowIndex === rowIndex).nativeElement;\n    }\n\n    private isKeySupportedInCell(key, ctrl) {\n        if (ctrl) {\n           return ['arrowup', 'arrowdown', 'up', 'down', 'end', 'home'].indexOf(key) === -1;\n        }\n        return ['down', 'up', 'left', 'right', 'arrowdown', 'arrowup', 'arrowleft', 'arrowright', 'home', 'end', 'tab'].indexOf(key) !== -1;\n    }\n\n    public translateSummary(summary: IgxSummaryResult): string {\n        return this.grid.resourceStrings[`igx_grid_summary_${summary.key}`] || summary.label;\n    }\n}\n"]}