MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
Нет описания правки |
Нет описания правки |
||
| Строка 122: | Строка 122: | ||
/* Функция для вставки Rutube-видео на страницу для шаблона Rutube, простая версия */ | /* Функция для вставки Rutube-видео на страницу для шаблона Rutube, простая версия */ | ||
mw. | mw.loader.using('mediawiki.util').then(function() { | ||
function initRutubePlayers() { | |||
var | var players = document.querySelectorAll('.rutube-player'); | ||
if ( | if (players.length === 0) return; | ||
var script = document.createElement('script'); | |||
script.src = 'https://rutube.ru/static/api/api.js'; | |||
script.onload = function() { | |||
initializePlayers(players); | |||
}; | |||
document.head.appendChild(script); | |||
} | |||
function initializePlayers(players) { | |||
players.forEach(function(player) { | |||
var videoId = player.getAttribute('data-video-id'); | |||
var width = player.getAttribute('data-width') || '560'; | |||
var height = player.getAttribute('data-height') || '315'; | |||
if (videoId && window.Rutube) { | |||
var playerContainer = document.createElement('div'); | |||
playerContainer.id = 'rutube-player-' + Date.now() + '-' + Math.random().toString(36).substr(2, 9); | |||
player.innerHTML = ''; | |||
player.appendChild(playerContainer); | |||
try { | |||
window.Rutube.init(playerContainer.id, { | |||
video: videoId, | |||
width: width, | |||
height: height, | |||
parent: window.location.hostname | |||
}); | |||
} catch (e) { | |||
console.error('Error initializing Rutube player:', e); | |||
fallbackEmbed(player, videoId, width, height); | |||
} | |||
} else if (videoId) { | |||
// Fallback если API не загрузилось | |||
fallbackEmbed(player, videoId, width, height); | |||
} | |||
}); | |||
} | |||
// Fallback метод через iframe | |||
function fallbackEmbed(player, videoId, width, height) { | |||
var iframe = document.createElement('iframe'); | var iframe = document.createElement('iframe'); | ||
iframe.src = 'https://rutube.ru/embed/' + videoId | iframe.src = 'https://rutube.ru/play/embed/' + videoId; | ||
iframe.width = | iframe.width = width; | ||
iframe.height = | iframe.height = height; | ||
iframe.frameBorder = '0'; | iframe.frameBorder = '0'; | ||
iframe.allow = 'autoplay; fullscreen; picture-in-picture'; | |||
iframe.allowFullscreen = true; | iframe.allowFullscreen = true; | ||
iframe.style.border = 'none'; | iframe.style.border = 'none'; | ||
iframe.style.display = 'block'; | iframe.style.display = 'block'; | ||
player.innerHTML = ''; | |||
player.appendChild(iframe); | |||
} | |||
// Инициализируем при загрузке страницы | |||
mw.hook('wikipage.content').add(function($content) { | |||
initRutubePlayers(); | |||
}); | }); | ||
// Инициализируем существующие плееры | |||
if (document.readyState === 'loading') { | |||
document.addEventListener('DOMContentLoaded', initRutubePlayers); | |||
} else { | |||
initRutubePlayers(); | |||
} | |||
}); | }); | ||
Версия от 08:30, 28 октября 2025
/* Нигилистические фокусы (см. [[Шаблон:Нигилизм/doc]]) */
$(function () {
var nihilism = $('#nihilism');
if (nihilism[0] && !document.location.href.match("diff")) {
var msg = nihilism.html();
if (!nihilism.hasClass('nihilism-no-white')) {
$('body').css('background-color', 'white');
}
var scripts = $('script');
var bodyNihilism = $('body').html('');
var divNihilism = $('<div class="mw-parser-output"></div>').html(msg);
if (nihilism.css('top') == '0px') {
bodyNihilism.css('top', '0px').css('left', '0px');
}
bodyNihilism.append(divNihilism).append(scripts);
$(document).dblclick(function () {
window.location = mw.util.getUrl(null, {'action': 'edit'});
});
}
});
/* Стирание памяти для «Людей в чёрном» */
$(function () {
if ($("#erase_memory")[0])
setTimeout(function () { $("#erase_memory").hide(); }, 20000);
});
/* Ссылка «править» для нулевой секции */
$(function () {
var zeroSectionTip = "Править введение";
if (!mw.config.get("wgArticleId")) {
return;
}
var action = mw.config.get("wgAction");
if (action != "view" && action != "purge")
return;
mw.util.$content.find("h2").children(".mw-editsection:first").clone().prependTo("#bodyContent").css("float", "right").find("a").each(function (index) {
$(this).attr("title", zeroSectionTip);
if ($(this).attr("class") === "mw-editsection-visualeditor") {
$(this).attr("href", mw.config.get("wgScript") + "?title=" + mw.util.wikiUrlencode(mw.config.get("wgPageName")) + "&veaction=edit&vesection=0&summary=/*%20Преамбула%20*/%20");
} else {
$(this).attr("href", mw.config.get("wgScript") + "?title=" + mw.util.wikiUrlencode(mw.config.get("wgPageName")) + "&action=edit§ion=0&summary=/*%20Преамбула%20*/%20");
}
});
});
/* Вставка юзернейма с помощью <span class="insertusername"></span> */
$(function () {
if ((typeof (disableUsernameReplace) == "undefined" || !disableUsernameReplace) && mw.config.get("wgUserName") !== null)
$("span.insertusername").html(mw.config.get("wgUserName"));
});
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}} */
$(function () {
var categoriesAlternative = $("#categories_alternative");
if (categoriesAlternative[0]) {
$('#mw-normal-catlinks').html(categoriesAlternative.html());
categoriesAlternative.hide();
}
});
/* Функция для вставки 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, простая версия */
mw.loader.using('mediawiki.util').then(function() {
function initRutubePlayers() {
var players = document.querySelectorAll('.rutube-player');
if (players.length === 0) return;
var script = document.createElement('script');
script.src = 'https://rutube.ru/static/api/api.js';
script.onload = function() {
initializePlayers(players);
};
document.head.appendChild(script);
}
function initializePlayers(players) {
players.forEach(function(player) {
var videoId = player.getAttribute('data-video-id');
var width = player.getAttribute('data-width') || '560';
var height = player.getAttribute('data-height') || '315';
if (videoId && window.Rutube) {
var playerContainer = document.createElement('div');
playerContainer.id = 'rutube-player-' + Date.now() + '-' + Math.random().toString(36).substr(2, 9);
player.innerHTML = '';
player.appendChild(playerContainer);
try {
window.Rutube.init(playerContainer.id, {
video: videoId,
width: width,
height: height,
parent: window.location.hostname
});
} catch (e) {
console.error('Error initializing Rutube player:', e);
fallbackEmbed(player, videoId, width, height);
}
} else if (videoId) {
// Fallback если API не загрузилось
fallbackEmbed(player, videoId, width, height);
}
});
}
// Fallback метод через iframe
function fallbackEmbed(player, videoId, width, height) {
var iframe = document.createElement('iframe');
iframe.src = 'https://rutube.ru/play/embed/' + videoId;
iframe.width = width;
iframe.height = height;
iframe.frameBorder = '0';
iframe.allow = 'autoplay; fullscreen; picture-in-picture';
iframe.allowFullscreen = true;
iframe.style.border = 'none';
iframe.style.display = 'block';
player.innerHTML = '';
player.appendChild(iframe);
}
// Инициализируем при загрузке страницы
mw.hook('wikipage.content').add(function($content) {
initRutubePlayers();
});
// Инициализируем существующие плееры
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', initRutubePlayers);
} else {
initRutubePlayers();
}
});