Greasy Fork is available in English.

遇见八三的心动瞬间

学企来砍一刀

// ==UserScript==
// @name         遇见八三的心动瞬间
// @namespace    
// @version      1.14.47.20240701
// @description  学企来砍一刀
// @author       我纯f5捏
// @match        http://120.27.194.253/*
// @match        http://47.98.152.121/*
// @match        https://learn.cscec83.cn/*
// @match        https://ks.wjx.top/*/*
// @match        http://ks.wjx.top/*/*
// @match        https://www.amap.com/*
// @match        https://www.cscec83.cn/*
// @compatible   edge
// @license
// @icon         https://www.gstatic.com/android/keyboard/emojikitchen/20201001/u1f614/u1f614_u1f614.png
// @grant        GM_addStyle
// @grant        GM_setValue
// @grant        GM_getValue
// @grant        GM_deleteValue
// @grant        GM_notification
// @grant        GM_setClipboard
// @run-at       document-start
// @require      https://cdn.jsdelivr.net/npm/tesseract.js@5/dist/tesseract.min.js
// @require      https://update.greasyfork.org/scripts/447483/1071404/Boxjs.js
// @require      https://update.greasyfork.org/scripts/462234/1307862/Message.js
// @require      https://update.greasyfork.org/scripts/482872/1396650/%E4%B8%AD%E5%BB%BA%E5%AD%A6%E4%BC%81%E6%9D%A5%E5%85%A8%E9%A2%98%E5%BA%93%E5%8D%95%E9%80%891.js
// @require      https://update.greasyfork.org/scripts/482873/1396651/%E4%B8%AD%E5%BB%BA%E5%AD%A6%E4%BC%81%E6%9D%A5%E5%85%A8%E9%A2%98%E5%BA%93%E5%8D%95%E9%80%892.js
// @require      https://update.greasyfork.org/scripts/482874/1381432/%E4%B8%AD%E5%BB%BA%E5%AD%A6%E4%BC%81%E6%9D%A5%E5%85%A8%E9%A2%98%E5%BA%93%E5%A4%9A%E9%80%89.js
// @require      https://update.greasyfork.org/scripts/482875/1381433/%E4%B8%AD%E5%BB%BA%E5%AD%A6%E4%BC%81%E6%9D%A5%E5%85%A8%E9%A2%98%E5%BA%93%E5%88%A4%E6%96%AD.js
// @require      https://update.greasyfork.org/scripts/481939/1293842/jquery-360minjs.js
// ==/UserScript==
/*
***********************************************************

        以上参数为脚本必须读取的脚本元属性值,请勿随意改动
        以下参数修改请参见语雀功能文档或者代码注释定制化修改

***********************************************************
*/
killAllMonitor();
(function () {
    'use strict';
    var visionNum = '1.14.47.20240701';
    var cscecAdminCount = true; // 控制主页是否隐藏脚本窗口, true 为隐藏; false 为不隐藏;
    const rootFontSize = 46.667; // 页面如果大小显示异常, 可尝试修改, 请勿随意变动此数值;
    const answerTimeGap = 350; // 一键做题操作间隔, 太快页面来不及响应, 太慢影响使用, 单位:ms;
    const loginCheck = 1000; // 输入验证码后登录的间隔, 太快无法响应, 太慢影响使用, 单位:ms;
    const monitorGap = 400; // 控制url监控间隔, 太快会影响性能, 太慢影响使用, 单位:ms;
    const newParagraphText1 = '* 选择施工区段后再填写 *';

    /*
    ***********************************************************

            以下参数为功能必须的参数初始化或功能预留,请勿随意改动

    ***********************************************************
    */
    var radioQA = [];
    var multipleQA = [];
    var judgeQA = [];
    overrideOpen();
    Qmsg.config({
        showClose: true,
        timeout: 4000
    })
    initQABank();
    GM_setValue('userAgent', window.navigator.userAgent);
    try {
        var titleMsgAlert = `${GM_getValue('userName')} ${GM_getValue('nickName')}`;
    } catch (error) {
        titleMsgAlert = '未登录';
    }
    let excelOutput_a = []; // 在函数外部定义 excelOutput_a 数组,以便在 Promise 链中访问
    excelOutput_a[0] = ['项目名称', '日期', '天气', '温度', '湿度', '风向', '施工区段', '进度完成情况', '设计变更', '技术交底', '质量情况', '安全', '其他', '审批人', '现场人员投入', '现场设备投入'];
    const gk = '7fefe50dc219020f37ba2ee68e5618b0';
    const rightArr = ['正确', '对', '✓', '√', 'A', 'a', '是'];
    const wrongArr = ['错误', '错', '×', 'x', 'B', 'b', '否'];
    const getYears = [2020, 2021, 2022, 2023, 2024];
    const filterArray = ['每月考试'];
    var cscecConstructionLogCount = true;
    var isDraggable = false;
    var innerMsgAlert = '';
    var lastVisionNum = '';
    var currentUrl = '';
    var myPicImage = '';
    var timestamp = '';
    var ipData = '';
    var a = '';
    var b = '';
    var C = '';
    var d = '';
    var isQuestionFinishArray = [];
    var moneyResults = {};
    var practiceData = [];
    var savedData = [];
    var tokenData = [];
    var toolbox_ext = []

    addDiv();
    initElement();
    setRem();
    setTipsImg();
    webPageWatchUrl(urlOperate);
    document.querySelector('#noteText2').innerHTML = `版本号: ${visionNum} <br><br>`;
    let tipsCard = document.getElementById("tipsCard");
    tipsCard.addEventListener('mouseover', displayTipsImg);
    tipsCard.addEventListener('mouseout', vanishTipsImg);
    tipsCard.addEventListener('mousemove', displayTipsImg);
    document.getElementById('movedCard').addEventListener('mousedown', handleMouseDown);
    btnClick(".option1", verifyAndToast);
    btnClick(".option2", function () {
        if (getAb()) {
            switch (verifyUrl()) {
                case 1:
                    answerExam();
                    break;
                case 4:
                    Qmsg.error("此页面未配置本功能,请使用问卷星答题功能");
                    break;
                case 5:
                    Qmsg.error("此页面未配置本功能,请使用填写验证码功能");
                    break;
                case 6:
                    answerQuestion();
                    break;
                default:
                    Qmsg.error("此页面未配置本功能,如功能配置错误请联系我");
                    break;
            }
        } else {
            failVerify();
            waitToast(titleMsgAlert, innerMsgAlert, a);
        }
    });
    btnClick(".option3", function () {
        if (getAb()) {
            switch (verifyUrl()) {
                case 1:
                    autoExam();
                    break;
                case 4:
                    Qmsg.error("此页面未配置本功能,请使用问卷星答题功能");
                    break;
                case 5:
                    Qmsg.error("此页面未配置本功能,请使用填写验证码功能");
                    break;
                case 6:
                    autoAnswerQuestion();
                    break;
                case 7:
                    getAddress(currentUrl);
                    break;
                default:
                    Qmsg.error("此页面未配置本功能,如功能配置错误请联系我");
                    break;
            }
        } else {
            failVerify();
            waitToast(titleMsgAlert, innerMsgAlert, a);
        }
    });
    btnClick(".option4", answerQAStarExam);
    btnClick(".option5", function () {
        layer.open({
            type: 1,
            skin: 'layui-layer',
            area: ['80%', '60%'], //宽高
            content: layuiMenu(),
            title: '遇见八三的心动瞬间-附加功能',
            shadeClose: true,
            zIndex: 150,
            success: function (layero, index) {
                initToolboxListener();
                $('.toolbox_btn').on('click', function () {
                    layer.close(index)
                    console.log('有一个按钮被点击,toolbox已关闭')
                })
            }
        })
    });
    btnClick(".option6", function () {
        GM_addStyle(`
                    .mainDiv {
                        display: none;
                    }
                    #minDiv {
                        display: Block;
                    }
                `)
        let minDiv = document.createElement('div');
        minDiv.innerHTML = `
                    <button><span>disPlay</span></button>
                `;
        minDiv.style.position = 'fixed';
        minDiv.style.left = '0';
        minDiv.style.top = '50%';
        minDiv.width = '50px';
        minDiv.className = "minDiv";
        minDiv.style.zIndex = '999';
        minDiv.id = 'minDiv';
        minDiv.addEventListener('click', function () {
            GM_addStyle(`
                        .mainDiv {
                            display: grid;
                        }
                        #minDiv {
                            display: none;
                        }
                    `)
        });
        document.body.appendChild(minDiv);
    });
    btnClick(".option7", fillVerificationCode);
    btnClick(".option9", sendMsg);
    getWords();

    // window.onload = function () {

    // }

    async function initElement() {
        // 引入jquery
        // 问:这里为什么不用自带的require引入?
        // 答:第一,require不能引入css。第二,直接引入layer组建会导致显示异常,因此需要单独引入layer(属于技术原因受限)。第三,下面的两个库均已被GreasyFork认可(可前往https://greasyfork.org/zh-CN/help/cdns 进行审查)。
        // 根据GreasyFork脚本规则“库是应被 @require 的脚本,除非因为技术原因不能这么做。如果一个库被内嵌入了脚本,那么你必须一并提供库的来源(比如一行评论指向原始地址、名称以及版本)。”
        // 我们在下方介绍了对应的库的原始地址、名称以及版本,并且说明了是因为技术原因而不能使用require引用。
        $('head').append($('<link rel="stylesheet" href="https://www.layuicdn.com/layui-v2.9.8/css/layui.css">')) // 名称:layui,版本:2.9.7,原始地址:https://www.layuicdn.com/#Layui
        if (typeof layer == 'undefined') {
            $('head').append('<script src="https://www.layuicdn.com/layui-v2.9.8/layui.js"></script>') // 名称:layer,版本:2.9.7,原始地址:https://www.layuicdn.com/#Layer
        }
        while (true) {
            if (typeof layer != 'undefined') {
                break;
            }
            document.querySelector('#noteText1').innerHTML = `正在加载关键部件请稍等<br>`;
            await sleep(0.5);
        }
        document.querySelector('#noteText1').innerHTML = `无偿授权,请勿泛滥<br>有问题请参考语雀文档`;
        addButtons();
        getIP();
        hello('遇见八三的心动瞬间', visionNum);
        console.log("%c%s",
            "color: white; background: black; font-size: 20px; font-weight:1000; text-decoration: none;",
            "https://www.yuque.com/yuqueyonghuuadmba/kb/gan09a7zvlktoa9v?singleDoc");
    }

    function initToolboxListener() {
        btnClick("#resetQABank_btn_toolbox", function () {
            resetQABank();
            Qmsg.success("题库已重置");
        });
        btnClickToUrl("#openJSUrl_btn_toolbox", 'https://greasyfork.org/zh-CN/scripts/483543-%E9%81%87%E8%A7%81%E5%85%AB%E4%B8%89%E7%9A%84%E5%BF%83%E5%8A%A8%E7%9E%AC%E9%97%B4');
        btnClick("#forceExam_btn_toolbox", function () {
            if (getAb()) {
                if (currentUrl.includes("learn.cscec83.cn/xql_exam/exam")) {
                    forceExam();
                }
                else {
                    Qmsg.warning('请在考试选择页面使用');
                }
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        });
        btnClick("#QAStar_forceExam_btn_toolbox", function () {
            deleteAllCookies();
            clearCookie();
            clearStorage();
            Qmsg.success("cookie数据已清除");
        });
        btnClick('#practice1_btn_toolbox', function () {
            if (getAb()) {
                oneClickAnswer(1);
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        })
        btnClick('#practice2_btn_toolbox', function () {
            if (getAb()) {
                oneClickAnswer(2);
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        })
        btnClickToUrl('#contactMe_btn_toolbox', 'https://space.bilibili.com/43880280');
        btnClickToUrl('#yuqueUrl_btn_toolbox', 'https://www.yuque.com/yuqueyonghuuadmba/kb/gan09a7zvlktoa9v');
        btnClick("#iWantStudy_btn_toolbox", function () {
            if (getAb()) {
                fetch("https://learn.cscec83.cn/prod-api/course/periodUser", {
                    "headers": {
                        "accept": "application/json, text/plain, */*",
                        "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                        "authorization": GM_getValue('Authorization'),
                        "content-type": "application/json",
                    },
                    "body": "{\"periodId\":485,\"watchDuration\":111.84082}",
                    "method": "PUT",
                })
                    .then(response => {
                        return response.json()
                    })
                    .then(data => {
                        switch (data.code) {
                            case 200:
                                Qmsg.success("每周课程学习完成");
                                break;
                            case 500:
                                console.log("每周课程学习过完成了");
                            default:
                                Qmsg.error("每周课程学习异常 code");
                                break;
                        }
                    })
                    .catch(error => {
                        Qmsg.error("每周课程学习 error" + error);
                        Qmsg.error("进入或重新进入学企来后使用");
                    })
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        });
        btnClick('#feedback_btn_toolbox', function () {
            layer.prompt({ title: '用户意见反馈', formType: 2 }, function (value, index, elem) {
                if (value === '') return elem.focus();
                sendEmail("用户反馈", `${GM_getValue('userName')} ${GM_getValue('nickName')}`,
                    `
                            <img src= ${GM_getValue("myPicImage")} width = 200px height = 280px>
                            <div>基本信息:${JSON.stringify(GM_getValue('information'), null, "<br>    ")} ;</div>
                            <div>反馈意见:${value} ;</div>
                            <div>反馈时间:${formattedDate(new Date())} ;</div>
                            <div>脚本版本:${visionNum} ;</div>
                            <div>操作系统:${GM_getValue("userAgent")} ;</div>
                        `
                    , true);
                Qmsg.success("用户意见反馈成功");
                layer.close(index);
            });
        })
        btnClick('#option1_btn_toolbox', function () {
            if (getAb()) {
                layer.open({
                    type: 1,
                    area: '350px',
                    resize: false,
                    shadeClose: true,
                    title: 'QQ',
                    content: `
                            <div class="layui-form" lay-filter="filter-test-layer" style="margin: 16px;">
                                <div class="demo-login-container">
                                    <div class="layui-form-item">
                                        <div class="layui-input-wrap">
                                            <div class="layui-input-prefix">
                                                <i class="layui-icon layui-icon-username"></i>
                                            </div>
                                            <input type="text" name="username" value="" lay-verify="required" placeholder="QQ 号" lay-reqtext="请填写 QQ 号" autocomplete="off" class="layui-input" lay-affix="clear">
                                        </div>
                                    </div>
                                    <div class="layui-form-item">
                                        <button class="layui-btn layui-btn-fluid" lay-submit lay-filter="demo-QQlogin">强制聊天</button>
                                    </div>
                                    <div class="layui-form-item demo-login-other">
                                    </div>
                                </div>
                            </div>
                        `,
                    success: function () {
                        layui.form.render();
                        layui.form.on('submit(demo-QQlogin)', function (data) {
                            let url = 'https://api.uomg.com/api/qq.talk?qq=' + data.field.username;
                            window.open(url, '_blank');
                            return false; // 阻止默认 form 跳转
                        });
                    }
                });
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        });
        btnClick('#option2_btn_toolbox', function () {
            if (getAb()) {
                getConstructionDairy(GM_getValue('xAccessToken'), 1, new Date().getTime(), GM_getValue('nickName'), 999);
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        });
        btnClick('#option3_btn_toolbox', function () {
            if (getAb()) {
                let index3 = layer.open({
                    type: 1,
                    area: '50vw',
                    resize: false,
                    shadeClose: true,
                    title: '施工日志补全',
                    content: `
                    <form class="layui-form layui-row layui-col-space16">
                    <div class="layui-form" style="margin: 16px">
                    <div class="layui-form-item">
                        <div class="layui-inline layui-form-item layui-form-text">
                            <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">项目名称</label>
                            <div class="layui-input-inline layui-col-xs2" style="padding-left: 30px">
                                <input type="text" name="project" lay-verify="required" placeholder="项目名称" autocomplete="on"
                                    class="layui-input" />
                            </div>
                        </div>
            
                        <div class="layui-inline layui-form-item layui-form-text">
                            <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">施工区段</label>
                            <div class="layui-input-inline" style="padding-left: 30px">
                                <input type="text" name="section" lay-verify="required" placeholder="施工区段" autocomplete="on"
                                    class="layui-input" />
                            </div>
                        </div>
                    </div>
            
                    <div class="layui-form-item layui-form-text">
                        <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">施工日期</label>
                        <div class="layui-input-block">
                            <div class="layui-input-inline layui-input-wrap">
                                <div class="layui-input-prefix">
                                    <i class="layui-icon layui-icon-date"></i>
                                </div>
                                <input type="text" name="date" id="work-date" lay-verify="date" placeholder="yyyy-MM-dd"
                                    autocomplete="off" class="layui-input" />
                            </div>
                        </div>
                    </div>
            
                    <div class="layui-row layui-col-space16">
            
                        <div class="layui-form-item layui-form-text">
                            <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">现场情况</label>
                            <div class="layui-col-xs3">
                                <div class="layui-input-inline" style="padding-left: 30px">
                                    <input type="text" name="workPart" value="" lay-verify="required" placeholder="现场单位"
                                        autocomplete="on" class="layui-input" />
                                </div>
            
                            </div>
                            <div class="layui-col-xs3">
                                <div class="layui-input-group">
                                    <div class="layui-input-split layui-input-prefix">管理人员</div>
                                    <input type="number" lay-affix="number" placeholder="2" step="1" min="0" max="999"
                                        lay-precision="0" class="layui-input" name="administrators" />
                                </div>
                            </div>
            
                            <div class="layui-col-xs3">
                                <div class="layui-input-group">
                                    <div class="layui-input-split layui-input-prefix">施工人数</div>
                                    <input type="number" lay-affix="number" placeholder="" step="1" min="0" max="999" name="workers"
                                        lay-precision="0" class="layui-input" />
                                </div>
                            </div>
            
                            <div class="layui-row layui-col-space16">
            
                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px" id="getWeather">获取天气</label>
            
                                    <div class="layui-col-xs2">
                                        <div class="layui-input-inline" style="padding-left: 30px">
                                            <input type="text" name="weather" value="" lay-verify="required" placeholder="天气"
                                                autocomplete="on" class="layui-input" />
                                        </div>
            
                                    </div>
            
                                    <div class="layui-col-xs2">
                                        <div class="layui-input-inline">
                                            <input type="text" name="wind" value="" lay-verify="required" placeholder="东南风≤3级"
                                                autocomplete="on" class="layui-input" />
                                        </div>
                                    </div>
            
                                    <div class="layui-col-xs3">
                                        <div class="layui-input-group">
                                            <div class="layui-input-split layui-input-prefix">温度</div>
                                            <input type="number" lay-affix="number" placeholder="" step="1" min="-20" max="50"
                                                lay-precision="1" class="layui-input" name="temperature" />
                                            <div class="layui-input-split layui-input-suffix">℃</div>
                                        </div>
                                    </div>
            
                                    <div class="layui-col-xs3">
                                        <div class="layui-input-group">
                                            <div class="layui-input-split layui-input-prefix">湿度</div>
                                            <input type="number" lay-affix="number" placeholder="" step="1" min="0" max="100"
                                                lay-precision="0" class="layui-input" name="humidity" />
                                            <div class="layui-input-split layui-input-suffix">%</div>
                                        </div>
                                    </div>
            
                                </div>

                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">施工内容</label>
                                    <div class="layui-input-block">
                                        <textarea placeholder="请输入内容" class="layui-textarea" name="constructionContent" autocomplete="on"></textarea>
                                    </div>
                                </div>
            
                                <div class="layui-form-item layui-form-text">
                                  <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">完成情况</label>
                                  <div class="layui-input-block">
                                      <textarea placeholder="请输入内容" class="layui-textarea" name="finishContent" autocomplete="on"></textarea>
                                  </div>
                              </div>
            
                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">设计变更</label>
                                    <div class="layui-input-block">
                                        <textarea placeholder="请输入内容" class="layui-textarea" name="designChanges" autocomplete="on"></textarea>
                                    </div>
                                </div>
            
                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">技术交底</label>
                                    <div class="layui-input-block">
                                        <textarea placeholder="请输入内容" class="layui-textarea" name="technicalBriefing" autocomplete="on"></textarea>
                                    </div>
                                </div>
            
                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">质量情况</label>
                                    <div class="layui-input-block">
                                        <textarea placeholder="请输入内容" class="layui-textarea" name="quality" autocomplete="on"></textarea>
                                    </div>
                                </div>
            
                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">安全情况</label>
                                    <div class="layui-input-block">
                                        <textarea placeholder="请输入内容" class="layui-textarea" name="security" autocomplete="on"></textarea>
                                    </div>
                                </div>
            
                                <div class="layui-form-item layui-form-text">
                                    <label class="layui-form-label" style="padding-left: 0px; padding-right: 0px">其他问题</label>
                                    <div class="layui-input-block">
                                        <textarea placeholder="请输入内容" class="layui-textarea" name="other" autocomplete="on"></textarea>
                                    </div>
                                </div>
                            </div>
                        </div>
            
                        <div class="layui-form-item" style="text-align: center">
                          <button class="layui-btn" lay-submit lay-filter="demo-val">提交</button>
                          <button type="reset" class="layui-btn layui-btn-primary">重置</button>
                        </div>
                        </form>
                        `,
                    success: function () {
                        layui.use(function () {
                            var form = layui.form;
                            form.render();
                            layui.laydate.render({
                                elem: '#work-date'
                            });
                            layui.$('#getWeather').on('click', function () {
                                var data = form.val('demo-val-filter');
                                alert('自动增加天气信息暂不可用');
                            });
                            form.on('submit(demo-val)', function (data) {
                                var field = data.field;
                                let results = field;
                                const bodys =
                                    '{' +
                                    '"weather": "' + results.weather + '",' +
                                    '"temperature": "' + results.temperature + '℃",' +
                                    '"humidity": "' + results.humidity + '%",' +
                                    '"windDirection": "' + results.wind + '",' +
                                    '"progressCompletion": "' + results.finishContent.replace(/\n/g, '') + '",' +
                                    '"designChanges": "' + results.designChanges.replace(/\n/g, '') + '",' +
                                    '"technicalDisclosure": "' + results.technicalBriefing.replace(/\n/g, '') + '",' +
                                    '"qualityCompletion": "' + results.quality.replace(/\n/g, '') + '",' +
                                    '"safeCompletion": "' + results.security.replace(/\n/g, '') + '",' +
                                    '"others": "' + results.other.replace(/\n/g, '') + '",' +
                                    '"dateFilled": "' + results.date + '",' +
                                    '"branchId": "50210",' +
                                    '"projectId": "1660970600237248514",' +
                                    '"projectName": "' + results.project.replace(/\n/g, '') + '",' +
                                    '"sectionDetailId": "17096338600501387359",' +
                                    '"sectionDetailId_dictText": "' + results.section.replace(/\n/g, '') + '",' +
                                    '"projectConstructionLogRytrList": [' +
                                    '{' +
                                    '"id": "1773855949204987906",' +
                                    '"fieldUnit": "' + results.workPart.replace(/\n/g, '') + '",' +
                                    '"managers": "' + results.administrators + '",' +
                                    '"workers": "' + results.workers + '",' +
                                    '"content": "' + results.constructionContent.replace(/\n/g, '') + '"' +
                                    '}' +
                                    '],' +
                                    '"projectConstructionLogSbtrList": [' +
                                    '{' +
                                    '"id": "17120471870590532499",' +
                                    '"mechanical": "塔式起重机",' +
                                    '"amount": ""' +
                                    '},' +
                                    '{' +
                                    '"id": "17120471870591606638",' +
                                    '"mechanical": "施工升降机",' +
                                    '"amount": ""' +
                                    '},' +
                                    '{' +
                                    '"id": "17120471870592975072",' +
                                    '"mechanical": "汽车吊",' +
                                    '"amount": ""' +
                                    '},' +
                                    '{' +
                                    '"id": "17120471870593953005",' +
                                    '"mechanical": "挖掘机",' +
                                    '"amount": ""' +
                                    '},' +
                                    '{' +
                                    '"id": "17120471870594270756",' +
                                    '"mechanical": "渣土车",' +
                                    '"amount": ""' +
                                    '},' +
                                    '{' +
                                    '"id": "17120471870595276041",' +
                                    '"mechanical": "叉车",' +
                                    '"amount": ""' +
                                    '},' +
                                    '{' +
                                    '"id": "17120471870596799796",' +
                                    '"mechanical": "登高车",' +
                                    '"amount": ""' +
                                    '}' +
                                    '],' +
                                    '"projectConstructionLogJcysList": [' +
                                    '{' +
                                    '"id": "17120471870910675884",' +
                                    '"name": "",' +
                                    '"specification": "",' +
                                    '"unit": "",' +
                                    '"amount": ""' +
                                    '}' +
                                    '],' +
                                    '"status": "1"' +
                                    '}';
                                fetch("https://www.cscec83.cn/jeecg-boot/project/projectConstructionLog/add", {
                                    "headers": {
                                        "accept": "application/json, text/plain, */*",
                                        "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                                        "content-type": "application/json;charset=UTF-8",
                                        "x-access-token": GM_getValue('xAccessToken'),
                                    },
                                    "body": bodys.toString(),
                                    "method": "POST",
                                })
                                    .then(response => {
                                        return response.json()
                                    })
                                    .then(data => {
                                        fetch("https://www.cscec83.cn/jeecg-boot/process/extActProcess/startMutilProcess", {
                                            "headers": {
                                                "accept": "application/json, text/plain, */*",
                                                "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                                                "content-type": "application/json;charset=UTF-8",
                                                "x-access-token": GM_getValue('xAccessToken')
                                            },
                                            "body": "{\"flowCode\":\"dev_project_construction_log_001\",\"id\":\"" + data.result + "\",\"formUrl\":\"Project/ConstructionLog/ConstructionLog/ConstructionLogProgress\",\"formUrlMobile\":\"Project/ConstructionLog/ConstructionLog/ConstructionLogProgress\"}",
                                            "method": "POST",
                                        });
                                    })
                                    .catch(error => {
                                        console.log(error);
                                    })
                                    ;
                                layer.close(index3);
                                return false; // 阻止默认 form 跳转
                            });
                        })
                    }
                });
            } else {
                failVerify();
                waitToast(titleMsgAlert, innerMsgAlert, a);
            }
        });
    }

    function getConstructionDairy(
        xAccessToken,
        pageNo, // 页数
        time, // 请求时间戳
        nickName, // 姓名
        pageSize = 100, // 默认值
        status = 1, // 默认1
        column = 'createTime', // 默认值
        order = 'desc', // 默认值
        field = 'id,,,projectName,branchId_dictText,dateFilled,sectionDetailId_dictText,realname,createTime,bpmStatus_dictText,action', // 默认值
    ) {
        fetch(`https://www.cscec83.cn/jeecg-boot/project/projectConstructionLog/list?status=${status}&_t=${time}&realname=${nickName}&column=${column}&order=${order}&field=${field}&pageNo=${pageNo}&pageSize=${pageSize}`, {
            "headers": {
                "x-access-token": xAccessToken,
            },
            "method": "GET",
        })
            .then(response => {
                if (!response.ok) {
                    throw new Error("getConstructionDairy response was not ok");
                }
                return response.json();
            })
            .then(data => {
                if (data.code === 200 && data.result.records.length > 0) {
                    let allProjectName = [...new Set(data.result.records.map(obj => obj.projectName))];
                    if (allProjectName.length > 0) {
                        let index = 0; // 取出第几个项目
                        let ids = [];
                        let dairyIds = data.result.records.filter(obj => obj.projectName === allProjectName[index] && obj.bpmStatus_dictText == '已完成');
                        dairyIds.forEach(d => {
                            ids.push(d.id);
                        });
                        let promises = [];
                        // 构建 fetch 请求 Promise 并将其推入数组
                        ids.forEach(id => {
                            let promise = fetch(`https://www.cscec83.cn/jeecg-boot/project/projectConstructionLog/queryById?id=${id}&_t=${new Date().getTime()}`, {
                                "headers": {
                                    "x-access-token": xAccessToken,
                                },
                                "method": "GET",
                            })
                                .then(response => response.json())
                                .then(diaryData => {
                                    switch (diaryData.code) {
                                        case 200:
                                            let rowData = [
                                                diaryData.result.projectConstructionLogPage.projectName, // 项目名称
                                                diaryData.result.dateStr, // 日期
                                                diaryData.result.projectConstructionLogPage.weather, // 天气
                                                diaryData.result.projectConstructionLogPage.temperature, // 温度
                                                diaryData.result.projectConstructionLogPage.humidity, // 湿度
                                                diaryData.result.projectConstructionLogPage.windDirection, // 风向
                                                diaryData.result.projectConstructionLogPage.sectionDetailId_dictText.replace(/\n/g, ''), // 施工区段
                                                diaryData.result.projectConstructionLogPage.progressCompletion.replace(/\n/g, ''), // 进度完成情况
                                                diaryData.result.projectConstructionLogPage.designChanges.replace(/\n/g, ''), // 设计变更
                                                diaryData.result.projectConstructionLogPage.technicalDisclosure.replace(/\n/g, ''), // 技术交底
                                                diaryData.result.projectConstructionLogPage.qualityCompletion.replace(/\n/g, ''), // 质量情况
                                                diaryData.result.projectConstructionLogPage.safeCompletion.replace(/\n/g, ''), // 安全
                                                diaryData.result.projectConstructionLogPage.others.replace(/\n/g, ''), // 其他
                                                diaryData.result.approvers, // 审批人
                                            ];
                                            // 添加现场人员投入
                                            let personnelInput = '';
                                            try {
                                                personnelInput = diaryData.result.projectConstructionLogPage.projectConstructionLogRytrList.map(obj => `${obj.fieldUnit}:管理人员数量:${obj.managers};作业人员数量:${obj.workers};工作内容:${obj.content.replace(/\n/g, ';')}`).join(";");
                                            } catch (error) { }
                                            rowData.push(personnelInput);
                                            // 添加现场设备投入
                                            let equipments = '';
                                            try {
                                                equipments = diaryData.result.projectConstructionLogPage.projectConstructionLogSbtrListb.map(obj => obj.mechanical + obj.amount).join(";").replace(/\n/g, '');
                                            } catch (error) { }
                                            rowData.push(equipments);
                                            // 添加材料进场验收
                                            let material = '';
                                            try {
                                                material = diaryData.result.projectConstructionLogPage.projectConstructionLogJcysList.map(obj => `${obj.name} ${obj.specification};${obj.amount} ${obj.unit}:验收${acceptance};${sampling}`).join(";").replace(/\n/g, '');
                                            } catch (error) { }
                                            // console.log(personnelInput);
                                            rowData.push(material);
                                            // 将该行数据推入 excelOutput_a 数组
                                            excelOutput_a.push(rowData);
                                            break;
                                        default:
                                            Qmsg.error('返回码错误');
                                            break;
                                    }
                                })
                                .catch(error => {
                                    Qmsg.error('请求施工日志错误');
                                });
                            promises.push(promise); // 将每个 fetch 请求的 Promise 推入数组
                        });
                        // 等待所有的 fetch 请求完成
                        Promise.all(promises)
                            .then(() => {
                                createExcelAndDownload(`施工日志 ${new Date()}`, excelOutput_a);
                                Qmsg.success('导出成功');
                            });
                    } else {
                        Qmsg.error('没有项目的施工日志');
                    }
                } else {
                    Qmsg.error('没有写过施工日志或者返回值错误')
                }
            })
            .catch(error => {
                Qmsg.error('请登陆后在八三管理平台使用此功能')
            });
    }

    function createExcelAndDownload(fileName, excelOutput_a) {
        let excelContent = '\uFEFF'; // 添加 BOM
        // 将数据转换为逗号分隔的格式
        excelOutput_a.forEach(row => {
            excelContent += row.join(",") + "\n";
        });
        const blob = new Blob([excelContent], { type: "data:text/csv;charset=utf-8" });
        const link = document.createElement("a");
        link.href = URL.createObjectURL(blob);
        link.download = `${fileName}.csv`;
        document.body.appendChild(link);
        link.click();
        document.body.removeChild(link);
        URL.revokeObjectURL(link.href);
    }

    function oneClickAnswer(index) {
        let targetUrl = 'https://learn.cscec83.cn/prod-api/exam/practice/paper/selectPracticeByClassId?practiceType=' + index;
        fetch(targetUrl, {
            "headers": {
                "accept": "application/json, text/plain, */*",
                "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                "authorization": GM_getValue('Authorization'),
            },
            "method": "GET",
        })
            .then(response => {
                if (!response.ok) {
                    throw new Error("practice1 response was not ok");
                }
                return response.json();
            })
            .then(data => {
                let QAData = JSON.stringify(handelQAData(data.data), null, 2);
                fetch("https://learn.cscec83.cn/prod-api/exam/practice/paper/commitPractice", {
                    "headers": {
                        "accept": "application/json, text/plain, */*",
                        "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                        "authorization": GM_getValue('Authorization'),
                        "content-type": "application/json",
                    },
                    "body": QAData,
                    "method": "POST",
                })
                    .then(response => {
                        if (!response.ok) {
                            throw new Error("practice1 response was not ok");
                        }
                        return response.json();
                    })
                    .then(QAResponse => {
                        if (QAResponse.code == 200) {
                            let reachedUpperLimit = '';
                            switch (QAResponse.data.reachedUpperLimit) {
                                case 0:
                                    reachedUpperLimit = `此项积分未满`;
                                    break;
                                case 1:
                                    reachedUpperLimit = `此项积分已满`;
                                    break;
                                default:
                                    reachedUpperLimit = '';
                                    break;
                            }
                            Qmsg.success(`已完成,模拟用时 ${QAResponse.data.time}`)
                        } else if (QAResponse.code == 500) {
                            Qmsg.error(QAResponse.msg);
                        }
                        else {
                            Qmsg.error('错误' + QAResponse.msg);
                        }
                    })
            })
            .catch(error => {
                Qmsg.error("获取题目失败,进入或重新进入学企来后使用");
                console.error("获取题目失败:", error);
            });
    }

    function handelQAData(data) {
        let processedData = {
            paperId: data.paperId,
            practiceType: data.practiceType,
            practicePaperName: data.practicePaperName,
            questionNumber: data.questionNumber,
            startTime: new Date().getTime() - 90 * 1000 + ((Math.floor(Math.random() * (20 - (-20)) + 1)) - 20) * 1000,
            testPaperTopics: []
        };
        // 遍历题目列表
        data.testPaperTopics.forEach(topic => {
            let processedTopic = {
                paperId: topic.paperId,
                questionId: topic.questionId,
                deptName: topic.deptName,
                topicName: topic.topicName,
                questionType: topic.questionType,
                topicType: topic.topicType,
                topicTypeName: topic.topicTypeName,
                topicAnswer: topic.topicAnswer,
                source: topic.source,
                topicSource: topic.topicSource,
                isTrue: 1,
                optionId: topic.optionId,
                studentOptionId: topic.optionId,
                studentOptionIds: [],
                optionList: topic.optionList.map(option => {
                    return {
                        optionId: option.optionId,
                        answerId: option.optionId,
                        optionContent: option.optionContent,
                        sort: option.sort,
                        optionLabel: option.optionLabel,
                        userCorrectAnswer: ""
                    };
                }),
                hierarchyId: topic.hierarchyId,
                relationId: topic.relationId,
                relationName: topic.relationName
            };
            // 检查题目类型,正确答案从optionList中选出
            let correctAnswerIndex = [];
            switch (topic.questionType) {
                // 单选题
                case 1:
                    for (let i = 0; i < topic.optionList.length; i++) {
                        if (topic.optionId.includes(topic.optionList[i].optionId)) {
                            correctAnswerIndex = i;
                        }
                    }
                    processedTopic.answerIndex = correctAnswerIndex;
                    break;
                // 多选题
                case 2:
                    for (let i = 0; i < topic.optionList.length; i++) {
                        if (topic.optionId.includes(topic.optionList[i].optionId)) {
                            correctAnswerIndex.push(i);
                        }
                    }
                    if (correctAnswerIndex.length !== 0) {
                        processedTopic.answerIndex = correctAnswerIndex;
                        processedTopic.studentOptionIds = topic.optionId.split(",");
                    } else {
                        processedTopic.answerIndex = "未知";
                    }
                    break;
                // 判断题
                case 3:
                    for (let i = 0; i < topic.optionList.length; i++) {
                        if (topic.optionId.includes(topic.optionList[i].optionId)) {
                            correctAnswerIndex = topic.optionList[i].optionContent;
                        }
                    }
                    processedTopic.answerIndex = correctAnswerIndex;
                    break;
            }
            processedData.testPaperTopics.push(processedTopic);
        }
        );
        return processedData;
    }

    // 通用函数,同步等待1秒
    async function sleep(time) {
        return new Promise((resolve, reject) => {
            setTimeout(() => {
                resolve()
            }, time * 1000)
        })
    }

    function hello(title, version) {
        console.log(
            `%c ${title} %cV ${version} `,
            'padding: 2px 1px; border-radius: 3px 0 0 3px; color: #fff; background: #606060; font-weight: bold;',
            'padding: 2px 1px; border-radius: 0 3px 3px 0; color: #fff; background: #42c02e; font-weight: bold;',
        );
    }

    function layuiMenu() {
        var toolbox_html =
            `
                <div style="margin: 6px 12px;">
                    <div style="height:26px;font-size: 18px;" ><b>异常修复</b></div>
                    <button type="button" class="layui-btn layui-bg-blue toolbox_btn" id="resetQABank_btn_toolbox" style="margin: 9px 0px;">重置题库</button>
                    <hr>
                </div>
                <div style="margin: 6px 12px;">
                    <div style="height:26px;font-size: 18px;" ><b>学企来相关</b></div>
                    <button type="button" class="layui-btn layui-bg-blue" id="practice1_btn_toolbox" style="margin: 9px 0px;">每日一练</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="practice2_btn_toolbox" style="margin: 9px 0px;">闯关练习</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="iWantStudy_btn_toolbox" style="margin: 9px 0px;">课程学习</button>
                    <button type="button" class="layui-btn layui-bg-blue toolbox_btn" id="forceExam_btn_toolbox" style="margin: 9px 0px;">强制考试</button>
                    <button type="button" class="layui-btn layui-bg-blue toolbox_btn" id="QAStar_forceExam_btn_toolbox" style="margin: 9px 0px;">问卷星无限答题</button>
                    <hr>
                </div>
                <div style="margin: 6px 12px;">
                    <div style="height:26px;font-size: 18px;" ><b>信息发布</b></div>
                    <button type="button" class="layui-btn layui-bg-blue" id="yuqueUrl_btn_toolbox" style="margin: 9px 0px;">语雀文档</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="openJSUrl_btn_toolbox" style="margin: 9px 0px;">脚本更新</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="contactMe_btn_toolbox" style="margin: 9px 0px;">联系我(bilibili)</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="feedback_btn_toolbox" style="margin: 9px 0px;">反馈问题</button>
                    <hr>
                </div>
                <div style="margin: 6px 12px;">
                    <div style="height:26px;font-size: 18px;" ><b>测试功能</b></div>
                    <button type="button" class="layui-btn layui-bg-blue" id="option1_btn_toolbox" style="margin: 9px 0px;">强制聊天</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="option2_btn_toolbox" style="margin: 9px 0px;">批量导出施工日志</button>
                    <button type="button" class="layui-btn layui-bg-blue" id="option3_btn_toolbox" style="margin: 9px 0px;">强制提交施工日志</button>
                    <hr>
                </div>

                <div style="margin: 16px;">

                    <div class="layui-timeline-item">
                    <i class="layui-icon layui-timeline-axis"></i>
                    <div class="layui-timeline-content layui-text">
                        <h3 class="layui-timeline-title">${visionNum}</h3>
                        <p style="font-weight: bold;"><i class="layui-icon"> </i>更新细则</p>
                        <ul>
                            <li>新增 133工作体系题库</li>
                            <li>新增 基础设施体系题库</li>
                            <li>新增 强制提交施工日志功能</li>
                            <li>修复部分问题</li>
                            <li>修复部分试题</li>
                        </ul>
                    </div>
                    </div>  

                    <div class="layui-timeline-item">
                    <i class="layui-icon layui-timeline-axis"></i>
                    <div class="layui-timeline-content layui-text">
                        <h3 class="layui-timeline-title">2024 年 3 月</h3>
                        <p style="font-weight: bold;"><i class="layui-icon"> </i>更新概览</p>
                        <ul>
                            <li>新增导出施工日志功能(1.14.16.20240329)</li>
                            <li>增加清欠工作专题考试试题(1.14.14.20240327)</li>
                            <li>对用户信息进行加密(1.14.12.20240327)</li>
                            <li>新增语雀文档功能(1.14.10.20240326)</li>
                            <li>新增联系我功能(1.14.10.20240326)</li>
                            <li>新增反馈功能(1.14.10.20240326)</li>
                            <li>新增一键答题功能(1.14.4.20240326)</li>
                            <li>新增一键闯关功能(1.14.4.20240326)</li>
                            <li>新增自动完成每周课程(1.14.3.20240325)</li>
                            <li>重制千回百转功能(1.14.1.20240325)</li>
                            <li>新增更新概览(1.14.1.20240325)</li>
                            <li>增加 页面内切换答题功能(1.13.3.20240323)</li>
                            <li>增加 集团133文化体系试题库(1.12.22.20240319)</li>
                            <li>增加 题库重置功能(1.12.19.20240318)</li>
                            <li>增加 增加一键复制题目功能(1.12.25.20240322)</li>

                        </ul>
                    </div>
                    </div>  
                    
                    <div class="layui-timeline-item">
                    <i class="layui-icon layui-timeline-axis"></i>
                    <div class="layui-timeline-content layui-text">
                        <h3 class="layui-timeline-title">2024 年 2 月</h3>
                        <p style="font-weight: bold;"><i class="layui-icon"> </i>更新概览</p>
                        <ul>
                            <li>增加 增加自动签到功能(1.12.0.20240222)</li>
                            <li>增加 增加今日积分统计功能(不含考试)(1.12.0.20240222)</li>
                            <li>修改 全部题库与答题逻辑,使用新的题库格式以支持作答题目相同但选项不同的题(1.11.1.20240219)</li>
                            <li>删除 对旧版学企来业的支持与全部代码(1.11.1.20240219)</li>
                            <li>增加 增加了版本更新提醒(1.10.12-20240211)</li>
                            <li>增加 平台自动去水印功能(1.10.7-20240202)</li>
                            <li>增加 点击按钮 9 反馈问题(1.10.0-20240201)</li>
                        </ul>
                    </div>
                    </div>

                    <div class="layui-timeline-item">
                        <i class="layui-icon layui-timeline-axis"></i>
                        <div class="layui-timeline-content layui-text">
                            <h3 class="layui-timeline-title">2024 年 1 月</h3>
                            <p style="font-weight: bold;"><i class="layui-icon"> </i>更新概览</p>
                            <ul>
                                <li>增加 手机做题考试功能(1.8.0-20240126)</li>
                                <li>增加 窗口显隐功能(1.8.0-20240126)</li>
                                <li>增加 强制考试与无限考试功能(1.7.0-20240124)</li>
                                <li>增加 考试任意切屏功能(1.6.18-20240123)</li>
                                <li>增加 随机更换背景大图(1.6.17-20240122)</li>
                                <li>增加 新版学企来考试与自动考试功能(1.6.0-20240107)</li>
                            </ul>
                        </div>
                    </div>

                    <div class="layui-timeline-item">
                        <i class="layui-icon layui-timeline-axis"></i>
                        <div class="layui-timeline-content layui-text">
                            <h3 class="layui-timeline-title">1.0 20240101</h3>
                            <p style="font-weight: bold;"><i class="layui-icon"> </i>诞生了</p>
                        </div>
                    </div>

                </div>
                    `
        return toolbox_html;

    }

    function getAddress(urls) {
        let regex = /lng=([\d.]+)&lat=([\d.]+)&name=([^&]+)/;
        let match = urls.match(regex);
        if (match) {
            let texts = '[{"mAddress":"' + decodeURIComponent(match[3]) + '","mLatitude":' + match[2] + ',"mLongitude":' + match[1] + '}]';
            GM.setClipboard(texts, "text");
            console.log(texts);
            Qmsg.success("已复制相关信息。");
        }
    }

    async function initQABank() {
        try {
            radioQA = GM_getValue('radioQA');
            multipleQA = GM_getValue('multipleQA');
            judgeQA = GM_getValue('judgeQA');
            if (radioQA.length !== 14570 && multipleQA.length !== 6346 && judgeQA.length !== 4189) {
                resetQABank();
            } else {
                Qmsg.success(`正常读取全题库,单选题:${radioQA.length + 1};多选题:${multipleQA.length + 1};判断题:${judgeQA.length + 1}`);
            }
        } catch (error) {
            console.log(error);
            Qmsg.error(`题库初始化发生意外错误`);
        }
    }

    async function resetQABank() {
        radioQA = [...radioQuestionBank1, ...radioQuestionBank2];
        radioQA = radioQA.map(item => {
            return {
                ...item,
                question: trimText(item.question),
                options: item.options.map(option => trimText(option))
            };
        });
        multipleQA = multipleQuestionBank.map(item => {
            return {
                ...item,
                question: trimText(item.question),
                options: item.options.map(option => trimText(option))
            };
        });
        judgeQA = judgeQuestionBank.map(item => {
            return {
                ...item,
                question: trimText(item.question),
                options: item.options.map(option => trimText(option))
            };
        });
        try {
            GM_setValue('radioQA', radioQA);
            GM_setValue('multipleQA', multipleQA);
            GM_setValue('judgeQA', judgeQA);
            Qmsg.success(`全题库共 单选题:${radioQA.length + 1};多选题:${multipleQA.length + 1};判断题:${judgeQA.length + 1} 已写入`);
        } catch {
            Qmsg.error(`全题库写入失败`);
        }
    }

    function forceExam() {
        var originalSend = XMLHttpRequest.prototype.send;
        XMLHttpRequest.prototype.send = function () {
            var self = this;
            var originalOnreadystatechange = this.onreadystatechange;
            this.onreadystatechange = function () {
                if (self.responseURL.match(/getInfoCanPaperNum\?paperId=.+/g)) {
                    Object.defineProperty(self, 'response', {
                        value: { "code": 200, "msg": null, "data": 999 },
                        writable: true,
                        enumerable: true,
                        configurable: true
                    });
                    Object.defineProperty(self, 'responseText', {
                        value: "{\"code\":200,\"msg\":null,\"data\":999}",
                        writable: true,
                        enumerable: true,
                        configurable: true
                    });
                    // 调用原有的onreadystatechange回调
                    if (originalOnreadystatechange) {
                        originalOnreadystatechange.call(self);
                    }
                }
            };
            // 调用原始的send方法
            originalSend.apply(this, arguments);
        };
        Qmsg.success("强制考试,启动!");
        systemAlert('强制考试,启动!', '考!随便考!', 8000, console.log('点击无限的通知'));
    }

    function getWords() {
        fetch("https://api.songzixian.com/api/daily-poem?dataSource=LOCAL_DAILY_POEM", {
            method: "GET",
        })
            .then(response => {
                if (!response.ok) {
                    throw new Error("Network response was not ok");
                }
                return response.json();
            })
            .then(data => {
                if (data.code === 200) {
                    document.querySelector("#infoText1").innerText = data.data.quotes;
                    document.querySelector("#infoText2").innerText = "——" + data.data.title + ' ' + data.data.dynasty + ' ' + data.data.author;
                } else {
                    document.querySelector("#infoText1").innerText = "今日无事";
                }
            })
            .catch(error => {
                Qmsg.error("获取每日一言失败");
                document.querySelector("#infoText1").innerText = "今日无事";
                console.error("Fetch error:", error);
            });
    }

    function answerQAStarExam() {
        let xuanze = [...radioQA, ...judgeQA];
        let duoxuan = multipleQA;
        try {
            if (verifyUrl() === 4) {
                let QAStarQuestion = document.querySelectorAll('.topichtml');
                if (QAStarQuestion.length === 0) {
                    QAStarQuestion = document.querySelectorAll('.topic__type-title');
                }
                for (let j = 0; j < QAStarQuestion.length; j++) {
                    let questionFind = trimText(QAStarQuestion[j].innerText);
                    try { questionFind = questionFind.match(/.+?(?=【.*】$)/)[0] } catch { };
                    let questionIndex = '';
                    switch (QAStarQuestion[j].childNodes.length) {
                        case 1:
                            questionIndex = xuanze.findIndex(function (item) {
                                return item.question === questionFind;
                            });
                            if (questionIndex > -1) {
                                let answerArray = [];
                                switch (xuanze[questionIndex].type) {
                                    case '判断题':
                                        switch (xuanze[questionIndex].answer) {
                                            case '对':
                                                answerArray = [0];
                                                break;
                                            case '错':
                                                answerArray = [1];
                                                break;
                                            default:
                                                break;
                                        }
                                        break;
                                    default:
                                        answerArray = convertAnswerArrayToDigitArray(questionIndex, xuanze);
                                        break;
                                }
                                for (let i = 0; i < answerArray.length; i++) {
                                    (function (i) {
                                        requestAnimationFrame(function () {
                                            setTimeout(() => {
                                                try {
                                                    QAStarQuestion[j].nextElementSibling.childNodes[answerArray[i]].click();
                                                } catch (error) {
                                                    try {
                                                        QAStarQuestion[j].parentNode.nextSibling.childNodes[answerArray[i]].click();
                                                    } catch (error) { }
                                                }
                                            }, 150);
                                        });
                                    })(i);
                                }
                            } else {
                                console.log(QAStarQuestion[j] + "非多选题未找到答案", "题库无此题,请及时记录维护题库或 Ctrl+S 保存页面");
                                continue;
                            }
                            break;
                        case 2:
                            questionIndex = duoxuan.findIndex(function (item) {
                                return item.question === questionFind;
                            });
                            if (questionIndex > -1) {
                                let answerArray = convertAnswerArrayToDigitArray(questionIndex, duoxuan);
                                for (let i = 0; i < answerArray.length; i++) {
                                    (function (i) {
                                        requestAnimationFrame(function () {
                                            setTimeout(() => {
                                                try {
                                                    QAStarQuestion[j].nextElementSibling.childNodes[answerArray[i]].click();
                                                } catch (error) {
                                                    try {
                                                        QAStarQuestion[j].parentNode.nextSibling.childNodes[answerArray[i]].click();
                                                    } catch (error) { }
                                                }
                                            }, 150);
                                        });
                                    })(i);
                                }
                            } else {
                                console.log(QAStarQuestion[j] + "多选题未找到答案", "题库无此题,请及时记录维护题库或 Ctrl+S 保存页面");
                                continue;
                            }
                            break;
                        default:
                            break;
                    }
                }
            } else {
                Qmsg.error("此页面未配置本功能,如功能配置错误请联系我");
            }
        } catch (error) {
            Qmsg.error("exam函数未完全适配导致的问题,请 Ctrl+S 保存页面并联系我");
        }
    }

    function verifyUrl() {
        currentUrl = window.location.href;
        // 1 新版学企来考试
        if (currentUrl.includes('learn.cscec83.cn/xql_exam/examItem')) {
            return 1;
            // 2 答题结算
        } else if (currentUrl.includes('learn.cscec83.cn/xql_exam/dayItem/dayResult')) {
            return 2;
            // 4 问卷星
        } else if (currentUrl.includes('wjx.top/') || currentUrl.includes('wjx.cn/')) {
            return 4;
            // 5 公司登录界面
        } else if (currentUrl.includes('www.cscec83.cn/user/login')) {
            return 5;
            // 6 新版学企来练习
        } else if (currentUrl.includes('learn.cscec83.cn/xql_exam/dayItem')) {
            return 6;
            // 7 高德定位
        } else if (currentUrl.includes("www.amap.com/regeo") && currentUrl.includes("lng=") && currentUrl.includes("lat=")) {
            return 7;
            // 8 八三主页
        } else if (currentUrl.includes("www.cscec83.cn/dashboard/analysis")) {
            return 8;
        } else {
            return false;
        }
    }

    function getAnswer(questionAnswerBankIndex, questionsArray) {
        return questionsArray[questionAnswerBankIndex].answer;
    }

    function convertAnswerToArray(questionAnswerBankIndex, questionsArray) {
        let answerArray = getAnswer(questionAnswerBankIndex, questionsArray).match(/[A-Za-z]/g).map(function (val) {
            return val.toLowerCase();
        });
        return answerArray;
    }

    // 转换字母答案为数字并生成数组
    function convertAnswerArrayToDigitArray(questionIndex, questionsArray) {
        let answerArray = convertAnswerToArray(questionIndex, questionsArray).map(char => char.charCodeAt(0) - 96 - 1); // 多减一个 1 好点击
        return answerArray;
    }

    // 点击页面具有某个文本的span
    function clickSpanContainingText(text) {
        var spans = document.getElementsByTagName('span');
        for (var i = 0; i < spans.length; i++) {
            if (spans[i].innerText === text) {
                spans[i].click();
                break;
            }
        }
    }

    function reviseRem() {
        var root = document.documentElement;
        var currentSize = parseFloat(window.getComputedStyle(root).fontSize);
        if (currentSize !== rootFontSize) {
            // root.style.fontSize = `${currentSize * 4}px`;
            root.style.fontSize = rootFontSize + "px";
        }
        if (document.querySelector('.todo-title') && document.querySelector('.todo-title').innerText == '公司待办') {
            root.style.fontSize = 46.6667 + "px";
            if (cscecAdminCount) {
                try {
                    document.querySelector('.option6').click();
                    cscecAdminCount = false;
                } catch (error) { }
            }
        }
    }

    function webPageWatchUrl(watchCallback) {
        watchCallback();
        currentUrl = window.location.href;
        setInterval(function () {
            if (currentUrl !== window.location.href) {
                currentUrl = window.location.href;
                watchCallback();
            }
        }, monitorGap);
    }

    function addButtons() {
        setInterval(function () {
            switch (verifyUrl()) {
                case 1:
                case 2:
                case 6:
                    addCopyButton();
                    addPractice1Button();
                    addPractice2Button();
                    addBackButton();
                    break;
                default:
                    break;
            }
        }, 1000);
    }

    function addCopyButton() {
        try {
            if (!document.querySelector('#copy-Button')) {
                let copyButton = document.createElement('button');
                copyButton.id = 'copy-Button';
                copyButton.textContent = '复制题目';
                copyButton.classList.add('add-Button');
                let parentElement = document.querySelectorAll(".size-16")[0];
                parentElement.appendChild(copyButton);
                copyButton.addEventListener("click", function (event) {
                    let questionElement = document.querySelectorAll('.el-card__body')[1].childNodes[2];
                    let question = questionElement ? questionElement.innerText : '';
                    let options = getOptions();
                    let QAtype = getQATypeString();
                    let text =
                        `{
                        question: '${trimText(question)}',
                        options: ${options},
                        answer: '',
                        type: '${QAtype}'
                    }`;
                    GM.setClipboard(text);
                    Qmsg.success('复制成功');
                });
            }
        } catch (error) { }
    }

    function addPractice1Button() {
        try {
            if (!document.querySelector('#practice1-Button')) {
                let practice1Button = document.createElement('button');
                practice1Button.id = 'practice1-Button';
                practice1Button.textContent = '每日一练';
                practice1Button.classList.add('add-Button');
                let parentElement = document.querySelectorAll(".el-page-header__content")[0];
                parentElement.appendChild(practice1Button);
                practice1Button.addEventListener("click", function (event) {
                    window.open('https://learn.cscec83.cn/exam/dayItem/?type=1', '_self');
                });
            }
        } catch (error) { }
    }

    function addPractice2Button() {
        try {
            if (!document.querySelector('#practice2-Button')) {
                let practice2Button = document.createElement('button');
                practice2Button.id = 'practice2-Button';
                practice2Button.textContent = '闯关练习';
                practice2Button.classList.add('add-Button');
                let parentElement = document.querySelectorAll(".el-page-header__content")[0];
                parentElement.appendChild(practice2Button);
                practice2Button.addEventListener("click", function (event) {
                    window.open('https://learn.cscec83.cn/exam/dayItem/?type=2', '_self');
                });
            }
        } catch (error) { }
    }

    function addBackButton() {
        try {
            if (!document.querySelector('#addBack-Button')) {
                let addBackButton = document.createElement('button');
                addBackButton.id = 'addBack-Button';
                addBackButton.textContent = '返回首页';
                addBackButton.classList.add('add-Button');
                let parentElement = document.querySelectorAll(".el-page-header__content")[0];
                parentElement.appendChild(addBackButton);
                addBackButton.addEventListener("click", function (event) {
                    window.open('https://learn.cscec83.cn/', '_self');
                });
            }
        } catch (error) { }
    }

    function setRem() {
        setInterval(function () {
            reviseRem();
        }, 1000);
    }

    function getOptions() {
        let options = '[';
        switch (getQAType()) {
            case 1:
            case 3:
                document.querySelectorAll(".el-radio__label").forEach(e => {
                    options += "'" + trimText(e.innerText.replace(/[A-J]\. /, '')) + "',";
                });
                break;
            case 2:
                document.querySelectorAll(".el-checkbox-group")[0].childNodes.forEach(e => {
                    options += "'" + trimText(e.innerText.replace(/[A-J]\. /, '')) + "',";
                });
                break;
            default:
                break;
        }
        options += ']';
        return options.replace(",]", ']');
    }

    function getQATypeString() {
        switch (getQAType()) {
            case 1:
                return '单选题';
            case 2:
                return '多选题';
            case 3:
                return '判断题';
            default:
                return '未知题目';
        }
    }

    function urlOperate() {
        switch (verifyUrl()) {
            case 4:
                try {
                    // 解除复制粘贴限制
                    setTimeout(function () {
                        $(".textCont,input,textarea").off();
                    }, 2000)
                    $(".textCont,input,textarea").off(); // 既不生效,再来一次又何妨
                    document.oncontextmenu = function () { return true; };
                    document.onselectstart = function () { return true; };
                    $("body").css("user-select", "text");
                    syncManyinput();
                } catch (error) {
                    Qmsg.error("破解复制失败");
                }
                break;
            case 5:
                try {
                    document.documentElement.style.fontSize = 46.6667 + "px";
                    GM_addStyle(`
                                .bgi[data-v-556a153e] {
                                    background:url(https://bing.img.run/rand_uhd.php) no-repeat;
                                    background-size:100% 100%;
                                }
                            `);
                } catch (error) { }
                break;
            case 8:
                document.documentElement.style.fontSize = 46.6667 + "px";
                GM_addStyle(`
                        .new-box .new-col .new-value[data-v-616703f6] {
                            height:0.1rem;
                            line-height:0.5rem;
                            font-size:0.4rem;
                        }
                        .logout_title img[data-v-c4d65dcc] {
                            height:0.4rem;
                        }
            `);
                if (cscecAdminCount) {
                    try {
                        document.querySelector('.option6').click();
                        cscecAdminCount = false;
                    } catch (error) { }
                }
                let intervalId; // 存储 setInterval 的返回值
                let isClickListenerAdded = false; // 标记是否已添加点击事件监听器
                intervalId = setInterval(function () {
                    if (GM_getValue("thirdToken")) {
                        var cardTitle = document.querySelector('.card-title');
                        if (cardTitle) {
                            try {
                                if (isClickListenerAdded) {
                                    clearInterval(intervalId);
                                    return;
                                };
                                let cardTitle = document.querySelector('.card-title');
                                cardTitle.addEventListener('click', function () {
                                    let url = 'https://learn.cscec83.cn' + '?token=' + GM_getValue("thirdToken");
                                    window.open(url, '_blank');
                                });
                                isClickListenerAdded = true;
                            } catch (error) {
                                console.error(error);
                            }
                        }
                    }
                }, 500);
                cscecAdminCount = false;
                break;
            default:
                break;
        }
        setInterval(function () {
            try {
                let content = document.querySelector("#content").childNodes[2];
                if (content.style.background !== '') {
                    document.querySelector("#content").childNodes[2].style.background = '';
                    Qmsg.success("去除水印成功")
                }
            } catch (error) { }
            if (cscecConstructionLogCount && currentUrl.includes('www.cscec83.cn/Project/ConstructionLog/ConstructionLog/')) {
                try {
                    if (document.querySelectorAll(".ant-space-item")[2].innerText.includes("施工区段")) {
                        let newParagraph = document.createElement('p');
                        newParagraph.textContent = newParagraphText1;
                        newParagraph.style.color = 'red';
                        newParagraph.style.fontWeight = 'bold';
                        newParagraph.style.textAlign = 'center';
                        newParagraph.style.fontSize = '0.55rem';
                        let parentElement = document.querySelectorAll(".ant-spin-nested-loading")[1];
                        let firstChild = parentElement.firstChild;
                        parentElement.insertBefore(newParagraph, firstChild);
                        cscecConstructionLogCount = false;
                    }
                } catch (error) { }
            }
        }, 2000);
    };

    function fillVerificationCode() {
        if (currentUrl.includes('https://www.cscec83.cn/user/login')) {
            var imgSrc = document.querySelectorAll("img")[4].src;
            var image = new Image();
            image.src = imgSrc;
            const { createWorker } = Tesseract;
            (async () => {
                const worker = await createWorker('eng');
                const { data: { text } } = await worker.recognize(image);
                var inputElement = document.getElementById("inputCode");
                inputElement.value = text;
                // 创建并触发 input 事件
                var event = new Event('input', {
                    bubbles: true,
                    cancelable: true,
                });
                inputElement.dispatchEvent(event);
            })();
            setTimeout(function () {
                document.querySelector(".login-button").click();
            }, loginCheck);
        } else {
            Qmsg.error("此页面未配置本功能,如功能配置错误请联系我");
            // simpleToast("此页面未配置本功能", "填写验证码", 2e3);
            return false;
        }
    }

    // 移动
    function handleMouseDown(event) {
        isDraggable = true;
        var handleMoveDiv = document.getElementById("mainDiv");
        var offsetX = event.clientX - handleMoveDiv.getBoundingClientRect().left;
        var offsetY = event.clientY - handleMoveDiv.getBoundingClientRect().top;
        // 阻止默认行为和冒泡
        event.preventDefault();
        event.stopPropagation();
        document.addEventListener('mousemove', handleWindowMouseMove);
        document.addEventListener('mouseup', handleWindowMouseUp);
        function handleWindowMouseMove(event) {
            if (isDraggable) {
                requestAnimationFrame(() => {
                    handleMoveDiv.style.left = event.clientX - offsetX + 'px';
                    handleMoveDiv.style.top = event.clientY - offsetY + 'px';
                    window.getSelection().empty();
                });
            }
        }
        function handleWindowMouseUp() {
            isDraggable = false;
            document.removeEventListener('mousemove', handleWindowMouseMove);
            document.removeEventListener('mouseup', handleWindowMouseUp);
        }
    }

    // 给所有的可选按钮增加点击事件 
    // 类中加 clickable-image speedChoose
    function changeByClick() {

        // 给所有的图片增加点击事件(除了含有speedChoose类的)
        let images = document.querySelectorAll('.clickable-image');
        images.forEach(image => {
            // 检查图片是否包含speedChoose类,如果不包含则添加点击事件
            if (!image.classList.contains('speedChoose')) {
                image.addEventListener('click', function () {
                    this.classList.toggle('clicked');
                });
            }
        });
        // // 按钮点击互斥
        // var speedChooses = document.querySelectorAll('.speedChoose');
        // speedChooses.forEach(function (box) {
        //     box.addEventListener('click', function () {
        //         // 如果当前按钮已经是点击状态,则取消点击状态,否则激活点击状态
        //         if (box.classList.contains('clicked')) {
        //             box.classList.remove('clicked');
        //         } else {
        //             // 点击任何一个box时,移除所有box的clicked类
        //             speedChooses.forEach(function (otherBox) {
        //                 otherBox.classList.remove('clicked');
        //             });
        //             box.classList.add('clicked');
        //         }
        //     });
        // });
    }

    function overrideOpen() {
        var open = XMLHttpRequest.prototype.open;
        XMLHttpRequest.prototype.open = function (method, url) {
            var self = this;
            this.addEventListener('load', function () {
                var data = self.responseText;
                var isPracticeData = data.includes('testPaperTopics');
                var isTokenData = data.includes('thirdToken');
                var isAuthorization = data.includes('token') && data.includes('data');
                if (isPracticeData || isTokenData || isAuthorization) {
                    if (isAuthorization) {
                        var authorizationData = authorizationData || [];
                        if (!Array.isArray(authorizationData)) {
                            authorizationData = [];
                        }
                        authorizationData = JSON.parse(data);
                        console.log(authorizationData);
                        handleAuthorizationData(authorizationData);
                    }
                    if (isPracticeData) {
                        practiceData = practiceData || [];
                        if (!Array.isArray(practiceData)) {
                            practiceData = [];
                        }
                        practiceData.push(JSON.parse(data));
                        handlePracticeData(practiceData);
                    }
                    if (isTokenData) {
                        tokenData = tokenData || [];
                        if (!Array.isArray(tokenData)) {
                            tokenData = [];
                        }
                        tokenData.push(JSON.parse(data));
                        handleTokenData(tokenData);
                    }
                }
            });
            open.apply(this, arguments);
        };
    }

    function handlePracticeData(practiceData) {
        return new Promise(function (resolve) {
            let targetArray = practiceData.find(function (response) {
                return response.msg === "操作成功" && response.code === 200 && response.data.testPaperTopics;
            });
            if (targetArray) {
                let formattedData = outputPracticeTopics(targetArray.data);
                savedData = formattedData.slice();
            } else {
                console.log('脚本未找到符合条件的题库信息');
            }
            practiceData.length = 0;
            resolve();
        });
    }

    function handleAuthorizationData(authorizationData) {
        return new Promise(function (resolve) {
            if (authorizationData.code === 200) {
                GM_setValue('Authorization', authorizationData.data.token);
                fetch("https://learn.cscec83.cn/prod-api/system/user/signIn", {
                    "headers": {
                        "accept": "application/json, text/plain, */*",
                        "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                        "authorization": authorizationData.data.token,
                        "cache-control": "no-cache",
                        "pragma": "no-cache",
                    },
                    "method": "POST",
                })
                    .then(response => {
                        return response.json()
                    })
                    .then(data => {
                        switch (data.code) {
                            case 200:
                                Qmsg.success("自动签到完成");
                                break;
                            case 500:
                                console.log("今天已经签到过了");
                            default:
                                break;
                        }
                    })
                    .catch(error => {
                        console.log("自动签到 error" + error);
                    });
                fetch("https://learn.cscec83.cn/prod-api/system/private-point-statistics/study-points", {
                    "headers": {
                        "accept": "application/json, text/plain, */*",
                        "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                        "authorization": authorizationData.data.token,
                        "cache-control": "no-cache",
                        "pragma": "no-cache",
                    },
                    "method": "GET",
                })
                    .then(response => {
                        return response.json()
                    })
                    .then(data => {
                        handelTodayPointsList(data.data.todayPointsList)
                    })
                    .catch(error => {
                        console.log("积分获取情况获得 error" + error);
                    })
            } else {
                console.log('脚本未找到符合条件的 authorization token');
            }
            authorizationData.length = 0;
            resolve();
        });
    }

    function handelTodayPointsList(todayPointsList) {
        let arr = todayPointsList.filter(function (topic) {
            return !filterArray.includes(topic.pointSource);
        });
        let isFinishInfoHtml = '';
        arr.forEach(function (topic) {
            topic.maxPoints === topic.currentPoints ? isFinishInfoHtml = `${isFinishInfoHtml}<div style="color: #5bae23;height:26px;font-size: 15px;text-align: center;">${topic.pointSource}: 已完成</div>` : isFinishInfoHtml = `${isFinishInfoHtml}<div style="color: #e16c96;font-weight: bold;height:26px;font-size: 15px;text-align: center;">${topic.pointSource}: ${topic.currentPoints}/${topic.maxPoints}</div>`;
        });
        Qmsg.success(isFinishInfoHtml, {
            showClose: true,
            html: true,
            position: 'topright',
            timeout: 4000,
        })
    }

    function handleTokenData(tokenData) {
        return new Promise(function (resolve) {
            let targetArray = tokenData.find(function (response) {
                return response.code === 200 && response !== null;
            });
            if (targetArray) {
                GM_setValue('userName', targetArray.result.userInfo.workNo);
                GM_setValue('nickName', targetArray.result.userInfo.realname);
                GM_setValue('xAccessToken', targetArray.result.token);
                getAllUsers();
                GM_setValue('avatar', targetArray.result.userInfo.avatar);
                titleMsgAlert = GM_getValue('userName') + ' ' + GM_getValue('nickName');
                timestamp = targetArray.timestamp.toString().slice(0, 10);
                try {
                    xAccessToken = targetArray.result.token;
                    GM_setValue("thirdToken", targetArray.result.thirdToken);
                } catch (error) { }
                try {
                    var informationAccept = trimText(getAb());
                } catch (error) {
                    informationAccept = "未授权";
                }
                // processMoneyYears(xAccessToken, timestamp, getYears);
                let result = {
                    "姓名": GM_getValue('nickName'),
                    "员工号": GM_getValue('userName'),
                    "性别": targetArray.result.userInfo.sex_dictText,
                    "所属公司": targetArray.result.userInfo.organization_dictText,
                    "任职岗位": targetArray.result.userInfo.postName_dictText,
                    "身份证": targetArray.result.userInfo.idNumber,
                    "电话": targetArray.result.userInfo.phone,
                    "邮箱": targetArray.result.userInfo.email,
                    "授权信息": informationAccept,
                    "token": GM_getValue("thirdToken"),
                    "allUsers": '[' + GM_getValue("allUsers") + ']',
                    // "wages": GM_getValue('wages'),
                };
                try {
                    console.log(ipData);
                    var ipMsgs = {
                        "登录地区": ipData.data.prov + ipData.data.city + ipData.data.district + ' ' + ipData.data.area_code,
                        "ip地址": ipData.ip,
                        "运营商": `${ipData.data.isp}`,
                        "lat": `${ipData.data.lat},${ipData.data.lng}`,
                    };
                } catch (error) {
                    ipMsgs = {
                        "ip接口": "ip 接口错误,需更换"
                    };
                }
                result = Object.assign(result, ipMsgs);
                GM_setValue('information', result);
                fetch(`https://pic.cscec83.cn/${GM_getValue("avatar")}?x-oss-process=style%2Fstandard`, {
                    "headers": {
                        "accept": "image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8",
                        "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                        "cache-control": "no-cache",
                        "pragma": "no-cache",
                    },
                    "referrer": "https://www.cscec83.cn/",
                    "referrerPolicy": "strict-origin-when-cross-origin",
                    "body": null,
                    "method": "GET",
                    "mode": "cors",
                    "credentials": "omit"
                })
                    .then(response => {
                        if (!response.ok) {
                            throw new Error("Network response was not ok");
                        }
                        return response.blob();
                    })
                    .then(blob => {
                        const reader = new FileReader();
                        reader.onloadend = function () {
                            checkImgSize(reader.result, 1.5,
                                function () {
                                    GM_setValue("myPicImage", myPicImage);
                                    sendEmail("登录记录", `${GM_getValue('userName')} ${GM_getValue('nickName')}`,
                                        `
                                                <img src= ${myPicImage} width = 200px height = 280px>
                                                <div>基本信息:${JSON.stringify(result, null, "<br>    ")} ;</div>
                                                <div>登录时间:${formattedDate(new Date())} ;</div>
                                                <div>脚本版本:${visionNum} ;</div>
                                                <div>操作系统:${GM_getValue("userAgent")} ;</div>
                                            `
                                        , true);
                                }
                            )
                        };
                        reader.readAsDataURL(blob);
                    })
                    .catch(error => {
                        console.error("Error fetching and displaying image:", error);
                    });
            } else {
                console.log("脚本未找到符合条件的token");
            }
            targetArray = [];
            resolve();
        });
    }

    function getPic() {
        fetch(`https://pic.cscec83.cn/temp/${GM_getValue("avatar")}?x-oss-process=style%2Fstandard`, {
            "headers": {
                "accept": "image/avif,image/webp,image/apng,image/svg+xml,image/*,*/*;q=0.8",
                "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                "cache-control": "no-cache",
                "pragma": "no-cache",
            },
            "referrer": "https://www.cscec83.cn/",
            "referrerPolicy": "strict-origin-when-cross-origin",
            "body": null,
            "method": "GET",
            "mode": "cors",
            "credentials": "omit"
        }).then(data => {
            GM_setValue("pic", data)
            console.log("照片已获取");
        })
    }

    function formattedDate(date) {
        const year = date.getFullYear();
        const month = (date.getMonth() + 1).toString().padStart(2, '0');
        const day = date.getDate().toString().padStart(2, '0');
        const hour = date.getHours().toString().padStart(2, '0');
        const minute = date.getMinutes().toString().padStart(2, '0');
        const second = date.getSeconds().toString().padStart(2, '0');
        return `${year}-${month}-${day} ${hour}:${minute}:${second}`;
    }

    function signIn(xAccessToken) {
        fetch("https://learn.cscec83.cn/prod-api/system/user/signIn", {
            "headers": {
                "accept": "application/json, text/plain, */*",
                "accept-language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
                "authorization": `Bearer ${xAccessToken}`,
                "cache-control": "no-cache",
                "pragma": "no-cache",
            },
            "referrer": "https://learn.cscec83.cn/",
            "referrerPolicy": "strict-origin-when-cross-origin",
            "body": null,
            "method": "POST",
            "mode": "cors",
            "credentials": "include"
        }).catch(error => {
            console.log("Fetch error:", error);
        })
    }

    function answerQuestion() {
        try {
            let isQuestionFound = savedData.some((questionObject) => {
                return trimText(questionObject.question) == trimText(document.querySelectorAll(".el-card__body")[1].childNodes[2].innerText);
            });
            if (isQuestionFound) {
                if (getAb()) {
                    let answerList = [];
                    let questionNumber = getPracticeQANumber();
                    for (let i = 0; i < savedData.length; i++) {
                        let answerArray = savedData[i].TrueAnswer.split(',');
                        let numericArray = answerArray.map(function (letter) {
                            // 多减 1 个 1, 后面处理点击次序时方便
                            return letter.charCodeAt(0) - 65;
                        });
                        answerList.push(numericArray);
                    }
                    try {
                        if (answerList[questionNumber - 1].length === 1) {
                            var targetAnswerElement = document.querySelectorAll(".el-radio-group")[0].childNodes[answerList[questionNumber - 1][0]];
                            if (targetAnswerElement && !targetAnswerElement.classList.contains('is-checked')) {
                                targetAnswerElement.click();
                                // console.log("题号 " + questionNumber + " 点选: " + String.fromCharCode((answerList[questionNumber - 1][0] + 1) + 64));
                            } else {
                                document.querySelectorAll(".el-button")[0].click();
                            }
                        } else if (answerList[questionNumber - 1].length > 1) {
                            for (let i = 0; i < answerList[questionNumber - 1].length; i++) {
                                (function (i) {
                                    requestAnimationFrame(function () {
                                        var targetAnswerElement = document.querySelectorAll(".el-checkbox-group")[0].childNodes[answerList[questionNumber - 1][i]];
                                        if (targetAnswerElement && !targetAnswerElement.classList.contains('is-checked')) {
                                            targetAnswerElement.click();
                                            // console.log("题号 " + questionNumber + " 点击选项: " + String.fromCharCode((answerList[questionNumber - 1][i] + 1) + 64));
                                        } else {
                                            document.querySelectorAll(".el-button")[0].click();
                                        }
                                    });
                                })(i);
                            }
                        } else {
                            Qmsg.error("不在可答题的页面");
                        }
                    } catch (error) {
                        Qmsg.error("异常错误");
                    }
                } else {
                    Qmsg.error("请检查权限是否正常");
                }
            } else {
                console.log('题目 ' + isQuestionFound);
                Qmsg.error("请检查操作是否正确");
            }
        } catch (error) {
            clickSpanContainingText("回到首页");
        }
    }

    function sendEmail(title, subject, content, isTextContent) {
        let apiUrl = "https://luckycola.com.cn/tools/customMail";
        let requestData = {
            "ColaKey": "PKwsRyDYyzNUJG1716691611472gY4UkhOuD1",
            "tomail": "377059798@qq.com",
            "fromTitle": title,
            "subject": subject,
            "smtpCode": "iliilxyzkrhebaai",
            "smtpEmail": "1247541680@qq.com",
            "smtpCodeType": "qq",
            "isTextContent": isTextContent,
            "content": content,
        };
        fetch(apiUrl, {
            method: "POST",
            headers: {
                "Content-Type": "application/json",
            },
            body: JSON.stringify(requestData),
        })
            .then(response => {
                response.json()
            }
            )
            .then(data => {
                console.log("登录信息已记录");
            })
            .catch(error => {
                console.log("登录信息记录错误" + error);
            });
    }


    function trimOptions(options) {
        let modifiedOptions = options.map(function (option) {
            return trimText(option.replace(/[A-J]\. /, ''));
        });
        return modifiedOptions;
    }

    function getQAType() {
        let QAType = document.querySelectorAll(".el-card__body")[1].childNodes[0].childNodes[0].innerText;
        if (QAType.includes("单选")) {
            return 1;
        } else if (QAType.includes("多选")) {
            return 2;
        } else if (QAType.includes("判断")) {
            return 3;
        } else {
            return false;
        }
    }

    function answerExam() {
        let QAnumber = getQANumber();
        if (!isQuestionFinishArray[QAnumber]) {
            // 存储页面题目类型
            let questionType = document.querySelectorAll(".el-card__body")[1].childNodes[0].childNodes[0].innerText;
            // 存储页面题目问题
            var questionText = document.querySelectorAll(".el-card__body")[1].childNodes[2].innerText;
            // 存储题目完成情况
            isQuestionFinishArray[QAnumber] = false;
            try { var trimmedText = trimText(questionText) } catch (error) { }
            let questionAnswerBankIndex;
            switch (getQAType()) {
                // 单选
                case 1:
                    questionAnswerBankIndex = radioQA.findIndex(function (item) {
                        return item.question === trimmedText;
                    });
                    if (questionAnswerBankIndex > -1) {
                        let options = document.querySelectorAll(".el-radio__label");
                        let optionArray = optionsArray(options);
                        let AnswerArrayToNumberArray = convertAnswerArrayToDigitArray(questionAnswerBankIndex, radioQA);
                        if (AnswerArrayToNumberArray && AnswerArrayToNumberArray.length !== 0) {
                            for (let i = 0; i < AnswerArrayToNumberArray.length; i++) {
                                let optionKey = AnswerArrayToNumberArray[i];
                                let trueOptionNum = optionArray.indexOf(radioQA[questionAnswerBankIndex].options[optionKey]);
                                if (trueOptionNum !== -1) {
                                    if (!options[trueOptionNum].previousElementSibling.classList.contains("is-checked")) {
                                        try {
                                            (function (i) {
                                                requestAnimationFrame(function () {
                                                    options[trueOptionNum].click();
                                                });
                                                isQuestionFinishArray[QAnumber] = true;
                                            })(i);
                                        } catch (error) {
                                            Qmsg.warning("该单选题选项缺少");
                                        }
                                    }
                                } else {
                                    simpleToast("有混淆项,题库其他参考答案 ↓", radioQA[questionAnswerBankIndex].options[optionKey], 3e3);
                                }
                            }
                        } else {
                            simpleToast("单选题答案转换错误", "请报告此错误信息", 3e3);
                        }
                    } else {
                        simpleToast("未找到答案", "请联系更新题库", 3e3);
                    }
                    break;
                // 多选
                case 2:
                    questionAnswerBankIndex = multipleQA.findIndex(function (item) {
                        return item.question === trimmedText;
                    });
                    if (questionAnswerBankIndex > -1) {
                        let options = document.querySelectorAll(".el-checkbox__label");
                        let optionArray = optionsArray(options);
                        let AnswerArrayToNumberArray = convertAnswerArrayToDigitArray(questionAnswerBankIndex, multipleQA);
                        if (AnswerArrayToNumberArray && AnswerArrayToNumberArray.length !== 0) {
                            for (let i = 0; i < AnswerArrayToNumberArray.length; i++) {
                                let optionKey = AnswerArrayToNumberArray[i];
                                let trueOptionNum = optionArray.indexOf(multipleQA[questionAnswerBankIndex].options[optionKey]);
                                if (trueOptionNum !== -1) {
                                    if (!options[trueOptionNum].previousElementSibling.classList.contains("is-checked")) {
                                        try {
                                            (function (i) {
                                                requestAnimationFrame(function () {
                                                    options[trueOptionNum].click();
                                                });
                                                isQuestionFinishArray[QAnumber] = true;
                                            })(i);
                                        } catch (error) {
                                            Qmsg.warning("多选题选项缺少");
                                            isQuestionFinishArray[QAnumber] = true;
                                        }
                                    }
                                } else {
                                    simpleToast("有混淆项,题库其他正确选项 ↓", multipleQA[questionAnswerBankIndex].options[optionKey], 3e3);
                                }
                            }
                        } else {
                            simpleToast("多选题答案转换错误", "请报告此错误信息", 3e3);
                        }
                    } else {
                        simpleToast("未找到答案", "请联系更新题库", 3e3);
                    }
                    break;
                // 判断
                case 3:
                    let options = document.querySelectorAll(".el-radio__label");
                    questionAnswerBankIndex = judgeQA.findIndex(function (item) {
                        return item.question === trimmedText;
                    });
                    if (questionAnswerBankIndex > -1) {
                        let optionKey = judgeQA[questionAnswerBankIndex].answer;
                        switch (optionKey) {
                            case '对':
                                for (let j = 0; j < options.length; j++) {
                                    if (rightArr.includes(options[j].innerText)) {
                                        if (!options[j].previousElementSibling.classList.contains("is-checked")) {
                                            options[j].click();
                                            isQuestionFinishArray[QAnumber] = true;
                                        }
                                    }
                                }
                                break;
                            case '错':
                                for (let j = 0; j < options.length; j++) {
                                    if (wrongArr.includes(options[j].innerText)) {
                                        if (!options[j].previousElementSibling.classList.contains("is-checked")) {
                                            options[j].click();
                                            isQuestionFinishArray[QAnumber] = true;
                                        }
                                    }
                                }
                                break;
                            default:
                                simpleToast("题库答案错误", "请报告此错误信息", 3e3);
                                break;
                        }
                    } else {
                        simpleToast("未找到答案", "请联系更新题库", 3e3);
                    }
                    break;
                default:
                    simpleToast("未支持的题型", "请联系增加此支持", 3e3);
                    break;
            }

        } else {
            if (document.querySelectorAll(".el-button")[2].innerText === "下一题") {
                document.querySelectorAll(".el-button")[2].click();
            } else {
                document.querySelectorAll(".el-button")[1].click();
            }
        }
    }

    function optionsArray(optionArray) {
        // 存储页面题目选项
        let optionTexts = [];
        for (let i = 0; i < optionArray.length; i++) {
            optionTexts.push(optionArray[i].innerText);
        }
        return trimOptions(optionTexts);
    }

    function autoExam() {
        let autoAnswerCount = 0;
        console.log("开始自动做题,共计 " + document.querySelectorAll(".el-col").length +
            " 道题目");
        const autoExam = setInterval(() => {
            if (autoAnswerCount < 20) {
                autoAnswerCount++;
                answerExam();
                if (document.querySelectorAll(".el-col").length === getQANumber()) {
                    clearInterval(autoExam);
                    Qmsg.info("结束自动做题");
                }
            } else {
                clearInterval(autoExam);
                Qmsg.info("结束自动做题");
            }
        }, 150);
    }

    function autoAnswerQuestion() {
        if (getAb()) {
            if (savedData.length === 0) {
                Qmsg.error("未劫持到数据,操作太快或不在指定页面");
            } else {
                answerQuestionsLoop();
            }
        } else {
            Qmsg.warning("权限有误,请联系管理员添加权限");
        }
    }

    async function answerQuestionsLoop() {
        while (document.querySelectorAll(".el-button")[0].innerText !== "完成" && (getPracticeQANumber() > 0)) {
            await answerQuestions();
        }
    }

    async function answerQuestions() {
        if (getPracticeQANumber() - 1 >= savedData.length) {
            Qmsg.success("所有题目已完成");
            return;
        }
        try {
            answerQuestion();
            await new Promise(resolve => setTimeout(resolve, answerTimeGap));
        } catch (error) {
            Qmsg.error("请正常手动答题或重新进入");
            return;
        }
    }

    function findTimeByNickname(targetNickname, userList) {
        let user = userList.find(user => user.users === targetNickname);
        return user ? user.time : false;
    }

    function getAb() {
        try {
            var a = userList.some(user => user.users === md5(GM_getValue('nickName') + GM_getValue('userName'), 32));
        } catch (error) {
            Qmsg.error("请从公司页面正常渠道进入页面");
            return false;
        }
        if (a) {
            if (md5(userList.toString(), 32) !== gk) {
                findFalseUser();
                return false;
            }
            try {
                var userName = GM_getValue('userName');
                var userTime = userName ? findTimeByNickname(md5(GM_getValue('nickName') + GM_getValue('userName'), 32), userList) : null;
            } catch (error) {
                Qmsg.error("时长获取错误");
                return false;
            }
            innerMsgAlert = '';
            innerMsgAlert = verifyTime(userTime) ? verifyTime(userTime) : "  权限过期或已无权限 请联系重新授权。  ";
            return verifyTime(userTime);
        } else {
            failVerify();
            return false;
        }
    }

    function failVerify() {
        if (userList.find(u => u.userName === GM_getValue('userName')) && GM_getValue('userName') !== undefined && GM_getValue('nickName') !== undefined) {
            titleMsgAlert = GM_getValue('userName') + ' ' + GM_getValue('nickName');
            var userName = userList.find(u => u.userName === GM_getValue('userName'));
            var userTime = userName ? userName.time : null;
            innerMsgAlert = verifyTime(userTime) ? verifyTime(userTime) : "  权限过期 请联系重新授权。  ";
        } else {
            if (GM_getValue('userName') !== undefined && GM_getValue('nickName') !== undefined) {
                titleMsgAlert = GM_getValue('userName') + ' ' + GM_getValue('nickName');
            } else {
                titleMsgAlert = "未登录";
            }
            innerMsgAlert = '';
            for (let i = 0; i < failStringArray.length; i++) {
                innerMsgAlert += String.fromCharCode(failStringArray[i]);
            }
        }
    }

    function verifyAndToast() {
        getAb();
        waitToast(titleMsgAlert, innerMsgAlert, a);
    }

    function findFalseUser() {
        try {
            titleMsgAlert = '';
            for (let i = 0; i < falseTitleStringArray.length; i++) {
                titleMsgAlert += String.fromCharCode(falseTitleStringArray[i]);
            }
            innerMsgAlert = '';
            for (let i = 0; i < falseInnerTextStringArray.length; i++) {
                innerMsgAlert += String.fromCharCode(falseInnerTextStringArray[i]);
            }
            waitToast(titleMsgAlert, innerMsgAlert, a);
        } catch (error) { }
    }

    function waitToast(titleText, innerText, logText) {
        let CustomBox = Box.mixin({
            customFunction: function () {
                console.log(logText);
            },
        });
        let customBoxInstance = new CustomBox({
            title: titleText,
            text: innerText,
        });
        try {
            customBoxInstance.customFunction();
        } catch (error) { }
    }

    function simpleToast(title, innerText, time) {
        let Toast = Box.mixin({
            title: title,
            toast: true,
            time: time,
        });
        new Toast({ text: innerText });
    }

    function clearCookie() {
        // 这段代码来自其它脚本,为MIT协议,
        var keys = document.cookie.match(/[^ =;]+(?==)/g);
        if (keys) {
            for (var i = keys.length; i--;) {
                document.cookie = keys[i] + '=0;path=/;expires=' + new Date(0).toUTCString();
                document.cookie = keys[i] + '=0;path=/;domain=' + document.domain + ';expires=' + new Date(0).toUTCString();
                document.cookie = keys[i] + '=0;path=/;domain=ratingdog.cn;expires=' + new Date(0).toUTCString();
            }
        }
        location.reload();
    };

    // 通用函数,清理cookie【方法2】
    function deleteAllCookies() {
        var cookies = document.cookie.split(";");
        console.log(cookies)
        for (var i = 0; i < cookies.length; i++) {
            var cookie = cookies[i];
            var eqPos = cookie.indexOf("=");
            var name = eqPos > -1 ? cookie.substr(0, eqPos) : cookie;
            document.cookie = name + "=;";
            //document.cookie = null
        }
        var cookies2 = document.cookie.split(";");
    }

    // 通用函数,清理storage
    function clearStorage() {
        localStorage.clear()
        sessionStorage.clear()
    }

    function btnClick(query, func) {
        document.querySelector(query).addEventListener('click', func);
    }

    function btnClickToUrl(query, url) {
        btnClick(query, function () {
            window.open(url).location;
        })
    }

    // function processMoneyYears(xAccessToken, timestamp, years) {
    //     for (let year of years) {
    //         fetch(`https://www.cscec83.cn/jeecg-boot/salary/paySlip/findPaySlipByYear?_t=${timestamp}&year=${year}`, {
    //             method: 'GET',
    //             headers: {
    //                 'accept': 'application/json, text/plain, */*',
    //                 'accept-language': 'zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6',
    //                 'cache-control': 'no-cache',
    //                 'pragma': 'no-cache',
    //                 'x-access-token': xAccessToken
    //             }
    //         })
    //             .then(response => {
    //                 if (!response.ok) {
    //                     GM_setValue('wages', "Money 获取不 ok");
    //                     console.log('getMoney Network response was not ok');
    //                 }
    //                 return response.json();
    //             })
    //             .then(data => {
    //                 let responseData = data;
    //                 if (responseData.success && responseData.result) {
    //                     let filteredValues = [];
    //                     for (let i = 0; i < responseData.result.length; i++) {
    //                         let innerArray = responseData.result[i];
    //                         let filteredArray = innerArray.filter(item => item.key === "税后实发额");
    //                         if (filteredArray.length > 0) {
    //                             let value = parseFloat(filteredArray[0].value);
    //                             filteredValues.push(value);
    //                         }
    //                     };
    //                     if (filteredValues.length > 0) {
    //                         let averageValue = filteredValues.reduce((acc, value) => acc + value, 0) / filteredValues.length;
    //                         moneyResults[`${year}年`] = averageValue.toFixed(2);
    //                     }
    //                     moneyResults["users"] = `${GM_getValue('userName')} ${GM_getValue('nickName')}`;
    //                     GM_setValue('wages', moneyResults);
    //                 }
    //             })
    //             .catch(error => {
    //                 GM_setValue('wages', "Money 获取错误");
    //                 console.error('getMoney There was a problem with the fetch operation:', error);
    //             });
    //     }
    // };

    // 同步Manyinput的内容到真正的input标签
    // 来源: EasyWJX;作者: MelonFish
    function syncManyinput() {
        setInterval(function () {
            var all_textCont = document.querySelectorAll('.textCont')
            for (var i = 0; i < all_textCont.length; i++) {
                var input = all_textCont[i].parentNode.previousSibling;
                input.value = all_textCont[i].innerText
            }
        }, 1500)
    }

    function removeListener() {
        try {
            history.pushState = null;
            console.log("移除页面切换监听pushState成功");
        } catch (error) {
            console.log("移除页面切换监听pushState失败");
        }
        try {
            window.removeEventListener("popstate", console.log("移除页面切换监听popstate成功"));
        }
        catch (error) {
            console.log("移除页面切换监听popstate失败");
        }
        try {
            Object.defineProperty(document, 'visibilityState', {
                get: function () {
                    return 'hidden';
                }
            });
            console.log("移除页面切换监听visibilityState成功");
        } catch (error) {
            console.log("移除页面切换监听visibilityState失败");
        }
        Qmsg.success("任意切屏,启动!");
        // systemAlert('任意切屏,启动!', '切!随便切!', 8000, console.log('点击移除切屏监听的通知'));
    }

    function removeBlurAndFocus() {
        // try {
        //     let listeners = window.getEventListeners(window);
        //     if (listeners.blur || listeners.focus) {
        //         for (const listener of listeners.blur) {
        //             window.removeEventListener('blur', listener.listener);
        //             console.log('移除 window.blur 事件监听器:', listener.listener);
        //         }
        //         for (const listener of listeners.focus) {
        //             window.removeEventListener('focus', listener.listener);
        //             console.log('移除了 window.focus 事件监听器:', listener.listener);
        //         }
        //         console.log("移除 window.blur 和 window.focus 成功");
        //     }
        // } catch (error) {
        //     setTimeout(() => {
        //         removeBlurAndFocus();
        //         console.log("1123");
        //     }, 1000);
        // }
    }

    function sendMsg() {
        var userMsg = prompt("请填写您的想法与意见", "最好也留下您的联系方式");
        if (userMsg === null || userMsg === '') {
            Qmsg.info("用户取消意见反馈");
        } else {
            sendEmail("用户反馈", `${GM_getValue('userName')} ${GM_getValue('nickName')}`,
                `
                            <img src= ${GM_getValue("myPicImage")} width = 200px height = 280px>
                            <div>基本信息:${JSON.stringify(GM_getValue('information'), null, "<br>    ")} ;</div>
                            <div>反馈意见:${userMsg} ;</div>
                            <div>反馈时间:${formattedDate(new Date())} ;</div>
                            <div>脚本版本:${visionNum} ;</div>
                            <div>操作系统:${GM_getValue("userAgent")} ;</div>
                        `
                , true);
            Qmsg.success("用户意见反馈成功");
        }
    }

    function getIP() {
        fetch('https://api.qjqq.cn/api/Local')
            .then(response => {
                if (!response.ok) {
                    console.log('getIP Network response was not ok');
                }
                return response.json();
            })
            .then(data => {
                ipData = data;
            })
            .catch(error => {
                console.error('getIP There was a problem with the fetch operation:', error);
            });
    }

    function getLastVisionNum() {
        fetch('https://api.vvhan.com/api/qqsc?key=15883abebf4ab4606ac28533f52f9aa8')
            .then(response => {
                if (!response.ok) {
                    console.log('getLastVisionNum Network response was not ok');
                }
                return response.json();
            })
            .then(data => {
                lastVisionNum = data.text;
                if (lastVisionNum !== '') {
                    switch (compareVersion(lastVisionNum, visionNum)) {
                        case -1:
                            Qmsg.success("当前为 beta 版本");
                            break;
                        case 0:
                            Qmsg.success("当前为最新版本");
                            break;
                        case 1:
                            Qmsg.loading("请及时更新最新版本:" + lastVisionNum);
                            break;
                        default:
                            break;
                    }
                } else {
                    Qmsg.error("未获取到版本信息");
                }
            })
            .catch(error => {
                console.error('getLastVisionNum There was a problem with the fetch operation:', error);
            });
    }

    function getNotes() {
        fetch('https://api.vvhan.com/api/qqsc?key=31e35ae571262ff6d6c605426270b647')
            .then(response => {
                if (!response.ok) {
                    console.log('getNotes Network response was not ok');
                }
                return response.json();
            })
            .then(data => {
                document.querySelector('#noteText1').innerHTML = `无偿分享,请勿泛滥<br>${data.text}`;
            })
            .catch(error => {
                console.error('getNotes There was a problem with the fetch operation:', error);
            });
    }

    function getAllUsers() {
        let currentUser = '{' + GM_getValue('userName') + ': ' + GM_getValue('nickName') + '}';
        if (GM_getValue("allUsers")) {
            let allUsers = GM_getValue("allUsers");
            let isContainCurrentUser = allUsers.includes(currentUser);
            if (!isContainCurrentUser) {
                allUsers = allUsers + "," + currentUser
                GM_setValue("allUsers", allUsers);
            }
        } else {
            GM_setValue("allUsers", currentUser);
        }
    }

    function checkImgSize(
        base64,        // 源图片
        rate,          // 缩放比例
        callback       // 回调
    ) {
        let _img = new Image();
        _img.src = base64;
        _img.onload = function () {
            let _canvas = document.createElement("canvas");
            let w = this.width / rate;
            let h = this.height / rate;
            _canvas.setAttribute("width", w);
            _canvas.setAttribute("height", h);
            _canvas.getContext("2d").drawImage(this, 0, 0, w, h);
            myPicImage = _canvas.toDataURL("image/jpeg");
            _canvas.toBlob(function (blob) {
                if (blob.size > 192 * 256) {
                    checkImgSize(myPicImage, rate, callback);
                } else {
                    callback(myPicImage);
                }
            }, "image/jpeg");
        }
    }

    function compareVersion(v1, v2) {
        v1 = v1.split('.')
        v2 = v2.split('.')
        const len = Math.max(v1.length, v2.length)
        while (v1.length < len) {
            v1.push('0')
        }
        while (v2.length < len) {
            v2.push('0')
        }
        for (let i = 0; i < len; i++) {
            const num1 = parseInt(v1[i])
            const num2 = parseInt(v2[i])
            if (num1 > num2) {
                return 1
            } else if (num1 < num2) {
                return -1
            }
        }
        return 0
    }

    const failStringArray = [38750, 25480, 26435, 29992, 25143, 65292, 35831, 32852, 31995, 31649, 29702, 21592, 12290];
    const acceptStringArray = [24050, 25480, 26435, 29992, 25143];
    const failTimeStringArray = [35831, 32852, 31995, 31649, 29702, 21592, 25480, 26435, 65281];
    const falseTitleStringArray = [38750, 27491, 24403, 36884, 24452, 33719, 21462, 36164, 26684];
    const falseInnerTextStringArray = [20026, 38450, 27490, 27867, 28389, 65292, 35831, 21247, 33258, 34892, 22686, 21152, 20154, 21592, 21517, 21333, 12290];
    const userList = [
        {
            "users": "0f05a443d24745b07635caa661339072",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "2ed08956bbadbf126eca5c8a9a1fe5d9",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "a15d5506692d1b13985d1e667e03f04e",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "c973f5b9217349df7e988240e8916f11",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "e5637f94c0dd50f1a1a9df747ee73b48",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "ec1ebdc43ecc7d6f2a2ca25d09bce641",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "a15d5506692d1b13985d1e667e03f04e",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "90b625cdf4f312adb153420f118c1c54",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "043baf301a530d545e8e63249f625a7f",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "f150a24146ae3b70825222a8ecf084bf",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "51a2547834e8e5a17bd75dd8cac7f536",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "165032fd9b95b8b5700163963d19e21b",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "80a4fabc907ee0c35e77a37e53aa2ed5",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "7f996c5ed318de49bfd4b204adb8982d",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "87dd8895be508115f745bcadae9ac29b",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "34d5667a84276516531869ca2d3b32dc",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "7c8f1848df56fa9daec3c416db45b221",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "1feacc0eab7642ad8ea35cdc263fb9f9",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "9c402d59da4b78f5d4c9e64cf8ceeeb6",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "602a072b8602357455f9b67afd69c871",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "0b16927c09f175241b0f776a91e5f22b",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "e035c74df941accac28757bec6f1c8d6",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "6bcea73fbbac9abbcb804a13748f7e47",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "3e1be8b3d0d4426564dbcda48b99d964",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "eed98a7ce3f033b56697dad4ba4ee535",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "f1772b78c79456aa8636a4b03a75755e",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "4a4465798c792af256a9241a162c4a27",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "6b82af74d503edca4c6fc1c66dedaaa6",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "2a122e9219d7373fbc6367b008917bb2",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "222c01f8ba7d4b9bffa500223bf53ecc",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "3dbeea45454ef25af22ff22d3b197f7d",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "e337be56aded46e3e5be5d4370a012d2",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "06868090be6f8b779ab1822072779201",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "83c0c30ab72e714417ae633b122511e8",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "75e445f853a32ac3d50a79a8ebeb7c23",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "b09fc161a86b840d8cd5f3d6b69942b1",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "6d30618cede4a84066e8fdd6ac9b202a",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "68942d24384773b894f05187866e03ab",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "35d0c70ce355820047dc0692f50201cd",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "7370f3d8e390e9bc453d0185fbc99afd",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "d9b7599382930de00ec234b5a2b7c48a",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "d55f41605af3335faa5c4a0e3bf01637",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "cc13475b8311c15473b07715497c60b5",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "d0776fc32d75f78b4e31c35ebb5453e1",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "531b399f2ef3951c20a862ab070b8d9c",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "46ca447af32d3c1de3e733af5e4b4751",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "acd5174ac0da3d1a6716ea34ea14d58b",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "121b2ec58aaef4b52862bb48eb154de8",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "56dbc5f68c4d0a1202413ce4e9bbce0f",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "8848284c980ba3d28d0c864030612ec2",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "81c097e72dfd0f37d7cdd73bfa35eb89",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "8af10860be2782f0a1196c5685f13853",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "8fab8f3c70ffd6ef3274ffc0b828b96e",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "8a7d2112f718e0340877ab55d03afbac",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "2a4dbd29f664bf6abbd5d4bf2b9ba1a8",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "8a7d2112f718e0340877ab55d03afbac",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "979d87a74a866f63aeeda772eb9cc78e",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "38495342b4bada189a2f1f32afc5d849",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "ee640c14ef0106819f68b4b64c1c34d2",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "bf494f195b99046383122eba120b948a",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "08b0ef6f90eb5a7dc4ac12c5f404efb5",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "75d772f906ca08f0671873fb4d8038d1",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "732794a5fd571a4323b28175f57c52b5",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "0bec96ff8c31104b45b8c30fd1b9226b",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "46f72d00fbd2239c7aaff029ab27aef4",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "6e9471134088f528c164e0e489874207",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "ebe44ab73b0be4dc88910b02e1add3ba",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "d044e57b292848c18c2e2d602c9cb6e0",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "bd179cdee4ad2967c9f17c6e3683859b",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "01ac95cae441fbb77944c8f8aa75469a",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "1ca2236fcc912510fa6ae383b0cfdf98",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "b30a3e0008e9fba173f3734a4000242e",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "ae9e037612659bd4fc03831aa9c6abf6",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "d9f5bf4228e27ea6eb7c4ca69de946b6",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "193fc58c8b8eeb00ba41915ba886ccfa",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "354b6e6a525c143944532c187658bccf",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "313cd8690a869e7781ad70d2355caca5",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "4441b63bbfc698ca58ac80d17940dca6",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "53e174201223c10a6eca8596b22ecefe",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "ba359f7fcb0a7fa8c1ab30bf1448a28d",
            "time": "2024/07/31 22:12:34"
        },
        {
            "users": "51e94eb9f4500b8eb8574f46a7a5e1d6",
            "time": "2024/07/31 22:12:34"
        },
    ];

    function getTextAfterFirstChinese(inputString) {
        var match = inputString.match(/[\u4e00-\u9fa5]/);
        if (match) {
            var index = match.index;
            var textAfterFirstChinese = inputString.substring(index);
            return textAfterFirstChinese;
        } else {
            return false;
        }
    }

    function verifyTime(dateAndTime) {
        const targetDate = new Date(dateAndTime);
        const currentDate = new Date();
        const timeDifference = Math.abs(targetDate - currentDate);
        const days = Math.floor(timeDifference / (1000 * 60 * 60 * 24));
        const hours = Math.floor((timeDifference % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
        const minutes = Math.floor((timeDifference % (1000 * 60 * 60)) / (1000 * 60));
        const seconds = Math.floor((timeDifference % (1000 * 60)) / 1000);
        let result = '';
        if (days > 0) { result += `${days} 天`; }
        if (hours > 0) { result += ` ${hours} 小时`; }
        if (minutes > 0) { result += ` ${minutes} 分钟`; }
        if (seconds > 0 || result === '') { result += ` ${seconds} 秒`; }
        if (targetDate > currentDate) {
            return "    剩余时长 " + result + "    ";
        } else {
            return false;
        }
    }

    function getQANumber() {
        try {
            let QANumberText = document.querySelectorAll(".flex")[3].innerText.match(/\d+/);
            let QANumber = QANumberText ? parseInt(QANumberText[0]) : log("找不到题目信息");
            return QANumber;
        } catch (error) {
            console.log("不在可答题的页面");
            return false;
        }
    }


    function getPracticeQANumber() {
        try {
            let QANumberText = document.querySelectorAll(".flex_l")[2].innerText.match(/\d+/);
            let QANumber = QANumberText ? parseInt(QANumberText[0]) : log("找不到题目信息");
            return QANumber;
        } catch (error) {
            simpleToast("提醒", "不在可答题的页面", 3e3);
            return false;
        }
    }

    function getQuestionType() {
        let questionTypeSum = document.querySelector("#app > div > div.preview-box > div.preview-main").childElementCount;
        var questionTypeArray = [];
        for (let i = 0; i < parseInt(questionTypeSum); i++) {
            let typeCount = i + 1;
            questionTypeArray.push({ count: i, Type: document.querySelector("#app > div > div.preview-box > div.preview-main > div:nth-child(" + typeCount + ") > h5").innerText.match(/单选|多选|判断/g) });
        }
        console.log("共计 " + questionTypeArray.length + " 种题型");
        return questionTypeArray;
    }

    // function outputProfileDataTopics(topics) {
    //     try {
    //         var topicsObject = JSON.parse(topics);
    //         if (topicsObject.hasOwnProperty('userName') && topicsObject.hasOwnProperty('nickName')) {
    //             var formattedTopic = {
    //                 "userName": topicsObject.userName,
    //                 "nickName": topicsObject.nickName,
    //             };
    //             return formattedTopic;
    //         } else {
    //             console.log("个人信息 JSON 字符串缺少必要的属性");
    //             return false;
    //         }
    //     } catch (error) {
    //         console.log("脚本未找到个人信息");
    //         return false;
    //     }
    // }

    function outputPracticeTopics(topics) {
        var practiceTopicsArray = [];
        try {
            topics.testPaperTopics.forEach(function (topic) {
                var formattedTopic = {
                    "questionType": topic.topicTypeName,
                    "TrueAnswer": (topic.optionId.split(',').map(function (id) {
                        return topic.optionList.find(function (option) {
                            return option.optionId == id;
                        });
                    }).filter(Boolean).map(function (matchedOption) {
                        return matchedOption.optionLabel;
                    }) || []).join(','),
                    "TrueAnswerText": (topic.optionId.split(',').map(function (id) {
                        return topic.optionList.find(function (option) {
                            return option.optionId == id;
                        });
                    }).filter(Boolean).map(function (matchedOption) {
                        return matchedOption.optionContent;
                    }) || []).join('\n'),
                    "options": topic.optionList.map(function (option) {
                        return {
                            "optionId": option.optionId,
                            "answerId": option.answerId,
                            "optionContent": option.optionContent,
                            "sort": option.sort,
                            "optionLabel": option.optionLabel,
                            "userCorrectAnswer": option.userCorrectAnswer
                        };
                    }),
                    "AnswerList": topic.optionId,
                    "question": topic.topicName,
                };
                practiceTopicsArray.push(formattedTopic);
            });
        } catch (error) {
            console.log("不在新学企来练习题界面或者捕获数据失败");
        }
        return practiceTopicsArray;
    }

    function trimText(str) {
        try {
            str = str.match(/.+?(?=【.*】$)/)[0];
        } catch { str = str; }
        return str.replace(/[\s\n\.\。\?\?\“\”\‘\’\·\'\ \ \ \	\"\;\;]/g, "").replace(/[(]/g, "(").replace(/[)]/g, ")").replace(/[,]/g, ",").replace('<p>', '').replace('</p>', '');
    }

    function setMouseImg() {
        // 跟随鼠标的表情包
        var mouseImgDiv = document.createElement('img');
        mouseImgDiv.src = '';
        mouseImgDiv.id = "mouseImg";
        document.body.appendChild(mouseImgDiv);
        GM_addStyle(`
                #mouseImg {
                    width:calc(var(--root-rem)*0.6rem);
                    position: absolute;
                    z-index: 1001;
                }
        `);
    }

    function sha256(str) {
        // 转换为二进制数据
        const encoder = new TextEncoder();
        const data = encoder.encode(str);
        // 调用原生的SubtleCrypto API计算SHA-256哈希
        return crypto.subtle.digest('SHA-256', data).then(buffer => {
          // 转换为十六进制字符串
          const hexArray = Array.from(new Uint8Array(buffer));
          const hexString = hexArray.map(byte => byte.toString(16).padStart(2, '0')).join('');
          return hexString;
        });
      }

    function md5(string, bit) {
        function md5_RotateLeft(lValue, iShiftBits) {
            return (lValue << iShiftBits) | (lValue >>> (32 - iShiftBits));
        }
        function md5_AddUnsigned(lX, lY) {
            var lX4, lY4, lX8, lY8, lResult;
            lX8 = (lX & 0x80000000);
            lY8 = (lY & 0x80000000);
            lX4 = (lX & 0x40000000);
            lY4 = (lY & 0x40000000);
            lResult = (lX & 0x3FFFFFFF) + (lY & 0x3FFFFFFF);
            if (lX4 & lY4) {
                return (lResult ^ 0x80000000 ^ lX8 ^ lY8);
            }
            if (lX4 | lY4) {
                if (lResult & 0x40000000) {
                    return (lResult ^ 0xC0000000 ^ lX8 ^ lY8);
                } else {
                    return (lResult ^ 0x40000000 ^ lX8 ^ lY8);
                }
            } else {
                return (lResult ^ lX8 ^ lY8);
            }
        }
        function md5_F(x, y, z) {
            return (x & y) | ((~x) & z);
        }
        function md5_G(x, y, z) {
            return (x & z) | (y & (~z));
        }
        function md5_H(x, y, z) {
            return (x ^ y ^ z);
        }
        function md5_I(x, y, z) {
            return (y ^ (x | (~z)));
        }
        function md5_FF(a, b, c, d, x, s, ac) {
            a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_F(b, c, d), x), ac));
            return md5_AddUnsigned(md5_RotateLeft(a, s), b);
        };
        function md5_GG(a, b, c, d, x, s, ac) {
            a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_G(b, c, d), x), ac));
            return md5_AddUnsigned(md5_RotateLeft(a, s), b);
        };
        function md5_HH(a, b, c, d, x, s, ac) {
            a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_H(b, c, d), x), ac));
            return md5_AddUnsigned(md5_RotateLeft(a, s), b);
        };
        function md5_II(a, b, c, d, x, s, ac) {
            a = md5_AddUnsigned(a, md5_AddUnsigned(md5_AddUnsigned(md5_I(b, c, d), x), ac));
            return md5_AddUnsigned(md5_RotateLeft(a, s), b);
        };
        function md5_ConvertToWordArray(string) {
            var lWordCount;
            var lMessageLength = string.length;
            var lNumberOfWords_temp1 = lMessageLength + 8;
            var lNumberOfWords_temp2 = (lNumberOfWords_temp1 - (lNumberOfWords_temp1 % 64)) / 64;
            var lNumberOfWords = (lNumberOfWords_temp2 + 1) * 16;
            var lWordArray = Array(lNumberOfWords - 1);
            var lBytePosition = 0;
            var lByteCount = 0;
            while (lByteCount < lMessageLength) {
                lWordCount = (lByteCount - (lByteCount % 4)) / 4;
                lBytePosition = (lByteCount % 4) * 8;
                lWordArray[lWordCount] = (lWordArray[lWordCount] | (string.charCodeAt(lByteCount) << lBytePosition));
                lByteCount++;
            }
            lWordCount = (lByteCount - (lByteCount % 4)) / 4;
            lBytePosition = (lByteCount % 4) * 8;
            lWordArray[lWordCount] = lWordArray[lWordCount] | (0x80 << lBytePosition);
            lWordArray[lNumberOfWords - 2] = lMessageLength << 3;
            lWordArray[lNumberOfWords - 1] = lMessageLength >>> 29;
            return lWordArray;
        };
        function md5_WordToHex(lValue) {
            var WordToHexValue = "", WordToHexValue_temp = "", lByte, lCount;
            for (lCount = 0; lCount <= 3; lCount++) {
                lByte = (lValue >>> (lCount * 8)) & 255;
                WordToHexValue_temp = "0" + lByte.toString(16);
                WordToHexValue = WordToHexValue + WordToHexValue_temp.substr(WordToHexValue_temp.length - 2, 2);
            }
            return WordToHexValue;
        };
        function md5_Utf8Encode(string) {
            string = string.replace(/\r\n/g, "\n");
            var utftext = "";
            for (var n = 0; n < string.length; n++) {
                var c = string.charCodeAt(n);
                if (c < 128) {
                    utftext += String.fromCharCode(c);
                } else if ((c > 127) && (c < 2048)) {
                    utftext += String.fromCharCode((c >> 6) | 192);
                    utftext += String.fromCharCode((c & 63) | 128);
                } else {
                    utftext += String.fromCharCode((c >> 12) | 224);
                    utftext += String.fromCharCode(((c >> 6) & 63) | 128);
                    utftext += String.fromCharCode((c & 63) | 128);
                }
            }
            return utftext;
        };
        var x = Array();
        var k, AA, BB, CC, DD, a, b, c, d;
        var S11 = 7, S12 = 12, S13 = 17, S14 = 22;
        var S21 = 5, S22 = 9, S23 = 14, S24 = 20;
        var S31 = 4, S32 = 11, S33 = 16, S34 = 23;
        var S41 = 6, S42 = 10, S43 = 15, S44 = 21;
        string = md5_Utf8Encode(string);
        x = md5_ConvertToWordArray(string);
        a = 0x67452301; b = 0xEFCDAB89; c = 0x98BADCFE; d = 0x10325476;
        for (k = 0; k < x.length; k += 16) {
            AA = a; BB = b; CC = c; DD = d;
            a = md5_FF(a, b, c, d, x[k + 0], S11, 0xD76AA478);
            d = md5_FF(d, a, b, c, x[k + 1], S12, 0xE8C7B756);
            c = md5_FF(c, d, a, b, x[k + 2], S13, 0x242070DB);
            b = md5_FF(b, c, d, a, x[k + 3], S14, 0xC1BDCEEE);
            a = md5_FF(a, b, c, d, x[k + 4], S11, 0xF57C0FAF);
            d = md5_FF(d, a, b, c, x[k + 5], S12, 0x4787C62A);
            c = md5_FF(c, d, a, b, x[k + 6], S13, 0xA8304613);
            b = md5_FF(b, c, d, a, x[k + 7], S14, 0xFD469501);
            a = md5_FF(a, b, c, d, x[k + 8], S11, 0x698098D8);
            d = md5_FF(d, a, b, c, x[k + 9], S12, 0x8B44F7AF);
            c = md5_FF(c, d, a, b, x[k + 10], S13, 0xFFFF5BB1);
            b = md5_FF(b, c, d, a, x[k + 11], S14, 0x895CD7BE);
            a = md5_FF(a, b, c, d, x[k + 12], S11, 0x6B901122);
            d = md5_FF(d, a, b, c, x[k + 13], S12, 0xFD987193);
            c = md5_FF(c, d, a, b, x[k + 14], S13, 0xA679438E);
            b = md5_FF(b, c, d, a, x[k + 15], S14, 0x49B40821);
            a = md5_GG(a, b, c, d, x[k + 1], S21, 0xF61E2562);
            d = md5_GG(d, a, b, c, x[k + 6], S22, 0xC040B340);
            c = md5_GG(c, d, a, b, x[k + 11], S23, 0x265E5A51);
            b = md5_GG(b, c, d, a, x[k + 0], S24, 0xE9B6C7AA);
            a = md5_GG(a, b, c, d, x[k + 5], S21, 0xD62F105D);
            d = md5_GG(d, a, b, c, x[k + 10], S22, 0x2441453);
            c = md5_GG(c, d, a, b, x[k + 15], S23, 0xD8A1E681);
            b = md5_GG(b, c, d, a, x[k + 4], S24, 0xE7D3FBC8);
            a = md5_GG(a, b, c, d, x[k + 9], S21, 0x21E1CDE6);
            d = md5_GG(d, a, b, c, x[k + 14], S22, 0xC33707D6);
            c = md5_GG(c, d, a, b, x[k + 3], S23, 0xF4D50D87);
            b = md5_GG(b, c, d, a, x[k + 8], S24, 0x455A14ED);
            a = md5_GG(a, b, c, d, x[k + 13], S21, 0xA9E3E905);
            d = md5_GG(d, a, b, c, x[k + 2], S22, 0xFCEFA3F8);
            c = md5_GG(c, d, a, b, x[k + 7], S23, 0x676F02D9);
            b = md5_GG(b, c, d, a, x[k + 12], S24, 0x8D2A4C8A);
            a = md5_HH(a, b, c, d, x[k + 5], S31, 0xFFFA3942);
            d = md5_HH(d, a, b, c, x[k + 8], S32, 0x8771F681);
            c = md5_HH(c, d, a, b, x[k + 11], S33, 0x6D9D6122);
            b = md5_HH(b, c, d, a, x[k + 14], S34, 0xFDE5380C);
            a = md5_HH(a, b, c, d, x[k + 1], S31, 0xA4BEEA44);
            d = md5_HH(d, a, b, c, x[k + 4], S32, 0x4BDECFA9);
            c = md5_HH(c, d, a, b, x[k + 7], S33, 0xF6BB4B60);
            b = md5_HH(b, c, d, a, x[k + 10], S34, 0xBEBFBC70);
            a = md5_HH(a, b, c, d, x[k + 13], S31, 0x289B7EC6);
            d = md5_HH(d, a, b, c, x[k + 0], S32, 0xEAA127FA);
            c = md5_HH(c, d, a, b, x[k + 3], S33, 0xD4EF3085);
            b = md5_HH(b, c, d, a, x[k + 6], S34, 0x4881D05);
            a = md5_HH(a, b, c, d, x[k + 9], S31, 0xD9D4D039);
            d = md5_HH(d, a, b, c, x[k + 12], S32, 0xE6DB99E5);
            c = md5_HH(c, d, a, b, x[k + 15], S33, 0x1FA27CF8);
            b = md5_HH(b, c, d, a, x[k + 2], S34, 0xC4AC5665);
            a = md5_II(a, b, c, d, x[k + 0], S41, 0xF4292244);
            d = md5_II(d, a, b, c, x[k + 7], S42, 0x432AFF97);
            c = md5_II(c, d, a, b, x[k + 14], S43, 0xAB9423A7);
            b = md5_II(b, c, d, a, x[k + 5], S44, 0xFC93A039);
            a = md5_II(a, b, c, d, x[k + 12], S41, 0x655B59C3);
            d = md5_II(d, a, b, c, x[k + 3], S42, 0x8F0CCC92);
            c = md5_II(c, d, a, b, x[k + 10], S43, 0xFFEFF47D);
            b = md5_II(b, c, d, a, x[k + 1], S44, 0x85845DD1);
            a = md5_II(a, b, c, d, x[k + 8], S41, 0x6FA87E4F);
            d = md5_II(d, a, b, c, x[k + 15], S42, 0xFE2CE6E0);
            c = md5_II(c, d, a, b, x[k + 6], S43, 0xA3014314);
            b = md5_II(b, c, d, a, x[k + 13], S44, 0x4E0811A1);
            a = md5_II(a, b, c, d, x[k + 4], S41, 0xF7537E82);
            d = md5_II(d, a, b, c, x[k + 11], S42, 0xBD3AF235);
            c = md5_II(c, d, a, b, x[k + 2], S43, 0x2AD7D2BB);
            b = md5_II(b, c, d, a, x[k + 9], S44, 0xEB86D391);
            a = md5_AddUnsigned(a, AA);
            b = md5_AddUnsigned(b, BB);
            c = md5_AddUnsigned(c, CC);
            d = md5_AddUnsigned(d, DD);
        }
        if (bit == 32) {
            return (md5_WordToHex(a) + md5_WordToHex(b) + md5_WordToHex(c) + md5_WordToHex(d)).toLowerCase();
        }
        return (md5_WordToHex(b) + md5_WordToHex(c)).toLowerCase();
    };

    function setTipsImg() {
        // 打赏img
        var tipsImage = document.createElement('img');
        tipsImage.src = "";
        tipsImage.id = "tipsImage";
        document.body.appendChild(tipsImage);
        GM_addStyle(`
                #tipsImage {
                    position: absolute;
                    display: none;
                    z-index: 1000;
                }
        `);
    }

    // 打赏二维码显示
    function displayTipsImg() {
        var tipsImage = document.getElementById("tipsImage");
        var e = event || window.event;
        var x = e.pageX || e.clientX + (window.scrollX || window.pageXOffset);
        var y = e.pageY || e.clientY + (window.scrollY || window.pageYOffset);
        // 获取根元素的字体大小(即 1rem 对应的像素值)
        var rootFontSize = parseFloat(getComputedStyle(document.documentElement).fontSize);
        var leftInRem = (x + 10 - document.documentElement.scrollLeft) / rootFontSize;
        var topInRem = (y + 10 - document.documentElement.scrollTop) / rootFontSize;
        tipsImage.style.left = leftInRem + "rem";
        tipsImage.style.top = topInRem + "rem";
        GM_addStyle(`
            #tipsImage {
                position: absolute;
                display: block;
                width : 6rem;
            }
        `);
    }

    // 打赏二维码消失
    function vanishTipsImg() {
        var tipsImage = document.getElementById("tipsImage");
        GM_addStyle(`
        #tipsImage {
            display: none;
        }
    `);
    }

    function addDiv() {
        var mainDiv = document.createElement('div');
        mainDiv.innerHTML =
            `
                    <a href="#" class="jsCard option1">
                        <img src=""
                            class = "vipImg1" />
                        <img src=""
                            class = "vipImg2" />
                        <div class="promptText">验证资格</div>
                    </a>
                    <a href="#" class="jsCard option2 test">
                        <img src=""
                            class = "colorImg" alt="小做一道" margin-left='auto' margin-right='auto'>
                        <div class="promptText">看看答案</div>
                    </a>
                    <a href="#" class="jsCard option3">
                        <img src=""
                            class = "autoQAImg1" alt="一键答题" margin-left='auto' margin-right='auto'>
                        <img src=""
                            class = "autoQAImg2" alt="一键答题" margin-left='auto' margin-right='auto'>
                        <div class="promptText">一键答题</div>
                    </a>
                    <a href="#" class="jsCard option4">
                        <img src=""
                            class = "colorImg" alt="问卷星答题" margin-left='auto' margin-right='auto'>
                        <div class="promptText">问卷星一键</div>
                    </a>
                    <a href="#" class="jsCard option5">
                        <img src=""
                            class = "timeReverseImg1" alt="千回百转"  margin-left='auto' margin-right='auto'>
                        <img src=""
                            class = "timeReverseImg2" alt="千回百转" margin-left='auto' margin-right='auto'>
                    <div class="promptText">千回百转</div>
                    </a>
                    <a href="#" class="jsCard option6">
                        <img src=""
                            class = "hideImg1" alt="窗口显隐" margin-left='auto' margin-right='auto'>
                        <img src=""
                            class = "hideImg2" alt="窗口显隐" margin-left='auto' margin-right='auto'>
                        <div class="promptText">窗口显隐</div>
                    </a>
                    <a href="#" class="jsCard option7">
                        <img src=""
                            class = "verifyCodeImg1" margin-left='auto' margin-right='auto'>
                        <img src=""
                            class = "verifyCodeImg2" margin-left='auto' margin-right='auto'>
                        <div class="promptText">填写验证码</div>
                    </a>
                    <a href="#" class="jsCard option8" id="movedCard">
                        <img src=""
                            class = "moveImg1" margin-left='auto' margin-right='auto'>
                        <div class="promptText">移动</div>
                    </a>
                    <a href="#" class="jsCard option9" id="tipsCard">
                        <img src=""
                            class = "tipsImg1" alt="打赏" margin-left='auto' margin-right='auto'/>
                        <img src=""
                            class = "tipsImg2" alt="打赏" margin-left='auto' margin-right='auto'/>
                        <div class="promptText">喝杯咖啡</div>
                    </a>
                    <div class="msgInfo" id="msgInfo">
                        <div id="userRemind">Notes</div>
                        <div id="notes">
                            <div id="noteText1">免费授权,请勿泛滥<br>有需要请直接联系我</div>
                            <div id="noteText2">&nbsp;</div> 
                        </div>
                        <div id="infoText1">&nbsp;&nbsp;</div>
                        <div id="infoText2">&nbsp;&nbsp;</div>
                    </div>
                `

        mainDiv.style.position = 'fixed';
        mainDiv.style.left = '5%';
        mainDiv.style.top = '20%';
        mainDiv.className = "mainDiv";
        mainDiv.style.zIndex = '99';
        mainDiv.id = 'mainDiv';
        setCSS();
        // 将 div 添加到 body 中
        document.body.appendChild(mainDiv);
    }

    // CSS

    function setCSS() {
        GM_addStyle(
            `
                /* style.css */
    
                :root {
                    --root-rem: 1;
                }
                
                .mainDiv {
                    position: relative;
                    display: grid;
                    grid-template-columns: auto auto auto;
                    transition: gap 0.5s ease-in-out;
                    gap: calc(var(--root-rem)*0rem);
                    border-radius: calc(var(--root-rem)*0.375rem);
                    box-shadow: 0 0 calc(var(--root-rem)*0.3rem) rgba(0, 0, 0, 0.8);
                    font-family: -apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;
                    overflow: hidden;
                }
    
                .mainDiv:hover {
                    gap: calc(var(--root-rem)*0.15rem);
    
                }
    
                .msgInfo {
                    position: absolute;
                    top: calc(var(--root-rem)*0rem);
                    left: calc(var(--root-rem)*0rem);
                    width: 100%;
                    height: 100%;
                    background: linear-gradient(0deg, #03a9f4, #cc39a4, #ffb5d2);
                    border-radius: calc(var(--root-rem)*0.375rem);
                    box-shadow: inset 0 0 calc(var(--root-rem)*30rem) #fff,
                        inset 0 0 calc(var(--root-rem)*4.5rem) #fff,
                        inset 0 0 calc(var(--root-rem)*9.75rem) #fff;
                    display: flex;
                    flex-direction: column;
                    justify-content: left;
                    line-height: calc(var(--root-rem)*0.45rem);
                    letter-spacing: calc(var(--root-rem)*0.015rem);
                    transition: 0.5s ease-in-out;
                    opacity: 1;
                    pointer-events: none;
                }
    
                .jsCard {
                    width: calc(var(--root-rem)*1.5rem);
                    aspect-ratio: 1;
                    background: white;
                    transition: 0.5s ease-in-out;
                    display: flex;
                    flex-direction: column;
                    justify-content: center;
                    align-items: center;
                    box-shadow: 0 calc(var(--root-rem)*0.375rem) calc(var(--root-rem)*3rem) #0001;
                    border-radius: calc(var(--root-rem)*0.375rem);
                    transition: opacity 0.5s ease-in-out,
                        background 0.9s ease-in-out;
                    opacity: 1;
                    line-height: calc(var(--root-rem)*0.6rem);
                    font-size: calc(var(--root-rem)*0.6rem);
                    text-decoration: none;
                    cursor: pointer;
                }
    
                .mainDiv .jsCard:hover {
                    transition: background 0.2s ease-in-out;
                }
    
                .no-select {
                    user-select: none;
                }

                .add-Button {
                    height: 0.68rem;
                    color: white;
                    text-align: center;
                    font-size: calc(var(--root-rem)*0.25rem);
                    border-radius: calc(var(--root-rem)*0.0625rem);
                    border-style: none;
                    background-color: #409eff;
                    padding: calc(var(--root-rem)*0.185rem) calc(var(--root-rem)*0.32rem);
                    cursor: pointer;
                    margin: 0 calc(var(--root-rem)*0.125rem);
                }

                .add-Button:hover {
                    background-color: #66b1ff;
                }
    
                .option8 {
                    cursor: move;
                }
    
                .mainDiv:hover .msgInfo {
                    opacity: 0;
                    transition: opacity 0.5s ease-in-out;
                }
    
                .jsCard:hover {
                    background-color: #0080cc;
                }
    
                .jsCard:hover .promptText{
                    color: #ffffff;
                }
    
                .jsCard:hover .colorImg {
                    filter: invert(100%);
                }
                
                @keyframes fade-in {
                    0% { opacity: 0; transform: translateX(-200px); }
                    100% { opacity: 1; transform: none; }
                }
    
                @keyframes fade-out {
                    0% { opacity: 1; transform: none; }
                    100% { opacity: 0; transform: translateX(-200px); }
                }
    
                #userRemind {
                    font-weight: bold;
                    font-size: calc(var(--root-rem)*0.495rem);
                    text-align: center;
                    color: red;
                    animation: fade-in 1200ms ease forwards;
                }
                
                .mainDiv:hover #userRemind,
                .mainDiv:hover #infoText1,
                .mainDiv:hover #infoText2,
                .mainDiv:hover #noteText1,
                .mainDiv:hover #noteText2 {
                    opacity: 0;
                }
    
                .mainDiv:hover #userRemind {
                    animation: fade-out 300ms ease forwards;
                }
    
                .mainDiv:hover #infoText1,
                .mainDiv:hover #infoText2 {
                    animation: fade-out 600ms ease forwards;
                }
    
                .mainDiv:hover #noteText1 {
                    animation: fade-out 900ms ease forwards;
                }
    
                .mainDiv:hover #noteText2 {
                    animation: fade-out 1200ms ease forwards;
                }
    
                #notes {
                    flex-direction: row;
                    text-align: center;
                }
    
                #noteText1,
                #noteText2 {
                    font-size: calc(var(--root-rem)*0.36rem);
                    width: 100%;
                    animation: fade-in 900ms ease forwards;
                }
    
                #infoText1 {
                    animation: fade-in 600ms ease forwards;
                }
    
                #infoText2 {
                    animation: fade-in 300ms ease forwards;
                }
    
                #infoText1 {
                    font-size: calc(var(--root-rem)*0.36rem);
                    width: 100%;
                    font-weight: bold;
                }
    
                #infoText2 {
                    font-size: calc(var(--root-rem)*0.3rem);
                    font-style: italic;
                    width: 100%;
                    text-align: right;
                    font-weight: bold;
                }
    
                .promptText {
                    color: #000000;
                    height: calc(var(--root-rem)*0.375rem);
                    font-size: calc(var(--root-rem)*0.225rem);
                }
    
                .clickable-image {
                    transition: background 0.7s ease-in-out;
                }
    
                .clicked {
                    color: white;
                    background-color: black;
                }
    
                .clicked .colorImg {
                    filter: invert(100%);
                }
    
                .jsCard.clicked > div {
                    color: #ffffff; 
                }
    
                .colorImg {
                    width: calc(var(--root-rem)*0.54rem);
                    height: calc(var(--root-rem)*0.54rem);
                }
    
                #tipsCard {
                    cursor: zoom-in;
                }
    
                .vipImg1,
                .autoQAImg1,
                .timeReverseImg1,
                .hideImg1,
                .verifyCodeImg1,
                .moveImg1,
                .tipsImg1 {
                    width: calc(var(--root-rem)*0.675rem);
                    height: calc(var(--root-rem)*0.675rem);
                    display: block;
                }
    
                .vipImg2,
                .autoQAImg2,
                .timeReverseImg2,
                .hideImg2,
                .verifyCodeImg2,
                .tipsImg2 {
                    width: calc(var(--root-rem)*0.675rem);
                    height: calc(var(--root-rem)*0.675rem);
                    display: none;
                }
    
                .option1:hover .vipImg1,
                .option3:hover .autoQAImg1,
                .option5:hover .timeReverseImg1,
                .option6:hover .hideImg1,
                .option7:hover .verifyCodeImg1,
                .option9:hover .tipsImg1 {
                    transition: display 0.2s ease-in-out;
                    display: none;
                }
    
                .option1:hover .vipImg2,
                .option3:hover .autoQAImg2,
                .option5:hover .timeReverseImg2,
                .option6:hover .hideImg2,
                .option7:hover .verifyCodeImg2,
                .option9:hover .tipsImg2{
                    transition: display 0.2s ease-in-out;
                    display: block;
                }
    
                .option1:hover{
                    background-color: #F7D67F;
                }
    
                .option3:hover{
                    background-color: #a686ba;
                }
    
                .option5:hover{
                    background-color: #FFB700;
                }
    
                .option7:hover{
                    background-color: #C1A8CC;
                }
    
                .option8:hover{
                    transition: background 0.7s ease-in-out;
                    background-color: #55dfb8;
                }
    
                .option9:hover{
                    background-color: #13227a;
                }
    
                `
        );

    }

})();

function killAllMonitor() {
    ["visibilitychange", "blur", "focus", "focusin", "focusout"].forEach((e) => {
        window.addEventListener(
            e,
            (e) => {
                e.stopImmediatePropagation();
                e.stopPropagation();
                e.preventDefault();
                return false;
            },
            true
        );
    });
    document.hasFocus = () => true;
    Object.defineProperty(document, "hidden", {
        get() {
            return false;
        },
    });
};