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 role="button" tabindex="0" id="togglelink"></a>' )
33 .text( mw.msg( hideToc ? 'showtoc' : 'hidetoc' ) )
34 .on( 'click keypress', function ( e ) {
37 e.type === 'keypress' && e.which === 13
45 .wrap( '<span class="toctoggle"></span>' )
53 $toc.addClass( 'tochidden' );
58 }( mediaWiki, jQuery ) );