UNPKG

@catull/igniteui-angular

Version:

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

328 lines 29.5 kB
var IgxColumnGroupComponent_1; import { __decorate, __metadata } from "tslib"; import { Component, ContentChildren, ChangeDetectionStrategy, Input, forwardRef, QueryList, TemplateRef, Output, EventEmitter } from '@angular/core'; import { IgxColumnComponent } from './column.component'; import { flatten } from '../../core/utils'; let IgxColumnGroupComponent = IgxColumnGroupComponent_1 = class IgxColumnGroupComponent extends IgxColumnComponent { constructor() { super(...arguments); this.children = new QueryList(); /** * Sets/gets whether the column group is `searchable`. * Default value is `true`. * ```typescript * let isSearchable = this.columnGroup.searchable; * ``` * ```html * <igx-column-group [searchable] = "false"></igx-column-group> * ``` * @memberof IgxColumnGroupComponent */ this.searchable = true; /** *@hidden */ this.hiddenChange = new EventEmitter(); // constructor(public gridAPI: GridBaseAPIService<IgxGridBaseDirective & IGridDataBindable>, public cdr: ChangeDetectorRef) { // // D.P. constructor duplication due to es6 compilation, might be obsolete in the future // super(gridAPI, cdr); // } } /** * Set if the column group is collapsible. * Default value is `false` * ```html * <igx-column-group [collapsible] = "true"></igx-column-group> * ``` * @memberof IgxColumnGroupComponent */ set collapsible(value) { this._collapsible = value; this.collapsibleChange.emit(this._collapsible); if (this.children && !this.hidden) { if (this._collapsible) { this.setExpandCollapseState(); } else { this.children.forEach(child => child.hidden = false); } } } get collapsible() { return this._collapsible && this.checkCollapsibleState(); } /** * Set whether the group is expanded or collapsed initially. * Applied only if the collapsible property is set to `true` * Default value is `true` * ```html * const state = false * <igx-column-group [(expand)] = "state"></igx-column-group> * ``` * @memberof IgxColumnGroupComponent */ set expanded(value) { this._expanded = value; this.expandedChange.emit(this._expanded); if (!this.collapsible) { return; } if (!this.hidden && this.children) { this.setExpandCollapseState(); } } get expanded() { return this._expanded; } /** * Gets the column group `summaries`. * ```typescript * let columnGroupSummaries = this.columnGroup.summaries; * ``` * @memberof IgxColumnGroupComponent */ get summaries() { return this._summaries; } /** * Sets the column group `summaries`. * ```typescript * this.columnGroup.summaries = IgxNumberSummaryOperand; * ``` * @memberof IgxColumnGroupComponent */ set summaries(classRef) { } /** * Gets the column group `filters`. * ```typescript * let columnGroupFilters = this.columnGroup.filters; * ``` * @memberof IgxColumnGroupComponent */ get filters() { return this._filters; } /** * Sets the column group `filters`. * ```typescript * this.columnGroup.filters = IgxStringFilteringOperand; * ``` * @memberof IgxColumnGroupComponent */ set filters(classRef) { } /** * Returns a reference to the body template. * ```typescript * let bodyTemplate = this.columnGroup.bodyTemplate; * ``` * @memberof IgxColumnGroupComponent */ get bodyTemplate() { return this._bodyTemplate; } /** * @hidden */ set bodyTemplate(template) { } /** * Allows you to define a custom template for expand/collapse indicator * @memberof IgxColumnGroupComponent */ get collapsibleIndicatorTemplate() { return this._collapseIndicatorTemplate; } set collapsibleIndicatorTemplate(template) { this._collapseIndicatorTemplate = template; } /** * Returns a reference to the inline editor template. * ```typescript * let inlineEditorTemplate = this.columnGroup.inlineEditorTemplate; * ``` * @memberof IgxColumnGroupComponent */ get inlineEditorTemplate() { return this._inlineEditorTemplate; } /** * @hidden */ set inlineEditorTemplate(template) { } /** * Gets the column group cells. * ```typescript * let columnCells = this.columnGroup.cells; * ``` * @memberof IgxColumnGroupComponent */ get cells() { return []; } /** * Gets whether the column group is hidden. * ```typescript * let isHidden = this.columnGroup.hidden; * ``` * @memberof IgxColumnGroupComponent */ get hidden() { return this.allChildren.every(c => c.hidden); } /** * Sets the column group hidden property. * ```html * <igx-column [hidden] = "true"></igx-column> * ``` * * Two-way data binding * ```html * <igx-column [(hidden)] = "model.columns[0].isHidden"></igx-column> * ``` * @memberof IgxColumnGroupComponent */ set hidden(value) { this._hidden = value; this.hiddenChange.emit(this._hidden); if (this._hidden || !this.collapsible) { this.children.forEach(child => child.hidden = this._hidden); } else { this.children.forEach(c => { if (c.visibleWhenCollapsed === undefined) { c.hidden = false; return; } c.hidden = this.expanded ? c.visibleWhenCollapsed : !c.visibleWhenCollapsed; }); } } /** *@hidden */ ngAfterContentInit() { /* @ContentChildren with descendants still returns the `parent` component in the query list. */ if (this.headTemplate && this.headTemplate.length) { this._headerTemplate = this.headTemplate.toArray()[0].template; } if (this.collapseIndicatorTemplate) { this._collapseIndicatorTemplate = this.collapseIndicatorTemplate.template; } // currently only ivy fixes the issue, we have to slice only if the first child is group if (this.children.first === this) { this.children.reset(this.children.toArray().slice(1)); } this.children.forEach(child => { child.parent = this; }); if (this.collapsible) { this.setExpandCollapseState(); } } /** * Returns the children columns collection. * ```typescript * let columns = this.columnGroup.allChildren; * ``` * @memberof IgxColumnGroupComponent */ get allChildren() { return flatten(this.children.toArray()); } /** * Returns a boolean indicating if the column is a `ColumnGroup`. * ```typescript * let isColumnGroup = this.columnGroup.columnGroup * ``` * @memberof IgxColumnGroupComponent */ get columnGroup() { return true; } /** * Returns a boolean indicating if the column is a `ColumnLayout` for multi-row layout. * ```typescript * let columnGroup = this.column.columnGroup; * ``` * @memberof IgxColumnComponent */ get columnLayout() { return false; } /** * Gets the width of the column group. * ```typescript * let columnGroupWidth = this.columnGroup.width; * ``` * @memberof IgxColumnGroupComponent */ get width() { let isChildrenWidthInPercent = false, width; width = `${this.children.reduce((acc, val) => { if (val.hidden) { return acc; } if (typeof val.width === 'string' && val.width.indexOf('%') !== -1) { isChildrenWidthInPercent = true; return acc + parseInt(val.width, 10); } return acc + parseInt(val.calcWidth, 10); }, 0)}`; return isChildrenWidthInPercent ? width + '%' : width + 'px'; } set width(val) { } }; __decorate([ ContentChildren(IgxColumnComponent, { read: IgxColumnComponent }), __metadata("design:type", Object) ], IgxColumnGroupComponent.prototype, "children", void 0); __decorate([ Input(), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxColumnGroupComponent.prototype, "collapsible", null); __decorate([ Input(), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxColumnGroupComponent.prototype, "expanded", null); __decorate([ Input(), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxColumnGroupComponent.prototype, "summaries", null); __decorate([ Input(), __metadata("design:type", Object) ], IgxColumnGroupComponent.prototype, "searchable", void 0); __decorate([ Input(), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxColumnGroupComponent.prototype, "filters", null); __decorate([ Input(), __metadata("design:type", TemplateRef), __metadata("design:paramtypes", [TemplateRef]) ], IgxColumnGroupComponent.prototype, "collapsibleIndicatorTemplate", null); __decorate([ Input(), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxColumnGroupComponent.prototype, "hidden", null); __decorate([ Output(), __metadata("design:type", Object) ], IgxColumnGroupComponent.prototype, "hiddenChange", void 0); IgxColumnGroupComponent = IgxColumnGroupComponent_1 = __decorate([ Component({ changeDetection: ChangeDetectionStrategy.OnPush, providers: [{ provide: IgxColumnComponent, useExisting: forwardRef(() => IgxColumnGroupComponent_1) }], selector: 'igx-column-group', template: `` }) ], IgxColumnGroupComponent); export { IgxColumnGroupComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-group.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/columns/column-group.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ContentChildren,\n    ChangeDetectionStrategy,\n    Input,\n    forwardRef,\n    QueryList,\n    TemplateRef,\n    Output,\n    EventEmitter\n} from '@angular/core';\n\nimport { IgxColumnComponent } from './column.component';\nimport { IgxGridCellComponent } from '../cell.component';\nimport { flatten } from '../../core/utils';\n\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: IgxColumnComponent, useExisting: forwardRef(() => IgxColumnGroupComponent) }],\n    selector: 'igx-column-group',\n    template: ``\n})\nexport class IgxColumnGroupComponent extends IgxColumnComponent implements AfterContentInit {\n\n    @ContentChildren(IgxColumnComponent, { read: IgxColumnComponent })\n    children = new QueryList<IgxColumnComponent>();\n\n    /**\n     * Set if the column group is collapsible.\n     * Default value is `false`\n     * ```html\n     *  <igx-column-group [collapsible] = \"true\"></igx-column-group>\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public set collapsible(value: boolean) {\n        this._collapsible = value;\n        this.collapsibleChange.emit(this._collapsible);\n        if (this.children && !this.hidden) {\n            if (this._collapsible) {\n                this.setExpandCollapseState();\n            } else {\n                this.children.forEach(child => child.hidden = false);\n            }\n        }\n    }\n    public get collapsible() {\n        return this._collapsible && this.checkCollapsibleState();\n    }\n\n    /**\n     * Set whether the group is expanded or collapsed initially.\n     * Applied only if the collapsible property is set to `true`\n     * Default value is `true`\n     * ```html\n     *  const state = false\n     *  <igx-column-group [(expand)] = \"state\"></igx-column-group>\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public set expanded(value: boolean) {\n        this._expanded = value;\n        this.expandedChange.emit(this._expanded);\n        if (!this.collapsible) { return; }\n        if (!this.hidden && this.children) {\n            this.setExpandCollapseState();\n        }\n    }\n    public get expanded() {\n        return this._expanded;\n    }\n\n    /**\n     * Gets the column group `summaries`.\n     * ```typescript\n     * let columnGroupSummaries = this.columnGroup.summaries;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public get summaries(): any {\n        return this._summaries;\n    }\n    /**\n     * Sets the column group `summaries`.\n     * ```typescript\n     * this.columnGroup.summaries = IgxNumberSummaryOperand;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    public set summaries(classRef: any) { }\n    /**\n     * Sets/gets whether the column group is `searchable`.\n     * Default value is `true`.\n     * ```typescript\n     * let isSearchable =  this.columnGroup.searchable;\n     * ```\n     * ```html\n     *  <igx-column-group [searchable] = \"false\"></igx-column-group>\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public searchable = true;\n    /**\n     * Gets the column group `filters`.\n     * ```typescript\n     * let columnGroupFilters = this.columnGroup.filters;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public get filters(): any {\n        return this._filters;\n    }\n    /**\n     * Sets the column group `filters`.\n     * ```typescript\n     * this.columnGroup.filters = IgxStringFilteringOperand;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    public set filters(classRef: any) { }\n\n    /**\n     * Returns a reference to the body template.\n     * ```typescript\n     * let bodyTemplate = this.columnGroup.bodyTemplate;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    get bodyTemplate(): TemplateRef<any> {\n        return this._bodyTemplate;\n    }\n    /**\n     * @hidden\n     */\n    set bodyTemplate(template: TemplateRef<any>) { }\n\n    /**\n     * Allows you to define a custom template for expand/collapse indicator\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    get collapsibleIndicatorTemplate(): TemplateRef<any> {\n        return this._collapseIndicatorTemplate;\n    }\n    set collapsibleIndicatorTemplate(template: TemplateRef<any>) {\n        this._collapseIndicatorTemplate = template;\n    }\n\n    /**\n     * Returns a reference to the inline editor template.\n     * ```typescript\n     * let inlineEditorTemplate = this.columnGroup.inlineEditorTemplate;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    get inlineEditorTemplate(): TemplateRef<any> {\n        return this._inlineEditorTemplate;\n    }\n    /**\n     * @hidden\n     */\n    set inlineEditorTemplate(template: TemplateRef<any>) { }\n    /**\n     * Gets the column group cells.\n     * ```typescript\n     * let columnCells = this.columnGroup.cells;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    get cells(): IgxGridCellComponent[] {\n        return [];\n    }\n    /**\n     * Gets whether the column group is hidden.\n     * ```typescript\n     * let isHidden = this.columnGroup.hidden;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    get hidden() {\n        return this.allChildren.every(c => c.hidden);\n    }\n    /**\n     * Sets the column group hidden property.\n     * ```html\n     * <igx-column [hidden] = \"true\"></igx-column>\n     * ```\n     *\n     * Two-way data binding\n     * ```html\n     * <igx-column [(hidden)] = \"model.columns[0].isHidden\"></igx-column>\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    set hidden(value: boolean) {\n        this._hidden = value;\n        this.hiddenChange.emit(this._hidden);\n        if (this._hidden || !this.collapsible) {\n            this.children.forEach(child => child.hidden = this._hidden);\n        } else {\n            this.children.forEach(c =>  {\n                if (c.visibleWhenCollapsed === undefined) {c.hidden = false; return; }\n                c.hidden = this.expanded ? c.visibleWhenCollapsed : !c.visibleWhenCollapsed;\n            });\n        }\n    }\n\n    /**\n     *@hidden\n     */\n    @Output()\n    public hiddenChange = new EventEmitter<boolean>();\n\n    /**\n     *@hidden\n     */\n    ngAfterContentInit() {\n        /*\n            @ContentChildren with descendants still returns the `parent`\n            component in the query list.\n        */\n        if (this.headTemplate && this.headTemplate.length) {\n            this._headerTemplate = this.headTemplate.toArray()[0].template;\n        }\n        if (this.collapseIndicatorTemplate) {\n            this._collapseIndicatorTemplate = this.collapseIndicatorTemplate.template;\n        }\n        // currently only ivy fixes the issue, we have to slice only if the first child is group\n        if (this.children.first === this) {\n            this.children.reset(this.children.toArray().slice(1));\n        }\n        this.children.forEach(child => {\n            child.parent = this;\n        });\n        if (this.collapsible) {\n            this.setExpandCollapseState();\n        }\n    }\n\n    /**\n     * Returns the children columns collection.\n     * ```typescript\n     * let columns =  this.columnGroup.allChildren;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    get allChildren(): IgxColumnComponent[] {\n        return flatten(this.children.toArray());\n    }\n    /**\n     * Returns a boolean indicating if the column is a `ColumnGroup`.\n     * ```typescript\n     * let isColumnGroup =  this.columnGroup.columnGroup\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    get columnGroup() {\n        return true;\n    }\n    /**\n     * Returns a boolean indicating if the column is a `ColumnLayout` for multi-row layout.\n     * ```typescript\n     * let columnGroup =  this.column.columnGroup;\n     * ```\n     * @memberof IgxColumnComponent\n     */\n    get columnLayout() {\n        return false;\n    }\n    /**\n     * Gets the width of the column group.\n     * ```typescript\n     * let columnGroupWidth = this.columnGroup.width;\n     * ```\n     * @memberof IgxColumnGroupComponent\n     */\n    get width() {\n        let isChildrenWidthInPercent = false, width;\n        width = `${this.children.reduce((acc, val) => {\n            if (val.hidden) {\n                return acc;\n            }\n            if (typeof val.width === 'string' && val.width.indexOf('%') !== -1) {\n                isChildrenWidthInPercent = true;\n                return acc + parseInt(val.width, 10);\n            }\n            return acc + parseInt(val.calcWidth, 10);\n        }, 0)}`;\n        return isChildrenWidthInPercent ? width + '%' : width + 'px';\n    }\n\n    set width(val) { }\n\n    // constructor(public gridAPI: GridBaseAPIService<IgxGridBaseDirective & IGridDataBindable>, public cdr: ChangeDetectorRef) {\n    //     // D.P. constructor duplication due to es6 compilation, might be obsolete in the future\n    //     super(gridAPI, cdr);\n    // }\n}\n"]}