UNPKG

datatables.net-plugins

Version:

Various small plug-ins for DataTables including feature, ordering, search and internationalisation plug-ins.

86 lines (75 loc) 2.68 kB
/*! © SpryMedia Ltd - datatables.net/license */ /** * @summary SearchHighlight * @description Search term highlighter for DataTables * @version 1.1.0 * @author SpryMedia Ltd * * License MIT - http://datatables.net/license/mit * * This feature plug-in for DataTables will highlight search terms in the * DataTable as they are entered into the main search input element, or via the * `search()` API method. * * It depends upon the jQuery Highlight plug-in by Bartek Szopka: * http://bartaz.github.io/sandbox.js/jquery.highlight.js * * Search highlighting in DataTables can be enabled by: * * * Adding the class `searchHighlight` to the HTML table * * Setting the `searchHighlight` parameter in the DataTables initialisation to * be true * * Setting the `searchHighlight` parameter to be true in the DataTables * defaults (thus causing all tables to have this feature) - i.e. * `DataTable.defaults.searchHighlight = true`. * * For more detailed information please see: * http://datatables.net/blog/2014-10-22 */ import $ from 'jquery'; import DataTable from 'datatables.net'; declare module 'datatables.net' { interface Config { searchHighlight?: boolean; } } function highlight( body, table ) { // Removing the old highlighting first body.unhighlight(); // Don't highlight the "not found" row, so we get the rows using the api if ( table.rows( { filter: 'applied' } ).data().length ) { table.columns().every( function () { var column = this; column.nodes().flatten().to$().unhighlight({ className: 'column_highlight' }); column.nodes().flatten().to$().highlight( column.search().trim().split(/\s+/), { className: 'column_highlight' } ); } ); body.highlight( table.search().trim().split(/\s+/) ); } } // Listen for DataTables initialisations $(document).on( 'init.dt.dth', function (e, settings, json) { if ( e.namespace !== 'dt' ) { return; } var table = new DataTable.Api( settings ); var body = $( table.table().body() ); if ( $( table.table().node() ).hasClass( 'searchHighlight' ) || // table has class settings.oInit.searchHighlight || // option specified DataTable.defaults.searchHighlight // default set ) { table .on( 'draw.dt.dth column-visibility.dt.dth column-reorder.dt.dth', function () { highlight( body, table ); } ) .on( 'destroy', function () { // Remove event handler table.off( 'draw.dt.dth column-visibility.dt.dth column-reorder.dt.dth' ); } ); // initial highlight for state saved conditions and initial states if ( table.search() ) { highlight( body, table ); } } } );