jav清单

jav清单,替代原网页我的清单,可用作自定义标签

// ==UserScript==
// @name         jav清单
// @namespace    http://tampermonkey.net/
// @version      1.2
// @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) {
        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) {
        var divBus = document.getElementsByClassName('col-md-3 info')[0];
        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) {
            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) {
                                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) {
                        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);
    }

    })();