1 // TODO: tablesorter shouldn't sort already sorted columns
2 function initTableSorter(tabid) {
5 case 'statustabs_queries':
6 $table = $('#serverstatusqueriesdetails');
9 widgets: ['fast-zebra'],
11 1: { sorter: 'fancyNumber' },
12 2: { sorter: 'fancyNumber' }
16 case 'statustabs_allvars':
17 $table = $('#serverstatusvariables');
20 widgets: ['fast-zebra'],
22 1: { sorter: 'withinSpanNumber' }
27 $table.tablesorter(opts);
28 $table.find('tr:first th')
29 .append('<img class="icon sortableIcon" src="themes/dot.gif" alt="">');
33 $.tablesorter.addParser({
36 return (/^[0-9]?[0-9,\.]*\s?(k|M|G|T|%)?$/).test(s);
38 format: function (s) {
39 var num = jQuery.tablesorter.formatFloat(
40 s.replace(PMA_messages.strThousandsSeparator, '')
41 .replace(PMA_messages.strDecimalSeparator, '.')
45 switch (s.charAt(s.length - 1)) {
49 // Todo: Complete this list (as well as in the regexp a few lines up)
64 return num * Math.pow(10, factor);
69 $.tablesorter.addParser({
70 id: "withinSpanNumber",
72 return (/<span class="original"/).test(s);
74 format: function (s, table, html) {
75 var res = html.innerHTML.match(/<span(\s*style="display:none;"\s*)?\s*class="original">(.*)?<\/span>/);
76 return (res && res.length >= 3) ? res[2] : 0;
81 // faster zebra widget: no row visibility check, faster css class switching, no cssChildRow check
82 $.tablesorter.addWidget({
84 format: function (table) {
85 if (table.config.debug) {
86 var time = new Date();
88 $("tr:even", table.tBodies[0])
89 .removeClass(table.config.widgetZebra.css[0])
90 .addClass(table.config.widgetZebra.css[1]);
91 $("tr:odd", table.tBodies[0])
92 .removeClass(table.config.widgetZebra.css[1])
93 .addClass(table.config.widgetZebra.css[0]);
94 if (table.config.debug) {
95 $.tablesorter.benchmark("Applying Fast-Zebra widget", time);