SHEGARE (обсуждение | вклад) Нет описания правки |
Dantes (обсуждение | вклад) Нет описания правки |
||
(не показано 227 промежуточных версий 2 участников) | |||
Строка 1: | Строка 1: | ||
/* ----------------------------------------------Блок Shegare ---------------------------------------------------------------------------------*/ | |||
/* Лого сайта | /* Лого сайта | ||
Shegare */ | Shegare */ | ||
Строка 13: | Строка 14: | ||
Shegare */ | Shegare */ | ||
if(document.getElementsByClassName('headerColor').length >= 1) { | 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 header = document.getElementsByClassName('headerColor'); | ||
Строка 19: | Строка 27: | ||
var i = 0; | var i = 0; | ||
for(; header[0].innerHTML[i] !== '|'; i++) | for(; header[0].innerHTML[i] !== '|' && i < header[0].innerHTML.length; i++) | ||
{ | { | ||
colorBorder += header[0].innerHTML[i]; | colorBorder += header[0].innerHTML[i]; | ||
Строка 29: | Строка 37: | ||
} | } | ||
if(isValidColor(colorBorder) && isValidColor(colorBtn) && header[0].innerHTML.length > 0) { | |||
headerRender (colorBorder, colorBtn); | |||
document.body.addEventListener('click', function() { | |||
headerRender(colorBorder, colorBtn); | |||
} | }); | ||
} | |||
else { | |||
throw "headerColor"; | |||
} | |||
} | } | ||
Строка 41: | Строка 54: | ||
{ | { | ||
if (array[i].className === 'citizen-section-heading') { | if (array[i].className === 'citizen-section-heading') { | ||
array[i].querySelector('.citizen-sections-enabled,.citizen-section-indicator').style.background = | 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 | 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 + ')'); | array[i].querySelector('.mw-headline').style.borderImage = ('linear-gradient(to right top, ' + colorBorder + ', black)'); | ||
array[i].querySelector('.mw-headline').style.borderImageSlice = '1'; | array[i].querySelector('.mw-headline').style.borderImageSlice = '1'; | ||
Строка 65: | Строка 78: | ||
document.getElementById('content').style.display = 'flex'; | document.getElementById('content').style.display = 'flex'; | ||
document.getElementById('bodyContent').style.minHeight = '1350px'; | 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; | |||
} | |||
}); | |||
}); | |||
/* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */ |
Текущая версия от 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; } }); }); /* ----------------------------------------------------------Планеты лора------------------------------------------------------------------------ */