MediaWiki:Common.js: Diferență între versiuni
m |
m |
||
Linia 80: | Linia 80: | ||
if (lootList.children.length === 0) { | if (lootList.children.length === 0) { | ||
var li = document.createElement('li'); | var li = document.createElement('li'); | ||
− | li.textContent = ' | + | li.textContent = 'No items found'; |
li.classList.add('loot-list-item'); | li.classList.add('loot-list-item'); | ||
lootList.appendChild(li); | lootList.appendChild(li); | ||
Linia 141: | Linia 141: | ||
updateHighlighting(); | updateHighlighting(); | ||
} | } | ||
+ | |||
+ | var searchInput = document.getElementById('monster-search'); | ||
+ | searchInput.addEventListener('input', function() { | ||
+ | var filter = searchInput.value.toLowerCase(); | ||
+ | monsterItems.forEach(function(item) { | ||
+ | var text = item.textContent.toLowerCase(); | ||
+ | if (text.indexOf(filter) > -1) { | ||
+ | item.style.display = ''; | ||
+ | item.classList.remove('highlighted'); | ||
+ | } else { | ||
+ | item.style.display = 'none'; | ||
+ | } | ||
+ | }); | ||
+ | |||
+ | // Highlight the first visible item that matches the search | ||
+ | var firstVisibleItem = document.querySelector('#monster-list li:not([style*="display: none"])'); | ||
+ | if (firstVisibleItem) { | ||
+ | firstVisibleItem.classList.add('highlighted'); | ||
+ | selectedMonster = firstVisibleItem.getAttribute('data-monster'); | ||
+ | showLoot(selectedMonster, selectedCategory); | ||
+ | } | ||
+ | }); | ||
+ | |||
+ | // Keyboard navigation for the search box | ||
+ | searchInput.addEventListener('keydown', function(event) { | ||
+ | var currentHighlighted = document.querySelector('#monster-list li.highlighted'); | ||
+ | if (event.key === 'ArrowDown') { | ||
+ | event.preventDefault(); | ||
+ | if (currentHighlighted) { | ||
+ | var nextSibling = currentHighlighted.nextElementSibling; | ||
+ | while (nextSibling && nextSibling.style.display === 'none') { | ||
+ | nextSibling = nextSibling.nextElementSibling; | ||
+ | } | ||
+ | if (nextSibling) { | ||
+ | currentHighlighted.classList.remove('highlighted'); | ||
+ | nextSibling.classList.add('highlighted'); | ||
+ | selectedMonster = nextSibling.getAttribute('data-monster'); | ||
+ | showLoot(selectedMonster, selectedCategory); | ||
+ | } | ||
+ | } | ||
+ | } else if (event.key === 'ArrowUp') { | ||
+ | event.preventDefault(); | ||
+ | if (currentHighlighted) { | ||
+ | var prevSibling = currentHighlighted.previousElementSibling; | ||
+ | while (prevSibling && prevSibling.style.display === 'none') { | ||
+ | prevSibling = prevSibling.previousElementSibling; | ||
+ | } | ||
+ | if (prevSibling) { | ||
+ | currentHighlighted.classList.remove('highlighted'); | ||
+ | prevSibling.classList.add('highlighted'); | ||
+ | selectedMonster = prevSibling.getAttribute('data-monster'); | ||
+ | showLoot(selectedMonster, selectedCategory); | ||
+ | } | ||
+ | } | ||
+ | } else if (event.key === 'Enter') { | ||
+ | if (currentHighlighted) { | ||
+ | showLoot(selectedMonster, selectedCategory); | ||
+ | } | ||
+ | } | ||
+ | }); | ||
}); | }); | ||
})(); | })(); |
Versiunea de la data 22 august 2024 14:07
(function () {
// Load GDPR Cookie Script
var req = new XMLHttpRequest();
req.addEventListener('load', function (ev) {
if (this.status >= 200 && this.status < 300) {
var data = JSON.parse(this.responseText);
if (data.hasOwnProperty('version')) {
var gdpr = document.createElement("script");
gdpr.src = "https://s3-static.geo.gfsrv.net/cookiebanner/" + data.version + "/cookie.min.js";
document.head.appendChild(gdpr);
}
}
});
req.open('GET', "https://s3-static.geo.gfsrv.net/cookiebanner/version.json");
req.send();
})();
(function () {
mw.hook('wikipage.content').add(function() {
var selectedMonster = null;
var selectedCategory = 'Weapondrops';
function showLoot(monster, category) {
var lootList = document.getElementById('loot-list');
if (!lootList) return;
lootList.innerHTML = '';
var apiUrl = 'https://ro-wiki.metin2.gameforge.com/api.php?action=parse&page=' + encodeURIComponent(monster) + '&prop=wikitext&format=json&origin=*';
fetch(apiUrl)
.then(function(response) {
if (!response.ok) {
throw new Error('Network response was not ok: ' + response.statusText);
}
return response.json();
})
.then(function(data) {
if (data.parse && data.parse.wikitext) {
var wikitext = data.parse.wikitext['*'];
var drops = {
Weapondrops: [],
Armordrops: [],
Otherdrops: []
};
['Weapondrops', 'Armordrops', 'Otherdrops'].forEach(function(dropType) {
var regex = new RegExp('\\|' + dropType + '\\s*=([\\s\\S]*?)(?=(\\n\\|\\w+\\s*=|$))', 'i');
var match = wikitext.match(regex);
if (match && match[1].trim()) {
var items = match[1].trim().split(/\n\s*[:*]\s*/);
drops[dropType] = items.map(function(item) {
var textMatch = item.match(/\{\{Ti\|[^}]+\}\}/);
if (textMatch) {
var linkTextMatch = textMatch[0].match(/\|\s*([^|}]+)\s*\}\}/);
if (linkTextMatch) {
return linkTextMatch[1].trim();
}
}
return null;
}).filter(Boolean);
}
});
var itemsToDisplay = drops[category] || [];
itemsToDisplay.forEach(function(item) {
var li = document.createElement('li');
li.classList.add('loot-list-item');
var link = document.createElement('a');
link.textContent = item;
link.href = 'https://ro-wiki.metin2.gameforge.com/index.php/' + encodeURIComponent(item);
link.target = '_blank';
link.style.color = 'white';
li.appendChild(link);
lootList.appendChild(li);
});
if (lootList.children.length === 0) {
var li = document.createElement('li');
li.textContent = 'No items found';
li.classList.add('loot-list-item');
lootList.appendChild(li);
}
} else {
console.error('Unexpected data format:', data);
}
})
}
function updateHighlighting() {
var monsterItems = document.querySelectorAll('#monster-list li');
monsterItems.forEach(function(item) {
item.classList.remove('highlighted');
if (item.getAttribute('data-monster') === selectedMonster) {
item.classList.add('highlighted');
}
});
var categoryItems = document.querySelectorAll('#category-list li');
categoryItems.forEach(function(item) {
item.classList.remove('highlighted');
if (item.getAttribute('data-category') === selectedCategory) {
item.classList.add('highlighted');
}
});
}
var monsterItems = document.querySelectorAll('#monster-list li');
monsterItems.forEach(function(item) {
item.addEventListener('click', function() {
selectedMonster = item.getAttribute('data-monster');
selectedCategory = 'Weapondrops';
showLoot(selectedMonster, selectedCategory);
updateHighlighting();
});
});
var categoryItems = document.querySelectorAll('#category-list li');
categoryItems.forEach(function(item) {
item.addEventListener('click', function() {
selectedCategory = item.getAttribute('data-category');
categoryItems.forEach(function(catItem) {
catItem.classList.remove('highlighted');
});
item.classList.add('highlighted');
if (selectedMonster) {
showLoot(selectedMonster, selectedCategory);
}
updateHighlighting();
});
});
if (monsterItems.length > 0) {
selectedMonster = monsterItems[0].getAttribute('data-monster');
showLoot(selectedMonster, selectedCategory);
updateHighlighting();
}
var searchInput = document.getElementById('monster-search');
searchInput.addEventListener('input', function() {
var filter = searchInput.value.toLowerCase();
monsterItems.forEach(function(item) {
var text = item.textContent.toLowerCase();
if (text.indexOf(filter) > -1) {
item.style.display = '';
item.classList.remove('highlighted');
} else {
item.style.display = 'none';
}
});
// Highlight the first visible item that matches the search
var firstVisibleItem = document.querySelector('#monster-list li:not([style*="display: none"])');
if (firstVisibleItem) {
firstVisibleItem.classList.add('highlighted');
selectedMonster = firstVisibleItem.getAttribute('data-monster');
showLoot(selectedMonster, selectedCategory);
}
});
// Keyboard navigation for the search box
searchInput.addEventListener('keydown', function(event) {
var currentHighlighted = document.querySelector('#monster-list li.highlighted');
if (event.key === 'ArrowDown') {
event.preventDefault();
if (currentHighlighted) {
var nextSibling = currentHighlighted.nextElementSibling;
while (nextSibling && nextSibling.style.display === 'none') {
nextSibling = nextSibling.nextElementSibling;
}
if (nextSibling) {
currentHighlighted.classList.remove('highlighted');
nextSibling.classList.add('highlighted');
selectedMonster = nextSibling.getAttribute('data-monster');
showLoot(selectedMonster, selectedCategory);
}
}
} else if (event.key === 'ArrowUp') {
event.preventDefault();
if (currentHighlighted) {
var prevSibling = currentHighlighted.previousElementSibling;
while (prevSibling && prevSibling.style.display === 'none') {
prevSibling = prevSibling.previousElementSibling;
}
if (prevSibling) {
currentHighlighted.classList.remove('highlighted');
prevSibling.classList.add('highlighted');
selectedMonster = prevSibling.getAttribute('data-monster');
showLoot(selectedMonster, selectedCategory);
}
}
} else if (event.key === 'Enter') {
if (currentHighlighted) {
showLoot(selectedMonster, selectedCategory);
}
}
});
});
})();