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

Страница интерфейса MediaWiki
Нет описания правки
Нет описания правки
Метка: ручная отмена
Строка 111: Строка 111:
/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */
/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */
(function () {
    var container = document.createElement('div');
    container.style.position = 'relative';
    container.style.width = '100%';
    container.style.height = '600px';
    container.style.backgroundColor = 'black';
    container.style.overflow = 'hidden';
    var planets = [
        { name: 'Потерянный мир Лумла', img: 'Земля.png', size: 100, x: 20, y: 40 },
        { name: 'Земля', img: 'Земля.png', size: 120, x: 60, y: 50 },
        { name: 'Аттонис', img: 'Аттонис.png', size: 80, x: 30, y: 70 },
        { name: 'Кантесс', img: 'Земля.png', size: 110, x: 80, y: 20 },
        { name: 'Магма-Карак', img: 'Земля.png', size: 90, x: 50, y: 10 }
    ];
    for (var i = 0; i < planets.length; i++) {
        var planet = planets[i];
        var planetDiv = document.createElement('div');
        planetDiv.style.position = 'absolute';
        planetDiv.style.width = planet.size + 'px';
        planetDiv.style.height = planet.size + 'px';
        planetDiv.style.left = planet.x + '%';
        planetDiv.style.top = planet.y + '%';
        planetDiv.style.transform = 'translate(-50%, -50%)';
        planetDiv.style.borderRadius = '50%';
        planetDiv.style.backgroundImage = 'url(/w/images/' + planet.img + ')';
        planetDiv.style.backgroundSize = 'cover';
        planetDiv.style.animation = 'rotate ' + (10 + Math.random() * 10) + 's linear infinite';
        var link = document.createElement('a');
        link.href = '/wiki/' + encodeURIComponent(planet.name);
        link.style.display = 'block';
        link.style.width = '100%';
        link.style.height = '100%';
        planetDiv.appendChild(link);
        container.appendChild(planetDiv);
    }
    document.body.insertBefore(container, document.body.firstChild);
    var style = document.createElement('style');
    style.textContent =
        '@keyframes rotate {' +
            '0% { transform: translate(-50%, -50%) rotate(0deg); }' +
            '100% { transform: translate(-50%, -50%) rotate(360deg); }' +
        '}';
    document.head.appendChild(style);
})();


/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */

Версия от 19:06, 21 ноября 2024

/* ----------------------------------------------Блок Shegare ---------------------------------------------------------------------------------*/
/* Лого сайта
Shegare */
document.getElementsByClassName('citizen-header__logo')[0].innerHTML = '<div class="logo1"><a href="https://spacestories.club/index.php?title=Заглавная страница" class="mw-logo citizen-header__button" title="Перейти на заглавную страницу"><img class="mw-logo-icon" src="/resources/assets/logo.png" alt="" aria-hidden="true" height="32" width="32"</a></div><div class="logo2"><a href="https://spacestories.club/index.php?title=Colonial_Marines" class="mw-logo citizen-header__button" title="Перейти на заглавную страницу CM"><img class="mw-logo-icon" src="/images/0/0d/CMlog.png" alt="" aria-hidden="true" height="32" width="32"></a></div>';


/* Перенос page-info в конец footer-places
Shegare */
document.getElementById('footer-places').insertAdjacentHTML('afterEnd', document.getElementsByClassName('page-info')[0].innerHTML);
document.getElementsByClassName('page-info')[0].innerHTML = null;


/* Begin логика цвета через headerColor
Shegare */
if(document.getElementsByClassName('headerColor').length >= 1) {

	var isValidColor = function(color) {
	  var el = document.createElement('div');
	  el.style.backgroundColor = color;
	  return el.style.backgroundColor ? true : false;
	};

    var header = document.getElementsByClassName('headerColor');

    var colorBorder = '';
    var colorBtn = '';

    var i = 0;
    for(; header[0].innerHTML[i] !== '|' && i < header[0].innerHTML.length; i++)
    {
        colorBorder += header[0].innerHTML[i];
    }
    i++;
    for(; i < header[0].innerHTML.length; i++)
    {
        colorBtn += header[0].innerHTML[i];
    }

	if(isValidColor(colorBorder) && isValidColor(colorBtn) && header[0].innerHTML.length > 0) {
	    headerRender (colorBorder, colorBtn);

	    document.body.addEventListener('click', function() {
	        headerRender(colorBorder, colorBtn);
	    });
	}
    else {
    	throw "headerColor";
    }
}

function headerRender (colorBorder, colorBtn) {
    var array = document.querySelectorAll('h1, h2, h3 , h4, h5');
    for(var i = 0; i < array.length; i++)
    {
        if (array[i].className === 'citizen-section-heading') {
            array[i].querySelector('.citizen-sections-enabled,.citizen-section-indicator').style.background = colorBtn;
            array[i].querySelector('.citizen-sections-enabled,.citizen-section-indicator').style.boxShadow  = ('0 0 20px 0px ' + colorBtn + 'cc');
            array[i].querySelector('.mw-headline').style.borderImage = ('linear-gradient(to right top, ' + colorBorder + ', black)');
            array[i].querySelector('.mw-headline').style.borderImageSlice = '1';

        }
        else if(array[i].className === 'citizen-section-heading citizen-section-heading--collapsed') {
            array[i].querySelector('.citizen-sections-enabled,.citizen-section-heading--collapsed,.citizen-section-indicator').style.background = 'black';
            array[i].querySelector('.citizen-sections-enabled,.citizen-section-heading--collapsed,.citizen-section-indicator').style.boxShadow = 'unset';
        }
    }
}
/* End логика цвета через headerColor
Shegare */


/* Begin sidebar для ролей
Shegare */

if(document.getElementsByClassName('JobsTableContainer').length >= 1) {
	document.getElementById('content').insertAdjacentHTML('afterbegin', document.getElementsByClassName('JobsTableContainer')[0].innerHTML);
	document.getElementById('IdJobsTableContainer1').id = 'IdJobsTableContainer2';
	document.getElementById('content').style.display = 'flex';
	document.getElementById('bodyContent').style.minHeight = '1350px';
}


/* ----------------------------------------------------------Данте------------------------------------------------------------------------ */
/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */
mw.loader.using(['mediawiki.util'], function () {
    var items = document.querySelectorAll('.custom-item');

    for (var i = 0; i < items.length; i++) {
        (function (item) {
            var link = item.querySelector('a');
            if (link) {
                item.style.cursor = 'pointer';
                item.onclick = function () {
                    window.location.href = link.href;
                };

                item.onmouseover = function () {
                    item.style.transform = 'scale(1.05)';
                    item.style.boxShadow = '0 4px 15px rgba(255, 255, 255, 0.3)';
                };

                item.onmouseout = function () {
                    item.style.transform = 'scale(1)';
                    item.style.boxShadow = 'none';
                };
            }
        })(items[i]);
    }
});

/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */

/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */