cpasbien preview Image

Show image preview next to the titles by hovering the mouse (without caching and forcefully deleting old cache).

// ==UserScript==
// @name         cpasbien preview Image
// @namespace    https://www.cpasbien.moe/
// @version      2.1
// @description  Show image preview next to the titles by hovering the mouse (without caching and forcefully deleting old cache).
// @author       dr.bobo0
// @match        https://www.cpasbien.biz/*
// @match        https://www.cpasbien.moe/*
// @match        https://www.cpasbien.wtf/*
// @match        https://www.cpasbien.rs/*
// @match        https://www.cpasbien.pm/*
// @match        https://www.cpasbien.city/*
// @match        https://www.cpasbien.sbs/*
// @match        https://www.cpasbien.*/*
// @include      https://www.cpasbien.*/*
// @icon     
// @grant        none
// ==/UserScript==

(function() {
    'use strict';

    // Function to clear all localStorage items related to this script
    function clearOldCache() {
        for(let i = 0; i < localStorage.length; i++) {
            let key = localStorage.key(i);
            if(key.startsWith('https://www.cpasbien.')) {
                localStorage.removeItem(key);
            }
        }
        console.log('Old cache cleared');
    }

    // Clear old cache on script load
    clearOldCache();

    document.querySelectorAll("td > a.titre").forEach(link => {
        link.addEventListener("mouseover", function(event) {
            let previewContainer = document.createElement("div");
            previewContainer.style.position = "fixed";
            previewContainer.style.display = "none";
            previewContainer.style.transition = "opacity 0.1s ease-in-out";
            previewContainer.style.opacity = 0;
            previewContainer.style.width = "216px";
            previewContainer.style.height = "307px";
            previewContainer.style.borderRadius = "10px"; // Rounded corners
            previewContainer.style.overflow = "hidden";
            document.body.appendChild(previewContainer);

            var url = link.href;
            var xhr = new XMLHttpRequest();
            xhr.open("GET", url);
            xhr.responseType = "document";

            xhr.onload = function() {
                let preview = xhr.response.querySelector("#bigcover img");
                previewContainer.innerHTML = `<img style="width: 100%; height: 100%;" src="${preview.getAttribute("src")}"/>`;
            };

            document.addEventListener("mousemove", function (event) {
                previewContainer.style.top = event.clientY + 20 + "px";
                previewContainer.style.left = event.clientX + 20 + "px";

                // Check if preview container is too close to edge of viewport
                if (previewContainer.getBoundingClientRect().right > window.innerWidth) {
                    previewContainer.style.left = (window.innerWidth - previewContainer.offsetWidth - 20) + "px";
                }
                if (previewContainer.getBoundingClientRect().bottom > window.innerHeight) {
                    previewContainer.style.top = (window.innerHeight - previewContainer.offsetHeight - 20) + "px";
                }
            });

            xhr.send();
            previewContainer.style.display = "block";
            setTimeout(function () {
                previewContainer.style.opacity = 1;
            }, 0);
        });

        link.addEventListener("mouseout", function() {
            let previewContainer = document.querySelector("div[style*='opacity: 1']");
            if (previewContainer) {
                previewContainer.style.opacity = 0;
                setTimeout(function () {
                    previewContainer.style.display = "none";
                    previewContainer.remove();
                }, 100);
            }
        });
    });
})();