Skip to content

Commit

Permalink
Core & pager: replace remaining jQuery each function. Fixes #827
Browse files Browse the repository at this point in the history
  • Loading branch information
Mottie committed May 17, 2015
1 parent ed321c2 commit 8d2abbb
Show file tree
Hide file tree
Showing 3 changed files with 132 additions and 97 deletions.
63 changes: 37 additions & 26 deletions addons/pager/jquery.tablesorter.pager.js
Original file line number Diff line number Diff line change
Expand Up @@ -377,12 +377,12 @@
// process data
if ( typeof(p.ajaxProcessing) === "function" ) {
// ajaxProcessing result: [ total, rows, headers ]
var i, j, hsh, $f, $sh, t, th, d, l, rr_count,
var i, j, t, hsh, $f, $sh, $headers, $h, icon, th, d, l, rr_count, len,
c = table.config,
$t = c.$table,
$table = c.$table,
tds = '',
result = p.ajaxProcessing(data, table, xhr) || [ 0, [] ],
hl = $t.find('thead th').length;
hl = $table.find('thead th').length;

// Clean up any previous error.
ts.showError(table);
Expand Down Expand Up @@ -445,28 +445,30 @@
p.processAjaxOnInit = true;
// only add new header text if the length matches
if ( th && th.length === hl ) {
hsh = $t.hasClass('hasStickyHeaders');
hsh = $table.hasClass('hasStickyHeaders');
$sh = hsh ? c.widgetOptions.$sticky.children('thead:first').children('tr').children() : '';
$f = $t.find('tfoot tr:first').children();
$f = $table.find('tfoot tr:first').children();
// don't change td headers (may contain pager)
c.$headers.filter('th').each(function(j){
var $t = $(this), icn;
$headers = c.$headers.filter( 'th ' );
len = $headers.length;
for ( j = 0; j < len; j++ ) {
$h = $headers.eq( j );
// add new test within the first span it finds, or just in the header
if ( $t.find('.' + ts.css.icon).length ) {
icn = $t.find('.' + ts.css.icon).clone(true);
$t.find('.tablesorter-header-inner').html( th[j] ).append(icn);
if ( $h.find('.' + ts.css.icon).length ) {
icon = $h.find('.' + ts.css.icon).clone(true);
$h.find('.tablesorter-header-inner').html( th[j] ).append(icon);
if ( hsh && $sh.length ) {
icn = $sh.eq(j).find('.' + ts.css.icon).clone(true);
$sh.eq(j).find('.tablesorter-header-inner').html( th[j] ).append(icn);
icon = $sh.eq(j).find('.' + ts.css.icon).clone(true);
$sh.eq(j).find('.tablesorter-header-inner').html( th[j] ).append(icon);
}
} else {
$t.find('.tablesorter-header-inner').html( th[j] );
$h.find('.tablesorter-header-inner').html( th[j] );
if (hsh && $sh.length) {
$sh.eq(j).find('.tablesorter-header-inner').html( th[j] );
}
}
$f.eq(j).html( th[j] );
});
}
}
}
if (c.showProcessing) {
Expand All @@ -479,15 +481,15 @@
p.last.currentFilters = p.currentFilters;
p.last.sortList = (c.sortList || []).join(',');
updatePageDisplay(table, p, false);
$t.trigger('updateCache', [function(){
$table.trigger('updateCache', [function(){
if (p.initialized) {
// apply widgets after table has rendered & after a delay to prevent
// multiple applyWidget blocking code from blocking this trigger
setTimeout(function(){
if (c.debug) {
ts.log('Pager: Triggering pagerChange');
}
$t
$table
.trigger('applyWidgets')
.trigger('pagerChange', p);
updatePageDisplay(table, p, true);
Expand Down Expand Up @@ -649,6 +651,7 @@
},

showAllRows = function(table, p){
var index, $controls, len;
if ( p.ajax ) {
pagerArrows(p, true);
} else {
Expand All @@ -669,9 +672,15 @@
}
}
// disable size selector
p.$size.add(p.$goto).add(p.$container.find('.ts-startRow, .ts-page')).each(function(){
$(this).attr('aria-disabled', 'true').addClass(p.cssDisabled)[0].disabled = true;
});
$controls = p.$size
.add( p.$goto )
.add( p.$container.find( '.ts-startRow, .ts-page' ) );
len = $controls.length;
for ( index = 0; index < len; index++ ) {
$controls.eq( index )
.attr( 'aria-disabled', 'true' )
.addClass( p.cssDisabled )[0].disabled = true;
}
},

// updateCache if delayInit: true
Expand Down Expand Up @@ -1043,13 +1052,15 @@
}() });

// see #486
ts.showError = function(table, message){
$(table).each(function(){
var $row,
c = this.config,
ts.showError = function(table, message) {
var index, $row, c, errorRow,
$table = $( table ),
len = $table.length;
for ( index = 0; index < len; index++ ) {
c = $table[ index ].config;
if ( c ) {
errorRow = c.pager && c.pager.cssErrorRow || c.widgetOptions.pager_css && c.widgetOptions.pager_css.errorRow || 'tablesorter-errorRow';
if (c) {
if (typeof message === 'undefined') {
if ( typeof message === 'undefined' ) {
c.$table.find('thead').find(c.selectorRemove).remove();
} else {
$row = ( /tr\>/.test(message) ? $(message) : $('<tr><td colspan="' + c.columns + '">' + message + '</td></tr>') )
Expand All @@ -1065,7 +1076,7 @@
});
}
}
});
}
};

// extend plugin scope
Expand Down
99 changes: 56 additions & 43 deletions js/jquery.tablesorter.js
Original file line number Diff line number Diff line change
Expand Up @@ -554,14 +554,15 @@
}

function updateHeader(table) {
var s, $th, col,
c = table.config;
c.$headers.each(function(index, th){
$th = $(th);
var index, s, $th, col,
c = table.config,
len = c.$headers.length;
for ( index = 0; index < len; index++ ) {
$th = c.$headers.eq( index );
col = ts.getColumnData( table, c.headers, index, true );
// add 'sorter-false' class if 'parser-false' is set
s = ts.getData( th, col, 'sorter' ) === 'false' || ts.getData( th, col, 'parser' ) === 'false';
th.sortDisabled = s;
s = ts.getData( $th, col, 'sorter' ) === 'false' || ts.getData( $th, col, 'parser' ) === 'false';
$th[0].sortDisabled = s;
$th[ s ? 'addClass' : 'removeClass' ]('sorter-false').attr('aria-disabled', '' + s);
// aria-controls - requires table ID
if (table.id) {
Expand All @@ -571,11 +572,11 @@
$th.attr('aria-controls', table.id);
}
}
});
}
}

function setHeadersCss(table) {
var f, i, j,
var f, h, i, j, $headers, $h, nextSort, txt,
c = table.config,
list = c.sortList,
len = list.length,
Expand Down Expand Up @@ -619,14 +620,19 @@
}
}
// add verbose aria labels
c.$headers.not('.sorter-false').each(function(){
var $this = $(this),
nextSort = this.order[(this.count + 1) % (c.sortReset ? 3 : 2)],
txt = $.trim( $this.text() ) + ': ' +
ts.language[ $this.hasClass(ts.css.sortAsc) ? 'sortAsc' : $this.hasClass(ts.css.sortDesc) ? 'sortDesc' : 'sortNone' ] +
len = c.$headers.length;
$headers = c.$headers.not('.sorter-false');
for ( i = 0; i < len; i++ ) {
$h = $headers.eq( i );
if ( $h.length ) {
h = $headers[ i ];
nextSort = h.order[ ( h.count + 1 ) % ( c.sortReset ? 3 : 2 ) ],
txt = $.trim( $h.text() ) + ': ' +
ts.language[ $h.hasClass( ts.css.sortAsc ) ? 'sortAsc' : $h.hasClass( ts.css.sortDesc ) ? 'sortDesc' : 'sortNone' ] +
ts.language[ nextSort === 0 ? 'nextAsc' : nextSort === 1 ? 'nextDesc' : 'nextNone' ];
$this.attr('aria-label', txt );
});
$h.attr( 'aria-label', txt );
}
}
}

function updateHeaderSortCount( table, list ) {
Expand Down Expand Up @@ -686,23 +692,25 @@
// let any updates complete before initializing a sort
return setTimeout(function(){ initSort(table, cell, event); }, 50);
}
var arry, indx, col, order, s,
var arry, indx, i, col, order, s, $header,
c = table.config,
key = !event[c.sortMultiSortKey],
$table = c.$table;
$table = c.$table,
len = c.$headers.length;
// Only call sortStart if sorting is enabled
$table.trigger('sortStart', table);
// get current column sort order
cell.count = event[c.sortResetKey] ? 2 : (cell.count + 1) % (c.sortReset ? 3 : 2);
// reset all sorts on non-current column - issue #30
if (c.sortRestart) {
indx = cell;
c.$headers.each(function() {
for ( i = 0; i < len; i++ ) {
$header = c.$headers.eq( i );
// only reset counts on columns that weren't just clicked on and if not included in a multisort
if (this !== indx && (key || !$(this).is('.' + ts.css.sortDesc + ',.' + ts.css.sortAsc))) {
this.count = -1;
if ( $header[0] !== indx && ( key || !$header.is('.' + ts.css.sortDesc + ',.' + ts.css.sortAsc) ) ) {
$header[0].count = -1;
}
});
}
}
// get current column index
indx = parseInt( $(cell).attr('data-column'), 10 );
Expand Down Expand Up @@ -1218,7 +1226,7 @@
// automatically add a colgroup with col elements set to a percentage width
ts.fixColumnWidth = function(table) {
table = $(table)[0];
var overallWidth, percent,
var overallWidth, percent, $tbodies, len, index,
c = table.config,
colgroup = c.$table.children('colgroup');
// remove plugin-added colgroup, in case we need to refresh the widths
Expand All @@ -1229,10 +1237,12 @@
colgroup = $('<colgroup class="' + ts.css.colgroup + '">');
overallWidth = c.$table.width();
// only add col for visible columns - fixes #371
c.$tbodies.find('tr:first').children(':visible').each(function() {
percent = parseInt( ( $(this).width() / overallWidth ) * 1000, 10 ) / 10 + '%';
$tbodies = c.$tbodies.find('tr:first').children(':visible'); //.each(function()
len = $tbodies.length;
for ( index = 0; index < len; index++ ) {
percent = parseInt( ( $tbodies.eq( index ).width() / overallWidth ) * 1000, 10 ) / 10 + '%';
colgroup.append( $('<col>').css('width', percent) );
});
}
c.$table.prepend(colgroup);
}
};
Expand Down Expand Up @@ -1424,17 +1434,20 @@

// restore headers
ts.restoreHeaders = function(table){
var $cell,
c = $(table)[0].config;
var index, $cell,
c = $(table)[0].config,
$headers = c.$table.find( c.selectorHeaders ),
len = $headers.length;
// don't use c.$headers here in case header cells were swapped
c.$table.find(c.selectorHeaders).each(function(i){
$cell = $(this);
for ( index = 0; index < len; index++ ) {
// c.$table.find(c.selectorHeaders).each(function(i){
$cell = $headers.eq( index );
// only restore header cells if it is wrapped
// because this is also used by the updateAll method
if ($cell.find('.' + ts.css.headerIn).length){
$cell.html( c.headerContent[i] );
if ( $cell.find( '.' + ts.css.headerIn ).length ) {
$cell.html( c.headerContent[ index ] );
}
});
}
};

ts.destroy = function(table, removeClasses, callback){
Expand Down Expand Up @@ -2121,7 +2134,7 @@
id: 'zebra',
priority: 90,
format: function(table, c, wo) {
var $tb, $tv, $tr, row, even, time, k,
var $tv, $tr, row, even, time, k, i, len,
child = new RegExp(c.cssChildRow, 'i'),
b = c.$tbodies.add( $( c.namespace + '_extra_table' ).children( 'tbody' ) );
if (c.debug) {
Expand All @@ -2130,17 +2143,17 @@
for (k = 0; k < b.length; k++ ) {
// loop through the visible rows
row = 0;
$tb = b.eq(k);
$tv = $tb.children('tr:visible').not(c.selectorRemove);
// revered back to using jQuery each - strangely it's the fastest method
/*jshint loopfunc:true */
$tv.each(function(){
$tr = $(this);
$tv = b.eq( k ).children( 'tr:visible' ).not( c.selectorRemove );
len = $tv.length;
for ( i = 0; i < len; i++ ) {
$tr = $tv.eq( i );
// style child rows the same way the parent row was styled
if (!child.test(this.className)) { row++; }
even = (row % 2 === 0);
$tr.removeClass(wo.zebra[even ? 1 : 0]).addClass(wo.zebra[even ? 0 : 1]);
});
if ( !child.test( $tr[0].className ) ) { row++; }
even = ( row % 2 === 0 );
$tr
.removeClass( wo.zebra[ even ? 1 : 0 ] )
.addClass( wo.zebra[ even ? 0 : 1 ] );
}
}
},
remove: function(table, c, wo, refreshing){
Expand Down
Loading

0 comments on commit 8d2abbb

Please sign in to comment.