動畫瘋自動播放

啟用自動播放。更新:解決Firefox的一些問題,新增選項介面。

目前为 2019-11-26 提交的版本,查看 最新版本

// ==UserScript==
// @name         動畫瘋自動播放
// @namespace    http://tampermonkey.net/
// @version      0.2.1
// @description  啟用自動播放。更新:解決Firefox的一些問題,新增選項介面。
// @author       南蠻酋長
// @match        *://ani.gamer.com.tw/animeVideo.php?sn=*
// @icon         https://i2.bahamut.com.tw/anime/baha_s.png
// @grant GM_setValue
// @grant GM_getValue
// ==/UserScript==

(function () {
const qs = (q) => document.querySelector(q);

function optionPlaneTemplate() {
    let firefoxTip = ""; //
    if (navigator.userAgent.search("Firefox") != -1) {
        let img = `<img style="max-width:100%;" src=""/>`;
        firefoxTip = `
<div class="ani-setting-section">
<h4 class="ani-setting-title">你使用的是 Firefox 瀏覽器</h4>
<div class="ani-setting-item ani-flex">
            <div class="ani-setting-label">
                <span class="ani-setting-label__mian">因為 Firefox 預設會阻擋網站的自動影音播放,需要將動畫瘋加入允許自動播放的名單中才能運作喔!</span>
            </div>
        </div>
<div class="ani-setting-item">${img}</div>
</div>`;
    }
    let html =
    `<div class="ani-setting-section">
        <h4 class="ani-setting-title">自動播放設定</h4>

        <div class="ani-setting-item ani-flex">
            <div class="ani-setting-label">
                <span class="ani-setting-label__mian">自動確認年齡分級</span>
            </div>
            <div class="ani-setting-value ani-set-flex-right">
                <div class="ani-checkbox">
                    <label class="ani-checkbox__label">
                        <input type="checkbox" name="ani-checkbox" id="age-skip">
                        <div class="ani-checkbox__button"></div>
                    </label>
                </div>
            </div>
        </div>

        <div class="ani-setting-item ani-flex">
            <div class="ani-setting-label">
                <span class="ani-setting-label__mian">自動跳過剩餘廣告</span>
            </div>
            <div class="ani-setting-value ani-set-flex-right">
                <div class="ani-checkbox">
                    <label class="ani-checkbox__label">
                        <input type="checkbox" name="ani-checkbox" id="ad-skip">
                        <div class="ani-checkbox__button"></div>
                    </label>
                </div>
            </div>
        </div>

        <div class="ani-setting-item ani-flex">
            <div class="ani-setting-label">
                <span class="ani-setting-label__mian">自動播放下一集</span>
            </div>
            <div class="ani-setting-value ani-set-flex-right">
                <div class="ani-checkbox">
                    <label class="ani-checkbox__label">
                        <input type="checkbox" name="ani-checkbox" id="auto-play">
                        <div class="ani-checkbox__button"></div>
                    </label>
                </div>
            </div>
        </div>
    </div>
${firefoxTip}
    `;

    return html;
}

async function loadOptionsFromStore() {
    return {
        "age-skip" : await GM_getValue("age-skip", true),
        "ad-skip" : await GM_getValue("ad-skip", true),
        "auto-play" : await GM_getValue("auto-play", true)
    };
}

function onOptionClick(id) { return () => {
    GM_setValue(id, document.getElementById(id).checked);
    enableFunction(id, document.getElementById(id).checked);
};}

window.init = setInterval(function(){
    let optionPlaneDom = document.getElementById("ani-tab-content-2");
    if(optionPlaneDom){
        optionPlaneDom.innerHTML += optionPlaneTemplate();

        loadOptionsFromStore().then( options => {
            console.log(options);
            qs("#age-skip").checked = options["age-skip"];
            qs("#ad-skip").checked = options["ad-skip"];
            qs("#auto-play").checked = options["auto-play"];

            qs("#age-skip").addEventListener("click", onOptionClick("age-skip"));
            qs("#ad-skip").addEventListener("click", onOptionClick("ad-skip"));
            qs("#auto-play").addEventListener("click", onOptionClick("auto-play"));

            enableFunction("age-skip", options["age-skip"]);
            enableFunction("ad-skip", options["ad-skip"]);
            enableFunction("auto-play", options["auto-play"]);

            clearInterval(window.init);
        });
    }
},1000);

function enableFunction(id, enable) {
    console.log(id + " : " + enable);
    switch(id) {
        case "age-skip":
            enableAgeSkip(enable);
            break;
        case "ad-skip":
            enableAdSkip(enable);
            break;
        case "auto-play":
            enableAutoPlay(enable);
            break;
    }
}

function enableAutoPlay(enable) {
    if (!enable) {
        clearInterval(window.auto_play_checker);
        return;
    }
    window.auto_play_checker = setInterval(function(){
        if(qs("#ani_video_html5_api") && qs("#ani_video_html5_api").readyState != 0  && qs("#ani_video_html5_api").ended){
            let replayPage = qs(".replay");
            let nextEpBtn = replayPage? replayPage.childNodes[1] : null;
            if(nextEpBtn){
                nextEpBtn.click();
            }
            clearInterval(window.auto_play_checker);
        }
    },500);
}

function enableAgeSkip(enable) {
    if (!enable) {
        clearInterval(window.adult_checker);
        return;
    }
    window.adult_checker = setInterval(function(){
        if(qs(".R18") && qs("#adult")){
            qs("#adult").click();
            clearInterval(window.adult_checker);
        }
    },500);
}

function enableAdSkip(enable) {
    if (!enable) {
        clearInterval(window.ad_skip_checker);
        return;
    }
    window.ad_skip_checker = setInterval(function(){
        if(qs("#adSkipButton") && qs("#adSkipButton").classList.contains("enabled")){
            qs("#adSkipButton").click();
            clearInterval(window.ad_skip_checker);
        }
        if(qs(".nativeAD-skip-button") && qs(".nativeAD-skip-button").classList.contains("enable")){
            qs(".nativeAD-skip-button").click();
            clearInterval(window.ad_skip_checker);
        }
    },500);
}

})();