Skip to content

Instantly share code, notes, and snippets.

@HazzazBinFaiz
Created January 6, 2022 04:49
Show Gist options
  • Star 2 You must be signed in to star a gist
  • Fork 1 You must be signed in to fork a gist
  • Save HazzazBinFaiz/f3c673e9b4b214babc6a16e4a754c4b2 to your computer and use it in GitHub Desktop.
Save HazzazBinFaiz/f3c673e9b4b214babc6a16e4a754c4b2 to your computer and use it in GitHub Desktop.
Tailwind styling for dataTables
(function (factory) {
if (typeof define === 'function' && define.amd) {
// AMD
define(['jquery', 'datatables.net'], function ($) {
return factory($, window, document);
});
} else if (typeof exports === 'object') {
// CommonJS
module.exports = function (root, $) {
if (!root) {
root = window;
}
if (!$ || !$.fn.dataTable) {
// Require DataTables, which attaches to jQuery, including
// jQuery if needed and have a $ property so we can access the
// jQuery object that is used
$ = require('datatables.net')(root, $).$;
}
return factory($, root, root.document);
};
} else {
// Browser
factory(jQuery, window, document);
}
}(function ($, window, document, undefined) {
'use strict';
var DataTable = $.fn.dataTable;
/* Set the defaults for DataTables initialisation */
$.extend(true, DataTable.defaults, {
dom:
"<'flex'<'w-full md:w-1/2'l><'w-full text-right md:w-1/2'f>>" +
"<'flex my-4'<'w-full'tr>>" +
"<'flex'<'w-full md:w-1/3'i><'w-full md:w-2/3 text-right'p>>",
renderer: 'tailwindcss'
});
/* Default class modification */
$.extend(DataTable.ext.classes, {
sWrapper: "w-full",
sTable: "w-full datatable",
sFilter: "font-semibold",
sFilterInput: "ml-2 p-2 rounded-md shadow-sm border border-gray-300 focus:border-indigo-300 focus:ring focus:ring-indigo-200 focus:ring-opacity-50",
sLength: "font-semibold",
sLengthSelect: "rounded-md shadow-sm border-gray-300 focus:border-indigo-300 focus:ring focus:ring-indigo-200 focus:ring-opacity-50",
sProcessing: "w-full p-4 bg-blue-200 text-center",
sFooterTH: "font-semibold border border-gray-300 p-2",
sHeaderTH: "font-semibold border border-gray-300 p-2 relative pr-6",
sSortable: "cursor-pointer sortable",
sStripeEven: "border border-gray-300",
sStripeOdd: "border border-gray-300",
sPaging: "relative z-0 inline-flex shadow-sm rounded-md",
sPageButton: "relative inline-flex items-center px-4 py-2 cursor-pointer -ml-px text-sm font-medium text-gray-700 bg-white border border-gray-300 leading-5 hover:text-gray-500 focus:z-10 focus:outline-none focus:ring ring-gray-300 focus:border-blue-300 active:bg-gray-100 active:text-gray-700 transition ease-in-out duration-150",
sRowEmpty: "w-full p-4 bg-red-200 text-center",
sInfo: "font-semibold",
});
/* Bootstrap paging button renderer */
DataTable.ext.renderer.pageButton.tailwindcss = function (settings, host, idx, buttons, page, pages) {
var api = new DataTable.Api(settings);
var classes = settings.oClasses;
var lang = settings.oLanguage.oPaginate;
var aria = settings.oLanguage.oAria.paginate || {};
var btnDisplay, btnClass, counter = 0;
var attach = function (container, buttons) {
var i, ien, node, button;
var clickHandler = function (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++) {
button = buttons[i];
if (Array.isArray(button)) {
attach(container, button);
} else {
btnDisplay = '';
btnClass = '';
switch (button) {
case 'ellipsis':
btnDisplay = '&#x2026;';
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,
'class': 'page-link'
})
.html(btnDisplay)
)
.appendTo(container);
settings.oApi._fnBindAction(
node, {action: button}, clickHandler
);
counter++;
}
}
}
};
// IE9 throws an 'unknown error' if document.activeElement is used
// inside an iframe or frame.
var activeEl;
try {
// Because this approach is destroying and recreating the paging
// elements, focus is lost on the select button which is bad for
// accessibility. So we want to restore focus once the draw has
// completed
activeEl = $(host).find(document.activeElement).data('dt-idx');
} catch (e) {
}
attach(
$(host).empty().html('<ul class="pagination"/>').children('ul'),
buttons
);
if (activeEl !== undefined) {
$(host).find('[data-dt-idx=' + activeEl + ']').trigger('focus');
}
};
return DataTable;
}));
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment