jquery-tablesorter 1.21.4 → 1.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (25) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/lib/jquery-tablesorter/version.rb +2 -2
  4. data/vendor/assets/images/jquery-tablesorter/bootstrap-black-unsorted.png +0 -0
  5. data/vendor/assets/images/jquery-tablesorter/metro-black-asc.png +0 -0
  6. data/vendor/assets/images/jquery-tablesorter/metro-black-desc.png +0 -0
  7. data/vendor/assets/images/jquery-tablesorter/metro-white-asc.png +0 -0
  8. data/vendor/assets/images/jquery-tablesorter/metro-white-desc.png +0 -0
  9. data/vendor/assets/javascripts/jquery-tablesorter/jquery.tablesorter.combined.js +63 -43
  10. data/vendor/assets/javascripts/jquery-tablesorter/jquery.tablesorter.js +33 -21
  11. data/vendor/assets/javascripts/jquery-tablesorter/jquery.tablesorter.widgets.js +30 -22
  12. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-columnSelector.js +62 -24
  13. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-currentSort.js +60 -0
  14. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-filter.js +13 -10
  15. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-grouping.js +3 -3
  16. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-mark.js +135 -0
  17. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-math.js +24 -15
  18. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-output.js +4 -4
  19. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-scroller.js +4 -2
  20. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-stickyHeaders.js +10 -5
  21. data/vendor/assets/javascripts/jquery-tablesorter/widgets/widget-uitheme.js +4 -4
  22. data/vendor/assets/stylesheets/jquery-tablesorter/theme.bootstrap.css +2 -2
  23. data/vendor/assets/stylesheets/jquery-tablesorter/theme.bootstrap_2.css +2 -2
  24. data/vendor/assets/stylesheets/jquery-tablesorter/theme.materialize.css +176 -0
  25. metadata +5 -2
@@ -1,4 +1,4 @@
1
- /*! Widget: grouping - updated 7/11/2016 (v2.26.6) *//*
1
+ /*! Widget: grouping - updated 7/31/2016 (v2.27.0) *//*
2
2
  * Requires tablesorter v2.8+ and jQuery 1.7+
3
3
  * by Rob Garrison
4
4
  */
@@ -144,7 +144,7 @@
144
144
  $label = $row.find( '.group-count' );
