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');
            });


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


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


// Проходим по строкам первого уровня
        var hasInvalidRowspan = false;
            topLevelRows.forEach(function(row) {
        var hasTooManyRowspan = false;
                // Получаем все ячейки строки, исключая те, что имеют класс 'mobile'
                var cells = Array.prototype.slice.call(row.querySelectorAll('td, th')).filter(function(cell) {
                return !cell.classList.contains('mobile');
                });
                var cellCount = cells.length;


                // Проверяем, есть ли больше двух ячеек с атрибутом rowspan
        // Проверка на корректность rowspan
                var rowspanCount = cells.filter(function(cell) {
        topLevelRows.forEach(function(row) {
                    return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1';
            var cells = Array.prototype.slice.call(row.querySelectorAll('td, th')).filter(function(cell) {
                }).length;
                return !cell.classList.contains('mobile');
            });
            var cellCount = cells.length;


                 // Если в строке больше двух ячеек с rowspan, функция не применяется
            var rowspanCount = cells.filter(function(cell) {
                if (rowspanCount > 2) {
                 return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1';
                    hasTooManyRowspan = true;
            }).length;
                    return;
                }


                // Если строка имеет 3 или меньше ячеек и больше одного rowspan, не применяем функцию
            if (rowspanCount > 2) {
                if (cellCount <= 3 && rowspanCount > 1) {
                hasTooManyRowspan = true;
                    hasTooManyRowspan = true;
                return;
                    return;
            }
                }


                // Проверяем, есть ли корректные ячейки с rowspan на краю строки (первый или последний элемент)
            if (cellCount <= 3 && rowspanCount > 1) {
                 var hasValidRowspanEdge = cells.some(function(cell, index) {
                 hasTooManyRowspan = true;
                    return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1' && (index === 0 || index === cells.length - 1);
                return;
                });
            }


                // Если ячейки с rowspan находятся не на краю, устанавливаем флаг ошибки
            var hasValidRowspanEdge = cells.some(function(cell, index) {
                if (!hasValidRowspanEdge && cells.some(function(cell, index) {
                return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1' && (index === 0 || index === cells.length - 1);
                    return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1' && index > 0 && index < cells.length - 1;
                })) {
                    hasInvalidRowspan = true;
                }
             });
             });


             // Если есть некорректные строки с rowspan или слишком много rowspan, выходим
             if (!hasValidRowspanEdge && cells.some(function(cell, index) {
             if (hasTooManyRowspan || hasInvalidRowspan) return;
                return cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1' && index > 0 && index < cells.length - 1;
            })) {
                hasInvalidRowspan = true;
             }
        });
 
        if (hasTooManyRowspan || hasInvalidRowspan) return;


            // Проходим по каждой строке для добавления событий подсветки
        // Проходим по каждой строке для добавления событий подсветки
            topLevelRows.forEach(function(row) {
        topLevelRows.forEach(function(row, rowIndex) {
                var cells = Array.prototype.slice.call(row.querySelectorAll('td, th'));
            var cells = Array.prototype.slice.call(row.querySelectorAll('td, th'));
                var originalStyles = cells.map(function(cell) {
            var originalStyles = cells.map(function(cell) {
                    // Сохраняем оригинальные стили каждой ячейки
                return {
                    return {
                    backgroundColor: getComputedStyle(cell).backgroundColor,
                        backgroundColor: getComputedStyle(cell).backgroundColor,
                    color: getComputedStyle(cell).color
                        color: getComputedStyle(cell).color
                };
                    };
            });
                });


                // Добавляем события 'mouseover' и 'mouseout' для подсветки
            cells.forEach(function(cell, cellIndex) {
                cells.forEach(function(cell, index) {
                if (cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1') {
                    if (cell.hasAttribute('rowspan') && cell.getAttribute('rowspan') !== '1') return;
                    var rowspan = parseInt(cell.getAttribute('rowspan'), 10);


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


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