// ==UserScript==
// @name jav清单
// @namespace http://tampermonkey.net/
// @version 1.5
// @description jav清单,替代原网页我的清单,可用作自定义标签
// @author lyscop
// @grant GM_openInTab
// @grant GM_xmlhttpRequest
// @grant GM_setValue
// @grant GM_getValue
// @grant GM_setClipboard
// @grant GM_info
// @grant GM_openInTab
// @grant GM_deleteValue
// @grant GM_listValues
// @license MIT
// @include *://*javdb*.com/*
// @include *://*javdb*.com/v/*
// @include *://javdb*.com/actors/*
// @include *://*javdb*.com/users/lists*
// @include *://*javdb*.com/users/collection_actors*
// @include /^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/
// @include *://www.javbus.com/*
// @include *://javdb*.com/v/*
// @include *://javdb*.com/search?q=*
// @include *://www.javdb.com/*
// @include *://*.javlib.com/*
// @include *://*.javlibrary.com/*
// @include *://*/cn/?v=jav*
// @include *://*/en/?v=jav*
// @include *://*/tw/?v=jav*
// @include *://*/ja/?v=jav*
// @include *://*.javlib.com/*
// @include *://*.javlibrary.com/*
// @include *://*/tw/movie/jav*
// @run-at document-end
// @require https://cdn.jsdelivr.net/npm/jquery@2.2.3/dist/jquery.min.js
// ==/UserScript==
(function() {
'use strict';
var image = '';
let d = new Date();
let TimeDateFormatText = '[Year]/[Month]/[Day] [Hour]:[Minute]:[Second]';
let timetext = TimeDateFormatText.replace(/\[YEAR\]/gi, d.getFullYear().toString()).replace(/\[MONTH\]/gi, ('0' +(d.getMonth()+1).toString()).slice(-2)).replace(/\[DAY\]/gi, ('0' +d.getDate().toString()).slice(-2)).replace(/\[HOUR\]/gi, ('0' +d.getHours().toString()).slice(-2)).replace(/\[MINUTE\]/gi, ('0' +d.getMinutes().toString()).slice(-2)).replace(/\[SECOND\]/gi, ('0' +d.getSeconds().toString()).slice(-2));
var origninfo;
let videoFanhao;
let videoTitle;
let videoName;
let videoDate;
let videoCover;
let videoUrl = window.location.href;
let videoaddDate = timetext;
if(videoUrl.indexOf('javdb') > -1) {
origninfo = document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML.trim();
videoFanhao = document.querySelector('[data-clipboard-text]').attributes[2].value;
videoTitle = document.getElementsByClassName('current-title')[0].innerHTML;
videoDate = document.getElementsByClassName('panel movie-panel-info')[0].childNodes[3].childNodes[3].innerHTML;
videoCover = document.getElementsByClassName('video-cover')[0].src;
} else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
videoFanhao = document.getElementsByClassName('col-md-3 info')[0].children[0].children[1].innerHTML;
videoTitle = document.getElementsByTagName('h3')[0].innerHTML.slice(document.getElementsByTagName('h3')[0].innerHTML.indexOf(' ') + 1);
videoDate = document.getElementsByClassName('col-md-3 info')[0].children[1].innerText.split(': ')[1];
videoCover = document.getElementsByClassName('bigImage')[0].children[0].src;
} else if(videoUrl.indexOf('javlib') > -1) {
videoFanhao = document.getElementById('video_id').children[0].children[0].children[0].children[1].innerHTML;
videoTitle = document.getElementsByClassName('post-title text')[0].children[0].innerHTML.slice(document.getElementsByClassName('post-title text')[0].children[0].innerHTML.indexOf(' ') + 1);
videoDate = document.getElementById('video_date').children[0].children[0].children[0].children[1].innerHTML;
videoCover = document.getElementById('video_jacket_img').src;
}
let allValue = GM_listValues();
var inLists = '';
var listsShow = false;
var newArray = [];
const buttonG = document.createElement('button');
if(videoUrl.indexOf('javdb') > -1) {
buttonG.style.borderColor = '#dbdbdb';
buttonG.style.backgroundColor = "#fff";
buttonG.style.color = '#363636';
document.querySelectorAll('.panel-block div.buttons')[0].appendChild(buttonG);
buttonG.classList.add('button', 'is-info', 'is-outlined', 'button-c');
} else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
var divBus = document.getElementsByClassName('col-md-3 info')[0];
console.log(divBus)
var inlistDiv = document.createElement('div');
buttonG.style.border = '1px solid #d1d1d1';
buttonG.style.backgroundColor = "#fff";
buttonG.style.marginBottom = '10px';
divBus.appendChild(buttonG);
inlistDiv.className = 'inListBus'
inlistDiv.style.marginBottom = '10px';
divBus.appendChild(inlistDiv);
} else if(videoUrl.indexOf('javlib') > -1) {
var divLibs = document.getElementById('video_favorite_edit');
var inlistSpan = document.createElement('span');
var spanLib = document.createElement('span');
inlistSpan.className = "favoritetype";
buttonG.className = 'smallbutton';
inlistSpan.appendChild(buttonG);
divLibs.appendChild(inlistSpan);
spanLib.className = "favoritetype";
divLibs.appendChild(spanLib);
}
buttonG.innerHTML = '清单';
buttonG.addEventListener('click', () => {
listssettings();
window.setTimeout(function(){
listsShow = true;
}, 300);
});
allValue = GM_listValues();
allValue.forEach(function (obj, i) {//数组
var newListEle = {};
newListEle['name'] = obj;
newListEle['count'] = Object.values(GM_getValue(obj)).length;
newArray.push(newListEle);
});
newArray.sort(compare( "count"));
newArray.forEach(function (obj, i) {//数组
Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组
//console.log(value.fanhao);
if(value.fanhao == videoFanhao) {
if(inLists == ' ') {
inLists = obj.name;
} else {
inLists = inLists + ' ' + obj.name;
}
}
});
});
// console.log(inLists);
if(inLists) {
if(videoUrl.indexOf('javdb') > -1) {
document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = origninfo + ' ' + inLists;
} else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
document.getElementsByClassName('inListBus')[0].innerHTML = inLists;
} else if(videoUrl.indexOf('javlib') > -1) {
document.getElementsByClassName('col-md-3 info')[0].innerHTML = inLists;
}
}
document.addEventListener('mouseover', function (e) {
if(e.target.className === 'button is-info is-outlined button-c') {
e.target.style.borderColor = "#b5b5b5";
}
});
document.addEventListener('mouseout', function (e) {
if(e.target.className === 'button is-info is-outlined button-c') {
e.target.style.borderColor = "#dbdbdb";
}
});
document.addEventListener('click', function (e) {
if(e.target.className === 'button is-info is-outlined button-c') {
e.target.blur()
}
});
var nodeEle = document.createElement('div');
nodeEle.id = "Lists";
document.documentElement.appendChild(nodeEle);//元素加入body
var wid = window.screen.width/2 - 120;
var hei = window.screen.height/2 - 360;
var flag = false;
function listssettings() {
const nodeDiv = document.getElementById("Lists");
nodeDiv.innerHTML = '';
nodeDiv.setAttribute('style', '' +
'position:fixed;' +
'left:' + wid + 'px;' +
'top:'+ hei + 'px;' +
'width:277px;' +//最大宽度
'height:592px;' +//最大高度
'overflow:auto;' +
'font-size:14px!important;' +
'border-radius:5px!important;' +
//'border:none;' +
//'border:1px solid #ccc!important;' +
'border:1px solid #a9a9a9!important;' +
'background-color:#fff!important;' +
'z-index:2147483647!important;' +//显示最顶层
'');
nodeDiv.style.display = 'block';
var titlenode = document.createElement('div');
titlenode.style.border = '1px';
titlenode.style.marginTop = '8px';
titlenode.style.marginBottom = '8px';
const nameDiv = document.createElement('div');
nameDiv.style.marginLeft = '18px';
nameDiv.style.display = 'inline-block';
nameDiv.innerHTML = '清单 (' + allValue.length + ')';
nameDiv.style.marginRight = '5px';
nameDiv.addEventListener('click', () => {
//showList('丝袜', 0);
});
const addlist = document.createElement('img');
addlist.setAttribute('src', image);
addlist.setAttribute('style', '' + 'width:16px;' + 'height:16px;' + 'margin-bottom: 1px;' + 'vertical-align:text-bottom;' + '');
addlist.setAttribute('alt', '新增清单');
addlist.setAttribute('title', '新增清单');
addlist.style.marginRight = '90px';
addlist.addEventListener('click', () => {//新增
var newList = prompt('请输入信息');
var listFlag = false;
allValue = GM_listValues();
allValue.forEach(function (obj, i) {//数组
if(newList == obj) listFlag = true;
});
if(newList && !listFlag) {
GM_setValue(newList, []);
listssettings();
showclipboard('新增清单 ' + newList);
} else if(!newList) {
showclipboard('未输入', 1);
} else if(listFlag) {
showclipboard('已存在 ' + newList, 0);
}
});
var inputSpan = document.createElement('span');
inputSpan.innerHTML = '导入';
inputSpan.style.color = '#d1d1d1';
inputSpan.style.marginRight = '5px';
inputSpan.style.cursor = "pointer";
inputSpan.addEventListener('click', () => {
var input = document.createElement('input');
input.type = 'file';
input.addEventListener('change', function(event) {
var file = event.target.files[0];
var reader = new FileReader();
reader.addEventListener('load', function(event) {
var content = event.target.result;
var jsonArray = JSON.parse(content);
console.log(jsonArray); // 输出文件内容
Object.keys(jsonArray).forEach(function (key, index) {//数组
GM_setValue(key, jsonArray[key]);
});
showclipboard('已导入');
});
reader.readAsText(file);
});
input.click();
});
inputSpan.addEventListener('mouseover', () => {
inputSpan.style.color = 'black';
});
inputSpan.addEventListener('mouseout', () => {
inputSpan.style.color = '#d1d1d1';
});
var outputSpan = document.createElement('span');
outputSpan.innerHTML = '导出';
outputSpan.style.color = '#d1d1d1';
outputSpan.style.marginRight = '10px';
outputSpan.style.cursor = "pointer";
outputSpan.addEventListener('click', () => {
var javLists = {};
allValue = GM_listValues();
allValue.forEach(function (obj, i) {//数组
javLists[obj] = GM_getValue(obj);
});
// var blob = new Blob([JSON.stringify(javLists)], {type:"application/json;charset=utf-8"}).slice(2,-1); //text 内容没有{}不构成json
var blob = new Blob([JSON.stringify(javLists)], {type:"application/json;charset=utf-8"}); //json
var url = URL.createObjectURL(blob);
var elem = document.createElement("a");
elem.href = url;
elem.download = 'javList-Backup-' + timetext;
document.body.appendChild(elem);
elem.click();
document.body.removeChild(elem);
showclipboard('已导出');
});
outputSpan.addEventListener('mouseover', () => {
outputSpan.style.color = 'black';
});
outputSpan.addEventListener('mouseout', () => {
outputSpan.style.color = '#d1d1d1';
});
var close = document.createElement('div');
close.innerHTML = '×';
close.title = 'Close';
close.className = 'close';
close.style.cursor = "pointer";
close.style.display = 'inline-block';
close.style.fontSize = 'initial';
close.style.verticalAlign = 'bottom';
close.addEventListener('click', () => {
const settingnodeDiv = document.getElementById("Lists");
settingnodeDiv.style.display = 'none';
listsShow = false;
});
close.addEventListener('mouseover', () => {
close.style.color = 'red';
});
close.addEventListener('mouseout', () => {
close.style.color = 'black';
});
titlenode.appendChild(nameDiv);
titlenode.appendChild(addlist);
titlenode.appendChild(inputSpan);
titlenode.appendChild(outputSpan);
titlenode.appendChild(close);
nodeDiv.appendChild(titlenode);
const blankLast = document.createElement('div');
blankLast.setAttribute('style', '' + 'height: 7px;' + '');
nodeDiv.appendChild(blankLast);
var newEle = {};
var newArray = [];
var newinLists = '';
allValue = GM_listValues();
allValue.forEach(function (obj, i) {//数组
var newListEle = {};
newListEle['name'] = obj;
newListEle['count'] = Object.values(GM_getValue(obj)).length;
newArray.push(newListEle);
});
newArray.sort(compare( "count"));
newArray.forEach(function (value, i) {//数组
var listsinfo = document.createElement('div');
listsinfo.style.marginLeft = '18px';
var list = document.createElement('span');
var count = document.createElement('span');
var modify = document.createElement('span');
var del = document.createElement('span');
var note = document.createElement('span');
list.innerHTML = value.name;
list.style.width = '80px';
list.style.textAlign = 'left';
list.style.cursor = "pointer";
list.style.display = 'inline-block';
Object.values(GM_getValue(value.name)).forEach(function (value1, index1) {//数组
//console.log(value.fanhao);
if(value1.fanhao == videoFanhao) {
list.style.color = '#48C78E';
list.setAttribute('id', '1');
}
});
var ele = GM_getValue(value.name);
list.addEventListener('click', () => {
if(list.id == 1) {
list.style.color = '#000';
list.setAttribute('id', '0');
Object.values(ele).forEach(function (value2, index2) {
if(videoFanhao == value2.fanhao) {
ele.splice(index2, 1)
GM_setValue(value.name, ele);
listssettings();
showclipboard('移除清单 ' + value.name, 0);
newArray.forEach(function (obj, i) {//数组
Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组
//console.log(value.fanhao);
if(value.fanhao == videoFanhao) {
if(newinLists == ' ') {
newinLists = obj.name;
} else {
newinLists = newinLists + ' ' + obj.name;
}
}
});
});
console.log(newinLists);
if(videoUrl.indexOf('javdb') > -1) {
document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = origninfo + ' ' + newinLists;
} else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
document.getElementsByClassName('inListBus')[0].innerHTML = newinLists;
} else if(videoUrl.indexOf('javlib') > -1) {
document.getElementsByClassName('favoritetype')[4].innerHTML = newinLists;
}
}
});
listssettings();
} else {
list.setAttribute('id', '1');
newEle['fanhao'] = videoFanhao;
newEle['title'] = videoTitle;
newEle['date'] = videoDate;
newEle['url'] = videoUrl;
newEle['cover'] = videoCover;
newEle['adddate'] = videoaddDate;
ele.push(newEle);
GM_setValue(value.name, ele);
listssettings();
showclipboard('添加至清单 ' + value.name);
console.log('Url ' + videoUrl);
newArray.forEach(function (obj, i) {//数组
Object.values(GM_getValue(obj.name)).forEach(function (value, index) {//数组
//console.log(value.fanhao);
if(value.fanhao == videoFanhao) {
if(newinLists == ' ') {
newinLists = obj.name;
} else {
newinLists = newinLists + ' ' + obj.name;
}
}
});
});
console.log(newinLists);
if(videoUrl.indexOf('javdb') > -1) {
document.querySelectorAll('.is-size-7.has-text-grey')[0].innerHTML = origninfo + ' ' + newinLists;
} else if(videoUrl.indexOf('javbus') > -1 || videoUrl.match(/^.*(jav|bus|dmm|see|cdn|fan){2}\..*$/)) {
document.getElementsByClassName('inListBus')[0].innerHTML = newinLists;
} else if(videoUrl.indexOf('javlib') > -1) {
document.getElementsByClassName('favoritetype')[4].innerHTML = newinLists;
}
}
});
count.innerHTML = '(' + value.count + ')';
count.className = 'count';
count.style.width = '55px';
count.style.textAlign = 'left';
count.style.cursor = "pointer";
count.style.display = 'inline-block';
count.addEventListener('click', () => {
var data = [];
data = GM_getValue(value.name);
data.sort(compare1("fanhao",0, 0));
showList(data, value.name, value.count, 1);
});
modify.innerHTML = '修改';
modify.style.width = '35px';
modify.style.textAlign = 'left';
modify.style.cursor = "pointer";
modify.style.display = 'inline-block';
modify.style.color = 'white';
modify.addEventListener('click', () => {
var newobj = prompt('修改 ' + value.name, value.name);
let newele = [];
var arr = GM_getValue(value.name);
newele = arr;
if(newobj && newobj != value.name) {
GM_deleteValue(value.name);
GM_setValue(newobj, newele);
showclipboard('修改清单 ' + value.name + '为 ' + newobj, 1);
listssettings();
} else {
showclipboard('修改失败', 0);
}
});
modify.addEventListener('mouseover', () => {
modify.style.color = 'blue';
});
modify.addEventListener('mouseout', () => {
modify.style.color = 'white';
});
del.innerHTML = '删除';
del.style.width = '35px';
del.style.textAlign = 'left';
del.style.cursor = "pointer";
del.style.display = 'inline-block';
del.style.color = 'white';
del.addEventListener('click', () => {
var arr = GM_getValue(value.name);
if(arr.length == 0) {
var result = confirm("是否确认删除清单 " + value.name);
if (result) {
GM_deleteValue(value.name);
showclipboard('删除清单 ' + value.name, 0);
listssettings();
}
} else {
showclipboard('清单番号页面数量不为零,无法删除', 1);
}
});
del.addEventListener('mouseover', () => {
del.style.color = 'red';
});
del.addEventListener('mouseout', () => {
del.style.color = 'white';
});
note.innerHTML = '备注';
note.style.width = '35px';
note.style.textAlign = 'left';
note.style.cursor = "pointer";
note.style.display = 'inline-block';
note.style.color = 'white';
note.addEventListener('click', () => {
});
note.addEventListener('mouseover', () => {
note.style.color = 'green';
});
note.addEventListener('mouseout', () => {
note.style.color = 'white';
});
listsinfo.appendChild(list);
listsinfo.appendChild(count);
listsinfo.appendChild(modify);
listsinfo.appendChild(del);
listsinfo.appendChild(note);
nodeDiv.appendChild(listsinfo);
});
nodeDiv.appendChild(blankLast);
}
var mouseFlag = false;
var mouseNode = document.getElementById('Lists');
mouseNode.onmouseenter = function(e){
mouseFlag = true;
console.log("ismouseenter");
}
mouseNode.onmouseleave = function(){
mouseFlag = false;
console.log("ismouseleave");
}
document.addEventListener('click', () => {
if(listsShow && !mouseFlag) {
const settingnodeDiv = document.getElementById("Lists");
settingnodeDiv.style.display = 'none';
listsShow = false;
}
});
function compare( propertyName) {
return function( object1, object2) {
var value1 = object1[propertyName];
var value2 = object2[propertyName];
if(value1 < value2) {
return 1;
} else if(value1 > value2) {
return - 1;
} else {
return 0;
}
}
}
function compare1(propertyName, m, n) {//番号排序逆序
return function( object1, object2) {
var value1;
var value2;
if(m == 0) {
value1 = object1[propertyName];
value2 = object2[propertyName];
} else if(m == 1) {
value1 = new Date(object1[propertyName]);
value2 = new Date(object2[propertyName]);
value1 = value1.getTime();
value2 = value2.getTime();
}
if(n == 0) {//0顺序1逆序
if(value1 > value2) {
return 1;
} else if(value1 < value2) {
return - 1;
} else {
return 0;
}
} else if(n == 1) {
if(value1 < value2) {
return 1;
} else if(value1 > value2) {
return - 1;
} else {
return 0;
}
}
}
}
var wrapEle = document.createElement('div');
wrapEle.id = "wrap";
wrapEle.setAttribute('style', '' +
'position:fixed;' +
'right:0px;' +
'top:0px;' +
'width:300px;' +//最大宽度
'background-color:rgba(255,255,255,0)!important;' +
'z-index:2147483647!important;' +//显示最顶层
'');
document.documentElement.appendChild(wrapEle);//元素加入body
function showclipboard(text, c) {
const wrapDiv = document.getElementById("wrap");
var div = document.createElement('div');
if(c == 0) {
div.setAttribute('style', '' +
'display:none!important;' +//去掉直接显示
'left:0px;' +
'top:0px;' +
'margin-left:auto;' +//table块靠右显示
'font-size:13px!important;' +
'overflow:auto!important;' +
'background-color:rgba(255,99,71,0.5)!important;' +
'font-family:sans-serif,Arial!important;' +
'font-weight:normal!important;' +
'font-color:rgba(255,255,255,1)!important;' +
'text-align:left!important;' +//左对齐
'color:#fff!important;' +//字体颜色白
'border-radius:3px!important;' +
'border: 1px solid rgb(10 10 10 / 10%) !important;'+
'max-height:1216px!important;' +
'z-index:2147483647!important;' +
'');
} else if(c == 1) {
div.setAttribute('style', '' +
'display:none!important;' +//去掉直接显示
'left:0px;' +
'top:0px;' +
'margin-left:auto;' +//table块靠右显示
'font-size:13px!important;' +
'overflow:auto!important;' +
'background-color:rgba(8,46,84,0.6)!important;' +
'font-family:sans-serif,Arial!important;' +
'font-weight:normal!important;' +
'text-align:left!important;' +//左对齐
'color:#fff!important;' +
'border-radius:3px!important;' +
'border: 1px solid rgb(10 10 10 / 10%) !important;'+
'max-height:1216px!important;' +
'z-index:2147483647!important;' +
'');
} else {
div.setAttribute('style', '' +
'display:none!important;' +//去掉直接显示
'left:0px;' +
'top:0px;' +
'margin-left:auto;' +//table块靠右显示
'font-size:13px!important;' +
'overflow:auto!important;' +
'background-color:rgba(255,255,255,0.7)!important;' +
'font-family:sans-serif,Arial!important;' +
'font-weight:normal!important;' +
'text-align:left!important;' +//左对齐
'color:#000!important;' +
'border-radius:3px!important;' +
'border: 1px solid rgb(10 10 10 / 10%) !important;'+
'max-height:1216px!important;' +
'z-index:2147483647!important;' +
'');
}
div.innerHTML = text;
div.style.display = 'table';// 换行显示结果
let fc = wrapDiv.firstElementChild
if (fc) {
wrapDiv.insertBefore(div,fc)
} else {
wrapDiv.appendChild(div);
}
setTimeout(() => {
div.parentNode.removeChild(div);
},6000)
}
document.addEventListener('keydown',function(event) {
var keynum;
if(window.event) // IE
keynum = event.keyCode;
else if(event.which) // Netscape/Firefox/Opera
keynum = event.which;
if (event.key === 'Escape') {
const settingnodeDiv = document.getElementById("Lists");
settingnodeDiv.style.display = 'none';
listsShow = false;
document.getElementById("listpage").style.display = 'none';
}
});
var showList = function(data, listname, n, s) {
document.getElementById("Lists").style.display = 'none';
listsShow = false;
var nodeEle1 = document.createElement('div');
nodeEle1.id = "listpage";
document.documentElement.appendChild(nodeEle1);//元素加入body
var newwid = (window.screen.width - 890)/2;
var newhei = (window.screen.height - 860)/2;
const newnodeDiv = document.getElementById("listpage");
newnodeDiv.innerHTML = '';
newnodeDiv.setAttribute('style', '' +
'position:fixed;' +
'left:' + newwid + 'px;' +
'top:'+ newhei + 'px;' +
'width:905px;' +//最大宽度
'height:715px;' +//最大高度
'overflow:auto;' +
'font-size:14px!important;' +
'border-radius:5px!important;' +
'border:1px solid #a9a9a9!important;' +
'background-color:#fff!important;' +
'z-index:2147483647!important;' +//显示最顶层
'');
var div0 = document.createElement('div');
var divl = document.createElement('span');
var download = document.createElement('span');
var downloadtxt = document.createElement('span');
//var downxls = document.createElement('span');
var downloadjson = document.createElement('span');
var sort = document.createElement('span');
var sortfanhao = document.createElement('span');
var sorttimerorder = document.createElement('span');
var sorttimerreversedorder = document.createElement('span');
var sortaddtimerorder = document.createElement('span');
var sortaddtimerreversedorder = document.createElement('span');
var divc = document.createElement('span');
var stri = '';
var queryi = [];
divl.innerText = listname + ' (' + n + ')';
divl.style.width = "180px";
divl.style.paddingLeft = "6px";
divl.style.display = 'inline-block';
download.innerHTML = '下载';
download.style.color = '#000';
download.style.marginRight = '10px';
downloadtxt.innerHTML = 'TXT';
downloadtxt.style.color = '#d1d1d1';
downloadtxt.style.marginRight = '10px';
downloadtxt.style.cursor = "pointer";
downloadtxt.addEventListener('click', () => {
GM_getValue(listname).forEach(function (value, i) {//数组
queryi.push(value.fanhao + ',' + value.title.trim());
});
queryi.sort();
for(var i=0;i<queryi.length;i++) {
stri = stri + queryi[i] + '\n';
}
var downLinki = document.createElement('a');
downLinki.download = listname;
//字符内容转换为blod地址
var blobi = new Blob([stri]);
downLinki.href = URL.createObjectURL(blobi);
// 链接插入到页面
document.body.appendChild(downLinki);
downLinki.click();
// 移除下载链接
document.body.removeChild(downLinki);
showclipboard('已下载TXT');
});
downloadtxt.addEventListener('mouseover', () => {
downloadtxt.style.color = 'black';
});
downloadtxt.addEventListener('mouseout', () => {
downloadtxt.style.color = '#d1d1d1';
});
downloadjson.innerHTML = 'JSON';
downloadjson.style.color = '#d1d1d1';
downloadjson.style.marginRight = '10px';
downloadjson.style.cursor = "pointer";
downloadjson.addEventListener('click', () => {
var javLists = {};
javLists[listname] = GM_getValue(listname);
var blob = new Blob([JSON.stringify(javLists)], {type:"application/json;charset=utf-8"}); //json
var url = URL.createObjectURL(blob);
var elem = document.createElement("a");
elem.href = url;
elem.download = 'javList-Backup-' + timetext;
document.body.appendChild(elem);
elem.click();
document.body.removeChild(elem);
showclipboard('已下载JSON');
});
downloadjson.addEventListener('mouseover', () => {
downloadjson.style.color = 'black';
});
downloadjson.addEventListener('mouseout', () => {
downloadjson.style.color = '#d1d1d1';
});
sort.innerHTML = '排序';
sort.style.color = '#000';
sort.style.marginRight = '10px';
sortfanhao.innerHTML = '番号顺序';
if(s == 1)
sortfanhao.style.color = '#d1d1d1';
else
sortfanhao.style.color = '#000';
sortfanhao.style.marginRight = '10px';
sortfanhao.style.cursor = "pointer";
sortfanhao.addEventListener('click', () => {
var data = [];
data = GM_getValue(listname);
data.sort(compare1("fanhao",0, 0));
showList(data, listname, n, 1);
});
sorttimerorder.innerHTML = '时间顺序';
if(s == 2)
sorttimerorder.style.color = '#d1d1d1';
else
sorttimerorder.style.color = '#000';
sorttimerorder.style.marginRight = '10px';
sorttimerorder.style.cursor = "pointer";
sorttimerorder.addEventListener('click', () => {
var data = [];
data = GM_getValue(listname);
data.sort(compare1("date",1, 0));
showList(data, listname, n, 2);
});
sorttimerreversedorder.innerHTML = '时间逆序';
if(s == 3)
sorttimerreversedorder.style.color = '#d1d1d1';
else
sorttimerreversedorder.style.color = '#000';
sorttimerreversedorder.style.marginRight = '10px';
sorttimerreversedorder.style.cursor = "pointer";
sorttimerreversedorder.addEventListener('click', () => {
var data = [];
data = GM_getValue(listname);
data.sort(compare1("date",1, 1));
showList(data, listname, n, 3);
});
sortaddtimerorder.innerHTML = '添加顺序';
if(s == 4)
sortaddtimerorder.style.color = '#d1d1d1';
else
sortaddtimerorder.style.color = '#000';
sortaddtimerorder.style.marginRight = '10px';
sortaddtimerorder.style.cursor = "pointer";
sortaddtimerorder.addEventListener('click', () => {
var data = [];
data = GM_getValue(listname);
data.sort(compare1("adddate",1, 0));
showList(data, listname, n, 4);
});
sortaddtimerreversedorder.innerHTML = '添加逆序';
if(s == 5)
sortaddtimerreversedorder.style.color = '#d1d1d1';
else
sortaddtimerreversedorder.style.color = '#000';
sortaddtimerreversedorder.style.marginRight = '10px';
sortaddtimerreversedorder.style.cursor = "pointer";
sortaddtimerreversedorder.addEventListener('click', () => {
var data = [];
data = GM_getValue(listname);
data.sort(compare1("adddate",1, 1));
showList(data, listname, n, 5);
});
divc.innerHTML = '×';
divc.title = 'Close';
divc.className = 'close';
divc.style.cursor = "pointer";
divc.style.display = 'inline-block';
divc.style.fontSize = 'initial';
divc.style.verticalAlign = 'bottom';
divc.style.marginLeft = '215px';
divc.addEventListener('click', () => {
document.getElementById("listpage").style.display = 'none';
});
divc.addEventListener('mouseover', () => {
divc.style.color = 'red';
});
divc.addEventListener('mouseout', () => {
divc.style.color = 'black';
});
div0.appendChild(divl);
div0.appendChild(download);
div0.appendChild(downloadtxt);
div0.appendChild(downloadjson);
div0.appendChild(sort);
div0.appendChild(sortfanhao);
div0.appendChild(sorttimerorder);
div0.appendChild(sorttimerreversedorder);
div0.appendChild(sortaddtimerorder);
div0.appendChild(sortaddtimerreversedorder);
div0.appendChild(divc);
newnodeDiv.appendChild(div0);
var newDiv = document.createElement('div');
newDiv.id = "List";
newDiv.style.paddingLeft = "6px";
newDiv.style.width = '890px';
newDiv.style.display = 'flex';
newDiv.style.flexWrap = 'wrap';
newDiv.style.justifyContent = 'flex-start';
newnodeDiv.appendChild(newDiv);
let div = document.getElementById("List"),
currentPage = 1,
pageCount = 12,
list = null,
li = null;
function paginationByJS(data, div, currentPage, pageCount, list, li) {
//拿到我们的总页码
function getTotalPage(data, pageCount){
if (Math.ceil(data.length / pageCount) < 0) return console.error('getTotalPage 出现问题');
return Math.ceil(data.length / pageCount);
}
//每次都能够返回 一个包含要取到数据的索引
function getArrIndex(currentPage, data, totalPge, pageCount){
let begin, end;
if (!currentPage > 0 && !data.length && !totalPge > 0 && !pageCount > 0) {
return console.error('您传入的参数有误');
}
//当前页在头尾的情况
if (currentPage === 1) {
return (totalPge === 1)? {
begin: 0,
end: data.length - 1
} : {
begin: 0,
end: pageCount -1
}
}
if (currentPage === totalPge){
begin = ((currentPage -1) * pageCount);
end = data.length -1;
return {
begin, end
}
}
//在中间的情况
if (currentPage > 1 && currentPage < totalPge){
begin = (currentPage - 1) * pageCount;
end = currentPage * pageCount -1;
return { begin, end };
}
}
//增删类名修改
function isActive(){
//拿到目前正在作用active的元素 并且获取他的innerText
let activeBtn = document.getElementsByClassName('active')[0],
oldActiveIndex = activeBtn? parseInt(activeBtn.innerText) : null;
//如果两次点击同一个按钮则不做操作
if (oldActiveIndex === currentPage){ return; }
//若按钮存在 么此先做一个删除
if (activeBtn){ activeBtn.classList.remove('active'); }
list = Array.from(document.getElementsByTagName('li'));
//遍历添加
(list.find(i=> parseInt(i.innerText) === currentPage)).classList.add('active');
var eleli = document.getElementsByTagName('li');
//console.log(eleli)
if(eleli) {
Object.values(eleli).forEach(function (value, index) {//数组
value.addEventListener('mouseover', () => {
value.style.border = '1px solid #d1d1d1';
value.style.padding = '4px';
});
value.addEventListener('mouseout', () => {
value.style.border = '0px solid #d1d1d1';
value.style.padding = '5px';
});
// console.log(value.className)
if(value.className == 'active') {
value.style.background = '#CCE8FF';
} else {
value.style.background = '#FFF';
}
});
}
}
//返回渲染数组
function getRenderList(){
let temp = getArrIndex(currentPage, data, getTotalPage(data, pageCount), pageCount);
return data.slice(temp.begin, temp.end + 1); //slice方法取头不拿尾
}
//第一次创造列表数据
function createBtn(totalPage){
//let ul = document.getElementsByTagName('ul')[0];
var newUl = document.createElement('ul');
newUl.id = "ul-list";
newUl.setAttribute('style', '' +
'padding: 0;' +
'position: relative;' +
'top: 10px;' +
//'left: 38%;' +
'overflow: hidden;' +
'list-style: none;' +
'border: 0px solid #c1c1c1;' +
'display: inline-block;' +
'margin-top: 5px;' +
'height: 30px;' +
'');
if(getTotalPage(data, pageCount) < 3) {
newUl.style.left = '45%';
} else if(getTotalPage(data, pageCount) > 3 && getTotalPage(data, pageCount) < 6) {
newUl.style.left = '42%';
} else if(getTotalPage(data, pageCount) > 6 && getTotalPage(data, pageCount) < 8) {
newUl.style.left = '40%';
} else {
newUl.style.left = '38%';
}
newnodeDiv.appendChild(newUl);
const ul = document.getElementById("ul-list");
//每次都至少显示五个 当前 当前的前2个 当前的后2个
for (let i =1; i<=totalPage; i++){
//开头
if (i === 1){
li = document.createElement('li');
li.setAttribute('style', '' +
'float: left;' +
'padding: 5px;' +
'color: #273346;' +
'font-size: 15px;' +
'cursor: pointer;' +
'');
li.innerText = '<';
ul.appendChild(li);
}
//拿到页码按钮集合
li = document.createElement('li');
li.setAttribute('style', '' +
'float: left;' +
'padding: 5px;' +
'color: #273346;' +
'font-size: 15px;' +
'cursor: pointer;' +
'');
li.innerText = i;
//保证至少页码为8的时候才出现省略号
if(i > 6 && totalPage > 7){
li.innerText = '...';
ul.appendChild(li);
li = document.createElement('li');
li.setAttribute('style', '' +
'float: left;' +
'padding: 5px;' +
'color: #273346;' +
'font-size: 15px;' +
'cursor: pointer;' +
'');
li.innerText = totalPage;
ul.appendChild(li);
li = document.createElement('li');
li.setAttribute('style', '' +
'float: left;' +
'padding: 5px;' +
'color: #273346;' +
'font-size: 15px;' +
'cursor: pointer;' +
'');
li.innerText = '>';
ul.appendChild(li);
break;
}
ul.appendChild(li);
//到头了您
if (i === totalPage){
li = document.createElement('li');
li.setAttribute('style', '' +
'float: left;' +
'padding: 5px;' +
'color: #273346;' +
'font-size: 15px;' +
'cursor: pointer;' +
'');
li.innerText = '>';
ul.appendChild(li);
}
}
}
function btnControl(totalPage, currentPage) {
//小于7 就直接全部排出来就ok 不用搞这些花里胡哨的
if (totalPage < 8)return;
let li,
before = currentPage - 2, //头
after = currentPage + 2, //尾巴
list = document.getElementsByTagName('li'), //数据列表
arr = Array.from(list).filter((i)=>{ //实际页码改变的按钮
var index = parseInt(i.innerText);
return (index !== 1 && index !== totalPage && index.toString() !== 'NaN');
}),
headFlag = list[2],
endFlag = list[list.length - 3];
//控制插入 '...'
// if (currentPage > 4 && headFlag.innerText !== '...'){
// li = document.createElement('li');
// li.setAttribute('style', '' +
// 'float: left;' +
// 'padding: 5px;' +
// 'color: #273346;' +
// 'font-size: 15px;' +
// 'cursor: pointer;' +
// '');
// li.innerText = '...';
// list[0].parentElement.insertBefore(li, headFlag);
// }
// if ((currentPage > 1) && endFlag.innerText !== '...'){
// li = document.createElement('li');
// li.setAttribute('style', '' +
// 'float: left;' +
// 'padding: 5px;' +
// 'color: #273346;' +
// 'font-size: 15px;' +
// 'cursor: pointer;' +
// '');
// li.innerText = '...';
// list[0].parentElement.insertBefore(li, list[list.length - 2]); //加入之前的所以是 list.length-2
// }
//控制删除 '...'
if (currentPage < 5 && headFlag.innerText === '...'){
headFlag.parentNode.removeChild(headFlag);
}
if (after + 1 >= totalPage && endFlag.innerText === '...'){
endFlag.parentNode.removeChild(endFlag);
}
//关键的控制 基于他们展示时当前页 和 头尾 在边界位置以及普通位置的情况来做考虑
//在中间的时候 以currentPage为中心 前后2格
if (before > 1 && after < totalPage){
for (let i = currentPage - 2, j = 0; i <= currentPage + 2; i++, j++){
arr[j].innerText = i;
}
}
//头碰到边界了 说明要从2开始 这个currentPage是3了
if (before === 1){
for (let i = currentPage - 1, j = 0; i <= currentPage + 3; i++, j++){
arr[j].innerText = i;
}
}
//尾巴碰到边界了 说明要从currentPage回头数三个开始,不然会生成一个和totalPage相同的page,就是bug了。
if (after === totalPage){
for (let i = currentPage - 3, j = 0; i < currentPage + 2; i++, j++){
arr[j].innerText = i;
}
}
//当前页首尾~同上
if (currentPage === 1){
for (let i = currentPage + 1, j = 0; i <= arr.length + 1; i++, j++){
arr[j].innerText = i;
}
}
if (currentPage === totalPage){
for (let i = currentPage - arr.length, j = 0; i < totalPage; i++, j++){
arr[j].innerText = i;
}
}
}
window.setTimeout(function(){
var eleli = document.getElementsByTagName('li');
//console.log(eleli)
if(eleli) {
Object.values(eleli).forEach(function (value, index) {//数组
value.addEventListener('mouseover', () => {
value.style.border = '1px solid #d1d1d1';
value.style.padding = '4px';
});
value.addEventListener('mouseout', () => {
value.style.border = '0px solid #d1d1d1';
value.style.padding = '5px';
});
// console.log(value.className)
if(value.className == 'active') {
value.style.background = '#CCE8FF';
}
});
}
}, 100);
function arrowControl(target, totalPage){
let event = target || window.event;
if (event) {
target = event.target;
}
if (target) {
switch (target.innerText){
case '<': currentPage = currentPage === 1? 1 : currentPage - 1;break;
case '>': currentPage = currentPage === totalPage? totalPage : currentPage + 1; break;
case '...': break;
default: currentPage = parseInt(target.innerText);
}
}
}
function displayData() {
let arr = getRenderList(), p;//最后得到的数据
div.innerHTML = ''; //重置div内容区域
arr.forEach(i =>{
//p = document.createElement('p');
var div1 = document.createElement('div');
var linkimg1 = document.createElement('a');
var img1 = document.createElement('img');
var s1 = document.createElement('div');
var s2 = document.createElement('div');
var t1 = document.createElement('span');
var t2 = document.createElement('span');
var delfanhao = document.createElement('div');
div1.style.border = '3px solid #fff';
linkimg1.href = i.url;
linkimg1.onclick = function(){
GM_openInTab(i.url, {
active: false
});
return false;
}
img1.src = i.cover;
img1.style.width = '215px';
s1.innerText = i.fanhao;
t1.innerText = i.date;
t1.style.fontSize = '10px';
t2.innerText = i.adddate;
t2.style.fontSize = '10px';
t2.style.marginLeft = '60px';
delfanhao.innerHTML = '删除';
delfanhao.title = '删除';
delfanhao.className = '删除';
delfanhao.style.cursor = "pointer";
delfanhao.style.fontSize = '13px';
delfanhao.style.textAlign = 'center';
delfanhao.addEventListener('click', () => {
var ele = GM_getValue(listname);
delfanhao.parentNode.remove();
var result1 = confirm("是否确认删除清单 " + listname);
if (result1) {
Object.values(ele).forEach(function (value, index) {
if(i.fanhao == value.fanhao) {
ele.splice(index, 1)
GM_setValue(listname, ele);
showclipboard('移除清单 ' + listname, 0);
}
});
}
});
delfanhao.addEventListener('mouseover', () => {
delfanhao.style.color = 'red';
});
delfanhao.addEventListener('mouseout', () => {
delfanhao.style.color = 'black';
});
linkimg1.appendChild(img1);
div1.appendChild(linkimg1);
div1.appendChild(s1);
s2.appendChild(t1);
s2.appendChild(t2);
div1.appendChild(s2);
div1.appendChild(delfanhao);
div.appendChild(div1);
}); //展示一下
}
//这个是事件的监听函数
function pagination(target){
let totalPage = getTotalPage(data, pageCount);
//兼容拿到事件
arrowControl(target, totalPage);
btnControl(totalPage, parseInt(currentPage));
isActive();
displayData();
}
//首次注册生成第一页数据和分页栏
function firstInit() {
createBtn(parseInt(getTotalPage(data, pageCount)));
isActive();
displayData();
}
//window.onload = function () {
firstInit();
Array.from(document.getElementsByTagName('li')).forEach(i => i.onclick = function (e) {
pagination(e)
});
//}
}
paginationByJS(data, div, currentPage, pageCount, list, li);
}
})();