b站 动态页添加稍后再看

动态页切换up并选择视频添加到稍后再看

// ==UserScript==
// @name         b站 动态页添加稍后再看
// @namespace    http://tampermonkey.net/
// @version      0.3
// @description  动态页切换up并选择视频添加到稍后再看
// @author       WindOfCast
// @match        *://t.bilibili.com/*
// @icon         
// @grant        GM_notification
// @homepage     https://gitee.com/windofcast/
// @website      https://space.bilibili.com/367207503
// @license      AGPL License
// ==/UserScript==

(function () {
    'use strict';

    const common = (function () {
        class Common {
            #currentIconIndex;
            #currentVideoIndex;
            #previousVideoIndex;
            #upIconList;
            #dynList;
            #dynVideoList;
            #border = "1px solid #033eff";
            #upIconListPrevBtn;
            #upIconListNextBtn;
            #mainWidth;
            #upIconWidth;
            #pageIndex;

            constructor() {
                this.#currentIconIndex = -1;
                this.#currentVideoIndex = -1;
                this.#previousVideoIndex = -1;
                this.#upIconList = undefined;
                this.#dynList = [];
                this.#dynVideoList = [];
                this.#pageIndex = 0;
            }

            notification(messageObj) {
                GM_notification({
                    title: messageObj.title, text: messageObj.message, timeout: messageObj.timeout || 3000,
                });
            }

            backTop() {
                let backTop = document.querySelector('.back-top');
                if (backTop) {
                    backTop.click();
                }
            }

            pageJump(direction) {
                let index = direction ? this.#currentIconIndex + 1 : this.#currentIconIndex;
                if (index === 0) {
                    return;
                }
                let volume = index * this.#upIconWidth;
                let nextPage = volume / this.#mainWidth;
                console.info(volume, nextPage, this.#pageIndex)
                if (this.#pageIndex === Math.floor(nextPage)) {
                    return;
                }
                if (nextPage > this.#pageIndex && Math.ceil(nextPage) > this.#pageIndex) {
                    this.#upIconListNextBtn.click();
                    this.#pageIndex++;
                } else if (nextPage < this.#pageIndex && Math.floor(nextPage) < this.#pageIndex) {
                    this.#upIconListPrevBtn.click();
                    this.#pageIndex--;
                }
            }

            getItemWidthByAttributes(element, ...attributes) {
                let style = window.getComputedStyle(element);
                return attributes.reduce((acc, attr) => acc + parseInt(style[attr]), 0);
            }

            moveUpIcon(code) {
                let direction = false;
                if (code === "ArrowRight") {
                    direction = true;
                } else if (code !== "ArrowLeft") {
                    return;
                }
                if (direction && this.#currentIconIndex < this.#upIconList.length - 1) {
                    this.#upIconList[++this.#currentIconIndex].click()
                } else if (!direction && this.#currentIconIndex > 0) {
                    this.#upIconList[--this.#currentIconIndex].click()
                }
                this.pageJump(direction)
                this.backTop();
            }

            moveUpVideo(code) {
                let direction = false;
                if (code === "ArrowDown") {
                    direction = true;
                } else if (code !== "ArrowUp") {
                    return;
                }
                if (this.#dynVideoList.length === 0) {
                    this.notification({
                        title: '提示', message: 'UP最近没有更新视频'
                    })
                    return;
                }
                if (this.#currentVideoIndex === -1 && this.#previousVideoIndex === -1) {
                    this.#currentVideoIndex = 0;
                    this.border(this.#currentVideoIndex, this.#previousVideoIndex);
                    return;
                }
                this.#previousVideoIndex = this.#currentVideoIndex;
                let loadMoreVideo = false;
                if (direction && this.#currentVideoIndex + 1 > this.#dynVideoList.length - 1) {
                    this.loadVideoList(false, 100);
                    loadMoreVideo = true;
                }
                setTimeout(() => {
                    if (direction && this.#currentVideoIndex < this.#dynVideoList.length - 1) {
                        this.#currentVideoIndex++;
                        this.border(this.#currentVideoIndex, this.#previousVideoIndex);
                    } else if (!direction && this.#currentVideoIndex > 0) {
                        this.#currentVideoIndex--;
                        this.border(this.#currentVideoIndex, this.#previousVideoIndex);
                    } else if (!direction && this.#currentVideoIndex === 0) {
                        this.backTop();
                        this.#currentVideoIndex--;
                        this.border(this.#currentVideoIndex, this.#previousVideoIndex);
                    }
                }, loadMoreVideo ? 200 : 0);
            }

            addMark() {
                if (this.#currentVideoIndex === -1) {
                    return;
                }
                let dynVideoItem = this.#dynList[this.#dynVideoList[this.#currentVideoIndex]];
                let markItem = dynVideoItem.querySelector('.bili-dyn-card-video__mark');
                let messageObj = {
                    title: '提示', message: undefined
                };
                let title = dynVideoItem.querySelector('.bili-dyn-card-video__title').textContent;
                if (this.hasClass(markItem, 'active')) {
                    messageObj.message = `添加稍后再看 [${title}]`;
                } else {
                    messageObj.message = `移除稍后再看 [${title}]`;
                }
                this.notification(messageObj)
                markItem.click();
            }

            border(draw, clear) {
                if (draw !== -1) {
                    let dynVideoItem = this.#dynList[this.#dynVideoList[draw]];
                    dynVideoItem.style.border = this.#border;
                    dynVideoItem.scrollIntoView({behavior: 'auto', block: 'center'});
                }
                if (clear !== -1) {
                    this.#dynList[this.#dynVideoList[clear]].style.border = '';
                }
            }

            run() {
                this.keydownListener();
                this.loadDynList();
                this.loadVideoList();
                this.backTop();
            }

            keydownListener() {
                document.addEventListener("keydown", (evt) => {
                    let code = evt.code;
                    switch (code) {
                        case "ArrowRight":
                        case "ArrowLeft":
                            this.moveUpIcon(code);
                            break;
                        case "ArrowUp":
                        case "ArrowDown":
                            this.moveUpVideo(code);
                            break;
                        case "Enter":
                            this.addMark();
                            break;
                    }
                })
            }

            loadDynList() {
                this.#upIconList = document.querySelectorAll(".bili-dyn-up-list__item");
                this.#upIconList.forEach((item, index) => {
                    item.addEventListener('click', () => {
                        this.#currentIconIndex = index;
                        this.loadVideoList(true);
                    })
                })
                this.#currentIconIndex = 0;
                this.#upIconListPrevBtn = document.querySelector('.prev').querySelector('.bili-dyn-up-list__nav__btn');
                this.#upIconListNextBtn = document.querySelector('.next').querySelector('.bili-dyn-up-list__nav__btn');
                this.#mainWidth = this.getItemWidthByAttributes(document.querySelector('.bili-dyn-up-list__content'), "width");
                let noUp;
                let baseIcon = (noUp = this.#upIconList.length > 1) ? this.#upIconList[1] : this.#upIconList[0];
                this.#upIconWidth = this.getItemWidthByAttributes(baseIcon, "width", "marginLeft", "marginRight");
                if (!noUp) {
                    this.#upIconWidth += 3;
                }
            }

            loadVideoList(reload = false, timeout = 500) {
                if (reload) {
                    this.#previousVideoIndex = -1;
                    this.#currentVideoIndex = -1;
                }
                setTimeout(() => {
                    this.#dynVideoList = [];
                    this.#dynList = document.querySelectorAll(".bili-dyn-list__item");
                    for (let i = 0; i < this.#dynList.length; i++) {
                        let dynItem = this.#dynList[i];
                        if (dynItem.querySelector('a') && this.hasClass(dynItem.querySelector('.bili-dyn-content__orig'), 'reference')) {
                            this.#dynVideoList.push(i);
                        }
                    }
                    if (this.#dynVideoList.length > 0 && this.#dynVideoList[0] === 0) {
                        this.#currentVideoIndex = 0
                        this.border(this.#currentVideoIndex, this.#previousVideoIndex)
                    }
                }, timeout);
            }

            hasClass(element, cls) {
                let className = element.className;
                return className.indexOf(cls) === -1;
            }
        }

        let common = null;
        return (function () {
            if (!common) {
                common = new Common();
            }
            return common;
        })();
    })();

    window.addEventListener("load", () => {
        setTimeout(() => {
            console.log("[b站 动态页添加稍后再看]: 已加载!");
            common.run();
        }, 1000);
    })
})();

QingJ © 2025

镜像随时可能失效,请加Q群300939539或关注我们的公众号极客氢云获取最新地址