javdb清单

javdb清单,替代原网页我的清单

Verze ze dne 02. 12. 2023. Zobrazit nejnovější verzi.

// ==UserScript==
// @name         javdb清单
// @namespace    http://tampermonkey.net/
// @version      0.1
// @description  javdb清单,替代原网页我的清单
// @author       lyscop
// @license      MIT
// @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
// @include      http*://javdb.com/v/*
// @include      http*://javdb*.com/v/*
// @include      http*://javdb.com/actors/*
// @include      http*://javdb.com/video_codes/*
// @include      http*://javdb.com/users/lists*
// @include      http*://javdb.com/users/collection_actors*
// @include      http*://javdb.com/users/collection_codes*
// @run-at       document-end
// @require      https://cdn.jsdelivr.net/npm/[email protected]/dist/jquery.min.js
// ==/UserScript==

(function() {
    'use strict';
    if(!GM_getValue('初始化')) {
        GM_setValue('初始化', true);
    } else {
        GM_deleteValue('初始化');
    }
    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));

    let videoFanhao = document.querySelector('[data-clipboard-text]').attributes[2].value;
    let videoTitle = document.getElementsByClassName('current-title')[0].innerHTML;
    let videoDate = document.getElementsByClassName('panel movie-panel-info')[0].childNodes[3].childNodes[3].innerHTML;
    let videoUrl = window.location.href;
    let videoCover = document.getElementsByClassName('video-cover')[0].src;
    let videoaddDate = timetext;

    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()
        }
    });

    const buttonG = document.createElement('button');
    document.querySelectorAll('.panel-block div.buttons')[0].appendChild(buttonG);
    buttonG.classList.add('button', 'is-info', 'is-outlined', 'button-c');
    //buttonG.innerHTML = site.name;
    buttonG.innerHTML = '清单';
    //buttonG.setAttribute('target', '_blank');
    //buttonG.setAttribute('alt', site.name);
    //buttonG.setAttribute('title', site.name);
    buttonG.style.borderColor = '#dbdbdb';
    buttonG.style.backgroundColor = "#fff";
    buttonG.style.color = '#363636';

    buttonG.addEventListener('click', () => {
        listssettings();
    });

    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;' +
                             //'right:0px;' +
                             //'top:0px;' +
                             // 'left:620px;' +
                             // 'bottom:240px;' +
                             'left:' + wid + 'px;' +
                             'top:'+ hei + 'px;' +
                             //'bottom:'+ he + 'px;' +
                             'width:277px;' +//最大宽度
                             //'height:390px;' +//最大宽度
                             'height:auto;' +
                             'overflow:auto;' +
                             //'overflow-wrap: break-word;' +
                             'font-size:14px!important;' +
                             //'padding:40px;' +
                             '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 = '清单 ';
        nameDiv.style.marginRight = '5px';

        const addlist = document.createElement('img');

        addlist.setAttribute('src', image);
        addlist.setAttribute('style', '' + 'width:16px;' + 'height:16px;' + 'margin-bottom: 2px;' + 'vertical-align:text-bottom;' + '');
        addlist.setAttribute('alt', '新增清单');
        addlist.setAttribute('title', '新增清单');
        addlist.style.marginRight = '185px';
        addlist.addEventListener('click', () => {//新增
            var newList = prompt('请输入信息');
            GM_setValue(newList, []);
            listssettings();
        });

        var close = document.createElement('div');
        close.innerHTML = '×';
        close.title = 'Close';
        close.className = 'close';
        close.style.cursor = "pointer";
        //close.style.position = "fixed";
        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';

        });
        close.addEventListener('mouseover', () => {
            close.style.color = 'red';
        });
        close.addEventListener('mouseout', () => {
            close.style.color = 'black';
        });

        titlenode.appendChild(nameDiv);
        titlenode.appendChild(addlist);

        titlenode.appendChild(close);
        nodeDiv.appendChild(titlenode);




        const blankLast = document.createElement('div');
        blankLast.setAttribute('style', '' + 'height: 7px;' + '');
        nodeDiv.appendChild(blankLast);

        let allValue = GM_listValues();
        var newEle = {};

        allValue.forEach(function (obj, i) {//数组
            var listsinfo = document.createElement('div');
            listsinfo.style.marginLeft = '18px';
            var list = document.createElement('span');
            var count = document.createElement('span');
            list.innerHTML = obj;
            list.style.width = '80px';
            list.style.textAlign = 'left';
            list.style.cursor = "pointer";
            list.style.display = 'inline-block';
            GM_getValue(obj).forEach(function (value, index) {//数组
                //console.log(value.fanhao);
                if(value.fanhao == videoFanhao) {
                    list.style.color = '#3D9140';
                    list.setAttribute('id', '1');
                    //console.log(list.id)
                }
            });
            var ele = GM_getValue(obj);
            list.addEventListener('click', () => {
                if(list.id == 1) {
                    list.style.color = '#000';
                    list.setAttribute('id', '0');
                    Object.values(ele).forEach(function (value, index) {
                        //console.log(value.fanhao)
                        //console.log(obj)
                        if(videoFanhao == value.fanhao) {
                            //ele = GM_getValue(obj);
                            ele.splice(index, 1)
                            GM_setValue(obj, ele);
                        }
                    });
                    listssettings();
                } else {
                    //list.style.color = '#3D9140';
                    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(obj, ele);
                    listssettings();
                }

            });
            count.innerHTML = '(' + GM_getValue(obj).length + ')';
            count.style.width = '50px';
            count.style.textAlign = 'left';
            count.style.cursor = "pointer";
            count.style.display = 'inline-block';
            count.addEventListener('click', () => {


            });
            listsinfo.appendChild(list);
            listsinfo.appendChild(count);
            nodeDiv.appendChild(listsinfo);

            //console.log(GM_getValue(obj));
        });

        nodeDiv.appendChild(blankLast);

    }

})();