1
0

Adde Button um Blackliste zu verwalten

This commit is contained in:
Akamaru
2025-09-30 19:40:59 +02:00
parent 56ec1da75b
commit 6bf0ba7569

View File

@@ -1,7 +1,7 @@
// ==UserScript== // ==UserScript==
// @name Serienfans/Filmfans Releasegruppen Filter // @name Serienfans/Filmfans Releasegruppen Filter
// @namespace https://git.ponywave.de/Akamaru/Userscripts // @namespace https://git.ponywave.de/Akamaru/Userscripts
// @version 1.1 // @version 1.2
// @description Blende Uploads bestimmter Releasegruppen aus // @description Blende Uploads bestimmter Releasegruppen aus
// @author Akamaru // @author Akamaru
// @match https://serienfans.org/* // @match https://serienfans.org/*
@@ -19,7 +19,7 @@
(function() { (function() {
'use strict'; 'use strict';
// CSS für Block-Button // CSS für Block-Button und Modal
GM_addStyle(` GM_addStyle(`
.block-group-btn { .block-group-btn {
display: inline; display: inline;
@@ -34,6 +34,153 @@
min-width: 0; min-width: 0;
vertical-align: middle; vertical-align: middle;
} }
#blacklist-modal {
display: none;
position: fixed;
z-index: 10000;
left: 0;
top: 0;
width: 100%;
height: 100%;
background-color: rgba(0,0,0,0.6);
animation: fadeIn 0.2s;
}
@keyframes fadeIn {
from { opacity: 0; }
to { opacity: 1; }
}
#blacklist-modal-content {
background-color: #1a1a1a;
margin: 5% auto;
padding: 30px;
border: 1px solid #333;
border-radius: 8px;
width: 90%;
max-width: 600px;
box-shadow: 0 4px 20px rgba(0,0,0,0.5);
color: #fff;
}
#blacklist-modal h2 {
margin-top: 0;
color: #fff;
font-size: 24px;
margin-bottom: 20px;
}
#blacklist-items {
max-height: 400px;
overflow-y: auto;
margin: 20px 0;
background: #2a2a2a;
border-radius: 4px;
padding: 10px;
}
.blacklist-item {
display: flex;
justify-content: space-between;
align-items: center;
padding: 10px;
margin: 5px 0;
background: #333;
border-radius: 4px;
transition: background 0.2s;
}
.blacklist-item:hover {
background: #3a3a3a;
}
.blacklist-item-name {
flex-grow: 1;
font-size: 16px;
}
.blacklist-item-remove {
background: #d32f2f;
color: white;
border: none;
padding: 5px 12px;
border-radius: 4px;
cursor: pointer;
font-size: 14px;
transition: background 0.2s;
}
.blacklist-item-remove:hover {
background: #b71c1c;
}
#blacklist-add-container {
display: flex;
gap: 10px;
margin: 20px 0;
}
#blacklist-add-input {
flex-grow: 1;
padding: 10px;
border: 1px solid #444;
border-radius: 4px;
background: #2a2a2a;
color: #fff;
font-size: 14px;
}
#blacklist-add-input:focus {
outline: none;
border-color: #666;
}
#blacklist-add-btn, #blacklist-close-btn {
padding: 10px 20px;
border: none;
border-radius: 4px;
cursor: pointer;
font-size: 14px;
font-weight: 500;
transition: background 0.2s;
}
#blacklist-add-btn {
background: #4caf50;
color: white;
}
#blacklist-add-btn:hover {
background: #45a049;
}
#blacklist-close-btn {
background: #666;
color: white;
width: 100%;
margin-top: 10px;
}
#blacklist-close-btn:hover {
background: #777;
}
.blacklist-empty {
text-align: center;
padding: 30px;
color: #888;
font-style: italic;
}
#blacklist-menu-btn {
cursor: pointer;
transition: opacity 0.2s;
}
#blacklist-menu-btn:hover {
opacity: 0.8;
}
`); `);
// Standard-Blacklist (kann über das Menü bearbeitet werden) // Standard-Blacklist (kann über das Menü bearbeitet werden)
@@ -126,23 +273,140 @@
}); });
} }
// Funktion zum Bearbeiten der Blacklist // Funktion zum Erstellen des Modal-Fensters
function editBlacklist() { function createBlacklistModal() {
const currentList = blacklist.join(', '); const modal = document.createElement('div');
const newList = prompt('Releasegruppen zum Ausblenden (kommagetrennt):\n\nBeispiel: SURCODE, WATCHABLE, ENDSTATiON', currentList); modal.id = 'blacklist-modal';
modal.innerHTML = `
<div id="blacklist-modal-content">
<h2>🚫 Releasegruppen-Filter</h2>
<div id="blacklist-add-container">
<input type="text" id="blacklist-add-input" placeholder="Releasegruppe hinzufügen (z.B. WvF, 4SF, WAYNE)">
<button id="blacklist-add-btn">Hinzufügen</button>
</div>
<div id="blacklist-items"></div>
<button id="blacklist-close-btn">Schließen</button>
</div>
`;
document.body.appendChild(modal);
if (newList !== null) { // Event Listeners
blacklist = newList.split(',').map(item => item.trim()).filter(item => item !== ''); modal.addEventListener('click', (e) => {
GM_setValue('releasegroup_blacklist', blacklist); if (e.target === modal) {
alert('Blacklist gespeichert! Die Seite wird neu geladen.'); closeModal();
location.reload(); }
});
document.getElementById('blacklist-close-btn').addEventListener('click', closeModal);
document.getElementById('blacklist-add-btn').addEventListener('click', addToBlacklist);
document.getElementById('blacklist-add-input').addEventListener('keypress', (e) => {
if (e.key === 'Enter') {
addToBlacklist();
}
});
updateBlacklistDisplay();
}
// Funktion zum Aktualisieren der Blacklist-Anzeige
function updateBlacklistDisplay() {
const container = document.getElementById('blacklist-items');
if (!container) return;
if (blacklist.length === 0) {
container.innerHTML = '<div class="blacklist-empty">Keine Releasegruppen geblockt</div>';
return;
}
container.innerHTML = blacklist.map(group => `
<div class="blacklist-item">
<span class="blacklist-item-name">${group}</span>
<button class="blacklist-item-remove" data-group="${group}">Entfernen</button>
</div>
`).join('');
// Event Listeners für Remove-Buttons
container.querySelectorAll('.blacklist-item-remove').forEach(btn => {
btn.addEventListener('click', (e) => {
const group = e.target.getAttribute('data-group');
removeFromBlacklist(group);
});
});
}
// Funktion zum Hinzufügen einer Releasegruppe
function addToBlacklist() {
const input = document.getElementById('blacklist-add-input');
const group = input.value.trim();
if (group === '') return;
if (blacklist.some(blocked => blocked.toLowerCase() === group.toLowerCase())) {
alert(`"${group}" ist bereits in der Blacklist!`);
return;
}
blacklist.push(group);
GM_setValue('releasegroup_blacklist', blacklist);
input.value = '';
updateBlacklistDisplay();
filterReleasesAlternative();
}
// Funktion zum Entfernen einer Releasegruppe
function removeFromBlacklist(group) {
blacklist = blacklist.filter(item => item !== group);
GM_setValue('releasegroup_blacklist', blacklist);
updateBlacklistDisplay();
location.reload();
}
// Funktion zum Öffnen des Modals
function openModal() {
const modal = document.getElementById('blacklist-modal');
if (modal) {
modal.style.display = 'block';
updateBlacklistDisplay();
document.getElementById('blacklist-add-input').focus();
} }
} }
// Registriere Menübefehl // Funktion zum Schließen des Modals
GM_registerMenuCommand('Releasegruppen-Filter bearbeiten', editBlacklist); function closeModal() {
const modal = document.getElementById('blacklist-modal');
if (modal) {
modal.style.display = 'none';
}
}
// Filtere beim Laden der Seite // Funktion zum Hinzufügen des Buttons im Header
function addHeaderButton() {
const menu = document.getElementById('menu');
if (!menu) return;
const menuBtn = document.createElement('a');
menuBtn.id = 'blacklist-menu-btn';
menuBtn.textContent = '🚫 Filter';
menuBtn.addEventListener('click', (e) => {
e.preventDefault();
openModal();
});
// Füge Button vor dem Settings-Link ein
const settingsLink = menu.querySelector('.settings');
if (settingsLink) {
menu.insertBefore(menuBtn, settingsLink);
} else {
menu.appendChild(menuBtn);
}
}
// Registriere Menübefehl (als Fallback)
GM_registerMenuCommand('Releasegruppen-Filter bearbeiten', openModal);
// Initialisierung
addHeaderButton();
createBlacklistModal();
filterReleasesAlternative(); filterReleasesAlternative();
// Beobachte Änderungen (falls Inhalte dynamisch nachgeladen werden) // Beobachte Änderungen (falls Inhalte dynamisch nachgeladen werden)