igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
177 lines • 17.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { ChangeDetectionStrategy, Component, HostBinding, forwardRef, ElementRef, ChangeDetectorRef, ViewChildren, QueryList, ViewChild } from '@angular/core';
import { IgxRowComponent } from '../row.component';
import { IgxHierarchicalSelectionAPIService } from './selection';
import { GridBaseAPIService } from '.././api.service';
import { IgxHierarchicalGridCellComponent } from './hierarchical-cell.component';
import { IgxGridCRUDService, IgxGridSelectionService } from '../../core/grid-selection';
var IgxHierarchicalRowComponent = /** @class */ (function (_super) {
tslib_1.__extends(IgxHierarchicalRowComponent, _super);
function IgxHierarchicalRowComponent(gridAPI, crudService, selectionService, hselection, element, cdr) {
var _this = _super.call(this, gridAPI, crudService, selectionService, hselection, element, cdr) || this;
_this.gridAPI = gridAPI;
_this.crudService = crudService;
_this.selectionService = selectionService;
_this.hselection = hselection;
_this.element = element;
_this.cdr = cdr;
/**
* @hidden
*/
_this.tabindex = 0;
return _this;
}
Object.defineProperty(IgxHierarchicalRowComponent.prototype, "expanded", {
/**
* Returns whether the row is expanded.
* ```typescript
* const RowExpanded = this.grid1.rowList.first.expanded;
* ```
*/
get: /**
* Returns whether the row is expanded.
* ```typescript
* const RowExpanded = this.grid1.rowList.first.expanded;
* ```
* @return {?}
*/
function () {
return this.grid.isExpanded(this.rowData);
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxHierarchicalRowComponent.prototype, "hasChildren", {
get: /**
* @return {?}
*/
function () {
return !!this.grid.childLayoutKeys.length;
},
enumerable: true,
configurable: true
});
Object.defineProperty(IgxHierarchicalRowComponent.prototype, "highlighted", {
/**
* @hidden
*/
get: /**
* @hidden
* @return {?}
*/
function () {
return this.grid && this.grid.highlightedRowID === this.rowID;
},
enumerable: true,
configurable: true
});
/**
* Toggles the hierarchical row.
* ```typescript
* this.grid1.rowList.first.toggle()
* ```
*/
/**
* Toggles the hierarchical row.
* ```typescript
* this.grid1.rowList.first.toggle()
* ```
* @return {?}
*/
IgxHierarchicalRowComponent.prototype.toggle = /**
* Toggles the hierarchical row.
* ```typescript
* this.grid1.rowList.first.toggle()
* ```
* @return {?}
*/
function () {
var _this = this;
if (this.added) {
return;
}
/** @type {?} */
var grid = this.gridAPI.grid;
/** @type {?} */
var state = this.gridAPI.grid.hierarchicalState;
if (!this.expanded) {
state.push({ rowID: this.rowID });
grid.hierarchicalState = tslib_1.__spread(state);
}
else {
grid.hierarchicalState = state.filter(function (v) {
return v.rowID !== _this.rowID;
});
}
grid.cdr.detectChanges();
requestAnimationFrame(function () {
grid.reflow();
});
};
IgxHierarchicalRowComponent.decorators = [
{ type: Component, args: [{
changeDetection: ChangeDetectionStrategy.OnPush,
preserveWhitespaces: false,
selector: 'igx-hierarchical-grid-row',
template: "<div (click)=\"toggle()\" class=\"igx-grid__hierarchical-expander\" [tabIndex]=\"tabindex\" *ngIf=\"hasChildren\" #expander>\n <igx-icon *ngIf=\"!expanded\" [isActive]='!added' fontSet=\"material\">expand_more</igx-icon>\n <igx-icon *ngIf=\"expanded\" [isActive]='!added' fontSet=\"material\">expand_less</igx-icon>\n</div>\n\n<ng-container *ngIf=\"rowSelectable\">\n <div class=\"igx-grid__cbx-selection\">\n <igx-checkbox [checked]=\"isSelected\" (change)=\"onCheckboxClick($event)\" disableRipple=\"true\" [disableTransitions]=\"grid.disableTransitions\" [aria-label]=\"rowCheckboxAriaLabel\"></igx-checkbox>\n </div>\n</ng-container>\n\n<ng-container *ngIf=\"pinnedColumns.length > 0\">\n <igx-hierarchical-grid-cell *ngFor=\"let col of pinnedColumns | igxNotGrouped\"\n class=\"igx-grid__td igx-grid__td--fw igx-grid__td--pinned\"\n [class.igx-grid__td--number]=\"col.dataType === 'number'\"\n [ngClass]=\"col.cellClasses | igxCellStyles:rowData[col.field]:rowData:col.field\"\n [editMode]=\"col.editable && crudService.isInEditMode(index, col.index)\"\n [column]=\"col\"\n [formatter]=\"col.formatter\"\n [row]=\"this\"\n [lastPinned]=\"col.isLastPinned\"\n [style.min-height.px]=\"grid.rowHeight || 32\"\n [rowData]=\"rowData\"\n [style.min-width.px]=\"col.width\"\n [style.flex-basis.px]=\"col.width\"\n [width]=\"col.getCellWidth()\"\n [visibleColumnIndex]=\"col.visibleIndex\"\n [value]=\"rowData[col.field]\"\n [cellTemplate]=\"col.bodyTemplate\">\n </igx-hierarchical-grid-cell>\n</ng-container>\n\n<ng-template igxGridFor let-col [igxGridForOf]=\"unpinnedColumns | igxNotGrouped\" [igxForScrollContainer]=\"grid.parentVirtDir\" let-colIndex=\"index\" [igxForSizePropName]='\"calcWidth\"' [igxForScrollOrientation]=\"'horizontal'\" [igxForContainerSize]='grid.unpinnedWidth' [igxForTrackBy]='grid.trackColumnChanges' #igxDirRef>\n <igx-hierarchical-grid-cell\n class=\"igx-grid__td igx-grid__td--fw\"\n [class.igx-grid__td--number]=\"col.dataType === 'number'\"\n [ngClass]=\"col.cellClasses | igxCellStyles:rowData[col.field]:rowData:col.field\"\n [editMode]=\"col.editable && crudService.isInEditMode(index, col.index)\"\n [column]=\"col\"\n [formatter]=\"col.formatter\"\n [row]=\"this\"\n [style.min-height.px]=\"grid.rowHeight || 32\"\n [rowData]=\"rowData\"\n [style.min-width.px]=\"col.width\"\n [style.flex-basis.px]=\"col.width\"\n [width]=\"col.getCellWidth()\"\n [visibleColumnIndex]=\"col.visibleIndex\"\n [value]=\"rowData[col.field]\"\n [cellTemplate]=\"col.bodyTemplate\">\n </igx-hierarchical-grid-cell>\n</ng-template>\n\n",
providers: [{ provide: IgxRowComponent, useExisting: forwardRef(function () { return IgxHierarchicalRowComponent; }) }]
}] }
];
/** @nocollapse */
IgxHierarchicalRowComponent.ctorParameters = function () { return [
{ type: GridBaseAPIService },
{ type: IgxGridCRUDService },
{ type: IgxGridSelectionService },
{ type: IgxHierarchicalSelectionAPIService },
{ type: ElementRef },
{ type: ChangeDetectorRef }
]; };
IgxHierarchicalRowComponent.propDecorators = {
cells: [{ type: ViewChildren, args: [forwardRef(function () { return IgxHierarchicalGridCellComponent; }), { read: IgxHierarchicalGridCellComponent },] }],
expander: [{ type: ViewChild, args: ['expander', { read: ElementRef },] }],
tabindex: [{ type: HostBinding, args: ['attr.tabindex',] }],
expanded: [{ type: HostBinding, args: ['class.igx-grid__tr--expanded',] }],
highlighted: [{ type: HostBinding, args: ['class.igx-grid__tr--highlighted',] }]
};
return IgxHierarchicalRowComponent;
}(IgxRowComponent));
export { IgxHierarchicalRowComponent };
if (false) {
/**
* The rendered cells in the row component.
*
* ```typescript
* // get the cells of the third selected row
* let selectedRowCells = this.grid.selectedRows[2].cells;
* ```
* @type {?}
*/
IgxHierarchicalRowComponent.prototype.cells;
/** @type {?} */
IgxHierarchicalRowComponent.prototype.expander;
/**
* @hidden
* @type {?}
*/
IgxHierarchicalRowComponent.prototype.tabindex;
/** @type {?} */
IgxHierarchicalRowComponent.prototype.gridAPI;
/** @type {?} */
IgxHierarchicalRowComponent.prototype.crudService;
/** @type {?} */
IgxHierarchicalRowComponent.prototype.selectionService;
/**
* @type {?}
* @private
*/
IgxHierarchicalRowComponent.prototype.hselection;
/** @type {?} */
IgxHierarchicalRowComponent.prototype.element;
/** @type {?} */
IgxHierarchicalRowComponent.prototype.cdr;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"hierarchical-row.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/hierarchical-grid/hierarchical-row.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    forwardRef,\n    ElementRef,\n    ChangeDetectorRef,\n    ViewChildren,\n    QueryList,\n    ViewChild\n} from '@angular/core';\nimport { IgxHierarchicalGridComponent } from './hierarchical-grid.component';\nimport { IgxRowComponent } from '../row.component';\nimport { IgxHierarchicalSelectionAPIService } from './selection';\nimport { GridBaseAPIService } from '.././api.service';\nimport { IgxHierarchicalGridCellComponent } from './hierarchical-cell.component';\nimport { IgxGridCRUDService, IgxGridSelectionService } from '../../core/grid-selection';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    preserveWhitespaces: false,\n    selector: 'igx-hierarchical-grid-row',\n    templateUrl: './hierarchical-row.component.html',\n    providers: [{ provide: IgxRowComponent, useExisting: forwardRef(() => IgxHierarchicalRowComponent) }]\n})\nexport class IgxHierarchicalRowComponent extends IgxRowComponent<IgxHierarchicalGridComponent> {\n    /**\n     * The rendered cells in the row component.\n     *\n     * ```typescript\n     * // get the cells of the third selected row\n     * let selectedRowCells = this.grid.selectedRows[2].cells;\n     * ```\n     */\n    @ViewChildren(forwardRef(() => IgxHierarchicalGridCellComponent), { read: IgxHierarchicalGridCellComponent })\n    public cells: QueryList<IgxHierarchicalGridCellComponent>;\n\n    @ViewChild('expander', { read: ElementRef })\n    public expander: ElementRef;\n\n    /**\n     * @hidden\n     */\n    @HostBinding('attr.tabindex')\n    public tabindex = 0;\n\n        /**\n     * Returns whether the row is expanded.\n     * ```typescript\n     * const RowExpanded = this.grid1.rowList.first.expanded;\n     * ```\n     */\n    @HostBinding('class.igx-grid__tr--expanded')\n    public get expanded() {\n        return this.grid.isExpanded(this.rowData);\n    }\n\n    public get hasChildren() {\n        return  !!this.grid.childLayoutKeys.length;\n    }\n\n    /**\n     * @hidden\n     */\n    @HostBinding('class.igx-grid__tr--highlighted')\n    public get highlighted() {\n        return this.grid && this.grid.highlightedRowID === this.rowID;\n    }\n\n    /**\n     * Toggles the hierarchical row.\n     * ```typescript\n     * this.grid1.rowList.first.toggle()\n     * ```\n     */\n    public toggle() {\n        if (this.added) {\n            return;\n        }\n        const grid = this.gridAPI.grid;\n        const state = this.gridAPI.grid.hierarchicalState;\n        if (!this.expanded) {\n            state.push({ rowID: this.rowID });\n            grid.hierarchicalState = [...state];\n        } else {\n            grid.hierarchicalState = state.filter(v => {\n                return v.rowID !== this.rowID;\n            });\n        }\n        grid.cdr.detectChanges();\n        requestAnimationFrame(() => {\n            grid.reflow();\n        });\n    }\n\n    constructor(public gridAPI: GridBaseAPIService<IgxHierarchicalGridComponent>,\n        public crudService: IgxGridCRUDService,\n        public selectionService: IgxGridSelectionService,\n        private hselection: IgxHierarchicalSelectionAPIService,\n        public element: ElementRef,\n        public cdr: ChangeDetectorRef) {\n            super(gridAPI, crudService, selectionService, hselection, element, cdr);\n        }\n}\n"]}