MediaWiki:Common.js : Différence entre versions
Ligne 301 : | Ligne 301 : | ||
toggleElement( $collapsible, wasCollapsed ? 'expand' : 'collapse', $toggle, options ); | toggleElement( $collapsible, wasCollapsed ? 'expand' : 'collapse', $toggle, options ); | ||
} | } | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− |
Version du 30 avril 2014 à 08:55
/* Tout JavaScript ici sera chargé avec chaque page accédée par n’importe quel utilisateur. */ /** Grid/slide **/ // this needs to be unminified; MediaWiki automatically minifies all CSS and JS before // serving it to users, so minifying it here just makes it nigh-unmaintainable jQuery(function(){jQuery(".GridSlide").each(function(){jQuery("div.GridSlideChild:first",this).addClass("active").show()});setInterval(function(){jQuery(".GridSlide").each(function(){var b=jQuery("div.active",this),a=b.next();a.length<1&&(a=jQuery("div.GridSlideChild:first",this));b.removeClass("active").hide();a.addClass("active").show()})},2E3)}); jQuery(function(){jQuery("div.grid-input-slide").each(function(){jQuery("span.grid-input:first",this).addClass("active").show();jQuery("span.grid-input-numbers:first",this).addClass("active").show()});jQuery("div.grid-output-slide").each(function(){jQuery("span.grid-output:first",this).addClass("active").show();jQuery("span.grid-output-numbers:first",this).addClass("active").show()});setInterval(function(){jQuery("div.grid-input-slide").each(function(){var b=jQuery("span.grid-input.active",this), a=b.next();if(a.length<1||!a.hasClass("grid-input"))a=jQuery("span.grid-input:first",this);b.removeClass("active").hide();a.addClass("active").show();b=jQuery("span.grid-input-numbers.active",this);a=b.next();a.length<1&&(a=jQuery("span.grid-input-numbers:first",this));b.removeClass("active").hide();a.addClass("active").show()});jQuery("div.grid-output-slide").each(function(){var b=jQuery("span.grid-output.active",this),a=b.next();if(a.length<1||!a.hasClass("grid-output"))a=jQuery("span.grid-output:first", this);b.removeClass("active").hide();a.addClass("active").show();b=jQuery("span.grid-output-numbers.active",this);a=b.next();a.length<1&&(a=jQuery("span.grid-output-numbers:first",this));b.removeClass("active").hide();a.addClass("active").show()})},2E3)}); function MyWikiGetCookie(c_name) { var i,x,y,ARRcookies=document.cookie.split(";"); for (i=0;i<ARRcookies.length;i++) { x=ARRcookies[i].substr(0,ARRcookies[i].indexOf("=")); y=ARRcookies[i].substr(ARRcookies[i].indexOf("=")+1); x=x.replace(/^\s+|\s+$/g,""); if (x==c_name) { return unescape(y); } } } function MyWikiSetCookie(c_name,value,exdays) { var exdate=new Date(); exdate.setDate(exdate.getDate() + exdays); var c_value=escape(value) + ((exdays==null) ? "" : "; expires="+exdate.toUTCString()); document.cookie=c_name + "=" + c_value; } var cookieIsOpen=MyWikiGetCookie("isMenuOpen"); if ((cookieIsOpen!=null && cookieIsOpen=="open") || window.location.pathname=="/wiki/index.php/Bienvenue_%C3%A0_la_biblioth%C3%A8que_publique_d%27Esperia") { cookieIsOpen = true; } else { cookieIsOpen = false; } $menuItems = $("#mw-panel").children(":not(:first)"); $navigationDiv = $("#mw-panel").children(":first").find("h5"); $("#mw-panel").children(":first").children(":not(:first)").hide(); if(!cookieIsOpen)$menuItems.hide(); var backgroundImage = "url(\"\")"; $content = $("#content"); if(!cookieIsOpen) { $content.css("margin-left", 0); $content.css("background-image", "url()"); } $navigationDiv.css("padding-bottom", "4px"); $navigationDiv.css("background-image", backgroundImage); $navigationDiv.css("background-position", "center bottom"); $navigationDiv.css("background-repeat", "repeat-x"); var open = "<span> ►</span>"; var close = "<span> ▼</span>"; var $openCloseMenu; if(cookieIsOpen) { $openCloseMenu = $(close); } else { $openCloseMenu = $(open); } function openMenu() { $openCloseMenu.html(close); $menuItems.show(); $content.css("margin-left", "10em"); $content.css("background-image", backgroundImage); $navigationDiv.unbind('click'); $navigationDiv.click(closeMenu); MyWikiSetCookie("isMenuOpen","open",3650); } function closeMenu() { $openCloseMenu.html(open); $menuItems.hide(); $content.css("margin-left",0); $content.css("background-image", "url()"); $navigationDiv.unbind('click'); $navigationDiv.click(openMenu); MyWikiSetCookie("isMenuOpen","close",3650); } if(cookieIsOpen) { $navigationDiv.click(closeMenu); } else { $navigationDiv.click(openMenu); } $navigationDiv.append($openCloseMenu); /** * jQuery makeCollapsible * * Dual licensed: * - CC BY 3.0 <http://creativecommons.org/licenses/by/3.0> * - GPL2 <http://www.gnu.org/licenses/old-licenses/gpl-2.0.html> * * @class jQuery.plugin.makeCollapsible */ ( function ( $, mw ) { /** * Handler for a click on a collapsible toggler. * * @private * @param {jQuery} $collapsible * @param {string} action The action this function will take ('expand' or 'collapse'). * @param {jQuery|null} [$defaultToggle] * @param {Object|undefined} [options] */ function toggleElement( $collapsible, action, $defaultToggle, options ) { var $collapsibleContent, $containers, hookCallback; options = options || {}; // Validate parameters // $collapsible must be an instance of jQuery if ( !$collapsible.jquery ) { return; } if ( action !== 'expand' && action !== 'collapse' ) { // action must be string with 'expand' or 'collapse' return; } if ( $defaultToggle === undefined ) { $defaultToggle = null; } if ( $defaultToggle !== null && !$defaultToggle.jquery ) { // is optional (may be undefined), but if defined it must be an instance of jQuery. // If it's not, abort right away. // After this $defaultToggle is either null or a valid jQuery instance. return; } // Trigger a custom event to allow callers to hook to the collapsing/expanding, // allowing the module to be testable, and making it possible to // e.g. implement persistence via cookies $collapsible.trigger( action === 'expand' ? 'beforeExpand.mw-collapsible' : 'beforeCollapse.mw-collapsible' ); hookCallback = function () { $collapsible.trigger( action === 'expand' ? 'afterExpand.mw-collapsible' : 'afterCollapse.mw-collapsible' ); }; // Handle different kinds of elements if ( !options.plainMode && $collapsible.is( 'table' ) ) { // Tables // If there is a caption, hide all rows; otherwise, only hide body rows if ( $collapsible.find( '> caption' ).length ) { $containers = $collapsible.find( '> * > tr' ); } else { $containers = $collapsible.find( '> tbody > tr' ); } if ( $defaultToggle ) { // Exclude table row containing togglelink $containers = $containers.not( $defaultToggle.closest( 'tr' ) ); } if ( action === 'collapse' ) { // Hide all table rows of this table // Slide doesn't work with tables, but fade does as of jQuery 1.1.3 // http://stackoverflow.com/questions/467336#920480 if ( options.instantHide ) { $containers.hide(); hookCallback(); } else { $containers.stop( true, true ).fadeOut().promise().done( hookCallback ); } } else { $containers.stop( true, true ).fadeIn().promise().done( hookCallback ); } } else if ( !options.plainMode && ( $collapsible.is( 'ul' ) || $collapsible.is( 'ol' ) ) ) { // Lists $containers = $collapsible.find( '> li' ); if ( $defaultToggle ) { // Exclude list-item containing togglelink $containers = $containers.not( $defaultToggle.parent() ); } if ( action === 'collapse' ) { if ( options.instantHide ) { $containers.hide(); hookCallback(); } else { $containers.stop( true, true ).slideUp().promise().done( hookCallback ); } } else { $containers.stop( true, true ).slideDown().promise().done( hookCallback ); } } else { // Everything else: <div>, <p> etc. $collapsibleContent = $collapsible.find( '> .mw-collapsible-content' ); // If a collapsible-content is defined, act on it if ( !options.plainMode && $collapsibleContent.length ) { if ( action === 'collapse' ) { if ( options.instantHide ) { $collapsibleContent.hide(); hookCallback(); } else { $collapsibleContent.slideUp().promise().done( hookCallback ); } } else { $collapsibleContent.slideDown().promise().done( hookCallback ); } // Otherwise assume this is a customcollapse with a remote toggle // .. and there is no collapsible-content because the entire element should be toggled } else { if ( action === 'collapse' ) { if ( options.instantHide ) { $collapsible.hide(); hookCallback(); } else { if ( $collapsible.is( 'tr' ) || $collapsible.is( 'td' ) || $collapsible.is( 'th' ) ) { $collapsible.fadeOut().promise().done( hookCallback ); } else { $collapsible.slideUp().promise().done( hookCallback ); } } } else { if ( $collapsible.is( 'tr' ) || $collapsible.is( 'td' ) || $collapsible.is( 'th' ) ) { $collapsible.fadeIn().promise().done( hookCallback ); } else { $collapsible.slideDown().promise().done( hookCallback ); } } } } } /** * Handle clicking/keypressing on the collapsible element toggle and other * situations where a collapsible element is toggled (e.g. the initial * toggle for collapsed ones). * * @private * @param {jQuery} $toggle the clickable toggle itself * @param {jQuery} $collapsible the collapsible element * @param {jQuery.Event|null} e either the event or null if unavailable * @param {Object|undefined} options */ function togglingHandler( $toggle, $collapsible, e, options ) { var wasCollapsed, $textContainer, collapseText, expandText; if ( options === undefined ) { options = {}; } if ( e ) { if ( e.type === 'click' && options.linksPassthru && $.nodeName( e.target, 'a' ) ) { // Don't fire if a link was clicked, if requested (for premade togglers by default) return; } else if ( e.type === 'keypress' && e.which !== 13 && e.which !== 32 ) { // Only handle keypresses on the "Enter" or "Space" keys return; } else { e.preventDefault(); e.stopPropagation(); } } // This allows the element to be hidden on initial toggle without fiddling with the class if ( options.wasCollapsed !== undefined ) { wasCollapsed = options.wasCollapsed; } else { wasCollapsed = $collapsible.hasClass( 'mw-collapsed' ); } // Toggle the state of the collapsible element (that is, expand or collapse) $collapsible.toggleClass( 'mw-collapsed', !wasCollapsed ); // Toggle the mw-collapsible-toggle classes, if requested (for default and premade togglers by default) if ( options.toggleClasses ) { $toggle .toggleClass( 'mw-collapsible-toggle-collapsed', !wasCollapsed ) .toggleClass( 'mw-collapsible-toggle-expanded', wasCollapsed ); } // Toggle the text ("Show"/"Hide"), if requested (for default togglers by default) if ( options.toggleText ) { collapseText = options.toggleText.collapseText; expandText = options.toggleText.expandText; $textContainer = $toggle.find( '> a' ); if ( !$textContainer.length ) { $textContainer = $toggle; } $textContainer.text( wasCollapsed ? collapseText : expandText ); } // And finally toggle the element state itself toggleElement( $collapsible, wasCollapsed ? 'expand' : 'collapse', $toggle, options ); }