4 // Table of contents toggle
5 mw.hook( 'wikipage.content' ).add( function ( $content ) {
6 var $toc, $tocTitle, $tocToggleLink, $tocList, hideToc;
7 $toc = $content.find( '#toc' );
8 $tocTitle = $content.find( '#toctitle' );
9 $tocToggleLink = $content.find( '#togglelink' );
10 $tocList = $toc.find( 'ul' ).eq( 0 );
12 // Hide/show the table of contents element
13 function toggleToc() {
14 if ( $tocList.is( ':hidden' ) ) {
15 $tocList.slideDown( 'fast' );
16 $tocToggleLink.text( mw.msg( 'hidetoc' ) );
17 $toc.removeClass( 'tochidden' );
18 mw.cookie.set( 'hidetoc', null );
20 $tocList.slideUp( 'fast' );
21 $tocToggleLink.text( mw.msg( 'showtoc' ) );
22 $toc.addClass( 'tochidden' );
23 mw.cookie.set( 'hidetoc', '1' );
27 // Only add it if there is a complete TOC and it doesn't
28 // have a toggle added already
29 if ( $toc.length && $tocTitle.length && $tocList.length && !$tocToggleLink.length ) {
30 hideToc = mw.cookie.get( 'hidetoc' ) === '1';
32 $tocToggleLink = $( '<a href="#" id="togglelink"></a>' )
33 .text( hideToc ? mw.msg( 'showtoc' ) : mw.msg( 'hidetoc' ) )
34 .click( function ( e ) {
41 .wrap( '<span class="toctoggle"></span>' )
49 $toc.addClass( 'tochidden' );
54 }( mediaWiki, jQuery ) );