// ==UserScript==
// @name Acfun过滤UP计划
// @namespace http://tampermonkey.net/
// @version 1.31
// @description 帮助你屏蔽不想看的UP主
// @author 人文情怀
// @match http://www.acfun.cn/a/ac*
// @match http://www.acfun.cn/v/list63
// @match https://www.acfun.cn/a/ac*
// @match http://www.acfun.cn/*
// @match https://www.acfun.cn/*
// @match https://www.acfun.cn/v/list*
// @match http://www.acfun.cn/a/ac*
// @match https://www.acfun.cn/a/ac*
// @match http://www.acfun.cn/v/ac*
// @match https://www.acfun.cn/v/ac*
// @match https://www.acfun.cn/v/as*
// @match http://www.acfun.cn/v/as*
// @connect gf.qytechs.cn
// @require https://code.jquery.com/jquery-3.4.1.min.js
// @grant GM_getValue
// @grant GM_setValue
// @grant GM.getValue
// @grant GM.setValue
// @grant GM_xmlhttpRequest
// @grant GM.xmlHttpRequest
// @grant unsafeWindow
// @run-at document-idle
// ==/UserScript==
function core() {
'use strict';
let version="1.31";
$.info = unsafeWindow.$.info;
let empty = (a) => {
return typeof a=="undefined" ? ()=>{} : a;
};
//TamperMonkey 和 GreaseMonkey兼容
console.log("GM:",typeof GM_setValue)
let GM_set = typeof GM_setValue == "undefined" ?
function (key, value, callback, failcallback) {
let p = GM.setValue(key, value);
p.then(empty(callback), empty(failcallback));
}
: function (key, value, callback) {
let res = GM_setValue(key, value);
callback();
};
let GM_get = typeof GM_getValue == "undefined" ?
function (key, value, callback) {
let p = GM.getValue(key, value);
p.then((debug)=>{empty(callback)(debug); }, ()=>{callback(value);});
//console.log("empty", empty(callback));
}
: function (key, value, callback, failcallback) {
let res = GM_getValue(key, value);
callback(res);
}
//检查更新
function checkAnnouncement(callback){
let xhttp = !!GM_xmlhttpRequest ? GM_xmlhttpRequest : GM.xmlHttpRequest
xhttp({
method: "GET",
url: "https://gf.qytechs.cn/scripts/384697-acfunblockerannoucement/code/AcfunBlockerAnnoucement.js",
onload: function(response) {
let text = response.responseText;
callback(text);
}
});
}
function checkUpdate(callback){
let xhttp = !!GM_xmlhttpRequest ? GM_xmlhttpRequest : GM.xmlHttpRequest
xhttp({
method: "GET",
url: "https://gf.qytechs.cn/scripts/381476-acfun%E8%BF%87%E6%BB%A4up%E8%AE%A1%E5%88%92/code/Acfun%E8%BF%87%E6%BB%A4UP%E8%AE%A1%E5%88%92.user.js",
onload: function(response) {
let text = response.responseText;
let p = /@version +(\d+\.\d+)/
let arr = p.exec(text);
let latest=arr[1];
callback(latest);
}
});
}
//清空列表。DEBUG用
function cleanList() {
GM_set("ACFUN_BLOCK_LIST", []);
GM_set("ACFUN_BLOCK_KEYWORDS", []);
}
let up = function (callback) {
GM_get("ACFUN_BLOCK_LIST", [], callback);
};
let keywords=function(callback){
GM_get("ACFUN_BLOCK_KEYWORDS", [], callback);
}
function addToList(id, callback) {
up((old) => {
if (old.indexOf(id) >= 0) {
$.info.show("你已经屏蔽过UP主[" + id + "]啦!")
return;
}
old.push(id);
GM_set("ACFUN_BLOCK_LIST", old, () => {
$.info.show("已将UP主[" + id + "]加入屏蔽列表")
empty(callback)();
});
});
}
function removeFromList(id, callback) {
up((old) => {
let i = old.indexOf(id);
if (i >= 0) {
old.splice(i, 1);
}
GM_set("ACFUN_BLOCK_LIST", old, () => {
$.info.show("已将UP主[" + id + "]移出屏蔽列表。");
empty(callback)();
});
});
}
function addToKeywords(id, callback){
keywords((old) => {
if (old.indexOf(id) >= 0) {
$.info.show("你已经添加过关键词[" + id + "]啦!")
return;
}
old.push(id);
GM_set("ACFUN_BLOCK_KEYWORDS", old, () => {
$.info.show("已将关键词[" + id + "]加入屏蔽列表")
empty(callback)();
});
});
}
function removeFromKeywords(id, callback) {
keywords((old) => {
let i = old.indexOf(id);
if (i >= 0) {
old.splice(i, 1);
}
GM_set("ACFUN_BLOCK_KEYWORDS", old, () => {
$.info.show("已将关键词[" + id + "]移出屏蔽列表。");
empty(callback)();
});
});
}
let filterButton = document.createElement("div");
function initButton() {
document.body.appendChild(filterButton);
$(filterButton)
.css("width", "15px")
.css("height", "15px")
.css("background-color", "rgba(255,0,0,1)")
.css("font-familty", "'黑体',serif")
.css("font-weight", "600")
.css("font-size", "11px")
.css("padding", "1.5px")
.css("left", "0")
.css("top", "0")
.css("transform", "translate(0,0)")
.css("display", "none")
.css("position", "absolute")
.css("z-index", "99999")
.css("background-size", "contain")
.css("background-image", "url()")
.css("border-radius","11px")
.css("border","2px rgb(230,230,230) solid")
.css("cursor","pointer")
}
function handleSpecialJSONstr(str){
let chunk =str.split("\"title\":\"");
let later = chunk[1].split("\"");
let title = later[0];
let res = str.replace(title,"");
return [res, title];
}
//获得所有主页的UP的DOM TAG
function getHomeSelection() {
let res = [];
//过滤主页视频
let selections = $("a[data-info]");
for (let i = 0; i < selections.length; i++) {
let tag = selections[i];
let info = $(tag).attr("data-info");
let json="";
try{
let temp=handleSpecialJSONstr(info);
json = JSON.parse(temp[0]);
let title=temp[1];
let username = json.userName;
res.push({tag: $(tag).parent()[0], title: title, username: username, type: 1});
}catch(e){
console.error(e);
}
//$(tag)
}
//过滤右边排行榜视频
let sel = $("ul[data-con]");
//For each rank
for (let i = 0; i < sel.length; i++) {
let tag = sel[i];
let rows = $(tag).find("li");
//For each row
for (let ri = 0; ri < rows.length; ri++) {
let rowTag = rows[ri];
let aTag = $(rowTag).find("[title]")[0];
let title = $(aTag).attr("title");
let matches = usernameByTitle(title);
let titlestr = titleByTitle(title)[0];
if (matches) {
let username = matches[0].substring(3).trim();
res.push({tag: rowTag, title: titlestr, username: username, type: 2});
}
}
}
//--------------------主页文章区
sel = $("div[data-con]");
for (let i = 0; i < sel.length; i++) {
let tag = sel[i];
let rows = $(tag).find("li");
//For each row
for (let ri = 0; ri < rows.length; ri++) {
let rowTag = rows[ri];
let aTag = $(rowTag).find("[title]")[0];
let title = $(aTag).attr("title");
if (title) {
let matches = usernameByTitle(title)
let titlestr = titleByTitle(title)[0];
if (matches) {
let username = matches[0].substring(3).trim();
res.push({tag: rowTag,title: titlestr, username: username, type: 3});
}
}
}
}
//香蕉搒
var allBananas = $("figure.fl.block-box.block-video.weblog-item").find("> figcaption > em > a");
for (let i = 0; i < allBananas.length; i++) {
let sel = allBananas[i];
let upname = $(sel).attr("title");
let tag = $(sel).parent().parent().parent()[0];
let title = $(sel).parent().parent().find('b > a').text();
res.push({tag: tag, username: upname, type: 1, title: title});
}
//大版推荐
let allBig = $('.module-video-big').find('.text-overflow').find('a[title]');
for (let i =0;i<allBig.length; i++){
let title = $(allBig[i]).attr("title");
let regx = /UP:(.+)/
let r = regx.exec(title);
let username = r[1];
let tag = $(allBig[i]).parent().parent();
let subtag = tag.prev();
let titlestr = titleByTitle(title)[0];
res.push({tag: subtag[0], subtag: tag[0], username: username, type: 5, title: titlestr});
}
// console.log("res",res);
return res;
}
function getListSelection() {
let res = [];
let sel = $("div.weblog-item");
for (let i = 0; i < sel.length; i++) {
let row = sel[i];
let aTag = $(row).find(".atc-up")[0];
let username = $(aTag).attr("title");
let title = $(row).find('a[title]').attr("title");
res.push({tag: row, username: username, type: 4, title: title});
}
return res;
}
let pageType = "home";
//显示/刷新屏蔽的UP主
function displayList() {
up((data)=>{
//console.log("up",data);
$("#blocklist1").empty();
for (let i=0;i<data.length;i++){
let style1 = "font-size:13px;display:inline-block;margin:2px;height:18px;background-color:white;"
let style2 = "width:18px; height:18px; line-height:18px; padding: 2px; background-color: rgb(255,120,120); border-width:0; font-size:15px";
let b = $("<div class='blockname' style='"+style1+"'><span>"+data[i]+"</span><button style='"+style2+"'>×</button></div>")
let str = data[i];
b.on("click", function(){
removeFromList(str, ()=>{
displayList();
if(pageType=="home"){
FilterHomePage();
}else{
FilterListPage();
}
});
});
$("#blocklist1").append(b);
}
});
}
//显示屏蔽的关键词
function displayKeywords(){
keywords((data)=>{
$("#keywords_list").empty();
for (let i=0;i<data.length;i++){
let style1 = "font-size:13px;display:inline-block;margin:2px;height:18px;background-color:white;"
let style2 = "width:18px; height:18px; line-height:18px; padding: 2px; background-color: rgb(255,120,120); border-width:0; font-size:15px";
let b = $("<div class='blockname' style='"+style1+"'><span>"+data[i]+"</span><button style='"+style2+"'>×</button></div>")
let str = data[i];
b.on("click", function(){
removeFromKeywords(str, ()=>{
displayKeywords();
if(pageType=="home"){
FilterHomePage();
}else{
FilterListPage();
}
});
});
$("#keywords_list").append(b);
}
})
}
let show = false;
let dragging =false;
function banana(i){
let banana_0="url()";
let res = "<div id='banana_"+i+"'class='bbanana' style='cursor: pointer;display:inline-block;height:20px; width:20px; background-image:"+banana_0+";background-position: center; background-repeat:no-repeat; background-size:contain'></div>";
return res
}
function feedBanana(n){
try{
let ajax = $.ajax;
let a = btoa(Math.random().toString(36).substr(2))
let str = '$.cookie("stochastic","'+a+'",{path:"/"});';
console.log(str);
unsafeWindow.eval();
let cookie = unsafeWindow.eval('(()=>{return })();');
let command = str+
`
let a = btoa(Math.random().toString(36).substr(2));
$.cookie("stochastic",a ,{path:"/"});
let c = $.cookie("_did");
$.ajax({
type:"post",
url: "/nd/pst?locationPath=throwBanana&certified="+a,
beforeSend: function(e) {
e.setRequestHeader("udid", c)
},
data: {
contentId: "10271618",
count: `+(n+1)+`,
userId: $.user.uid,
},
dataType: "json",
xhrFields: {
withCredentials: !0
}
}).done(function(e){
if (e.success>0){
$.info.success("成功投食了作者"+`+(n+1)+`+"根香蕉O(∩_∩)O。谢谢支持!", 3e3)
}else{
$.info.warning("投食作者失败了。"+e.info, 3e3);
}
}).fail(function(){
$.info.warning("投食作者失败了 /(ㄒoㄒ)/~~。请于稍后重新操作。", 3e3)
})`
unsafeWindow.eval(command);
}catch(e){
console.log("投食DEBUG",e);
}
}
let banana_n = -1;
function attachBananaEvent(){
let banana_0="url()"
let banana_1="url()";
$(".bbanana").on("mouseover", function(){
let id = $(this).attr("id");
let n = parseInt(id.split("_")[1]);
banana_n=n;
let all = $(".bbanana");
for (let i = 0;i<all.length;i++){
let tid = $(all[i]).attr("id");
let tn = parseInt(tid.split("_")[1]);
if (tn<=n){
$(all[i]).css("background-image",banana_1)
}else{
$(all[i]).css("background-image",banana_0)
}
}
})
.on("click", function(){
let id = $(this).attr("id");
let n = parseInt(id.split("_")[1]);
feedBanana(n);
})
$("#banana_contain").on("mouseleave",function(){
$(".bbanana").css("background-image",banana_0)
})
}
function bindKeywordInputs(){
$('#keyword').keypress(function(e){
if(e.keyCode==13)
$('#enterKeyword').click();
});
$('#enterKeyword').on("click", function(){
let val = $("#keyword").val();
if (val.length>1){
$("#keyword").val('')
addToKeywords(val, ()=>{
displayKeywords();
if(pageType=="home"){
FilterHomePage();
}else{
FilterListPage();
}
});
}else{
$.info.warning('不能添加过短的关键词。');
}
})
}
function addPanel() {
let dx=0;
let dy=0;
let sx=0;
let sy=0;
let ox=0;
let oy=0;
let btnImage = "url()"
let ppanelwrap = $("<div id='blockbuttoncontainer' style=';z-index:999;position:fixed;left: 0; top: 0px;text-orientation:upright;'></div>");
let ppanel = $("<div style='position: relative;height: 100px; with: 22px;'></div>")
ppanelwrap.append(ppanel);
let dragbutton = $("<div id='blockdrag' style='height:22px; width: 23px; background-color:rgb(230, 121, 126);text-align:center;cursor:grab; user-select:none;-webkit-user-select:none'>|||||</div>")
let pbutton = $("<button id='blockbutton' style='height: 100px; padding: 3px; width: 23px;background-color:rgb(255, 193, 193); border-width:0;'>屏蔽设置</button>");
let pbtnImage = $("<div style='cursor:grab; position: absolute; left: 20px; height: 100px; width: 66px; background-image:"+btnImage+"; background-size:contain; background-repeat: no-repeat'></div>")
//panel container
ppanel.append(pbtnImage);
let p = $("<div id='blockpanel' style=' width: 218px;display:none; padding: 0px;z-index:998;position:fixed; background-color:rgb(255, 196, 196);left:23px; top: 0px;; '></div>");
//tabs
let ptabs=$("<div id='tabs' style='position:relative;height: 21px;border-bottom: solid white 1px; font-size: 13px'></div>")
let ptab1=$("<a style='padding: 1px;position:absolute; bottom:0; border-style:solid;display:inline-block; margin-left: 5px; height:16px; border-width: 1px 1px 0 1px; border-color: white; z-index: 9999; transform: translate(0,2px); background-color:#FFC4C4;'>UP主</a>")
let ptab2=$("<a style='padding: 1px;position:absolute; bottom:0; left:49px; border-style:solid;display:inline-block; height:16px; border-width: 1px 1px 0 1px; border-color: white; z-index: 9999; transform: translate(0,0px); background-color: #ffefa2;'>关键字</a>")
let ptab3=$("<a style='padding: 1px;position:absolute; bottom:0; right:5px; border-style:solid;display:inline-block; height:16px; border-width: 1px 1px 0 1px; border-color: white; z-index: 9999; transform: translate(0,0px); background-color: #ffefa2;'>公告</a>")
let plist1 = $("<div id='blocklist1' style='background-color:rgb(226, 185, 185);height: 220px; border: 0px solid white; width: 210px; margin: 3px;overflow-y:scroll'></div>")
let plist2 = $(`
<div id='blocklist2' style='background-color:#ffefa2;height: 220px; border: 0px solid white; width: 210px; margin: 3px; overflow:hidden; display:none'>
<div style='height: 22px'>
<input id='keyword' style='height: 18px;width: 120px; border: 0 solid black; padding: 0; margin: 0;' type='text' autocomplete="off" ></input>
<input type='submit' id='enterKeyword' style='line-height:18px; height: 18px;width: 60px; border: 0 solid black; margin: 0; padding: 0;' value='添加↵'></input>
</div>
<div id='keywords_list' style='height: 198px;overflow-y: scroll; background-color: #ffefa2;'>
</div>
</div>
`)
let plist3= $("<div id='announcement' style='background-color:black; color: white;height: 220px; border: 0px solid white; width: 210px; margin: 3px;overflow-y:scroll; display:none; '>正在加载公告....</div>")
let pAd = $("<div style='border: 1px solid white; margin:3px;padding: 2px; font-size: 11px;background-color:rgb(255, 217, 67); color: black'>喜欢的话 安利哟:<a target='_blank' style='color:rgb(71, 71, 138); text-decoration: underline' href='/a/ac10271618'>ac10271618</a></div>")
let bananas = "<a id='banana_contain'>"+banana(0)+banana(1)+banana(2)+banana(3)+banana(4)+"</a>";
let pinfo =$("<div style='border: 0px solid white; margin:3px;padding: 2px; font-size: 11px;background-color:rgb(234, 200, 65); color: rgb(50,50,50)'>当前版本:"+version+" "+ bananas+"</div>")
let pupdate = $("<div style='background-color: green; color: white; display: none; margin:3px; padding: 2px;' id='update_info'></div>")
checkUpdate((v)=>{
console.log(v,version);
if (parseFloat(v)> parseFloat(version)){
pupdate.css("display","block")
.html("<a style='color:white' target='_blank' href='https://gf.qytechs.cn/en/scripts/381476'>可以升级至:"+v+" 👉</a>");
$.info.show("【AcFun屏蔽UP主计划】有新版本了!")
}
})
GM_get("ACFUN_BLOCK_POS", "{ox:0, oy:0}", (d)=>{
ox=parseInt(d.ox);
oy=parseInt(d.oy);
ox = isNaN(ox) ? 0 : ox;
oy = isNaN(oy) ? 300 : oy;
p.css("transform","translate("+(ox)+"px,"+(oy)+"px)");
$(ppanel).css("transform","translate("+(ox)+"px,"+(oy)+"px)");
});
$(document.body).append(ppanelwrap);
//ppanel.append(dragbutton);
ppanel.append(pbutton);
p.append(ptabs);
ptabs.append(ptab1);
ptab1.on("click", ()=>{
ptab1.css("transform","translate(0,2px)");
ptab2.css("transform","translate(0,0px)");
ptab3.css("transform","translate(0,0)");
plist1.css("display","block");
plist2.css("display","none");
plist3.css("display","none");
})
ptabs.append(ptab2);
ptab2.on("click", ()=>{
ptab1.css("transform","translate(0,0)");
ptab2.css("transform","translate(0,2px)");
ptab3.css("transform","translate(0,0)");
plist1.css("display","none");
plist2.css("display","block");
plist3.css("display","none");
})
ptabs.append(ptab3);
ptab3.on("click", ()=>{
ptab1.css("transform","translate(0,0)");
ptab2.css("transform","translate(0,0))");
ptab3.css("transform","translate(0,2px)");
plist1.css("display","none");
plist2.css("display","none")
plist3.css("display","block");
})
p.append(plist1);
p.append(plist2);
p.append(plist3);
p.append(pAd);
p.append(pinfo);
p.append(pupdate);
$(document.body).append(p);
bindKeywordInputs();
attachBananaEvent();
checkAnnouncement((text)=>{
unsafeWindow.eval(text);
})
pbutton.on("click", function () {
show = !show;
p.css("display", show ? "block" : "none");
if (show) {
displayList();
displayKeywords();
pbtnImage.css("left", "241px")
}else{
pbtnImage.css("left", "20px")
}
})
pbtnImage.on("mousedown", (event )=>{
sx=event.pageX;
sy=event.pageY;
dragging=true;
});
dragbutton.on("mousedown", (event )=>{
sx=event.pageX;
sy=event.pageY;
dragging=true;
});
$(document).on("mouseup", ()=>{
if (dragging){
ox=dx+ox;
oy=dy+oy;
dx=0;
dy=0;
let maxHeight = $(window.top).height()-123;
let maxWidth = 240;
ox = ox>maxWidth?maxWidth:ox;
ox = ox<0?0:ox;
oy= oy<0?0:oy;
oy = oy>maxHeight? maxHeight: oy;
p.css("transform","translate("+(ox)+"px,"+(oy)+"px)");
$(ppanel).css("transform","translate("+(ox)+"px,"+(oy)+"px)");
GM_set("ACFUN_BLOCK_POS", {ox:ox,oy:oy}, (d)=>{
//console.log("DEBUG", "POSITION SET", ox, oy);
});
}
dragging=false;
});
$(document).on("mousemove",(event)=>{
if (dragging){
dx=event.pageX-sx;
dy=event.pageY-sy;
$(ppanel).css("transform","translate("+(dx+ox)+"px,"+(dy+oy)+"px)")
p.css("transform","translate("+(dx+ox)+"px,"+(dy+oy)+"px)");
}
})
}
function addButton() {
let attach = function (list) {
for (let i = 0; i < list.length; i++) {
let tag = list[i].tag;
if ($(tag).hasClass("event-attached")) continue;
let tagType = list[i].type;
$(tag).addClass("event-attached");
$(tag).on("mouseover",function () {
if (window.currentTag == tag) return;
let button = $(filterButton).detach();
const HOME_PAGE_ARTICLE=3;
if (tagType==HOME_PAGE_ARTICLE){
$(tag)
.css("white-space", "nowrap")
$(tag)
.css("overflow", "visible")
}else{
}
$(tag)
.css("position", "relative")
.append(button)
window.currentTag = tag;
window.currentUser = list[i].username;
$(filterButton).css("display","block").off("click");
if (pageType !== "home") {
$(filterButton)
.css("right", "0")
.css("top", "0")
.css("transform", "translate(0,0)")
}else{
$(filterButton).css("transform", "translate("+ (tagType==HOME_PAGE_ARTICLE? "-100%":0)+",0)")
}
$(filterButton).on("click", function (e) {
e.preventDefault();
if (typeof window.currentTag !== "undefined" && window.currentTag !== null) {
addToList(window.currentUser, ()=>{
displayList();
if(pageType=="home"){
FilterHomePage();
}else{
FilterListPage();
}
});
}
})
.show();
})
$(tag).on("mouseleave",function () {
$(filterButton).detach();
window.currentTag = null;
window.currentUser = null;
$(filterButton).off("click").hide()
})
}
}
if (pageType == "home") {
let list = getHomeSelection();
attach(list);
} else {
let list = getListSelection();
attach(list);
}
}
let pannelAdded = false;
function watchHomepage(){
let mutationObserver = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
let target = mutation.target;
if ($(target).hasClass("clearfix") && $(target).hasClass("module-video")){
addButton();
HandleHomePage();
}
});
});
mutationObserver.observe(unsafeWindow.document, {subtree: true, childList: true});
}
function watchList(){
let mutationObserver = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
let target = mutation.target;
if ($(target).hasClass("article-list")){
addButton();
//屏蔽文章页,
FilterListPage();
}
});
});
mutationObserver.observe(unsafeWindow.document, {subtree: true, childList: true});
}
function addUI() {
if (!pannelAdded) {
addPanel();
pannelAdded = true;
if (pageType=="home"){
watchHomepage();
}else{
watchList();
}
}
}
function titleByTitle(t){
let regex=/.+/
return t.match(regex);
}
function usernameByTitle(title) {
let regex = /UP:(.+)[\s\v\n]/g
return title.match(regex);
}
function hideTag(tag){
if ($(tag).css("display")!=="none"){
//console.log(tag, tag.getBoundingClientRect);
let rect = tag.getBoundingClientRect();
$(tag).css("transition","0.5s")
.css("-webkit-transition","0.5s")
.css("overflow","hidden")
.css("height", rect.height+"px")
let d=$(tag).css("display");
tag["_d"]=d;
tag["_h"]=rect.height+"px";
//console.log("hide tag",tag["_d"], tag["_h"]);
$(tag).css("height","0px");
setTimeout(()=>{
$(tag).css("display", "none");
},500)
let bar = $(tag).next();
//console.log(bar);
if (bar.length>0 && $(bar).prop("tagName").toUpperCase()=="HR"){
$(bar).css("display", "none");
}
}
}
function showTag(tag){
if ($(tag).css("display")=="none"){
$(tag).css("transition","0.5s")
.css("-webkit-transition","0.5s")
.css("overflow","hidden")
if (typeof tag["_d"]!=="undefined"){
$(tag).css("display", tag["_d"]);
}else{
$(tag).css("display", "block");
}
if (typeof tag["_h"]!=="undefined"){
$(tag).css("height", tag["_h"]);
}else{
$(tag).css("height", "auto");
}
let bar = $(tag).next();
if (bar.length>0 && $(bar).prop("tagName").toUpperCase()=="HR"){
$(bar).css("display", "block");
}
}
}
function FilterHomePage() {
keywords((keywordList)=>{
up((upList) => {
//过滤主页视频
let selections = getHomeSelection("FILTER", false, false);
for (let i = 0; i < selections.length; i++) {
let tag = selections[i].tag;
let tagType =selections[i].type;
let username = selections[i].username;
let title = selections[i].title;
if (upList.indexOf(username) >= 0 || containsKeyword(keywordList, title)){
hideTag(tag);
if (tagType==5){
hideTag(selections[i].subtag);
}
} else {
showTag(tag);
if (tagType==5){
showTag(selections[i].subtag);
}
}
}
})
})
}
function containsKeyword(list, title){
for (let i =0;i<list.length; i++){
let w= list[i];
if (title.indexOf(w)>=0){
return true;
}
}
return false;
}
//过滤文章列表页
function FilterListPage() {
keywords((keywordList)=>{
up(((upList) => {
let sel = getListSelection();
for (let i = 0; i < sel.length; i++) {
let row = sel[i].tag;
//if (typeof row.visited=="undefined"){ row.visited = true; }else{continue;}
//let aTag = $(row).find(".atc-up")[0];
let username = sel[i].username;
let title = sel[i].title;
//console.log("username",username, window.currentUser);
console.log("keywords", keywordList, title, sel[i])
if (upList.indexOf(username) >= 0 || containsKeyword(keywordList, title)) {
//console.log("过滤文脏区",username);
//屏蔽
hideTag(row);
} else {
showTag(row);
}
}
window.scrollTo(window.scrollX, window.scrollY + 1);
}))
})
}
function HandleHomePage() {
//屏蔽首页UP,包括视频和右边的文章区
FilterHomePage();
}
function HandleListPage() {
// console.log("debug timer list")
setTimeout(FilterListPage, 500);
}
function HandleArticlePage() {
//对于单独的文章页或者视频,添加一个按钮屏蔽当前UP主
//console.log(window.location.href.indexOf("www.acfun.cn/a/ac"), window.location.href.indexOf("www.acfun.cn/v/ac"))
let button = $("<div style='z-index: 9999;position:fixed; left:0px; top: 200px; width:30px; padding: 5px; background-color: rgba(255,50,50,0.3);user-select:none;-webkit-user-select:none; cursor: pointer;'>屏蔽UP</div>");
$(document.body).append(button);
button.on("click", function () {
let upname = "";
if (window.location.href.indexOf("www.acfun.cn/v/ac") >= 0) {
upname = $("a.name-wrap").html();
} else if (window.location.href.indexOf("www.acfun.cn/a/ac") >= 0) {
upname = $("a.upname").html();
}
addToList(upname);
})
}
function initLoad() {
if (typeof $ == "undefined") {
console.log("Loading..");
$=unsafeWindow.$;
setTimeout(initLoad, 1000);
return;
}
function isArtileListPage(){
if ( window.location.href.indexOf("www.acfun.cn/v/as")>0) return true;
let t = ["list63","list110","list73","list164","list184","list74","list75"];
let url = window.location.href;
for (let i=0;i<t.length; i++){
if (url.indexOf(t[i])>=0) return true;
}
return false;
}
console.log("DEBUG body Loaded");
if (window.location.href === "http://www.acfun.cn/" || window.location.href === "https://www.acfun.cn/") {
pageType="home";
initButton(); addUI();addButton();
HandleHomePage();
}
if (window.location.href.indexOf("www.acfun.cn/v/list") >= 0 || window.location.href.indexOf("www.acfun.cn/v/as")>0 ) {
//可能是文章列表
if (isArtileListPage()){
pageType="list";
initButton(); addUI();
HandleListPage();
}else{
pageType="home";
initButton(); addUI();addButton();
HandleHomePage();
}
}
if (window.location.href.indexOf("www.acfun.cn/v/ac") >= 0 || window.location.href.indexOf("www.acfun.cn/a/ac") >= 0) {
HandleArticlePage();
}
$.info.success("ACFUN屏蔽系统启动成功!")
}
initLoad();
};
core();