Greasy Fork is available in English.
开发上一个 Pixiv 插件时,意识到官方的 (全年龄/R-18) 过滤器并不能覆盖所有场景,容易使我的身体吃不消。因此需要更强大的强制过滤插件来一键过滤所有不良信息。
当前为
// ==UserScript==
// @name Pixiv-ForceSafeMode
// @name:zh-CN Pixiv-一键强制和谐
// @name:ja Pixiv-ワンタッチセキュリティモード
// @namespace https://github.com/TitanRGB
// @version 1.0
// @description While writing the last Pixiv user script, I realized that the official (Safe/R-18) filter didn't cover all the scenes. So I made this script to filter all bad information with one click.
// @description:zh-CN 开发上一个 Pixiv 插件时,意识到官方的 (全年龄/R-18) 过滤器并不能覆盖所有场景,容易使我的身体吃不消。因此需要更强大的强制过滤插件来一键过滤所有不良信息。
// @description:ja 前回のPixivユーザースクリプトを作成している最中、公式の(セーフ/ R-18)フィルターがすべてのシーンをカバーしていないことに気づきました。 したがって、1つのクリックですべての不適切な情報をフィルタリングするより強力な強制フィルタリングスクリプトが必要です。
// @author https://github.com/TitanRGB
// @icon 
// @include http*://www.pixiv.net*
// @match http://www.pixiv.net/
// @connect i.pximg.net
// @connect i-f.pximg.net
// @connect i-cf.pximg.net
// @license MPL-2.0
// @license^ Mozilla Public License 2.0
// @grant GM_setValue
// @grant GM_getValue
// @grant unsafeWindow
// @homepageURL https://github.com/SynRGB/Pixiv-ForceSafeMode
// @contributionURL https://github.com/SynRGB/Pixiv-ForceSafeMode
// @copyright Copyright © 2022-PRESENT, TitanRGB (https://github.com/TitanRGB)
// @charset UTF-8
// @run-at document-end
// ==/UserScript==
if (GM_getValue('pixiv-quick-safemode') === undefined) {
GM_setValue('pixiv-quick-safemode', false);
}
let last_run_time = new Date().getTime();
let delete_r18 = function () {
if (GM_getValue('pixiv-quick-safemode', false)) {
let div = document.querySelectorAll('div[type="illust"]');
for (let i = 0; i < div.length; i++) {
let divs = div[i].querySelectorAll('div');
for (let j = 0; j < divs.length; j++) {
// if contains 'R-18' or 'R-18G' in a div
if (divs[j].innerText.includes('R-18') || divs[j].innerText.includes('R-18G')) {
if (div[i].offsetWidth === 136) {
let new_div = document.createElement('div');
new_div.setAttribute('id', 'Pixiv-QuickSafeMode-Deleted');
new_div.setAttribute('style', `
width: 136px;
height: 136px;
background-color: #fff;
border: 1px solid #ddd;
border-radius: 4px;
display: flex;
justify-content: center;
align-items: center;
font-size: 12px;
color: #999;
`);
new_div.innerText = 'R-18';
div[i] = div[i].parentNode.replaceChild(new_div, div[i]);
break;
} else {
let parent3 = div[i].parentNode.parentNode.parentNode;
let parent2 = div[i].parentNode.parentNode;
let parent1 = div[i].parentNode;
if (parent3.querySelectorAll('div[type="illust"]').length === 1) {
parent3.remove();
} else if (parent2.querySelectorAll('div[type="illust"]').length === 1) {
parent2.remove();
} else if (parent1.querySelectorAll('div[type="illust"]').length === 1) {
parent1.remove();
} else {
div[i].remove();
}
break;
}
}
}
}
let li = document.querySelectorAll('li[offset="0"]');
for (let i = 0; i < li.length; i++) {
let divs = li[i].querySelectorAll('div');
for (let j = 0; j < divs.length; j++) {
// if contains 'R-18' or 'R-18G' in a div
if (divs[j].innerText.includes('R-18') || divs[j].innerText.includes('R-18G')) {
try {
let parent3 = li[i].parentNode.parentNode.parentNode;
let parent2 = li[i].parentNode.parentNode;
let parent1 = li[i].parentNode;
if (parent3.querySelectorAll('div[type="illust"]').length === 1) {
parent3.remove();
} else if (parent2.querySelectorAll('div[type="illust"]').length === 1) {
parent2.remove();
} else if (parent1.querySelectorAll('div[type="illust"]').length === 1) {
parent1.remove();
} else {
li[i].remove();
}
} catch (e) {
}
}
}
}
last_run_time = new Date().getTime();
}
}
let button = function (style) {
let div = document.createElement('div');
div.style.display = 'flex';
let span = document.createElement('span');
if (style === 'nav') {
span.setAttribute('style', `
display: flex;
-webkit-box-align: center;
align-items: center;
height: 46px;
padding-left: 24px;
padding-right: 24px;
font-weight: bold;
font-size: 16px;
line-height: 24px;
text-decoration: none;
border-top: 4px solid transparent;
transition: color 0.2s ease 0s;
cursor: pointer;
box-sizing: border-box;
white-space: nowrap;
background-color: transparent;
color: #0096FA;
cursor: default;
`);
div.setAttribute('style', `
display: flex;
`);
} else if (style === 'artwork') {
span.setAttribute('style', `
display: flex;
align-items: center;
width: -webkit-fill-available;
display: inline-grid;
align-items: center;
-webkit-box-align: center;
-webkit-box-pack: center;
justify-content: center;
cursor: pointer;
user-select: none;
white-space: nowrap;
font-size: 14px;
line-height: 22px;
font-weight: bold;
padding-right: 16px;
padding-left: 16px;
border-radius: 999999px;
box-sizing: border-box
transition: color 0.2s ease 0s, background-color 0.2s ease 0s, box-shadow 0.2s ease 0s;
height: 32px;
background-color: transparent;
color: #0096FA;
position: relative;
top: -7px;
`);
div.setAttribute('style', `
display: block;
`);
}
span.innerText = 'R-18';
if (GM_getValue('pixiv-quick-safemode', false)) {
span.style.backgroundColor = 'rgba(255, 255, 255, 0.12)';
span.style.color = 'rgb(255, 64, 96)';
}
span.addEventListener('click', function () {
if (GM_getValue('pixiv-quick-safemode', false)) {
GM_setValue('pixiv-quick-safemode', false);
span.style.backgroundColor = 'transparent';
span.style.color = '#0096FA';
} else {
GM_setValue('pixiv-quick-safemode', true);
span.style.backgroundColor = 'rgba(255, 255, 255, 0.12)';
span.style.color = 'rgb(255, 64, 96)';
}
}, false);
div.appendChild(span);
div.setAttribute('class', 'Pixiv-QuickSafeMode');
return div;
}
let main = function () {
let nav = document.querySelectorAll('nav');
let figcaption = document.querySelectorAll('figcaption');
let section = document.querySelectorAll('section');
// 确定为作品页面 (作品页面没有顶部 <nav> 菜单栏)
if (section.length > 4 && figcaption.length === 1 && nav[0].parentNode.childNodes.length === 1) {
if (section[3].parentNode === section[4].parentNode) {
section[3].appendChild(button("artwork"));
}
}
// 通过顶部 <nav> 菜单栏定位按钮
else if (nav.length > 0 && figcaption.length === 0) {
let div_nav = document.querySelector('nav');
div_nav.appendChild(button("nav"));
}
delete_r18();
last_run_time = new Date().getTime();
}
let MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver;
let observer = new MutationObserver(function (mutations) {
mutations.forEach(function () {
if (new Date().getTime() - last_run_time > 10) {
setTimeout(function () {
if (document.querySelectorAll('div[class="Pixiv-QuickSafeMode"]').length === 0) {
main();
} else {
delete_r18();
}
}, 15);
}
});
});
observer.observe(document.body, {
childList: true,
subtree: true
});
console.log("JS script Pixiv-ForceSafeMode (Pixiv-一键强制和谐) loaded. See more details at https://github.com/SynRGB/Pixiv-QuickSafeMode");