Merry Christmas from the IIWiki Team! Have a happy new year!
MediaWiki:Gadget-SidebarTOC.js: Difference between revisions
Jump to navigation
Jump to search
mNo edit summary |
mNo edit summary |
||
Line 1: | Line 1: | ||
mw.loader.using( 'mediawiki.toc', function () { | mw.loader.using( 'mediawiki.toc', function () { | ||
$( function () { | $( function () { | ||
var $window, $mwPanel, $floatTOC | var $window, $mwPanel, $floatTOC, | ||
tocLimit, headingOffsets, headingThreshold, | tocLimit, headingOffsets, headingThreshold, | ||
$toc = $( '.toc' ); | $toc = $( '.toc' ); | ||
Line 34: | Line 34: | ||
} | } | ||
return false; | return false; | ||
} ); | }); | ||
Line 50: | Line 50: | ||
// For the window scroll event | // For the window scroll event | ||
$window.on('scroll', function () { | |||
var $current, | var $current, | ||
scrollTop = $window.scrollTop(); | scrollTop = $window.scrollTop(); | ||
Line 85: | Line 85: | ||
$mwPanel.show(); | $mwPanel.show(); | ||
} | } | ||
} | }); | ||
}); | }); | ||
}); | }); |
Revision as of 06:47, 22 February 2024
mw.loader.using( 'mediawiki.toc', function () {
$( function () {
var $window, $mwPanel, $floatTOC,
tocLimit, headingOffsets, headingThreshold,
$toc = $( '.toc' );
if ( !$toc.length ) {
return;
}
$window = $( window );
$mwPanel = $( '#mw-panel' );
headingThreshold = $window.height() / 5.0;
$floatTOC = $toc
.clone()
.removeAttr( 'id' )
.addClass( 'floatTOC' )
.appendTo( 'body' )
.css( {
visibility: 'hidden',
opacity: 0
} );
// Show the ToC ul even if it's hidden
$floatTOC.find( 'ul' ).show();
// Hijack links so that we can scroll to the content
$floatTOC.find( 'a' ).click( function ( e ) {
var target = $( this.hash.replace( /\./g, '\\.' ));
if (target.length) {
$( 'html, body' ).animate( {
scrollTop: target.offset().top - headingThreshold
} );
}
return false;
});
tocLimit = $toc.offset().top + $toc.height();
headingOffsets = [];
// Get all heading positions
$toc.find('a').each(function () {
var id = $(this).attr('href').substring(1);
var $heading = $('#' + id);
if ($heading.length) {
headingOffsets.push([id, $heading.offset().top]);
}
});
// For the window scroll event
$window.on('scroll', function () {
var $current,
scrollTop = $window.scrollTop();
if (scrollTop > tocLimit) {
$floatTOC.css({
visibility: 'visible',
opacity: 1
});
$mwPanel.hide();
// Highlight current
var highlight = false;
// Current section is above the first heading below the top of the screen
$.each(headingOffsets, function (i, v) {
// Skip first as there's no previous heading before the first
if (i !== 0 && (scrollTop + headingThreshold) < v[1]) {
highlight = headingOffsets[i - 1][0];
return false;
}
});
if (highlight) {
$current = $floatTOC.find('a[href="#' + highlight + '"]');
$floatTOC.find('a').not($current).css('font-weight', '');
$current.css('font-weight', 'bold');
}
} else {
$floatTOC.css({
visibility: 'hidden',
opacity: 0
});
$mwPanel.show();
}
});
});
});