Raw Source
TitanRGB / Pixiv-QuickBookmark

// ==UserScript==
// @name                Pixiv-QuickBookmark
// @name:zh-CN          Pixiv-快捷收藏
// @name:ja             Pixiv-クイックブックマーク
// @namespace           https://github.com/Mehver
// @version             2.9
// @description         When press the main area of the image, it will add the bookmark instead of jump to the image page. And add a button to jump to the image page.
// @description:zh-CN   点击图片主区域,会直接收藏图片,而不是跳转到图片页面。并额外添加一个按钮用于跳转到图片页面。
// @description:ja      画像のメインエリアを押すと、ブックマークが追加され、画像ページにジャンプしなくなります。 さらに、画像ページにジャンプするためのボタンを追加します。
// @author              https://github.com/Mehver
// @icon                
// @match               http*://pixiv.net
// @match               http*://pixiv.net/*
// @match               http*://www.pixiv.net
// @match               http*://www.pixiv.net/*
// @license             MPL-2.0
// @license^            Mozilla Public License 2.0
// @grant               unsafeWindow
// @homepageURL         https://github.com/SynRGB/Pixiv-QuickBookmark
// @contributionURL     https://github.com/SynRGB/Pixiv-QuickBookmark
// @updateURL           https://github.com/SynRGB/Pixiv-QuickBookmark/releases/new
// @copyright           Copyright © 2022-PRESENT, Mehver (https://github.com/Mehver)
// @charset		        UTF-8
// @run-at              document-end
// ==/UserScript==

let last_run_time = new Date().getTime();

let main = function () {
    // pixiv.net/users/* 页面下特有的顶部精选图片,唯一内部dom结构不同的
    // the top featured images on pixiv.net/users/*, only theses have different internal dom structure
    let userFeatured_Imgs = document.querySelectorAll('div[radius="8"]');
    // 其他所有图片,内部的dom结构都一样
    // all other images, the internal dom structure is the same
    let allOther_Imgs = document.querySelectorAll('div[radius="4"]');
    /////////////////////////////////////////////////////////////////////////////////////////
    // 遍历 userFeatured_Imgs
    for (let i = 0; i < userFeatured_Imgs.length; i++) {
        // let div = userFeatured_Imgs[i].parentNode.parentNode;
        let div = userFeatured_Imgs[i].parentNode.parentNode.parentNode;
        let button = div.querySelector('button');
        // 避免重复添加
        // avoid duplicate modification
        let added_check = div.querySelector('div[class="Pixiv-QuickBookmark"]');
        // filter real img div
        if (button !== null && added_check === null) {
            // get the parent div of the button
            let buttonDiv = button.parentNode;
            // move button to left side
            let divWidth = div.clientWidth;
            buttonDiv.setAttribute('style', `
                position: absolute;
                width: ${divWidth}px;
                bottom: 0;
            `);
            // add the jump page button to right bottom edge
            let divToAdd_newJumpButton = document.createElement('div');
            divToAdd_newJumpButton.setAttribute('class', 'Pixiv-QuickBookmark');
            divToAdd_newJumpButton.setAttribute('style', `
                content: '';
                position: absolute;
                right: 0;
                bottom: 0;
                border: 17px solid #0096FA;
                border-top-color: transparent;
                border-left-color: transparent;
            `);
            divToAdd_newJumpButton.addEventListener('click', function () {
                let a = div.querySelector('a');
                a.click();
            });
            div.appendChild(divToAdd_newJumpButton);
            // modify the jump page area to bookmark button
            div.querySelector('a').childNodes[0].addEventListener('click', function (e) {
                e.preventDefault();
                button.click();
            });
        }
    }
    /////////////////////////////////////////////////////////////////////////////////////////
    // 遍历 allOther_Imgs
    for (let i = 0; i < allOther_Imgs.length; i++) {
        let div = allOther_Imgs[i].parentNode.parentNode.parentNode;
        // use for filter real img div
        let button = div.querySelector('button');
        // 避免重复添加
        // avoid duplicate modification
        let added_check = div.querySelector('div[class="Pixiv-QuickBookmark"]');
        // filter real img div
        if (button !== null && added_check === null) {
            // get the parent div of the button
            let buttonInnerDiv = button.parentNode;
            let buttonOuterDiv = button.parentNode.parentNode;
            // move button to left side
            let divWidth = div.clientWidth;
            buttonOuterDiv.setAttribute('style', `
                position: absolute;
                width: ${divWidth}px;
                bottom: 0;
            `);
            buttonInnerDiv.setAttribute('style', `
                position: relative;
                left: -${divWidth - 32}px;
            `);
            // add the jump page button to right bottom edge
            let divToAdd_newJumpButton = document.createElement('div');
            divToAdd_newJumpButton.setAttribute('class', 'Pixiv-QuickBookmark');
            divToAdd_newJumpButton.setAttribute('style', `
                content: '';
                position: absolute;
                right: 0;
                bottom: 0;
                border: 17px solid #0096FA;
                border-top-color: transparent;
                border-left-color: transparent;
            `);
            divToAdd_newJumpButton.addEventListener('click', function () {
                let a = div.querySelector('a');
                a.click();
            });
            div.appendChild(divToAdd_newJumpButton);
            // modify the jump page area to bookmark button
            div.querySelector('a').childNodes[0].addEventListener('click', function (e) {
                e.preventDefault();
                button.click();
            });
        }
    }
    last_run_time = new Date().getTime();
}

// if DOM changed, re-run the script
let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;
let observer = new MutationObserver(function (mutations) {
    mutations.forEach(function () {
        // 通过增加时间间隔来避免无限回调
        if (new Date().getTime() - last_run_time > 50) {
            main();
        }
    });
});
observer.observe(document.body, {
    childList: true,
    subtree: true
});

console.log("Userscript Pixiv-QuickBookmark (Pixiv-快捷收藏) loaded. See more details at https://github.com/SynRGB/Pixiv-QuickBookmark");