MediaWiki:Common.js: различия между версиями

Материал из Ascaron Online
Перейти к навигации Перейти к поиску
Нет описания правки
Метка: отменено
Нет описания правки
 
(не показаны 23 промежуточные версии этого же участника)
Строка 1: Строка 1:
<style>
.lang-placeholder {
    display: inline-block;
    width: 100%;
    min-height: 1em;
    background-color: #e0e0e0;
    border-radius: 4px;
    animation: pulse 1.2s infinite ease-in-out;
    color: transparent;
    overflow: hidden;
}
@keyframes pulse {
    0% { opacity: 1; }
    50% { opacity: 0.4; }
    100% { opacity: 1; }
}
</style>
mw.loader.using('mediawiki.util').then(function () {
mw.loader.using('mediawiki.util').then(function () {
    // Не выполнять скрипт на странице редактирования
     if (location.href.includes('action=edit')) return;
     if (location.href.includes('action=edit')) return;
    if (location.href.includes('action=submit')) return;


     var supportedLanguages = ['ru', 'en'];
    // Поддерживаемые языки: русский, испанский и английский
     var supportedLanguages = ['ru', 'es', 'en'];


     var userLangRaw = navigator.languages && navigator.languages.length
    // Получаем язык браузера
         ? navigator.languages[0]
     var browserLang = '';
         : navigator.language || navigator.userLanguage || 'en';
   
 
    // Проверяем все возможные свойства
     var lang = userLangRaw.slice(0, 2).toLowerCase();
    if (navigator.languages && navigator.languages.length > 0) {
         browserLang = navigator.languages[0];
    } else if (navigator.language) {
         browserLang = navigator.language;
    } else if (navigator.userLanguage) {
        browserLang = navigator.userLanguage;
    } else if (navigator.systemLanguage) {
        browserLang = navigator.systemLanguage;
    } else {
        browserLang = 'en';
    }
   
    console.log('Browser language:', browserLang);
   
    // Извлекаем код языка
     var lang = browserLang.slice(0, 2).toLowerCase();
    console.log('Extracted language code:', lang);
   
    // Определяем поддерживаемый язык
     var userLang = supportedLanguages.includes(lang) ? lang : 'en';
     var userLang = supportedLanguages.includes(lang) ? lang : 'en';
    console.log('Final language:', userLang);


     function processLangBlocks(container) {
     function processLangBlocks(container) {
         container.innerHTML = container.innerHTML.replace(
         container.innerHTML = container.innerHTML.replace(
             /\{ru\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
             /\{ru\}([\s\S]*?)\{es\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
             function(match, ruText, enText) {
             function(match, ruText, esText, enText) {
                 return '<span class="lang-processed">' +
                 if (userLang === 'ru') {
                     (userLang === 'ru' ? ruText.trim() : enText.trim()) +
                     return ruText.trim();
                 '</span>';
                } else if (userLang === 'es') {
                    return esText.trim();
                } else {
                    return enText.trim();
                 }
             }
             }
         );
         );
     }
     }


     // Эффект скелетона: обернём все языковые блоки в placeholder до обработки
     processLangBlocks(document.body);
    document.querySelectorAll('body').forEach(function (el) {
        el.innerHTML = el.innerHTML.replace(
            /\{ru\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
            function () {
                return '<span class="lang-placeholder">&nbsp;</span>';
            }
        );
    });
 
    // После небольшой задержки (или сразу после загрузки), показываем нужный язык
    window.addEventListener('DOMContentLoaded', function () {
        setTimeout(function () {
            processLangBlocks(document.body);
        }, 100); // можно увеличить для наглядного эффекта
    });
});
});

Текущая версия от 06:26, 18 октября 2025

mw.loader.using('mediawiki.util').then(function () {
    // Не выполнять скрипт на странице редактирования
    if (location.href.includes('action=edit')) return;
    if (location.href.includes('action=submit')) return;

    // Поддерживаемые языки: русский, испанский и английский
    var supportedLanguages = ['ru', 'es', 'en'];

    // Получаем язык браузера
    var browserLang = '';
    
    // Проверяем все возможные свойства
    if (navigator.languages && navigator.languages.length > 0) {
        browserLang = navigator.languages[0];
    } else if (navigator.language) {
        browserLang = navigator.language;
    } else if (navigator.userLanguage) {
        browserLang = navigator.userLanguage;
    } else if (navigator.systemLanguage) {
        browserLang = navigator.systemLanguage;
    } else {
        browserLang = 'en';
    }
    
    console.log('Browser language:', browserLang);
    
    // Извлекаем код языка
    var lang = browserLang.slice(0, 2).toLowerCase();
    console.log('Extracted language code:', lang);
    
    // Определяем поддерживаемый язык
    var userLang = supportedLanguages.includes(lang) ? lang : 'en';
    console.log('Final language:', userLang);

    function processLangBlocks(container) {
        container.innerHTML = container.innerHTML.replace(
            /\{ru\}([\s\S]*?)\{es\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
            function(match, ruText, esText, enText) {
                if (userLang === 'ru') {
                    return ruText.trim();
                } else if (userLang === 'es') {
                    return esText.trim();
                } else {
                    return enText.trim();
                }
            }
        );
    }

    processLangBlocks(document.body);
});