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

Alternative using object embed
Откат правки 362378 участника Тэйтанка-птекила (обс.)
Метка: отмена
 
(не показано 55 промежуточных версий этого же участника)
Строка 1: Строка 1:
/* Нигилистические фокусы (см. [[Шаблон:Нигилизм/doc]]) */
/* Нигилистические фокусы (см. шаблон {{tl|Нигилизм}}) */
$(function () {
$(function () {
     var nihilism = $('#nihilism');
     var nihilism = $('#nihilism');
Строка 20: Строка 20:
});
});


/* Стирание памяти для «Людей в чёрном» */
/* Стирание памяти для [[MIB]] («Людей в чёрном») */
$(function () {
$(function () {
     if ($("#erase_memory")[0])
     if ($("#erase_memory")[0])
Строка 50: Строка 50:
/* Вставка юзернейма с помощью <span class="insertusername"></span> */
/* Вставка юзернейма с помощью <span class="insertusername"></span> */
$(function () {
$(function () {
     if ((typeof (disableUsernameReplace) == "undefined" || !disableUsernameReplace) && mw.config.get("wgUserName") !== null)
     if ((typeof (disableUsernameReplace) == "undefined" || !disableUsernameReplace) && mw.config.get("wgUserName") !== null) {
         $("span.insertusername").html(mw.config.get("wgUserName"));
        var username = mw.config.get("wgUserName");
         $("span.insertusername").text(username);
    }
});
});


function defaultUploadInfo() {
    var rewrite = document.getElementById("wpForReUpload");
    if (!rewrite) return;
    if (rewrite.value == 1) return;
    var d = document.getElementById("wpUploadDescription");
    if (d) {
        if (!d.value.match(/\[\[(Категория|Category):/)) {
            d.value += "\n\n\n[[Категория:Некатегоризованные изображения]]";
        }
    }
}


/* Замена категорий для шаблона {{Cats}} */
/* Замена категорий для шаблона {{Cats}} */
Строка 77: Строка 67:




/* Функция для вставки VK-видео на страницу для шаблона VKVideo, простая версия */
/* Вставка VK-видео на страницу для шаблона {{VKVideo}} */
window.vkVideoInit = function() {
    console.log('VK Video: Initializing...');
   
    var containers = document.querySelectorAll('.vk-video-js');
    console.log('VK Video: Found ' + containers.length + ' containers');
   
    for (var i = 0; i < containers.length; i++) {
        var container = containers[i];
        var oid = container.getAttribute('data-oid');
        var id = container.getAttribute('data-id');
        var width = container.getAttribute('data-width') || '640';
        var height = container.getAttribute('data-height') || '360';
       
        console.log('VK Video: Container ' + i + ' - oid:' + oid + ' id:' + id);
       
        if (oid && id && oid !== 'null' && id !== 'null') {
            var iframe = document.createElement('iframe');
            iframe.src = 'https://vk.com/video_ext.php?oid=' + encodeURIComponent(oid) + '&id=' + encodeURIComponent(id);
            iframe.width = width;
            iframe.height = height;
            iframe.frameBorder = '0';
            iframe.allowFullscreen = true;
            iframe.style.border = 'none';
            iframe.style.borderRadius = '4px';
           
            container.innerHTML = '';
            container.appendChild(iframe);
            console.log('VK Video: Container ' + i + ' - SUCCESS');
        } else {
            console.error('VK Video: Container ' + i + ' - MISSING DATA');
            container.innerHTML = '<div style="color: red; padding: 10px; text-align: center; border: 1px solid red;">Ошибка: неверные параметры видео</div>';
        }
    }
};
 
    /* Запускаем после загрузки ВК-видео DOM */
if (document.readyState === 'loading') {
    document.addEventListener('DOMContentLoaded', window.vkVideoInit);
} else {
    window.vkVideoInit();
}
 
 
/* Функция для вставки Rutube-видео на страницу для шаблона Rutube, простая версия */
(function() {
(function() {
     'use strict';
     'use strict';
      
      
     function createRutubeObject(videoId) {
     function initVKVideo() {
         var object = document.createElement('object');
         var containers = document.querySelectorAll('.vk-video-js');
        object.setAttribute('data', 'https://rutube.ru/play/embed/' + videoId);
        object.setAttribute('width', '560');
        object.setAttribute('height', '315');
        object.setAttribute('type', 'text/html');
          
          
         var fallback = document.createElement('a');
         for (var i = 0; i < containers.length; i++) {
        fallback.setAttribute('href', 'https://rutube.ru/video/' + videoId + '/');
            var container = containers[i];
        fallback.textContent = 'Смотреть видео на Rutube';
            var oid = container.getAttribute('data-oid');
        object.appendChild(fallback);
            var id = container.getAttribute('data-id');
       
            var width = container.getAttribute('data-width') || '560';
        object.style.border = 'none';
            var height = container.getAttribute('data-height') || '315';
        object.style.display = 'block';
           
       
            width = parseInt(width) || 560;
        return object;
            height = parseInt(height) || 315;
    }
             if (width > 1920) width = 1920;
   
            if (height < 100) height = 100;
    function initRutubePlayers() {
            if (height > 1080) height = 1080;
        var players = document.querySelectorAll('.rutube-player[data-video-id]');
       
        players.forEach(function(player) {
             if (player.hasAttribute('data-processed')) return;
              
              
             var videoId = player.getAttribute('data-video-id');
             if (oid && id && oid !== 'null' && id !== 'null' && /^[a-zA-Z0-9_-]{1,100}$/.test(oid) && /^[-_a-zA-Z0-9]+$/.test(id)) {
            if (videoId) {
                var iframe = document.createElement('iframe');
                 var embed = createRutubeObject(videoId);
                iframe.src = 'https://vk.com/video_ext.php?oid=' + encodeURIComponent(oid) + '&id=' + encodeURIComponent(id);
                 player.appendChild(embed);
                iframe.width = width;
                 player.setAttribute('data-processed', 'true');
                iframe.height = height;
                iframe.frameBorder = '0';
                iframe.allowFullscreen = true;
               
                iframe.sandbox = 'allow-scripts allow-same-origin allow-presentation allow-fullscreen';
                iframe.allow = 'fullscreen';
                iframe.referrerPolicy = 'no-referrer';
                iframe.loading = 'lazy';
                 iframe.style.border = 'none';
               
                while (container.firstChild) {
                    container.removeChild(container.firstChild);
                 }
                container.appendChild(iframe);
            } else {
                 var errorDiv = document.createElement('div');
               
                errorDiv.style.color = 'red';
                errorDiv.style.padding = '10px';
                errorDiv.style.textAlign = 'center';
                errorDiv.style.border = '1px solid';
                errorDiv.style.backgroundColor = '#fff';
                errorDiv.style.fontFamily = 'Arial, sans-serif';
                errorDiv.style.fontSize = '14px';
                errorDiv.style.margin = '5px 0';
 
                errorDiv.textContent = 'Ошибка: неверные параметры видео';
               
                while (container.firstChild) {
                    container.removeChild(container.firstChild);
                }
                container.appendChild(errorDiv);
             }
             }
         });
         }
     }
     }
      
      
     document.addEventListener('DOMContentLoaded', initRutubePlayers);
     if (document.readyState === 'loading') {
        document.addEventListener('DOMContentLoaded', initVKVideo);
    } else {
        initVKVideo();
    }
})();
})();