NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==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");