From 5a1c22a349caaa6d8578ed6fbef43c58ee22b7f2 Mon Sep 17 00:00:00 2001 From: Mottie Date: Thu, 12 Dec 2013 12:23:44 -0600 Subject: [PATCH] Pager filtered rows count properly includes/excludes child rows --- addons/pager/jquery.tablesorter.pager.js | 5 +++-- js/widgets/widget-pager.js | 8 ++++---- 2 files changed, 7 insertions(+), 6 deletions(-) diff --git a/addons/pager/jquery.tablesorter.pager.js b/addons/pager/jquery.tablesorter.pager.js index 6ea76527..47baf727 100644 --- a/addons/pager/jquery.tablesorter.pager.js +++ b/addons/pager/jquery.tablesorter.pager.js @@ -120,10 +120,11 @@ var i, pg, s, out, c = table.config, f = c.$table.hasClass('hasFilters') && !p.ajaxUrl, - t = (c.widgetOptions && c.widgetOptions.filter_filteredRow || 'filtered') + ',' + c.selectorRemove, + t = (c.widgetOptions && c.widgetOptions.filter_filteredRow || 'filtered') + ',' + c.selectorRemove + + (p.countChildRows ? '' : ',.' + c.cssChildRow), sz = p.size || 10; // don't allow dividing by zero p.totalPages = Math.ceil( p.totalRows / sz ); // needed for "pageSize" method - p.filteredRows = (f) ? c.$tbodies.eq(0).children('tr:not(.' + t + ')').length : p.totalRows; + p.filteredRows = (f) ? c.$tbodies.eq(0).children('tr').not('.' + t ).length : p.totalRows; p.filteredPages = (f) ? Math.ceil( p.filteredRows / sz ) || 1 : p.totalPages; if ( Math.min( p.totalPages, p.filteredPages ) >= 0 ) { t = (p.size * p.page > p.filteredRows); diff --git a/js/widgets/widget-pager.js b/js/widgets/widget-pager.js index c26115ae..5a043566 100644 --- a/js/widgets/widget-pager.js +++ b/js/widgets/widget-pager.js @@ -307,12 +307,12 @@ tsp = ts.pager = { wo = c.widgetOptions, p = c.pager, f = c.$table.hasClass('hasFilters') && !wo.pager_ajaxUrl, - t = (c.widgetOptions && c.widgetOptions.filter_filteredRow || 'filtered') + ',' + c.selectorRemove, + t = (c.widgetOptions && c.widgetOptions.filter_filteredRow || 'filtered') + ',' + c.selectorRemove + + (wo.pager_countChildRows ? '' : ',.' + c.cssChildRow), sz = p.size || 10; // don't allow dividing by zero - p.$size.removeClass(wo.pager_css.disabled).removeAttr('disabled'); - p.$goto.removeClass(wo.pager_css.disabled).removeAttr('disabled'); + p.$size.add(p.$goto).removeClass(wo.pager_css.disabled).removeAttr('disabled'); p.totalPages = Math.ceil( p.totalRows / sz ); // needed for "pageSize" method - p.filteredRows = (f) ? c.$tbodies.eq(0).children('tr:not(.' + t + ')').length : p.totalRows; + p.filteredRows = (f) ? c.$tbodies.eq(0).children('tr').not('.' + t).length : p.totalRows; p.filteredPages = (f) ? Math.ceil( p.filteredRows / sz ) || 1 : p.totalPages; if ( Math.min( p.totalPages, p.filteredPages ) >= 0 ) { t = (p.size * p.page > p.filteredRows);