All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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;

    $.fn.waitingPanel = function (data) {

        function processAjaxUpdate() {
            var ajaxRequestRunning = false;

            // console.log('Setting waiting panel delay to ' + waitingPanelOpeningDelay);

            function processEvent(data) {
                if (data.status == 'begin') {
                    // console.log('Begin ajax event');
                    ajaxRequestRunning = true;
                    setTimeout(function () {
                        // console.log('Ajax request running: ' + ajaxRequestRunning);
                        if (ajaxRequestRunning) {
                            // console.log('Ajax request is running. Showing modal panel');
                            $waitingPanelDialog.css({'display':'inline-block'});
                            $waitingPanelDialog.butterDisableElements();
                            $waitingPanelDialog.css({'display':'none'});
                        } else {
                            // console.log('Ajax request is not running. Not showing modal panel');
                        }

                    }, waitingPanelOpeningDelay);

                } else if (data.status == 'success') {
                    // console.log('End ajax event');
                    ajaxRequestRunning = false;
                    $waitingPanelDialog.butterEnableElements();
                }
            }

            return processEvent;
        }

        return this.each(function () {
            var $originalElement = $(this);
            var _elementId = $originalElement.attr('id');
            var _msg = document.getElementById(_elementId);

            $waitingPanelDialog = $(_msg);
            waitingPanelOpeningDelay = data.waitingPanelDelay;

            // 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('Register: ' + _elementId);

                jsf.ajax.addOnEvent(processAjaxUpdate());
                eventRegistered = true;
            }
        });

    };
}(jQuery));




© 2015 - 2025 Weber Informatics LLC | Privacy Policy