WeLearn一键完成

一键完成WeLearn的油猴脚本

// ==UserScript==
// @name         WeLearn一键完成
// @namespace    https://github.com/Zonakkis
// @version      0.1.3
// @description  一键完成WeLearn的油猴脚本
// @author       Zonakkis
// @match        *://welearn.sflep.com/student/StudyCourse.aspx*
// @match        *://welearn.sflep.com/student/studyccourse.aspx*
// @grant        none
// @license      MIT
// ==/UserScript==

(function () {
    'use strict';
    function Wait(ms) {
        return new Promise(resolve => setTimeout(resolve, ms));
    }
    function GetInnerDocument() {
        return document.getElementById("contentFrame").contentDocument;
    }
    function FillingShort() {
        const divs = innerdocument.querySelectorAll('div[data-controltype="filling"]');
        for (let i = 0; i < divs.length; i++) {
            const input = divs[i].querySelector('input');
            ///const result = divs[i].querySelector('div[data-itemtype="result"]');
            const myresult = divs[i].querySelector('div[data-itemtype="myresult"]');
            let answer = input.dataset.solution;
            input.value = answer;
            if (myresult != null) {
                myresult.innerText = answer;
            }
        }
    }
    function FillingLong() {
        const divs = innerdocument.querySelectorAll('div[data-controltype="fillinglong"]');
        for (let i = 0; i < divs.length; i++) {
            const textarea = divs[i].querySelector('textarea');
            const result = divs[i].querySelector('div[data-itemtype="result"]');
            let answer = result.innerText
                .trim()
                .replace(/\s+/g, ' ')
                .replace(/\([^)]*\)/g, '')
                .replace(/(?<=\s|^)(\w+)(?:\s*\/\s*\w+)+(?=\s|$)/, '$1');
            textarea.value = answer;
        }
    }
    function Choice() {
        const divs = innerdocument.querySelectorAll('div[data-controltype="choice"]');
        for (let i = 0; i < divs.length; i++) {
            const ul = divs[i].querySelector('ul[data-itemtype="options"]');
            const li = ul.querySelector('li[data-solution]');
            li.dataset.choiced = "";
        }
    }
    async function Finish() {
        console.log("EDIT!");
        innerdocument = GetInnerDocument();
        FillingShort();
        FillingLong();
        Choice();
        await Submit();
        await Wait(300);
        Next();
    }
    async function Submit() {
        const submit = innerdocument.getElementsByClassName("cmd cmd_submit")[0];
        submit.click();
        await Wait(300);
        Confirm();
    }
    function Confirm() {
        const yes = innerdocument.getElementsByClassName("layui-layer-btn0")[0];
        yes.click();
    }
    function Next() {
        next.click();
    }
    function AddButton() {
        next = document.getElementsByClassName("c_s_3_2")[0].childNodes[0];
        const aiSpan = document.getElementsByClassName("c_s_2_5")[0];
        aiSpan.style.display = "block";
        const button = aiSpan.childNodes[0];
        button.href = "javascript:void(0)";
        button.style.fontSize = "12px";
        button.innerText = "一键完成";
        button.onclick = Finish;
    }
    let innerdocument;
    let next;
    window.onload = AddButton;
})();