Note: After publishing, you may have to bypass your browser's cache to see the changes.
- Firefox / Safari: Hold Shift while clicking Reload, or press either Ctrl-F5 or Ctrl-R (⌘-R on a Mac)
- Google Chrome: Press Ctrl-Shift-R (⌘-Shift-R on a Mac)
- Edge: Hold Ctrl while clicking Refresh, or press Ctrl-F5.
/* All JavaScript here will be loaded for users of the Citizen skin */
mw.hook('wikipage.content').add(function($content) {
if (window.innerWidth >= 768) { // Desktop only
const idsToCollapse = [
'Muling', 'Misc', 'Anti-ban', 'Anti-PK', 'Trip_Settings', 'Skills_Settings', 'Equipment'
];
idsToCollapse.forEach(function(rawId) {
var id = rawId.replace(/ /g, "_");
var heading = document.getElementById(id);
if (!heading) return;
var sectionHeading = heading.closest('.citizen-section-heading');
var content = sectionHeading?.nextElementSibling;
if (content && content.classList.contains('citizen-section')) {
content.hidden = 'until-found'; // ✅ collapse it using Citizen’s native system
}
});
}
});
// === Hook into Citizen TOC clicks ===
mw.hook('wikipage.content').add(function() {
if (window.innerWidth < 768) return; // Desktop only
// Wait for Citizen TOC module to load
mw.loader.using('skins.citizen.toc').then(function() {
// Override onHeadingClick behavior
const citizenToc = require('skins.citizen.toc');
const originalOnHeadingClick = citizenToc.props.onHeadingClick;
citizenToc.props.onHeadingClick = function(id) {
// Expand the main page section manually
const anchor = document.getElementById(id.replace(/^toc-/, '')); // Remove "toc-" prefix
if (anchor) {
const sectionHeading = anchor.closest('.citizen-section-heading');
const content = sectionHeading?.nextElementSibling;
if (content && content.hidden) {
content.hidden = false; // Expand parent section
}
// Scroll after a slight delay
setTimeout(() => {
anchor.scrollIntoView({ behavior: 'smooth', block: 'start' });
}, 50);
}
// Then call the original behavior to update TOC highlighting
if (originalOnHeadingClick) {
originalOnHeadingClick(id);
}
};
});
});