From c6d3b2a1f3df9e7374c91280b243d5592013f7a6 Mon Sep 17 00:00:00 2001 From: David Jellesma Date: Mon, 1 Feb 2016 18:45:43 -0500 Subject: [PATCH] fix(saveState): Fixes #4146 - Allow saving of pagination state --- src/features/saveState/js/saveState.js | 44 +++++++++++++++ src/features/saveState/test/saveState.spec.js | 56 +++++++++++++++++++ 2 files changed, 100 insertions(+) diff --git a/src/features/saveState/js/saveState.js b/src/features/saveState/js/saveState.js index 5d9f593050..090ba70f64 100644 --- a/src/features/saveState/js/saveState.js +++ b/src/features/saveState/js/saveState.js @@ -287,6 +287,7 @@ savedState.selection = service.saveSelection( grid ); savedState.grouping = service.saveGrouping( grid ); savedState.treeView = service.saveTreeView( grid ); + savedState.pagination = service.savePagination( grid ); return savedState; }, @@ -323,6 +324,10 @@ service.restoreTreeView( grid, state.treeView ); } + if ( state.pagination ){ + service.restorePagination( grid, state.pagination ); + } + grid.refresh(); }, @@ -474,6 +479,26 @@ }, + /** + * @ngdoc function + * @name savePagination + * @methodOf ui.grid.saveState.service:uiGridSaveStateService + * @description Saves the pagination state, if the pagination feature is enabled + * @param {Grid} grid the grid whose state we'd like to save + * @returns {object} the pagination state ready to be saved + */ + savePagination: function( grid ) { + if ( !grid.api.pagination || !grid.options.paginationPageSize ){ + return {}; + } + + return { + paginationCurrentPage: grid.options.paginationCurrentPage, + paginationPageSize: grid.options.paginationPageSize + }; + }, + + /** * @ngdoc function * @name saveTreeView @@ -698,6 +723,25 @@ grid.api.treeView.setTreeView( treeViewState ); }, + /** + * @ngdoc function + * @name restorePagination + * @methodOf ui.grid.saveState.service:uiGridSaveStateService + * @description Restores the pagination information, if pagination is enabled. + * @param {Grid} grid the grid whose state we'd like to restore + * @param {object} pagination the pagination object to be restored + * @param {number} pagination.paginationCurrentPage the page number to restore + * @param {number} pagination.paginationPageSize the number of items displayed per page + */ + restorePagination: function( grid, pagination ){ + if ( !grid.api.pagination || !grid.options.paginationPageSize ){ + return; + } + + grid.options.paginationCurrentPage = pagination.paginationCurrentPage; + grid.options.paginationPageSize = pagination.paginationPageSize; + }, + /** * @ngdoc function * @name findRowByIdentity diff --git a/src/features/saveState/test/saveState.spec.js b/src/features/saveState/test/saveState.spec.js index 4d3a474e42..f7f92e2dad 100644 --- a/src/features/saveState/test/saveState.spec.js +++ b/src/features/saveState/test/saveState.spec.js @@ -189,6 +189,22 @@ describe('ui.grid.saveState uiGridSaveStateService', function () { }); }); + describe('savePagination', function() { + beforeEach(function() { + grid.options.paginationPageSize = 25; + grid.options.paginationCurrentPage = 2; + grid.api.pagination = true; + }); + + it('saves paginationCurrentPage', function() { + expect(uiGridSaveStateService.savePagination( grid ) ).toEqual({ + paginationCurrentPage: 2, + paginationPageSize: 25 + }); + }); + + }); + describe('saveScrollFocus', function() { it('does nothing when no cellNav module initialized', function() { @@ -482,6 +498,46 @@ describe('ui.grid.saveState uiGridSaveStateService', function () { }); }); + describe('restorePagination', function() { + var pagination = { + paginationCurrentPage: 2, + paginationPageSize: 25 + }; + + describe('when pagination is on', function() { + beforeEach(function() { + grid.options.paginationPageSize = 1; + grid.api.pagination = true; + uiGridSaveStateService.restorePagination( grid, pagination ); + }); + + it('sets the paginationPageSize', function() { + expect(grid.options.paginationPageSize).toEqual(25); + }); + + it('sets the paginationCurrentPage', function() { + expect(grid.options.paginationCurrentPage).toEqual(2); + }); + }); + + describe('when pagination is off', function() { + beforeEach(function() { + grid.api.pagination = false; + uiGridSaveStateService.restorePagination( grid, pagination ); + }); + + it('does not modify paginationPageSize', function() { + expect(grid.options.paginationPageSize).toBeUndefined(); + }); + + it('does not modify paginationCurrentPage', function() { + expect(grid.options.paginationCurrentPage).toBeUndefined(); + }); + + + }); + }); + describe('restoreScrollFocus', function() { it('does nothing when no cellNav module initialized', function() {