/** * jQuery spinner * * Simple jQuery plugin to create, inject and remove spinners. */ ( function ( $ ) { // Default options for new spinners, // stored outside the function to share between calls. var defaults = { id: undefined, size: 'small', type: 'inline' }; $.extend({ /** * Creates a spinner element. * * The argument is an object with options used to construct the spinner. These can be: * * It is a good practice to keep a reference to the created spinner to be able to remove it later. * Alternatively one can use the id option and removeSpinner() (but make sure to choose an id * that's unlikely to cause conflicts, e.g. with extensions, gadgets or user scripts). * * CSS classes used: * .mw-spinner for every spinner * .mw-spinner-small / .mw-spinner-large for size * .mw-spinner-block / .mw-spinner-inline for display types * * @example * // Create a large spinner reserving all available horizontal space. * var $spinner = $.createSpinner({ size: 'large', type: 'block' }); * // Insert above page content. * $( '#mw-content-text' ).prepend( $spinner ); * @example * // Place a small inline spinner next to the "Save" button * var $spinner = $.createSpinner({ size: 'small', type: 'inline' }); * // Alternatively, just `$.createSpinner();` as these are the default options. * $( '#wpSave' ).after( $spinner ); * @example * // The following two are equivalent: * $.createSpinner( 'magic' ); * $.createSpinner({ id: 'magic' }); * * @param {Object|String} opts [optional] ID string or options: * - id: If given, spinner will be given an id of "mw-spinner-" * - size: 'small' (default) or 'large' for a 20-pixel or 32-pixel spinner * - type: 'inline' (default) or 'block'. Inline creates an inline-block with width and * height equal to spinner size. Block is a block-level element with width 100%, height * equal to spinner size. * @return {jQuery} */ createSpinner: function ( opts ) { if ( opts !== undefined && $.type( opts ) !== 'object' ) { opts = { id: opts }; } opts = $.extend( {}, defaults, opts ); var $spinner = $( '
', { 'class': 'mw-spinner', 'title': '...' } ); if ( opts.id !== undefined ) { $spinner.attr( 'id', 'mw-spinner-' + opts.id ); } $spinner.addClass( opts.size === 'large' ? 'mw-spinner-large' : 'mw-spinner-small' ); $spinner.addClass( opts.type === 'block' ? 'mw-spinner-block' : 'mw-spinner-inline' ); return $spinner; }, /** * Removes a spinner element. * * @param {String} id [optional] Id of the spinner, as passed to createSpinner. * @return {jQuery} The (now detached) spinner. */ removeSpinner: function ( id ) { return $( '#mw-spinner-' + id ).remove(); } }); /** * Injects a spinner after the elements in the jQuery collection * (as siblings, not children). Collection contents remain unchanged. * * @param {Object} opts See createSpinner() for description. * @return {jQuery} */ $.fn.injectSpinner = function ( opts ) { return this.after( $.createSpinner( opts ) ); }; }( jQuery ) );