Dantes (обсуждение | вклад) Нет описания правки Метка: ручная отмена |
Dantes (обсуждение | вклад) Нет описания правки |
||
(не показано 9 промежуточных версий этого же участника) | |||
Строка 84: | Строка 84: | ||
/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */ | /* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */ | ||
mw.loader.using(['mediawiki.util'], function () { | mw.loader.using(['mediawiki.util'], function () { | ||
var | var cards = document.querySelectorAll('.planet-card'); | ||
for (var i = 0; i < | for (var i = 0; i < cards.length; i++) { | ||
(function ( | (function (card) { | ||
var link = | var link = card.querySelector('.planet-name a'); | ||
if (link) { | if (link) { | ||
card.style.cursor = 'pointer'; | |||
card.onclick = function () { | |||
window.location.href = link.href; | window.location.href = link.href; | ||
}; | }; | ||
} | } | ||
})( | })(cards[i]); | ||
} | } | ||
}); | }); | ||
Строка 111: | Строка 101: | ||
/* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */ | /* ----------------------------------------------------------Главное меню лора------------------------------------------------------------------------ */ | ||
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ | /* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ | ||
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(); | |||
var descriptionPanel = document.querySelector('.planet-description-panel'); | |||
if (activeCard) { | |||
activeCard.classList.remove('active'); | |||
descriptionPanel.classList.remove('active'); | |||
overlay.classList.remove('active'); | |||
activeCard = null; | |||
} | |||
if (activeCard !== card) { | |||
activeCard = card; | |||
card.classList.add('active'); | |||
overlay.classList.add('active'); | |||
// Динамическое размещение панели описания | |||
var cardRect = card.getBoundingClientRect(); | |||
descriptionPanel.style.top = `${cardRect.top}px`; | |||
descriptionPanel.style.left = `${cardRect.right + 10}px`; | |||
descriptionPanel.innerHTML = card.querySelector('.planet-description').innerHTML; | |||
descriptionPanel.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; | |||
} | |||
}); | |||
}); | |||
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ | /* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ |
Текущая версия от 18:15, 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(); var descriptionPanel = document.querySelector('.planet-description-panel'); if (activeCard) { activeCard.classList.remove('active'); descriptionPanel.classList.remove('active'); overlay.classList.remove('active'); activeCard = null; } if (activeCard !== card) { activeCard = card; card.classList.add('active'); overlay.classList.add('active'); // Динамическое размещение панели описания var cardRect = card.getBoundingClientRect(); descriptionPanel.style.top = `${cardRect.top}px`; descriptionPanel.style.left = `${cardRect.right + 10}px`; descriptionPanel.innerHTML = card.querySelector('.planet-description').innerHTML; descriptionPanel.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; } }); }); /* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */