From 8bd3f4f68247681f8eb57e7aabd59b636face7e7 Mon Sep 17 00:00:00 2001 From: ghiscoding Date: Wed, 3 Nov 2021 11:38:15 -0400 Subject: [PATCH] fix(tree): reset to initial tree sort when calling "Clear all Sorting" --- .../common/src/controls/__tests__/slickGridMenu.spec.ts | 6 ++++++ packages/common/src/controls/slickGridMenu.ts | 3 +++ 2 files changed, 9 insertions(+) diff --git a/packages/common/src/controls/__tests__/slickGridMenu.spec.ts b/packages/common/src/controls/__tests__/slickGridMenu.spec.ts index 049b9c63d..ba93ed1b7 100644 --- a/packages/common/src/controls/__tests__/slickGridMenu.spec.ts +++ b/packages/common/src/controls/__tests__/slickGridMenu.spec.ts @@ -1092,6 +1092,7 @@ describe('GridMenuControl', () => { it('should call "clearFrozenColumns" when the command triggered is "clear-pinning"', () => { const setOptionsSpy = jest.spyOn(gridStub, 'setOptions'); const setColumnsSpy = jest.spyOn(gridStub, 'setColumns'); + const pubSubSpy = jest.spyOn(pubSubServiceStub, 'publish'); const copyGridOptionsMock = { ...gridOptionsMock, gridMenu: { commandLabels: gridOptionsMock.gridMenu.commandLabels, hideClearFrozenColumnsCommand: false, } } as unknown as GridOption; jest.spyOn(SharedService.prototype, 'gridOptions', 'get').mockReturnValue(copyGridOptionsMock); jest.spyOn(gridStub, 'getOptions').mockReturnValue(copyGridOptionsMock); @@ -1105,11 +1106,13 @@ describe('GridMenuControl', () => { expect(setColumnsSpy).toHaveBeenCalled(); expect(setOptionsSpy).toHaveBeenCalledWith({ frozenColumn: -1, frozenRow: -1, frozenBottom: false, enableMouseWheelScrollHandler: false }); + expect(pubSubSpy).toHaveBeenCalledWith('onGridMenuClearAllPinning'); }); it('should call "clearFilters" and dataview refresh when the command triggered is "clear-filter"', () => { const filterSpy = jest.spyOn(filterServiceStub, 'clearFilters'); const refreshSpy = jest.spyOn(SharedService.prototype.dataView, 'refresh'); + const pubSubSpy = jest.spyOn(pubSubServiceStub, 'publish'); const copyGridOptionsMock = { ...gridOptionsMock, enableFiltering: true, showHeaderRow: true, } as unknown as GridOption; jest.spyOn(SharedService.prototype, 'gridOptions', 'get').mockReturnValue(copyGridOptionsMock); jest.spyOn(gridStub, 'getOptions').mockReturnValue(copyGridOptionsMock); @@ -1123,11 +1126,13 @@ describe('GridMenuControl', () => { expect(filterSpy).toHaveBeenCalled(); expect(refreshSpy).toHaveBeenCalled(); + expect(pubSubSpy).toHaveBeenCalledWith('onGridMenuClearAllFilters'); }); it('should call "clearSorting" and dataview refresh when the command triggered is "clear-sorting"', () => { const sortSpy = jest.spyOn(sortServiceStub, 'clearSorting'); const refreshSpy = jest.spyOn(SharedService.prototype.dataView, 'refresh'); + const pubSubSpy = jest.spyOn(pubSubServiceStub, 'publish'); const copyGridOptionsMock = { ...gridOptionsMock, enableSorting: true, } as unknown as GridOption; jest.spyOn(SharedService.prototype, 'gridOptions', 'get').mockReturnValue(copyGridOptionsMock); jest.spyOn(gridStub, 'getOptions').mockReturnValue(copyGridOptionsMock); @@ -1141,6 +1146,7 @@ describe('GridMenuControl', () => { expect(sortSpy).toHaveBeenCalled(); expect(refreshSpy).toHaveBeenCalled(); + expect(pubSubSpy).toHaveBeenCalledWith('onGridMenuClearAllSorting'); }); it('should call "exportToExcel" and expect an error thrown when ExcelExportService is not registered prior to calling the method', () => { diff --git a/packages/common/src/controls/slickGridMenu.ts b/packages/common/src/controls/slickGridMenu.ts index c23300838..2b8ccf0ae 100644 --- a/packages/common/src/controls/slickGridMenu.ts +++ b/packages/common/src/controls/slickGridMenu.ts @@ -689,14 +689,17 @@ export class SlickGridMenu extends MenuBaseClass { if (gridOptions.enableAutoSizeColumns) { this.grid.autosizeColumns(); } + this.pubSubService.publish('onGridMenuClearAllPinning'); break; case 'clear-filter': this.filterService.clearFilters(); this.sharedService.dataView.refresh(); + this.pubSubService.publish('onGridMenuClearAllFilters'); break; case 'clear-sorting': this.sortService.clearSorting(); this.sharedService.dataView.refresh(); + this.pubSubService.publish('onGridMenuClearAllSorting'); break; case 'export-csv': const exportCsvService: TextExportService = registeredResources.find((service: any) => service.className === 'TextExportService');