mirror of
https://github.com/Mottie/tablesorter.git
synced 2025-01-12 15:24:21 +00:00
parent
caf7432a3c
commit
5608727c80
375
docs/example-widget-sort-tbodies.html
Normal file
375
docs/example-widget-sort-tbodies.html
Normal file
@ -0,0 +1,375 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<title>jQuery plugin: Tablesorter 2.0 - Sort multiple tbodies by primary row</title>
|
||||
|
||||
<!-- jQuery -->
|
||||
<script src="js/jquery-latest.min.js"></script>
|
||||
|
||||
<!-- Demo stuff -->
|
||||
<link class="ui-theme" rel="stylesheet" href="css/jquery-ui.min.css">
|
||||
<script src="js/jquery-ui.min.js"></script>
|
||||
<link rel="stylesheet" href="css/jq.css">
|
||||
<link href="css/prettify.css" rel="stylesheet">
|
||||
<script src="js/prettify.js"></script>
|
||||
<script src="js/docs.js"></script>
|
||||
|
||||
<!-- Tablesorter: required -->
|
||||
<link rel="stylesheet" href="../css/theme.blue.css">
|
||||
<script src="../js/jquery.tablesorter.js"></script>
|
||||
|
||||
<!-- Tablesorter: widgets (optional) -->
|
||||
<!-- <script src="../js/jquery.tablesorter.widgets.js"></script> -->
|
||||
<script src="../js/widgets/widget-filter.js"></script>
|
||||
<script src="../js/widgets/widget-sortTbodies.js"></script>
|
||||
<style>
|
||||
caption { font-weight: bold; font-size: 18px; }
|
||||
th.rank, #table3 th.rank { width: 5%; }
|
||||
th, #table3 th.info { width: 30%; }
|
||||
#table3 th { width: 15%; }
|
||||
.info { background: #ffeaca; color: #333; padding: 2px 5px; border: #cdcdcd 1px solid; }
|
||||
</style>
|
||||
|
||||
<style id="css">/* add different color to child rows - needed css because zebra striping is not applied to
|
||||
info-only tbodies (first table), & row indexing is reset for each tbody (second table), so
|
||||
with only a row + child row, would all end up the same color */
|
||||
#table2 .tablesorter-childRow td {
|
||||
background: #eee;
|
||||
}
|
||||
#table2 .tablesorter-childRow:hover td {
|
||||
background: #ddd;
|
||||
}
|
||||
|
||||
/* Make the primary row stand out */
|
||||
.tablesorter tbody tr.main td {
|
||||
background: #ffeaca;
|
||||
color: #333;
|
||||
}
|
||||
|
||||
/* dark border to make each tbody distinct */
|
||||
#table1 tbody tr.main td,
|
||||
#table2 tbody tr.main td {
|
||||
border-top: 1px solid #777;
|
||||
/* main row is clickable; toggle sibling/child rows */
|
||||
cursor: pointer;
|
||||
}
|
||||
/* no-sort-tbody style 4b7fb4*/
|
||||
.tablesorter-no-sort-tbody td {
|
||||
background: #497baf;
|
||||
color: #fff;
|
||||
}
|
||||
.tablesorter-no-sort-tbody tr:hover td {
|
||||
color: #333;
|
||||
}</style>
|
||||
|
||||
<script id="js">$( function() {
|
||||
|
||||
// settings work for all three demos
|
||||
$( 'table' ).tablesorter({
|
||||
widgets: [ 'sortTbody', 'filter', 'zebra' ],
|
||||
widgetOptions: {
|
||||
sortTbody_primaryRow : '.main',
|
||||
sortTbody_sortRows : false,
|
||||
sortTbody_noSort : 'tablesorter-no-sort-tbody',
|
||||
|
||||
// include child row content while filtering the second demo table
|
||||
filter_childRows : true
|
||||
}
|
||||
});
|
||||
|
||||
// toggle rows in first two demos
|
||||
$( '#table1, #table2' ).find( '.main' ).on( 'click', function() {
|
||||
// hide other rows when clicking on primary row
|
||||
// this is only meant to work with two rows, otherwise use .nextUntil()
|
||||
$( this ).siblings().toggleClass( 'filtered' );
|
||||
});
|
||||
|
||||
// third demo; toggle sort internal rows option
|
||||
$( '.toggle' ).on( 'click', function() {
|
||||
var $this = $( this ),
|
||||
val = $this.text() === 'false';
|
||||
$( '#table3' ).data( 'tablesorter' ).widgetOptions.sortTbody_sortRows = val;
|
||||
$this.text( '' + val );
|
||||
});
|
||||
|
||||
});</script>
|
||||
</head>
|
||||
<body>
|
||||
<div id="banner">
|
||||
<h1>table<em>sorter</em></h1>
|
||||
<h2>Sort multiple tbodies by primary row (beta)</h2>
|
||||
<h3>Flexible client-side table sorting</h3>
|
||||
<a href="index.html">Back to documentation</a>
|
||||
</div>
|
||||
<div id="main">
|
||||
|
||||
<p></p>
|
||||
<br>
|
||||
<div id="root" class="accordion">
|
||||
|
||||
<h3 id="notes"><a href="#">Notes</a></h3>
|
||||
<div>
|
||||
<ul>
|
||||
<li>This widget (<span class="version">v2.22.2</span>) allows the sorting of tbodies (not rows) based on a specified row set by the <code>sortTbody_primaryRow</code> option.</li>
|
||||
<li>This widget replaces the <a href="index.html#cssinfoblock"><code>cssInfoBlock</code></a> setting:
|
||||
<ul>
|
||||
<li>The value is replaced with the value from <code>sortTbody_noSort</code> option so as to include info-only tbodies in the tbody sort.</li>
|
||||
<li>Due to this modification, tbodies with <code>colspan</code> and <code>rowspan</code> cells may not sort or filter as expected, so it would be best to <em>avoid <code>colspan</code> and <code>rowspan</code> cells in the primary row!</em></li>
|
||||
</ul>
|
||||
<li>This widget also modifies the <a href="index.html#serversidesorting"><code>serverSideSorting</code></a> option:
|
||||
<ul>
|
||||
<li>This value is set to <code>true</code> to disable tbody internal row sorting.</li>
|
||||
<li>This value is set to <code>false</code> (default) when the <code>sortTbody_sortRows</code> widget option is <code>true</code>.</li>
|
||||
<li>This modification should not dramatically affect other widgets; at least none that I can think of right now.</li>
|
||||
</ul>
|
||||
<br>
|
||||
</li>
|
||||
<li>In these demos,
|
||||
<ul>
|
||||
<li>Primary Rows are styled with a <span class="info">light yellow background</span> as an indicator.</li>
|
||||
<li>The primary row color difference is important in the <a href="#sort-internal-rows">third table</a> when the sorting of internal rows is enabled (<code>sortTbody_sortRows</code> is <code>true</code>).</li>
|
||||
<li>The first two tables:
|
||||
<ul>
|
||||
<li>Primary rows are clickable. Clicking on them toggles the sibling rows (in the <a href="#table1">first table</a>), or child rows (in the <a href="#table2">second table</a>).</li>
|
||||
<li>Primary rows have a dark top border to add a visual separation of each tbody.</li>
|
||||
<li><span class="label warning">*NOTE*</span> when filtering the content of the <a href="#table1">first table</a>, sibling rows that do not match the query will be hidden. Toggling their view is only possible because the <code>"filtered"</code> class (used by the filter widget & set by the <a href="index.html#widget-filter-filteredrow"><code>filter_filteredRow</code></a> widget option) is toggled.</li>
|
||||
</ul>
|
||||
</li>
|
||||
</ul>
|
||||
<br>
|
||||
</li>
|
||||
<li><span class="label alert">*ALERT*</span> This widget requires tablesorter v2.22.2+ and jQuery 1.4+</li>
|
||||
</ul>
|
||||
</div>
|
||||
|
||||
<h3><a href="#">Options</a></h3>
|
||||
<div>
|
||||
<div>
|
||||
<span class="label label-info">TIP!</span> Click on the link in the function column to reveal full details (or <a href="#" class="toggleAll">toggle</a>|<a href="#" class="showAll">show</a>|<a href="#" class="hideAll">hide</a> all) or double click to update the browser location.
|
||||
</div>
|
||||
<table class="options tablesorter-blue" data-sortlist="[[0,0]]">
|
||||
<thead>
|
||||
<tr><th>Option</th><th class="defaults">Default</th><th class="sorter-false">Description</th></tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
|
||||
<tr id="sorttbody-primaryrow">
|
||||
<td><a href="#" class="permalink">sortTbody_primaryRow</a></td>
|
||||
<td>null</td>
|
||||
<td>Set this option to a string containing a jQuery selector pointing to the primary row to use for tbody sorting.
|
||||
<div class="collapsible">
|
||||
<br>
|
||||
<p>If a sortable tbody does not contain a primary row, or the primary row is not found, it will be sorted at the bottom of the table.</p>
|
||||
<p>In these demos, all primary rows have a class name of <code>"main"</code>, so this option is then set as follows:</p>
|
||||
<pre class="prettyprint lang-js">sortTbody_primaryRow : '.main'</pre>
|
||||
<p><span class="label label-info">*NOTE*</span> This will accept any jQuery selector, so it is possible to target multiple classes <code>'.main, .primary'</code>, but only the first found cell in the sorted column will be used when sorting the tbody.</p>
|
||||
<p><span class="label warning">*WARNING*</span> This widget was not designed to deal with <code>colspan</code> or <code>rowspan</code> within the primary row, so it is best to avoid them.</p>
|
||||
</div>
|
||||
</td>
|
||||
</tr>
|
||||
|
||||
<tr id="sorttbody-sortrows">
|
||||
<td><span class="permalink">sortTbody_sortRows</span></td>
|
||||
<td>false</td>
|
||||
<td>When <code>true</code>, all rows within each <code>tbody</code> will also be sorted; the primary row is included!</td>
|
||||
</tr>
|
||||
|
||||
<tr id="sorttbody-nosort">
|
||||
<td><span class="permalink">sortTbody_noSort</span></td>
|
||||
<td>'tablesorter-no-sort-tbody'</td>
|
||||
<td>Add the class name from this option to any tbodies that are to remain static. They will not be sorted.</td>
|
||||
</tr>
|
||||
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
<p></p>
|
||||
<h1>Demo</h1>
|
||||
<div id="demo"><!--
|
||||
***********************************
|
||||
TABLE 1 DEMO
|
||||
*********************************** -->
|
||||
<table id="table1" class="tablesorter-blue">
|
||||
<caption>Sort info-only tbodies by their primary row</caption>
|
||||
<thead>
|
||||
<tr>
|
||||
<th class="rank">Rank</th>
|
||||
<th>First Name</th>
|
||||
<th>Last Name</th>
|
||||
<th>Superhero Name</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody class="tablesorter-infoOnly">
|
||||
<tr class="main"><td>3</td><td>Bruce</td><td>Wayne</td><td>Batman</td></tr>
|
||||
<tr><td colspan="4">Batman is the superhero protector of Gotham City, a man dressed like a bat who fights against evil and strikes terror into the hearts of criminals everywhere. In his secret identity he is Bruce Wayne, billionaire industrialist and notorious playboy. Although he has no superhuman powers, he is one of the world's smartest men and greatest fighters. His physical prowess and technical ingenuity make him an incredibly dangerous opponent. He is also a founding member of the Justice League and the Outsiders.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody class="tablesorter-infoOnly">
|
||||
<tr class="main"><td>4</td><td>Hal</td><td>Jordan</td><td>Green Latern</td></tr>
|
||||
<tr><td colspan="4">Hal Jordan is the most well-known Green Lantern. He was the first earthman ever inducted into the Green Lantern Corps, and has been heralded as possibly the greatest Green Lantern of all time. Green Lantern is also a founding member of the Justice League of America.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody class="tablesorter-infoOnly">
|
||||
<tr class="main"><td>2</td><td>Clark</td><td>Kent</td><td>Superman</td></tr>
|
||||
<tr><td colspan="4">Superman, also known as the Man of Steel, is one of the most powerful superheroes in the DC Universe. His abilities include incredible super-strength, super-speed, invulnerability, freezing breath, flight, and heat-vision.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody class="tablesorter-infoOnly">
|
||||
<tr class="main"><td>5</td><td>Charles</td><td>Xavier</td><td>Professor X</td></tr>
|
||||
<tr><td colspan="4">Charles Francis Xavier was born in New York City to the wealthy Brian Xavier, a well-respected nuclear scientist, and Sharon Xavier. After Brian died in an accident, his science partner Kurt Marko comforts and marries the grieving Sharon. When Xavier's telepathic mutant powers emerge, he discovers Kurt cares only about his mother's money.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody class="tablesorter-infoOnly" id="invisible-woman">
|
||||
<tr class="main"><td>1</td><td>Susan</td><td>Richards</td><td>Invisible Woman</td></tr>
|
||||
<tr><td colspan="4">Susan's primary power deals with light waves, allowing her to render herself and others invisible.</td></tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<br>
|
||||
<!--
|
||||
***********************************
|
||||
TABLE 2 DEMO
|
||||
*********************************** -->
|
||||
<table id="table2" class="tablesorter-blue">
|
||||
<caption>Sort tbodies by their primary row (using child rows for extra info)</caption>
|
||||
<thead>
|
||||
<tr>
|
||||
<th class="rank">Rank</th>
|
||||
<th>First Name</th>
|
||||
<th>Last Name</th>
|
||||
<th>Superhero Name</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tbody>
|
||||
<tr class="main"><td>3</td><td>Bruce</td><td>Wayne</td><td>Batman</td></tr>
|
||||
<tr class="tablesorter-childRow"><td colspan="4">Batman is the superhero protector of Gotham City, a man dressed like a bat who fights against evil and strikes terror into the hearts of criminals everywhere. In his secret identity he is Bruce Wayne, billionaire industrialist and notorious playboy. Although he has no superhuman powers, he is one of the world's smartest men and greatest fighters. His physical prowess and technical ingenuity make him an incredibly dangerous opponent. He is also a founding member of the Justice League and the Outsiders.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody>
|
||||
<tr class="main"><td>4</td><td>Hal</td><td>Jordan</td><td>Green Latern</td></tr>
|
||||
<tr class="tablesorter-childRow"><td colspan="4">Hal Jordan is the most well-known Green Lantern. He was the first earthman ever inducted into the Green Lantern Corps, and has been heralded as possibly the greatest Green Lantern of all time. Green Lantern is also a founding member of the Justice League of America.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody>
|
||||
<tr class="main"><td>2</td><td>Clark</td><td>Kent</td><td>Superman</td></tr>
|
||||
<tr class="tablesorter-childRow"><td colspan="4">Superman, also known as the Man of Steel, is one of the most powerful superheroes in the DC Universe. His abilities include incredible super-strength, super-speed, invulnerability, freezing breath, flight, and heat-vision.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody>
|
||||
<tr class="main"><td>5</td><td>Charles</td><td>Xavier</td><td>Professor X</td></tr>
|
||||
<tr class="tablesorter-childRow"><td colspan="4">Charles Francis Xavier was born in New York City to the wealthy Brian Xavier, a well-respected nuclear scientist, and Sharon Xavier. After Brian died in an accident, his science partner Kurt Marko comforts and marries the grieving Sharon. When Xavier's telepathic mutant powers emerge, he discovers Kurt cares only about his mother's money.</td></tr>
|
||||
</tbody>
|
||||
|
||||
<tbody id="invisible-woman">
|
||||
<tr class="main"><td>1</td><td>Susan</td><td>Richards</td><td>Invisible Woman</td></tr>
|
||||
<tr class="tablesorter-childRow"><td colspan="4">Susan's primary power deals with light waves, allowing her to render herself and others invisible.</td></tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
<br>
|
||||
<hr id="sort-internal-rows">
|
||||
|
||||
<!--
|
||||
***********************************
|
||||
TABLE 3 DEMO
|
||||
*********************************** -->
|
||||
<code>sortTbody_sortRows</code>: <button class="toggle" type="button">false</button> (sort internal rows)
|
||||
<table id="table3" class="tablesorter-blue">
|
||||
<caption>Sortable & non-sortable tbodies</caption>
|
||||
<thead>
|
||||
<tr>
|
||||
<th class="rank">#</th>
|
||||
<th class="rank">ID</th>
|
||||
<th>First</th>
|
||||
<th>Last</th>
|
||||
<th>State</th>
|
||||
<th class="info">Info</th>
|
||||
</tr>
|
||||
</thead>
|
||||
<tfoot>
|
||||
<tr>
|
||||
<th class="rank">#</th>
|
||||
<th class="rank">ID</th>
|
||||
<th>First</th>
|
||||
<th>Last</th>
|
||||
<th>State</th>
|
||||
<th class="info">Info</th>
|
||||
</tr>
|
||||
</tfoot>
|
||||
<tbody>
|
||||
<tr class="main"><td>1</td><td>337</td><td>Denise</td><td>Harris</td><td>CT</td><td>lectus tortor vestibulum</td></tr>
|
||||
<tr><td>2</td><td>268</td><td>Brien</td><td>Barrow</td><td>KY</td><td>ipsum aenean eros</td></tr>
|
||||
<tr><td>3</td><td>665</td><td>Mikel</td><td>Absalom</td><td>FL</td><td>amet vestibulum adipiscing</td></tr>
|
||||
<tr><td>4</td><td>540</td><td>LaShonda</td><td>Buikema</td><td>SD</td><td>pulvinar at consectetur</td></tr>
|
||||
</tbody>
|
||||
<tbody class="tablesorter-no-sort-tbody">
|
||||
<tr><td colspan="6">Tbody "tablesorter-no-sort-tbody" spacer 1</td></tr>
|
||||
</tbody>
|
||||
<tbody>
|
||||
<tr class="main"><td>5</td><td>212</td><td>Leif</td><td>Choate</td><td>UT</td><td>porttitor mattis sit</td></tr>
|
||||
<tr><td>6</td><td>367</td><td>Ericka</td><td>Ragusa</td><td>MA</td><td>at sollicitudin hendrerit</td></tr>
|
||||
<tr><td>7</td><td>136</td><td>Waddie</td><td>Maynard</td><td>NH</td><td>sollicitudin ac mi</td></tr>
|
||||
<tr><td>8</td><td>305</td><td>Ken</td><td>Weissmann</td><td>AK</td><td>magna sit at</td></tr>
|
||||
</tbody>
|
||||
<tbody class="tablesorter-no-sort-tbody">
|
||||
<tr><td colspan="6">Tbody "tablesorter-no-sort-tbody" spacer 2</td></tr>
|
||||
</tbody>
|
||||
<tbody>
|
||||
<tr class="main"><td>9</td><td>983</td><td>Petr</td><td>Kunselman</td><td>WI</td><td>amet convallis eros</td></tr>
|
||||
<tr><td>10</td><td>306</td><td>Melanie</td><td>Nabors</td><td>MA</td><td>tincidunt risus porttitor</td></tr>
|
||||
<tr><td>11</td><td>345</td><td>Emil</td><td>Corson</td><td>MO</td><td>dui aliquam aliquam</td></tr>
|
||||
<tr><td>12</td><td>335</td><td>Theodore</td><td>Brill</td><td>WV</td><td>sit pulvinar eros</td></tr>
|
||||
</tbody>
|
||||
<tbody class="tablesorter-no-sort-tbody">
|
||||
<tr><td colspan="6">Tbody "tablesorter-no-sort-tbody" spacer 3</td></tr>
|
||||
</tbody>
|
||||
<tbody>
|
||||
<tr class="main"><td>13</td><td>430</td><td>Nishal</td><td>Smith</td><td>DE</td><td>tortor tincidunt porttitor</td></tr>
|
||||
<tr><td>14</td><td>470</td><td>Sheryl</td><td>Scheppe</td><td>ID</td><td>sed massa hendrerit</td></tr>
|
||||
<tr><td>15</td><td>795</td><td>Christopher</td><td>Pollard</td><td>CT</td><td>sed lacus adipiscing</td></tr>
|
||||
<tr><td>16</td><td>400</td><td>Raymond</td><td>Jessica</td><td>IN</td><td>mi vestibulum amet</td></tr>
|
||||
</tbody>
|
||||
<tbody class="tablesorter-no-sort-tbody">
|
||||
<tr><td colspan="6">Tbody "tablesorter-no-sort-tbody" spacer 4</td></tr>
|
||||
</tbody>
|
||||
<tbody>
|
||||
<tr class="main"><td>17</td><td>927</td><td>Donovan</td><td>Joslin</td><td>MN</td><td>amet augue aliquam</td></tr>
|
||||
<tr><td>18</td><td>882</td><td>Ning</td><td>Mccollum</td><td>KS</td><td>sed egestas vestibulum</td></tr>
|
||||
<tr><td>19</td><td>772</td><td>Sarah</td><td>Radist</td><td>DE</td><td>ipsum odio dui</td></tr>
|
||||
<tr><td>20</td><td>975</td><td>Aisha</td><td>Badertscher</td><td>CT</td><td>mi nec massa</td></tr>
|
||||
</tbody>
|
||||
</table>
|
||||
</div>
|
||||
|
||||
<h1>Page Header</h1>
|
||||
<div>
|
||||
<pre class="prettyprint lang-html"><link rel="stylesheet" href="../css/theme.blue.css">
|
||||
<script src="js/jquery-latest.min.js"></script>
|
||||
<script src="../js/jquery.tablesorter.js"></script>
|
||||
|
||||
<!-- Tablesorter: widgets (optional) -->
|
||||
<script src="../js/jquery.tablesorter.widgets.js"></script>
|
||||
<script src="../js/widgets/widget-sortTbodies.js"></script></pre>
|
||||
</div>
|
||||
|
||||
<h1>CSS</h1>
|
||||
<div id="css">
|
||||
<pre class="prettyprint lang-css"></pre>
|
||||
</div>
|
||||
<h1>Javascript</h1>
|
||||
<div id="javascript">
|
||||
<pre class="prettyprint lang-js"></pre>
|
||||
</div>
|
||||
<h1>HTML</h1>
|
||||
<div id="html">
|
||||
<pre class="prettyprint lang-html"></pre>
|
||||
</div>
|
||||
|
||||
</div>
|
||||
|
||||
</body>
|
||||
</html>
|
@ -474,14 +474,14 @@
|
||||
|
||||
<ul>
|
||||
<li><a href="example-widget-align-character.html">Align Character Widget</a> (<span class="version">v2.15.8</span>; <span class="version updated">v2.19.0</span>).</li>
|
||||
<li><a href="example-widget-build-table.html">Build Table Widget</a> (<span class="version">v2.11</span>; <span class="version updated">v2.21.3</span>).</li>
|
||||
<li><a href="example-widget-build-table.html">Build table Widget</a> (<span class="version">v2.11</span>; <span class="version updated">v2.21.3</span>).</li>
|
||||
|
||||
<li><span class="label label-info">Beta</span> <a href="example-widget-chart.html">Chart Widget</a> (<span class="version">v2.19.0</span>).</li>
|
||||
<li><span class="results">†</span> <a href="example-widget-columns.html">Columns Highlight widget</a> (v2.0.17)</li>
|
||||
<li><a href="example-widget-column-selector.html">Column Selector widget</a> (<span class="version">v2.15</span>; <span class="version updated">v2.21.0</span>).</li>
|
||||
<li><a href="example-widget-editable.html">Content Editable widget</a> (v2.9; <span class="version updated">v2.22.0</span>).</li>
|
||||
<li><span class="results">†</span> <a href="example-widget-columns.html">Columns highlight widget</a> (v2.0.17)</li>
|
||||
<li><a href="example-widget-column-selector.html">Column selector widget</a> (<span class="version">v2.15</span>; <span class="version updated">v2.21.0</span>).</li>
|
||||
<li><a href="example-widget-editable.html">Content editable widget</a> (v2.9; <span class="version updated">v2.22.0</span>).</li>
|
||||
<li><span class="label label-info">Beta</span> <a href="example-dragtable.html">Dragtable mod</a> - (jQuery UI widget for column reordering [<a href="http://stackoverflow.com/a/27770224/145346">ref</a>]; <span class="version">v2.19.0</span>).</li>
|
||||
<li><span class="results">†</span> Filter Widget (<span class="version updated">v2.22.1</span>):
|
||||
<li><span class="results">†</span> Filter widget (<span class="version updated">v2.22.1</span>):
|
||||
<ul>
|
||||
<li><a href="example-widget-filter.html">basic</a> (v2.0.18; <span class="version updated">v2.18.1</span>)</li>
|
||||
<li><a href="example-widget-filter-any-match.html">external option (match any column)</a> (<span class="version">v2.13.3</span>; <span class="version updated">v2.22.0</span>)</li>
|
||||
@ -515,11 +515,13 @@
|
||||
|
||||
<li><a href="example-widget-print.html">Print widget</a> (<span class="version">v2.16.4</span>; <span class="version updated">v2.19.0</span>)</li>
|
||||
<li><a href="example-widget-reflow.html">Reflow widget</a> (<span class="version">v2.16</span>; <span class="version updated">v2.19.0</span>)</li>
|
||||
<li><a href="example-widgets.html">Repeat Headers widget</a> (v2.0.5; <span class="version updated">v2.19.0</span>)</li>
|
||||
<li><span class="results">†</span> <a href="example-widget-resizable.html">Resizable Columns widget</a> (v2.0.23.1; <span class="version updated">v2.22.0</span>)</li>
|
||||
<li><a href="example-widgets.html">Repeat headers widget</a> (v2.0.5; <span class="version updated">v2.19.0</span>)</li>
|
||||
<li><span class="results">†</span> <a href="example-widget-resizable.html">Resizable columns widget</a> (v2.0.23.1; <span class="version updated">v2.22.0</span>)</li>
|
||||
<li><span class="results">†</span> <a href="example-widget-savesort.html">Save sort widget</a> (v2.0.27)</li>
|
||||
<li><a href="example-widget-scroller.html">Scroller widget</a> (<span class="version">v2.9</span>; <span class="version updated">v2.22.0</span>).</li>
|
||||
<li><a href="example-widget-static-row.html">StaticRow widget</a> (<span class="version">v2.16</span>; <span class="version updated">v2.19.1</span>).</li>
|
||||
<li><span class="label label-info">Beta</span> <a href="example-widget-sort-tbodies.html">Sort tbodies widget</a> (<span class="version">v2.22.2</span>).</li>
|
||||
<li><a href="example-widget-static-row.html">Static row widget</a> (<span class="version">v2.16</span>; <span class="version updated">v2.19.1</span>).</li>
|
||||
|
||||
<li><span class="results">†</span> <a href="example-widget-sticky-header.html">Sticky header widget</a> (v2.0.21.1; <span class="version updated">v2.21.3</span>)</li>
|
||||
<li><a href="example-widget-css-sticky-header.html">Sticky header (css3) widget</a> (<span class="version">v2.14.2</span>; <span class="version updated">v2.19.1</span>).</li>
|
||||
<li><span class="results">†</span> UITheme widget (<span class="version updated">v2.17.4</span>; <span class="version updated">v2.19.0</span>):
|
||||
|
228
js/widgets/widget-sortTbodies.js
Normal file
228
js/widgets/widget-sortTbodies.js
Normal file
@ -0,0 +1,228 @@
|
||||
/*! tablesorter tbody sorting widget (BETA) - 6/10/2015 (core v2.22.2)
|
||||
* Requires tablesorter v2.22.2+ and jQuery 1.4+
|
||||
* by Rob Garrison
|
||||
*/
|
||||
/*jshint browser:true, jquery:true, unused:false */
|
||||
/*global jQuery: false */
|
||||
;( function( $ ) {
|
||||
'use strict';
|
||||
var ts = $.tablesorter;
|
||||
|
||||
ts.sortTbodies = {
|
||||
init: function( c, wo ) {
|
||||
|
||||
var index, rows, txt, max, $rows,
|
||||
namespace = c.namespace + 'sortTbody',
|
||||
$tbodies = c.$table.children( 'tbody' ),
|
||||
len = $tbodies.length;
|
||||
|
||||
// save serverSideSorting value; use to toggle internal row sorting
|
||||
wo.sortTbody_original_serverSideSorting = c.serverSideSorting;
|
||||
|
||||
// include info-only tbodies - we need parsed data from *all* tbodies
|
||||
wo.sortTbody_original_cssInfoBlock = c.cssInfoBlock;
|
||||
c.cssInfoBlock = wo.sortTbody_noSort;
|
||||
ts.sortTbodies.setTbodies( c, wo );
|
||||
|
||||
// add original order index for stable sort
|
||||
for ( index = 0; index < len; index++ ) {
|
||||
$tbodies.eq( index ).attr( 'data-ts-original-order', index );
|
||||
}
|
||||
|
||||
c.$table
|
||||
.unbind( 'sortBegin updateComplete '.split( ' ' ).join( namespace + ' ' ) )
|
||||
.bind( 'sortBegin' + namespace, function() {
|
||||
ts.sortTbodies.sorter( c );
|
||||
})
|
||||
.bind( 'updateComplete' + namespace, function() {
|
||||
// find parsers for each column
|
||||
ts.sortTbodies.setTbodies( c, wo );
|
||||
c.$table.trigger( 'updateCache', [ null, c.$tbodies ] );
|
||||
});
|
||||
|
||||
// detect parsers - in case the table contains only info-only tbodies
|
||||
if ( $.isEmptyObject( c.parsers ) || c.$tbodies.length !== $tbodies.length ) {
|
||||
ts.sortTbodies.setTbodies( c, wo );
|
||||
c.$table.trigger( 'updateCache', [ null, c.$tbodies ] );
|
||||
}
|
||||
|
||||
// find colMax; this only matter for numeric columns
|
||||
$rows = $tbodies.children( 'tr' );
|
||||
len = $rows.length;
|
||||
for ( index = 0; index < c.columns; index++ ) {
|
||||
max = 0;
|
||||
if ( c.parsers[ index ].type === 'numeric' ) {
|
||||
for ( rows = 0; rows < len; rows++ ) {
|
||||
// update column max value (ignore sign)
|
||||
txt = ts.getParsedText( c, $rows.eq( rows ).children()[ index ], index );
|
||||
max = Math.max( Math.abs( txt ) || 0, max );
|
||||
}
|
||||
}
|
||||
c.$headerIndexed[ index ].attr( 'data-ts-col-max-value', max );
|
||||
}
|
||||
|
||||
},
|
||||
|
||||
// make sure c.$tbodies is up-to-date (init & after updates)
|
||||
setTbodies: function( c, wo ) {
|
||||
c.$tbodies = c.$table.children( 'tbody' ).not( '.' + wo.sortTbody_noSort );
|
||||
},
|
||||
|
||||
sorter: function( c ) {
|
||||
var $table = c.$table,
|
||||
wo = c.widgetOptions;
|
||||
|
||||
// prevent multiple calls while processing
|
||||
if ( wo.sortTbody_busy !== true ) {
|
||||
wo.sortTbody_busy = true;
|
||||
var $tbodies = $table.children( 'tbody' ).not( '.' + wo.sortTbody_noSort ),
|
||||
primary = wo.sortTbody_primaryRow || 'tr:eq(0)',
|
||||
sortList = c.sortList || [],
|
||||
len = sortList.length;
|
||||
|
||||
if ( len ) {
|
||||
|
||||
// toggle internal row sorting
|
||||
c.serverSideSorting = !wo.sortTbody_sortRows;
|
||||
|
||||
$tbodies.sort( function( a, b ) {
|
||||
var sortListIndex, txt, dir, num, colMax, sort, col, order, colA, colB, x, y,
|
||||
table = c.table,
|
||||
parsers = c.parsers,
|
||||
cts = c.textSorter || '',
|
||||
$tbodyA = $( a ),
|
||||
$tbodyB = $( b ),
|
||||
$a = $tbodyA.find( primary ).children( 'td, th' ),
|
||||
$b = $tbodyB.find( primary ).children( 'td, th' );
|
||||
for ( sortListIndex = 0; sortListIndex < len; sortListIndex++ ) {
|
||||
col = sortList[ sortListIndex ][0];
|
||||
order = sortList[ sortListIndex ][1];
|
||||
// sort direction, true = asc, false = desc
|
||||
dir = order === 0;
|
||||
// column txt - tbody A
|
||||
txt = ts.getElementText( c, $a.eq( col ), col );
|
||||
colA = parsers[ col ].format( txt, table, $a[ col ], col );
|
||||
// column txt - tbody B
|
||||
txt = ts.getElementText( c, $b.eq( col ), col );
|
||||
colB = parsers[ col ].format( txt, table, $b[ col ], col );
|
||||
|
||||
if (c.sortStable && colA === colB && len === 1) {
|
||||
return $tbodyA.attr( 'data-ts-original-order' ) - $tbodyB.attr( 'data-ts-original-order' );
|
||||
}
|
||||
|
||||
// fallback to natural sort since it is more robust
|
||||
num = /n/i.test( parsers && parsers[ col ] ? parsers[ col ].type || '' : '' );
|
||||
if ( num && c.strings[ col ] ) {
|
||||
colMax = c.$headerIndexed[ col ].attr( 'data-ts-col-max-value' ) ||
|
||||
1.79E+308; // close to Number.MAX_VALUE
|
||||
// sort strings in numerical columns
|
||||
if ( typeof ( c.string[ c.strings[ col ] ] ) === 'boolean' ) {
|
||||
num = ( dir ? 1 : -1 ) * ( c.string[ c.strings[ col ] ] ? -1 : 1 );
|
||||
} else {
|
||||
num = ( c.strings[ col ] ) ? c.string[ c.strings[ col ] ] || 0 : 0;
|
||||
}
|
||||
// fall back to built-in numeric sort
|
||||
// var sort = $.tablesorter['sort' + s](a, b, dir, colMax, table);
|
||||
sort = c.numberSorter ? c.numberSorter( colA, colB, dir, colMax, table ) :
|
||||
ts[ 'sortNumeric' + ( dir ? 'Asc' : 'Desc' ) ]( colA, colB, num, colMax, col, table );
|
||||
} else {
|
||||
// set a & b depending on sort direction
|
||||
x = dir ? colA : colB;
|
||||
y = dir ? colB : colA;
|
||||
// text sort function
|
||||
if ( typeof ( cts ) === 'function' ) {
|
||||
// custom OVERALL text sorter
|
||||
sort = cts( x, y, dir, col, table );
|
||||
} else if ( typeof ( cts ) === 'object' && cts.hasOwnProperty( col ) ) {
|
||||
// custom text sorter for a SPECIFIC COLUMN
|
||||
sort = cts[ col ]( x, y, dir, col, table );
|
||||
} else {
|
||||
// fall back to natural sort
|
||||
sort = ts[ 'sortNatural' + ( dir ? 'Asc' : 'Desc' ) ]( colA, colB, col, table, c );
|
||||
}
|
||||
}
|
||||
if ( sort ) { return sort; }
|
||||
}
|
||||
return $tbodyA.attr( 'data-ts-original-order' ) - $tbodyB.attr( 'data-ts-original-order' );
|
||||
});
|
||||
|
||||
ts.sortTbodies.restoreTbodies ( c, wo, $tbodies );
|
||||
wo.sortTbody_busy = false;
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
restoreTbodies : function ( c, wo, $sortedTbodies ) {
|
||||
var $nosort, $tbodies, $thisTbody, tbLen, nsLen, hasShuffled, index, indx, targetIndex,
|
||||
$table = c.$table,
|
||||
hasShuffled = true,
|
||||
indx = 0;
|
||||
|
||||
// hide entire table to improve sort performance
|
||||
$table.hide();
|
||||
$sortedTbodies.appendTo( $table );
|
||||
|
||||
// reposition no-sort tbodies
|
||||
$tbodies = $table.children( 'tbody' );
|
||||
tbLen = $tbodies.length;
|
||||
$nosort = $tbodies.filter( '.' + wo.sortTbody_noSort ).appendTo( $table );
|
||||
nsLen = $nosort.length;
|
||||
|
||||
if ( nsLen ) {
|
||||
// don't allow the while loop to cycle more times than the set number of no-sort tbodies
|
||||
while ( hasShuffled && indx < nsLen ) {
|
||||
hasShuffled = false;
|
||||
for ( index = 0; index < nsLen; index++ ) {
|
||||
targetIndex = parseInt( $nosort.eq( index ).attr( 'data-ts-original-order' ), 10 );
|
||||
// if target index > number of tbodies, make it last
|
||||
targetIndex = targetIndex >= tbLen ? tbLen : targetIndex < 0 ? 0 : targetIndex;
|
||||
|
||||
if ( targetIndex !== $nosort.eq( index ).index() ) {
|
||||
hasShuffled = true;
|
||||
$thisTbody = $nosort.eq( index ).detach();
|
||||
|
||||
if ( targetIndex >= tbLen ) {
|
||||
// Are we trying to be the last tbody?
|
||||
$thisTbody.appendTo( $table );
|
||||
} else if ( targetIndex === 0 ) {
|
||||
// Are we trying to be the first tbody?
|
||||
$thisTbody.prependTo( $table );
|
||||
} else {
|
||||
// No, we want to be somewhere in the middle!
|
||||
$thisTbody.insertBefore( $table.children( 'tbody:eq(' + targetIndex + ')' ) );
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
indx++;
|
||||
}
|
||||
}
|
||||
|
||||
$table.show();
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
ts.addWidget({
|
||||
id: 'sortTbody',
|
||||
// priority < 50 (filter widget), so c.$tbodies has the correct elements
|
||||
priority: 40,
|
||||
options: {
|
||||
// point to a row within the tbody that matches the number of header columns
|
||||
sortTbody_primaryRow : null,
|
||||
// sort tbody internal rows
|
||||
sortTbody_sortRows : false,
|
||||
// static tbodies (like static rows)
|
||||
sortTbody_noSort : 'tablesorter-no-sort-tbody'
|
||||
},
|
||||
init : function( table, thisWidget, c, wo ) {
|
||||
ts.sortTbodies.init( c, wo );
|
||||
},
|
||||
remove : function( table, c, wo, refreshing ) {
|
||||
c.$table.unbind( 'sortBegin updateComplete '.split( ' ' ).join( c.namespace + 'sortTbody ' ) );
|
||||
c.serverSideSorting = wo.sortTbody_original_serverSideSorting;
|
||||
c.cssInfoBlock = wo.sortTbody_original_cssInfoBlock;
|
||||
}
|
||||
});
|
||||
|
||||
})( jQuery );
|
Loading…
Reference in New Issue
Block a user