UNPKG

datatables.net-responsive-bs4

Version:

Responsive for DataTables with styling for [Bootstrap4](https://getbootstrap.com/docs/4.6/getting-started/introduction/)

76 lines (62 loc) 1.82 kB
/*! Bootstrap 4 integration for DataTables' Responsive * © SpryMedia Ltd - datatables.net/license */ import jQuery from 'jquery'; import DataTable from 'datatables.net-bs4'; 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="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>' + '</div>' + '<div class="modal-body"/>' + '</div>' + '</div>' + '</div>' ); _display.modal = function (options) { return function (row, update, render, closeCallback) { if (!$.fn.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(); } 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 - do nothing return null; } } return true; } }; }; export default DataTable;