您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
Check if the URL has been accessed before and signaling to the user. With this script you will be able to know if you have already accessed the specific page of some image/video/tag before. If you have never accessed a URL, it will persist it in IndexedDB, if you have already accessed it, a warning message will be added to your screen.
// ==UserScript== // @name SankakuComplex - URL Verifier with IndexedDB // @namespace http://tampermonkey.net/ // @version 0.15 // @description Check if the URL has been accessed before and signaling to the user. With this script you will be able to know if you have already accessed the specific page of some image/video/tag before. If you have never accessed a URL, it will persist it in IndexedDB, if you have already accessed it, a warning message will be added to your screen. // @author mtpontes // @match *://chan.sankakucomplex.com/posts/* // @match *://chan.sankakucomplex.com/*/posts/* // @match *://idol.sankakucomplex.com/posts/* // @match *://idol.sankakucomplex.com/*/posts/* // @match *://legacy.sankakucomplex.com/posts/* // @match *://legacy.sankakucomplex.com/*/posts/* // @grant none // @icon  // @grant none // @license MIT // ==/UserScript== (function() { console.log('=== Starting execution of the visited URLs persister ==='); const dbName = 'VisitedDB'; const storeName = 'visitedURLs' const readMode = 'readonly' const writeMode = 'readwrite' function getDatabaseConnection() { return new Promise((resolve, reject) => { const request = indexedDB.open(dbName, 1); // If the database structure needs to be created or updated request.onupgradeneeded = (event) => { const db = event.target.result; if (!db.objectStoreNames.contains(storeName)) { db.createObjectStore(storeName, { keyPath: 'url' }); } }; request.onsuccess = (event) => resolve(event.target.result); // Returns the database as the result of the Promise request.onerror = (event) => reject('Error opening the database'); }); } function getDbTransaction(db, mode) { return db.transaction([storeName], mode).objectStore(storeName); } async function isVisitedPage(db, pageUrl) { const store = getDbTransaction(db, readMode); const getRequest = store.get(pageUrl); return new Promise((resolve, reject) => { getRequest.onsuccess = () => resolve(!!getRequest.result); // Operation succeeded getRequest.onerror = () => reject('Error accessing the database'); // Runs if the operation above fails }); } async function addCurrentPage(db, pageUrl) { const store = getDbTransaction(db, writeMode); return new Promise((resolve, reject) => { const request = store.add({ url: pageUrl }); request.onsuccess = () => resolve(); // If successful, resolve without any value request.onerror = () => reject('Error adding the URL to the database'); // Runs if the operation above fails }); } function addWarning() { const warningDiv = document.createElement('div'); warningDiv.style.position = 'fixed'; warningDiv.style.top = '10px'; warningDiv.style.left = '10px'; warningDiv.style.backgroundColor = 'rgba(255, 0, 0, 0.8)'; warningDiv.style.color = 'white'; warningDiv.style.padding = '10px'; warningDiv.style.zIndex = '9999'; warningDiv.innerText = 'You have already visited this page!'; document.body.appendChild(warningDiv); console.log('Visited URL warning was added'); } async function run() { try { const currentUrl = window.location.href; const db = await getDatabaseConnection(); const isVisited = await isVisitedPage(db, currentUrl); if (isVisited) { console.log('URL already visited'); addWarning(); return; } await addCurrentPage(db, currentUrl); console.log('URL added to the database'); } catch (error) { console.error('Error:', error); } } run(); })();