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

Страница интерфейса MediaWiki
Нет описания правки
Нет описания правки
Строка 1: Строка 1:
/* Лого сайта
/* Лого сайта Shegare */
Shegare */
(function() {
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>';
    var logo = document.getElementsByClassName('citizen-header__logo')[0];
    if (logo) {
        logo.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 */
(function() {
    var footerPlaces = document.getElementById('footer-places');
    var pageInfo = document.getElementsByClassName('page-info')[0];
    if (footerPlaces && pageInfo) {
        footerPlaces.insertAdjacentHTML('afterEnd', pageInfo.innerHTML);
        pageInfo.innerHTML = ''; // Очистка содержимого
    }
})();


/* Перенос page-info в конец footer-places
/* Логика цвета через headerColor Shegare */
Shegare */
(function() {
document.getElementById('footer-places').insertAdjacentHTML('afterEnd', document.getElementsByClassName('page-info')[0].innerHTML);
    if (document.getElementsByClassName('headerColor').length >= 1) {
document.getElementsByClassName('page-info')[0].innerHTML = null;
        var isValidColor = function(color) {
            var el = document.createElement('div');
            el.style.backgroundColor = color;
            return el.style.backgroundColor ? true : false;
        };


        var header = document.getElementsByClassName('headerColor')[0];
        var colorParts = header.innerHTML.split('|');
        var colorBorder = colorParts[0] || '';
        var colorBtn = colorParts[1] || '';


/* Begin логика цвета через headerColor
        if (isValidColor(colorBorder) && isValidColor(colorBtn) && header.innerHTML.length > 0) {
Shegare */
            headerRender(colorBorder, colorBtn);
if(document.getElementsByClassName('headerColor').length >= 1) {


var isValidColor = function(color) {
            document.body.addEventListener('click', function() {
  var el = document.createElement('div');
                headerRender(colorBorder, colorBtn);
  el.style.backgroundColor = color;
            });
  return el.style.backgroundColor ? true : false;
         } else {
};
            throw "Invalid headerColor values";
 
         }
    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) {
function headerRender(colorBorder, colorBtn) {
    headerRender (colorBorder, colorBtn);
    var array = document.querySelectorAll('h1, h2, h3 , h4, h5');
 
    array.forEach(function(el) {
    document.body.addEventListener('click', function() {
        if (el.classList.contains('citizen-section-heading')) {
        headerRender(colorBorder, colorBtn);
            var sectionIndicator = el.querySelector('.citizen-sections-enabled,.citizen-section-indicator');
    });
            if (sectionIndicator) {
}
                sectionIndicator.style.background = colorBtn;
    else {
                sectionIndicator.style.boxShadow = '0 0 20px 0px ' + colorBtn + 'cc';
    throw "headerColor";
            }
     }
            var headline = el.querySelector('.mw-headline');
            if (headline) {
                headline.style.borderImage = 'linear-gradient(to right top, ' + colorBorder + ', black)';
                headline.style.borderImageSlice = '1';
            }
        } else if (el.classList.contains('citizen-section-heading--collapsed')) {
            var collapsedIndicator = el.querySelector('.citizen-sections-enabled,.citizen-section-heading--collapsed,.citizen-section-indicator');
            if (collapsedIndicator) {
                collapsedIndicator.style.background = 'black';
                collapsedIndicator.style.boxShadow = 'unset';
            }
        }
     });
}
}


function headerRender (colorBorder, colorBtn) {
/* Sidebar для ролей Shegare */
     var array = document.querySelectorAll('h1, h2, h3 , h4, h5');
(function() {
    for(var i = 0; i < array.length; i++)
     var jobsTableContainer = document.getElementsByClassName('JobsTableContainer')[0];
     {
     if (jobsTableContainer) {
        if (array[i].className === 'citizen-section-heading') {
        document.getElementById('content').insertAdjacentHTML('afterbegin', jobsTableContainer.innerHTML);
            array[i].querySelector('.citizen-sections-enabled,.citizen-section-indicator').style.background = colorBtn;
        var jobTable = document.getElementById('IdJobsTableContainer1');
            array[i].querySelector('.citizen-sections-enabled,.citizen-section-indicator').style.boxShadow  = ('0 0 20px 0px ' + colorBtn + 'cc');
         if (jobTable) {
            array[i].querySelector('.mw-headline').style.borderImage = ('linear-gradient(to right top, ' + colorBorder + ', black)');
             jobTable.id = 'IdJobsTableContainer2';
            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';
         }
         }
        document.getElementById('content').style.display = 'flex';
        document.getElementById('bodyContent').style.minHeight = '1350px';
     }
     }
}
})();
/* 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';
}
 
 
/*полигон данте*/
 


/* Фильтрация событий по категории */
function filterEvents(category) {
function filterEvents(category) {
  var events = document.querySelectorAll('.event');
    var events = document.querySelectorAll('.event');
  events.forEach(function(event) {
    events.forEach(function(event) {
    if (event.dataset.category === category) {
        if (event.dataset.category === category) {
      event.style.display = 'block';
            event.style.display = 'block';
    } else {
        } else {
      event.style.display = 'none';
            event.style.display = 'none';
    }
        }
  });
    });
}
}

Версия от 04:14, 17 ноября 2024

/* Лого сайта Shegare */
(function() {
    var logo = document.getElementsByClassName('citizen-header__logo')[0];
    if (logo) {
        logo.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 */
(function() {
    var footerPlaces = document.getElementById('footer-places');
    var pageInfo = document.getElementsByClassName('page-info')[0];
    if (footerPlaces && pageInfo) {
        footerPlaces.insertAdjacentHTML('afterEnd', pageInfo.innerHTML);
        pageInfo.innerHTML = ''; // Очистка содержимого
    }
})();

/* Логика цвета через headerColor Shegare */
(function() {
    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')[0];
        var colorParts = header.innerHTML.split('|');
        var colorBorder = colorParts[0] || '';
        var colorBtn = colorParts[1] || '';

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

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

function headerRender(colorBorder, colorBtn) {
    var array = document.querySelectorAll('h1, h2, h3 , h4, h5');
    array.forEach(function(el) {
        if (el.classList.contains('citizen-section-heading')) {
            var sectionIndicator = el.querySelector('.citizen-sections-enabled,.citizen-section-indicator');
            if (sectionIndicator) {
                sectionIndicator.style.background = colorBtn;
                sectionIndicator.style.boxShadow = '0 0 20px 0px ' + colorBtn + 'cc';
            }
            var headline = el.querySelector('.mw-headline');
            if (headline) {
                headline.style.borderImage = 'linear-gradient(to right top, ' + colorBorder + ', black)';
                headline.style.borderImageSlice = '1';
            }
        } else if (el.classList.contains('citizen-section-heading--collapsed')) {
            var collapsedIndicator = el.querySelector('.citizen-sections-enabled,.citizen-section-heading--collapsed,.citizen-section-indicator');
            if (collapsedIndicator) {
                collapsedIndicator.style.background = 'black';
                collapsedIndicator.style.boxShadow = 'unset';
            }
        }
    });
}

/* Sidebar для ролей Shegare */
(function() {
    var jobsTableContainer = document.getElementsByClassName('JobsTableContainer')[0];
    if (jobsTableContainer) {
        document.getElementById('content').insertAdjacentHTML('afterbegin', jobsTableContainer.innerHTML);
        var jobTable = document.getElementById('IdJobsTableContainer1');
        if (jobTable) {
            jobTable.id = 'IdJobsTableContainer2';
        }
        document.getElementById('content').style.display = 'flex';
        document.getElementById('bodyContent').style.minHeight = '1350px';
    }
})();

/* Фильтрация событий по категории */
function filterEvents(category) {
    var events = document.querySelectorAll('.event');
    events.forEach(function(event) {
        if (event.dataset.category === category) {
            event.style.display = 'block';
        } else {
            event.style.display = 'none';
        }
    });
}