💯🥇🥇柠檬文才-批量课程助手💯🥇🥇

柠檬文才-批量课程助手

在您安裝前,Greasy Fork希望您了解本腳本包含“負面功能”,可能幫助腳本的作者獲利,而不能給你帶來任何收益。

此腳本只有在您 付費後才能使用全部的功能。 Greasy Fork尚未支付費用,因此無法驗證使用需要付費的商品,也無法幫助您獲得退款。

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name         💯🥇🥇柠檬文才-批量课程助手💯🥇🥇
// @namespace    http://www.xxx.com
// @version      1.0
// @description  柠檬文才-批量课程助手
// @author       Your Name
// @match        *.wencaischool.net/*
// @grant        GM_addStyle
// @grant      				GM_info
// @grant      				GM_getTab
// @grant      				GM_saveTab
// @grant      				GM_setValue
// @grant      				GM_getValue
// @grant      				unsafeWindow
// @grant      				GM_listValues
// @grant      				GM_deleteValue
// @grant      				GM_notification
// @grant      				GM_xmlhttpRequest
// @grant      				GM_getResourceText
// @grant      				GM_addValueChangeListener
// @grant      				GM_removeValueChangeListener
// @run-at     				document-start
// @namespace  				https://enncy.cn
// @homepage   				https://docs.ocsjs.com
// @source     				https://github.com/ocsjs/ocsjs
// @icon       				https://cdn.ocsjs.com/logo.png
// @connect    				enncy.cn
// @connect    				icodef.com
// @connect    				ocsjs.com
// @connect    				localhost
// @antifeature				payment
// ==/UserScript==

// Create the float box element
const floatBox = document.createElement('div');
floatBox.id = 'float-box';
floatBox.innerHTML = `
    <div style="background-color: rgba(255, 255, 0, 0.8); padding: 10px;">
        <p style="font-weight: bold; font-size: 18px;">float box for 柠檬文才</p>
        <br>
        <p><input type="checkbox">第一学期</p>
        <p><input type="checkbox">第二学期</p>
        <p><input type="checkbox">第三学期</p>
        <p><input type="checkbox">第四学期</p>
        <p><input type="checkbox">第五学期</p>
        <p><input type="checkbox">第六学期</p>
        <br>
        <p><input type="checkbox">课件</p>
        <p><input type="checkbox">作业</p>
        <br>
        <button id="start-btn">启动挂机</button>
        <br>
        <p>当前题库共:796189道</p>
        <br>
        <p><a href="https://flowus.cn/share/320cb53a-9376-4c35-987e-436e46f9b235" style="color: blue;">查看批量教程</a></p>
    </div>
`;

// Add the float box to the page
document.body.appendChild(floatBox);

// Add styles to the float box
GM_addStyle(`
    #float-box {
        position: fixed;
        top: 50px;
        left: 50px;
        z-index: 9999;
        cursor: move;
    }
`);

// Make the float box draggable
let isDragging = false;
let dragOffsetX = 0;
let dragOffsetY = 0;

floatBox.addEventListener('mousedown', (e) => {
    isDragging = true;
    dragOffsetX = e.pageX - floatBox.offsetLeft;
    dragOffsetY = e.pageY - floatBox.offsetTop;
});

floatBox.addEventListener('mouseup', () => {
    isDragging = false;
});

floatBox.addEventListener('mousemove', (e) => {
    if (isDragging) {
        floatBox.style.left = `${e.pageX - dragOffsetX}px`;
        floatBox.style.top = `${e.pageY - dragOffsetY}px`;
    }
});

// Add event listener to the start button
const startBtn = document.getElementById('start-btn');
startBtn.addEventListener('click', () => {
    alert('启动失败需要更新');
});
  WorkerJSPlus({
        name: "柠檬文才(考试)",
        match: () => {
            const pathMatch = location.pathname.includes("/separation/exam/");
            const matchHostArr = [ "learning.wuxuejiaoyu.cn", "learning.wencaischool.net", "learning.zk211.com" ];
            return pathMatch && matchHostArr.includes(location.host);
        },
        intv: () => {
            return $("#paperExam").css("display") != "none";
        },
        root: ".paperWrapper .tmList",
        elements: {
            question: ".tmTitleTxt",
            options: ".ansbox .opCont",
            $options: ".ansbox input"
        },
        ignore_click: $item => {
            return $item.prop("checked");
        },
        wrap: obj => {
            if (obj.options.length === 0) {
                obj.type = 2;
            }
            console.log(obj);
        },
        fill: (type, answer, $option) => {
            if (type === 4 || type === 2) {
                $option.val(answer);
            }
        }
    });
    WorkerJSPlus({
        name: "柠檬文才(作业)",
        match: () => {
            const matchHostArr = [ "learning.wuxuejiaoyu.cn", "learning.wencaischool.net", "learning.zk211.com" ];
            return location.pathname.includes("/xbsflearning/exam/") && matchHostArr.includes(location.host);
        },
        intv: () => {
            return $("#paperExam").css("display") !== "none";
        },
        root: "#_block_content_exam #tblDataList>tbody>tr",
        elements: {
            question: "tbody:first>tr>td:last table",
            options: ".ansbox .opCont",
            $options: ".ansbox input"
        },
        ignore_click: $item => {
            return $item.prop("checked");
        },
        wrap: obj => {
            obj.question = $("#_block_content_exam #tblDataList>tbody>tr>td").find(" tbody:first>tr>td:last table:first").eq(GLOBAL.index - 1).find("tr:first").text();
            obj.options = [];
            $("#_block_content_exam #tblDataList>tbody>tr>td").find(" tbody:first>tr>td:last table:first").eq(GLOBAL.index - 1).find("tr:first").next().find("label").map((i, y) => {
                obj.options.push($(y).text());
            });
            obj.$options = [];
            $("#_block_content_exam #tblDataList>tbody>tr>td").find(" tbody:first>tr>td:last table:first").eq(GLOBAL.index - 1).find("tr:first").next().find("input").map((i, y) => {
                obj.$options.push(y);
            });
            obj.type = 0;
            console.log(obj);
        }
    });