14 if ( typeof define ===
'function' && define.amd ) {
16 define( [
'jquery',
'datatables.net'],
function ( $ ) {
17 return factory( $, window, document );
20 else if ( typeof exports ===
'object' ) {
22 module.exports =
function (root, $) {
27 if ( ! $ || ! $.fn.dataTable ) {
31 $ = require(
'datatables.net')(root, $).$;
34 return factory( $, root, root.document );
39 factory( jQuery, window, document );
41 }(
function( $, window, document, undefined ) {
43 var DataTable = $.fn.dataTable;
47 $.extend(
true, DataTable.defaults, {
50 "<'mdl-cell mdl-cell--6-col'l>"+
51 "<'mdl-cell mdl-cell--6-col'f>"+
53 "<'mdl-grid dt-table'"+
54 "<'mdl-cell mdl-cell--12-col'tr>"+
57 "<'mdl-cell mdl-cell--4-col'i>"+
58 "<'mdl-cell mdl-cell--8-col'p>"+
65 $.extend( DataTable.ext.classes, {
66 sWrapper:
"dataTables_wrapper form-inline dt-material",
67 sFilterInput:
"form-control input-sm",
68 sLengthSelect:
"form-control input-sm",
69 sProcessing:
"dataTables_processing panel panel-default"
74 DataTable.ext.renderer.pageButton.material =
function ( settings, host, idx, buttons, page, pages ) {
75 var api =
new DataTable.Api( settings );
76 var classes = settings.oClasses;
77 var lang = settings.oLanguage.oPaginate;
78 var aria = settings.oLanguage.oAria.paginate || {};
79 var btnDisplay, btnClass, counter=0;
81 var attach =
function( container, buttons ) {
82 var i, ien, node, button, disabled, active;
83 var clickHandler =
function ( e ) {
85 if ( !$(e.currentTarget).hasClass(
'disabled') && api.page() != e.data.action ) {
86 api.page( e.data.action ).draw(
'page' );
90 for ( i=0, ien=buttons.length ; i<ien ; i++ ) {
93 if ( $.isArray( button ) ) {
94 attach( container, button );
102 btnDisplay =
'…';
103 btnClass =
'disabled';
107 btnDisplay = lang.sFirst;
108 btnClass = button + (page > 0 ?
113 btnDisplay = lang.sPrevious;
114 btnClass = button + (page > 0 ?
119 btnDisplay = lang.sNext;
120 btnClass = button + (page < pages-1 ?
125 btnDisplay = lang.sLast;
126 btnClass = button + (page < pages-1 ?
131 btnDisplay = button + 1;
133 active = page === button;
138 btnClass +=
' mdl-button--raised mdl-button--colored';
142 node = $(
'<button>', {
143 'class':
'mdl-button '+btnClass,
144 'id': idx === 0 && typeof button ===
'string' ?
145 settings.sTableId +
'_'+ button :
147 'aria-controls': settings.sTableId,
148 'aria-label': aria[ button ],
149 'data-dt-idx': counter,
150 'tabindex': settings.iTabIndex,
151 'disabled': btnClass.indexOf(
'disabled') !== -1
154 .appendTo( container );
156 settings.oApi._fnBindAction(
157 node, {action: button}, clickHandler
175 activeEl = $(host).find(document.activeElement).data(
'dt-idx');
180 $(host).empty().html(
'<div class="pagination"/>').children(),
185 $(host).find(
'[data-dt-idx='+activeEl+
']' ).focus();