@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
346 lines • 41.4 kB
JavaScript
import { __decorate, __extends, __metadata, __param } from "tslib";
import { AfterContentInit, ChangeDetectionStrategy, Component, ContentChildren, Input, QueryList, OnInit, Inject, ElementRef, ChangeDetectorRef, ComponentFactoryResolver, IterableDiffers, ViewContainerRef, NgZone, AfterViewInit, OnChanges, Output, EventEmitter, Optional, OnDestroy, DoCheck } from '@angular/core';
import { IgxGridTransaction } from '../grid-base.directive';
import { GridBaseAPIService } from '../api.service';
import { DOCUMENT } from '@angular/common';
import { IgxFilteringService } from '../filtering/grid-filtering.service';
import { DisplayDensityToken } from '../../core/displayDensity';
import { IgxGridSummaryService } from '../summaries/grid-summary.service';
import { IgxHierarchicalGridBaseDirective } from './hierarchical-grid-base.directive';
import { IgxHierarchicalGridNavigationService } from './hierarchical-grid-navigation.service';
import { IgxGridSelectionService, IgxGridCRUDService } from '../selection/selection.service';
import { IgxOverlayService } from '../../services/index';
import { takeUntil } from 'rxjs/operators';
import { IgxColumnComponent } from '../columns/column.component';
import { IgxRowIslandAPIService } from './row-island-api.service';
import { IgxColumnResizingService } from '../resizing/resizing.service';
var IgxRowIslandComponent = /** @class */ (function (_super) {
__extends(IgxRowIslandComponent, _super);
function IgxRowIslandComponent(selectionService, crudService, colResizingService, gridAPI, transactionFactory, elementRef, zone, document, cdr, resolver, differs, viewRef, navigation, filteringService, overlayService, summaryService, _displayDensityOptions, rowIslandAPI) {
var _this = _super.call(this, selectionService, crudService, colResizingService, gridAPI, typeof transactionFactory === 'function' ? transactionFactory() : transactionFactory, elementRef, zone, document, cdr, resolver, differs, viewRef, navigation, filteringService, overlayService, summaryService, _displayDensityOptions) || this;
_this.selectionService = selectionService;
_this.colResizingService = colResizingService;
_this.transactionFactory = transactionFactory;
_this.document = document;
_this.overlayService = overlayService;
_this.summaryService = summaryService;
_this._displayDensityOptions = _displayDensityOptions;
_this.rowIslandAPI = rowIslandAPI;
/**
* @hidden
*/
_this.children = new QueryList();
/**
* @hidden
*/
_this.childColumns = new QueryList();
/**
* @hidden
*/
_this.onLayoutChange = new EventEmitter();
/**
* Event emmited when a grid is being created based on this row island.
* ```html
* <igx-hierarchical-grid [data]="Data" [autoGenerate]="true">
* <igx-row-island [key]="'childData'" (onGridCreated)="gridCreated($event)" #rowIsland>
* <!-- ... -->
* </igx-row-island>
* </igx-hierarchical-grid>
* ```
* @memberof IgxRowIslandComponent
*/
_this.onGridCreated = new EventEmitter();
/**
* @hidden
*/
_this.initialChanges = [];
/**
* @hidden
*/
_this.rootGrid = null;
_this.layout_id = "igx-row-island-";
_this.isInit = false;
_this.hgridAPI = gridAPI;
return _this;
}
IgxRowIslandComponent_1 = IgxRowIslandComponent;
Object.defineProperty(IgxRowIslandComponent.prototype, "expandChildren", {
/**
* Gets if all immediate children of the grids for this `IgxRowIslandComponent` have been set to be expanded/collapsed.
* ```typescript
* const expanded = this.rowIsland.expandChildren;
* ```
* @memberof IgxRowIslandComponent
*/
get: function () {
return this._expandChildren;
},
/**
* Sets if all immediate children of the grids for this `IgxRowIslandComponent` should be expanded/collapsed.
* ```html
* <igx-hierarchical-grid [data]="Data" [autoGenerate]="true">
* <igx-row-island [key]="'childData'" [expandChildren]="true" #rowIsland>
* <!-- ... -->
* </igx-row-island>
* </igx-hierarchical-grid>
* ```
* @memberof IgxRowIslandComponent
*/
set: function (value) {
this._expandChildren = value;
this.rowIslandAPI.getChildGrids().forEach(function (grid) {
if (document.body.contains(grid.nativeElement)) {
// Detect changes right away if the grid is visible
grid.expandChildren = value;
grid.markForCheck();
}
else {
// Else defer the detection on changes when the grid gets into view for performance.
grid.updateOnRender = true;
}
});
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRowIslandComponent.prototype, "id", {
/**
* @hidden
*/
get: function () {
var pId = this.parentId ? this.parentId.substring(this.parentId.indexOf(this.layout_id) + this.layout_id.length) + '-' : '';
return this.layout_id + pId + this.key;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRowIslandComponent.prototype, "parentId", {
/**
* @hidden
*/
get: function () {
return this.parentIsland ? this.parentIsland.id : null;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxRowIslandComponent.prototype, "level", {
/**
* @hidden
*/
get: function () {
var ptr = this.parentIsland;
var lvl = 0;
while (ptr) {
lvl++;
ptr = ptr.parentIsland;
}
return lvl + 1;
},
enumerable: true,
configurable: true
});
/**
* @hidden
*/
IgxRowIslandComponent.prototype.ngOnInit = function () {
this.rootGrid = this.hgridAPI.grid;
this.rowIslandAPI.rowIsland = this;
};
/**
* @hidden
*/
IgxRowIslandComponent.prototype.ngDoCheck = function () {
};
/**
* @hidden
*/
IgxRowIslandComponent.prototype.ngAfterContentInit = function () {
var _this = this;
this.updateChildren();
this.children.notifyOnChanges();
this.children.changes.pipe(takeUntil(this.destroy$))
.subscribe(function (change) {
_this.updateChildren();
// update existing grids since their child ri have been changed.
_this.getGridsForIsland(_this.key).forEach(function (grid) {
grid.onRowIslandChange(_this.children);
});
});
var nestedColumns = this.children.map(function (layout) { return layout.columnList.toArray(); });
var colsArray = [].concat.apply([], nestedColumns);
var topCols = this.columnList.filter(function (item) {
return colsArray.indexOf(item) === -1;
});
this.childColumns.reset(topCols);
this.columnList.changes.pipe(takeUntil(this.destroy$)).subscribe(function () { _this.updateColumnList(); });
};
IgxRowIslandComponent.prototype.updateChildren = function () {
var _this = this;
if (this.children.first === this) {
this.children.reset(this.children.toArray().slice(1));
}
this.children.forEach(function (child) {
child.parentIsland = _this;
});
};
/**
* @hidden
*/
IgxRowIslandComponent.prototype.ngAfterViewInit = function () {
this.rowIslandAPI.register(this);
if (this.parentIsland) {
this.parentIsland.rowIslandAPI.registerChildRowIsland(this);
}
else {
this.rootGrid.hgridAPI.registerChildRowIsland(this);
}
this._init = false;
};
/**
* @hidden
*/
IgxRowIslandComponent.prototype.ngOnChanges = function (changes) {
this.onLayoutChange.emit(changes);
if (!this.isInit) {
this.initialChanges.push(changes);
}
};
/**
* @hidden
*/
IgxRowIslandComponent.prototype.ngOnDestroy = function () {
var _this = this;
// Override the base destroy because we don't have rendered anything to use removeEventListener on
this.destroy$.next(true);
this.destroy$.complete();
this._destroyed = true;
this.rowIslandAPI.unset(this.id);
if (this.parentIsland) {
this.getGridsForIsland(this.key).forEach(function (grid) {
_this.cleanGridState(grid);
grid.hgridAPI.unsetChildRowIsland(_this);
});
this.parentIsland.rowIslandAPI.unsetChildRowIsland(this);
}
else {
this.rootGrid.hgridAPI.unsetChildRowIsland(this);
this.cleanGridState(this.rootGrid);
}
};
IgxRowIslandComponent.prototype.cleanGridState = function (grid) {
grid.childGridTemplates.forEach(function (tmpl) {
tmpl.owner.cleanView(tmpl.context.templateID);
});
grid.childGridTemplates.clear();
grid.onRowIslandChange();
};
/**
* @hidden
*/
IgxRowIslandComponent.prototype.reflow = function () { };
/**
* @hidden
*/
IgxRowIslandComponent.prototype.calculateGridHeight = function () { };
IgxRowIslandComponent.prototype.updateColumnList = function () {
var _this = this;
var nestedColumns = this.children.map(function (layout) { return layout.columnList.toArray(); });
var colsArray = [].concat.apply([], nestedColumns);
var topCols = this.columnList.filter(function (item) {
if (colsArray.indexOf(item) === -1) {
/* Reset the default width of the columns that come into this row island,
because the root catches them first during the detectChanges() and sets their defaultWidth. */
item.defaultWidth = undefined;
return true;
}
return false;
});
this.childColumns.reset(topCols);
if (this.parentIsland) {
this.parentIsland.columnList.notifyOnChanges();
}
else {
this.rootGrid.columnList.notifyOnChanges();
}
this.rowIslandAPI.getChildGrids().forEach(function (grid) {
grid.createColumnsList(_this.childColumns.toArray());
if (!document.body.contains(grid.nativeElement)) {
grid.updateOnRender = true;
}
});
};
var IgxRowIslandComponent_1;
IgxRowIslandComponent.ctorParameters = function () { return [
{ type: IgxGridSelectionService },
{ type: IgxGridCRUDService },
{ type: IgxColumnResizingService },
{ type: GridBaseAPIService },
{ type: undefined, decorators: [{ type: Inject, args: [IgxGridTransaction,] }] },
{ type: ElementRef },
{ type: NgZone },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] },
{ type: ChangeDetectorRef },
{ type: ComponentFactoryResolver },
{ type: IterableDiffers },
{ type: ViewContainerRef },
{ type: IgxHierarchicalGridNavigationService },
{ type: IgxFilteringService },
{ type: IgxOverlayService, decorators: [{ type: Inject, args: [IgxOverlayService,] }] },
{ type: IgxGridSummaryService },
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DisplayDensityToken,] }] },
{ type: IgxRowIslandAPIService }
]; };
__decorate([
Input(),
__metadata("design:type", String)
], IgxRowIslandComponent.prototype, "key", void 0);
__decorate([
Input(),
__metadata("design:type", Boolean),
__metadata("design:paramtypes", [Boolean])
], IgxRowIslandComponent.prototype, "expandChildren", null);
__decorate([
ContentChildren(IgxRowIslandComponent_1, { read: IgxRowIslandComponent_1, descendants: false }),
__metadata("design:type", Object)
], IgxRowIslandComponent.prototype, "children", void 0);
__decorate([
ContentChildren(IgxColumnComponent, { read: IgxColumnComponent, descendants: false }),
__metadata("design:type", Object)
], IgxRowIslandComponent.prototype, "childColumns", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxRowIslandComponent.prototype, "onLayoutChange", void 0);
__decorate([
Output(),
__metadata("design:type", Object)
], IgxRowIslandComponent.prototype, "onGridCreated", void 0);
IgxRowIslandComponent = IgxRowIslandComponent_1 = __decorate([
Component({
changeDetection: ChangeDetectionStrategy.OnPush,
selector: 'igx-row-island',
template: "",
providers: [IgxRowIslandAPIService]
}),
__param(4, Inject(IgxGridTransaction)),
__param(7, Inject(DOCUMENT)),
__param(14, Inject(IgxOverlayService)),
__param(16, Optional()), __param(16, Inject(DisplayDensityToken)),
__metadata("design:paramtypes", [IgxGridSelectionService,
IgxGridCRUDService,
IgxColumnResizingService,
GridBaseAPIService, Object, ElementRef,
NgZone, Object, ChangeDetectorRef,
ComponentFactoryResolver,
IterableDiffers,
ViewContainerRef,
IgxHierarchicalGridNavigationService,
IgxFilteringService,
IgxOverlayService,
IgxGridSummaryService, Object, IgxRowIslandAPIService])
], IgxRowIslandComponent);
return IgxRowIslandComponent;
}(IgxHierarchicalGridBaseDirective));
export { IgxRowIslandComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"row-island.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/hierarchical-grid/row-island.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    ChangeDetectionStrategy,\n    Component,\n    ContentChildren,\n    Input,\n    QueryList,\n    OnInit,\n    Inject,\n    ElementRef,\n    ChangeDetectorRef,\n    ComponentFactoryResolver,\n    IterableDiffers,\n    ViewContainerRef,\n    NgZone,\n    AfterViewInit,\n    OnChanges,\n    Output,\n    EventEmitter,\n    Optional,\n    OnDestroy,\n    DoCheck\n} from '@angular/core';\nimport { IgxHierarchicalGridComponent } from './hierarchical-grid.component';\nimport { IgxGridTransaction, IgxGridBaseDirective } from '../grid-base.directive';\nimport { GridBaseAPIService } from '../api.service';\nimport { IgxHierarchicalGridAPIService } from './hierarchical-grid-api.service';\nimport { DOCUMENT } from '@angular/common';\nimport { IgxFilteringService } from '../filtering/grid-filtering.service';\nimport { IDisplayDensityOptions, DisplayDensityToken } from '../../core/displayDensity';\nimport { TransactionService, Transaction, State } from '../../services';\nimport { IgxGridSummaryService } from '../summaries/grid-summary.service';\nimport { IgxHierarchicalGridBaseDirective } from './hierarchical-grid-base.directive';\nimport { IgxHierarchicalGridNavigationService } from './hierarchical-grid-navigation.service';\nimport { IgxGridSelectionService, IgxGridCRUDService } from '../selection/selection.service';\n\nimport { IgxOverlayService } from '../../services/index';\nimport { takeUntil } from 'rxjs/operators';\nimport { IgxColumnComponent } from '../columns/column.component';\nimport { IgxRowIslandAPIService } from './row-island-api.service';\nimport { IBaseEventArgs } from '../../core/utils';\nimport { IgxColumnResizingService } from '../resizing/resizing.service';\nimport { GridType } from '../common/grid.interface';\nexport interface IGridCreatedEventArgs extends IBaseEventArgs {\n    owner: IgxRowIslandComponent;\n    parentID: any;\n    grid: IgxHierarchicalGridComponent;\n}\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'igx-row-island',\n    template: ``,\n    providers: [IgxRowIslandAPIService]\n})\nexport class IgxRowIslandComponent extends IgxHierarchicalGridBaseDirective\n            implements AfterContentInit, AfterViewInit, OnChanges, OnInit, OnDestroy, DoCheck {\n    /**\n     * Sets the key of the row island by which child data would be taken from the row data if such is provided.\n     * ```html\n     * <igx-hierarchical-grid [data]=\"Data\" [autoGenerate]=\"true\">\n     *      <igx-row-island [key]=\"'childData'\">\n     *          <!-- ... -->\n     *      </igx-row-island>\n     * </igx-hierarchical-grid>\n     * ```\n     * @memberof IgxRowIslandComponent\n     */\n    @Input()\n    public key: string;\n\n    /**\n     * Sets if all immediate children of the grids for this `IgxRowIslandComponent` should be expanded/collapsed.\n     * ```html\n     * <igx-hierarchical-grid [data]=\"Data\" [autoGenerate]=\"true\">\n     *      <igx-row-island [key]=\"'childData'\" [expandChildren]=\"true\" #rowIsland>\n     *          <!-- ... -->\n     *      </igx-row-island>\n     * </igx-hierarchical-grid>\n     * ```\n     * @memberof IgxRowIslandComponent\n     */\n    @Input()\n    set expandChildren(value: boolean) {\n        this._expandChildren = value;\n        this.rowIslandAPI.getChildGrids().forEach((grid) => {\n            if (document.body.contains(grid.nativeElement)) {\n                // Detect changes right away if the grid is visible\n                grid.expandChildren = value;\n                grid.markForCheck();\n            } else {\n                // Else defer the detection on changes when the grid gets into view for performance.\n                grid.updateOnRender = true;\n            }\n        });\n    }\n\n    /**\n     * Gets if all immediate children of the grids for this `IgxRowIslandComponent` have been set to be expanded/collapsed.\n     * ```typescript\n     * const expanded = this.rowIsland.expandChildren;\n     * ```\n     * @memberof IgxRowIslandComponent\n     */\n    get expandChildren(): boolean {\n        return this._expandChildren;\n    }\n\n    /**\n     * @hidden\n     */\n    @ContentChildren(IgxRowIslandComponent, { read: IgxRowIslandComponent, descendants: false })\n    public children = new QueryList<IgxRowIslandComponent>();\n\n    /**\n     * @hidden\n     */\n    @ContentChildren(IgxColumnComponent, { read: IgxColumnComponent, descendants: false })\n    public childColumns = new QueryList<IgxColumnComponent>();\n\n    /**\n     * @hidden\n     */\n    @Output()\n    public onLayoutChange = new EventEmitter<any>();\n\n    /**\n     * Event emmited when a grid is being created based on this row island.\n     * ```html\n     * <igx-hierarchical-grid [data]=\"Data\" [autoGenerate]=\"true\">\n     *      <igx-row-island [key]=\"'childData'\" (onGridCreated)=\"gridCreated($event)\" #rowIsland>\n     *          <!-- ... -->\n     *      </igx-row-island>\n     * </igx-hierarchical-grid>\n     * ```\n     * @memberof IgxRowIslandComponent\n     */\n    @Output()\n    public onGridCreated = new EventEmitter<IGridCreatedEventArgs>();\n\n    /**\n     * @hidden\n     */\n    get id() {\n        const pId = this.parentId ? this.parentId.substring(this.parentId.indexOf(this.layout_id) + this.layout_id.length) + '-' : '';\n        return this.layout_id + pId +  this.key;\n    }\n\n    /**\n     * @hidden\n     */\n    get parentId() {\n       return this.parentIsland ? this.parentIsland.id : null;\n    }\n\n    /**\n     * @hidden\n     */\n    get level() {\n        let ptr = this.parentIsland;\n        let lvl = 0;\n        while (ptr) {\n            lvl++;\n            ptr = ptr.parentIsland;\n        }\n        return lvl + 1;\n    }\n\n    /**\n     * @hidden\n     */\n    public initialChanges = [];\n\n    /**\n     * @hidden\n     */\n    public rootGrid = null;\n    readonly data: any[];\n    readonly filteredData: any[];\n    private layout_id = `igx-row-island-`;\n    private isInit = false;\n\n    constructor(\n        public selectionService: IgxGridSelectionService,\n        crudService: IgxGridCRUDService,\n        public colResizingService: IgxColumnResizingService,\n        gridAPI: GridBaseAPIService<IgxGridBaseDirective & GridType>,\n        @Inject(IgxGridTransaction) protected transactionFactory: any,\n        elementRef: ElementRef,\n        zone: NgZone,\n        @Inject(DOCUMENT) public document,\n        cdr: ChangeDetectorRef,\n        resolver: ComponentFactoryResolver,\n        differs: IterableDiffers,\n        viewRef: ViewContainerRef,\n        navigation: IgxHierarchicalGridNavigationService,\n        filteringService: IgxFilteringService,\n        @Inject(IgxOverlayService) protected overlayService: IgxOverlayService,\n        public summaryService: IgxGridSummaryService,\n        @Optional() @Inject(DisplayDensityToken) protected _displayDensityOptions: IDisplayDensityOptions,\n        public rowIslandAPI: IgxRowIslandAPIService) {\n        super(\n            selectionService,\n            crudService,\n            colResizingService,\n            gridAPI,\n            typeof transactionFactory === 'function' ? transactionFactory() : transactionFactory,\n            elementRef,\n            zone,\n            document,\n            cdr,\n            resolver,\n            differs,\n            viewRef,\n            navigation,\n            filteringService,\n            overlayService,\n            summaryService,\n            _displayDensityOptions\n        );\n        this.hgridAPI = <IgxHierarchicalGridAPIService>gridAPI;\n    }\n\n    /**\n     * @hidden\n     */\n    ngOnInit() {\n        this.rootGrid = this.hgridAPI.grid;\n        this.rowIslandAPI.rowIsland = this;\n    }\n\n    /**\n     * @hidden\n     */\n    ngDoCheck() {\n    }\n\n    /**\n     * @hidden\n     */\n    ngAfterContentInit() {\n        this.updateChildren();\n        this.children.notifyOnChanges();\n        this.children.changes.pipe(takeUntil(this.destroy$))\n        .subscribe((change) => {\n            this.updateChildren();\n            // update existing grids since their child ri have been changed.\n            this.getGridsForIsland(this.key).forEach(grid => {\n                (grid as any).onRowIslandChange(this.children);\n            });\n        });\n        const nestedColumns = this.children.map((layout) => layout.columnList.toArray());\n        const colsArray = [].concat.apply([], nestedColumns);\n        const topCols = this.columnList.filter((item) => {\n            return colsArray.indexOf(item) === -1;\n        });\n        this.childColumns.reset(topCols);\n        this.columnList.changes.pipe(takeUntil(this.destroy$)).subscribe(() => { this.updateColumnList(); });\n    }\n\n    protected updateChildren() {\n        if (this.children.first === this) {\n            this.children.reset(this.children.toArray().slice(1));\n        }\n        this.children.forEach(child => {\n            child.parentIsland = this;\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    ngAfterViewInit() {\n        this.rowIslandAPI.register(this);\n        if (this.parentIsland) {\n            this.parentIsland.rowIslandAPI.registerChildRowIsland(this);\n        } else {\n            this.rootGrid.hgridAPI.registerChildRowIsland(this);\n        }\n        this._init = false;\n    }\n\n    /**\n     * @hidden\n     */\n    ngOnChanges(changes) {\n        this.onLayoutChange.emit(changes);\n        if (!this.isInit) {\n            this.initialChanges.push(changes);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    ngOnDestroy() {\n        // Override the base destroy because we don't have rendered anything to use removeEventListener on\n        this.destroy$.next(true);\n        this.destroy$.complete();\n        this._destroyed = true;\n        this.rowIslandAPI.unset(this.id);\n        if (this.parentIsland) {\n            this.getGridsForIsland(this.key).forEach(grid => {\n                this.cleanGridState(grid);\n                grid.hgridAPI.unsetChildRowIsland(this);\n            });\n            this.parentIsland.rowIslandAPI.unsetChildRowIsland(this);\n        } else {\n            this.rootGrid.hgridAPI.unsetChildRowIsland(this);\n            this.cleanGridState(this.rootGrid);\n        }\n    }\n\n    private cleanGridState(grid) {\n        grid.childGridTemplates.forEach((tmpl) => {\n            tmpl.owner.cleanView(tmpl.context.templateID);\n        });\n        grid.childGridTemplates.clear();\n        grid.onRowIslandChange();\n    }\n\n    /**\n     * @hidden\n     */\n    reflow() {}\n\n    /**\n     * @hidden\n     */\n    calculateGridHeight() {}\n\n    protected updateColumnList() {\n        const nestedColumns = this.children.map((layout) => layout.columnList.toArray());\n        const colsArray = [].concat.apply([], nestedColumns);\n        const topCols = this.columnList.filter((item) => {\n            if (colsArray.indexOf(item) === -1) {\n                /* Reset the default width of the columns that come into this row island,\n                because the root catches them first during the detectChanges() and sets their defaultWidth. */\n                item.defaultWidth = undefined;\n                return true;\n            }\n            return false;\n        });\n        this.childColumns.reset(topCols);\n\n        if (this.parentIsland) {\n            this.parentIsland.columnList.notifyOnChanges();\n        } else {\n            this.rootGrid.columnList.notifyOnChanges();\n        }\n\n        this.rowIslandAPI.getChildGrids().forEach((grid: IgxHierarchicalGridComponent) => {\n            grid.createColumnsList(this.childColumns.toArray());\n            if (!document.body.contains(grid.nativeElement)) {\n                grid.updateOnRender = true;\n            }\n        });\n    }\n}\n"]}