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