UNPKG

@catull/igniteui-angular

Version:

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

216 lines 22.4 kB
import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, Input, OnInit, ViewChild, AfterViewInit, SimpleChanges, ComponentFactoryResolver } from '@angular/core'; import { GridBaseAPIService } from '.././api.service'; import { IgxRowIslandComponent } from './row-island.component'; import { IgxGridComponent } from '../grid/grid.component'; import { takeUntil } from 'rxjs/operators'; var IgxChildGridRowComponent = /** @class */ (function () { function IgxChildGridRowComponent(gridAPI, element, resolver, cdr) { this.gridAPI = gridAPI; this.element = element; this.cdr = cdr; /** * Returns whether the row is expanded. * ```typescript * const RowExpanded = this.grid1.rowList.first.expanded; * ``` */ this.expanded = false; /** * The data passed to the row component. * * ```typescript * // get the row data for the first selected row * let selectedRowData = this.grid.selectedRows[0].rowData; * ``` */ this.rowData = []; /** * @hidden */ this.tabindex = 0; /** * @hidden */ this.role = 'row'; this.resolver = resolver; } Object.defineProperty(IgxChildGridRowComponent.prototype, "parentHasScroll", { /** * @hidden */ get: function () { return !this.parentGrid.verticalScrollContainer.dc.instance.notVirtual; }, enumerable: true, configurable: true }); Object.defineProperty(IgxChildGridRowComponent.prototype, "parentGrid", { /** * Get a reference to the grid that contains the selected row. * * ```typescript * handleRowSelection(event) { * // the grid on which the onRowSelectionChange event was triggered * const grid = event.row.grid; * } * ``` * * ```html * <igx-grid * [data]="data" * (onRowSelectionChange)="handleRowSelection($event)"> * </igx-grid> * ``` */ // TODO: Refactor get: function () { return this.gridAPI.grid; }, enumerable: true, configurable: true }); Object.defineProperty(IgxChildGridRowComponent.prototype, "level", { get: function () { return this.layout.level; }, enumerable: true, configurable: true }); Object.defineProperty(IgxChildGridRowComponent.prototype, "nativeElement", { /** * The native DOM element representing the row. Could be null in certain environments. * * ```typescript * // get the nativeElement of the second selected row * let selectedRowNativeElement = this.grid.selectedRows[1].nativeElement; * ``` */ get: function () { return this.element.nativeElement; }, enumerable: true, configurable: true }); /** * @hidden */ IgxChildGridRowComponent.prototype.ngOnInit = function () { var _this = this; this.layout.onLayoutChange.subscribe(function (ch) { _this._handleLayoutChanges(ch); }); var changes = this.layout.initialChanges; changes.forEach(function (change) { _this._handleLayoutChanges(change); }); this.hGrid.parent = this.parentGrid; this.hGrid.parentIsland = this.layout; this.hGrid.childRow = this; // handler logic that re-emits hgrid events on the row island this.setupEventEmitters(); this.layout.onGridCreated.emit({ owner: this.layout, parentID: this.rowData.rowID, grid: this.hGrid }); }; /** * @hidden */ IgxChildGridRowComponent.prototype.ngAfterViewInit = function () { var _this = this; this.hGrid.childLayoutList = this.layout.children; if (this.layout.childColumns.length > 0 && !this.hGrid.autoGenerate) { this.hGrid.createColumnsList(this.layout.childColumns.toArray()); } var layouts = this.hGrid.childLayoutList.toArray(); layouts.forEach(function (l) { return _this.hGrid.hgridAPI.registerChildRowIsland(l); }); this.parentGrid.hgridAPI.registerChildGrid(this.rowData.rowID, this.layout.key, this.hGrid); this.layout.rowIslandAPI.registerChildGrid(this.rowData.rowID, this.hGrid); this.hGrid.cdr.detectChanges(); }; IgxChildGridRowComponent.prototype.setupEventEmitters = function () { var _this = this; var destructor = takeUntil(this.hGrid.destroy$); var factory = this.resolver.resolveComponentFactory(IgxGridComponent); // exclude outputs related to two-way binding functionality var inputNames = factory.inputs.map(function (input) { return input.propName; }); var outputs = factory.outputs.filter(function (o) { var matchingInputPropName = o.propName.slice(0, o.propName.indexOf('Change')); return inputNames.indexOf(matchingInputPropName) === -1; }); outputs.forEach(function (output) { if (_this.hGrid[output.propName]) { _this.hGrid[output.propName].pipe(destructor).subscribe(function (args) { if (!args) { args = {}; } args.owner = _this.hGrid; _this.layout[output.propName].emit(args); }); } }); }; IgxChildGridRowComponent.prototype._handleLayoutChanges = function (changes) { for (var change in changes) { if (changes.hasOwnProperty(change)) { this.hGrid[change] = changes[change].currentValue; } } }; IgxChildGridRowComponent.ctorParameters = function () { return [ { type: GridBaseAPIService }, { type: ElementRef }, { type: ComponentFactoryResolver }, { type: ChangeDetectorRef } ]; }; __decorate([ Input(), __metadata("design:type", IgxRowIslandComponent) ], IgxChildGridRowComponent.prototype, "layout", void 0); __decorate([ Input(), __metadata("design:type", String) ], IgxChildGridRowComponent.prototype, "parentGridID", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxChildGridRowComponent.prototype, "rowData", void 0); __decorate([ Input(), __metadata("design:type", Number) ], IgxChildGridRowComponent.prototype, "index", void 0); __decorate([ ViewChild('hgrid', { static: true }), __metadata("design:type", Object) ], IgxChildGridRowComponent.prototype, "hGrid", void 0); __decorate([ HostBinding('attr.tabindex'), __metadata("design:type", Object) ], IgxChildGridRowComponent.prototype, "tabindex", void 0); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxChildGridRowComponent.prototype, "role", void 0); __decorate([ HostBinding('attr.data-level'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxChildGridRowComponent.prototype, "level", null); IgxChildGridRowComponent = __decorate([ Component({ changeDetection: ChangeDetectionStrategy.OnPush, preserveWhitespaces: false, selector: 'igx-child-grid-row', template: "<div class=\"igx-grid__hierarchical-indent\" [ngClass]=\"{'igx-grid__hierarchical-indent--scroll': parentHasScroll}\">\n <igx-hierarchical-grid #hgrid [data]='rowData.childGridsData[layout.key]'></igx-hierarchical-grid>\n</div>\n" }), __metadata("design:paramtypes", [GridBaseAPIService, ElementRef, ComponentFactoryResolver, ChangeDetectorRef]) ], IgxChildGridRowComponent); return IgxChildGridRowComponent; }()); export { IgxChildGridRowComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"child-grid-row.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/hierarchical-grid/child-grid-row.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    HostBinding,\n    Input,\n    OnInit,\n    ViewChild,\n    AfterViewInit,\n    SimpleChanges,\n    ComponentFactoryResolver\n} from '@angular/core';\nimport { GridBaseAPIService } from '.././api.service';\nimport { IgxRowIslandComponent } from './row-island.component';\nimport { IgxGridComponent } from '../grid/grid.component';\nimport { takeUntil } from 'rxjs/operators';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-child-grid-row',\n    templateUrl: './child-grid-row.component.html'\n})\nexport class IgxChildGridRowComponent implements AfterViewInit, OnInit {\nprivate resolver;\n\n    /**\n * Returns whether the row is expanded.\n * ```typescript\n * const RowExpanded = this.grid1.rowList.first.expanded;\n * ```\n */\n    public expanded = false;\n\n    @Input()\n    layout: IgxRowIslandComponent;\n\n    /**\n     * @hidden\n     */\n    public get parentHasScroll() {\n        return !this.parentGrid.verticalScrollContainer.dc.instance.notVirtual;\n    }\n\n\n    /**\n    * @hidden\n    */\n    @Input()\n    public parentGridID: string;\n\n    /**\n     *  The data passed to the row component.\n     *\n     * ```typescript\n     * // get the row data for the first selected row\n     * let selectedRowData = this.grid.selectedRows[0].rowData;\n     * ```\n     */\n    @Input()\n    public rowData: any = [];\n\n    /**\n     * The index of the row.\n     *\n     * ```typescript\n     * // get the index of the second selected row\n     * let selectedRowIndex = this.grid.selectedRows[1].index;\n     * ```\n     */\n    @Input()\n    public index: number;\n\n    @ViewChild('hgrid', { static: true })\n    private hGrid: any/* TODO: IgxHierarchicalGridComponent*/;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.role')\n    public role = 'row';\n\n    /**\n     * Get a reference to the grid that contains the selected row.\n     *\n     * ```typescript\n     * handleRowSelection(event) {\n     *  // the grid on which the onRowSelectionChange event was triggered\n     *  const grid = event.row.grid;\n     * }\n     * ```\n     *\n     * ```html\n     *  <igx-grid\n     *    [data]=\"data\"\n     *    (onRowSelectionChange)=\"handleRowSelection($event)\">\n     *  </igx-grid>\n     * ```\n     */\n    // TODO: Refactor\n    get parentGrid(): any/* TODO: IgxHierarchicalGridComponent*/ {\n        return this.gridAPI.grid;\n    }\n\n    @HostBinding('attr.data-level')\n    get level() {\n        return this.layout.level;\n    }\n\n    /**\n     * The native DOM element representing the row. Could be null in certain environments.\n     *\n     * ```typescript\n     * // get the nativeElement of the second selected row\n     * let selectedRowNativeElement = this.grid.selectedRows[1].nativeElement;\n     * ```\n     */\n    get nativeElement() {\n        return this.element.nativeElement;\n    }\n\n    constructor(public gridAPI: GridBaseAPIService<any/* TODO: IgxHierarchicalGridComponent*/>,\n        public element: ElementRef,\n        resolver: ComponentFactoryResolver,\n        public cdr: ChangeDetectorRef) {\n            this.resolver = resolver;\n    }\n\n    /**\n     * @hidden\n     */\n    ngOnInit() {\n        this.layout.onLayoutChange.subscribe((ch) => {\n            this._handleLayoutChanges(ch);\n        });\n        const changes = this.layout.initialChanges;\n        changes.forEach(change => {\n            this._handleLayoutChanges(change);\n        });\n        this.hGrid.parent = this.parentGrid;\n        this.hGrid.parentIsland = this.layout;\n        this.hGrid.childRow =  this;\n        // handler logic that re-emits hgrid events on the row island\n        this.setupEventEmitters();\n        this.layout.onGridCreated.emit({\n            owner: this.layout,\n            parentID: this.rowData.rowID,\n            grid: this.hGrid\n        });\n    }\n\n    /**\n     * @hidden\n     */\n    ngAfterViewInit() {\n        this.hGrid.childLayoutList = this.layout.children;\n        if (this.layout.childColumns.length > 0 && !this.hGrid.autoGenerate) {\n            this.hGrid.createColumnsList(this.layout.childColumns.toArray());\n        }\n        const layouts = this.hGrid.childLayoutList.toArray();\n        layouts.forEach((l) => this.hGrid.hgridAPI.registerChildRowIsland(l));\n        this.parentGrid.hgridAPI.registerChildGrid(this.rowData.rowID, this.layout.key, this.hGrid);\n        this.layout.rowIslandAPI.registerChildGrid(this.rowData.rowID, this.hGrid);\n\n        this.hGrid.cdr.detectChanges();\n    }\n\n    private setupEventEmitters() {\n        const destructor = takeUntil(this.hGrid.destroy$);\n\n        const factory = this.resolver.resolveComponentFactory(IgxGridComponent);\n        // exclude outputs related to two-way binding functionality\n        const inputNames = factory.inputs.map(input => input.propName);\n        const outputs = factory.outputs.filter(o => {\n            const matchingInputPropName = o.propName.slice(0, o.propName.indexOf('Change'));\n            return inputNames.indexOf(matchingInputPropName) === -1;\n        });\n        outputs.forEach(output => {\n            if (this.hGrid[output.propName]) {\n                this.hGrid[output.propName].pipe(destructor).subscribe((args) => {\n                    if (!args) {\n                        args = {};\n                    }\n                    args.owner = this.hGrid;\n                    this.layout[output.propName].emit(args);\n                });\n            }\n        });\n    }\n\n\n    private _handleLayoutChanges(changes: SimpleChanges) {\n        for (const change in changes) {\n            if (changes.hasOwnProperty(change)) {\n                this.hGrid[change] = changes[change].currentValue;\n            }\n        }\n    }\n}\n"]}