From 94c488d93d2ec1cee18559d7f58952b908898726 Mon Sep 17 00:00:00 2001 From: Qi Chen Date: Wed, 17 Dec 2014 10:21:48 +0800 Subject: [PATCH 1/3] fix filter issue when using with Edit module --- core/model/extensions/Modify.js | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/core/model/extensions/Modify.js b/core/model/extensions/Modify.js index 3552b4429..a29281c5f 100644 --- a/core/model/extensions/Modify.js +++ b/core/model/extensions/Modify.js @@ -140,10 +140,13 @@ define([ byId: function(id){ var t = this, c = t.inner._call('byId', arguments); - if(!c){ return c; } + if(!c) return c; var d = lang.mixin({}, c); + d.rawData = lang.mixin({}, d.rawData, t._lazyRawData[id]); - d.data = lang.mixin({}, d.data, t._lazyData[id]); + if (d.data) { + d.data = lang.mixin({}, d.data, t._lazyData[id]); + } return d; }, @@ -151,11 +154,14 @@ define([ var t = this, c = t.inner._call('byIndex', arguments), id = t.inner._call('indexToId', arguments); - if(!c){ return c; } + + if(!c) return c; var d = lang.mixin({}, c); d.rawData = lang.mixin({}, d.rawData, t._lazyRawData[id]); - d.data = lang.mixin({}, d.data, t._lazyData[id]); + if (d.data) { + d.data = lang.mixin({}, d.data, t._lazyData[id]); + } return d; }, From 77764ac50c1d9323a86b087182479de32015e889 Mon Sep 17 00:00:00 2001 From: Qi Chen Date: Fri, 19 Dec 2014 17:56:25 +0800 Subject: [PATCH 2/3] fix summary for ZOS --- core/model/Model.js | 8 ++++---- support/Summary.js | 1 + 2 files changed, 5 insertions(+), 4 deletions(-) diff --git a/core/model/Model.js b/core/model/Model.js index 9bdc468cb..824a12752 100644 --- a/core/model/Model.js +++ b/core/model/Model.js @@ -377,15 +377,15 @@ define([ }, _sizeAll: function(parentId){ - var size = this.size(parentId), i, childId, - count = 0; + var size = this.size(parentId), + count = 0, + i, childId; size = size === -1 ? 0 : size; count += size; - for(i = 0; i < size; i++){ + for(i = 0; i < size; i++) { childId = this.indexToId(i, parentId); - console.log(childId); count += this._sizeAll(childId); } diff --git a/support/Summary.js b/support/Summary.js index d990fa871..d6fc736d8 100644 --- a/support/Summary.js +++ b/support/Summary.js @@ -54,6 +54,7 @@ define([ firstIdx = 0, lastIdx = 0; + size = g.tree? g.model._sizeAll() : size; if(pagination){ cp = pagination.currentPage(); firstIdx = pagination.firstIndexInPage(cp) + 1; From 7e95f801a54bfcb5fdb502c10150014780a9bbf3 Mon Sep 17 00:00:00 2001 From: Qi Chen Date: Fri, 26 Dec 2014 15:20:56 +0800 Subject: [PATCH 3/3] add size handler for user to customize row count --- support/Summary.js | 4 ++++ tests/support/common.css | 6 ++++++ tests/test_grid_pagination.html | 6 ++++++ 3 files changed, 16 insertions(+) diff --git a/support/Summary.js b/support/Summary.js index d6fc736d8..9bab91455 100644 --- a/support/Summary.js +++ b/support/Summary.js @@ -54,6 +54,10 @@ define([ firstIdx = 0, lastIdx = 0; + if (g.sizeHandler && typeof g.sizeHandler === 'function') { + size = g.sizeHandler(g); + } + size = g.tree? g.model._sizeAll() : size; if(pagination){ cp = pagination.currentPage(); diff --git a/tests/support/common.css b/tests/support/common.css index 0cf90a083..597dfb096 100644 --- a/tests/support/common.css +++ b/tests/support/common.css @@ -11,6 +11,12 @@ body { margin: 5em; } +h3 { + color: blue; + margin: 0; + padding: 0; +} + .title { font-size: large; font-weight: bolder; diff --git a/tests/test_grid_pagination.html b/tests/test_grid_pagination.html index ee9d31b8c..7c0c5a0a4 100644 --- a/tests/test_grid_pagination.html +++ b/tests/test_grid_pagination.html @@ -36,10 +36,16 @@

Pagination Grid with API only

] '>

Link-button style PaginationBar

+

using self defined size handler to calculate row count