145
145
  if ( $label.length ) {
146
146
  if ( wo.group_count ) {
147
- $label.html( wo.group_count.replace( /\{num\}/g, $rows.length ) );
147
+ $label.html( wo.group_count.toString().replace( /\{num\}/g, $rows.length ) );
148
148
  }
149
149
  if ( $.isFunction( wo.group_callback ) ) {
150
150
  wo.group_callback( $row.find( 'td' ), $rows, data.column, c.table );
@@ -167,7 +167,7 @@
167
167
  },
168
168
 
169
169
  groupHeaderHTML : function( c, wo, data ) {
170
- var name = ( data.currentGroup || '' ).replace(/</g, '&lt;').replace(/>/g, '&gt;');
170
+ var name = ( data.currentGroup || '' ).toString().replace(/</g, '&lt;').replace(/>/g, '&gt;');
171
171
  return '<tr class="group-header ' + c.selectorRemove.slice(1) +
172
172
  '" unselectable="on" ' + ( c.tabIndex ? 'tabindex="0" ' : '' ) + 'data-group-index="' +
173
173
  data.groupIndex + '">' +
@@ -0,0 +1,135 @@
1
+ /*! Widget: mark.js - updated 7/31/2016 (v2.27.1) *//*
2
+ * Requires tablesorter v2.8+ and jQuery 1.7+
3
+ * by Rob Garrison
4
+ */
5
+ ;( function( $ ) {
6
+ 'use strict';
7
+ var ts = $.tablesorter;
8
+
9
+ ts.mark = {
10
+ init : function( c ) {
11
+ if ( typeof $.fn.mark === 'function' ) {
12
+ var tmp,
13
+ update = c.widgetOptions.mark_tsUpdate;
14
+ c.$table.on( 'filterEnd.tsmark' + ( update ? ' ' + update : '' ), function( e, filters ) {
15
+ // filterEnd passes "config" as the param
16
+ ts.mark.update( c, e.type === 'filterEnd' ? '' : filters );
17
+ });
18
+ // Regex to split up a query
19
+ tmp = '(?:<|=|>|\\||\"|' + "\\'|" +
20
+ '\\s+(?:&&|-|' +
21
+ ( ts.language.and || 'and' ) + '|' +
22
+ ( ts.language.or || 'or' ) + '|' +
23
+ ( ts.language.to || 'to' ) + ')\\s+)';
24
+ ts.mark.regex.filter = new RegExp(tmp, 'gim');
25
+ } else {
26
+ console.warn('Widget-mark not initialized: missing "jquery.mark.js"');
27
+ }
28
+ },
29
+ regex : {
30
+ mark : /^mark_(.+)$/,
31
+ // test for regex (e.g. "/(lorem|ipsum)/gi")
32
+ pure : /^\/((?:\\\/|[^\/])+)\/([mig]{0,3})?$/
33
+ },
34
+ checkRegex : function( regex ) {
35
+ if ( regex instanceof RegExp ) {
36
+ // prevent lock up of mark.js (see https://github.com/julmot/mark.js/issues/55)
37
+ var result = '\u0001\u0002\u0003\u0004\u0005'.match( regex );
38
+ return result === null || result.length < 5;
39
+ }
40
+ return false;
41
+ },
42
+ cleanMatches : function( matches ) {
43
+ var results = [],
44
+ indx = matches && matches.length || 0;
45
+ while ( indx-- ) {
46
+ if ( matches[indx] !== '' ) {
47
+ results[ results.length ] = matches[ indx ];
48
+ }
49
+ }
50
+ return results;
51
+ },
52
+ update : function( c, filters ) {
53
+ var options = {},
54
+ regex = ts.mark.regex,
55
+ $rows = c.$table
56
+ .find( 'tbody tr' )
57
+ .unmark()
58
+ .not( '.' + ( c.widgetOptions.filter_filteredRow || 'filtered' ) );
59
+ filters = filters || $.tablesorter.getFilters( c.$table );
60
+ // extract & save mark options from widgetOptions (prefixed with "mark_")
61
+ // update dynamically
62
+ $.each( filters, function( indx, filter ) {
63
+ if ( filter ) {
64
+ var testRegex = null,
65
+ matches = filter,
66
+ useRegex = false,
67
+ col = indx === c.columns ? '' : ':nth-child(' + ( indx + 1 ) + ')';
68
+ // regular expression entered
69
+ if ( regex.pure.test( filter ) ) {
70
+ matches = regex.pure.exec( filter );
71
+ // ignore "all" matches (i.e. /.*/)
72
+ if (matches[1] === '.*') {
73
+ matches[1] = '';
74
+ }
75
+ try {
76
+ // make sure to include global flag when testing regex
77
+ testRegex = new RegExp( matches[ 1 ], 'gim' );
78
+ matches = new RegExp( matches[ 1 ], matches[ 2 ] );
79
+ } catch (err) {
80
+ matches = null;
81
+ }
82
+ if ( ts.mark.checkRegex( testRegex ) ) {
83
+ $rows.children( col ).markRegExp( matches, options );
84
+ }
85
+ // matches is either null, invalid, or done my markRegExp
86
+ return;
87
+ }
88
+ // all special querys (or, and, wild cards & fuzzy)
89
+ // regex seems to not be consistent here; so use string indexOf
90
+ // fuzzy or wild card matches
91
+ if ( filter.indexOf( '~' ) === 0 ) {
92
+ useRegex = true;
93
+ // fuzzy search separate each letter
94
+ matches = filter.replace( /~/g, '' ).split( '' );
95
+ } else {
96
+ // wild card matching
97
+ if ( filter.indexOf( '?' ) > -1 ) {
98
+ useRegex = true;
99
+ filter = filter.replace( /\?/g, '\\S{1}' );
100
+ }
101
+ if ( filter.indexOf( '*' ) > -1 ) {
102
+ useRegex = true;
103
+ filter = filter.replace( /\*/g, '\\S*' );
104
+ }
105
+ matches = filter.split( regex.filter );
106
+ }
107
+ if ( useRegex && matches && matches.length ) {
108
+ matches = new RegExp( ts.mark.cleanMatches( matches ).join( '.*' ), 'gim' );
109
+ if ( ts.mark.checkRegex( matches ) ) {
110
+ $rows.children( col ).markRegExp( matches, options );
111
+ }
112
+ } else {
113
+ // pass an array of matches
114
+ $rows.children( col ).mark( ts.mark.cleanMatches( matches ), options );
115
+ }
116
+ }
117
+ });
118
+ }
119
+ };
120
+
121
+ ts.addWidget({
122
+ id: 'mark',
123
+ options: {
124
+ mark_tsUpdate : 'markUpdate'
125
+ },
126
+ init : function( table, thisWidget, c, wo ) {
127
+ ts.mark.init( c, wo );
128
+ },
129
+ remove : function( table, c ) {
130
+ var update = c.widgetOptions.mark_tsUpdate;
131
+ c.$table.off( 'filterEnd.tsmark' + ( update ? ' ' + update : '' ) );
132
+ }
133
+ });
134
+
135
+ })( jQuery );
@@ -1,4 +1,4 @@
1
- /*! Widget: math - updated 3/1/2016 (v2.25.5) *//*
1
+ /*! Widget: math - updated 7/31/2016 (v2.27.0) *//*
2
2
  * Requires tablesorter v2.16+ and jQuery 1.7+
3
3
  * by Rob Garrison
4
4
  */
@@ -216,7 +216,7 @@
216
216
  var undef, time, mathAttr, $mathCells, indx, len,
217
217
  changed = false,
218
218
  filters = {};
219
- if ( c.debug ) {
219
+ if ( c.debug || wo.math_debug ) {
220
220
  time = new Date();
221
221
  }
222
222
 
@@ -232,7 +232,6 @@
232
232
  mathAttr = wo.math_dataAttrib;
233
233
  $mathCells = c.$tbodies.children( 'tr' ).children( '[' + mathAttr + ']' );
234
234
  changed = math.mathType( c, $mathCells, wo.math_priority ) || changed;
235
-
236
235
  // only info tbody cells
237
236
  $mathCells = c.$table
238
237
  .children( '.' + c.cssInfoBlock + ', tfoot' )
@@ -257,17 +256,17 @@
257
256
  // trigger an update only if cells inside the tbody changed
258
257
  if ( changed ) {
259
258
  wo.math_isUpdating = true;
260
- if ( c.debug ) {
261
- console[ console.group ? 'group' : 'log' ]( 'Math widget triggering an update after recalculation' );
259
+ if ( c.debug || wo.math_debug ) {
260
+ console[ console.group ? 'group' : 'log' ]( 'Math widget updating the cache after recalculation' );
262
261
  }
263
262
 
264
- // update internal cache
265
- ts.update( c, undef, function(){
263
+ // update internal cache, but ignore "remove-me" rows and do not resort
264
+ ts.updateCache( c, function() {
266
265
  math.updateComplete( c );
267
266
  if ( !init && typeof wo.math_completed === 'function' ) {
268
267
  wo.math_completed( c );
269
268
  }
270
- if ( c.debug ) {
269
+ if ( c.debug || wo.math_debug ) {
271
270
  console.log( 'Math widget update completed' + ts.benchmark( time ) );
272
271
  }
273
272
  });
@@ -275,7 +274,7 @@
275
274
  if ( !init && typeof wo.math_completed === 'function' ) {
276
275
  wo.math_completed( c );
277
276
  }
278
- if ( c.debug ) {
277
+ if ( c.debug || wo.math_debug ) {
279
278
  console.log( 'Math widget found no changes in data' + ts.benchmark( time ) );
280
279
  }
281
280
  }
@@ -284,7 +283,9 @@
284
283
 
285
284
  updateComplete : function( c ) {
286
285
  var wo = c.widgetOptions;
287
- if ( wo.math_isUpdating && c.debug && console.groupEnd ) { console.groupEnd(); }
286
+ if ( wo.math_isUpdating && (c.debug || wo.math_debug ) && console.groupEnd ) {
287
+ console.groupEnd();
288
+ }
288
289
  wo.math_isUpdating = false;
289
290
  },
290
291
 
@@ -299,7 +300,7 @@
299
300
  // mathType is called multiple times if more than one "hasFilter" is used
300
301
  getAll = math.getAll( c, hasFilter );
301
302
  }
302
- if (c.debug) {
303
+ if (c.debug || wo.math_debug) {
303
304
  console[ console.group ? 'group' : 'log' ]( 'Tablesorter Math widget recalculation' );
304
305
  }
305
306
  // $.each is okay here... only 4 priorities
@@ -308,7 +309,7 @@
308
309
  $targetCells = $cells.filter( '[' + mathAttr + '^=' + type + ']' ),
309
310
  len = $targetCells.length;
310
311
  if ( len ) {
311
- if (c.debug) {
312
+ if (c.debug || wo.math_debug) {
312
313
  console[ console.group ? 'group' : 'log' ]( type );
313
314
  }
314
315
  for ( index = 0; index < len; index++ ) {
@@ -324,7 +325,7 @@
324
325
  if ( equations[ formula ] ) {
325
326
  if ( arry.length ) {
326
327
  result = equations[ formula ]( arry, c );
327
- if ( c.debug ) {
328
+ if ( c.debug || wo.math_debug ) {
328
329
  console.log( $el.attr( mathAttr ), hasFilter ? '("' + hasFilter + '")' : '', arry, '=', result );
329
330
  }
330
331
  } else {
@@ -334,10 +335,10 @@
334
335
  changed = math.output( $el, c, result, arry ) || changed;
335
336
  }
336
337
  }
337
- if ( c.debug && console.groupEnd ) { console.groupEnd(); }
338
+ if ( ( c.debug || wo.math_debug ) && console.groupEnd ) { console.groupEnd(); }
338
339
  }
339
340
  });
340
- if ( c.debug && console.groupEnd ) { console.groupEnd(); }
341
+ if ( ( c.debug || wo.math_debug ) && console.groupEnd ) { console.groupEnd(); }
341
342
  return changed;
342
343
  }
343
344
  return false;
@@ -350,7 +351,14 @@
350
351
  changed = false,
351
352
  prev = $cell.html(),
352
353
  mask = $cell.attr( 'data-' + wo.math_data + '-mask' ) || wo.math_mask,
354
+ target = $cell.attr( 'data-' + wo.math_data + '-target' ) || '',
353
355
  result = ts.formatMask( mask, value, wo.math_wrapPrefix, wo.math_wrapSuffix );
356
+ if (target) {
357
+ $el = $cell.find(target);
358
+ if ($el.length) {
359
+ $cell = $el;
360
+ }
361
+ }
354
362
  if ( typeof wo.math_complete === 'function' ) {
355
363
  result = wo.math_complete( $cell, wo, result, value, arry );
356
364
  }
@@ -583,6 +591,7 @@
583
591
  priority: 100,
584
592
  options: {
585
593
  math_data : 'math',
594
+ math_debug : false,
586
595
  // column index to ignore
587
596
  math_ignore : [],
588
597
  // mask info: https://code.google.com/p/javascript-number-formatter/
@@ -1,4 +1,4 @@
1
- /*! Widget: output - updated 1/15/2016 (v2.25.2) *//*
1
+ /*! Widget: output - updated 7/31/2016 (v2.27.0) *//*
2
2
  * Requires tablesorter v2.8+ and jQuery 1.7+
3
3
  * Modified from:
4
4
  * HTML Table to CSV: http://www.kunalbabre.com/projects/table2CSV.php (License unknown?)
@@ -145,8 +145,8 @@
145
145
  });
146
146
  headers = output.processRow(c, $this, true, outputJSON);
147
147
 
148
- // all tbody rows
149
- $rows = $el.children('tbody').children('tr');
148
+ // all tbody rows - do not include widget added rows (e.g. grouping widget headers)
149
+ $rows = $el.children('tbody').children('tr').not(c.selectorRemove);
150
150
 
151
151
  // check for a filter callback function first! because
152
152
  // /^f/.test(function(){ console.log('test'); }) is TRUE! (function is converted to a string)
@@ -193,7 +193,7 @@
193
193
 
194
194
  // callback; if true returned, continue processing
195
195
  if ($.isFunction(wo.output_callback)) {
196
- tmp = wo.output_callback(c, mydata);
196
+ tmp = wo.output_callback(c, mydata, c.pager && c.pager.ajaxObject.url || null);
197
197
  if ( tmp === false ) {
198
198
  return;
199
199
  } else if ( typeof tmp === 'string' ) {
@@ -1,4 +1,4 @@
1
- /*! Widget: scroller - updated 7/11/2016 (v2.26.6) *//*
1
+ /*! Widget: scroller - updated 7/31/2016 (v2.27.0) *//*
2
2
  Copyright (C) 2011 T. Connell & Associates, Inc.
3
3
 
4
4
  Dual-licensed under the MIT and GPL licenses
@@ -77,7 +77,9 @@
77
77
  scroller_barWidth : null
78
78
  },
79
79
  format : function( table, c, wo ) {
80
- if ( !c.isScrolling ) {
80
+ if ( c.isScrolling ) {
81
+ ts.scroller.resize( c, wo );
82
+ } else {
81
83
  // initialize here instead of in widget init to give the
82
84
  // filter widget time to finish building the filter row
83
85
  ts.scroller.setup( c, wo );
@@ -1,4 +1,4 @@
1
- /*! Widget: stickyHeaders - updated 5/1/2016 (v2.26.0) *//*
1
+ /*! Widget: stickyHeaders - updated 7/31/2016 (v2.27.0) *//*
2
2
  * Requires tablesorter v2.8+ and jQuery 1.4.3+
3
3
  * by Rob Garrison
4
4
  */
@@ -61,10 +61,11 @@
61
61
  // **************************
62
62
  ts.addWidget({
63
63
  id: 'stickyHeaders',
64
- priority: 60, // sticky widget must be initialized after the filter widget!
64
+ priority: 55, // sticky widget must be initialized after the filter widget!
65
65
  options: {
66
66
  stickyHeaders : '', // extra class name added to the sticky header row
67
- stickyHeaders_attachTo : null, // jQuery selector or object to attach sticky header to
67
+ stickyHeaders_appendTo : null, // jQuery selector or object to phycially attach the sticky headers
68
+ stickyHeaders_attachTo : null, // jQuery selector or object to attach scroll listener to (overridden by xScroll & yScroll settings)
68
69
  stickyHeaders_xScroll : null, // jQuery selector or object to monitor horizontal scroll position (defaults: xScroll > attachTo > window)
69
70
  stickyHeaders_yScroll : null, // jQuery selector or object to monitor vertical scroll position (defaults: yScroll > attachTo > window)
70
71
  stickyHeaders_offset : 0, // number or jquery selector targeting the position:fixed element
@@ -215,8 +216,12 @@
215
216
 
216
217
  ts.bindEvents(table, $stickyThead.children().children('.' + ts.css.header));
217
218
 
218
- // add stickyheaders AFTER the table. If the table is selected by ID, the original one (first) will be returned.
219
- $table.after( $stickyWrap );
219
+ if (wo.stickyHeaders_appendTo) {
220
+ $(wo.stickyHeaders_appendTo).append( $stickyWrap );
221
+ } else {
222
+ // add stickyheaders AFTER the table. If the table is selected by ID, the original one (first) will be returned.
223
+ $table.after( $stickyWrap );
224
+ }
220
225
 
221
226
  // onRenderHeader is defined, we need to do something about it (fixes #641)
222
227
  if (c.onRenderHeader) {
@@ -1,4 +1,4 @@
1
- /*! Widget: uitheme - updated 7/11/2016 (v2.26.6) */
1
+ /*! Widget: uitheme - updated 7/31/2016 (v2.27.0) */
2
2
  ;(function ($) {
3
3
  'use strict';
4
4
  var ts = $.tablesorter || {};
@@ -37,9 +37,9 @@
37
37
  hover : 'ui-state-hover', // hover class
38
38
  // icon class names
39
39
  icons : 'ui-icon', // icon class added to the <i> in the header
40
- iconSortNone : 'ui-icon-carat-2-n-s', // class name added to icon when column is not sorted
41
- iconSortAsc : 'ui-icon-carat-1-n', // class name added to icon when column has ascending sort
42
- iconSortDesc : 'ui-icon-carat-1-s', // class name added to icon when column has descending sort
40
+ iconSortNone : 'ui-icon-carat-2-n-s ui-icon-caret-2-n-s', // class name added to icon when column is not sorted
41
+ iconSortAsc : 'ui-icon-carat-1-n ui-icon-caret-1-n', // class name added to icon when column has ascending sort
42
+ iconSortDesc : 'ui-icon-carat-1-s ui-icon-caret-1-s', // class name added to icon when column has descending sort
43
43
  filterRow : '',
44
44
  footerRow : '',
45
45
  footerCells : '',
@@ -51,12 +51,12 @@
51
51
 
52
52
  /* black unsorted icon */
53
53
  .tablesorter-bootstrap .bootstrap-icon-unsorted {
54
- background-image: url();
54
+ background-image: url();
55
55
  }
56
56
 
57
57
  /* white unsorted icon */
58
58
  .tablesorter-bootstrap .icon-white.bootstrap-icon-unsorted {
59
- background-image: url();
59
+ background-image: url();
60
60
  }
61
61
 
62
62
  /* since bootstrap (table-striped) uses nth-child(), we just use this to add a zebra stripe color */
@@ -61,12 +61,12 @@
61
61
 
62
62
  /* black unsorted icon */
63
63
  .tablesorter-bootstrap .bootstrap-icon-unsorted {
64
- background-image: url();
64
+ background-image: url();
65
65
  }
66
66
 
67
67
  /* white unsorted icon */
68
68
  .tablesorter-bootstrap .icon-white.bootstrap-icon-unsorted {
69
- background-image: url();
69
+ background-image: url();
70
70
  }
71
71
 
72
72
  /* since bootstrap (table-striped) uses nth-child(), we just use this to add a zebra stripe color */
@@ -0,0 +1,176 @@
1
+ /*************
2
+ Materialize theme (http://materializecss.com/)
3
+ *************/
4
+ /* jQuery materialize Theme */
5
+ .tablesorter-materialize {
6
+ width: 100%;
7
+ }
8
+ .tablesorter-materialize thead th,
9
+ .tablesorter-materialize thead td,
10
+ .tablesorter-materialize tfoot th,
11
+ .tablesorter-materialize tfoot td {
12
+ font: 14px/20px Arial, Sans-serif;
13
+ font-weight: bold;
14
+ padding: 4px;
15
+ margin: 0 0 18px;
16
+ background-color: #eee;
17
+ }
18
+
19
+ .tablesorter-materialize .tablesorter-header {
20
+ cursor: pointer;
21
+ }
22
+ .tablesorter-materialize .sorter-false {
23
+ cursor: default;
24
+ }
25
+
26
+ .tablesorter-materialize .tablesorter-header-inner {
27
+ position: relative;
28
+ padding: 4px 18px 4px 4px;
29
+ }
30
+
31
+ /* sort icons */
32
+ .tablesorter-materialize thead .tablesorter-header {
33
+ background-repeat: no-repeat;
34
+ background-position: center right;
35
+ padding: 4px 18px 4px 4px;
36
+ white-space: normal;
37
+ cursor: pointer;
38
+ }
39
+
40
+ /* black unsorted icon */
41
+ .tablesorter-materialize thead .tablesorter-headerUnSorted {
42
+ /* <svg xmlns="http://www.w3.org/2000/svg" width="18" height="12" viewBox="0 0 24 16"><path d="M15 8 1 8 8 0zM15 9 1 9 8 16z" fill="#222"/></svg> */
43
+ background-image: url();
44
+ }
45
+ /* black asc icon */
46
+ .tablesorter-materialize thead .tablesorter-headerAsc {
47
+ /* <svg xmlns="http://www.w3.org/2000/svg" width="18" height="12" viewBox="0 0 24 16"><path d="M15 11 1 11 8 3z" fill="#222"/></svg> */
48
+ background-image: url();
49
+ }
50
+ /* black desc icon */
51
+ .tablesorter-materialize thead .tablesorter-headerDesc {
52
+ /* <svg xmlns="http://www.w3.org/2000/svg" width="18" height="12" viewBox="0 0 24 16"><path d="M15 6 1 6 8 13z" fill="#222"/></svg> */
53
+ background-image: url();
54
+ }
55
+
56
+ /* white unsorted icon */
57
+ .tablesorter-materialize-dark thead .tablesorter-headerUnSorted {
58
+ /* <svg xmlns="http://www.w3.org/2000/svg" width="18" height="12" viewBox="0 0 24 16"><path d="M15 8 1 8 8 0zM15 9 1 9 8 16z" fill="#fff"/></svg> */
59
+ background-image: url();
60
+ }
61
+ /* white asc icon */
62
+ .tablesorter-materialize-dark thead .tablesorter-headerAsc {
63
+ /* <svg xmlns="http://www.w3.org/2000/svg" width="18" height="12" viewBox="0 0 24 16"><path d="M15 11 1 11 8 3z" fill="#fff"/></svg> */
64
+ background-image: url();
65
+ }
66
+ /* white desc icon */
67
+ .tablesorter-materialize-dark thead .tablesorter-headerDesc {
68
+ /* <svg xmlns="http://www.w3.org/2000/svg" width="18" height="12" viewBox="0 0 24 16"><path d="M15 6 1 6 8 13z" fill="#fff"/></svg> */
69
+ background-image: url();
70
+ }
71
+
72
+ /* since materialize (table-striped) uses nth-child(), we just use this to add a zebra stripe color */
73
+ .tablesorter-materialize > tbody > tr.odd > td,
74
+ .tablesorter-materialize > tbody > tr.tablesorter-hasChildRow.odd:hover ~ tr.tablesorter-hasChildRow.odd ~ .tablesorter-childRow.odd > td {
75
+ background-color: #f9f9f9;
76
+ }
77
+ .tablesorter-materialize > tbody > tr.hover > td,
78
+ .tablesorter-materialize > tbody > tr.odd:hover > td,
79
+ .tablesorter-materialize > tbody > tr.even:hover > td,
80
+ .tablesorter-materialize > tbody > tr.tablesorter-hasChildRow.odd:hover ~ .tablesorter-childRow.odd > td,
81
+ .tablesorter-materialize > tbody > tr.tablesorter-hasChildRow.even:hover ~ .tablesorter-childRow.even > td {
82
+ background-color: #f5f5f5;
83
+ }
84
+ .tablesorter-materialize > tbody > tr.even > td,
85
+ .tablesorter-materialize > tbody > tr.tablesorter-hasChildRow.even:hover ~ tr.tablesorter-hasChildRow.even ~ .tablesorter-childRow.even > td {
86
+ background-color: #fff;
87
+ }
88
+
89
+ /* processing icon */
90
+ .tablesorter-materialize .tablesorter-processing {
91
+ background-image: url('');
92
+ background-position: center center !important;
93
+ background-repeat: no-repeat !important;
94
+ }
95
+
96
+ /* caption */
97
+ .caption {
98
+ background-color: #fff;
99
+ }
100
+
101
+ /* filter widget */
102
+ .tablesorter-materialize .tablesorter-filter-row input.tablesorter-filter,
103
+ .tablesorter-materialize .tablesorter-filter-row select.tablesorter-filter {
104
+ width: 98%;
105
+ margin: 0;
106
+ padding: 4px 6px;
107
+ color: #333;
108
+ -webkit-box-sizing: border-box;
109
+ -moz-box-sizing: border-box;
110
+ box-sizing: border-box;
111
+ -webkit-transition: height 0.1s ease;
112
+ -moz-transition: height 0.1s ease;
113
+ -o-transition: height 0.1s ease;
114
+ transition: height 0.1s ease;
115
+ }
116
+ .tablesorter-materialize .tablesorter-filter-row .tablesorter-filter.disabled {
117
+ background-color: #eee;
118
+ color: #555;
119
+ cursor: not-allowed;
120
+ border: 1px solid #ccc;
121
+ border-radius: 4px;
122
+ box-shadow: 0px 1px 1px rgba(0, 0, 0, 0.075) inset;
123
+ box-sizing: border-box;
124
+ transition: height 0.1s ease;
125
+ }
126
+ .tablesorter-materialize .tablesorter-filter-row {
127
+ background-color: #efefef;
128
+ }
129
+ .tablesorter-materialize .tablesorter-filter-row td {
130
+ background-color: #efefef;
131
+ line-height: normal;
132
+ text-align: center;
133
+ padding: 4px 6px;
134
+ vertical-align: middle;
135
+ -webkit-transition: line-height 0.1s ease;
136
+ -moz-transition: line-height 0.1s ease;
137
+ -o-transition: line-height 0.1s ease;
138
+ transition: line-height 0.1s ease;
139
+ }
140
+ /* hidden filter row */
141
+ .tablesorter-materialize .tablesorter-filter-row.hideme td {
142
+ padding: 2px; /* change this to modify the thickness of the closed border row */
143
+ margin: 0;
144
+ line-height: 0;
145
+ }
146
+ .tablesorter-materialize .tablesorter-filter-row.hideme * {
147
+ height: 1px;
148
+ min-height: 0;
149
+ border: 0;
150
+ padding: 0;
151
+ margin: 0;
152
+ /* don't use visibility: hidden because it disables tabbing */
153
+ opacity: 0;
154
+ filter: alpha(opacity=0);
155
+ }
156
+ /* rows hidden by filtering (needed for child rows) */
157
+ .tablesorter .filtered {
158
+ display: none;
159
+ }
160
+
161
+ /* pager plugin */
162
+ .tablesorter-materialize .tablesorter-pager select {
163
+ padding: 4px 6px;
164
+ display: inline-block;
165
+ width: auto;
166
+ }
167
+ .tablesorter-materialize .tablesorter-pager .pagedisplay {
168
+ border: 0;
169
+ }
170
+
171
+ /* ajax error row */
172
+ .tablesorter .tablesorter-errorRow td {
173
+ text-align: center;
174
+ cursor: pointer;
175
+ background-color: #e6bf99;
176
+ }