Jump to content

MediaWiki:Common.js: Difference between revisions

From Farmpedia – Agricultural Encyclopedia for Farmers
No edit summary
No edit summary
 
(9 intermediate revisions by the same user not shown)
Line 1: Line 1:
/* Any JavaScript here will be loaded for all users on every page load. */
/* Force viewport meta for mobile responsiveness */
(function() {
var existing = document.querySelector('meta[name="viewport"]');
if (existing) {
existing.setAttribute('content', 'width=device-width, initial-scale=1');
} else {
var meta = document.createElement('meta');
meta.name = 'viewport';
meta.content = 'width=device-width, initial-scale=1';
document.head.appendChild(meta);
}
})();


$(document).ready(function() {
$(document).ready(function () {


    /* Force main menu to be pinned on desktop */
/* ===== PIN MAIN MENU ON DESKTOP ===== */
    if (window.innerWidth >= 1024) {
if (window.innerWidth >= 1000) {
        var pinnedContainer = document.getElementById('vector-main-menu-pinned-container');
var pinnedContainer = document.getElementById('vector-main-menu-pinned-container');
        var unpinnedContainer = document.getElementById('vector-main-menu-unpinned-container');
var unpinnedContainer = document.getElementById('vector-main-menu-unpinned-container');
        var mainMenu = document.getElementById('vector-main-menu');
var mainMenu = document.getElementById('vector-main-menu');


        if (unpinnedContainer && mainMenu) {
if (unpinnedContainer && mainMenu) {
            if (pinnedContainer && !pinnedContainer.contains(mainMenu)) {
if (pinnedContainer && !pinnedContainer.contains(mainMenu)) {
                pinnedContainer.appendChild(mainMenu);
pinnedContainer.appendChild(mainMenu);
            }
}
        }
}


        var pinButton = document.querySelector('.vector-pinnable-header-pin-button');
// Click pin button if available
        if (pinButton) {
var pinButton = document.querySelector('.vector-pinnable-header-pin-button');
            pinButton.click();
if (pinButton) pinButton.click();
        }
}
    }


    /* Google Translate Widget */
/* ===== MOVE TRANSLATE LINK INTO SIDEBAR ===== */
    var translateHtml =
// Find translate link from Tools menu
        '<div class="mw-portlet vector-menu" id="p-translate">' +
var $translateLi = $('#p-tb li').filter(function () {
            '<div class="vector-menu-heading">Translate</div>' +
return $(this).find('a').attr('href') &&
            '<div class="vector-menu-content">' +
$(this).find('a').attr('href').indexOf('Translate') !== -1;
                '<div id="google_translate_element"></div>' +
});
            '</div>' +
        '</div>';


    // Try multiple selectors to find Main Menu portlet
var translateHref = '#';
    var mainMenuPortlet = document.querySelector('#p-Main_Menu') ||
if ($translateLi.length) {
                          document.querySelector('.mw-portlet-Main_Menu') ||
translateHref = $translateLi.find('a').attr('href');
                          document.querySelector('[id*="Main_Menu"]') ||
$translateLi.hide(); // Hide from Tools menu
                          document.querySelector('[id*="main-menu"]');
}


    if (mainMenuPortlet) {
// Also check ULS trigger (MediaWiki translate extension button)
        mainMenuPortlet.insertAdjacentHTML('afterend', translateHtml);
var $ulsBtn = $('#p-lang-btn, .uls-trigger, #pt-uls');
    } else {
if ($ulsBtn.length) {
        // Fallback - append to sidebar
translateHref = $ulsBtn.attr('href') || translateHref;
        var sidebar = document.querySelector('#mw-panel, .vector-sidebar');
}
        if (sidebar) {
            sidebar.insertAdjacentHTML('beforeend', translateHtml);
        }
    }


    /* Load Google Translate script */
    var script = document.createElement('script');
    script.src = '//translate.google.com/translate_a/element.js?cb=googleTranslateElementInit';
    document.body.appendChild(script);


}); /* end document.ready */
/* ===== CLEAN UP TOOLS MENU — REMOVE LESS USEFUL ITEMS ===== */
// Optional: hide items you don't want in Tools
var hideFromTools = ['t-permalink', 't-info']; // add IDs to hide
hideFromTools.forEach(function(id) {
$('#' + id).hide();
});


function googleTranslateElementInit() {
});
    new google.translate.TranslateElement({
        pageLanguage: 'en',
        layout: google.translate.TranslateElement.InlineLayout.SIMPLE,
        autoDisplay: false
    }, 'google_translate_element');
}

Latest revision as of 19:12, 14 April 2026

/* Force viewport meta for mobile responsiveness */
(function() {
var existing = document.querySelector('meta[name="viewport"]');
if (existing) {
existing.setAttribute('content', 'width=device-width, initial-scale=1');
} else {
var meta = document.createElement('meta');
meta.name = 'viewport';
meta.content = 'width=device-width, initial-scale=1';
document.head.appendChild(meta);
}
})();

$(document).ready(function () {

/* ===== PIN MAIN MENU ON DESKTOP ===== */
if (window.innerWidth >= 1000) {
var pinnedContainer = document.getElementById('vector-main-menu-pinned-container');
var unpinnedContainer = document.getElementById('vector-main-menu-unpinned-container');
var mainMenu = document.getElementById('vector-main-menu');

if (unpinnedContainer && mainMenu) {
if (pinnedContainer && !pinnedContainer.contains(mainMenu)) {
pinnedContainer.appendChild(mainMenu);
}
}

// Click pin button if available
var pinButton = document.querySelector('.vector-pinnable-header-pin-button');
if (pinButton) pinButton.click();
}

/* ===== MOVE TRANSLATE LINK INTO SIDEBAR ===== */
// Find translate link from Tools menu
var $translateLi = $('#p-tb li').filter(function () {
return $(this).find('a').attr('href') &&
$(this).find('a').attr('href').indexOf('Translate') !== -1;
});

var translateHref = '#';
if ($translateLi.length) {
translateHref = $translateLi.find('a').attr('href');
$translateLi.hide(); // Hide from Tools menu
}

// Also check ULS trigger (MediaWiki translate extension button)
var $ulsBtn = $('#p-lang-btn, .uls-trigger, #pt-uls');
if ($ulsBtn.length) {
translateHref = $ulsBtn.attr('href') || translateHref;
}


/* ===== CLEAN UP TOOLS MENU — REMOVE LESS USEFUL ITEMS ===== */
// Optional: hide items you don't want in Tools
var hideFromTools = ['t-permalink', 't-info']; // add IDs to hide
hideFromTools.forEach(function(id) {
$('#' + id).hide();
});

});