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

мНет описания правки
Нет описания правки
Метка: ручная отмена
Строка 339: Строка 339:
// Функция для подсветки ячеек в таблице при наведении
// Функция для подсветки ячеек в таблице при наведении
function applyHighlighting() {
function applyHighlighting() {
     // Проверка, является ли устройство мобильным
     // Проверка, является ли устройство мобильным, если да — функция не выполняется
     if (/Mobi|Android/i.test(navigator.userAgent)) {
     if (/Mobi|Android/i.test(navigator.userAgent)) {
         return;
         return;
Строка 353: Строка 353:
         var noHeader = table.classList.contains('no-header-table');
         var noHeader = table.classList.contains('no-header-table');


         if (!tbody) return;
        // Проверяем, что тело таблицы существует
         if (tbody) {
            // Получаем все строки <tr> внутри tbody, исключая строки, содержащие вложенные таблицы
            var rows = Array.prototype.slice.call(tbody.querySelectorAll('tr')).filter(function(row) {
                return !row.querySelector('table');
            });


        // Получаем все строки <tr> внутри tbody, исключая строки с вложенными таблицами
            // Пропускаем первую строку, если нет thead и нет класса 'no-header'
        var rows = Array.prototype.slice.call(tbody.querySelectorAll('tr')).filter(function(row) {
            var topLevelRows = (!thead && !noHeader) ? rows.slice(1) : rows;
            return !row.querySelector('table');
        });


        // Пропускаем первую строку, если нет thead и нет класса 'no-header'
            var hasInvalidRowspan = false;
        var topLevelRows = (!thead && !noHeader) ? rows.slice(1) : rows;
            var hasTooManyRowspan = false;


        // Проходим по каждой строке для добавления событий подсветки
// Проходим по строкам первого уровня
        topLevelRows.forEach(function(row, rowIndex) {
            topLevelRows.forEach(function(row) {
            var cells = Array.prototype.slice.call(row.querySelectorAll('td, th'));
                // Получаем все ячейки строки, исключая те, что имеют класс 'mobile'
            var originalStyles = cells.map(function(cell) {
                var cells = Array.prototype.slice.call(row.querySelectorAll('td, th')).filter(function(cell) {
                return {
                return !cell.classList.contains('mobile');
                    backgroundColor: getComputedStyle(cell).backgroundColor,
                });
                    color: getComputedStyle(cell).color
                var cellCount = cells.length;
                };
 
            });
                // Проверяем, есть ли больше двух ячеек с атрибутом rowspan
                var rowspanCount = cells.filter(function(cell) {
                    return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1';
                }).length;
 
                // Если в строке больше двух ячеек с rowspan, функция не применяется
                if (rowspanCount > 2) {
                    hasTooManyRowspan = true;
                    return;
                }


            cells.forEach(function(cell, cellIndex) {
                // Если строка имеет 3 или меньше ячеек и больше одного rowspan, не применяем функцию
                var rowspan = cell.hasAttribute('rowspan') ? parseInt(cell.getAttribute('rowspan'), 10) : 1;
                if (cellCount <= 3 && rowspanCount > 1) {
                    hasTooManyRowspan = true;
                    return;
                }


                 // Наведение на ячейку
                 // Проверяем, есть ли корректные ячейки с rowspan на краю строки (первый или последний элемент)
                 cell.addEventListener('mouseover', function() {
                 var hasValidRowspanEdge = cells.some(function(cell, index) {
                     highlightRow(rowIndex, rowspan);
                     return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1' && (index === 0 || index === cells.length - 1);
                 });
                 });


                 // Убираем подсветку при выходе мыши
                 // Если ячейки с rowspan находятся не на краю, устанавливаем флаг ошибки
                 cell.addEventListener('mouseout', function() {
                 if (!hasValidRowspanEdge && cells.some(function(cell, index) {
                     resetHighlight(rowIndex, rowspan);
                    return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1' && index > 0 && index < cells.length - 1;
                })) {
                    hasInvalidRowspan = true;
                }
            });
 
            // Если есть некорректные строки с rowspan или слишком много rowspan, выходим
            if (hasTooManyRowspan || hasInvalidRowspan) return;
 
            // Проходим по каждой строке для добавления событий подсветки
            topLevelRows.forEach(function(row) {
                var cells = Array.prototype.slice.call(row.querySelectorAll('td, th'));
                var originalStyles = cells.map(function(cell) {
                     // Сохраняем оригинальные стили каждой ячейки
                    return {
                        backgroundColor: getComputedStyle(cell).backgroundColor,
                        color: getComputedStyle(cell).color
                    };
                 });
                 });


                 // Функция для подсветки строки и ячеек с rowspan
                 // Добавляем события 'mouseover' и 'mouseout' для подсветки
                 function highlightRow(startRowIndex, rowspan) {
                 cells.forEach(function(cell, index) {
                     for (var i = startRowIndex; i < startRowIndex + rowspan; i++) {
                     if (cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1') return;
                        var targetRow = rows[i];
                        if (!targetRow) continue;


                        var targetCells = Array.prototype.slice.call(targetRow.querySelectorAll('td, th'));
                    // Добавляем обработчик события при наведении мыши
                         targetCells.forEach(function(targetCell) {
                    cell.addEventListener('mouseover', function() {
                             targetCell.style.backgroundColor = brightenColor(getComputedStyle(targetCell).backgroundColor);
                         cells.forEach(function(innerCell, innerIndex) {
                            targetCell.style.color = brightenColor(getComputedStyle(targetCell).color);
                             if (!innerCell.hasAttribute('rowspan') || innerCell.getAttribute('rowspan') === '1') {
                                // Увеличиваем яркость фона и текста ячейки при наведении
                                innerCell.style.backgroundColor = brightenColor(originalStyles[innerIndex].backgroundColor);
                                innerCell.style.color = brightenColor(originalStyles[innerIndex].color);
                            }
                         });
                         });
                    }
                    // Подсветить все ячейки в текущем ряду
                    cells.forEach(function(targetCell) {
                        targetCell.style.backgroundColor = brightenColor(getComputedStyle(targetCell).backgroundColor);
                        targetCell.style.color = brightenColor(getComputedStyle(targetCell).color);
                     });
                     });
                }
                // Функция для сброса подсветки
                function resetHighlight(startRowIndex, rowspan) {
                    for (var i = startRowIndex; i < startRowIndex + rowspan; i++) {
                        var targetRow = rows[i];
                        if (!targetRow) continue;


                        var targetCells = Array.prototype.slice.call(targetRow.querySelectorAll('td, th'));
                    // Добавляем обработчик события, когда мышь уходит с ячейки
                         targetCells.forEach(function(targetCell, targetIndex) {
                    cell.addEventListener('mouseout', function() {
                             targetCell.style.backgroundColor = originalStyles[targetIndex].backgroundColor;
                         cells.forEach(function(innerCell, innerIndex) {
                            targetCell.style.color = originalStyles[targetIndex].color;
                             if (!innerCell.hasAttribute('rowspan') || innerCell.getAttribute('rowspan') === '1') {
                                // Восстанавливаем оригинальные стили после наведения
                                innerCell.style.backgroundColor = originalStyles[innerIndex].backgroundColor;
                                innerCell.style.color = originalStyles[innerIndex].color;
                            }
                         });
                         });
                    }
                    // Сбросить подсветку всех ячеек в текущем ряду
                    cells.forEach(function(targetCell, targetIndex) {
                        targetCell.style.backgroundColor = originalStyles[targetIndex].backgroundColor;
                        targetCell.style.color = originalStyles[targetIndex].color;
                     });
                     });
                 }
                 });
             });
             });
         });
         }
     });
     });
}
}