Show a spinner while loading individual panels

This commit is contained in:
theopolisme 2014-02-26 21:41:41 -06:00
parent 5d588b9923
commit 2ce77e9ff5

View File

@ -632,11 +632,11 @@
AFCH.initFeedback( '#afchLeft', 'article review' ); AFCH.initFeedback( '#afchLeft', 'article review' );
// Set up click handlers // Set up click handlers
$( '#afchAccept' ).click( showAcceptOptions ); $( '#afchAccept' ).click( function () { spinnerAndRun( showAcceptOptions ); } );
$( '#afchDecline' ).click( showDeclineOptions ); $( '#afchDecline' ).click( function () { spinnerAndRun( showDeclineOptions ); } );
$( '#afchComment' ).click( showCommentOptions ); $( '#afchComment' ).click( function () { spinnerAndRun( showCommentOptions ); } );
$( '#afchSubmit' ).click( showSubmitOptions ); $( '#afchSubmit' ).click( function () { spinnerAndRun( showSubmitOptions ); } );
$( '#afchG13' ).click( showG13Options ); $( '#afchG13' ).click( function () { spinnerAndRun( showG13Options ); } );
// Get G13 eligibility and when known, display the button... // Get G13 eligibility and when known, display the button...
// but don't hold up the rest of the loading to do so // but don't hold up the rest of the loading to do so
@ -731,6 +731,37 @@
} ); } );
} }
/**
* Displays a spinner in the main content area and then
* calls the passed function
* @param {function} fn function to call when spinner has been displayed
* @return {[type]} [description]
*/
function spinnerAndRun ( fn ) {
var $spinner, $container = $( '#afchContent' );
// Add a new spinner if one doesn't already exist
if ( !$container.find( '.mw-spinner' ).length ) {
$spinner = $.createSpinner( {
size: 'large',
type: 'block'
} )
// Set the spinner's dimensions equal to the viewers's dimensions so that
// the current scroll position is not lost when emptied
.css( {
height: $container.height(),
width: $container.width()
} );
$container.empty().append( $spinner );
}
if ( typeof fn === 'function' ) {
fn();
}
}
/** /**
* Loads a new view * Loads a new view
* @param {string} name view to be loaded * @param {string} name view to be loaded