UNPKG

datatables.net-responsive-bs5

Version:

Responsive for DataTables with styling for [Bootstrap5](https://getbootstrap.com/)

107 lines (85 loc) 2.44 kB
/*! Bootstrap 5 integration for DataTables' Responsive * © SpryMedia Ltd - datatables.net/license */ import jQuery from 'jquery'; import DataTable from 'datatables.net-bs5'; import Responsive from 'datatables.net-responsive'; // Allow reassignment of the $ variable let $ = jQuery; var _display = DataTable.Responsive.display; var _original = _display.modal; var _modal = $( '<div class="modal fade dtr-bs-modal" role="dialog">' + '<div class="modal-dialog" role="document">' + '<div class="modal-content">' + '<div class="modal-header">' + '<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>' + '</div>' + '<div class="modal-body"/>' + '</div>' + '</div>' + '</div>' ); var modal; // Note this could be undefined at the time of initialisation - the // DataTable.Responsive.bootstrap function can be used to set a different // bootstrap object var _bs = window.bootstrap; DataTable.Responsive.bootstrap = function (bs) { _bs = bs; }; // Get the Bootstrap library from locally set (legacy) or from DT. function getBs() { let dtBs = DataTable.use('bootstrap'); if (dtBs) { return dtBs; } if (_bs) { return _bs; } throw new Error('No Bootstrap library. Set it with `DataTable.use(bootstrap);`'); } _display.modal = function (options) { if (!modal && _bs.Modal) { let localBs = getBs(); modal = new localBs.Modal(_modal[0]); } return function (row, update, render, closeCallback) { if (! modal) { return _original(row, update, render, closeCallback); } else { var rendered = render(); if (rendered === false) { return false; } if (!update) { if (options && options.header) { var header = _modal.find('div.modal-header'); var button = header.find('button').detach(); header .empty() .append('<h4 class="modal-title">' + options.header(row) + '</h4>') .append(button); } _modal.find('div.modal-body').empty().append(rendered); _modal .data('dtr-row-idx', row.index()) .one('hidden.bs.modal', closeCallback) .appendTo('body'); modal.show(); } else { if ($.contains(document, _modal[0]) && row.index() === _modal.data('dtr-row-idx')) { _modal.find('div.modal-body').empty().append(rendered); } else { // Modal not shown for this row - do nothing return null; } } return true; } }; }; export default DataTable;