mirror of
https://github.com/Mottie/tablesorter.git
synced 2025-01-12 15:24:21 +00:00
Added $.tablesorter.addInstanceMethods function which allows one
to define config object instance methods. Refactored getting the column header using config-object method $columnHeader.
This commit is contained in:
parent
fb9ad1acac
commit
c71e8f6220
@ -5294,6 +5294,43 @@ $('table').trigger( 'search', [['', '', '', '', 'orange']] ); // find orange in
|
|||||||
</td>
|
</td>
|
||||||
<td></td>
|
<td></td>
|
||||||
</tr>
|
</tr>
|
||||||
|
<tr id="variable-instanceMethods">
|
||||||
|
<td><a href="#" class="permalink">$.tablesorter.instanceMethods</a></td>
|
||||||
|
<td>Object</td>
|
||||||
|
<td>This is an object of all instance methods of config object. They can be added using the <a href="#function-addInstanceMethods"><code>addInstanceMethods</code></a> function before table initialization.
|
||||||
|
<div class="collapsible">
|
||||||
|
<pre class="prettyprint lang-js">
|
||||||
|
$.tablesorter.addInstanceMethods({
|
||||||
|
columnSum: function(colNumber) {
|
||||||
|
var sum = 0, tbodyIndex, normalizedRows, rowIndex;
|
||||||
|
// `this` refer to config object
|
||||||
|
for (tbodyIndex = 0; tbodyIndex < this.$tbodies.length; ++tbodyIndex){
|
||||||
|
normalizedRows = this.cache[tbodyIndex].normalized;
|
||||||
|
for (rowIndex = 0; rowIndex < normalizedRows.length; ++rowIndex) {
|
||||||
|
sum += normalizedRows[rowIndex][colNumber];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return sum;
|
||||||
|
},
|
||||||
|
columnMean: function(colNumber) {
|
||||||
|
return this.columnSum(colNumber) / this.totalRows;
|
||||||
|
},
|
||||||
|
});
|
||||||
|
|
||||||
|
$('table').tablesorter();
|
||||||
|
c = $('table')[0].config;
|
||||||
|
console.log('sum of third column: ' + c.columnSum(2));
|
||||||
|
console.log('mean of third column: ' + c.columnMean(2));
|
||||||
|
</pre>
|
||||||
|
Some predefined instance methods are already defined:
|
||||||
|
<ul>
|
||||||
|
<li><code>c.$columnHeader(n, options)</code> returns n-th header cell.</li>
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
<td></td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
</tbody>
|
</tbody>
|
||||||
|
|
||||||
<!-- non-sorting tbody -->
|
<!-- non-sorting tbody -->
|
||||||
@ -6173,6 +6210,20 @@ $.tablesorter.isValueInArray(2, sortList);</pre>
|
|||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
|
<tr id="function-addInstanceMethods">
|
||||||
|
<td><a href="#" class="permalink">addInstanceMethods</a></td>
|
||||||
|
<td>This function allows to add custom methods for config object.
|
||||||
|
<div class="collapsible"><br>
|
||||||
|
Access it as follows:
|
||||||
|
<pre class="prettyprint lang-js">$.tablesorter.addInstanceMethods(methods);</pre>
|
||||||
|
<ul>
|
||||||
|
<li><code>methods</code> - an object containing methods to be added, indexed by method names. These methods can use config object by refering <code>this</code></li>
|
||||||
|
</ul>
|
||||||
|
Take a look at <a href="#variable-instanceMethods">instanceMethods</a> variable description for more details.
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
<tr id="function-getparserbyid">
|
<tr id="function-getparserbyid">
|
||||||
<td><a href="#" class="permalink">getParserById</a></td>
|
<td><a href="#" class="permalink">getParserById</a></td>
|
||||||
<td>This function returns the named parser object.
|
<td>This function returns the named parser object.
|
||||||
|
@ -154,6 +154,18 @@
|
|||||||
nextNone : 'activate to remove the sort'
|
nextNone : 'activate to remove the sort'
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// These methods can be applied on table.config instance
|
||||||
|
ts.instanceMethods = {
|
||||||
|
// Returns a jQuery object of n-th column header
|
||||||
|
$columnHeader: function(n, options) {
|
||||||
|
var $headers, lastOnly;
|
||||||
|
options = options || {},
|
||||||
|
$headers = (options.headers !== undefined) ? $(options.headers) : this.$headers;
|
||||||
|
lastOnly = (options.lastOnly !== undefined) ? options.lastOnly : true;
|
||||||
|
return lastOnly ? $headers.filter('[data-column="' + n + '"]:last') : $headers.filter('[data-column="' + n + '"]');
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
/* debuging utils */
|
/* debuging utils */
|
||||||
function log() {
|
function log() {
|
||||||
var a = arguments[0],
|
var a = arguments[0],
|
||||||
@ -256,7 +268,7 @@
|
|||||||
if (rows.length) {
|
if (rows.length) {
|
||||||
l = c.columns; // rows[j].cells.length;
|
l = c.columns; // rows[j].cells.length;
|
||||||
for (i = 0; i < l; i++) {
|
for (i = 0; i < l; i++) {
|
||||||
h = c.$headers.filter('[data-column="' + i + '"]:last');
|
h = c.$columnHeader(i);
|
||||||
// get column indexed table cell
|
// get column indexed table cell
|
||||||
ch = ts.getColumnData( table, c.headers, i );
|
ch = ts.getColumnData( table, c.headers, i );
|
||||||
// get column parser/extractor
|
// get column parser/extractor
|
||||||
@ -561,7 +573,7 @@
|
|||||||
// direction = 2 means reset!
|
// direction = 2 means reset!
|
||||||
if (list[i][1] !== 2) {
|
if (list[i][1] !== 2) {
|
||||||
// multicolumn sorting updating - choose the :last in case there are nested columns
|
// multicolumn sorting updating - choose the :last in case there are nested columns
|
||||||
f = c.$headers.not('.sorter-false').filter('[data-column="' + list[i][0] + '"]' + (len === 1 ? ':last' : '') );
|
f = c.$columnHeader(list[i][0], {lastOnly: (len === 1)}).not('.sorter-false');
|
||||||
if (f.length) {
|
if (f.length) {
|
||||||
for (j = 0; j < f.length; j++) {
|
for (j = 0; j < f.length; j++) {
|
||||||
if (!f[j].sortDisabled) {
|
if (!f[j].sortDisabled) {
|
||||||
@ -601,7 +613,7 @@
|
|||||||
// ensure all sortList values are numeric - fixes #127
|
// ensure all sortList values are numeric - fixes #127
|
||||||
col = parseInt(v[0], 10);
|
col = parseInt(v[0], 10);
|
||||||
// make sure header exists
|
// make sure header exists
|
||||||
o = c.$headers.filter('[data-column="' + col + '"]:last')[0];
|
o = c.$columnHeader(col)[0];
|
||||||
if (o) { // prevents error if sorton array is wrong
|
if (o) { // prevents error if sorton array is wrong
|
||||||
// o.count = o.count + 1;
|
// o.count = o.count + 1;
|
||||||
t = ('' + v[1]).match(/^(1|d|s|o|n)/);
|
t = ('' + v[1]).match(/^(1|d|s|o|n)/);
|
||||||
@ -705,7 +717,7 @@
|
|||||||
// reverse the sorting direction
|
// reverse the sorting direction
|
||||||
for (col = 0; col < c.sortList.length; col++) {
|
for (col = 0; col < c.sortList.length; col++) {
|
||||||
s = c.sortList[col];
|
s = c.sortList[col];
|
||||||
order = c.$headers.filter('[data-column="' + s[0] + '"]:last')[0];
|
order = c.$columnHeader( s[0] )[0];
|
||||||
if (s[0] === indx) {
|
if (s[0] === indx) {
|
||||||
// order.count seems to be incorrect when compared to cell.count
|
// order.count seems to be incorrect when compared to cell.count
|
||||||
s[1] = order.order[cell.count];
|
s[1] = order.order[cell.count];
|
||||||
@ -1051,7 +1063,7 @@
|
|||||||
return this.each(function() {
|
return this.each(function() {
|
||||||
var table = this,
|
var table = this,
|
||||||
// merge & extend config options
|
// merge & extend config options
|
||||||
c = $.extend(true, {}, ts.defaults, settings);
|
c = $.extend(true, {}, ts.defaults, settings, ts.instanceMethods);
|
||||||
// save initial settings
|
// save initial settings
|
||||||
c.originalSettings = settings;
|
c.originalSettings = settings;
|
||||||
// create a table from data (build table widget)
|
// create a table from data (build table widget)
|
||||||
@ -1600,6 +1612,12 @@
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Use it to add a set of methods to table.config which will be available for all tables.
|
||||||
|
// This should be done before table initialization
|
||||||
|
ts.addInstanceMethods = function(methods) {
|
||||||
|
$.extend(ts.instanceMethods, methods);
|
||||||
|
};
|
||||||
|
|
||||||
ts.getParserById = function(name) {
|
ts.getParserById = function(name) {
|
||||||
/*jshint eqeqeq:false */
|
/*jshint eqeqeq:false */
|
||||||
if (name == 'false') { return false; }
|
if (name == 'false') { return false; }
|
||||||
@ -1955,7 +1973,7 @@
|
|||||||
if (s) {
|
if (s) {
|
||||||
var date, d,
|
var date, d,
|
||||||
c = table.config,
|
c = table.config,
|
||||||
ci = c.$headers.filter('[data-column="' + cellIndex + '"]:last'),
|
ci = c.$columnHeader(cellIndex),
|
||||||
format = ci.length && ci[0].dateFormat || ts.getData( ci, ts.getColumnData( table, c.headers, cellIndex ), 'dateFormat') || c.dateFormat;
|
format = ci.length && ci[0].dateFormat || ts.getData( ci, ts.getColumnData( table, c.headers, cellIndex ), 'dateFormat') || c.dateFormat;
|
||||||
d = s.replace(/\s+/g, ' ').replace(/[\-.,]/g, '/'); // escaped - because JSHint in Firefox was showing it as an error
|
d = s.replace(/\s+/g, ' ').replace(/[\-.,]/g, '/'); // escaped - because JSHint in Firefox was showing it as an error
|
||||||
if (format === 'mmddyyyy') {
|
if (format === 'mmddyyyy') {
|
||||||
|
@ -47,7 +47,7 @@
|
|||||||
b, t,
|
b, t,
|
||||||
// process number here to get a numerical format (us or eu)
|
// process number here to get a numerical format (us or eu)
|
||||||
n = $.tablesorter.formatFloat(s.replace(/[^\w,. \-()]/g, ""), table),
|
n = $.tablesorter.formatFloat(s.replace(/[^\w,. \-()]/g, ""), table),
|
||||||
$t = table.config.$headers.filter('[data-column="' + cellIndex + '"]'),
|
$t = table.config.$columnHeader(cellIndex, {lastOnly: false}),
|
||||||
m = $t.data('metric');
|
m = $t.data('metric');
|
||||||
if (!m) {
|
if (!m) {
|
||||||
// stored values
|
// stored values
|
||||||
|
@ -36,7 +36,7 @@ ts.filterFormatter.select2 = function($cell, indx, select2Def) {
|
|||||||
$cell.find('.select2').select2('val', val);
|
$cell.find('.select2').select2('val', val);
|
||||||
updateSelect2();
|
updateSelect2();
|
||||||
}),
|
}),
|
||||||
$header = c.$headers.filter('[data-column="' + indx + '"]:last'),
|
$header = c.$columnHeader(indx),
|
||||||
onlyAvail = $header.hasClass(wo.filter_onlyAvail),
|
onlyAvail = $header.hasClass(wo.filter_onlyAvail),
|
||||||
$shcell = [],
|
$shcell = [],
|
||||||
matchPrefix = o.match ? '' : '^',
|
matchPrefix = o.match ? '' : '^',
|
||||||
|
@ -209,7 +209,7 @@ ts.filter = {
|
|||||||
parsed = data.parsed[index],
|
parsed = data.parsed[index],
|
||||||
query = ts.filter.parseFilter(c, data.iFilter.replace(ts.filter.regex.orReplace, "|"), index, parsed);
|
query = ts.filter.parseFilter(c, data.iFilter.replace(ts.filter.regex.orReplace, "|"), index, parsed);
|
||||||
// look for an exact match with the "or" unless the "filter-match" class is found
|
// look for an exact match with the "or" unless the "filter-match" class is found
|
||||||
if (!c.$headers.filter('[data-column="' + index + '"]:last').hasClass('filter-match') && /\|/.test(query)) {
|
if (!c.$columnHeader(index).hasClass('filter-match') && /\|/.test(query)) {
|
||||||
// show all results while using filter match. Fixes #727
|
// show all results while using filter match. Fixes #727
|
||||||
if (query[ query.length - 1 ] === '|') { query += '*'; }
|
if (query[ query.length - 1 ] === '|') { query += '*'; }
|
||||||
query = data.anyMatch && $.isArray(data.rowArray) ? '(' + query + ')' : '^(' + query + ')$';
|
query = data.anyMatch && $.isArray(data.rowArray) ? '(' + query + ')' : '^(' + query + ')$';
|
||||||
@ -330,7 +330,7 @@ ts.filter = {
|
|||||||
fxn = ts.getColumnData( table, wo.filter_functions, column );
|
fxn = ts.getColumnData( table, wo.filter_functions, column );
|
||||||
if (fxn) {
|
if (fxn) {
|
||||||
// remove "filter-select" from header otherwise the options added here are replaced with all options
|
// remove "filter-select" from header otherwise the options added here are replaced with all options
|
||||||
$header = c.$headers.filter('[data-column="' + column + '"]:last').removeClass('filter-select');
|
$header = c.$columnHeader(column).removeClass('filter-select');
|
||||||
// don't build select if "filter-false" or "parser-false" set
|
// don't build select if "filter-false" or "parser-false" set
|
||||||
noSelect = !($header.hasClass('filter-false') || $header.hasClass('parser-false'));
|
noSelect = !($header.hasClass('filter-false') || $header.hasClass('parser-false'));
|
||||||
options = '';
|
options = '';
|
||||||
@ -468,7 +468,7 @@ ts.filter = {
|
|||||||
// if no filters saved, then check default settings
|
// if no filters saved, then check default settings
|
||||||
if (filters.join('') === '') {
|
if (filters.join('') === '') {
|
||||||
for (indx = 0; indx < c.columns; indx++) {
|
for (indx = 0; indx < c.columns; indx++) {
|
||||||
filters[indx] = c.$headers.filter('[data-column="' + indx + '"]:last').attr(wo.filter_defaultAttrib) || filters[indx];
|
filters[indx] = c.$columnHeader(indx).attr(wo.filter_defaultAttrib) || filters[indx];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
c.$table.data('lastSearch', filters);
|
c.$table.data('lastSearch', filters);
|
||||||
@ -497,7 +497,7 @@ ts.filter = {
|
|||||||
for (column = 0; column < columns; column++) {
|
for (column = 0; column < columns; column++) {
|
||||||
disabled = false;
|
disabled = false;
|
||||||
// assuming last cell of a column is the main column
|
// assuming last cell of a column is the main column
|
||||||
$header = c.$headers.filter('[data-column="' + column + '"]:last');
|
$header = c.$columnHeader(column);
|
||||||
ffxn = ts.getColumnData( table, wo.filter_functions, column );
|
ffxn = ts.getColumnData( table, wo.filter_functions, column );
|
||||||
buildSelect = (wo.filter_functions && ffxn && typeof ffxn !== "function" ) ||
|
buildSelect = (wo.filter_functions && ffxn && typeof ffxn !== "function" ) ||
|
||||||
$header.hasClass('filter-select');
|
$header.hasClass('filter-select');
|
||||||
@ -784,7 +784,7 @@ ts.filter = {
|
|||||||
data.parsed = c.$headers.map(function(columnIndex) {
|
data.parsed = c.$headers.map(function(columnIndex) {
|
||||||
return c.parsers && c.parsers[columnIndex] && c.parsers[columnIndex].parsed ||
|
return c.parsers && c.parsers[columnIndex] && c.parsers[columnIndex].parsed ||
|
||||||
// getData won't return "parsed" if other "filter-" class names exist (e.g. <th class="filter-select filter-parsed">)
|
// getData won't return "parsed" if other "filter-" class names exist (e.g. <th class="filter-select filter-parsed">)
|
||||||
ts.getData && ts.getData(c.$headers.filter('[data-column="' + columnIndex + '"]:last'), ts.getColumnData( table, c.headers, columnIndex ), 'filter') === 'parsed' ||
|
ts.getData && ts.getData(c.$columnHeader(columnIndex), ts.getColumnData( table, c.headers, columnIndex ), 'filter') === 'parsed' ||
|
||||||
$(this).hasClass('filter-parsed');
|
$(this).hasClass('filter-parsed');
|
||||||
}).get();
|
}).get();
|
||||||
|
|
||||||
@ -860,7 +860,7 @@ ts.filter = {
|
|||||||
// don't search only filtered if the value is negative ('> -10' => '> -100' will ignore hidden rows)
|
// don't search only filtered if the value is negative ('> -10' => '> -100' will ignore hidden rows)
|
||||||
!(/(>=?\s*-\d)/.test(val) || /(<=?\s*\d)/.test(val)) &&
|
!(/(>=?\s*-\d)/.test(val) || /(<=?\s*\d)/.test(val)) &&
|
||||||
// if filtering using a select without a "filter-match" class (exact match) - fixes #593
|
// if filtering using a select without a "filter-match" class (exact match) - fixes #593
|
||||||
!( val !== '' && c.$filters && c.$filters.eq(indx).find('select').length && !c.$headers.filter('[data-column="' + indx + '"]:last').hasClass('filter-match') );
|
!( val !== '' && c.$filters && c.$filters.eq(indx).find('select').length && !c.$columnHeader(indx).hasClass('filter-match') );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
notFiltered = $rows.not('.' + wo.filter_filteredRow).length;
|
notFiltered = $rows.not('.' + wo.filter_filteredRow).length;
|
||||||
@ -990,7 +990,7 @@ ts.filter = {
|
|||||||
// data.iFilter = case insensitive (if wo.filter_ignoreCase is true), data.filter = case sensitive
|
// data.iFilter = case insensitive (if wo.filter_ignoreCase is true), data.filter = case sensitive
|
||||||
data.iFilter = wo.filter_ignoreCase ? (data.filter || '').toLocaleLowerCase() : data.filter;
|
data.iFilter = wo.filter_ignoreCase ? (data.filter || '').toLocaleLowerCase() : data.filter;
|
||||||
fxn = ts.getColumnData( table, wo.filter_functions, columnIndex );
|
fxn = ts.getColumnData( table, wo.filter_functions, columnIndex );
|
||||||
$cell = c.$headers.filter('[data-column="' + columnIndex + '"]:last');
|
$cell = c.$columnHeader(columnIndex);
|
||||||
hasSelect = $cell.hasClass('filter-select');
|
hasSelect = $cell.hasClass('filter-select');
|
||||||
if ( fxn || ( hasSelect && val ) ) {
|
if ( fxn || ( hasSelect && val ) ) {
|
||||||
if (fxn === true || hasSelect) {
|
if (fxn === true || hasSelect) {
|
||||||
@ -1093,7 +1093,7 @@ ts.filter = {
|
|||||||
return $.inArray(value, arry) === indx;
|
return $.inArray(value, arry) === indx;
|
||||||
});
|
});
|
||||||
|
|
||||||
if (c.$headers.filter('[data-column="' + column + '"]:last').hasClass('filter-select-nosort')) {
|
if (c.$columnHeader(column).hasClass('filter-select-nosort')) {
|
||||||
// unsorted select options
|
// unsorted select options
|
||||||
return arry;
|
return arry;
|
||||||
} else {
|
} else {
|
||||||
@ -1146,7 +1146,7 @@ ts.filter = {
|
|||||||
// check if has class filtered
|
// check if has class filtered
|
||||||
if (onlyAvail && row.className.match(wo.filter_filteredRow)) { continue; }
|
if (onlyAvail && row.className.match(wo.filter_filteredRow)) { continue; }
|
||||||
// get non-normalized cell content
|
// get non-normalized cell content
|
||||||
if (wo.filter_useParsedData || c.parsers[column].parsed || c.$headers.filter('[data-column="' + column + '"]:last').hasClass('filter-parsed')) {
|
if (wo.filter_useParsedData || c.parsers[column].parsed || c.$columnHeader(column).hasClass('filter-parsed')) {
|
||||||
arry.push( '' + cache.normalized[rowIndex][column] );
|
arry.push( '' + cache.normalized[rowIndex][column] );
|
||||||
} else {
|
} else {
|
||||||
cell = row.cells[column];
|
cell = row.cells[column];
|
||||||
@ -1165,7 +1165,7 @@ ts.filter = {
|
|||||||
var indx, val, txt, t, $filters, $filter,
|
var indx, val, txt, t, $filters, $filter,
|
||||||
c = table.config,
|
c = table.config,
|
||||||
wo = c.widgetOptions,
|
wo = c.widgetOptions,
|
||||||
node = c.$headers.filter('[data-column="' + column + '"]:last'),
|
node = c.$columnHeader(column),
|
||||||
// t.data('placeholder') won't work in jQuery older than 1.4.3
|
// t.data('placeholder') won't work in jQuery older than 1.4.3
|
||||||
options = '<option value="">' + ( node.data('placeholder') || node.attr('data-placeholder') || wo.filter_placeholder.select || '' ) + '</option>',
|
options = '<option value="">' + ( node.data('placeholder') || node.attr('data-placeholder') || wo.filter_placeholder.select || '' ) + '</option>',
|
||||||
// Get curent filter value
|
// Get curent filter value
|
||||||
@ -1220,7 +1220,7 @@ ts.filter = {
|
|||||||
columns = c.columns;
|
columns = c.columns;
|
||||||
// build default select dropdown
|
// build default select dropdown
|
||||||
for (columnIndex = 0; columnIndex < columns; columnIndex++) {
|
for (columnIndex = 0; columnIndex < columns; columnIndex++) {
|
||||||
$header = c.$headers.filter('[data-column="' + columnIndex + '"]:last');
|
$header = c.$columnHeader(columnIndex);
|
||||||
noSelect = !($header.hasClass('filter-false') || $header.hasClass('parser-false'));
|
noSelect = !($header.hasClass('filter-false') || $header.hasClass('parser-false'));
|
||||||
// look for the filter-select class; build/update it if found
|
// look for the filter-select class; build/update it if found
|
||||||
if (($header.hasClass('filter-select') || ts.getColumnData( table, wo.filter_functions, columnIndex ) === true) && noSelect) {
|
if (($header.hasClass('filter-select') || ts.getColumnData( table, wo.filter_functions, columnIndex ) === true) && noSelect) {
|
||||||
|
@ -29,7 +29,7 @@
|
|||||||
$headers = [];
|
$headers = [];
|
||||||
// set up variables
|
// set up variables
|
||||||
for ( column = 0; column < c.columns; column++ ) {
|
for ( column = 0; column < c.columns; column++ ) {
|
||||||
$headers[ column ] = c.$headers.filter('[data-column="' + column + '"]:last');
|
$headers[ column ] = c.$columnHeader(column);
|
||||||
formatter[ column ] = ts.getColumnData( c.table, wo.formatter_column, column ) || false;
|
formatter[ column ] = ts.getColumnData( c.table, wo.formatter_column, column ) || false;
|
||||||
}
|
}
|
||||||
// main loop
|
// main loop
|
||||||
|
@ -66,12 +66,12 @@ ts.grouping = {
|
|||||||
// clear pager saved spacer height (in case the rows are collapsed)
|
// clear pager saved spacer height (in case the rows are collapsed)
|
||||||
c.$table.data('pagerSavedHeight', 0);
|
c.$table.data('pagerSavedHeight', 0);
|
||||||
}
|
}
|
||||||
if (column >= 0 && !c.$headers.filter('[data-column="' + column + '"]:last').hasClass('group-false')) {
|
if (column >= 0 && !c.$columnHeader(column).hasClass('group-false')) {
|
||||||
wo.group_currentGroup = ''; // save current groups
|
wo.group_currentGroup = ''; // save current groups
|
||||||
wo.group_currentGroups = {};
|
wo.group_currentGroups = {};
|
||||||
|
|
||||||
// group class finds "group-{word/separator/letter/number/date/false}-{optional:#/year/month/day/week/time}"
|
// group class finds "group-{word/separator/letter/number/date/false}-{optional:#/year/month/day/week/time}"
|
||||||
groupClass = (c.$headers.filter('[data-column="' + column + '"]:last').attr('class') || '').match(/(group-\w+(-\w+)?)/g);
|
groupClass = (c.$columnHeader(column).attr('class') || '').match(/(group-\w+(-\w+)?)/g);
|
||||||
// grouping = [ 'group', '{word/separator/letter/number/date/false}', '{#/year/month/day/week/time}' ]
|
// grouping = [ 'group', '{word/separator/letter/number/date/false}', '{#/year/month/day/week/time}' ]
|
||||||
grouping = groupClass ? groupClass[0].split('-') : ['group','letter',1]; // default to letter 1
|
grouping = groupClass ? groupClass[0].split('-') : ['group','letter',1]; // default to letter 1
|
||||||
|
|
||||||
@ -97,14 +97,14 @@ ts.grouping = {
|
|||||||
// fixes #438
|
// fixes #438
|
||||||
if (ts.grouping.types[grouping[1]]) {
|
if (ts.grouping.types[grouping[1]]) {
|
||||||
currentGroup = norm_rows[rowIndex] ?
|
currentGroup = norm_rows[rowIndex] ?
|
||||||
ts.grouping.types[grouping[1]]( c, c.$headers.filter('[data-column="' + column + '"]:last'), norm_rows[rowIndex][column], /date/.test(groupClass) ?
|
ts.grouping.types[grouping[1]]( c, c.$columnHeader(column), norm_rows[rowIndex][column], /date/.test(groupClass) ?
|
||||||
grouping[2] : parseInt(grouping[2] || 1, 10) || 1, group, lang ) : currentGroup;
|
grouping[2] : parseInt(grouping[2] || 1, 10) || 1, group, lang ) : currentGroup;
|
||||||
if (group !== currentGroup) {
|
if (group !== currentGroup) {
|
||||||
group = currentGroup;
|
group = currentGroup;
|
||||||
// show range if number > 1
|
// show range if number > 1
|
||||||
if (grouping[1] === 'number' && grouping[2] > 1 && currentGroup !== '') {
|
if (grouping[1] === 'number' && grouping[2] > 1 && currentGroup !== '') {
|
||||||
currentGroup += ' - ' + (parseInt(currentGroup, 10) +
|
currentGroup += ' - ' + (parseInt(currentGroup, 10) +
|
||||||
((parseInt(grouping[2],10) - 1) * (c.$headers.filter('[data-column="' + column + '"]:last').hasClass(ts.css.sortAsc) ? 1 : -1)));
|
((parseInt(grouping[2],10) - 1) * (c.$columnHeader(column).hasClass(ts.css.sortAsc) ? 1 : -1)));
|
||||||
}
|
}
|
||||||
if ($.isFunction(wo.group_formatter)) {
|
if ($.isFunction(wo.group_formatter)) {
|
||||||
currentGroup = wo.group_formatter((currentGroup || '').toString(), column, table, c, wo) || currentGroup;
|
currentGroup = wo.group_formatter((currentGroup || '').toString(), column, table, c, wo) || currentGroup;
|
||||||
|
@ -97,7 +97,7 @@ tablereflow = {
|
|||||||
|
|
||||||
// add <b> to every table cell with thead cell contents
|
// add <b> to every table cell with thead cell contents
|
||||||
for (i = 0; i < cols; i++) {
|
for (i = 0; i < cols; i++) {
|
||||||
$hdr = c.$headers.filter('[data-column="' + i + '"]');
|
$hdr = c.$columnHeader(i, {lastOnly: false});
|
||||||
if ($hdr.length > 1) {
|
if ($hdr.length > 1) {
|
||||||
txt = [];
|
txt = [];
|
||||||
/*jshint loopfunc:true */
|
/*jshint loopfunc:true */
|
||||||
|
@ -109,7 +109,7 @@ ts.addWidget({
|
|||||||
.bind('mousedown', function(event) {
|
.bind('mousedown', function(event) {
|
||||||
// save header cell and mouse position
|
// save header cell and mouse position
|
||||||
$target = $(event.target).closest('th');
|
$target = $(event.target).closest('th');
|
||||||
var $header = c.$headers.filter('[data-column="' + $target.attr('data-column') + '"]');
|
var $header = c.$columnHeader($target.attr('data-column'), {lastOnly: false});
|
||||||
if ($header.length > 1) { $target = $target.add($header); }
|
if ($header.length > 1) { $target = $target.add($header); }
|
||||||
// if table is not as wide as it's parent, then resize the table
|
// if table is not as wide as it's parent, then resize the table
|
||||||
$next = event.shiftKey ? $target.parent().find('th').not('.resizable-false').filter(':last') : $target.nextAll(':not(.resizable-false)').eq(0);
|
$next = event.shiftKey ? $target.parent().find('th').not('.resizable-false').filter(':last') : $target.nextAll(':not(.resizable-false)').eq(0);
|
||||||
|
@ -130,9 +130,9 @@ ts.addWidget({
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
for (i = 0; i < c.columns; i++) {
|
for (i = 0; i < c.columns; i++) {
|
||||||
$header = c.$headers.add(c.$extraHeaders).not('.sorter-false').filter('[data-column="' + i + '"]');
|
$header = c.$columnHeader(i, {headers: c.$headers.add(c.$extraHeaders), lastOnly: false}).not('.sorter-false');
|
||||||
$icon = (ts.css.icon) ? $header.find('.' + ts.css.icon) : $();
|
$icon = (ts.css.icon) ? $header.find('.' + ts.css.icon) : $();
|
||||||
$h = $headers.not('.sorter-false').filter('[data-column="' + i + '"]:last');
|
$h = c.$columnHeader(i, {headers: $headers}).not('.sorter-false');
|
||||||
if ($h.length) {
|
if ($h.length) {
|
||||||
$header.removeClass(remove);
|
$header.removeClass(remove);
|
||||||
$icon.removeClass(iconRmv);
|
$icon.removeClass(iconRmv);
|
||||||
|
Loading…
Reference in New Issue
Block a user