@catull/igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
216 lines • 22.4 kB
JavaScript
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"]}