igniteui-angular 17.2.18 → 17.2.19

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -245,6 +245,9 @@ export class IgxColumnGroupComponent extends IgxColumnComponent {
245
245
  if (this.pinned) {
246
246
  child.pinned = this.pinned;
247
247
  }
248
+ if (this._hidden) {
249
+ child.hidden = this._hidden;
250
+ }
248
251
  });
249
252
  if (this.collapsible) {
250
253
  this.setExpandCollapseState();
@@ -377,4 +380,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.4", ngImpor
377
380
  type: Input,
378
381
  args: [{ transform: booleanAttribute }]
379
382
  }] } });
380
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-group.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/lib/grids/columns/column-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEH,SAAS,EACT,eAAe,EACf,uBAAuB,EACvB,KAAK,EACL,UAAU,EACV,SAAS,EAET,gBAAgB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,kBAAkB,EAAE,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,OAAO,EAAE,MAAM,kBAAkB,CAAC;;AAW3C,MAAM,OAAO,uBAAwB,SAAQ,kBAAkB;IAP/D;;QAUoB,aAAQ,GAAG,IAAI,SAAS,EAAsB,CAAC;QA0E/D;;;;;;;;;;;WAWG;QAEa,eAAU,GAAG,IAAI,CAAC;KAsRrC;IA3WG;;;;;;;;OAQG;IACH,IACoB,WAAW,CAAC,KAAc;QAC1C,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;QAC1B,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC/C,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE;YAC/B,IAAI,IAAI,CAAC,YAAY,EAAE;gBACnB,IAAI,CAAC,sBAAsB,EAAE,CAAC;aACjC;iBAAM;gBACH,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;aACxD;SACJ;IACL,CAAC;IACD,IAAoB,WAAW;QAC3B,OAAO,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,qBAAqB,EAAE,CAAC;IAC7D,CAAC;IAED;;;;;;;;;;OAUG;IACH,IACoB,QAAQ,CAAC,KAAc;QACvC,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACzC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnB,OAAO;SACV;QACD,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC/B,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;IACL,CAAC;IACD,IAAoB,QAAQ;QACxB,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;;;;;;;OAOG;IACH,IACoB,SAAS;QACzB,OAAO,IAAI,CAAC,UAAU,CAAC;IAC3B,CAAC;IACD;;;;;;;OAOG;IACH,IAAoB,SAAS,CAAC,QAAa,IAAI,CAAC;IAehD;;;;;;;OAOG;IACH,IACoB,OAAO;QACvB,OAAO,IAAI,CAAC,QAAQ,CAAC;IACzB,CAAC;IACD;;;;;;;OAOG;IACH,IAAoB,OAAO,CAAC,QAAa,IAAI,CAAC;IAE9C;;;;;;;OAOG;IACH,IAAoB,UAAU;QAC1B,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAC1E,CAAC;IAED;;OAEG;IACH,IAAoB,UAAU,CAAC,KAAc,IAAI,CAAC;IAElD;;OAEG;IACH,IAAoB,YAAY;QAC5B,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IACD;;OAEG;IACH,IAAoB,YAAY,CAAC,QAA0B,IAAI,CAAC;IAUhE;;OAEG;IACH,IAAoB,oBAAoB;QACpC,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACtC,CAAC;IACD;;OAEG;IACH,IAAoB,oBAAoB,CAAC,QAA0B,IAAI,CAAC;IACxE;;;;;;;OAOG;IACH,IAAoB,KAAK;QACrB,OAAO,EAAE,CAAC;IACd,CAAC;IACD;;;;;;;OAOG;IACH,IACoB,MAAM;QACtB,OAAO,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACjD,CAAC;IACD;;;;;;;;;;;;OAYG;IACH,IAAoB,MAAM,CAAC,KAAc;QACrC,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;QACrB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACrC,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACnC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC;SAC/D;aAAM;YACH,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACtB,IAAI,CAAC,CAAC,oBAAoB,KAAK,SAAS,EAAE;oBACtC,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC;oBAAC,OAAO;iBAC5B;gBACD,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,oBAAoB,CAAC;YAChF,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED;;;;;;;OAOG;IACH,IAAoB,QAAQ;QACxB,MAAM,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,IAAI,CAAC,CAAC,UAAU,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;QACrG,OAAO,kBAAkB,CAAC,MAAM,GAAG,CAAC,IAAI,kBAAkB,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC;IACtF,CAAC;IAED;;;;;;;OAOG;IACH,IAAoB,QAAQ,CAAC,KAAc;QACvC,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACtB,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC;YACvB,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED;;OAEG;IACa,kBAAkB;QAC9B;;;UAGE;QACF,IAAI,IAAI,CAAC,YAAY,IAAI,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE;YAC/C,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;SAClE;QACD,IAAI,IAAI,CAAC,yBAAyB,EAAE;YAChC,IAAI,CAAC,4BAA4B,GAAG,IAAI,CAAC,yBAAyB,CAAC,QAAQ,CAAC;SAC/E;QACD,wFAAwF;QACxF,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,KAAK,IAAI,EAAE;YAC9B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;SACzD;QACD,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAC1B,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC;YACpB,IAAI,IAAI,CAAC,MAAM,EAAE;gBACb,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;aAC9B;QACL,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;QAED,IAAI,CAAC,QAAQ,CAAC,OAAO;aAChB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC9B,SAAS,CAAC,CAAC,MAAqC,EAAE,EAAE;YACjD,IAAI,mBAAmB,GAAG,KAAK,CAAC;YAChC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACf,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;gBAChB,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,KAAK,IAAI,CAAC,MAAM,EAAE;oBACzC,mBAAmB,GAAG,IAAI,CAAC;oBAC3B,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;iBAC1B;YACL,CAAC,CAAC,CAAC;YACH,IAAI,IAAI,CAAC,WAAW,EAAE;gBAClB,IAAI,CAAC,sBAAsB,EAAE,CAAC;aACjC;YACD,IAAI,mBAAmB,EAAE;gBACpB,IAAI,CAAC,IAAY,CAAC,WAAW,EAAE,CAAC;aACpC;QACL,CAAC,CAAC,CAAC;IAEX,CAAC;IAED,yBAAyB;IACzB,IAAoB,WAAW;QAC3B,OAAO,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,CAAC,CAAC;IAC5C,CAAC;IACD;;;;;;;OAOG;IACH,IAAoB,WAAW;QAC3B,OAAO,IAAI,CAAC;IAChB,CAAC;IACD;;;;;;;OAOG;IACH,IAAoB,YAAY;QAC5B,OAAO,KAAK,CAAC;IACjB,CAAC;IACD;;;;;;;OAOG;IACH,IAAoB,KAAK;QACrB,MAAM,KAAK,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC/C,IAAI,GAAG,CAAC,MAAM,EAAE;gBACZ,OAAO,GAAG,CAAC;aACd;YACD,OAAO,GAAG,GAAG,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QAC7C,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QACR,OAAO,KAAK,GAAG,IAAI,CAAC;IACxB,CAAC;IAED,IAAoB,KAAK,CAAC,GAAG,IAAI,CAAC;IAElC,yBAAyB;IACzB,IAAoB,aAAa;QAC7B,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IAED;;OAEG;IACH,IAAoB,oBAAoB;QACpC,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACtC,CAAC;IAED;;OAEG;IACH,IAAoB,oBAAoB,CAAC,KAAc;QACnD,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;YACnC,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACtB,CAAC,CAAC,oBAAoB,GAAG,KAAK,CAAC;YACnC,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED;;;OAGG;IACa,YAAY;QACxB,MAAM,eAAe,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC;QAC1E,MAAM,EAAE,GAAG,eAAe,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;QAC3C,MAAM,EAAE,GAAG,eAAe,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,YAAY,CAAC;QACpE,OAAO,EAAE,GAAG,EAAE,GAAG,CAAC,CAAC;IACvB,CAAC;8GA/WQ,uBAAuB;kGAAvB,uBAAuB,0GAcZ,gBAAgB,sCA2BhB,gBAAgB,oEAgDhB,gBAAgB,kHAyFhB,gBAAgB,gBAvLzB,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,uBAAuB,CAAC,EAAE,CAAC,mDAOnF,kBAAkB,QAAU,kBAAkB,oDALrD,EAAE;;2FAGH,uBAAuB;kBAPnC,SAAS;mBAAC;oBACP,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,wBAAwB,CAAC,EAAE,CAAC;oBACpG,QAAQ,EAAE,kBAAkB;oBAC5B,QAAQ,EAAE,EAAE;oBACZ,UAAU,EAAE,IAAI;iBACnB;8BAImB,QAAQ;sBADvB,eAAe;uBAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,kBAAkB,EAAE;gBAa7C,WAAW;sBAD9B,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBA4BlB,QAAQ;sBAD3B,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAwBlB,SAAS;sBAD5B,KAAK;gBA0BU,UAAU;sBADzB,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAWlB,OAAO;sBAD1B,KAAK;gBAgDU,4BAA4B;sBAD3C,KAAK;gBAiCc,MAAM;sBADzB,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE","sourcesContent":["import {\n    AfterContentInit,\n    Component,\n    ContentChildren,\n    ChangeDetectionStrategy,\n    Input,\n    forwardRef,\n    QueryList,\n    TemplateRef,\n    booleanAttribute\n} from '@angular/core';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { IgxColumnComponent } from './column.component';\nimport { flatten } from '../../core/utils';\nimport { CellType, IgxColumnTemplateContext } from '../common/grid.interface';\n\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: IgxColumnComponent, useExisting: forwardRef(() => IgxColumnGroupComponent) }],\n    selector: 'igx-column-group',\n    template: ``,\n    standalone: true\n})\nexport class IgxColumnGroupComponent extends IgxColumnComponent implements AfterContentInit {\n\n    @ContentChildren(IgxColumnComponent, { read: IgxColumnComponent })\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override 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 override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override set expanded(value: boolean) {\n        this._expanded = value;\n        this.expandedChange.emit(this._expanded);\n        if (!this.collapsible) {\n            return;\n        }\n        if (!this.hidden && this.children) {\n            this.setExpandCollapseState();\n        }\n    }\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public override get summaries(): any {\n        return this._summaries;\n    }\n    /**\n     * Sets the column group `summaries`.\n     * ```typescript\n     * this.columnGroup.summaries = IgxNumberSummaryOperand;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override searchable = true;\n    /**\n     * Gets the column group `filters`.\n     * ```typescript\n     * let columnGroupFilters = this.columnGroup.filters;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public override get filters(): any {\n        return this._filters;\n    }\n    /**\n     * Sets the column group `filters`.\n     * ```typescript\n     * this.columnGroup.filters = IgxStringFilteringOperand;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override set filters(classRef: any) { }\n\n    /**\n     * Returns if the column group is selectable\n     * ```typescript\n     * let columnGroupSelectable = this.columnGroup.selectable;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get selectable(): boolean {\n        return this.children && this.children.some(child => child.selectable);\n    }\n\n    /**\n     * @hidden\n     */\n    public override set selectable(value: boolean) { }\n\n    /**\n     * @hidden\n     */\n    public override get bodyTemplate(): TemplateRef<any> {\n        return this._bodyTemplate;\n    }\n    /**\n     * @hidden\n     */\n    public override set bodyTemplate(template: TemplateRef<any>) { }\n\n    /**\n     * Allows you to define a custom template for expand/collapse indicator\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public override collapsibleIndicatorTemplate: TemplateRef<IgxColumnTemplateContext>;\n\n    /**\n     * @hidden\n     */\n    public override get inlineEditorTemplate(): TemplateRef<any> {\n        return this._inlineEditorTemplate;\n    }\n    /**\n     * @hidden\n     */\n    public override set inlineEditorTemplate(template: TemplateRef<any>) { }\n    /**\n     * Will return empty array. Use this.children.toArray()[index].cells to get the cells for a column that is part of the column group.\n     * ```typescript\n     * let columnCells = this.columnGroup.cells;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get cells(): CellType[] {\n        return [];\n    }\n    /**\n     * Gets whether the column group is hidden.\n     * ```typescript\n     * let isHidden = this.columnGroup.hidden;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override 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) {\n                    c.hidden = false; return;\n                }\n                c.hidden = this.expanded ? c.visibleWhenCollapsed : !c.visibleWhenCollapsed;\n            });\n        }\n    }\n\n    /**\n     * Returns if the column group is selected.\n     * ```typescript\n     * let isSelected = this.columnGroup.selected;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get selected(): boolean {\n        const selectableChildren = this.allChildren.filter(c => !c.columnGroup && c.selectable && !c.hidden);\n        return selectableChildren.length > 0 && selectableChildren.every(c => c.selected);\n    }\n\n    /**\n     * Select/deselect the column group.\n     * ```typescript\n     * this.columnGroup.selected = true;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override set selected(value: boolean) {\n        if (this.selectable) {\n            this.children.forEach(c => {\n                c.selected = value;\n            });\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override 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.collapsibleIndicatorTemplate = 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            if (this.pinned) {\n                child.pinned = this.pinned;\n            }\n        });\n        if (this.collapsible) {\n            this.setExpandCollapseState();\n        }\n\n        this.children.changes\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((change: QueryList<IgxColumnComponent>) => {\n                let shouldReinitPinning = false;\n                change.forEach(x => {\n                    x.parent = this;\n                    if (this.pinned && x.pinned !== this.pinned) {\n                        shouldReinitPinning = true;\n                        x.pinned = this.pinned;\n                    }\n                });\n                if (this.collapsible) {\n                    this.setExpandCollapseState();\n                }\n                if (shouldReinitPinning) {\n                    (this.grid as any).initPinning();\n                }\n            });\n\n    }\n\n    /** @hidden @internal **/\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override 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     *\n     * @memberof IgxColumnComponent\n     */\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get width() {\n        const width = `${this.children.reduce((acc, val) => {\n            if (val.hidden) {\n                return acc;\n            }\n            return acc + parseInt(val.calcWidth, 10);\n        }, 0)}`;\n        return width + 'px';\n    }\n\n    public override set width(val) { }\n\n    /** @hidden @internal **/\n    public override get resolvedWidth() {\n        return this.width;\n    }\n\n    /**\n     * @hidden\n     */\n    public override get applySelectableClass(): boolean {\n        return this._applySelectableClass;\n    }\n\n    /**\n     * @hidden\n     */\n    public override set applySelectableClass(value: boolean) {\n        if (this.selectable) {\n            this._applySelectableClass = value;\n            this.children.forEach(c => {\n                c.applySelectableClass = value;\n            });\n        }\n    }\n\n    /**\n     * @hidden\n     * Calculates the number of visible columns, based on indexes of first and last visible columns.\n     */\n    public override calcChildren(): number {\n        const visibleChildren = this.allChildren.filter(c => c.visibleIndex > -1);\n        const fi = visibleChildren[0].visibleIndex;\n        const li = visibleChildren[visibleChildren.length - 1].visibleIndex;\n        return li - fi + 1;\n    }\n}\n"]}
383
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-group.component.js","sourceRoot":"","sources":["../../../../../../projects/igniteui-angular/src/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    booleanAttribute\n} from '@angular/core';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { IgxColumnComponent } from './column.component';\nimport { flatten } from '../../core/utils';\nimport { CellType, IgxColumnTemplateContext } from '../common/grid.interface';\n\n\n@Component({\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [{ provide: IgxColumnComponent, useExisting: forwardRef(() => IgxColumnGroupComponent) }],\n    selector: 'igx-column-group',\n    template: ``,\n    standalone: true\n})\nexport class IgxColumnGroupComponent extends IgxColumnComponent implements AfterContentInit {\n\n    @ContentChildren(IgxColumnComponent, { read: IgxColumnComponent })\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override 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 override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override set expanded(value: boolean) {\n        this._expanded = value;\n        this.expandedChange.emit(this._expanded);\n        if (!this.collapsible) {\n            return;\n        }\n        if (!this.hidden && this.children) {\n            this.setExpandCollapseState();\n        }\n    }\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public override get summaries(): any {\n        return this._summaries;\n    }\n    /**\n     * Sets the column group `summaries`.\n     * ```typescript\n     * this.columnGroup.summaries = IgxNumberSummaryOperand;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override searchable = true;\n    /**\n     * Gets the column group `filters`.\n     * ```typescript\n     * let columnGroupFilters = this.columnGroup.filters;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public override get filters(): any {\n        return this._filters;\n    }\n    /**\n     * Sets the column group `filters`.\n     * ```typescript\n     * this.columnGroup.filters = IgxStringFilteringOperand;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override set filters(classRef: any) { }\n\n    /**\n     * Returns if the column group is selectable\n     * ```typescript\n     * let columnGroupSelectable = this.columnGroup.selectable;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get selectable(): boolean {\n        return this.children && this.children.some(child => child.selectable);\n    }\n\n    /**\n     * @hidden\n     */\n    public override set selectable(value: boolean) { }\n\n    /**\n     * @hidden\n     */\n    public override get bodyTemplate(): TemplateRef<any> {\n        return this._bodyTemplate;\n    }\n    /**\n     * @hidden\n     */\n    public override set bodyTemplate(template: TemplateRef<any>) { }\n\n    /**\n     * Allows you to define a custom template for expand/collapse indicator\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input()\n    public override collapsibleIndicatorTemplate: TemplateRef<IgxColumnTemplateContext>;\n\n    /**\n     * @hidden\n     */\n    public override get inlineEditorTemplate(): TemplateRef<any> {\n        return this._inlineEditorTemplate;\n    }\n    /**\n     * @hidden\n     */\n    public override set inlineEditorTemplate(template: TemplateRef<any>) { }\n    /**\n     * Will return empty array. Use this.children.toArray()[index].cells to get the cells for a column that is part of the column group.\n     * ```typescript\n     * let columnCells = this.columnGroup.cells;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get cells(): CellType[] {\n        return [];\n    }\n    /**\n     * Gets whether the column group is hidden.\n     * ```typescript\n     * let isHidden = this.columnGroup.hidden;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    @Input({ transform: booleanAttribute })\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override 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) {\n                    c.hidden = false; return;\n                }\n                c.hidden = this.expanded ? c.visibleWhenCollapsed : !c.visibleWhenCollapsed;\n            });\n        }\n    }\n\n    /**\n     * Returns if the column group is selected.\n     * ```typescript\n     * let isSelected = this.columnGroup.selected;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get selected(): boolean {\n        const selectableChildren = this.allChildren.filter(c => !c.columnGroup && c.selectable && !c.hidden);\n        return selectableChildren.length > 0 && selectableChildren.every(c => c.selected);\n    }\n\n    /**\n     * Select/deselect the column group.\n     * ```typescript\n     * this.columnGroup.selected = true;\n     * ```\n     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override set selected(value: boolean) {\n        if (this.selectable) {\n            this.children.forEach(c => {\n                c.selected = value;\n            });\n        }\n    }\n\n    /**\n     * @hidden\n     */\n    public override 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.collapsibleIndicatorTemplate = 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            if (this.pinned) {\n                child.pinned = this.pinned;\n            }\n            if (this._hidden) {\n                child.hidden = this._hidden;\n            }\n        });\n        if (this.collapsible) {\n            this.setExpandCollapseState();\n        }\n\n        this.children.changes\n            .pipe(takeUntil(this.destroy$))\n            .subscribe((change: QueryList<IgxColumnComponent>) => {\n                let shouldReinitPinning = false;\n                change.forEach(x => {\n                    x.parent = this;\n                    if (this.pinned && x.pinned !== this.pinned) {\n                        shouldReinitPinning = true;\n                        x.pinned = this.pinned;\n                    }\n                });\n                if (this.collapsible) {\n                    this.setExpandCollapseState();\n                }\n                if (shouldReinitPinning) {\n                    (this.grid as any).initPinning();\n                }\n            });\n\n    }\n\n    /** @hidden @internal **/\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override 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     *\n     * @memberof IgxColumnComponent\n     */\n    public override 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     *\n     * @memberof IgxColumnGroupComponent\n     */\n    public override get width() {\n        const width = `${this.children.reduce((acc, val) => {\n            if (val.hidden) {\n                return acc;\n            }\n            return acc + parseInt(val.calcWidth, 10);\n        }, 0)}`;\n        return width + 'px';\n    }\n\n    public override set width(val) { }\n\n    /** @hidden @internal **/\n    public override get resolvedWidth() {\n        return this.width;\n    }\n\n    /**\n     * @hidden\n     */\n    public override get applySelectableClass(): boolean {\n        return this._applySelectableClass;\n    }\n\n    /**\n     * @hidden\n     */\n    public override set applySelectableClass(value: boolean) {\n        if (this.selectable) {\n            this._applySelectableClass = value;\n            this.children.forEach(c => {\n                c.applySelectableClass = value;\n            });\n        }\n    }\n\n    /**\n     * @hidden\n     * Calculates the number of visible columns, based on indexes of first and last visible columns.\n     */\n    public override calcChildren(): number {\n        const visibleChildren = this.allChildren.filter(c => c.visibleIndex > -1);\n        const fi = visibleChildren[0].visibleIndex;\n        const li = visibleChildren[visibleChildren.length - 1].visibleIndex;\n        return li - fi + 1;\n    }\n}\n"]}
@@ -43679,6 +43679,9 @@ class IgxColumnGroupComponent extends IgxColumnComponent {
43679
43679
  if (this.pinned) {
43680
43680
  child.pinned = this.pinned;
43681
43681
  }
43682
+ if (this._hidden) {
43683
+ child.hidden = this._hidden;
43684
+ }
43682
43685
  });
43683
43686
  if (this.collapsible) {
43684
43687
  this.setExpandCollapseState();