329 lines
9.2 KiB
Plaintext
329 lines
9.2 KiB
Plaintext
|
/* Tablesorter Custom Bootstrap v3 LESS Theme by Rob Garrison
|
||
|
|
||
|
To create your own theme, modify the code below and run it through
|
||
|
a LESS compiler, like this one: http://leafo.net/lessphp/editor.html
|
||
|
or download less.js from http://lesscss.org/
|
||
|
|
||
|
Test out these customization files live
|
||
|
Basic LESS Theme : http://codepen.io/Mottie/pen/eqBbn
|
||
|
Bootstrap LESS : http://codepen.io/Mottie/pen/Ltzpi
|
||
|
Metro LESS Style : http://codepen.io/Mottie/pen/gCslk
|
||
|
Basic SCSS : http://codepen.io/Mottie/pen/LbXdNR
|
||
|
|
||
|
*/
|
||
|
|
||
|
/*** theme ***/
|
||
|
@theme : tablesorter-bootstrap;
|
||
|
|
||
|
/*** fonts ***/
|
||
|
@tableHeaderFont : 14px bold Arial, Sans-serif;
|
||
|
@tableBodyFont : 14px "Helvetica Neue", Helvetica, Arial, sans-serif;
|
||
|
|
||
|
/*** color definitions ***/
|
||
|
/* for best results, only change the hue (240),
|
||
|
leave the saturation (60%) and luminosity (80%) alone
|
||
|
pick the color from here: http://hslpicker.com/#99E699 */
|
||
|
@headerBackground : hsl(240, 60%, 80%);
|
||
|
@borderAndBackground : #cdcdcd;
|
||
|
@overallBorder : @borderAndBackground 1px solid;
|
||
|
@headerTextColor : #000;
|
||
|
|
||
|
@bodyBackground : #fff;
|
||
|
@bodyTextColor : #000;
|
||
|
|
||
|
@headerAsc : darken(spin(@headerBackground, 5), 10%); /* darken(@headerBackground, 10%); */
|
||
|
@headerDesc : lighten(spin(@headerBackground, -5), 10%); /* desaturate(@headerAsc, 5%); */
|
||
|
|
||
|
@captionBackground : #fff; /* it might be best to match the document body background color here */
|
||
|
@errorBackground : #e6bf99; /* ajax error message (added to thead) */
|
||
|
|
||
|
@filterCellBackground : #eee;
|
||
|
@filterElementTextColor: #333;
|
||
|
@filterElementBkgd : #fff;
|
||
|
@filterElementBorder : 1px solid #bbb;
|
||
|
@filterTransitionTime : 0.1s;
|
||
|
@filterRowHiddenHeight : 4px; /* becomes height using padding (so it's divided by 2) */
|
||
|
|
||
|
@overallPadding : 4px;
|
||
|
/* 20px should be slightly wider than the icon width to avoid overlap */
|
||
|
@headerPadding : 4px 20px 4px 4px;
|
||
|
@headerMargin : 0 0 18px;
|
||
|
|
||
|
/* url(icons/loading.gif); */
|
||
|
@processingIcon : url('');
|
||
|
|
||
|
/* zebra striping */
|
||
|
.allRows {
|
||
|
background-color: @bodyBackground;
|
||
|
color: @bodyTextColor;
|
||
|
}
|
||
|
.evenRows {
|
||
|
background-color: lighten(@headerBackground, 35%);
|
||
|
}
|
||
|
.oddRows {
|
||
|
background-color: lighten(@headerBackground, 18%);
|
||
|
}
|
||
|
|
||
|
/* hovered rows */
|
||
|
.oddHovered {
|
||
|
background-color: desaturate(@headerBackground, 60%);
|
||
|
}
|
||
|
.evenHovered {
|
||
|
background-color: lighten( desaturate(@headerBackground, 60%), 10% );
|
||
|
}
|
||
|
|
||
|
/* Columns widget */
|
||
|
@primaryOdd : spin(@headerBackground, 10); /* saturate( darken( desaturate(@headerBackground, 10%), 10% ), 30%); */
|
||
|
@primaryEven : lighten( @primaryOdd, 10% );
|
||
|
@secondaryOdd : @primaryEven;
|
||
|
@secondaryEven : lighten( @primaryEven, 5% );
|
||
|
@tertiaryOdd : @secondaryEven;
|
||
|
@tertiaryEven : lighten( @secondaryEven, 5% );
|
||
|
|
||
|
/* Filter widget transition */
|
||
|
.filterWidgetTransition {
|
||
|
-webkit-transition: line-height @filterTransitionTime ease;
|
||
|
-moz-transition: line-height @filterTransitionTime ease;
|
||
|
-o-transition: line-height @filterTransitionTime ease;
|
||
|
transition: line-height @filterTransitionTime ease;
|
||
|
}
|
||
|
|
||
|
/*** icon block ***/
|
||
|
.iconPosition {
|
||
|
font-size: 11px;
|
||
|
position: absolute;
|
||
|
right: 2px;
|
||
|
top: 50%;
|
||
|
margin-top: -7px; /* half the icon height; older IE doesn't like this */
|
||
|
width: 14px;
|
||
|
height: 14px;
|
||
|
background-repeat: no-repeat;
|
||
|
line-height: 14px;
|
||
|
}
|
||
|
|
||
|
/* black */
|
||
|
@unsortedBlack : url();
|
||
|
|
||
|
/* white */
|
||
|
@unsortedWhite : url();
|
||
|
|
||
|
/* automatically choose the correct arrow/text color */
|
||
|
.headerText (@a) when (lightness(@a) >= 50%) {
|
||
|
color: @headerTextColor;
|
||
|
}
|
||
|
.headerText (@a) when (lightness(@a) < 50%) {
|
||
|
color: lighten(@headerTextColor, 90%);
|
||
|
}
|
||
|
.unsorted (@a) when (lightness(@a) >= 50%) {
|
||
|
background-image: @unsortedBlack;
|
||
|
color: @headerTextColor;
|
||
|
}
|
||
|
.unsorted (@a) when (lightness(@a) < 50%) {
|
||
|
background-image: @unsortedWhite;
|
||
|
color: lighten(@headerTextColor, 90%);
|
||
|
}
|
||
|
|
||
|
/* variable theme name - requires less.js 1.3+;
|
||
|
or just replace (!".@{theme}") with the contents of @theme
|
||
|
*/
|
||
|
.@{theme} {
|
||
|
font: @tableBodyFont;
|
||
|
background-color: @borderAndBackground;
|
||
|
width: 100%;
|
||
|
|
||
|
/* style th's outside of the thead */
|
||
|
th, thead td {
|
||
|
font: @tableHeaderFont;
|
||
|
font-weight: bold;
|
||
|
background-color: @headerBackground;
|
||
|
.headerText(@headerBackground);
|
||
|
border-collapse: collapse;
|
||
|
margin: @headerMargin;
|
||
|
padding: @overallPadding;
|
||
|
}
|
||
|
|
||
|
tbody td, tfoot th, tfoot td {
|
||
|
padding: @overallPadding;
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
|
||
|
/* style header */
|
||
|
.tablesorter-header {
|
||
|
cursor: pointer;
|
||
|
}
|
||
|
|
||
|
.tablesorter-header-inner {
|
||
|
position: relative;
|
||
|
padding: @headerPadding;
|
||
|
}
|
||
|
|
||
|
/* bootstrap uses <i> for icons */
|
||
|
.tablesorter-header-inner i.tablesorter-icon {
|
||
|
.iconPosition
|
||
|
}
|
||
|
|
||
|
.tablesorter-header.sorter-false {
|
||
|
cursor: default;
|
||
|
|
||
|
i.tablesorter-icon {
|
||
|
display: none;
|
||
|
}
|
||
|
.tablesorter-header-inner {
|
||
|
padding: @overallPadding;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
.tablesorter-headerAsc {
|
||
|
background-color: @headerAsc;
|
||
|
}
|
||
|
|
||
|
.tablesorter-headerDesc {
|
||
|
background-color: @headerDesc;
|
||
|
}
|
||
|
|
||
|
.bootstrap-icon-unsorted {
|
||
|
.unsorted(@headerBackground);
|
||
|
}
|
||
|
|
||
|
|
||
|
/* tfoot */
|
||
|
tfoot .tablesorter-headerAsc,
|
||
|
tfoot .tablesorter-headerDesc {
|
||
|
/* remove sort arrows from footer */
|
||
|
background-image: none;
|
||
|
}
|
||
|
|
||
|
/* optional disabled input styling */
|
||
|
.disabled {
|
||
|
opacity: 0.5;
|
||
|
filter: alpha(opacity=50);
|
||
|
cursor: not-allowed;
|
||
|
}
|
||
|
|
||
|
/* body */
|
||
|
tbody {
|
||
|
|
||
|
td {
|
||
|
.allRows;
|
||
|
padding: @overallPadding;
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
|
||
|
/* Zebra Widget - row alternating colors */
|
||
|
tr.odd > td {
|
||
|
.oddRows;
|
||
|
}
|
||
|
tr.even > td {
|
||
|
.evenRows;
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
/* hovered row colors
|
||
|
you'll need to add additional lines for
|
||
|
rows with more than 2 child rows
|
||
|
*/
|
||
|
tbody > tr.hover > td,
|
||
|
tbody > tr:hover > td,
|
||
|
tbody > tr:hover + tr.tablesorter-childRow > td,
|
||
|
tbody > tr:hover + tr.tablesorter-childRow + tr.tablesorter-childRow > td,
|
||
|
tbody > tr.even.hover > td,
|
||
|
tbody > tr.even:hover > td,
|
||
|
tbody > tr.even:hover + tr.tablesorter-childRow > td,
|
||
|
tbody > tr.even:hover + tr.tablesorter-childRow + tr.tablesorter-childRow > td {
|
||
|
.evenHovered;
|
||
|
}
|
||
|
tbody > tr.odd.hover > td,
|
||
|
tbody > tr.odd:hover > td,
|
||
|
tbody > tr.odd:hover + tr.tablesorter-childRow > td,
|
||
|
tbody > tr.odd:hover + tr.tablesorter-childRow + tr.tablesorter-childRow > td {
|
||
|
.oddHovered;
|
||
|
}
|
||
|
|
||
|
/* table processing indicator - indeterminate spinner */
|
||
|
.tablesorter-processing {
|
||
|
background-image: @processingIcon;
|
||
|
background-position: center center;
|
||
|
background-repeat: no-repeat;
|
||
|
}
|
||
|
|
||
|
/* Column Widget - column sort colors */
|
||
|
tr.odd td.primary {
|
||
|
background-color: @primaryOdd;
|
||
|
}
|
||
|
td.primary, tr.even td.primary {
|
||
|
background-color: @primaryEven;
|
||
|
}
|
||
|
tr.odd td.secondary {
|
||
|
background-color: @secondaryOdd;
|
||
|
}
|
||
|
td.secondary, tr.even td.secondary {
|
||
|
background-color: @secondaryEven;
|
||
|
}
|
||
|
tr.odd td.tertiary {
|
||
|
background-color: @tertiaryOdd;
|
||
|
}
|
||
|
td.tertiary, tr.even td.tertiary {
|
||
|
background-color: @tertiaryEven;
|
||
|
}
|
||
|
|
||
|
/* caption (non-theme matching) */
|
||
|
caption {
|
||
|
background-color: @captionBackground ;
|
||
|
}
|
||
|
|
||
|
/* filter widget */
|
||
|
.tablesorter-filter-row input,
|
||
|
.tablesorter-filter-row select{
|
||
|
width: 98%;
|
||
|
margin: 0;
|
||
|
padding: @overallPadding;
|
||
|
color: @filterElementTextColor;
|
||
|
background-color: @filterElementBkgd;
|
||
|
border: @filterElementBorder;
|
||
|
-webkit-box-sizing: border-box;
|
||
|
-moz-box-sizing: border-box;
|
||
|
box-sizing: border-box;
|
||
|
.filterWidgetTransition;
|
||
|
}
|
||
|
.tablesorter-filter-row {
|
||
|
background-color: @filterCellBackground;
|
||
|
}
|
||
|
.tablesorter-filter-row td {
|
||
|
text-align: center;
|
||
|
background-color: @filterCellBackground;
|
||
|
line-height: normal;
|
||
|
text-align: center; /* center the input */
|
||
|
.filterWidgetTransition;
|
||
|
}
|
||
|
/* hidden filter row */
|
||
|
.tablesorter-filter-row.hideme td {
|
||
|
padding: @filterRowHiddenHeight / 2;
|
||
|
margin: 0;
|
||
|
line-height: 0;
|
||
|
cursor: pointer;
|
||
|
}
|
||
|
.tablesorter-filter-row.hideme * {
|
||
|
height: 1px;
|
||
|
min-height: 0;
|
||
|
border: 0;
|
||
|
padding: 0;
|
||
|
margin: 0;
|
||
|
/* don't use visibility: hidden because it disables tabbing */
|
||
|
opacity: 0;
|
||
|
filter: alpha(opacity=0);
|
||
|
}
|
||
|
/* rows hidden by filtering (needed for child rows) */
|
||
|
.filtered {
|
||
|
display: none;
|
||
|
}
|
||
|
|
||
|
/* ajax error row */
|
||
|
.tablesorter-errorRow td {
|
||
|
text-align: center;
|
||
|
cursor: pointer;
|
||
|
background-color: @errorBackground;
|
||
|
}
|
||
|
|
||
|
}
|