Dantes (обсуждение | вклад) Нет описания правки |
Dantes (обсуждение | вклад) (Отмена правки 13766, сделанной Dantes (обсуждение)) Метка: отмена |
||
| Строка 125: | Строка 125: | ||
var descriptionPanel = document.querySelector('.planet-description-panel'); | var descriptionPanel = document.querySelector('.planet-description-panel'); | ||
descriptionPanel.innerHTML = card.querySelector('.planet-description').innerHTML; | descriptionPanel.innerHTML = card.querySelector('.planet-description').innerHTML; | ||
descriptionPanel.classList.add('active'); | descriptionPanel.classList.add('active'); | ||
overlay.classList.add('active'); | overlay.classList.add('active'); | ||
Версия от 18:13, 22 ноября 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 cards = document.querySelectorAll('.planet-card');
for (var i = 0; i < cards.length; i++) {
(function (card) {
var link = card.querySelector('.planet-name a');
if (link) {
card.style.cursor = 'pointer';
card.onclick = function () {
window.location.href = link.href;
};
}
})(cards[i]);
}
});
/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */
mw.loader.using(['mediawiki.util'], function () {
var cards = document.querySelectorAll('.planet-card');
var overlay = document.createElement('div');
overlay.className = 'overlay';
document.body.appendChild(overlay);
var activeCard = null;
cards.forEach(function (card) {
card.addEventListener('click', function (e) {
if (e.target.tagName === 'A') return;
e.stopPropagation();
if (activeCard) {
activeCard.classList.remove('active');
document.querySelector('.planet-description-panel').classList.remove('active');
overlay.classList.remove('active');
activeCard = null;
}
if (activeCard !== card) {
activeCard = card;
card.classList.add('active');
var descriptionPanel = document.querySelector('.planet-description-panel');
descriptionPanel.innerHTML = card.querySelector('.planet-description').innerHTML;
descriptionPanel.classList.add('active');
overlay.classList.add('active');
}
});
});
overlay.addEventListener('click', function () {
if (activeCard) {
activeCard.classList.remove('active');
document.querySelector('.planet-description-panel').classList.remove('active');
overlay.classList.remove('active');
activeCard = null;
}
});
});
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */