// ==UserScript== // @name 1fichier auto-clicker // @name:en 1fichier auto-clicker // @namespace Violentmonkey Scripts // @icon  // @match https://1fichier.com/* // @grant window.close // @version 1.1 // @license GNU GPLv3 // @author Dummy_mole // @description Ce script automatise le téléchargement instantané ou différé par compte à rebours. // @description:en This script automate instant or delayed by countdown download. // @downloadURL none // ==/UserScript== (() => { 'use strict' const delayBeforeReload = 300000 // 5 min 300000ms (300s) / 60000ms ==> (60s) = 5 min const localLangage = (navigator.language || navigator.userLanguage)?.split('-')[0] === "fr" ? "fr" : "en" //------------------------------------------------------------------------------------------------- const messages = { fr: { downloadStart: "Votre téléchargement commencera automatiquement à ", reloadMessage: "Un téléchargement est déjà en cours - Prochain rechargement à ", autoStartMessage: "Le téléchargement commencera automatiquement à la fin", startSoonMessage: "🚀Téléchargement immminent🚀", remainingMinutes: "🚀", minutesLeft: "min restantes" }, en: { downloadStart: "Your Download will automatically start at ", reloadMessage: "A download is already in progress - next Reload at ", autoStartMessage: "Download will auto start at the end", startSoonMessage: "🚀the download is about to start🚀", remainingMinutes: "🚀", minutesLeft: "min left" } } function getLocalizedMessage(key) { return messages[localLangage][key] } function waitForElm(selector, all = false) { const elementDirect = all ? document.querySelectorAll(selector) : document.querySelector(selector) return new Promise(resolve => { if (elementDirect) { return resolve(elementDirect) } const observer = new MutationObserver(mutations => { const elementObserved = all ? document.querySelectorAll(selector) : document.querySelector(selector) if (elementObserved) { resolve(elementObserved) observer.disconnect() } }) observer.observe(document.body, { childList: true, subtree: true }) }) } function moveMessage(parent, endTargetElement) { const newDiv = document.createElement('div') newDiv.className = 'moved-message' while (parent.firstChild !== endTargetElement) newDiv.appendChild(parent.firstChild) parent.prepend(newDiv) const lastNode = [...newDiv.childNodes].at(-1) const text = lastNode.nodeValue const minutes = text.match(/\d+/)[0] const beforeMinutes = text.match(/(.*?)\d+/)[1] const afterMinutes = text.match(/\d+(.*)/)[1] const formattedTimeNode = `