
META-INF.resources.butterfaces-js.butterfaces-waitingpanel.jquery.js Maven / Gradle / Ivy
/**
* jQuery-Plugin "Waiting panel popup" for ajax popup animation. If registered an waiting panel popup will be rendered
* as long as ajax request is running.
* Works with at least jQuery 1.3.2.
*
* How to use:
* jQuery("#someSelector").waitingPanel();
*/
(function ($) {
// extend jQuery --------------------------------------------------------------------
var $waitingPanelDialog = null;
var eventRegistered = false;
var waitingPanelOpeningDelay = null;
var blockpage = null;
$.fn.waitingPanel = function (data) {
function processAjaxUpdate() {
var ajaxRequestRunning = false;
//console.log('waitingPanel - setting waiting panel delay to ' + waitingPanelOpeningDelay);
function processEvent(data) {
if (data.status == 'begin') {
//console.log('waitingPanel - begin ajax event, showing overlay');
ajaxRequestRunning = true;
butter.overlay.show({delay: waitingPanelOpeningDelay, blockpage: blockpage})
} else if (data.status == 'success') {
//console.log('waitingPanel - end ajax event, hiding overlay');
ajaxRequestRunning = false;
butter.overlay.hide();
}
}
return processEvent;
}
return this.each(function () {
var $originalElement = $(this);
var _elementId = $originalElement.attr('id');
var _msg = document.getElementById(_elementId);
$waitingPanelDialog = $(_msg);
waitingPanelOpeningDelay = data.waitingPanelDelay;
blockpage = data.blockpage;
// I found no way to remove event listener from jsf js.
// I tried to register a callback once and change it on render waiting panel but after this
// no waiting panel appears anymore.
// Actually on each rendering of this component a new callback is put on event listener collection.
if (!eventRegistered) {
//console.log('waitingPanel - register: ' + _elementId);
jsf.ajax.addOnEvent(processAjaxUpdate());
eventRegistered = true;
}
});
};
}(jQuery));
© 2015 - 2025 Weber Informatics LLC | Privacy Policy