-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPixiv-QuickBookmark.user.js
147 lines (143 loc) · 8.85 KB
/
Pixiv-QuickBookmark.user.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
// ==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");