Diferencia entre revisiones de «MediaWiki:Common.js»
Ir a la navegación
Ir a la búsqueda
Sin resumen de edición |
Sin resumen de edición |
||
| Línea 1: | Línea 1: | ||
function safeNormalize(text) { | (function () { | ||
function safeNormalize(text) { | |||
text = String(text || '').toLowerCase().trim(); | |||
try { | |||
return text.normalize('NFD').replace(/[\u0300-\u036f]/g, ''); | |||
} catch (e) { | |||
return | return text; | ||
} | |||
} | |||
function hasMark(cellText) { | |||
cellText = String(cellText || '').replace(/\s+/g, '').trim(); | |||
return ( | |||
cellText !== '' && | |||
( | |||
cellText.indexOf('✔') !== -1 || | |||
cellText.indexOf('✅') !== -1 || | |||
cellText.indexOf('☑') !== -1 | |||
) | |||
); | |||
} | } | ||
function | function getActiveCategoryCol(tableId) { | ||
var activeBtn = document.querySelector('.oroza-cat-btn.active[data-table="' + tableId + '"]'); | |||
if (!activeBtn) { | |||
var firstBtn = document.querySelector('.oroza-cat-btn[data-table="' + tableId + '"]'); | |||
if (!firstBtn) return null; | |||
firstBtn.classList.add('active'); | |||
return parseInt(firstBtn.getAttribute('data-col'), 10); | |||
} | |||
return parseInt(activeBtn.getAttribute('data-col'), 10); | |||
} | |||
function getSearchTextForRow(row, tableId) { | |||
var cells = row.getElementsByTagName('td'); | |||
var text = row.getAttribute('data-search') || ''; | |||
var visibleInfoCols = tableId === 'tableSlot1' ? 2 : 3; | |||
for (var i = 0; i < visibleInfoCols; i++) { | |||
if (cells[i]) { | |||
text += ' ' + (cells[i].textContent || cells[i].innerText || ''); | |||
} | |||
} | |||
return safeNormalize(text); | |||
} | |||
var | function updateCategoryView(tableId, inputId) { | ||
var table = document.getElementById(tableId); | |||
var input = document.getElementById(inputId); | |||
if (!table || !table.tBodies.length || !table.tHead || !table.tHead.rows.length) return; | |||
var | var activeCol = getActiveCategoryCol(tableId); | ||
if (activeCol === null) return; | |||
var searchText = input ? safeNormalize(input.value) : ''; | |||
var rows = table.tBodies[0].getElementsByTagName('tr'); | |||
var headerRow = table.tHead.rows[0]; | |||
var staticCols = tableId === 'tableSlot1' ? 2 : 3; | |||
for (var h = 0; h < headerRow.cells.length; h++) { | |||
headerRow.cells[h].style.display = (h < staticCols || h === activeCol) ? '' : 'none'; | |||
} | } | ||
for (var i = 0; i < rows.length; i++) { | |||
var | var row = rows[i]; | ||
var cells = row.getElementsByTagName('td'); | |||
var matchCategory = false; | |||
var matchText = true; | |||
if ( | if (cells[activeCol]) { | ||
matchCategory = hasMark(cells[activeCol].textContent || cells[activeCol].innerText); | |||
} | } | ||
if (searchText !== '') { | |||
var searchPool = getSearchTextForRow(row, tableId); | |||
if (searchPool.indexOf(searchText) === -1) { | |||
matchText = false; | |||
} | |||
} | |||
row.style.display = (matchCategory && matchText) ? '' : 'none'; | |||
for (var c = 0; c < cells.length; c++) { | |||
cells[c].style.display = (c < staticCols || c === activeCol) ? '' : 'none'; | |||
} | } | ||
} | } | ||
} | |||
function bindCategoryButtons(tableId, inputId) { | |||
var buttons = document.querySelectorAll('.oroza-cat-btn[data-table="' + tableId + '"]'); | |||
for (var i = 0; i < buttons.length; i++) { | |||
if (buttons[i].dataset.orozaBound === '1') continue; | |||
buttons[i].dataset.orozaBound = '1'; | |||
buttons[i].addEventListener('click', function () { | |||
var sameTableButtons = document.querySelectorAll('.oroza-cat-btn[data-table="' + tableId + '"]'); | |||
for (var j = 0; j < sameTableButtons.length; j++) { | |||
sameTableButtons[j].classList.remove('active'); | |||
} | |||
this.classList.add('active'); | |||
updateCategoryView(tableId, inputId); | |||
}); | |||
} | |||
} | } | ||
function | function bindSearchInput(tableId, inputId) { | ||
var input = document.getElementById(inputId); | |||
if (!input || input.dataset.orozaBound === '1') return; | |||
input.dataset.orozaBound = '1'; | |||
input.addEventListener('input', function () { | |||
updateCategoryView(tableId, inputId); | |||
}); | |||
} | |||
function initOrozaDropFilters() { | |||
if (document.getElementById('tableSlot1')) { | |||
bindCategoryButtons('tableSlot1', 'textSlot1'); | |||
bindSearchInput('tableSlot1', 'textSlot1'); | |||
updateCategoryView('tableSlot1', 'textSlot1'); | |||
} | |||
if (document.getElementById('tableSlot2')) { | |||
bindCategoryButtons('tableSlot2', 'textSlot2'); | |||
bindSearchInput('tableSlot2', 'textSlot2'); | |||
} | updateCategoryView('tableSlot2', 'textSlot2'); | ||
} | |||
} | |||
if (window.mw && mw.hook) { | |||
mw.hook('wikipage.content').add(function () { | |||
initOrozaDropFilters(); | |||
}); | |||
} else if (document.readyState === 'loading') { | |||
document.addEventListener('DOMContentLoaded', initOrozaDropFilters); | document.addEventListener('DOMContentLoaded', initOrozaDropFilters); | ||
} else { | |||
initOrozaDropFilters(); | |||
} | |||
})(); | |||
Revisión del 23:48 3 abr 2026
(function () {
function safeNormalize(text) {
text = String(text || '').toLowerCase().trim();
try {
return text.normalize('NFD').replace(/[\u0300-\u036f]/g, '');
} catch (e) {
return text;
}
}
function hasMark(cellText) {
cellText = String(cellText || '').replace(/\s+/g, '').trim();
return (
cellText !== '' &&
(
cellText.indexOf('✔') !== -1 ||
cellText.indexOf('✅') !== -1 ||
cellText.indexOf('☑') !== -1
)
);
}
function getActiveCategoryCol(tableId) {
var activeBtn = document.querySelector('.oroza-cat-btn.active[data-table="' + tableId + '"]');
if (!activeBtn) {
var firstBtn = document.querySelector('.oroza-cat-btn[data-table="' + tableId + '"]');
if (!firstBtn) return null;
firstBtn.classList.add('active');
return parseInt(firstBtn.getAttribute('data-col'), 10);
}
return parseInt(activeBtn.getAttribute('data-col'), 10);
}
function getSearchTextForRow(row, tableId) {
var cells = row.getElementsByTagName('td');
var text = row.getAttribute('data-search') || '';
var visibleInfoCols = tableId === 'tableSlot1' ? 2 : 3;
for (var i = 0; i < visibleInfoCols; i++) {
if (cells[i]) {
text += ' ' + (cells[i].textContent || cells[i].innerText || '');
}
}
return safeNormalize(text);
}
function updateCategoryView(tableId, inputId) {
var table = document.getElementById(tableId);
var input = document.getElementById(inputId);
if (!table || !table.tBodies.length || !table.tHead || !table.tHead.rows.length) return;
var activeCol = getActiveCategoryCol(tableId);
if (activeCol === null) return;
var searchText = input ? safeNormalize(input.value) : '';
var rows = table.tBodies[0].getElementsByTagName('tr');
var headerRow = table.tHead.rows[0];
var staticCols = tableId === 'tableSlot1' ? 2 : 3;
for (var h = 0; h < headerRow.cells.length; h++) {
headerRow.cells[h].style.display = (h < staticCols || h === activeCol) ? '' : 'none';
}
for (var i = 0; i < rows.length; i++) {
var row = rows[i];
var cells = row.getElementsByTagName('td');
var matchCategory = false;
var matchText = true;
if (cells[activeCol]) {
matchCategory = hasMark(cells[activeCol].textContent || cells[activeCol].innerText);
}
if (searchText !== '') {
var searchPool = getSearchTextForRow(row, tableId);
if (searchPool.indexOf(searchText) === -1) {
matchText = false;
}
}
row.style.display = (matchCategory && matchText) ? '' : 'none';
for (var c = 0; c < cells.length; c++) {
cells[c].style.display = (c < staticCols || c === activeCol) ? '' : 'none';
}
}
}
function bindCategoryButtons(tableId, inputId) {
var buttons = document.querySelectorAll('.oroza-cat-btn[data-table="' + tableId + '"]');
for (var i = 0; i < buttons.length; i++) {
if (buttons[i].dataset.orozaBound === '1') continue;
buttons[i].dataset.orozaBound = '1';
buttons[i].addEventListener('click', function () {
var sameTableButtons = document.querySelectorAll('.oroza-cat-btn[data-table="' + tableId + '"]');
for (var j = 0; j < sameTableButtons.length; j++) {
sameTableButtons[j].classList.remove('active');
}
this.classList.add('active');
updateCategoryView(tableId, inputId);
});
}
}
function bindSearchInput(tableId, inputId) {
var input = document.getElementById(inputId);
if (!input || input.dataset.orozaBound === '1') return;
input.dataset.orozaBound = '1';
input.addEventListener('input', function () {
updateCategoryView(tableId, inputId);
});
}
function initOrozaDropFilters() {
if (document.getElementById('tableSlot1')) {
bindCategoryButtons('tableSlot1', 'textSlot1');
bindSearchInput('tableSlot1', 'textSlot1');
updateCategoryView('tableSlot1', 'textSlot1');
}
if (document.getElementById('tableSlot2')) {
bindCategoryButtons('tableSlot2', 'textSlot2');
bindSearchInput('tableSlot2', 'textSlot2');
updateCategoryView('tableSlot2', 'textSlot2');
}
}
if (window.mw && mw.hook) {
mw.hook('wikipage.content').add(function () {
initOrozaDropFilters();
});
} else if (document.readyState === 'loading') {
document.addEventListener('DOMContentLoaded', initOrozaDropFilters);
} else {
initOrozaDropFilters();
}
})();