From 240c00696a08d8a97617711508158a059febcfa4 Mon Sep 17 00:00:00 2001
From: Valeria Toneva <106249179+valeriatoneva@users.noreply.github.com>
Date: Tue, 20 Feb 2024 09:27:02 +0200
Subject: [PATCH] fix(column-groups): add logic for collapsible and expanded
(#13931)
---
.../src/lib/grids/columns/column.component.ts | 2 +-
.../src/lib/grids/state.directive.spec.ts | 50 ++++++++++++++++++-
.../src/lib/grids/state.directive.ts | 8 ++-
src/app/grid-state/grid-state.component.html | 8 +--
4 files changed, 61 insertions(+), 7 deletions(-)
diff --git a/projects/igniteui-angular/src/lib/grids/columns/column.component.ts b/projects/igniteui-angular/src/lib/grids/columns/column.component.ts
index 7db48e8cc99..ca3343e3fa6 100644
--- a/projects/igniteui-angular/src/lib/grids/columns/column.component.ts
+++ b/projects/igniteui-angular/src/lib/grids/columns/column.component.ts
@@ -1540,7 +1540,7 @@ export class IgxColumnComponent implements AfterContentInit, OnDestroy, ColumnTy
this._visibleWhenCollapsed = value;
this.visibleWhenCollapsedChange.emit(this._visibleWhenCollapsed);
if (this.parent) {
- this.parent.setExpandCollapseState();
+ this.parent?.setExpandCollapseState?.();
}
}
diff --git a/projects/igniteui-angular/src/lib/grids/state.directive.spec.ts b/projects/igniteui-angular/src/lib/grids/state.directive.spec.ts
index b8a37d899bb..e71bb32a600 100644
--- a/projects/igniteui-angular/src/lib/grids/state.directive.spec.ts
+++ b/projects/igniteui-angular/src/lib/grids/state.directive.spec.ts
@@ -18,7 +18,7 @@ import { GridSelectionRange } from './common/types';
import { CustomFilter } from '../test-utils/grid-samples.spec';
import { IgxPaginatorComponent } from '../paginator/paginator.component';
import { NgFor } from '@angular/common';
-import { IgxColumnComponent, IgxGridDetailTemplateDirective } from './public_api';
+import { IgxColumnComponent, IgxColumnGroupComponent, IgxGridDetailTemplateDirective } from './public_api';
/* eslint-disable max-len */
describe('IgxGridState - input properties #grid', () => {
@@ -416,6 +416,33 @@ describe('IgxGridState - input properties #grid', () => {
HelperFunctions.verifyColumns(columnsStateObject.columns, gridState);
});
+ it('setState should correctly restore grid columns state properties: collapsible and expanded', () => {
+ const fix = TestBed.createComponent(CollapsibleColumnGroupTestComponent);
+ fix.detectChanges();
+ const state = fix.componentInstance.state;
+ const grid = fix.componentInstance.grid;
+ /* eslint-disable max-len */
+ const initialState = '{"columns":[{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":false,"dataType":"string","hasSummary":false,"field":"ID","width":"100px","header":"","resizable":false,"searchable":true,"selectable":true,"parent":null,"columnGroup":false,"disableHiding":false,"disablePinning":false},{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":false,"dataType":"string","hasSummary":false,"width":"100px","header":"Address Information","resizable":false,"searchable":true,"selectable":true,"parent":null,"columnGroup":true,"disableHiding":false,"disablePinning":false,"collapsible":true,"expanded":true},{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":true,"dataType":"string","hasSummary":false,"field":"City","width":"100px","header":"","resizable":false,"searchable":true,"selectable":true,"parent":"Address Information","columnGroup":false,"disableHiding":false,"disablePinning":false,"visibleWhenCollapsed":true},{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":false,"dataType":"string","hasSummary":false,"field":"Address","width":"100px","header":"","resizable":false,"searchable":true,"selectable":true,"parent":"Address Information","columnGroup":false,"disableHiding":false,"disablePinning":false,"visibleWhenCollapsed":false}]}'
+ const newState = `{"columns":[{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":false,"dataType":"string","hasSummary":false,"field":"ID","width":"100px","header":"","resizable":false,"searchable":true,"selectable":true,"parent":null,"columnGroup":false,"disableHiding":false,"disablePinning":false},{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":false,"dataType":"string","hasSummary":false,"width":"100px","header":"Address Information","resizable":false,"searchable":true,"selectable":true,"parent":null,"columnGroup":true,"disableHiding":false,"disablePinning":false,"collapsible":true,"expanded":false},{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":true,"dataType":"string","hasSummary":false,"field":"City","width":"100px","header":"","resizable":false,"searchable":true,"selectable":true,"parent":"Address Information","columnGroup":false,"disableHiding":false,"disablePinning":false,"visibleWhenCollapsed":true},{"pinned":false,"sortable":false,"filterable":true,"editable":false,"sortingIgnoreCase":true,"filteringIgnoreCase":true,"headerClasses":"","headerGroupClasses":"","groupable":false,"movable":false,"hidden":false,"dataType":"string","hasSummary":false,"field":"Address","width":"100px","header":"","resizable":false,"searchable":true,"selectable":true,"parent":"Address Information","columnGroup":false,"disableHiding":false,"disablePinning":false,"visibleWhenCollapsed":false}]}`
+ /* eslint-enable max-len */
+ const columnsStateObject = JSON.parse(newState);
+ let gridState = state.getState(true, 'columns');
+ expect(gridState).toBe(initialState);
+ // 1. initial state collapsible:true, expanded: true;
+ // 2. new state collapsible:true, expanded: false after restoration
+
+ state.setState(columnsStateObject); // set new state - resored state
+ gridState = state.getState(false, 'columns') as IGridState;
+ HelperFunctions.verifyColumns(columnsStateObject.columns, gridState);
+ gridState = state.getState(true, 'columns');
+ fix.detectChanges();
+ expect(gridState).toBe(newState);
+
+ const addressInfoGroup = grid.columns.find(c => c.header === "Address Information");
+ expect(addressInfoGroup.collapsible).toBe(true);
+ expect(addressInfoGroup.expanded).toBe(false);
+ });
+
it('setState should correctly restore grid paging state from string', () => {
const fix = TestBed.createComponent(IgxGridStateComponent);
fix.detectChanges();
@@ -866,5 +893,26 @@ export class IgxGridStateWithDetailsComponent {
public data = SampleTestData.foodProductData();
}
+
+@Component({
+ template: `
+
+
+
+
+
+
+
+ `,
+ standalone: true,
+ imports: [IgxGridComponent, IgxColumnComponent, IgxColumnGroupComponent, IgxGridStateDirective, NgFor]
+})
+export class CollapsibleColumnGroupTestComponent {
+ @ViewChild(IgxGridComponent, { read: IgxGridComponent, static: true })
+ public grid: IgxGridComponent;
+ @ViewChild(IgxGridStateDirective, { static: true })
+ public state: IgxGridStateDirective;
+ public data = SampleTestData.contactInfoDataFull();
+}
/* eslint-enable max-len */
diff --git a/projects/igniteui-angular/src/lib/grids/state.directive.ts b/projects/igniteui-angular/src/lib/grids/state.directive.ts
index a5c1231581f..9b2601ffad0 100644
--- a/projects/igniteui-angular/src/lib/grids/state.directive.ts
+++ b/projects/igniteui-angular/src/lib/grids/state.directive.ts
@@ -90,6 +90,9 @@ export interface IColumnState {
parent: any;
disableHiding: boolean;
disablePinning: boolean;
+ collapsible?: boolean;
+ expanded?: boolean;
+ visibleWhenCollapsed?: boolean;
}
export type GridFeatures = keyof IGridStateOptions;
@@ -202,7 +205,10 @@ export class IgxGridStateDirective {
parent: c.parent ? c.parent.header : null,
columnGroup: c.columnGroup,
disableHiding: c.disableHiding,
- disablePinning: c.disablePinning
+ disablePinning: c.disablePinning,
+ collapsible: c.columnGroup ? c.collapsible : undefined,
+ expanded: c.columnGroup ? c.expanded : undefined,
+ visibleWhenCollapsed: c.parent?.columnGroup ? (c as IgxColumnComponent).visibleWhenCollapsed : undefined
}));
return { columns: gridColumns };
},
diff --git a/src/app/grid-state/grid-state.component.html b/src/app/grid-state/grid-state.component.html
index 631adc9c7a4..d6e1048680d 100644
--- a/src/app/grid-state/grid-state.component.html
+++ b/src/app/grid-state/grid-state.component.html
@@ -58,10 +58,10 @@
-
+
-
+ field="FirstName" [visibleWhenCollapsed]="true">
+
@@ -243,4 +243,4 @@
Hi I'm {{ cell.value }}
-
\ No newline at end of file
+