forked from community/device-mgt-core
Merge pull request #1241 from madawas/master
Add a delay for data tables server side pagingrevert-70aa11f8
commit
c21a9dba53
@ -0,0 +1,49 @@
|
||||
/**
|
||||
* Enables filtration delay for keeping the browser more responsive while
|
||||
* searching for a longer keyword.
|
||||
*
|
||||
* This can be particularly useful when working with server-side processing,
|
||||
* where you wouldn't typically want an Ajax request to be made with every key
|
||||
* press the user makes when searching the table.
|
||||
*
|
||||
* Please note that this plug-in has been deprecated and the `dt-init
|
||||
* searchDelay` option in DataTables 1.10 should now be used. This plug-in will
|
||||
* not operate with v1.10+.
|
||||
*
|
||||
* @name fnSetFilteringDelay
|
||||
* @summary Add a key debouce delay to the global filtering input of a table
|
||||
* @author [Zygimantas Berziunas](http://www.zygimantas.com/),
|
||||
* [Allan Jardine](http://www.sprymedia.co.uk/) and _vex_
|
||||
*/
|
||||
|
||||
jQuery.fn.dataTableExt.oApi.fnSetFilteringDelay = function (oSettings, iDelay) {
|
||||
var _that = this;
|
||||
|
||||
if (iDelay === undefined) {
|
||||
iDelay = 250;
|
||||
}
|
||||
|
||||
this.each(function (i) {
|
||||
if (typeof _that.fnSettings().aanFeatures.f !== 'undefined') {
|
||||
$.fn.dataTableExt.iApiIndex = i;
|
||||
var
|
||||
oTimerId = null,
|
||||
sPreviousSearch = null,
|
||||
anControl = $('input', _that.fnSettings().aanFeatures.f);
|
||||
|
||||
anControl.unbind('keyup search input').bind('keyup search input', function () {
|
||||
|
||||
if (sPreviousSearch === null || sPreviousSearch != anControl.val()) {
|
||||
window.clearTimeout(oTimerId);
|
||||
sPreviousSearch = anControl.val();
|
||||
oTimerId = window.setTimeout(function () {
|
||||
$.fn.dataTableExt.iApiIndex = i;
|
||||
_that.fnFilter(anControl.val());
|
||||
}, iDelay);
|
||||
}
|
||||
});
|
||||
return this;
|
||||
}
|
||||
});
|
||||
return this;
|
||||
};
|
Loading…
Reference in new issue