downtoutemonannee

Télécharger les albums de toutemonannee.com

// ==UserScript==
// @name         downtoutemonannee
// @version      1
// @description  Télécharger les albums de toutemonannee.com
// @author       jp
// @match        https://www.toutemonannee.com/*
// @license      MIT 
// @namespace https://greasyfork.org/users/177745
// ==/UserScript==

function downfuck() {
    const urls = [];
    const nodeList = document.querySelectorAll(".fancybox-thumbs__list > a");
    const link = document.createElement('a');
    nodeList.forEach(item => {
        s = item.style.backgroundImage;
        url1 = s.replace('url("', '')
        url2 = url1.replace('")', '')
        urlFinal = url2.replace('/thumbs/', '/hd/')
        urlVraimentFinal = urlFinal.split('?')[0]
        //console.log(urlVraimentFinal);
        urls.push(urlVraimentFinal);
    });
    var name = prompt("Nom de l'album (sera le préfixe des images téléchargées) :", titre);
    if (name === null) {
        return; //break out of the function early
    }
    // console.log(urls);
    urls.forEach(url => {
        fetch(url)
            .then(response => response.blob())
            .then(blob => {
                const url = URL.createObjectURL(blob);
                const link = document.createElement("a");
                link.href = url;
                //link.download = url.split("/").pop();
                link.download = name + "." + url.split(".")[1];
                document.body.appendChild(link);
                link.click();
                document.body.removeChild(link);
            });
    })
}

// Créez une instance de MutationObserver avec une fonction de rappel
const observer = new MutationObserver(function (mutationsList, observer) {
   // var tousLesElements = document.querySelectorAll(".photos-counter");
    document.querySelectorAll(".photos-counter")
    	.forEach(function (element) {
        element.addEventListener("click", function (event) {
          ////
          globalThis.titre = event.target
            .parentNode
            .parentNode
            .querySelector('h2')
            .textContent;
        });
    });
    for (let mutation of mutationsList) {
        if (mutation.type === 'childList') {
            // Vérifiez chaque nouveau noeud ajouté
            mutation.addedNodes.forEach(function (node) {
                // Vérifiez si le noeud ajouté a la classe "fancybox-container"
                if (node.classList && node.classList.contains('fancybox-container')) {
                    //console.log('Le noeud avec la classe "fancybox-container" a été ajouté à la racine du body.');
                    const monElement = document.querySelector(".fancybox-toolbar");
                    const monBouton = document.createElement("button");
                    monBouton.id = "coolos";
                    monBouton.title = "Télécharger l'album";
                    monBouton.style.backgroundColor = "transparent";
                    monBouton.style.width = "44px";
                    monBouton.style.height = "45px";
                    monBouton.style.margin = "-4px 40px 20px 0px";
                    monBouton.style.backgroundPosition = "center";
                    monBouton.style.backgroundSize = "cover";
                    monBouton.style.backgroundRepeat = "no-repeat";
                    monBouton.style.border = "none";
                    monBouton.style.outline = "none";
                    monBouton.style.cursor = "pointer";
                    monBouton.style.zIndex = "99999";
                    monElement.prepend(monBouton);
                    monBouton.addEventListener("click", downfuck, false);
                    const monImage = document.createElement("img");
                    monImage.src = src = ""
                    monImage.style.height = "50px"
                  	monBouton.appendChild(monImage);
                  
                }
            });
        }
    }
});
// Démarrez l'observation en utilisant le noeud cible et les options de configuration
observer.observe(document.body, { attributes: false, childList: true, subtree: true });