UNPKG

@catull/igniteui-angular

Version:

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

122 lines 17.5 kB
import { __decorate, __extends, __metadata, __param, __read, __spread } from "tslib"; import { Component, ChangeDetectorRef, ElementRef, ViewChild, Inject, ChangeDetectionStrategy, NgZone, OnInit, Input, TemplateRef } from '@angular/core'; import { IgxGridCellComponent } from '../cell.component'; import { GridBaseAPIService } from '../api.service'; import { getNodeSizeViaRange, PlatformUtil } from '../../core/utils'; import { DOCUMENT } from '@angular/common'; import { IgxGridSelectionService, IgxGridCRUDService } from '../selection/selection.service'; import { HammerGesturesManager } from '../../core/touch'; var IgxGridExpandableCellComponent = /** @class */ (function (_super) { __extends(IgxGridExpandableCellComponent, _super); function IgxGridExpandableCellComponent(selectionService, crudService, gridAPI, cdr, element, zone, touchManager, document, platformUtil) { var _this = _super.call(this, selectionService, crudService, gridAPI, cdr, element, zone, touchManager, platformUtil) || this; _this.zone = zone; _this.document = document; _this.platformUtil = platformUtil; /** * @hidden */ _this.expanded = false; return _this; } /** * @hidden */ IgxGridExpandableCellComponent.prototype.toggle = function (event) { event.stopPropagation(); var expandedStates = this.grid.expansionStates; expandedStates.set(this.row.rowID, !this.row.expanded); this.grid.expansionStates = expandedStates; if (this.grid.rowEditable) { this.grid.endEdit(true); } }; /** * @hidden */ IgxGridExpandableCellComponent.prototype.onIndicatorFocus = function () { this.gridAPI.submit_value(); this.nativeElement.focus(); }; /** * @hidden */ IgxGridExpandableCellComponent.prototype.calculateSizeToFit = function (range) { var indicatorWidth = this.indicator.nativeElement.getBoundingClientRect().width; var indicatorStyle = this.document.defaultView.getComputedStyle(this.indicator.nativeElement); var indicatorMargin = parseFloat(indicatorStyle.marginRight); var leftPadding = 0; if (this.indentationDiv) { var indentationStyle = this.document.defaultView.getComputedStyle(this.indentationDiv.nativeElement); leftPadding = parseFloat(indentationStyle.paddingLeft); } var largestWidth = Math.max.apply(Math, __spread(Array.from(this.nativeElement.children) .map(function (child) { return getNodeSizeViaRange(range, child); }))); return largestWidth + indicatorWidth + indicatorMargin + leftPadding; }; Object.defineProperty(IgxGridExpandableCellComponent.prototype, "iconTemplate", { /** * @hidden */ get: function () { if (this.expanded) { return this.grid.rowExpandedIndicatorTemplate || this.defaultExpandedTemplate; } else { return this.grid.rowCollapsedIndicatorTemplate || this.defaultCollapsedTemplate; } }, enumerable: true, configurable: true }); IgxGridExpandableCellComponent.ctorParameters = function () { return [ { type: IgxGridSelectionService }, { type: IgxGridCRUDService }, { type: GridBaseAPIService }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: NgZone }, { type: HammerGesturesManager }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }, { type: PlatformUtil } ]; }; __decorate([ Input(), __metadata("design:type", Object) ], IgxGridExpandableCellComponent.prototype, "expanded", void 0); __decorate([ ViewChild('indicator', { read: ElementRef }), __metadata("design:type", ElementRef) ], IgxGridExpandableCellComponent.prototype, "indicator", void 0); __decorate([ ViewChild('indentationDiv', { read: ElementRef }), __metadata("design:type", ElementRef) ], IgxGridExpandableCellComponent.prototype, "indentationDiv", void 0); __decorate([ ViewChild('defaultExpandedTemplate', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxGridExpandableCellComponent.prototype, "defaultExpandedTemplate", void 0); __decorate([ ViewChild('defaultCollapsedTemplate', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxGridExpandableCellComponent.prototype, "defaultCollapsedTemplate", void 0); IgxGridExpandableCellComponent = __decorate([ Component({ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-expandable-grid-cell', template: "<ng-template #defaultCell>\n <div igxTextHighlight style=\"pointer-events: none\" [cssClass]=\"highlightClass\" [activeCssClass]=\"activeHighlightClass\" [groupName]=\"gridID\"\n [value]=\"formatter ? formatter(value) : column.dataType === 'number' ? (value | igxdecimal: grid.locale) : column.dataType === 'date' ? (value | igxdate: grid.locale) : value\"\n [row]=\"rowData\" [column]=\"this.column.field\" [containerClass]=\"'igx-grid__td-text'\"\n class=\"igx-grid__td-text\">{{ formatter ? formatter(value) : column.dataType === 'number' ? (value | igxdecimal:\n grid.locale) : column.dataType === 'date' ? (value | igxdate: grid.locale) : value }}</div>\n</ng-template>\n<ng-template #inlineEditor let-cell=\"cell\">\n <ng-container *ngIf=\"column.dataType === 'string'\">\n <igx-input-group displayDensity=\"compact\">\n <input igxInput [(ngModel)]=\"editValue\" [igxFocus]=\"focused\">\n </igx-input-group>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'number'\">\n <igx-input-group displayDensity=\"compact\">\n <input igxInput [(ngModel)]=\"editValue\" [igxFocus]=\"focused\" type=\"number\">\n </igx-input-group>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'boolean'\">\n <igx-checkbox (change)=\"editValue = $event.checked\" [value]=\"editValue\" [checked]=\"editValue\" [disableRipple]=\"true\"></igx-checkbox>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'date'\">\n <igx-date-picker [style.width.%]=\"100\" [outlet]=\"grid.outletDirective\" mode=\"dropdown\"\n [locale]=\"grid.locale\" [(value)]=\"editValue\" [igxFocus]=\"focused\" [labelVisibility]=\"false\">\n </igx-date-picker>\n </ng-container>\n</ng-template>\n<ng-container *ngIf=\"!editMode\">\n <div #indicator\n class=\"igx-grid__tree-grouping-indicator\"\n (click)=\"toggle($event)\" (focus)=\"onIndicatorFocus()\" tabindex=\"-1\">\n <ng-container *ngTemplateOutlet=\"iconTemplate; context: { $implicit: this }\">\n </ng-container>\n </div>\n</ng-container>\n<ng-container *ngTemplateOutlet=\"template; context: context\">\n</ng-container>\n<ng-template #defaultExpandedTemplate>\n <igx-icon fontSet=\"material\">expand_more</igx-icon>\n</ng-template>\n<ng-template #defaultCollapsedTemplate>\n <igx-icon fontSet=\"material\">chevron_right</igx-icon>\n</ng-template>\n", providers: [HammerGesturesManager] }), __param(7, Inject(DOCUMENT)), __metadata("design:paramtypes", [IgxGridSelectionService, IgxGridCRUDService, GridBaseAPIService, ChangeDetectorRef, ElementRef, NgZone, HammerGesturesManager, Object, PlatformUtil]) ], IgxGridExpandableCellComponent); return IgxGridExpandableCellComponent; }(IgxGridCellComponent)); export { IgxGridExpandableCellComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"expandable-cell.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/grid/expandable-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ChangeDetectorRef, ElementRef, ViewChild, Inject,\n     ChangeDetectionStrategy, NgZone, OnInit, Input, TemplateRef } from '@angular/core';\nimport { IgxGridCellComponent } from '../cell.component';\nimport { GridBaseAPIService } from '../api.service';\nimport { getNodeSizeViaRange, PlatformUtil } from '../../core/utils';\nimport { DOCUMENT } from '@angular/common';\nimport { IgxGridBaseDirective } from '.';\nimport { IgxGridSelectionService, IgxGridCRUDService } from '../selection/selection.service';\nimport { HammerGesturesManager } from '../../core/touch';\nimport { GridType } from '../common/grid.interface';\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    selector: 'igx-expandable-grid-cell',\n    templateUrl: 'expandable-cell.component.html',\n    providers: [HammerGesturesManager]\n})\nexport class IgxGridExpandableCellComponent extends IgxGridCellComponent implements OnInit {\n\n    constructor(\n                selectionService: IgxGridSelectionService,\n                crudService: IgxGridCRUDService,\n                gridAPI: GridBaseAPIService<IgxGridBaseDirective & GridType>,\n                cdr: ChangeDetectorRef,\n                element: ElementRef,\n                protected zone: NgZone,\n                touchManager: HammerGesturesManager,\n                @Inject(DOCUMENT) public document,\n                protected platformUtil: PlatformUtil) {\n        super(selectionService, crudService, gridAPI, cdr, element, zone, touchManager, platformUtil);\n    }\n\n    /**\n     * @hidden\n    */\n    @Input()\n    expanded = false;\n\n    @ViewChild('indicator', { read: ElementRef })\n    public indicator: ElementRef;\n\n    @ViewChild('indentationDiv', { read: ElementRef })\n    public indentationDiv: ElementRef;\n\n    /**\n    * @hidden\n    */\n   @ViewChild('defaultExpandedTemplate', { read: TemplateRef, static: true })\n   protected defaultExpandedTemplate: TemplateRef<any>;\n\n    /**\n    * @hidden\n    */\n   @ViewChild('defaultCollapsedTemplate', { read: TemplateRef, static: true })\n   protected defaultCollapsedTemplate: TemplateRef<any>;\n\n    /**\n     * @hidden\n     */\n    public toggle(event: Event) {\n        event.stopPropagation();\n        const expandedStates = this.grid.expansionStates;\n        expandedStates.set(this.row.rowID, !this.row.expanded);\n        this.grid.expansionStates = expandedStates;\n\n        if (this.grid.rowEditable) {\n            this.grid.endEdit(true);\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public onIndicatorFocus() {\n        this.gridAPI.submit_value();\n        this.nativeElement.focus();\n    }\n\n    /**\n     * @hidden\n     */\n    public calculateSizeToFit(range: any): number {\n        const indicatorWidth = this.indicator.nativeElement.getBoundingClientRect().width;\n        const indicatorStyle = this.document.defaultView.getComputedStyle(this.indicator.nativeElement);\n        const indicatorMargin = parseFloat(indicatorStyle.marginRight);\n        let leftPadding = 0;\n        if (this.indentationDiv) {\n            const indentationStyle = this.document.defaultView.getComputedStyle(this.indentationDiv.nativeElement);\n            leftPadding = parseFloat(indentationStyle.paddingLeft);\n        }\n        const largestWidth = Math.max(...Array.from(this.nativeElement.children)\n            .map((child) => getNodeSizeViaRange(range, child)));\n        return largestWidth + indicatorWidth + indicatorMargin + leftPadding;\n    }\n\n    /**\n     * @hidden\n    */\n    public get iconTemplate() {\n        if (this.expanded) {\n            return this.grid.rowExpandedIndicatorTemplate || this.defaultExpandedTemplate;\n        } else {\n            return this.grid.rowCollapsedIndicatorTemplate || this.defaultCollapsedTemplate;\n        }\n    }\n}\n"]}