-
HongKee Moon authoredHongKee Moon authored
datatable.js 3.14 KiB
const $ = window.jQuery = require('jquery');
window.DataTables = require('datatables.net');
const DataTable = $.fn.dataTable;
/* Set the defaults for DataTables initialisation */
$.extend(true, DataTable.defaults, {
dom:
"<'row'<'col-sm-6'l><'col-sm-6'f>>" +
"<'row'<'col-sm-12'tr>>" +
"<'row'<'col-sm-5'i><'col-sm-7'p>>",
renderer: 'bootstrap',
});
/* Default class modification */
$.extend(DataTable.ext.classes, {
sWrapper: 'dataTables_wrapper form-inline dt-bootstrap',
sFilterInput: 'form-control input-sm',
sLengthSelect: 'form-control input-sm',
sProcessing: 'dataTables_processing panel panel-default',
});
/* Bootstrap paging button renderer */
DataTable.ext.renderer.pageButton.bootstrap = (settings, host, idx, buttons, page, pages) => {
const api = new DataTable.Api(settings);
const classes = settings.oClasses;
const lang = settings.oLanguage.oPaginate;
const aria = settings.oLanguage.oAria.paginate || {};
let btnDisplay;
let btnClass;
let counter = 0;
const attach = (container, buttons) => {
let i;
let ien;
let node;
let button;
const clickHandler = (e) => {
e.preventDefault();
if (!$(e.currentTarget).hasClass('disabled') && api.page() !== e.data.action) {
api.page(e.data.action).draw('page');
}
};
for (i = 0, ien = buttons.length; i < ien; i += 1) {
button = buttons[i];
if ($.isArray(button)) {
attach(container, button);
} else {
btnDisplay = '';
btnClass = '';
switch (button) {
case 'ellipsis':
btnDisplay = '…';
btnClass = 'disabled';
break;
case 'first':
btnDisplay = lang.sFirst;
btnClass = button + (page > 0 ? '' : ' disabled');
break;
case 'previous':
btnDisplay = lang.sPrevious;
btnClass = button + (page > 0 ? '' : ' disabled');
break;
case 'next':
btnDisplay = lang.sNext;
btnClass = button + (page < pages - 1 ? '' : ' disabled');
break;
case 'last':
btnDisplay = lang.sLast;
btnClass = button + (page < pages - 1 ? '' : ' disabled');
break;
default:
btnDisplay = button + 1;
btnClass = page === button ? 'active' : '';
break;
}
if (btnDisplay) {
node = $('<li>', {
class: `${classes.sPageButton} ${btnClass}`,
id: idx === 0 && typeof button === 'string'
? `${settings.sTableId}_${button}`
: null,
})
.append($('<a>', {
href: '#',
'aria-controls': settings.sTableId,
'aria-label': aria[button],
'data-dt-idx': counter,
tabindex: settings.iTabIndex,
})
.html(btnDisplay))
.appendTo(container);
settings.oApi._fnBindAction(node, { action: button }, clickHandler);
counter += 1;
}
}
}
};
attach(
$(host).empty().html('<ul class="pagination"/>').children('ul'),
buttons,
);
};