MediaWiki:Common.js: различия между версиями
Перейти к навигации
Перейти к поиску
- старое |
Нет описания правки |
||
| Строка 184: | Строка 184: | ||
iframe.style.maxWidth = '100%'; | iframe.style.maxWidth = '100%'; | ||
iframe.setAttribute('sandbox', 'allow-scripts allow-same-origin | iframe.setAttribute('sandbox', 'allow-scripts allow-same-origin'); | ||
iframe.setAttribute('referrerpolicy', 'strict-origin-when-cross-origin'); | iframe.setAttribute('referrerpolicy', 'strict-origin-when-cross-origin'); | ||
iframe.setAttribute('loading', 'lazy'); | iframe.setAttribute('loading', 'lazy'); | ||
Версия от 07:43, 1 ноября 2025
/* Нигилистические фокусы (см. шаблон {{Нигилизм}}) */
$(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'});
});
}
});
/* Стирание памяти для [[MIB]] («Людей в чёрном») */
$(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) {
var username = mw.config.get("wgUserName");
$("span.insertusername").text(username);
}
});
/* Замена категорий для шаблона {{Cats}} */
$(function () {
var categoriesAlternative = $("#categories_alternative");
if (categoriesAlternative[0]) {
$('#mw-normal-catlinks').html(categoriesAlternative.html());
categoriesAlternative.hide();
}
});
/* Вставка VK-видео на страницу для шаблона {{VKVideo}} */
(function() {
'use strict';
function initVKVideo() {
var containers = document.querySelectorAll('.vk-video-js');
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') || '560';
var height = container.getAttribute('data-height') || '315';
width = parseInt(width) || 560;
height = parseInt(height) || 315;
if (width > 1920) width = 1920;
if (height < 100) height = 100;
if (height > 1080) height = 1080;
if (oid && id && oid !== 'null' && id !== 'null' && /^[a-zA-Z0-9_-]{1,100}$/.test(oid) && /^[-_a-zA-Z0-9]+$/.test(id)) {
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.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 red';
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);
}
}
}
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', initVKVideo);
} else {
initVKVideo();
}
})();
/* Вставка Rutube-видео на страницу для шаблона {{Rutube}} */
(function() {
'use strict';
function sanitizeVideoId(videoId) {
if (typeof videoId !== 'string') return null;
return videoId.match(/^[a-zA-Z0-9_-]+$/) ? videoId : null;
}
function sanitizeDimension(dim, defaultValue, maxValue) {
if (typeof dim !== 'string') return defaultValue;
const cleanDim = dim.match(/^(100|[1-9]\d?)%$|^\d+$/) ? dim : defaultValue;
if (cleanDim.match(/^\d+$/)) {
const numValue = parseInt(cleanDim, 10);
return (numValue >= 100 && numValue <= maxValue) ? cleanDim : defaultValue;
}
return cleanDim;
}
function initRutubeEmbeds() {
var embeds = document.querySelectorAll('.rutube-video-embed:not([data-processed])');
embeds.forEach(function(embed) {
var rawVideoId = embed.getAttribute('data-video-id');
var videoId = sanitizeVideoId(rawVideoId);
if (!videoId) {
console.warn('Invalid Rutube video ID format');
embed.setAttribute('data-processed', 'true');
return;
}
var width = sanitizeDimension(embed.getAttribute('data-width'), '560', 1920);
var height = sanitizeDimension(embed.getAttribute('data-height'), '315', 1080);
var iframe = document.createElement('iframe');
iframe.src = 'https://rutube.ru/play/embed/' + encodeURIComponent(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';
iframe.style.maxWidth = '100%';
iframe.setAttribute('sandbox', 'allow-scripts allow-same-origin');
iframe.setAttribute('referrerpolicy', 'strict-origin-when-cross-origin');
iframe.setAttribute('loading', 'lazy');
iframe.setAttribute('importance', 'low');
iframe.addEventListener('error', function() {
clearTimeout(loadTimeout);
console.error('Rutube iframe failed to load:', videoId);
if (embed.parentNode && iframe.parentNode === embed) {
const errorMsg = document.createElement('p');
errorMsg.textContent = 'Не удалось загрузить видео';
errorMsg.style.padding = '20px';
errorMsg.style.textAlign = 'center';
errorMsg.style.color = '#666';
embed.replaceChild(errorMsg, iframe);
}
});
while (embed.firstChild) {
embed.removeChild(embed.firstChild);
}
embed.appendChild(iframe);
embed.setAttribute('data-processed', 'true');
});
}
if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', initRutubeEmbeds);
} else {
initRutubeEmbeds();
}
if (typeof mw !== 'undefined' && mw.hook) {
mw.hook('wikipage.content').add(initRutubeEmbeds);
}
})();