UNPKG

igniteui-angular

Version:

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

282 lines • 23.9 kB
/** * @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"]}