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

Материал из Ascaron Online
Перейти к навигации Перейти к поиску
Нет описания правки
Метка: отменено
Нет описания правки
Метка: отменено
Строка 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;


    // Поддерживаемые языки
     var supportedLanguages = ['ru', 'en'];
     var supportedLanguages = ['ru', 'en'];


    // Определяем язык из браузера (Accept-Language)
     var userLangRaw = navigator.languages && navigator.languages.length
     var userLangRaw = navigator.languages && navigator.languages.length
         ? navigator.languages[0]
         ? navigator.languages[0]
Строка 28: Строка 12:


     var lang = userLangRaw.slice(0, 2).toLowerCase();
     var lang = userLangRaw.slice(0, 2).toLowerCase();
    // Если язык не поддерживается — по умолчанию 'en'
     var userLang = supportedLanguages.includes(lang) ? lang : 'en';
     var userLang = supportedLanguages.includes(lang) ? lang : 'en';


Строка 34: Строка 20:
             /\{ru\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
             /\{ru\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
             function(match, ruText, enText) {
             function(match, ruText, enText) {
                 return '<span class="lang-processed">' +
                 return '<span class="lang-processed" style="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;">' +
                     (userLang === 'ru' ? ruText.trim() : enText.trim()) +
                     (userLang === 'ru' ? ruText.trim() : enText.trim()) +
                 '</span>';
                 '</span>';
Строка 46: Строка 32:
             /\{ru\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
             /\{ru\}([\s\S]*?)\{else\}([\s\S]*?)\{end\}/gi,
             function () {
             function () {
                 return '<span class="lang-placeholder">&nbsp;</span>';
                 return '<span class="lang-placeholder" style="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;">&nbsp;</span>';
             }
             }
         );
         );

Версия от 07:14, 5 апреля 2025

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

    // Поддерживаемые языки
    var supportedLanguages = ['ru', 'en'];

    // Определяем язык из браузера (Accept-Language)
    var userLangRaw = navigator.languages && navigator.languages.length
        ? navigator.languages[0]
        : navigator.language || navigator.userLanguage || 'en';

    var lang = userLangRaw.slice(0, 2).toLowerCase();

    // Если язык не поддерживается — по умолчанию 'en'
    var userLang = supportedLanguages.includes(lang) ? lang : 'en';

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

    // Эффект скелетона: обернём все языковые блоки в placeholder до обработки
    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" style="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;">&nbsp;</span>';
            }
        );
    });

    // После небольшой задержки (или сразу после загрузки), показываем нужный язык
    window.addEventListener('DOMContentLoaded', function () {
        setTimeout(function () {
            processLangBlocks(document.body);
        }, 100); // можно увеличить для наглядного эффекта
    });
});