UNPKG

igniteui-angular

Version:

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

177 lines • 17.1 kB
/** * @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"]}