@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
193 lines • 21.2 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { Component, Input, HostBinding, HostListener, ChangeDetectionStrategy, ElementRef } from '@angular/core';
import { IgxColumnComponent } from '../columns/column.component';
import { SUPPORTED_KEYS } from '../../core/utils';
let IgxSummaryCellComponent = class IgxSummaryCellComponent {
constructor(element) {
this.element = element;
this.firstCellIndentation = 0;
this.hasSummary = false;
this.tabindex = 0;
}
get visibleColumnIndex() {
return this.column.visibleIndex;
}
get describeby() {
return `Summary_${this.column.field}`;
}
onFocus() {
this.focused = true;
}
onBlur() {
this.focused = false;
}
get selectionNode() {
return {
row: this.rowIndex,
column: this.column.columnLayoutChild ? this.column.parent.visibleIndex : this.visibleColumnIndex,
isSummaryRow: true
};
}
dispatchEvent(event) {
// TODO: Refactor
const key = event.key.toLowerCase();
const ctrl = event.ctrlKey;
const shift = event.shiftKey;
if (!SUPPORTED_KEYS.has(key)) {
return;
}
event.stopPropagation();
const 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.grid.selectionService.keyboardState.shift = shift && !(key === 'tab');
const row = this.getRowElementByIndex(this.rowIndex);
switch (key) {
case 'tab':
if (shift) {
this.grid.navigation.performShiftTabKey(row, this.selectionNode);
break;
}
this.grid.navigation.performTab(row, this.selectionNode);
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.selectionNode);
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.selectionNode);
break;
case 'arrowup':
case 'up':
this.grid.navigation.navigateUp(row, this.selectionNode);
break;
case 'arrowdown':
case 'down':
this.grid.navigation.navigateDown(row, this.selectionNode);
break;
}
}
get width() {
return this.column.getCellWidth();
}
get nativeElement() {
return this.element.nativeElement;
}
get columnDatatype() {
return this.column.dataType;
}
get itemHeight() {
return this.column.grid.defaultSummaryHeight;
}
/**
* @hidden
*/
get grid() {
return this.column.grid;
}
getRowElementByIndex(rowIndex) {
const summaryRows = this.grid.summariesRowList.toArray();
return summaryRows.find((sr) => sr.dataRowIndex === rowIndex).nativeElement;
}
isKeySupportedInCell(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;
}
translateSummary(summary) {
return this.grid.resourceStrings[`igx_grid_summary_${summary.key}`] || summary.label;
}
};
IgxSummaryCellComponent.ctorParameters = () => [
{ type: ElementRef }
];
__decorate([
Input(),
__metadata("design:type", Array)
], IgxSummaryCellComponent.prototype, "summaryResults", void 0);
__decorate([
Input(),
__metadata("design:type", IgxColumnComponent)
], IgxSummaryCellComponent.prototype, "column", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSummaryCellComponent.prototype, "firstCellIndentation", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSummaryCellComponent.prototype, "hasSummary", void 0);
__decorate([
Input(),
__metadata("design:type", Object)
], IgxSummaryCellComponent.prototype, "density", void 0);
__decorate([
Input(),
HostBinding('attr.data-rowIndex'),
__metadata("design:type", Number)
], IgxSummaryCellComponent.prototype, "rowIndex", void 0);
__decorate([
HostBinding('attr.data-visibleIndex'),
__metadata("design:type", Number),
__metadata("design:paramtypes", [])
], IgxSummaryCellComponent.prototype, "visibleColumnIndex", null);
__decorate([
HostBinding('attr.tabindex'),
__metadata("design:type", Object)
], IgxSummaryCellComponent.prototype, "tabindex", void 0);
__decorate([
HostBinding('attr.aria-describedby'),
__metadata("design:type", Object),
__metadata("design:paramtypes", [])
], IgxSummaryCellComponent.prototype, "describeby", null);
__decorate([
HostBinding('class.igx-grid-summary--active'),
__metadata("design:type", Boolean)
], IgxSummaryCellComponent.prototype, "focused", void 0);
__decorate([
HostListener('focus'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxSummaryCellComponent.prototype, "onFocus", null);
__decorate([
HostListener('blur'),
__metadata("design:type", Function),
__metadata("design:paramtypes", []),
__metadata("design:returntype", void 0)
], IgxSummaryCellComponent.prototype, "onBlur", null);
__decorate([
HostListener('keydown', ['$event']),
__metadata("design:type", Function),
__metadata("design:paramtypes", [KeyboardEvent]),
__metadata("design:returntype", void 0)
], IgxSummaryCellComponent.prototype, "dispatchEvent", null);
IgxSummaryCellComponent = __decorate([
Component({
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"
}),
__metadata("design:paramtypes", [ElementRef])
], IgxSummaryCellComponent);
export { IgxSummaryCellComponent };
//# 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 '../columns/column.component';\nimport { DataType } from '../../data-operations/data-util';\nimport { ISelectionNode } from '../selection/selection.service';\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) {\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    protected get selectionNode(): ISelectionNode {\n        return {\n            row: this.rowIndex,\n            column: this.column.columnLayoutChild ? this.column.parent.visibleIndex : this.visibleColumnIndex,\n            isSummaryRow: true\n        };\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.grid.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.selectionNode);\n                    break;\n                }\n                this.grid.navigation.performTab(row, this.selectionNode);\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.selectionNode);\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.selectionNode);\n                break;\n            case 'arrowup':\n            case 'up':\n                    this.grid.navigation.navigateUp(row, this.selectionNode);\n                break;\n            case 'arrowdown':\n            case 'down':\n                    this.grid.navigation.navigateDown(row, this.selectionNode);\n                break;\n        }\n    }\n\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"]}