From 4174433bf3f3c78cfac4253a009b1432fdd11ed0 Mon Sep 17 00:00:00 2001 From: viktorkombov Date: Tue, 1 Feb 2022 12:23:59 +0200 Subject: [PATCH 1/5] feat(hgrid): allow to prevent exiting of edit mode when row is toggled --- .../src/lib/grids/api.service.ts | 7 ++ .../src/lib/grids/common/grid.interface.ts | 27 +++---- .../hierarchical-grid-api.service.ts | 14 +++- .../hierarchical-grid.spec.ts | 70 +++++++++++++++++++ .../hierarchical-row.component.ts | 22 ++---- 5 files changed, 110 insertions(+), 30 deletions(-) diff --git a/projects/igniteui-angular/src/lib/grids/api.service.ts b/projects/igniteui-angular/src/lib/grids/api.service.ts index 1953235f749..09c2cc8cbc1 100644 --- a/projects/igniteui-angular/src/lib/grids/api.service.ts +++ b/projects/igniteui-angular/src/lib/grids/api.service.ts @@ -397,6 +397,13 @@ export class GridBaseAPIService implements GridServiceType { if (args.cancel) { return; } + + const isHierarchicalGrid = grid.nativeElement.tagName.toLowerCase() === 'igx-hierarchical-grid'; + + if (isHierarchicalGrid) { + grid.hgridAPI.endEditAll(); + } + expandedStates.set(rowID, expanded); grid.expansionStates = expandedStates; this.crudService.endEdit(false); diff --git a/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts b/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts index eb78c3ded15..1edd300d8db 100644 --- a/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts +++ b/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts @@ -50,23 +50,23 @@ export interface IGridDataBindable { } export interface CellType { - value: any; - editValue: any; - selected: boolean; - active: boolean; - editable: boolean; - editMode: boolean; + value: any; + editValue: any; + selected: boolean; + active: boolean; + editable: boolean; + editMode: boolean; nativeElement?: HTMLElement; - column: ColumnType; - row: RowType; - grid: GridType; - id: { rowID: any; columnID: number; rowIndex: number }; + column: ColumnType; + row: RowType; + grid: GridType; + id: { rowID: any; columnID: number; rowIndex: number }; cellID?: any; readonly?: boolean; title?: any; - width: string; + width: string; visibleColumnIndex?: number; - update: (value: any) => void; + update: (value: any) => void; setEditMode?(value: boolean): void; calculateSizeToFit?(range: any): number; activate?(event: FocusEvent | KeyboardEvent): void; @@ -95,7 +95,7 @@ export interface RowType { children?: RowType[]; parent?: RowType; hasChildren?: boolean; - treeRow? : ITreeGridRecord; + treeRow?: ITreeGridRecord; addRowUI?: boolean; focused?: boolean; grid: GridType; @@ -247,6 +247,7 @@ export interface GridServiceType { getChildGrid?(path: IPathSegment[]): GridType; // XXX: Fix type unsetChildRowIsland?(rowIsland: any): void; + endEditAll?(): void; } diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts index b38b8d4f9fd..772965bd9df 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts @@ -3,11 +3,10 @@ import { Subject } from 'rxjs'; import { GridType, IPathSegment } from '../common/grid.interface'; import { Injectable } from '@angular/core'; import { GridBaseAPIService } from '../api.service'; - @Injectable() export class IgxHierarchicalGridAPIService extends GridBaseAPIService { protected childRowIslands: Map = new Map(); - protected childGrids: Map> = + protected childGrids: Map> = new Map>(); public registerChildRowIsland(rowIsland: IgxRowIslandComponent) { @@ -127,4 +126,15 @@ export class IgxHierarchicalGridAPIService extends GridBaseAPIService const index = this.get_row_index_in_data(rowID, data); return data[index]; } + + public endEditAll(): void { + if (this.grid.gridAPI.crudService.cellInEditMode) { + this.grid.gridAPI.crudService.endEdit(); + } + this.getChildGrids(true).forEach(g => { + if (g.gridAPI.crudService.cellInEditMode) { + g.gridAPI.crudService.endEdit(); + } + }); + } } diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts index 0ea78be32f8..cedb722ebb0 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts @@ -438,6 +438,76 @@ describe('Basic IgxHierarchicalGrid #hGrid', () => { expect(childGridSecondRow.inEditMode).toBeFalsy(); }); + it('should be able to prevent exiting of edit mode when row is toggled through the UI', async () => { + hierarchicalGrid.primaryKey = 'ID'; + hierarchicalGrid.rowEditable = true; + hierarchicalGrid.rowToggle.subscribe((e) => { + e.cancel = true; + }); + fixture.detectChanges(); + wait(); + + const masterGridFirstRow = hierarchicalGrid.hgridAPI.get_row_by_index(0) as IgxHierarchicalRowComponent; + expect(masterGridFirstRow.expanded).toBeFalsy(); + + const masterGridSecondCell = masterGridFirstRow.cells.find(c => c.columnIndex === 1); + expect(masterGridSecondCell.editMode).toBeFalsy(); + + masterGridSecondCell.setEditMode(true); + fixture.detectChanges(); + wait(); + + expect(masterGridSecondCell.editMode).toBeTruthy(); + + UIInteractions.simulateClickAndSelectEvent(masterGridFirstRow.expander); + fixture.detectChanges(); + wait(); + + expect(masterGridFirstRow.expanded).toBeFalsy(); + expect(masterGridSecondCell.editMode).toBeTruthy(); + + hierarchicalGrid.rowToggle.subscribe((e) => { + e.cancel = false; + }); + UIInteractions.simulateClickAndSelectEvent(masterGridFirstRow.expander); + fixture.detectChanges(); + wait(); + + expect(masterGridFirstRow.expanded).toBeTruthy(); + expect(masterGridSecondCell.editMode).toBeFalsy(); + + const childGrid = hierarchicalGrid.hgridAPI.getChildGrids(false)[0] as IgxHierarchicalGridComponent; + expect(childGrid).toBeDefined(); + + childGrid.primaryKey = 'ID'; + childGrid.rowEditable = true; + childGrid.rowToggle.subscribe((e) => { + e.cancel = true; + }); + fixture.detectChanges(); + wait(); + + childGrid.columnList.find(c => c.index === 1).editable = true; + const childGridSecondRow = childGrid.gridAPI.get_row_by_index(1) as IgxHierarchicalRowComponent; + expect(childGridSecondRow.expanded).toBeFalsy(); + + const childGridSecondCell = childGridSecondRow.cells.find(c => c.columnIndex === 1); + expect(childGridSecondCell.editMode).toBeFalsy(); + + childGridSecondCell.setEditMode(true); + fixture.detectChanges(); + wait(); + + expect(childGridSecondCell.editMode).toBeTruthy(); + + UIInteractions.simulateClickAndSelectEvent(masterGridFirstRow.expander); + fixture.detectChanges(); + wait(); + + expect(childGrid.gridAPI.crudService.cellInEditMode).toBeTruthy(); + expect(childGridSecondRow.inEditMode).toBeTruthy(); + }); + it('child grid width should be recalculated if parent no longer shows scrollbar.', async () => { hierarchicalGrid.height = '1000px'; fixture.detectChanges(); diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts index 19a10cc8373..0dc40b8e0fe 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts @@ -58,7 +58,7 @@ export class IgxHierarchicalRowComponent extends IgxRowDirective { } public get viewIndex(): number { - return this.index + (this.grid.paginator?.page || 0 ) * (this.grid.paginator?.perPage || 0); + return this.index + (this.grid.paginator?.page || 0) * (this.grid.paginator?.perPage || 0); } /** @@ -80,7 +80,7 @@ export class IgxHierarchicalRowComponent extends IgxRowDirective { } public get hasChildren() { - return !!this.grid.childLayoutKeys.length; + return !!this.grid.childLayoutKeys.length; } /** @@ -91,10 +91,10 @@ export class IgxHierarchicalRowComponent extends IgxRowDirective { return this.grid && this.grid.highlightedRowID === this.key; } - /** - * @hidden - */ - public expanderClick(event) { + /** + * @hidden + */ + public expanderClick(event) { event.stopPropagation(); this.toggle(); } @@ -109,7 +109,6 @@ export class IgxHierarchicalRowComponent extends IgxRowDirective { if (this.added) { return; } - this.endEdit(this.grid.rootGrid); this.grid.gridAPI.set_row_expansion_state(this.key, !this.expanded); this.grid.cdr.detectChanges(); } @@ -150,13 +149,6 @@ export class IgxHierarchicalRowComponent extends IgxRowDirective { // TODO: consider moving into CRUD protected endEdit(grid: GridType) { - if (grid.gridAPI.crudService.cellInEditMode) { - grid.gridAPI.crudService.endEdit(); - } - grid.hgridAPI.getChildGrids(true).forEach(g => { - if (g.gridAPI.crudService.cellInEditMode) { - g.gridAPI.crudService.endEdit(); - } - }); + grid.gridAPI.endEditAll(); } } From c07854c4def6b87427cb6cd0c38aa7d9265941dd Mon Sep 17 00:00:00 2001 From: viktorkombov Date: Tue, 1 Feb 2022 12:45:25 +0200 Subject: [PATCH 2/5] chore(*): fixing the endEditAll method in order to end edit of all grids --- .../hierarchical-grid/hierarchical-grid-api.service.ts | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts index 772965bd9df..9dcca7428c9 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts @@ -128,10 +128,11 @@ export class IgxHierarchicalGridAPIService extends GridBaseAPIService } public endEditAll(): void { - if (this.grid.gridAPI.crudService.cellInEditMode) { - this.grid.gridAPI.crudService.endEdit(); + const rootGrid = this.grid.rootGrid; + if (rootGrid.gridAPI.crudService.cellInEditMode) { + rootGrid.gridAPI.crudService.endEdit(); } - this.getChildGrids(true).forEach(g => { + rootGrid.getChildGrids(true).forEach(g => { if (g.gridAPI.crudService.cellInEditMode) { g.gridAPI.crudService.endEdit(); } From 0371feb6ca4912ee6264e3ea7c7d7d5e4e668357 Mon Sep 17 00:00:00 2001 From: viktorkombov Date: Tue, 1 Feb 2022 16:06:21 +0200 Subject: [PATCH 3/5] chore(*): fix failing unit test --- .../grids/hierarchical-grid/hierarchical-grid-api.service.ts | 2 +- .../src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts | 2 +- .../lib/grids/hierarchical-grid/hierarchical-row.component.ts | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts index 9dcca7428c9..af7425de844 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid-api.service.ts @@ -132,7 +132,7 @@ export class IgxHierarchicalGridAPIService extends GridBaseAPIService if (rootGrid.gridAPI.crudService.cellInEditMode) { rootGrid.gridAPI.crudService.endEdit(); } - rootGrid.getChildGrids(true).forEach(g => { + rootGrid.hgridAPI.getChildGrids(true).forEach(g => { if (g.gridAPI.crudService.cellInEditMode) { g.gridAPI.crudService.endEdit(); } diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts index cedb722ebb0..dd048fdc42c 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-grid.spec.ts @@ -500,7 +500,7 @@ describe('Basic IgxHierarchicalGrid #hGrid', () => { expect(childGridSecondCell.editMode).toBeTruthy(); - UIInteractions.simulateClickAndSelectEvent(masterGridFirstRow.expander); + UIInteractions.simulateClickAndSelectEvent(childGridSecondRow.expander); fixture.detectChanges(); wait(); diff --git a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts index 0dc40b8e0fe..1eac2933d1b 100644 --- a/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts +++ b/projects/igniteui-angular/src/lib/grids/hierarchical-grid/hierarchical-row.component.ts @@ -149,6 +149,6 @@ export class IgxHierarchicalRowComponent extends IgxRowDirective { // TODO: consider moving into CRUD protected endEdit(grid: GridType) { - grid.gridAPI.endEditAll(); + grid.hgridAPI.endEditAll(); } } From 3fc14b504abe570bbe93b012a77f777682d4ece5 Mon Sep 17 00:00:00 2001 From: viktorkombov Date: Fri, 4 Feb 2022 08:19:19 +0200 Subject: [PATCH 4/5] chore(*): define endEditAll in the right place in GridServiceType interface --- .../igniteui-angular/src/lib/grids/common/grid.interface.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts b/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts index 59c07ea2e74..6c35242174d 100644 --- a/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts +++ b/projects/igniteui-angular/src/lib/grids/common/grid.interface.ts @@ -246,9 +246,9 @@ export interface GridServiceType { getParentRowId?(child: GridType): any; getChildGrids?(inDepth?: boolean): GridType[]; getChildGrid?(path: IPathSegment[]): GridType; + endEditAll?(): void; // XXX: Fix type unsetChildRowIsland?(rowIsland: any): void; - endEditAll?(): void; } From 30d5e74025e08635ef3bfba52278168b012163bd Mon Sep 17 00:00:00 2001 From: Katrin Date: Fri, 4 Feb 2022 10:34:14 +0200 Subject: [PATCH 5/5] ci(public api): add GridSelectionRange to public api (#10916) Closes 10870 Co-authored-by: Hristo --- projects/igniteui-angular/src/public_api.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/projects/igniteui-angular/src/public_api.ts b/projects/igniteui-angular/src/public_api.ts index 2c545f5bd1d..348222c0607 100644 --- a/projects/igniteui-angular/src/public_api.ts +++ b/projects/igniteui-angular/src/public_api.ts @@ -136,3 +136,4 @@ export { IChipResourceStrings } from './lib/core/i18n/chip-resources'; export { IActionStripResourceStrings } from './lib/core/i18n/action-strip-resources'; export { PickerInteractionMode } from './lib/date-common/types'; export { SplitterType } from './lib/splitter/splitter.component'; +export { GridSelectionRange } from './lib/grids/common/types';