Greasy Fork 还支持 简体中文。

Mydealz Bookmark Button

Bringt auf Übersichtsseiten das Bookmark Icon zurück, um den Deal per Klick für später zu speichern

Per 04-02-2025. Zie de nieuwste versie.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey, Greasemonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Violentmonkey.

Voor het installeren van scripts heb je een extensie nodig, zoals Tampermonkey of Userscripts.

Voor het installeren van scripts heb je een extensie nodig, zoals {tampermonkey_link:Tampermonkey}.

Voor het installeren van scripts heb je een gebruikersscriptbeheerder nodig.

(Ik heb al een user script manager, laat me het downloaden!)

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een extensie nodig, zoals {stylus_link:Stylus}.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

Voor het installeren van gebruikersstijlen heb je een gebruikersstijlbeheerder nodig.

(Ik heb al een beheerder - laat me doorgaan met de installatie!)

// ==UserScript==
// @name         Mydealz Bookmark Button
// @namespace    http://tampermonkey.net/
// @version      1.1
// @description  Bringt auf Übersichtsseiten das Bookmark Icon zurück, um den Deal per Klick für später zu speichern
// @match        https://www.mydealz.de/*
// @exclude      https://www.mydealz.de/profile/*
// @exclude      https://www.mydealz.de/*[0-9]*
// @license MIT 
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    const ICON = {
        active: '/assets/img/ico_707ed.svg#bookmark-active',
        inactive: '/assets/img/ico_707ed.svg#bookmark'
    };

    function getBookmarkState(thread) {
        try {
            const vueData = JSON.parse(thread.querySelector('[data-vue2]').dataset.vue2);
            return vueData.props.thread.isBookmarked;
        } catch (e) {
            console.error('Metadaten-Parsing fehlgeschlagen:', e);
            return false;
        }
    }

    function updateButtonState(button, isBookmarked) {
        button.dataset.bookmarked = isBookmarked;
        button.querySelector('use').setAttribute('xlink:href',
            isBookmarked ? ICON.active : ICON.inactive
        );
    }

    function createBookmarkButton() {
        const button = document.createElement('button');
        button.className = 'bookmark-button';
        button.innerHTML = `
            <svg width="24" height="24">
                <use xlink:href="${ICON.inactive}"></use>
            </svg>
        `;
        return button;
    }

    function handleBookmarkClick(button, threadId) {
        const currentState = button.dataset.bookmarked === 'true';
        const newState = !currentState;

        toggleBookmark(threadId, newState).then(success => {
            if (success) {
                updateButtonState(button, newState);
            }
        });
    }

    async function toggleBookmark(threadId, state) {
        try {
            const xsrfToken = document.cookie
                .split('; ')
                .find(row => row.startsWith('xsrf_t='))
                ?.split('=')[1]
                .replace(/"/g, '');

            const response = await fetch('https://www.mydealz.de/threads/thread-save/toggle', {
                method: 'POST',
                headers: {
                    'Content-Type': 'application/json',
                    'X-XSRF-TOKEN': xsrfToken
                },
                body: JSON.stringify({ threadId, state })
            });

            return response.ok;
        } catch (error) {
            console.error('Fehler beim Toggle:', error);
            return false;
        }
    }

    function initBookmarks() {
        document.querySelectorAll('.thread:not([data-bm-init])').forEach(thread => {
            const button = createBookmarkButton();
            const threadId = thread.id.replace('thread_', '');

            // Initialzustand setzen
            updateButtonState(button, getBookmarkState(thread));

            // Click-Handler
            button.addEventListener('click', (e) => {
                e.preventDefault();
                e.stopPropagation();
                handleBookmarkClick(button, threadId);
            });

            thread.querySelector('.threadListCard-footer').prepend(button);
            thread.dataset.bmInit = 'true';
        });
    }

    // Mutation Observer für dynamische Inhalte
    new MutationObserver(initBookmarks)
        .observe(document.body, { childList: true, subtree: true });

    initBookmarks();
})();