X-Git-Url: https://scm.cri.ensmp.fr/git/Plinn.git/blobdiff_plain/35e1ecea933ffa33927b13242e5b3c5c480ef9f5..98e7c46baa1b613b9b137c8478f99da593fdc46b:/skins/ajax_scripts/ajax_form_manager.js?ds=sidebyside diff --git a/skins/ajax_scripts/ajax_form_manager.js b/skins/ajax_scripts/ajax_form_manager.js index d942234..03ebdd8 100644 --- a/skins/ajax_scripts/ajax_form_manager.js +++ b/skins/ajax_scripts/ajax_form_manager.js @@ -4,8 +4,11 @@ // // +var FormManager; -function FormManager(form, responseTextDest, lazy) { +(function(){ + +FormManager = function(form, responseTextDest, lazy) { if (form.elements.namedItem("noAjax")) {return;} this.form = form; @@ -39,7 +42,7 @@ function FormManager(form, responseTextDest, lazy) { this.onResponseLoad = function(req){ thisManager.restoreField(req); }; this.lazyListeners = []; } -} +}; FormManager.prototype.submit = function(evt) { var form = this.form; @@ -426,6 +429,14 @@ FormManager.prototype.loadResponse = function(req) { onAfterPopulate = eval(onAfterPopulate); } onAfterPopulate(); + this.scrollToPortalMessage(); +}; + +FormManager.prototype.scrollToPortalMessage = function() { + var psm = document.getElementById('DesktopStatusBar'); + var msgOffset = psm.offsetTop; + smoothScroll(window.scrollY, msgOffset); + shake(psm, 10, 1000); }; FormManager.prototype._fitField = function(evt) { @@ -447,5 +458,69 @@ function initForms(baseElement, lazy) { } } +function smoothScroll(from, to) { + var intervalId; + var step = 25; + var pos = from; + var dir; + if (to > from) { + dir = 1; + } + else { + dir = -1; + } + + var jump = function() { + window.scroll(0, pos); + pos = pos + step * dir; + if ((dir === 1 && pos >= to) || + (dir === -1 && pos <= to)) { + window.clearInterval(intervalId); + window.scroll(0, to); + } + }; + intervalId = window.setInterval(jump, 10); +} + +/* adapted from http://xahlee.info/js/js_shake_box.html */ +function shake(e, distance, time) { + // Handle arguments + if (!time) time = 500; + if (!distance) distance = 5; + + // Save the original style of e, Make e relatively positioned, Note the animation start time, Start the animation + var originalStyle = e.style.cssText; + e.style.position = "relative"; + var start = (new Date()).getTime(); + animate(); + + // This function checks the elapsed time and updates the position of e. + // If the animation is complete, it restores e to its original state. + // Otherwise, it updates e's position and schedules itself to run again. + function animate() { + var now = (new Date()).getTime(); + // Get current time + var elapsed = now-start; + // How long since we started + var fraction = elapsed/time; + // What fraction of total time? + if (fraction < 1) { + // If the animation is not yet complete + // Compute the x position of e as a function of animation + // completion fraction. We use a sinusoidal function, and multiply + // the completion fraction by 4pi, so that it shakes back and + // forth twice. + var x = distance * Math.sin(fraction*8*Math.PI); + e.style.left = x + "px"; + // Try to run again in 25ms or at the end of the total time. + // We're aiming for a smooth 40 frames/second animation. + setTimeout(animate, Math.min(25, time-elapsed)); + } + else { + // Otherwise, the animation is complete + e.style.cssText = originalStyle; // Restore the original style + } + } +} -//registerStartupFunction(initForms); \ No newline at end of file +}());