igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
158 lines • 15.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ChangeDetectorRef, ElementRef, ViewChild, Inject, ChangeDetectionStrategy, NgZone, Input } from '@angular/core';
import { IgxGridCellComponent } from '../cell.component';
import { GridBaseAPIService } from '../api.service';
import { IgxSelectionAPIService } from '../../core/selection';
import { getNodeSizeViaRange } from '../../core/utils';
import { DOCUMENT } from '@angular/common';
import { IgxGridSelectionService, IgxGridCRUDService } from '../../core/grid-selection';
export class IgxTreeGridCellComponent extends IgxGridCellComponent {
/**
* @param {?} selectionService
* @param {?} crudService
* @param {?} gridAPI
* @param {?} selection
* @param {?} cdr
* @param {?} element
* @param {?} zone
* @param {?} document
*/
constructor(selectionService, crudService, gridAPI, selection, cdr, element, zone, document) {
super(selectionService, crudService, gridAPI, selection, cdr, element, zone);
this.zone = zone;
this.document = document;
/**
* @hidden
*/
this.expanded = false;
/**
* @hidden
*/
this.level = 0;
/**
* @hidden
*/
this.showIndicator = false;
this.treeGridAPI = (/** @type {?} */ (gridAPI));
}
/**
* @hidden
* @return {?}
*/
get hasChildren() {
return this.row.treeRow.children && this.row.treeRow.children.length > 0;
}
/**
* @hidden
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
}
/**
* @hidden
* @param {?} event
* @return {?}
*/
toggle(event) {
event.stopPropagation();
this.treeGridAPI.trigger_row_expansion_toggle(this.row.treeRow, !this.row.expanded, event, this.visibleColumnIndex);
}
/**
* @hidden
* @return {?}
*/
onIndicatorFocus() {
this.gridAPI.submit_value();
this.nativeElement.focus();
}
/**
* @hidden
* @param {?} range
* @return {?}
*/
calculateSizeToFit(range) {
/** @type {?} */
const indicatorWidth = this.indicator.nativeElement.getBoundingClientRect().width;
/** @type {?} */
const indicatorStyle = this.document.defaultView.getComputedStyle(this.indicator.nativeElement);
/** @type {?} */
const indicatorMargin = parseFloat(indicatorStyle.marginRight);
/** @type {?} */
let leftPadding = 0;
if (this.indentationDiv) {
/** @type {?} */
const indentationStyle = this.document.defaultView.getComputedStyle(this.indentationDiv.nativeElement);
leftPadding = parseFloat(indentationStyle.paddingLeft);
}
/** @type {?} */
const largestWidth = Math.max(...Array.from(this.nativeElement.children)
.map((child) => getNodeSizeViaRange(range, child)));
return largestWidth + indicatorWidth + indicatorMargin + leftPadding;
}
}
IgxTreeGridCellComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
selector: 'igx-tree-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 [(ngModel)]=\"editValue\" [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 [(ngModel)]=\"editValue\" [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\" [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 *ngIf=\"!inEditMode\">\n <ng-container *ngIf=\"level > 0\">\n <div #indentationDiv class=\"igx-grid__tree-cell--padding-level-{{level}}\"></div>\n </ng-container>\n <div #indicator class=\"igx-grid__tree-grouping-indicator\" [ngStyle]=\"{'visibility': showIndicator ? 'visible' : 'hidden'}\"\n (click)=\"toggle($event)\" (focus)=\"onIndicatorFocus()\" tabindex=\"-1\">\n <igx-icon *ngIf=\"!expanded\" fontSet=\"material\">expand_more</igx-icon>\n <igx-icon *ngIf=\"expanded\" fontSet=\"material\">expand_less</igx-icon>\n </div>\n</ng-container>\n<ng-container *ngTemplateOutlet=\"template; context: context\">\n</ng-container>\n"
}] }
];
/** @nocollapse */
IgxTreeGridCellComponent.ctorParameters = () => [
{ type: IgxGridSelectionService },
{ type: IgxGridCRUDService },
{ type: GridBaseAPIService },
{ type: IgxSelectionAPIService },
{ type: ChangeDetectorRef },
{ type: ElementRef },
{ type: NgZone },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
];
IgxTreeGridCellComponent.propDecorators = {
expanded: [{ type: Input }],
level: [{ type: Input }],
showIndicator: [{ type: Input }],
indicator: [{ type: ViewChild, args: ['indicator', { read: ElementRef },] }],
indentationDiv: [{ type: ViewChild, args: ['indentationDiv', { read: ElementRef },] }],
defaultContentElement: [{ type: ViewChild, args: ['defaultContentElement', { read: ElementRef },] }]
};
if (false) {
/**
* @type {?}
* @private
*/
IgxTreeGridCellComponent.prototype.treeGridAPI;
/**
* @hidden
* @type {?}
*/
IgxTreeGridCellComponent.prototype.expanded;
/**
* @hidden
* @type {?}
*/
IgxTreeGridCellComponent.prototype.level;
/**
* @hidden
* @type {?}
*/
IgxTreeGridCellComponent.prototype.showIndicator;
/** @type {?} */
IgxTreeGridCellComponent.prototype.indicator;
/** @type {?} */
IgxTreeGridCellComponent.prototype.indentationDiv;
/** @type {?} */
IgxTreeGridCellComponent.prototype.defaultContentElement;
/**
* @type {?}
* @protected
*/
IgxTreeGridCellComponent.prototype.zone;
/** @type {?} */
IgxTreeGridCellComponent.prototype.document;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tree-cell.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/tree-grid/tree-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectorRef, ElementRef, ViewChild, Inject, ChangeDetectionStrategy, NgZone, OnInit, Input } from '@angular/core';\nimport { IgxGridCellComponent } from '../cell.component';\nimport { IgxTreeGridAPIService } from './tree-grid-api.service';\nimport { GridBaseAPIService } from '../api.service';\nimport { IgxSelectionAPIService } from '../../core/selection';\nimport { getNodeSizeViaRange } from '../../core/utils';\nimport { DOCUMENT } from '@angular/common';\nimport { IgxGridBaseComponent, IGridDataBindable } from '../grid';\nimport { IgxGridSelectionService, IgxGridCRUDService } from '../../core/grid-selection';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'igx-tree-grid-cell',\n    templateUrl: 'tree-cell.component.html'\n})\nexport class IgxTreeGridCellComponent extends IgxGridCellComponent implements OnInit {\n    private treeGridAPI: IgxTreeGridAPIService;\n\n    constructor(\n                selectionService: IgxGridSelectionService,\n                crudService: IgxGridCRUDService,\n                gridAPI: GridBaseAPIService<IgxGridBaseComponent & IGridDataBindable>,\n                selection: IgxSelectionAPIService,\n                cdr: ChangeDetectorRef,\n                element: ElementRef,\n                protected zone: NgZone,\n                @Inject(DOCUMENT) public document) {\n        super(selectionService, crudService, gridAPI, selection, cdr, element, zone);\n        this.treeGridAPI = <IgxTreeGridAPIService>gridAPI;\n    }\n\n    /**\n     * @hidden\n     */\n    @Input()\n    expanded = false;\n\n    /**\n     * @hidden\n     */\n    @Input()\n    level = 0;\n\n    /**\n     * @hidden\n     */\n    @Input()\n    showIndicator = false;\n\n    @ViewChild('indicator', { read: ElementRef })\n    public indicator: ElementRef;\n\n    @ViewChild('indentationDiv', { read: ElementRef })\n    public indentationDiv: ElementRef;\n\n    @ViewChild('defaultContentElement', { read: ElementRef })\n    public defaultContentElement: ElementRef;\n\n\n    /**\n     * @hidden\n     */\n    public get hasChildren() {\n        return this.row.treeRow.children && this.row.treeRow.children.length > 0;\n    }\n\n    /**\n     * @hidden\n     */\n    ngOnInit() {\n        super.ngOnInit();\n    }\n\n    /**\n     * @hidden\n     */\n    public toggle(event: Event) {\n        event.stopPropagation();\n        this.treeGridAPI.trigger_row_expansion_toggle(this.row.treeRow, !this.row.expanded, event, this.visibleColumnIndex);\n    }\n\n    /**\n     * @hidden\n     */\n    public onIndicatorFocus() {\n        this.gridAPI.submit_value();\n        this.nativeElement.focus();\n    }\n\n    /**\n     * @hidden\n     */\n    public calculateSizeToFit(range: any): number {\n        const indicatorWidth = this.indicator.nativeElement.getBoundingClientRect().width;\n        const indicatorStyle = this.document.defaultView.getComputedStyle(this.indicator.nativeElement);\n        const indicatorMargin = parseFloat(indicatorStyle.marginRight);\n        let leftPadding = 0;\n        if (this.indentationDiv) {\n            const indentationStyle = this.document.defaultView.getComputedStyle(this.indentationDiv.nativeElement);\n            leftPadding = parseFloat(indentationStyle.paddingLeft);\n        }\n        const largestWidth = Math.max(...Array.from(this.nativeElement.children)\n            .map((child) => getNodeSizeViaRange(range, child)));\n        return largestWidth + indicatorWidth + indicatorMargin + leftPadding;\n    }\n}\n"]}