Dantes (обсуждение | вклад) Нет описания правки |
Dantes (обсуждение | вклад) Нет описания правки |
||
Строка 104: | Строка 104: | ||
var cards = document.querySelectorAll('.planet-card'); | var cards = document.querySelectorAll('.planet-card'); | ||
var container = document.querySelector('.planet-container'); | var container = document.querySelector('.planet-container'); | ||
var overlay = document.createElement('div'); | |||
overlay.className = 'overlay'; | |||
document.body.appendChild(overlay); | |||
var activeCard = null; | var activeCard = null; | ||
cards.forEach(function (card) { | cards.forEach(function (card) { | ||
card.addEventListener('click', function () { | card.addEventListener('click', function (e) { | ||
e.stopPropagation(); | |||
if (activeCard) { | if (activeCard) { | ||
activeCard.classList.remove('active'); | activeCard.classList.remove('active'); | ||
document.querySelector('.planet-description-panel').classList.remove('active'); | document.querySelector('.planet-description-panel').classList.remove('active'); | ||
overlay.classList.remove('active'); | |||
activeCard = null; | |||
} | } | ||
Строка 120: | Строка 126: | ||
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.addEventListener('click', function () { | |||
if (activeCard) { | |||
activeCard.classList.remove('active'); | |||
document.querySelector('.planet-description-panel').classList.remove('active'); | |||
overlay.classList.remove('active'); | |||
activeCard = null; | |||
} | |||
}); | }); | ||
}); | }); | ||
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ | /* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ |
Версия от 17:49, 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 container = document.querySelector('.planet-container'); var overlay = document.createElement('div'); overlay.className = 'overlay'; document.body.appendChild(overlay); var activeCard = null; cards.forEach(function (card) { card.addEventListener('click', function (e) { 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; } }); }); /* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */