/*! DataTables Tailwind CSS integration */ (function (factory) { if (typeof define === 'function' && define.amd) { // AMD define(['jquery', 'datatables.net'], function ($) { return factory($, window, document); }); } else if (typeof exports === 'object') { // CommonJS var jq = require('jquery'); var cjsRequires = function (root, $) { if (!$.fn.dataTable) { require('datatables.net')(root, $); } }; if (typeof window === 'undefined') { module.exports = function (root, $) { if (!root) { // CommonJS environments without a window global must pass a // root. This will give an error otherwise root = window; } if (!$) { $ = jq(root); } cjsRequires(root, $); return factory($, root, root.document); }; } else { cjsRequires(window, jq); module.exports = factory(jq, window, window.document); } } else { // Browser factory(jQuery, window, document); } })(function ($, window, document) { 'use strict'; var DataTable = $.fn.dataTable; /* * This is a tech preview of Tailwind CSS integration with DataTables. */ // Set the defaults for DataTables initialisation $.extend(true, DataTable.defaults, { renderer: 'tailwindcss', }); // Default class modification $.extend(true, DataTable.ext.classes, { container: 'dt-container dt-tailwindcss', search: { input: 'border placeholder-gray-500 ml-2 px-3 py-2 rounded-lg border-gray-200 focus:border-blue-500 focus:ring focus:ring-blue-500 focus:ring-opacity-50 dark:bg-gray-800 dark:border-gray-600 dark:focus:border-blue-500 dark:placeholder-gray-400', }, length: { select: 'border px-3 py-2 rounded-lg border-gray-200 focus:border-blue-500 focus:ring focus:ring-blue-500 focus:ring-opacity-50 dark:bg-gray-800 dark:border-gray-600 dark:focus:border-blue-500', }, processing: { container: 'dt-processing', }, paging: { active: 'font-semibold bg-gray-100 dark:bg-gray-700/75', notActive: 'bg-white dark:bg-gray-800', button: 'relative inline-flex justify-center items-center space-x-2 border px-4 py-2 -mr-px leading-6 hover:z-10 focus:z-10 active:z-10 border-gray-200 active:border-gray-200 active:shadow-none dark:border-gray-700 dark:active:border-gray-700', first: 'rounded-l-lg', last: 'rounded-r-lg', enabled: 'text-gray-800 hover:text-gray-900 hover:border-gray-300 hover:shadow-sm focus:ring focus:ring-gray-300 focus:ring-opacity-25 dark:text-gray-300 dark:hover:border-gray-600 dark:hover:text-gray-200 dark:focus:ring-gray-600 dark:focus:ring-opacity-40', notEnabled: 'text-gray-300 dark:text-gray-600', }, table: 'dataTable min-w-full text-sm align-middle whitespace-nowrap', thead: { row: 'border-b border-gray-100', cell: 'px-3 py-4 text-gray-900 bg-gray-200 font-semibold text-left', }, tbody: { row: 'even:bg-gray-100', cell: 'p-3', }, tfoot: { row: 'even:bg-gray-50', cell: 'p-3 text-left', }, }); DataTable.ext.renderer.pagingButton.tailwindcss = function (settings, buttonType, content, active, disabled) { var classes = settings.oClasses.paging; var btnClasses = [classes.button]; btnClasses.push(active ? classes.active : classes.notActive); btnClasses.push(disabled ? classes.notEnabled : classes.enabled); var a = $('', { href: disabled ? null : '#', class: btnClasses.join(' '), }).html(content); return { display: a, clicker: a, }; }; DataTable.ext.renderer.pagingContainer.tailwindcss = function (settings, buttonEls) { var classes = settings.oClasses.paging; buttonEls[0].addClass(classes.first); buttonEls[buttonEls.length - 1].addClass(classes.last); return $('