igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
199 lines • 19.5 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { IgxGridCellComponent } from '../cell.component';
import { GridBaseAPIService } from '../api.service';
import { ChangeDetectorRef, ElementRef, ChangeDetectionStrategy, Component, HostListener, NgZone } from '@angular/core';
import { IgxHierarchicalSelectionAPIService } from './selection';
import { IgxGridSelectionService, IgxGridCRUDService } from '../../core/grid-selection';
export class IgxHierarchicalGridCellComponent extends IgxGridCellComponent {
/**
* @param {?} selectionService
* @param {?} crudService
* @param {?} gridAPI
* @param {?} selection
* @param {?} cdr
* @param {?} helement
* @param {?} zone
*/
constructor(selectionService, crudService, gridAPI, selection, cdr, helement, zone) {
super(selectionService, crudService, gridAPI, selection, cdr, helement, zone);
this.selectionService = selectionService;
this.crudService = crudService;
this.gridAPI = gridAPI;
this.selection = selection;
this.cdr = cdr;
this.helement = helement;
this.zone = zone;
this.hSelection = (/** @type {?} */ (selection));
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
this._rootGrid = this._getRootGrid();
}
/**
* @private
* @return {?}
*/
_getRootGrid() {
/** @type {?} */
let currGrid = this.grid;
while (currGrid.parent) {
currGrid = currGrid.parent;
}
return currGrid;
}
// TODO: Extend the new selection service to avoid complete traversal
/**
* @return {?}
*/
_clearAllHighlights() {
[this._rootGrid, ...this._rootGrid.getChildGrids(true)].forEach(grid => {
grid.selectionService.clear();
grid.selectionService.activeElement = null;
grid.nativeElement.classList.remove('igx-grid__tr--highlighted');
grid.highlightedRowID = null;
grid.cdr.markForCheck();
});
}
/**
* @return {?}
*/
_updateCellSelectionStatus() {
this._clearAllHighlights();
/** @type {?} */
const currentElement = this.grid.nativeElement;
/** @type {?} */
let parentGrid = this.grid;
/** @type {?} */
let childGrid;
// add highligh to the current grid
if (this._rootGrid.id !== currentElement.id) {
currentElement.classList.add('igx-grid__tr--highlighted');
}
// add highligh to the current grid
while (this._rootGrid.id !== parentGrid.id) {
childGrid = parentGrid;
parentGrid = parentGrid.parent;
/** @type {?} */
const parentRowID = parentGrid.hgridAPI.getParentRowId(childGrid);
parentGrid.highlightedRowID = parentRowID;
}
super._updateCellSelectionStatus();
}
// TODO: Refactor
/**
* @param {?} event
* @return {?}
*/
dispatchEvent(event) {
/** @type {?} */
const key = event.key.toLowerCase();
if (event.altKey) {
/** @type {?} */
const grid = this.gridAPI.grid;
/** @type {?} */
const state = this.gridAPI.grid.hierarchicalState;
/** @type {?} */
const collapse = this.row.expanded && (key === 'left' || key === 'arrowleft' || key === 'up' || key === 'arrowup');
/** @type {?} */
const expand = !this.row.expanded && (key === 'right' || key === 'arrowright' || key === 'down' || key === 'arrowdown');
if (collapse) {
grid.hierarchicalState = state.filter(v => {
return v.rowID !== this.row.rowID;
});
}
else if (expand) {
state.push({ rowID: this.row.rowID });
grid.hierarchicalState = [...state];
}
if (expand || collapse) {
/** @type {?} */
const rowID = this.cellID.rowID;
grid.cdr.detectChanges();
this.persistFocusedCell(rowID);
}
return;
}
super.dispatchEvent(event);
}
/**
* @protected
* @param {?} rowID
* @return {?}
*/
persistFocusedCell(rowID) {
requestAnimationFrame(() => {
// TODO: Test it out
/** @type {?} */
const cell = this.gridAPI.get_cell_by_key(rowID, this.column.field);
if (cell) {
cell.nativeElement.focus();
}
});
}
}
IgxHierarchicalGridCellComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
preserveWhitespaces: false,
selector: 'igx-hierarchical-grid-cell',
template: "<ng-template #defaultCell>\n <div igxTextHighlight [cssClass]=\"highlightClass\" [activeCssClass]=\"activeHighlightClass\" [groupName]=\"gridID\"\n [value]=\"formatter ? formatter(value) : column.dataType === 'number' ? (value | igxdecimal: grid.locale) : column.dataType === 'date' ? (value | igxdate: grid.locale) : value\"\n [row]=\"rowData\" [column]=\"this.column.field\" [containerClass]=\"'igx-grid__td-text'\"\n class=\"igx-grid__td-text\">{{ formatter ? formatter(value) : column.dataType === 'number' ? (value | igxdecimal:\n grid.locale) : column.dataType === 'date' ? (value | igxdate: grid.locale) : value }}</div>\n</ng-template>\n<ng-template #inlineEditor let-cell=\"cell\">\n <ng-container *ngIf=\"column.dataType === 'string'\">\n <igx-input-group displayDensity=\"compact\">\n <input igxInput [value]=\"editValue\" (input)=\"editValue = $event.target.value\" [igxFocus]=\"focused\" />\n </igx-input-group>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'number'\">\n <igx-input-group displayDensity=\"compact\">\n <input igxInput [value]=\"editValue\" (input)=\"editValue = $event.target.value\" [igxFocus]=\"focused\" type=\"number\">\n </igx-input-group>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'boolean'\">\n <igx-checkbox (change)=\"editValue = $event.checked\" [value]=\"editValue\" [checked]=\"editValue\"\n [igxFocus]=\"focused\" [disableRipple]=\"true\"></igx-checkbox>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'date'\">\n <igx-date-picker [style.width.%]=\"100\" [outlet]=\"grid.outletDirective\" mode=\"dropdown\" (onSelection)=\"editValue = $event\"\n [locale]=\"grid.locale\" [value]=\"editValue\" [igxFocus]=\"focused\" [labelVisibility]=\"false\">\n </igx-date-picker>\n </ng-container>\n</ng-template>\n<ng-container *ngTemplateOutlet=\"template; context: context\">\n</ng-container>\n"
}] }
];
/** @nocollapse */
IgxHierarchicalGridCellComponent.ctorParameters = () => [
{ type: IgxGridSelectionService },
{ type: IgxGridCRUDService },
{ type: GridBaseAPIService },
{ type: IgxHierarchicalSelectionAPIService },
{ type: ChangeDetectorRef },
{ type: ElementRef },
{ type: NgZone }
];
IgxHierarchicalGridCellComponent.propDecorators = {
dispatchEvent: [{ type: HostListener, args: ['keydown', ['$event'],] }]
};
if (false) {
/**
* @type {?}
* @protected
*/
IgxHierarchicalGridCellComponent.prototype.hSelection;
/**
* @type {?}
* @protected
*/
IgxHierarchicalGridCellComponent.prototype._rootGrid;
/**
* @type {?}
* @protected
*/
IgxHierarchicalGridCellComponent.prototype.selectionService;
/**
* @type {?}
* @protected
*/
IgxHierarchicalGridCellComponent.prototype.crudService;
/** @type {?} */
IgxHierarchicalGridCellComponent.prototype.gridAPI;
/** @type {?} */
IgxHierarchicalGridCellComponent.prototype.selection;
/** @type {?} */
IgxHierarchicalGridCellComponent.prototype.cdr;
/**
* @type {?}
* @private
*/
IgxHierarchicalGridCellComponent.prototype.helement;
/**
* @type {?}
* @protected
*/
IgxHierarchicalGridCellComponent.prototype.zone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hierarchical-cell.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/hierarchical-grid/hierarchical-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { IgxGridCellComponent } from '../cell.component';\nimport { GridBaseAPIService } from '../api.service';\nimport { ChangeDetectorRef, ElementRef, ChangeDetectionStrategy, Component,\n     OnInit, HostListener, NgZone } from '@angular/core';\nimport { IgxHierarchicalGridComponent } from './hierarchical-grid.component';\nimport { IgxHierarchicalSelectionAPIService } from './selection';\nimport { IgxGridSelectionService, IgxGridCRUDService } from '../../core/grid-selection';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-hierarchical-grid-cell',\n    templateUrl: './../cell.component.html'\n})\nexport class IgxHierarchicalGridCellComponent extends IgxGridCellComponent implements OnInit {\n\n    protected hSelection;\n    protected _rootGrid;\n\n    constructor(\n        protected selectionService: IgxGridSelectionService,\n        protected crudService: IgxGridCRUDService,\n        public gridAPI: GridBaseAPIService<IgxHierarchicalGridComponent>,\n        public selection: IgxHierarchicalSelectionAPIService,\n        public cdr: ChangeDetectorRef,\n        private helement: ElementRef,\n        protected zone: NgZone,\n        ) {\n            super(selectionService, crudService, gridAPI, selection, cdr, helement, zone);\n            this.hSelection = <IgxHierarchicalSelectionAPIService>selection;\n         }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this._rootGrid = this._getRootGrid();\n    }\n\n    private _getRootGrid() {\n        let currGrid = this.grid;\n        while (currGrid.parent) {\n            currGrid = currGrid.parent;\n        }\n        return currGrid;\n    }\n\n    // TODO: Extend the new selection service to avoid complete traversal\n    _clearAllHighlights() {\n        [this._rootGrid, ...this._rootGrid.getChildGrids(true)].forEach(grid => {\n            grid.selectionService.clear();\n            grid.selectionService.activeElement = null;\n            grid.nativeElement.classList.remove('igx-grid__tr--highlighted');\n            grid.highlightedRowID = null;\n            grid.cdr.markForCheck();\n        });\n    }\n\n    _updateCellSelectionStatus() {\n        this._clearAllHighlights();\n        const currentElement = this.grid.nativeElement;\n        let parentGrid = this.grid;\n        let childGrid;\n        // add highligh to the current grid\n        if (this._rootGrid.id !== currentElement.id) {\n            currentElement.classList.add('igx-grid__tr--highlighted');\n        }\n\n        // add highligh to the current grid\n        while (this._rootGrid.id !== parentGrid.id) {\n            childGrid = parentGrid;\n            parentGrid = parentGrid.parent;\n\n            const parentRowID = parentGrid.hgridAPI.getParentRowId(childGrid);\n            parentGrid.highlightedRowID = parentRowID;\n        }\n        super._updateCellSelectionStatus();\n    }\n\n    // TODO: Refactor\n    @HostListener('keydown', ['$event'])\n    dispatchEvent(event: KeyboardEvent) {\n        const key = event.key.toLowerCase();\n        if (event.altKey) {\n            const grid = this.gridAPI.grid;\n            const state = this.gridAPI.grid.hierarchicalState;\n            const collapse = this.row.expanded && (key === 'left' || key === 'arrowleft' || key === 'up' || key === 'arrowup');\n            const expand = !this.row.expanded && (key === 'right' || key === 'arrowright' || key === 'down' || key === 'arrowdown');\n            if (collapse) {\n                grid.hierarchicalState = state.filter(v => {\n                    return v.rowID !== this.row.rowID;\n                });\n            } else if (expand) {\n                state.push({ rowID: this.row.rowID });\n                grid.hierarchicalState = [...state];\n            }\n            if (expand || collapse) {\n                const rowID = this.cellID.rowID;\n                grid.cdr.detectChanges();\n                this.persistFocusedCell(rowID);\n            }\n            return;\n        }\n        super.dispatchEvent(event);\n    }\n    protected persistFocusedCell(rowID) {\n        requestAnimationFrame(() => {\n            // TODO: Test it out\n            const cell = this.gridAPI.get_cell_by_key(rowID, this.column.field);\n            if (cell) {\n                cell.nativeElement.focus();\n            }\n        });\n    }\n}\n"]}