Douyu Auto Loot Script

My work is based on EternalPhane - 斗鱼助手

Add function:

  • Automatic start
  • 5 seconds count down notification by TTS audio message

GitHub

GitHub license
https://github.com/MKMark/UserScripts

Use TamperMonkey.

let chestId = null;
let yuwanId = null;
var ttscrc = '"http://tts.baidu.com/text2audio?idx=1&tex=' + document.title.substring(0,5) + '&cuid=baidu_speech_demo&cod=2&lan=zh&ctp=1&pdt=1&spd=5&vol=5&pit=5&per=3"';
$( "body" ).append("<audio id='audioPlay' src=" + ttscrc + " type='audio/mpeg'> hidden='true'>" );
var audio = document.getElementById( "audioPlay" );

(() => {
    'use strict';
    GM_addStyle(GM_getResourceText('css'));
    $('div#js-stats-and-actions > div:nth-child(3)').after(GM_getResourceText('html'));
    const getYuwan = () => {
        const time = $('span.getyw-time').text();
        const wait = () => {
            if ($('div.aui_content').text()) {
                $('button.aui_state_highlight').click();
                $('input#yuwan-switch').click();
            } else if ($('div.geetest_wait').length) {
                $('div.geetest_btn')
                    .mouseenter()
                    .click();
                getYuwan();
            } else {
                setTimeout(wait, 100);
            }
        };
        switch (time) {
            case '领取':
                if ($('div.v3-sign-wrap:visible').length) {
                    break;
                }
                $('a.may-btn')
                    .mouseenter()
                    .click();
                setTimeout(wait, 100);
                return;
            case '完成':
                return;
            case '':
                break;
            default:
                const [minute, second] = time.split(':');
                const ms = (Number(minute) * 60 + Number(second)) * 1000;
                yuwanId = setTimeout(getYuwan, ms);
                return;
        }
        yuwanId = setTimeout(getYuwan, 1000);
    };

    clickChest();
    $('input#chest-switch').change((e) => {
        e.currentTarget.checked
            ? clickChest()
            : clearInterval(chestId);
    });
    $('input#chest-switch').prop("checked",true);
    $('input#yuwan-switch').change(
        (e) => (e.currentTarget.checked ? getYuwan() : clearTimeout(yuwanId))
    );
})();

function clickChest(){
    chestId = setInterval(() => {
        if ($('div.geetest_fullpage_click_box:visible').length) {
            return;
        }
        const peck = $('div.peck-cdn');
        peck.length && '00:05' === peck.text() && audio.play();
        peck.length && '领取' === peck.text() && peck.mouseenter().click() && audio.play();
    }, 100)
}
Hover your mouse or tap on the left edge to navigate.
Upon dismissing, you acknowledge that you have read and understand our Privacy Policy.