UNPKG

alpaca

Version:

Alpaca provides the easiest and fastest way to generate interactive forms for the web and mobile devices. It runs simply as HTML5 or more elaborately using Bootstrap, jQuery Mobile or jQuery UI. Alpaca uses Handlebars to process JSON schema and provide

82 lines (75 loc) 2.81 kB
/** * @summary ConditionalPaging * @description Hide paging controls when the amount of pages is <= 1 * @version 1.0.0 * @file dataTables.conditionalPaging.js * @author Matthew Hasbach (https://github.com/mjhasbach) * @contact hasbach.git@gmail.com * @copyright Copyright 2015 Matthew Hasbach * * License MIT - http://datatables.net/license/mit * * This feature plugin for DataTables hides paging controls when the amount * of pages is <= 1. The controls can either appear / disappear or fade in / out * * @example * $('#myTable').DataTable({ * conditionalPaging: true * }); * * @example * $('#myTable').DataTable({ * conditionalPaging: { * style: 'fade', * speed: 500 // optional * } * }); */ (function(window, document, $) { $(document).on('init.dt', function(e, dtSettings) { if ( e.namespace !== 'dt' ) { return; } var options = dtSettings.oInit.conditionalPaging; if ($.isPlainObject(options) || options === true) { var config = $.isPlainObject(options) ? options : {}, api = new $.fn.dataTable.Api(dtSettings), speed = 'slow', conditionalPaging = function(e) { var $paging = $(api.table().container()).find('div.dataTables_paginate'), pages = api.page.info().pages; if (e instanceof $.Event) { if (pages <= 1) { if (config.style === 'fade') { $paging.stop().fadeTo(speed, 0); } else { $paging.css('visibility', 'hidden'); } } else { if (config.style === 'fade') { $paging.stop().fadeTo(speed, 1); } else { $paging.css('visibility', ''); } } } else if (pages <= 1) { if (config.style === 'fade') { $paging.css('opacity', 0); } else { $paging.css('visibility', 'hidden'); } } }; if ($.isNumeric(config.speed) || $.type(config.speed) === 'string') { speed = config.speed; } conditionalPaging(); api.on('draw.dt', conditionalPaging); } }); })(window, document, jQuery);