爱问答助手

全平台问答助手,一键获取整个页面的试题答案,目前支持【超星学习通、知到智慧树、国家开放大学、广东开放大学、江苏开放大学、上海开放大学、云南开放大学、芯位教育、云慕学苑、职教云、川农在线、安徽继续教育平台、青书学堂、睿学在线、成教云、京人平台、绎通继教云、学起Plus、云上河开、河南继续教育、四川开放大学、良师在线、继教云、日照专业技术人员继续教育、麦能网、21tb、168网校、云班课、电大中专、learnin、西财在线、春风雨】,更多平台开发中...

您需要先安装一个扩展,例如 篡改猴Greasemonkey暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴暴力猴,之后才能安装此脚本。

您需要先安装一个扩展,例如 篡改猴Userscripts ,之后才能安装此脚本。

您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。

您需要先安装用户脚本管理器扩展后才能安装此脚本。

(我已经安装了用户脚本管理器,让我安装!)

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展,比如 Stylus,才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

您需要先安装一款用户样式管理器扩展后才能安装此样式。

(我已经安装了用户样式管理器,让我安装!)

// ==UserScript==
// @name         爱问答助手
// @namespace    aiask/askHelper
// @version      2.4.4
// @author       aiask
// @description  全平台问答助手,一键获取整个页面的试题答案,目前支持【超星学习通、知到智慧树、国家开放大学、广东开放大学、江苏开放大学、上海开放大学、云南开放大学、芯位教育、云慕学苑、职教云、川农在线、安徽继续教育平台、青书学堂、睿学在线、成教云、京人平台、绎通继教云、学起Plus、云上河开、河南继续教育、四川开放大学、良师在线、继教云、日照专业技术人员继续教育、麦能网、21tb、168网校、云班课、电大中专、learnin、西财在线、春风雨】,更多平台开发中...
// @icon         
// @match        *://*.chaoxing.com/*
// @match        *://*.hlju.edu.cn/*
// @match        *://*.ecust.edu.cn/*
// @match        *://lms.ouchn.cn/*
// @match        *://*.ouchn.cn/*
// @match        *://xczxzdbf.moodle.qwbx.ouchn.cn/*
// @match        *://study.ouchn.cn/*
// @match        *://moodle.syxy.ouchn.cn/*
// @match        *://moodle.qwbx.ouchn.cn/*
// @match        *://*.tongyi.com/*
// @match        *://chatglm.cn/*
// @match        *://xinghuo.xfyun.cn/*
// @match        *://chat.deepseek.com/*
// @match        *://*.zhihuishu.com/*
// @match        *://course.ougd.cn/*
// @match        *://elearning.bjou.edu.cn/*
// @match        *://whkpc.hnqtyq.cn:5678/*
// @match        *://www.51xinwei.com/*
// @match        *://*.w-ling.cn/*
// @match        *://*.edu-edu.com/*
// @match        *://xuexi.jsou.cn/*
// @match        *://*.icve.com.cn/*
// @match        *://zice.cnzx.info/*
// @match        *://any.cnzx.info:81/*
// @match        *://www.icourse163.org/*
// @match        *://*.shou.org.cn/*
// @match        *://*.ahjxjy.cn/*
// @match        *://*.chinaedu.net/*
// @match        *://*.qingshuxuetang.com/*
// @match        *://cce.org.uooconline.com/*
// @match        *://*.courshare.cn/*
// @match        *://*.cep.webtrn.cn/*
// @match        *://*.webtrn.cn/*
// @match        *://*.cj-edu.com/*
// @match        *://*.ytccr.com/*
// @match        *://*.exam-cloud.cn/*
// @match        *://gdrtvu.exam-cloud.cn/*
// @match        *://*.open.ha.cn/*
// @match        *://lhycjy.cloudwis.tech/*
// @match        *://*.sclecb.cn/*
// @match        *://*.web2.superchutou.com/*
// @match        *://*.ls365.net/*
// @match        *://*.jijiaox.com/*
// @match        *://*.wencaischool.net/*
// @match        *://sdrz.gxk.yxlearning.com/*
// @match        *://*.crjxjy.net/*
// @match        *://*.cjnep.net/*
// @match        *://*.91huayi.com/*
// @match        *://teach.ynou.edu.cn/*
// @match        *://*.edu-edu.com.cn/*
// @match        *://*.21tb.com/*
// @match        *://*.168wangxiao.com/*
// @match        *://*.mynep.com/*
// @match        *://www.mosoteach.cn/*
// @match        *://*.aufe.edu.cn/*
// @match        *://*.learnin.com.cn/*
// @match        *://*.ouchn.edu.cn/*
// @match        *://*.swufe-online.com/*
// @match        *://ks.cqsdx.cn/*
// @match        *://*.qau.edu.cn/*
// @match        *://*.gdufemooc.cn/*
// @match        *://*.telfri-edu.com/*
// @match        *://www.beeline-ai.com/*
// @match        *://*.wxic.edu.cn/*
// @match        *://*.yxbyun.com/*
// @match        *://*.wdjycj.com/*
// @match        *://*.hbcjpt.com/*
// @match        *://*.csmu.edu.cn/*
// @match        *://*.ketangx.net/*
// @match        *://*.cnzx.info/*
// @match        *://www.asklib.com/*
// @match        *://*.xust.edu.cn/*
// @match        *://*.whut.edu.cn/*
// @match        *://*.lut.edu.cn/*
// @match        *://*.wwwwsoft.com/*
// @match        *://*.dufe.edu.cn/*
// @match        *://*.lygtc.edu.cn/*
// @match        *://*.iwdjy.com/*
// @match        *://*.jijiaool.com/*
// @match        *://lms.cjzx.hblll.com/*
// @match        *://*.ouc-online.com.cn/*
// @match        *://*.lsedu.vip/*
// @require      https://lib.baomitu.com/vue/3.4.27/vue.global.min.js
// @require      https://lib.baomitu.com/vue-demi/0.14.6/index.iife.js
// @require      data:application/javascript,%3Bwindow.Vue%3DVue%3B
// @require      https://lib.baomitu.com/element-plus/2.8.2/index.full.min.js
// @require      https://lib.baomitu.com/jquery/3.6.0/jquery.min.js
// @require      https://lib.baomitu.com/dompurify/3.1.6/purify.min.js
// @require      https://lib.baomitu.com/crypto-js/4.2.0/crypto-js.min.js
// @resource     ElementPlus  https://lib.baomitu.com/element-plus/2.8.2/index.min.css
// @connect      127.0.0.1
// @connect      icodef.com
// @connect      muketool.com
// @connect      wk66.top
// @connect      82.157.105.20
// @connect      zhihuishu.com
// @connect      greasyfork.org
// @connect      chaoxing.com
// @connect      shou.org.cn
// @connect      jsdelivr.net
// @connect      jsdmirror.cn
// @connect      gitee.com
// @connect      vxo.im
// @connect      zeroai.chat
// @connect      forestpolice.org
// @connect      scriptcat.org
// @connect      aiask.site
// @connect      *
// @grant        GM_addStyle
// @grant        GM_deleteValue
// @grant        GM_getResourceText
// @grant        GM_getValue
// @grant        GM_info
// @grant        GM_listValues
// @grant        GM_setValue
// @grant        GM_xmlhttpRequest
// @grant        unsafeWindow
// @run-at       document-start
// ==/UserScript==
// hello

(function (vue, V, D, R, J) {
    'use strict';

    var e = Object.defineProperty, __publicField = (t, n, a) => ((t, n, a) => n in t ? e(t, n, {
        enumerable: !0,
        configurable: !0,
        writable: !0,
        value: a
    }) : t[n] = a)(t, "symbol" != typeof n ? n + "" : n, a);

    var Q = vue.defineComponent({
        name: "ArrowLeft",
        __name: "arrow-left",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M609.408 149.376 277.76 489.6a32 32 0 0 0 0 44.672l331.648 340.352a29.12 29.12 0 0 0 41.728 0 30.592 30.592 0 0 0 0-42.752L339.264 511.936l311.872-319.872a30.592 30.592 0 0 0 0-42.688 29.12 29.12 0 0 0-41.728 0z"
        }) ]))
    }), W = vue.defineComponent({
        name: "ArrowRight",
        __name: "arrow-right",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M340.864 149.312a30.592 30.592 0 0 0 0 42.752L652.736 512 340.864 831.872a30.592 30.592 0 0 0 0 42.752 29.12 29.12 0 0 0 41.728 0L714.24 534.336a32 32 0 0 0 0-44.672L382.592 149.376a29.12 29.12 0 0 0-41.728 0z"
        }) ]))
    }), K = vue.defineComponent({
        name: "ChatDotRound",
        __name: "chat-dot-round",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m174.72 855.68 135.296-45.12 23.68 11.84C388.096 849.536 448.576 864 512 864c211.84 0 384-166.784 384-352S723.84 160 512 160 128 326.784 128 512c0 69.12 24.96 139.264 70.848 199.232l22.08 28.8-46.272 115.584zm-45.248 82.56A32 32 0 0 1 89.6 896l58.368-145.92C94.72 680.32 64 596.864 64 512 64 299.904 256 96 512 96s448 203.904 448 416-192 416-448 416a461.056 461.056 0 0 1-206.912-48.384l-175.616 58.56z"
        }), vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M512 563.2a51.2 51.2 0 1 1 0-102.4 51.2 51.2 0 0 1 0 102.4m192 0a51.2 51.2 0 1 1 0-102.4 51.2 51.2 0 0 1 0 102.4m-384 0a51.2 51.2 0 1 1 0-102.4 51.2 51.2 0 0 1 0 102.4"
        }) ]))
    }), Y = vue.defineComponent({
        name: "Coin",
        __name: "coin",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m161.92 580.736 29.888 58.88C171.328 659.776 160 681.728 160 704c0 82.304 155.328 160 352 160s352-77.696 352-160c0-22.272-11.392-44.16-31.808-64.32l30.464-58.432C903.936 615.808 928 657.664 928 704c0 129.728-188.544 224-416 224S96 833.728 96 704c0-46.592 24.32-88.576 65.92-123.264z"
        }), vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m161.92 388.736 29.888 58.88C171.328 467.84 160 489.792 160 512c0 82.304 155.328 160 352 160s352-77.696 352-160c0-22.272-11.392-44.16-31.808-64.32l30.464-58.432C903.936 423.808 928 465.664 928 512c0 129.728-188.544 224-416 224S96 641.728 96 512c0-46.592 24.32-88.576 65.92-123.264z"
        }), vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M512 544c-227.456 0-416-94.272-416-224S284.544 96 512 96s416 94.272 416 224-188.544 224-416 224m0-64c196.672 0 352-77.696 352-160S708.672 160 512 160s-352 77.696-352 160 155.328 160 352 160"
        }) ]))
    }), X = vue.defineComponent({
        name: "CollectionTag",
        __name: "collection-tag",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M256 128v698.88l196.032-156.864a96 96 0 0 1 119.936 0L768 826.816V128zm-32-64h576a32 32 0 0 1 32 32v797.44a32 32 0 0 1-51.968 24.96L531.968 720a32 32 0 0 0-39.936 0L243.968 918.4A32 32 0 0 1 192 893.44V96a32 32 0 0 1 32-32"
        }) ]))
    }), Z = vue.defineComponent({
        name: "DataAnalysis",
        __name: "data-analysis",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m665.216 768 110.848 192h-73.856L591.36 768H433.024L322.176 960H248.32l110.848-192H160a32 32 0 0 1-32-32V192H64a32 32 0 0 1 0-64h896a32 32 0 1 1 0 64h-64v544a32 32 0 0 1-32 32zM832 192H192v512h640zM352 448a32 32 0 0 1 32 32v64a32 32 0 0 1-64 0v-64a32 32 0 0 1 32-32m160-64a32 32 0 0 1 32 32v128a32 32 0 0 1-64 0V416a32 32 0 0 1 32-32m160-64a32 32 0 0 1 32 32v192a32 32 0 1 1-64 0V352a32 32 0 0 1 32-32"
        }) ]))
    }), ee = vue.defineComponent({
        name: "Delete",
        __name: "delete",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M160 256H96a32 32 0 0 1 0-64h256V95.936a32 32 0 0 1 32-32h256a32 32 0 0 1 32 32V192h256a32 32 0 1 1 0 64h-64v672a32 32 0 0 1-32 32H192a32 32 0 0 1-32-32zm448-64v-64H416v64zM224 896h576V256H224zm192-128a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32m192 0a32 32 0 0 1-32-32V416a32 32 0 0 1 64 0v320a32 32 0 0 1-32 32"
        }) ]))
    }), te = vue.defineComponent({
        name: "Document",
        __name: "document",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M832 384H576V128H192v768h640zm-26.496-64L640 154.496V320zM160 64h480l256 256v608a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V96a32 32 0 0 1 32-32m160 448h384v64H320zm0-192h160v64H320zm0 384h384v64H320z"
        }) ]))
    }), ne = vue.defineComponent({
        name: "Download",
        __name: "download",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M160 832h704a32 32 0 1 1 0 64H160a32 32 0 1 1 0-64m384-253.696 236.288-236.352 45.248 45.248L508.8 704 192 387.2l45.248-45.248L480 584.704V128h64z"
        }) ]))
    }), ae = vue.defineComponent({
        name: "EditPen",
        __name: "edit-pen",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m199.04 672.64 193.984 112 224-387.968-193.92-112-224 388.032zm-23.872 60.16 32.896 148.288 144.896-45.696zM455.04 229.248l193.92 112 56.704-98.112-193.984-112-56.64 98.112zM104.32 708.8l384-665.024 304.768 175.936L409.152 884.8h.064l-248.448 78.336zm384 254.272v-64h448v64h-448z"
        }) ]))
    }), oe = vue.defineComponent({
        name: "Edit",
        __name: "edit",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M832 512a32 32 0 1 1 64 0v352a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V160a32 32 0 0 1 32-32h352a32 32 0 0 1 0 64H192v640h640z"
        }), vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m469.952 554.24 52.8-7.552L847.104 222.4a32 32 0 1 0-45.248-45.248L477.44 501.44l-7.552 52.8zm422.4-422.4a96 96 0 0 1 0 135.808l-331.84 331.84a32 32 0 0 1-18.112 9.088L436.8 623.68a32 32 0 0 1-36.224-36.224l15.104-105.6a32 32 0 0 1 9.024-18.112l331.904-331.84a96 96 0 0 1 135.744 0z"
        }) ]))
    }), se = vue.defineComponent({
        name: "FolderOpened",
        __name: "folder-opened",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M878.08 448H241.92l-96 384h636.16l96-384zM832 384v-64H485.76L357.504 192H128v448l57.92-231.744A32 32 0 0 1 216.96 384zm-24.96 512H96a32 32 0 0 1-32-32V160a32 32 0 0 1 32-32h287.872l128.384 128H864a32 32 0 0 1 32 32v96h23.04a32 32 0 0 1 31.04 39.744l-112 448A32 32 0 0 1 807.04 896"
        }) ]))
    }), ie = vue.defineComponent({
        name: "Folder",
        __name: "folder",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M128 192v640h768V320H485.76L357.504 192zm-32-64h287.872l128.384 128H928a32 32 0 0 1 32 32v576a32 32 0 0 1-32 32H96a32 32 0 0 1-32-32V160a32 32 0 0 1 32-32"
        }) ]))
    }), re = vue.defineComponent({
        name: "House",
        __name: "house",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M192 413.952V896h640V413.952L512 147.328zM139.52 374.4l352-293.312a32 32 0 0 1 40.96 0l352 293.312A32 32 0 0 1 896 398.976V928a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V398.976a32 32 0 0 1 11.52-24.576"
        }) ]))
    }), le = vue.defineComponent({
        name: "Lock",
        __name: "lock",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M224 448a32 32 0 0 0-32 32v384a32 32 0 0 0 32 32h576a32 32 0 0 0 32-32V480a32 32 0 0 0-32-32zm0-64h576a96 96 0 0 1 96 96v384a96 96 0 0 1-96 96H224a96 96 0 0 1-96-96V480a96 96 0 0 1 96-96"
        }), vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M512 544a32 32 0 0 1 32 32v192a32 32 0 1 1-64 0V576a32 32 0 0 1 32-32m192-160v-64a192 192 0 1 0-384 0v64zM512 64a256 256 0 0 1 256 256v128H256V320A256 256 0 0 1 512 64"
        }) ]))
    }), ce = vue.defineComponent({
        name: "Minus",
        __name: "minus",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M128 544h768a32 32 0 1 0 0-64H128a32 32 0 0 0 0 64"
        }) ]))
    }), pe = vue.defineComponent({
        name: "Notebook",
        __name: "notebook",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M192 128v768h640V128zm-32-64h704a32 32 0 0 1 32 32v832a32 32 0 0 1-32 32H160a32 32 0 0 1-32-32V96a32 32 0 0 1 32-32"
        }), vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M672 128h64v768h-64zM96 192h128q32 0 32 32t-32 32H96q-32 0-32-32t32-32m0 192h128q32 0 32 32t-32 32H96q-32 0-32-32t32-32m0 192h128q32 0 32 32t-32 32H96q-32 0-32-32t32-32m0 192h128q32 0 32 32t-32 32H96q-32 0-32-32t32-32"
        }) ]))
    }), ue = vue.defineComponent({
        name: "Plus",
        __name: "plus",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M480 480V128a32 32 0 0 1 64 0v352h352a32 32 0 1 1 0 64H544v352a32 32 0 1 1-64 0V544H128a32 32 0 0 1 0-64z"
        }) ]))
    }), de = vue.defineComponent({
        name: "QuestionFilled",
        __name: "question-filled",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896m23.744 191.488c-52.096 0-92.928 14.784-123.2 44.352-30.976 29.568-45.76 70.4-45.76 122.496h80.256c0-29.568 5.632-52.8 17.6-68.992 13.376-19.712 35.2-28.864 66.176-28.864 23.936 0 42.944 6.336 56.32 19.712 12.672 13.376 19.712 31.68 19.712 54.912 0 17.6-6.336 34.496-19.008 49.984l-8.448 9.856c-45.76 40.832-73.216 70.4-82.368 89.408-9.856 19.008-14.08 42.24-14.08 68.992v9.856h80.96v-9.856c0-16.896 3.52-31.68 10.56-45.76 6.336-12.672 15.488-24.64 28.16-35.2 33.792-29.568 54.208-48.576 60.544-55.616 16.896-22.528 26.048-51.392 26.048-86.592 0-42.944-14.08-76.736-42.24-101.376-28.16-25.344-65.472-37.312-111.232-37.312zm-12.672 406.208a54.272 54.272 0 0 0-38.72 14.784 49.408 49.408 0 0 0-15.488 38.016c0 15.488 4.928 28.16 15.488 38.016A54.848 54.848 0 0 0 523.072 768c15.488 0 28.16-4.928 38.72-14.784a51.52 51.52 0 0 0 16.192-38.72 51.968 51.968 0 0 0-15.488-38.016 55.936 55.936 0 0 0-39.424-14.784z"
        }) ]))
    }), me = vue.defineComponent({
        name: "Search",
        __name: "search",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "m795.904 750.72 124.992 124.928a32 32 0 0 1-45.248 45.248L750.656 795.904a416 416 0 1 1 45.248-45.248zM480 832a352 352 0 1 0 0-704 352 352 0 0 0 0 704"
        }) ]))
    }), he = vue.defineComponent({
        name: "Setting",
        __name: "setting",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M600.704 64a32 32 0 0 1 30.464 22.208l35.2 109.376c14.784 7.232 28.928 15.36 42.432 24.512l112.384-24.192a32 32 0 0 1 34.432 15.36L944.32 364.8a32 32 0 0 1-4.032 37.504l-77.12 85.12a357.12 357.12 0 0 1 0 49.024l77.12 85.248a32 32 0 0 1 4.032 37.504l-88.704 153.6a32 32 0 0 1-34.432 15.296L708.8 803.904c-13.44 9.088-27.648 17.28-42.368 24.512l-35.264 109.376A32 32 0 0 1 600.704 960H423.296a32 32 0 0 1-30.464-22.208L357.696 828.48a351.616 351.616 0 0 1-42.56-24.64l-112.32 24.256a32 32 0 0 1-34.432-15.36L79.68 659.2a32 32 0 0 1 4.032-37.504l77.12-85.248a357.12 357.12 0 0 1 0-48.896l-77.12-85.248A32 32 0 0 1 79.68 364.8l88.704-153.6a32 32 0 0 1 34.432-15.296l112.32 24.256c13.568-9.152 27.776-17.408 42.56-24.64l35.2-109.312A32 32 0 0 1 423.232 64H600.64zm-23.424 64H446.72l-36.352 113.088-24.512 11.968a294.113 294.113 0 0 0-34.816 20.096l-22.656 15.36-116.224-25.088-65.28 113.152 79.68 88.192-1.92 27.136a293.12 293.12 0 0 0 0 40.192l1.92 27.136-79.808 88.192 65.344 113.152 116.224-25.024 22.656 15.296a294.113 294.113 0 0 0 34.816 20.096l24.512 11.968L446.72 896h130.688l36.48-113.152 24.448-11.904a288.282 288.282 0 0 0 34.752-20.096l22.592-15.296 116.288 25.024 65.28-113.152-79.744-88.192 1.92-27.136a293.12 293.12 0 0 0 0-40.256l-1.92-27.136 79.808-88.128-65.344-113.152-116.288 24.96-22.592-15.232a287.616 287.616 0 0 0-34.752-20.096l-24.448-11.904L577.344 128zM512 320a192 192 0 1 1 0 384 192 192 0 0 1 0-384m0 64a128 128 0 1 0 0 256 128 128 0 0 0 0-256"
        }) ]))
    }), fe = vue.defineComponent({
        name: "TrophyBase",
        __name: "trophy-base",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            "xml:space": "preserve",
            style: {
                "enable-background": "new 0 0 1024 1024"
            },
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M918.4 201.6c-6.4-6.4-12.8-9.6-22.4-9.6H768V96c0-9.6-3.2-16-9.6-22.4C752 67.2 745.6 64 736 64H288c-9.6 0-16 3.2-22.4 9.6C259.2 80 256 86.4 256 96v96H128c-9.6 0-16 3.2-22.4 9.6-6.4 6.4-9.6 16-9.6 22.4 3.2 108.8 25.6 185.6 64 224 34.4 34.4 77.56 55.65 127.65 61.99 10.91 20.44 24.78 39.25 41.95 56.41 40.86 40.86 91 65.47 150.4 71.9V768h-96c-9.6 0-16 3.2-22.4 9.6-6.4 6.4-9.6 12.8-9.6 22.4s3.2 16 9.6 22.4c6.4 6.4 12.8 9.6 22.4 9.6h256c9.6 0 16-3.2 22.4-9.6 6.4-6.4 9.6-12.8 9.6-22.4s-3.2-16-9.6-22.4c-6.4-6.4-12.8-9.6-22.4-9.6h-96V637.26c59.4-7.71 109.54-30.01 150.4-70.86 17.2-17.2 31.51-36.06 42.81-56.55 48.93-6.51 90.02-27.7 126.79-61.85 38.4-38.4 60.8-112 64-224 0-6.4-3.2-16-9.6-22.4zM256 438.4c-19.2-6.4-35.2-19.2-51.2-35.2-22.4-22.4-35.2-70.4-41.6-147.2H256zm390.4 80C608 553.6 566.4 576 512 576s-99.2-19.2-134.4-57.6C342.4 480 320 438.4 320 384V128h384v256c0 54.4-19.2 99.2-57.6 134.4m172.8-115.2c-16 16-32 25.6-51.2 35.2V256h92.8c-6.4 76.8-19.2 124.8-41.6 147.2zM768 896H256c-9.6 0-16 3.2-22.4 9.6-6.4 6.4-9.6 12.8-9.6 22.4s3.2 16 9.6 22.4c6.4 6.4 12.8 9.6 22.4 9.6h512c9.6 0 16-3.2 22.4-9.6 6.4-6.4 9.6-12.8 9.6-22.4s-3.2-16-9.6-22.4c-6.4-6.4-12.8-9.6-22.4-9.6"
        }) ]))
    }), ge = vue.defineComponent({
        name: "Upload",
        __name: "upload",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M160 832h704a32 32 0 1 1 0 64H160a32 32 0 1 1 0-64m384-578.304V704h-64V247.296L237.248 490.048 192 444.8 508.8 128l316.8 316.8-45.312 45.248z"
        }) ]))
    }), ye = vue.defineComponent({
        name: "User",
        __name: "user",
        setup: e => (e, t) => (vue.openBlock(), vue.createElementBlock("svg", {
            xmlns: "http://www.w3.org/2000/svg",
            viewBox: "0 0 1024 1024"
        }, [ vue.createElementVNode("path", {
            fill: "currentColor",
            d: "M512 512a192 192 0 1 0 0-384 192 192 0 0 0 0 384m0 64a256 256 0 1 1 0-512 256 256 0 0 1 0 512m320 320v-96a96 96 0 0 0-96-96H288a96 96 0 0 0-96 96v96a32 32 0 1 1-64 0v-96a160 160 0 0 1 160-160h448a160 160 0 0 1 160 160v96a32 32 0 1 1-64 0"
        }) ]))
    });

    let we;

    const setActivePinia = e => we = e, ve = Symbol();

    function isPlainObject(e) {
        return e && "object" == typeof e && "[object Object]" === Object.prototype.toString.call(e) && "function" != typeof e.toJSON;
    }

    var be, xe;

    (xe = be || (be = {})).direct = "direct", xe.patchObject = "patch object", xe.patchFunction = "patch function";

    const noop = () => {};

    function addSubscription(e, t, n, a = noop) {
        e.push(t);
        const removeSubscription = () => {
            const n = e.indexOf(t);
            n > -1 && (e.splice(n, 1), a());
        };
        return !n && vue.getCurrentScope() && vue.onScopeDispose(removeSubscription), removeSubscription;
    }

    function triggerSubscriptions(e, ...t) {
        e.slice().forEach((e => {
            e(...t);
        }));
    }

    const fallbackRunWithContext = e => e(), _e = Symbol(), ke = Symbol();

    function mergeReactiveObjects(e, t) {
        e instanceof Map && t instanceof Map ? t.forEach(((t, n) => e.set(n, t))) : e instanceof Set && t instanceof Set && t.forEach(e.add, e);
        for (const n in t) {
            if (!t.hasOwnProperty(n)) continue;
            const a = t[n], o = e[n];
            isPlainObject(o) && isPlainObject(a) && e.hasOwnProperty(n) && !vue.isRef(a) && !vue.isReactive(a) ? e[n] = mergeReactiveObjects(o, a) : e[n] = a;
        }
        return e;
    }

    const qe = Symbol();

    const {assign: Ce} = Object;

    function createSetupStore(e, t, n = {}, a, o, r) {
        let l;
        const c = Ce({
            actions: {}
        }, n), f = {
            deep: !0
        };
        let g, w, v, b = [], x = [];
        const _ = a.state.value[e];
        let k;
        function $patch(t) {
            let n;
            g = w = !1, "function" == typeof t ? (t(a.state.value[e]), n = {
                type: be.patchFunction,
                storeId: e,
                events: v
            }) : (mergeReactiveObjects(a.state.value[e], t), n = {
                type: be.patchObject,
                payload: t,
                storeId: e,
                events: v
            });
            const o = k = Symbol();
            vue.nextTick().then((() => {
                k === o && (g = !0);
            })), w = !0, triggerSubscriptions(b, n, a.state.value[e]);
        }
        r || _ || (a.state.value[e] = {}), vue.ref({});
        const q = r ? function() {
            const {state: e} = n, t = e ? e() : {};
            this.$patch((e => {
                Ce(e, t);
            }));
        } : noop;
        const action = (t, n = "") => {
            if (_e in t) return t[ke] = n, t;
            const wrappedAction = function() {
                setActivePinia(a);
                const n = Array.from(arguments), o = [], s = [];
                let i;
                triggerSubscriptions(x, {
                    args: n,
                    name: wrappedAction[ke],
                    store: T,
                    after: function(e) {
                        o.push(e);
                    },
                    onError: function(e) {
                        s.push(e);
                    }
                });
                try {
                    i = t.apply(this && this.$id === e ? this : T, n);
                } catch (r) {
                    throw triggerSubscriptions(s, r), r;
                }
                return i instanceof Promise ? i.then((e => (triggerSubscriptions(o, e), e))).catch((e => (triggerSubscriptions(s, e), 
                Promise.reject(e)))) : (triggerSubscriptions(o, i), i);
            };
            return wrappedAction[_e] = !0, wrappedAction[ke] = n, wrappedAction;
        }, C = {
            _p: a,
            $id: e,
            $onAction: addSubscription.bind(null, x),
            $patch: $patch,
            $reset: q,
            $subscribe(t, n = {}) {
                const o = addSubscription(b, t, n.detached, (() => s())), s = l.run((() => vue.watch((() => a.state.value[e]), (a => {
                    ("sync" === n.flush ? w : g) && t({
                        storeId: e,
                        type: be.direct,
                        events: v
                    }, a);
                }), Ce({}, f, n))));
                return o;
            },
            $dispose: function() {
                l.stop(), b = [], x = [], a._s.delete(e);
            }
        }, T = vue.reactive(C);
        a._s.set(e, T);
        const A = (a._a && a._a.runWithContext || fallbackRunWithContext)((() => a._e.run((() => (l = vue.effectScope()).run((() => t({
            action: action
        })))))));
        for (const s in A) {
            const t = A[s];
            if (vue.isRef(t) && (!vue.isRef(H = t) || !H.effect) || vue.isReactive(t)) r || (!_ || isPlainObject(S = t) && S.hasOwnProperty(qe) || (vue.isRef(t) ? t.value = _[s] : mergeReactiveObjects(t, _[s])), 
            a.state.value[e][s] = t); else if ("function" == typeof t) {
                const e = action(t, s);
                A[s] = e, c.actions[s] = t;
            }
        }
        var S, H;
        return Ce(T, A), Ce(vue.toRaw(T), A), Object.defineProperty(T, "$state", {
            get: () => a.state.value[e],
            set: e => {
                $patch((t => {
                    Ce(t, e);
                }));
            }
        }), a._p.forEach((e => {
            Ce(T, l.run((() => e({
                store: T,
                app: a._a,
                pinia: a,
                options: c
            }))));
        })), _ && r && n.hydrate && n.hydrate(T.$state, _), g = !0, w = !0, T;
    }

    function defineStore(e, t, n) {
        let a, o;
        const s = "function" == typeof t;
        function useStore(e, n) {
            const i = vue.hasInjectionContext();
            (e = e || (i ? vue.inject(ve, null) : null)) && setActivePinia(e), (e = we)._s.has(a) || (s ? createSetupStore(a, t, o, e) : function(e, t, n) {
                const {state: a, actions: o, getters: s} = t, i = n.state.value[e];
                createSetupStore(e, (function() {
                    i || (n.state.value[e] = a ? a() : {});
                    const t = vue.toRefs(n.state.value[e]);
                    return Ce(t, o, Object.keys(s || {}).reduce(((t, a) => (t[a] = vue.markRaw(vue.computed((() => {
                        setActivePinia(n);
                        const t = n._s.get(e);
                        return s[a].call(t, t);
                    }))), t)), {}));
                }), t, n, 0, !0);
            }(a, o, e));
            return e._s.get(a);
        }
        return "string" == typeof e ? (a = e, o = s ? n : t) : (o = e, a = e.id), useStore.$id = a, 
        useStore;
    }

    var Te = (() => "undefined" != typeof GM_deleteValue ? GM_deleteValue : void 0)(), Ae = (() => "undefined" != typeof GM_getResourceText ? GM_getResourceText : void 0)(), Se = (() => "undefined" != typeof GM_getValue ? GM_getValue : void 0)(), He = (() => "undefined" != typeof GM_info ? GM_info : void 0)(), Ue = (() => "undefined" != typeof GM_listValues ? GM_listValues : void 0)(), Ee = (() => "undefined" != typeof GM_setValue ? GM_setValue : void 0)(), ze = (() => "undefined" != typeof GM_xmlhttpRequest ? GM_xmlhttpRequest : void 0)(), $e = (() => "undefined" != typeof unsafeWindow ? unsafeWindow : void 0)();

    const je = "AiAsk_";

    class Cache {
        static set(e, t, n = 0) {
            e = je + e;
            const a = {
                value: t,
                expire: n > 0 ? Date.now() + 1e3 * n : 0
            };
            return Ee(e, a), Se(e);
        }
        static get(e, t = null) {
            const n = Se(e = je + e);
            return n && n.expire && n.expire < Date.now() ? (Te(e), t) : n ? n.value : t;
        }
        static match(e) {
            return e = je + e, Ue().filter((t => t.startsWith(e)));
        }
        static matchGet(e) {
            const t = je + e;
            let n = Ue().filter((e => e.startsWith(t))).map((e => {
                const t = Se(e, {
                    value: null,
                    expire: 0
                }).value;
                return t && (t.key = e.replace(je, "")), t;
            })).filter((e => null !== e));
            return n.sort(((e, t) => (t.createTime || 0) - (e.createTime || 0))), n;
        }
        static remove(e) {
            Te(je + e);
        }
        static clear() {
            Ue().filter((e => e.startsWith(je))).forEach(Te);
        }
        static matchRemove(e) {
            e = je + e, Ue().filter((t => t.startsWith(e))).forEach(Te);
        }
    }

    function getDefaultExportFromCjs(e) {
        return e && e.__esModule && Object.prototype.hasOwnProperty.call(e, "default") ? e.default : e;
    }

    var Ie, Le, Oe = {
        exports: {}
    }, Fe = {
        exports: {}
    };

    Ie = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/", Le = {
        rotl: function(e, t) {
            return e << t | e >>> 32 - t;
        },
        rotr: function(e, t) {
            return e << 32 - t | e >>> t;
        },
        endian: function(e) {
            if (e.constructor == Number) return 16711935 & Le.rotl(e, 8) | 4278255360 & Le.rotl(e, 24);
            for (var t = 0; t < e.length; t++) e[t] = Le.endian(e[t]);
            return e;
        },
        randomBytes: function(e) {
            for (var t = []; e > 0; e--) t.push(Math.floor(256 * Math.random()));
            return t;
        },
        bytesToWords: function(e) {
            for (var t = [], n = 0, a = 0; n < e.length; n++, a += 8) t[a >>> 5] |= e[n] << 24 - a % 32;
            return t;
        },
        wordsToBytes: function(e) {
            for (var t = [], n = 0; n < 32 * e.length; n += 8) t.push(e[n >>> 5] >>> 24 - n % 32 & 255);
            return t;
        },
        bytesToHex: function(e) {
            for (var t = [], n = 0; n < e.length; n++) t.push((e[n] >>> 4).toString(16)), t.push((15 & e[n]).toString(16));
            return t.join("");
        },
        hexToBytes: function(e) {
            for (var t = [], n = 0; n < e.length; n += 2) t.push(parseInt(e.substr(n, 2), 16));
            return t;
        },
        bytesToBase64: function(e) {
            for (var t = [], n = 0; n < e.length; n += 3) for (var a = e[n] << 16 | e[n + 1] << 8 | e[n + 2], o = 0; o < 4; o++) 8 * n + 6 * o <= 8 * e.length ? t.push(Ie.charAt(a >>> 6 * (3 - o) & 63)) : t.push("=");
            return t.join("");
        },
        base64ToBytes: function(e) {
            e = e.replace(/[^A-Z0-9+\/]/gi, "");
            for (var t = [], n = 0, a = 0; n < e.length; a = ++n % 4) 0 != a && t.push((Ie.indexOf(e.charAt(n - 1)) & Math.pow(2, -2 * a + 8) - 1) << 2 * a | Ie.indexOf(e.charAt(n)) >>> 6 - 2 * a);
            return t;
        }
    }, Fe.exports = Le;

    var Pe, Me, Ve, De, Ne, Be = Fe.exports, Ge = {
        utf8: {
            stringToBytes: function(e) {
                return Ge.bin.stringToBytes(unescape(encodeURIComponent(e)));
            },
            bytesToString: function(e) {
                return decodeURIComponent(escape(Ge.bin.bytesToString(e)));
            }
        },
        bin: {
            stringToBytes: function(e) {
                for (var t = [], n = 0; n < e.length; n++) t.push(255 & e.charCodeAt(n));
                return t;
            },
            bytesToString: function(e) {
                for (var t = [], n = 0; n < e.length; n++) t.push(String.fromCharCode(e[n]));
                return t.join("");
            }
        }
    }, Re = Ge, isBuffer_1 = function(e) {
        return null != e && (isBuffer(e) || function(e) {
            return "function" == typeof e.readFloatLE && "function" == typeof e.slice && isBuffer(e.slice(0, 0));
        }(e) || !!e._isBuffer);
    };

    function isBuffer(e) {
        return !!e.constructor && "function" == typeof e.constructor.isBuffer && e.constructor.isBuffer(e);
    }

    Pe = Be, Me = Re.utf8, Ve = isBuffer_1, De = Re.bin, (Ne = function(e, t) {
        e.constructor == String ? e = t && "binary" === t.encoding ? De.stringToBytes(e) : Me.stringToBytes(e) : Ve(e) ? e = Array.prototype.slice.call(e, 0) : Array.isArray(e) || e.constructor === Uint8Array || (e = e.toString());
        for (var n = Pe.bytesToWords(e), a = 8 * e.length, o = 1732584193, s = -271733879, i = -1732584194, r = 271733878, l = 0; l < n.length; l++) n[l] = 16711935 & (n[l] << 8 | n[l] >>> 24) | 4278255360 & (n[l] << 24 | n[l] >>> 8);
        n[a >>> 5] |= 128 << a % 32, n[14 + (a + 64 >>> 9 << 4)] = a;
        var c = Ne._ff, p = Ne._gg, u = Ne._hh, d = Ne._ii;
        for (l = 0; l < n.length; l += 16) {
            var m = o, h = s, f = i, g = r;
            o = c(o, s, i, r, n[l + 0], 7, -680876936), r = c(r, o, s, i, n[l + 1], 12, -389564586), 
            i = c(i, r, o, s, n[l + 2], 17, 606105819), s = c(s, i, r, o, n[l + 3], 22, -1044525330), 
            o = c(o, s, i, r, n[l + 4], 7, -176418897), r = c(r, o, s, i, n[l + 5], 12, 1200080426), 
            i = c(i, r, o, s, n[l + 6], 17, -1473231341), s = c(s, i, r, o, n[l + 7], 22, -45705983), 
            o = c(o, s, i, r, n[l + 8], 7, 1770035416), r = c(r, o, s, i, n[l + 9], 12, -1958414417), 
            i = c(i, r, o, s, n[l + 10], 17, -42063), s = c(s, i, r, o, n[l + 11], 22, -1990404162), 
            o = c(o, s, i, r, n[l + 12], 7, 1804603682), r = c(r, o, s, i, n[l + 13], 12, -40341101), 
            i = c(i, r, o, s, n[l + 14], 17, -1502002290), o = p(o, s = c(s, i, r, o, n[l + 15], 22, 1236535329), i, r, n[l + 1], 5, -165796510), 
            r = p(r, o, s, i, n[l + 6], 9, -1069501632), i = p(i, r, o, s, n[l + 11], 14, 643717713), 
            s = p(s, i, r, o, n[l + 0], 20, -373897302), o = p(o, s, i, r, n[l + 5], 5, -701558691), 
            r = p(r, o, s, i, n[l + 10], 9, 38016083), i = p(i, r, o, s, n[l + 15], 14, -660478335), 
            s = p(s, i, r, o, n[l + 4], 20, -405537848), o = p(o, s, i, r, n[l + 9], 5, 568446438), 
            r = p(r, o, s, i, n[l + 14], 9, -1019803690), i = p(i, r, o, s, n[l + 3], 14, -187363961), 
            s = p(s, i, r, o, n[l + 8], 20, 1163531501), o = p(o, s, i, r, n[l + 13], 5, -1444681467), 
            r = p(r, o, s, i, n[l + 2], 9, -51403784), i = p(i, r, o, s, n[l + 7], 14, 1735328473), 
            o = u(o, s = p(s, i, r, o, n[l + 12], 20, -1926607734), i, r, n[l + 5], 4, -378558), 
            r = u(r, o, s, i, n[l + 8], 11, -2022574463), i = u(i, r, o, s, n[l + 11], 16, 1839030562), 
            s = u(s, i, r, o, n[l + 14], 23, -35309556), o = u(o, s, i, r, n[l + 1], 4, -1530992060), 
            r = u(r, o, s, i, n[l + 4], 11, 1272893353), i = u(i, r, o, s, n[l + 7], 16, -155497632), 
            s = u(s, i, r, o, n[l + 10], 23, -1094730640), o = u(o, s, i, r, n[l + 13], 4, 681279174), 
            r = u(r, o, s, i, n[l + 0], 11, -358537222), i = u(i, r, o, s, n[l + 3], 16, -722521979), 
            s = u(s, i, r, o, n[l + 6], 23, 76029189), o = u(o, s, i, r, n[l + 9], 4, -640364487), 
            r = u(r, o, s, i, n[l + 12], 11, -421815835), i = u(i, r, o, s, n[l + 15], 16, 530742520), 
            o = d(o, s = u(s, i, r, o, n[l + 2], 23, -995338651), i, r, n[l + 0], 6, -198630844), 
            r = d(r, o, s, i, n[l + 7], 10, 1126891415), i = d(i, r, o, s, n[l + 14], 15, -1416354905), 
            s = d(s, i, r, o, n[l + 5], 21, -57434055), o = d(o, s, i, r, n[l + 12], 6, 1700485571), 
            r = d(r, o, s, i, n[l + 3], 10, -1894986606), i = d(i, r, o, s, n[l + 10], 15, -1051523), 
            s = d(s, i, r, o, n[l + 1], 21, -2054922799), o = d(o, s, i, r, n[l + 8], 6, 1873313359), 
            r = d(r, o, s, i, n[l + 15], 10, -30611744), i = d(i, r, o, s, n[l + 6], 15, -1560198380), 
            s = d(s, i, r, o, n[l + 13], 21, 1309151649), o = d(o, s, i, r, n[l + 4], 6, -145523070), 
            r = d(r, o, s, i, n[l + 11], 10, -1120210379), i = d(i, r, o, s, n[l + 2], 15, 718787259), 
            s = d(s, i, r, o, n[l + 9], 21, -343485551), o = o + m >>> 0, s = s + h >>> 0, i = i + f >>> 0, 
            r = r + g >>> 0;
        }
        return Pe.endian([ o, s, i, r ]);
    })._ff = function(e, t, n, a, o, s, i) {
        var r = e + (t & n | ~t & a) + (o >>> 0) + i;
        return (r << s | r >>> 32 - s) + t;
    }, Ne._gg = function(e, t, n, a, o, s, i) {
        var r = e + (t & a | n & ~a) + (o >>> 0) + i;
        return (r << s | r >>> 32 - s) + t;
    }, Ne._hh = function(e, t, n, a, o, s, i) {
        var r = e + (t ^ n ^ a) + (o >>> 0) + i;
        return (r << s | r >>> 32 - s) + t;
    }, Ne._ii = function(e, t, n, a, o, s, i) {
        var r = e + (n ^ (t | ~a)) + (o >>> 0) + i;
        return (r << s | r >>> 32 - s) + t;
    }, Ne._blocksize = 16, Ne._digestsize = 16, Oe.exports = function(e, t) {
        if (null == e) throw new Error("Illegal argument " + e);
        var n = Pe.wordsToBytes(Ne(e, t));
        return t && t.asBytes ? n : t && t.asString ? De.bytesToString(n) : Pe.bytesToHex(n);
    };

    const Je = getDefaultExportFromCjs(Oe.exports), Qe = [ {
        type: "hook",
        name: "\u4e91\u5e55\u5b66\u82d1hook",
        match: location.host.includes("w-ling.cn"),
        main: e => {
            $e.mainClass = R("#app")[0].__vue__.$route.path;
            let t = new MutationObserver((async e => {
                $e.mainClass !== R("#app")[0].__vue__.$route.path && ($e.mainClass = R("#app")[0].__vue__.$route.path, 
                "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 !== R(".selectDan").length;
                })), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "save",
        name: "\u4e91\u5e55\u5b66\u82d1\u6536\u5f55",
        match: () => location.host.includes("w-ling.cn") && location.href.includes("practiceRecord"),
        question: {
            html: ".selectDan >div >div",
            question: ".title",
            options: ".selectItem label .tagbq",
            type: ".question-box .tag",
            workType: "yunmuxueyuan",
            pageType: "yunmuxueyuan"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".selectDan >div >div");
            }));
        },
        answerHook: e => {
            const t = R(e.html).parent().find("h3").text().split("\u3001")[1];
            e.question = e.question.replace(/^\d+\u3001/, ""), e.question = e.question.replace(/\(\d+\u5206\)$/, "");
            let n = R(e.html).find(".anaylize > span:eq(0)").text().replace("\u4f5c\u7b54\u6b63\u786e\uff1a", "");
            switch ("" === n && (n = R(e.html).find(".falsanaly > span:eq(1)").text().replace("\u6b63\u786e\u7b54\u6848\uff1a", "")), 
            t) {
              case "\u5355\u9009\u9898":
              case "\u591a\u9009\u9898":
                let t = n.split("");
                if (e.answer = t.map((t => e.options[t.charCodeAt(0) - 65])), 0 === e.answer.length) return;
                e.answer.length > 1 ? e.type = "1" : e.type = "0";
                break;

              case "\u5224\u65ad\u9898":
                e.type = "3", "T" == n && (e.answer = [ "\u6b63\u786e" ]), "F" == n && (e.answer = [ "\u9519\u8bef" ]);
                break;

              case "\u586b\u7a7a\u9898":
                e.answer = R(e.html).find(".riganswer > span").first().nextAll("span").map(((e, t) => removeHtml(R(t).text()))).get(), 
                e.type = "2";
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u4e91\u5e55\u5b66\u82d1",
        tips: "",
        match: () => location.host.includes("w-ling.cn") && (location.href.includes("practicePaper") || location.href.includes("examIndex")),
        types: [ "0", "1", "3" ],
        question: {
            html: ".selectDan >div >div",
            question: ".title",
            options: ".selectItem label .tagbq",
            type: ".question-box .tag",
            workType: "yunmuxueyuan",
            pageType: "yunmuxueyuan"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".selectDan >div >div").length;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            e.question = e.question.replace(/^\d+\u3001/, ""), e.question = e.question.replace(/\(\d+\u5206\)$/, "");
            switch (R(e.html).parent().find("h4").text().split("\u3001")[1]) {
              case "\u5355\u9009\u9898":
                e.type = "0";
                break;

              case "\u591a\u9009\u9898":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
                e.type = "3", e.$options = R(e.html).find(".selectItem label"), e.options = e.$options.map(((e, t) => removeHtml(R(t).text()))).get(), 
                e.$options;
                break;

              case "\u586b\u7a7a\u9898":
                e.type = "2";
            }
            return e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "3":
                break;

              case "2":
                return R(e.html).find(".tiankong input").each(((t, n) => {
                    let a = R(n).parent()[0].__vue__;
                    R(n).val(e.answer[t]);
                    const o = new Event("input");
                    n.dispatchEvent(o), a.$emit("change", e.answer[t]);
                })), !1;
            }
            return !0;
        },
        finish: e => {}
    } ];

    class Answer {
        constructor() {}
        static score(e, t) {
            let n = Cache.get("api_" + e, {
                score: 0
            });
            n.score += t, Cache.set("api_" + e, n, 600);
        }
        static async getAllAnswers(e) {
            const t = [ this.getAnswer1(e) ];
            return Promise.all(t);
        }
        static async getAnswersFree(e) {
            const t = [ this.getMainAnswer(e), this.getAnswer1(e) ];
            return Promise.all(t);
        }
        static async getAnswer1(e) {
            let t = function() {
                let e = Array.from({
                    length: 4
                }, (() => Math.floor(255 * Math.random()))).join(".");
                return {
                    "X-Forwarded-For": e,
                    "X-Real-IP": e
                };
            }();
            return new Promise((n => {
                request("http://cx.icodef.com/wyn-nb?v=4", "POST", {
                    question: e.question
                }, t).then((e => {
                    let t = e[1];
                    try {
                        e = JSON.parse(e[0].responseText);
                    } catch (o) {
                        n({
                            form: "\u4e00\u4e4b\u9898\u5e93",
                            answer: null,
                            error: o,
                            duration: t
                        });
                    }
                    let a = "";
                    if (1 === e.code) {
                        let t = e.data.replace(/javascript:void\(0\);/g, "").trim().replace(/\n/g, "");
                        [ "\u53db\u9006", "\u516c\u4f17\u53f7", "\u674e\u6052\u96c5", "\u4e00\u4e4b" ].every((e => !t.includes(e))) && (a = t.split("#"));
                    }
                    n({
                        form: "\u4e00\u4e4b\u9898\u5e93",
                        answer: a,
                        duration: t
                    });
                })).catch((e => {
                    "timeout" === e && this.score("icodef", -1), n({
                        form: "\u4e00\u4e4b\u9898\u5e93",
                        answer: "",
                        msg: e,
                        duration: 5e3
                    });
                }));
            }));
        }
        static async getAnswer2(e) {
            return new Promise((t => {
                [ 0, 1, 2 ].includes(parseInt(e.type)) ? request("https://api.muketool.com/cx/v2/query", "POST", {
                    question: e.question,
                    type: parseInt(e.type)
                }, {}).then((e => {
                    let n = e[1];
                    e = JSON.parse(e[0].responseText), t({
                        form: "muketool",
                        answer: 1 === e.code ? e.data.split("#") : "",
                        duration: n
                    });
                })).catch((e => {
                    "timeout" === e && this.score("muketool", -1), t({
                        form: "muketool",
                        answer: ""
                    });
                })) : t({
                    form: "muketool",
                    answer: "",
                    duration: "\u4e0d\u652f\u6301\u7684\u9898\u578b"
                });
            }));
        }
        static getTimestamp() {
            return Math.floor((new Date).getTime() / 1e3);
        }
        static cacheAnswer(e) {
            const t = {
                type: e.type,
                question: e.question,
                options: e.options,
                answer: e.answer
            }, n = questionHash(t.type, t.question, t.options);
            t.createTime = this.getTimestamp(), Cache.set("ques1_" + n, t);
        }
        static async getCacheAnswer(e) {
            const t = questionHash(e.type, e.question, e.options);
            e.type, e.question, e.options;
            let n = Cache.get("ques1_" + t);
            return n ? {
                form: "\u672c\u5730\u7f13\u5b58",
                answer: n.answer,
                duration: 10
            } : {
                form: "\u672c\u5730\u7f13\u5b58",
                answer: "",
                duration: 10,
                msg: "\u672a\u627e\u5230\u7f13\u5b58"
            };
        }
        static getMainAnswer(e) {
            const t = {
                type: e.type,
                question: e.question,
                options: e.options.map((e => e)),
                workType: e.workType,
                pageType: e.pageType
            };
            return new Promise((e => {
                requestApi("https://www.aiask.site/v1/question/search", "POST", t, {}).then((t => {
                    let n = t[1];
                    200 === (t = JSON.parse(t[0].responseText)).code && t.data.answer ? e({
                        form: "\u7231\u95ee\u7b54\u9898\u5e93",
                        answer: t.data.answer,
                        duration: n,
                        msg: t.msg
                    }) : 401 === t.code ? e({
                        form: "\u7231\u95ee\u7b54\u9898\u5e93",
                        answer: "",
                        duration: n,
                        msg: t.message,
                        needLogin: !0
                    }) : e({
                        form: "\u7231\u95ee\u7b54\u9898\u5e93",
                        answer: "",
                        duration: n,
                        msg: t.message
                    });
                })).catch((t => {
                    e({
                        form: "\u7231\u95ee\u7b54\u9898\u5e93",
                        answer: "",
                        error: t,
                        duration: 10,
                        msg: "\u8bf7\u6c42\u5931\u8d25"
                    });
                }));
            }));
        }
        static async syncQuestionList(e) {
            return new Promise((t => {
                requestApi("https://www.aiask.site/v1/question/sync", "POST", e, {}).then((e => {
                    e[0].responseText, t(e[0].responseText);
                })).catch((e => {
                    t(e);
                }));
            }));
        }
        static async syncPaper(e) {
            return new Promise(((t, n) => {
                requestApi("https://www.aiask.site/v1/question/courseSync", "POST", e, {}).then((e => {
                    try {
                        const n = e[0].responseText, a = JSON.parse(n);
                        a && (200 === a.code || 0 === a.code || a.success), t(a);
                    } catch (n) {
                        t({
                            code: -1,
                            error: n,
                            msg: "\u54cd\u5e94\u89e3\u6790\u5931\u8d25"
                        });
                    }
                })).catch((e => {
                    t({
                        code: -1,
                        error: e,
                        msg: "\u7f51\u7edc\u8bf7\u6c42\u5931\u8d25"
                    });
                }));
            }));
        }
    }

    const defaultSetAnswer = async (e, t, n, a) => {
        var o;
        switch (e) {
          case "xx":
            for (let o = 0; o < n.$options.length; o++) if (t.includes(o)) {
                if (a.ischecked && a.ischecked(n.$options.eq(o))) continue;
                n.$options.eq(o).click(), await sleep(Math.floor(300 * Math.random() + 200));
            } else a.ischecked && a.ischecked(n.$options.eq(o)) && (n.$options.eq(o).click(), 
            await sleep(Math.floor(300 * Math.random() + 200)));
            break;

          case "pd":
            let e = t;
            0 == n.options.length ? n.$options.each(((t, n) => {
                isTrue(e) && isTrue(removeHtml(R(n).html())) && R(n).click(), isFalse(e) && isFalse(removeHtml(R(n).html())) && R(n).click();
            })) : n.$options.each(((t, a) => {
                isTrue(e) && isTrue(n.options[t]) && R(a).click(), isFalse(e) && isFalse(n.options[t]) && R(a).click();
            }));
            break;

          case "jd":
            R(n.html).find("textarea").each((function(e) {
                $e.UE.getEditor(R(this).attr("name")).ready((function() {
                    this.setContent(t[e].replace(/\u7b2c.\u7a7a:/g, ""));
                }));
            })), null == (o = R(n.html).find(".savebtndiv>a")) || o.click();
        }
    }, ApiAnswerMatch = (e, t, n = !1) => {
        const a = getAskStore();
        let o, s = 0, i = !0, r = t.type, l = t.html, c = [], p = [ "", c, t, a.rule ];
        switch (t.$options && "function" == typeof t.$options && (t.$options = t.$options()), 
        r) {
          case "0":
          case "1":
            for (let o = 0; o < e.length; o++) {
                let a = e[o].answer;
                "" == a && (a = []), n && (Array.isArray(a) ? a = a.map((e => {
                    let n = e.charCodeAt() - 65;
                    return t.options[n];
                })) : (a = a.replace(/[^a-zA-Z]/g, ""), a = a.split("").map((e => {
                    let n = e.charCodeAt() - 65;
                    return t.options[n];
                }))));
                let s = matchAnswer(a, t.options);
                e[o].match = s;
            }
            if (c = e.filter((e => e.match.length > 0)), 0 === c.length) return {
                res: e,
                haveAnswer: !1
            };
            if (c.length > 1) {
                if (!c.every((e => e.match.length === c[0].match.length))) {
                    let e = c[0];
                    for (let t = 1; t < c.length; t++) c[t].match.length > e.match.length && (e = c[t]);
                    c = [ e ];
                }
            }
            let a = c[0].match;
            p[0] = "xx", p[1] = a;
            break;

          case "3":
            if (c = e.map((e => {
                let t = e.answer;
                return "object" == typeof t && (t = t[0]), isTrue(t) ? e.answer = "\u6b63\u786e" : isFalse(t) ? e.answer = "\u9519\u8bef" : e.answer = "", 
                e;
            })), c = e.filter((e => "" !== e.answer)), 0 === c.length) return {
                res: e,
                haveAnswer: !1
            };
            p[0] = "pd", p[1] = c[0].answer;
            break;

          case "2":
          case "9":
          case "4":
          case "5":
          case "6":
          case "7":
            if (s = R(l).find("textarea").length, 0 === s && (s = t.$options.length), c = e.filter((e => e.answer.length > 0)), 
            0 === c.length) return {
                res: e,
                haveAnswer: !1
            };
            if (o = c[0].answer, "string" == typeof o && (o = [ o ]), 0 !== s && (c = c.filter((e => ("string" == typeof e.answer ? 1 : e.answer.length) === s)), 
            0 === c.length)) return {
                res: e,
                haveAnswer: !1
            };
            p[0] = "jd", p[1] = o;
            break;

          case "14":
            if (s = t.$options.length, c = e.filter((e => e.answer.length > 0 && e.answer.length === s)), 
            0 === c.length) return {
                res: e,
                haveAnswer: !1
            };
            if (o = c[0].answer, c = c.filter((e => ("string" == typeof e.answer ? 1 : e.answer.length) === s)), 
            0 === c.length) return {
                res: e,
                haveAnswer: !1
            };
            p[0] = "wxtk", p[1] = o;
            break;

          case "11":
            if (c = e.filter((e => "object" == typeof e.answer)), 0 === c.length) return {
                res: e,
                haveAnswer: !1
            };
            o = c[0].answer, p[0] = "lx", p[1] = o;
            break;

          default:
            return {
                res: e,
                haveAnswer: !1
            };
        }
        return a.rule.setAnswerHook && "function" == typeof a.rule.setAnswerHook && a.rule.setAnswerHook({
            type: r,
            answer: p[1],
            html: t.html,
            ques: t
        }), a.rule.setAnswer && "function" == typeof a.rule.setAnswer && (i = a.rule.setAnswer({
            type: r,
            answer: p[1],
            html: l,
            ques: t,
            rule: a.rule
        })), i && defaultSetAnswer(p[0], p[1], t, a.rule), {
            res: e,
            form: c ? c[0] : [],
            haveAnswer: !0
        };
    }, We = class _Paper {
        static getPaper(e) {
            return Cache.get(`${_Paper.prefix}_${e}`);
        }
        static getLastSyncedHashes(e) {
            const t = Cache.get(`${_Paper.lastSyncedPrefix}_${e}`, {
                questions: [],
                chapters: []
            });
            return {
                questions: new Set(t.questions || []),
                chapters: new Set(t.chapters || [])
            };
        }
        static setLastSyncedHashes(e, t, n) {
            Cache.set(`${_Paper.lastSyncedPrefix}_${e}`, {
                questions: t,
                chapters: n
            });
        }
        static compareAndGetNewData(e, t) {
            const n = _Paper.getLastSyncedHashes(t), a = new Set, o = new Set, s = new Map, i = new Map;
            e.chapter && Array.isArray(e.chapter) && e.chapter.forEach((e => {
                const t = e.hash;
                o.add(t);
                const n = new Map;
                e.question && Array.isArray(e.question) && e.question.forEach((e => {
                    const t = e.hash;
                    a.add(t), s.set(t, e), n.set(t, e);
                })), i.set(t, {
                    chapter: e,
                    questions: n
                });
            }));
            const r = [], l = [];
            a.forEach((e => {
                n.questions.has(e) || r.push(e);
            })), o.forEach((e => {
                n.chapters.has(e) || l.push(e);
            }));
            const c = {
                hash: e.hash,
                name: e.name,
                platform: e.platform,
                info: e.info,
                chapter: []
            };
            return i.forEach(((e, t) => {
                if (l.includes(t)) c.chapter.push({
                    hash: e.chapter.hash,
                    name: e.chapter.name,
                    question: Array.from(e.questions.values())
                }); else {
                    const t = [];
                    e.questions.forEach(((e, n) => {
                        r.includes(n) && t.push(e);
                    })), t.length > 0 && c.chapter.push({
                        hash: e.chapter.hash,
                        name: e.chapter.name,
                        question: t
                    });
                }
            })), {
                newData: c,
                newQuestionHashes: r,
                newChapterHashes: l
            };
        }
        static async setPaper(e, t) {
            if (!e || !t) return;
            const n = _Paper.getPaper(e) || {
                chapter: []
            };
            t.chapter && t.chapter.forEach((e => {
                const t = n.chapter.find((t => t.hash === e.hash));
                t ? (e.question.forEach((e => {
                    const n = t.question.findIndex((t => t.hash === e.hash));
                    -1 !== n ? t.question[n] = e : t.question.push(e);
                })), Object.keys(e).forEach((n => {
                    "question" !== n && (t[n] = e[n]);
                }))) : n.chapter.push(e);
            })), Object.keys(t).forEach((e => {
                "chapter" !== e && (n[e] = t[e]);
            })), Cache.set(`${_Paper.prefix}_${e}`, n);
            const {newData: a, newQuestionHashes: o, newChapterHashes: s} = _Paper.compareAndGetNewData(n, e);
            if (o.length > 0 || s.length > 0) {
                if (0 === a.chapter.length) return;
                o.length, s.length;
                try {
                    const t = await Answer.syncPaper(a);
                    let n;
                    if ("string" == typeof t) try {
                        n = JSON.parse(t);
                    } catch (i) {
                        return;
                    } else n = t;
                    if (!n || 200 !== n.code && 0 !== n.code && !0 !== n.success) JSON.stringify(n); else {
                        const t = _Paper.getLastSyncedHashes(e), n = Array.from(new Set([ ...t.questions, ...o ])), a = Array.from(new Set([ ...t.chapters, ...s ]));
                        _Paper.setLastSyncedHashes(e, n, a), o.length, s.length;
                    }
                } catch (r) {}
            }
        }
        static hasChapter(e, t) {
            const n = _Paper.getPaper(e);
            return !(!n || !n.chapter) && n.chapter.some((e => e.hash === t));
        }
        static getAllPapers() {
            return Cache.matchGet(`${_Paper.prefix}_`);
        }
    };

    __publicField(We, "prefix", "paper_"), __publicField(We, "lastSyncedPrefix", "paper_last_synced_");

    let Ke = We;

    var Ye = {
        parse: function(e) {
            var t = Ye._bin, n = new Uint8Array(e), a = 0;
            t.readFixed(n, a), a += 4;
            var o = t.readUshort(n, a);
            a += 2, t.readUshort(n, a), a += 2, t.readUshort(n, a), a += 2, t.readUshort(n, a), 
            a += 2;
            for (var s = [ "cmap", "head", "hhea", "maxp", "hmtx", "name", "OS/2", "post", "loca", "glyf", "kern", "CFF ", "GPOS", "GSUB", "SVG " ], i = {
                _data: n
            }, r = {}, l = 0; l < o; l++) {
                var c = t.readASCII(n, a, 4);
                a += 4, t.readUint(n, a), a += 4;
                var p = t.readUint(n, a);
                a += 4;
                var u = t.readUint(n, a);
                a += 4, r[c] = {
                    offset: p,
                    length: u
                };
            }
            for (l = 0; l < s.length; l++) {
                var d = s[l];
                r[d] && (i[d.trim()] = Ye[d.trim()].parse(n, r[d].offset, r[d].length, i));
            }
            return i;
        },
        _tabOffset: function(e, t) {
            for (var n = Ye._bin, a = n.readUshort(e, 4), o = 12, s = 0; s < a; s++) {
                var i = n.readASCII(e, o, 4);
                o += 4, n.readUint(e, o), o += 4;
                var r = n.readUint(e, o);
                if (o += 4, n.readUint(e, o), o += 4, i == t) return r;
            }
            return 0;
        }
    };

    Ye._bin = {
        readFixed: function(e, t) {
            return (e[t] << 8 | e[t + 1]) + (e[t + 2] << 8 | e[t + 3]) / 65540;
        },
        readF2dot14: function(e, t) {
            return Ye._bin.readShort(e, t) / 16384;
        },
        readInt: function(e, t) {
            var n = Ye._bin.t.uint8;
            return n[0] = e[t + 3], n[1] = e[t + 2], n[2] = e[t + 1], n[3] = e[t], Ye._bin.t.int32[0];
        },
        readInt8: function(e, t) {
            return Ye._bin.t.uint8[0] = e[t], Ye._bin.t.int8[0];
        },
        readShort: function(e, t) {
            var n = Ye._bin.t.uint8;
            return n[1] = e[t], n[0] = e[t + 1], Ye._bin.t.int16[0];
        },
        readUshort: function(e, t) {
            return e[t] << 8 | e[t + 1];
        },
        readUshorts: function(e, t, n) {
            for (var a = [], o = 0; o < n; o++) a.push(Ye._bin.readUshort(e, t + 2 * o));
            return a;
        },
        readUint: function(e, t) {
            var n = Ye._bin.t.uint8;
            return n[3] = e[t], n[2] = e[t + 1], n[1] = e[t + 2], n[0] = e[t + 3], Ye._bin.t.uint32[0];
        },
        readUint64: function(e, t) {
            return 4294967296 * Ye._bin.readUint(e, t) + Ye._bin.readUint(e, t + 4);
        },
        readASCII: function(e, t, n) {
            for (var a = "", o = 0; o < n; o++) a += String.fromCharCode(e[t + o]);
            return a;
        },
        readUnicode: function(e, t, n) {
            for (var a = "", o = 0; o < n; o++) {
                var s = e[t++] << 8 | e[t++];
                a += String.fromCharCode(s);
            }
            return a;
        },
        _tdec: window.TextDecoder ? new window.TextDecoder : null,
        readUTF8: function(e, t, n) {
            var a = Ye._bin._tdec;
            return a && 0 == t && n == e.length ? a.decode(e) : Ye._bin.readASCII(e, t, n);
        },
        readBytes: function(e, t, n) {
            for (var a = [], o = 0; o < n; o++) a.push(e[t + o]);
            return a;
        },
        readASCIIArray: function(e, t, n) {
            for (var a = [], o = 0; o < n; o++) a.push(String.fromCharCode(e[t + o]));
            return a;
        }
    }, Ye._bin.t = {
        buff: new ArrayBuffer(8)
    }, Ye._bin.t.int8 = new Int8Array(Ye._bin.t.buff), Ye._bin.t.uint8 = new Uint8Array(Ye._bin.t.buff), 
    Ye._bin.t.int16 = new Int16Array(Ye._bin.t.buff), Ye._bin.t.uint16 = new Uint16Array(Ye._bin.t.buff), 
    Ye._bin.t.int32 = new Int32Array(Ye._bin.t.buff), Ye._bin.t.uint32 = new Uint32Array(Ye._bin.t.buff), 
    Ye._lctf = {}, Ye._lctf.parse = function(e, t, n, a, o) {
        var s = Ye._bin, i = {}, r = t;
        s.readFixed(e, t), t += 4;
        var l = s.readUshort(e, t);
        t += 2;
        var c = s.readUshort(e, t);
        t += 2;
        var p = s.readUshort(e, t);
        return t += 2, i.scriptList = Ye._lctf.readScriptList(e, r + l), i.featureList = Ye._lctf.readFeatureList(e, r + c), 
        i.lookupList = Ye._lctf.readLookupList(e, r + p, o), i;
    }, Ye._lctf.readLookupList = function(e, t, n) {
        var a = Ye._bin, o = t, s = [], i = a.readUshort(e, t);
        t += 2;
        for (var r = 0; r < i; r++) {
            var l = a.readUshort(e, t);
            t += 2;
            var c = Ye._lctf.readLookupTable(e, o + l, n);
            s.push(c);
        }
        return s;
    }, Ye._lctf.readLookupTable = function(e, t, n) {
        var a = Ye._bin, o = t, s = {
            tabs: []
        };
        s.ltype = a.readUshort(e, t), t += 2, s.flag = a.readUshort(e, t), t += 2;
        var i = a.readUshort(e, t);
        t += 2;
        for (var r = 0; r < i; r++) {
            var l = a.readUshort(e, t);
            t += 2;
            var c = n(e, s.ltype, o + l);
            s.tabs.push(c);
        }
        return s;
    }, Ye._lctf.numOfOnes = function(e) {
        for (var t = 0, n = 0; n < 32; n++) e >>> n & 1 && t++;
        return t;
    }, Ye._lctf.readClassDef = function(e, t) {
        var n = Ye._bin, a = [], o = n.readUshort(e, t);
        if (t += 2, 1 == o) {
            var s = n.readUshort(e, t);
            t += 2;
            var i = n.readUshort(e, t);
            t += 2;
            for (var r = 0; r < i; r++) a.push(s + r), a.push(s + r), a.push(n.readUshort(e, t)), 
            t += 2;
        }
        if (2 == o) {
            var l = n.readUshort(e, t);
            t += 2;
            for (r = 0; r < l; r++) a.push(n.readUshort(e, t)), t += 2, a.push(n.readUshort(e, t)), 
            t += 2, a.push(n.readUshort(e, t)), t += 2;
        }
        return a;
    }, Ye._lctf.getInterval = function(e, t) {
        for (var n = 0; n < e.length; n += 3) {
            var a = e[n], o = e[n + 1];
            if (e[n + 2], a <= t && t <= o) return n;
        }
        return -1;
    }, Ye._lctf.readValueRecord = function(e, t, n) {
        var a = Ye._bin, o = [];
        return o.push(1 & n ? a.readShort(e, t) : 0), t += 1 & n ? 2 : 0, o.push(2 & n ? a.readShort(e, t) : 0), 
        t += 2 & n ? 2 : 0, o.push(4 & n ? a.readShort(e, t) : 0), t += 4 & n ? 2 : 0, o.push(8 & n ? a.readShort(e, t) : 0), 
        t += 8 & n ? 2 : 0, o;
    }, Ye._lctf.readCoverage = function(e, t) {
        var n = Ye._bin, a = {};
        a.fmt = n.readUshort(e, t), t += 2;
        var o = n.readUshort(e, t);
        return t += 2, 1 == a.fmt && (a.tab = n.readUshorts(e, t, o)), 2 == a.fmt && (a.tab = n.readUshorts(e, t, 3 * o)), 
        a;
    }, Ye._lctf.coverageIndex = function(e, t) {
        var n = e.tab;
        if (1 == e.fmt) return n.indexOf(t);
        if (2 == e.fmt) {
            var a = Ye._lctf.getInterval(n, t);
            if (-1 != a) return n[a + 2] + (t - n[a]);
        }
        return -1;
    }, Ye._lctf.readFeatureList = function(e, t) {
        var n = Ye._bin, a = t, o = [], s = n.readUshort(e, t);
        t += 2;
        for (var i = 0; i < s; i++) {
            var r = n.readASCII(e, t, 4);
            t += 4;
            var l = n.readUshort(e, t);
            t += 2, o.push({
                tag: r.trim(),
                tab: Ye._lctf.readFeatureTable(e, a + l)
            });
        }
        return o;
    }, Ye._lctf.readFeatureTable = function(e, t) {
        var n = Ye._bin;
        n.readUshort(e, t), t += 2;
        var a = n.readUshort(e, t);
        t += 2;
        for (var o = [], s = 0; s < a; s++) o.push(n.readUshort(e, t + 2 * s));
        return o;
    }, Ye._lctf.readScriptList = function(e, t) {
        var n = Ye._bin, a = t, o = {}, s = n.readUshort(e, t);
        t += 2;
        for (var i = 0; i < s; i++) {
            var r = n.readASCII(e, t, 4);
            t += 4;
            var l = n.readUshort(e, t);
            t += 2, o[r.trim()] = Ye._lctf.readScriptTable(e, a + l);
        }
        return o;
    }, Ye._lctf.readScriptTable = function(e, t) {
        var n = Ye._bin, a = t, o = {}, s = n.readUshort(e, t);
        t += 2, o.default = Ye._lctf.readLangSysTable(e, a + s);
        var i = n.readUshort(e, t);
        t += 2;
        for (var r = 0; r < i; r++) {
            var l = n.readASCII(e, t, 4);
            t += 4;
            var c = n.readUshort(e, t);
            t += 2, o[l.trim()] = Ye._lctf.readLangSysTable(e, a + c);
        }
        return o;
    }, Ye._lctf.readLangSysTable = function(e, t) {
        var n = Ye._bin, a = {};
        n.readUshort(e, t), t += 2, a.reqFeature = n.readUshort(e, t), t += 2;
        var o = n.readUshort(e, t);
        return t += 2, a.features = n.readUshorts(e, t, o), a;
    }, Ye.CFF = {}, Ye.CFF.parse = function(e, t, n) {
        var a = Ye._bin;
        (e = new Uint8Array(e.buffer, t, n))[t = 0], e[++t], e[++t], e[++t], t++;
        var o = [];
        t = Ye.CFF.readIndex(e, t, o);
        for (var s = [], i = 0; i < o.length - 1; i++) s.push(a.readASCII(e, t + o[i], o[i + 1] - o[i]));
        t += o[o.length - 1];
        var r = [];
        t = Ye.CFF.readIndex(e, t, r);
        var l = [];
        for (i = 0; i < r.length - 1; i++) l.push(Ye.CFF.readDict(e, t + r[i], t + r[i + 1]));
        t += r[r.length - 1];
        var c = l[0], p = [];
        t = Ye.CFF.readIndex(e, t, p);
        var u = [];
        for (i = 0; i < p.length - 1; i++) u.push(a.readASCII(e, t + p[i], p[i + 1] - p[i]));
        if (t += p[p.length - 1], Ye.CFF.readSubrs(e, t, c), c.CharStrings) {
            t = c.CharStrings;
            p = [];
            t = Ye.CFF.readIndex(e, t, p);
            var d = [];
            for (i = 0; i < p.length - 1; i++) d.push(a.readBytes(e, t + p[i], p[i + 1] - p[i]));
            c.CharStrings = d;
        }
        c.Encoding && (c.Encoding = Ye.CFF.readEncoding(e, c.Encoding, c.CharStrings.length)), 
        c.charset && (c.charset = Ye.CFF.readCharset(e, c.charset, c.CharStrings.length)), 
        c.Private && (t = c.Private[1], c.Private = Ye.CFF.readDict(e, t, t + c.Private[0]), 
        c.Private.Subrs && Ye.CFF.readSubrs(e, t + c.Private.Subrs, c.Private));
        var m = {};
        for (var h in c) -1 != [ "FamilyName", "FullName", "Notice", "version", "Copyright" ].indexOf(h) ? m[h] = u[c[h] - 426 + 35] : m[h] = c[h];
        return m;
    }, Ye.CFF.readSubrs = function(e, t, n) {
        var a = Ye._bin, o = [];
        t = Ye.CFF.readIndex(e, t, o);
        var s, i = o.length;
        s = i < 1240 ? 107 : i < 33900 ? 1131 : 32768, n.Bias = s, n.Subrs = [];
        for (var r = 0; r < o.length - 1; r++) n.Subrs.push(a.readBytes(e, t + o[r], o[r + 1] - o[r]));
    }, Ye.CFF.tableSE = [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 0, 111, 112, 113, 114, 0, 115, 116, 117, 118, 119, 120, 121, 122, 0, 123, 0, 124, 125, 126, 127, 128, 129, 130, 131, 0, 132, 133, 0, 134, 135, 136, 137, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 138, 0, 139, 0, 0, 0, 0, 140, 141, 142, 143, 0, 0, 0, 0, 0, 144, 0, 0, 0, 145, 0, 0, 146, 147, 148, 149, 0, 0, 0, 0 ], 
    Ye.CFF.glyphByUnicode = function(e, t) {
        for (var n = 0; n < e.charset.length; n++) if (e.charset[n] == t) return n;
        return -1;
    }, Ye.CFF.glyphBySE = function(e, t) {
        return t < 0 || t > 255 ? -1 : Ye.CFF.glyphByUnicode(e, Ye.CFF.tableSE[t]);
    }, Ye.CFF.readEncoding = function(e, t, n) {
        Ye._bin;
        var a = [ ".notdef" ], o = e[t];
        if (t++, 0 != o) throw "error: unknown encoding format: " + o;
        var s = e[t];
        t++;
        for (var i = 0; i < s; i++) a.push(e[t + i]);
        return a;
    }, Ye.CFF.readCharset = function(e, t, n) {
        var a = Ye._bin, o = [ ".notdef" ], s = e[t];
        if (t++, 0 == s) for (var i = 0; i < n; i++) {
            var r = a.readUshort(e, t);
            t += 2, o.push(r);
        } else {
            if (1 != s && 2 != s) throw "error: format: " + s;
            for (;o.length < n; ) {
                r = a.readUshort(e, t);
                t += 2;
                var l = 0;
                1 == s ? (l = e[t], t++) : (l = a.readUshort(e, t), t += 2);
                for (i = 0; i <= l; i++) o.push(r), r++;
            }
        }
        return o;
    }, Ye.CFF.readIndex = function(e, t, n) {
        var a = Ye._bin, o = a.readUshort(e, t), s = e[t += 2];
        if (t++, 1 == s) for (var i = 0; i < o + 1; i++) n.push(e[t + i]); else if (2 == s) for (i = 0; i < o + 1; i++) n.push(a.readUshort(e, t + 2 * i)); else if (3 == s) for (i = 0; i < o + 1; i++) n.push(16777215 & a.readUint(e, t + 3 * i - 1)); else if (0 != o) throw "unsupported offset size: " + s + ", count: " + o;
        return (t += (o + 1) * s) - 1;
    }, Ye.CFF.getCharString = function(e, t, n) {
        var a = Ye._bin, o = e[t], s = e[t + 1];
        e[t + 2], e[t + 3], e[t + 4];
        var i = 1, r = null, l = null;
        o <= 20 && (r = o, i = 1), 12 == o && (r = 100 * o + s, i = 2), 21 <= o && o <= 27 && (r = o, 
        i = 1), 28 == o && (l = a.readShort(e, t + 1), i = 3), 29 <= o && o <= 31 && (r = o, 
        i = 1), 32 <= o && o <= 246 && (l = o - 139, i = 1), 247 <= o && o <= 250 && (l = 256 * (o - 247) + s + 108, 
        i = 2), 251 <= o && o <= 254 && (l = 256 * -(o - 251) - s - 108, i = 2), 255 == o && (l = a.readInt(e, t + 1) / 65535, 
        i = 5), n.val = null != l ? l : "o" + r, n.size = i;
    }, Ye.CFF.readCharString = function(e, t, n) {
        for (var a = t + n, o = Ye._bin, s = []; t < a; ) {
            var i = e[t], r = e[t + 1];
            e[t + 2], e[t + 3], e[t + 4];
            var l = 1, c = null, p = null;
            i <= 20 && (c = i, l = 1), 12 == i && (c = 100 * i + r, l = 2), 19 != i && 20 != i || (c = i, 
            l = 2), 21 <= i && i <= 27 && (c = i, l = 1), 28 == i && (p = o.readShort(e, t + 1), 
            l = 3), 29 <= i && i <= 31 && (c = i, l = 1), 32 <= i && i <= 246 && (p = i - 139, 
            l = 1), 247 <= i && i <= 250 && (p = 256 * (i - 247) + r + 108, l = 2), 251 <= i && i <= 254 && (p = 256 * -(i - 251) - r - 108, 
            l = 2), 255 == i && (p = o.readInt(e, t + 1) / 65535, l = 5), s.push(null != p ? p : "o" + c), 
            t += l;
        }
        return s;
    }, Ye.CFF.readDict = function(e, t, n) {
        for (var a = Ye._bin, o = {}, s = []; t < n; ) {
            var i = e[t], r = e[t + 1];
            e[t + 2], e[t + 3], e[t + 4];
            var l = 1, c = null, p = null;
            if (28 == i && (p = a.readShort(e, t + 1), l = 3), 29 == i && (p = a.readInt(e, t + 1), 
            l = 5), 32 <= i && i <= 246 && (p = i - 139, l = 1), 247 <= i && i <= 250 && (p = 256 * (i - 247) + r + 108, 
            l = 2), 251 <= i && i <= 254 && (p = 256 * -(i - 251) - r - 108, l = 2), 255 == i) throw p = a.readInt(e, t + 1) / 65535, 
            l = 5, "unknown number";
            if (30 == i) {
                var u = [];
                for (l = 1; ;) {
                    var d = e[t + l];
                    l++;
                    var m = d >> 4, h = 15 & d;
                    if (15 != m && u.push(m), 15 != h && u.push(h), 15 == h) break;
                }
                for (var f = "", g = [ 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, ".", "e", "e-", "reserved", "-", "endOfNumber" ], y = 0; y < u.length; y++) f += g[u[y]];
                p = parseFloat(f);
            }
            if (i <= 21) if (c = [ "version", "Notice", "FullName", "FamilyName", "Weight", "FontBBox", "BlueValues", "OtherBlues", "FamilyBlues", "FamilyOtherBlues", "StdHW", "StdVW", "escape", "UniqueID", "XUID", "charset", "Encoding", "CharStrings", "Private", "Subrs", "defaultWidthX", "nominalWidthX" ][i], 
            l = 1, 12 == i) c = [ "Copyright", "isFixedPitch", "ItalicAngle", "UnderlinePosition", "UnderlineThickness", "PaintType", "CharstringType", "FontMatrix", "StrokeWidth", "BlueScale", "BlueShift", "BlueFuzz", "StemSnapH", "StemSnapV", "ForceBold", 0, 0, "LanguageGroup", "ExpansionFactor", "initialRandomSeed", "SyntheticBase", "PostScript", "BaseFontName", "BaseFontBlend", 0, 0, 0, 0, 0, 0, "ROS", "CIDFontVersion", "CIDFontRevision", "CIDFontType", "CIDCount", "UIDBase", "FDArray", "FDSelect", "FontName" ][r], 
            l = 2;
            null != c ? (o[c] = 1 == s.length ? s[0] : s, s = []) : s.push(p), t += l;
        }
        return o;
    }, Ye.cmap = {}, Ye.cmap.parse = function(e, t, n) {
        e = new Uint8Array(e.buffer, t, n), t = 0;
        var a = Ye._bin, o = {};
        a.readUshort(e, t), t += 2;
        var s = a.readUshort(e, t);
        t += 2;
        var i = [];
        o.tables = [];
        for (var r = 0; r < s; r++) {
            var l = a.readUshort(e, t);
            t += 2;
            var c = a.readUshort(e, t);
            t += 2;
            var p = a.readUint(e, t);
            t += 4;
            var u = "p" + l + "e" + c, d = i.indexOf(p);
            if (-1 == d) {
                var m;
                d = o.tables.length, i.push(p);
                var h = a.readUshort(e, p);
                0 == h ? m = Ye.cmap.parse0(e, p) : 4 == h ? m = Ye.cmap.parse4(e, p) : 6 == h ? m = Ye.cmap.parse6(e, p) : 12 == h ? m = Ye.cmap.parse12(e, p) : console.log("unknown format: " + h, l, c, p), 
                o.tables.push(m);
            }
            if (null != o[u]) throw "multiple tables for one platform+encoding";
            o[u] = d;
        }
        return o;
    }, Ye.cmap.parse0 = function(e, t) {
        var n = Ye._bin, a = {};
        a.format = n.readUshort(e, t), t += 2;
        var o = n.readUshort(e, t);
        t += 2, n.readUshort(e, t), t += 2, a.map = [];
        for (var s = 0; s < o - 6; s++) a.map.push(e[t + s]);
        return a;
    }, Ye.cmap.parse4 = function(e, t) {
        var n = Ye._bin, a = t, o = {};
        o.format = n.readUshort(e, t), t += 2;
        var s = n.readUshort(e, t);
        t += 2, n.readUshort(e, t), t += 2;
        var i = n.readUshort(e, t);
        t += 2;
        var r = i / 2;
        o.searchRange = n.readUshort(e, t), t += 2, o.entrySelector = n.readUshort(e, t), 
        t += 2, o.rangeShift = n.readUshort(e, t), t += 2, o.endCount = n.readUshorts(e, t, r), 
        t += 2 * r, t += 2, o.startCount = n.readUshorts(e, t, r), t += 2 * r, o.idDelta = [];
        for (var l = 0; l < r; l++) o.idDelta.push(n.readShort(e, t)), t += 2;
        for (o.idRangeOffset = n.readUshorts(e, t, r), t += 2 * r, o.glyphIdArray = []; t < a + s; ) o.glyphIdArray.push(n.readUshort(e, t)), 
        t += 2;
        return o;
    }, Ye.cmap.parse6 = function(e, t) {
        var n = Ye._bin, a = {};
        a.format = n.readUshort(e, t), t += 2, n.readUshort(e, t), t += 2, n.readUshort(e, t), 
        t += 2, a.firstCode = n.readUshort(e, t), t += 2;
        var o = n.readUshort(e, t);
        t += 2, a.glyphIdArray = [];
        for (var s = 0; s < o; s++) a.glyphIdArray.push(n.readUshort(e, t)), t += 2;
        return a;
    }, Ye.cmap.parse12 = function(e, t) {
        var n = Ye._bin, a = {};
        a.format = n.readUshort(e, t), t += 2, t += 2, n.readUint(e, t), t += 4, n.readUint(e, t), 
        t += 4;
        var o = n.readUint(e, t);
        t += 4, a.groups = [];
        for (var s = 0; s < o; s++) {
            var i = t + 12 * s, r = n.readUint(e, i + 0), l = n.readUint(e, i + 4), c = n.readUint(e, i + 8);
            a.groups.push([ r, l, c ]);
        }
        return a;
    }, Ye.glyf = {}, Ye.glyf.parse = function(e, t, n, a) {
        for (var o = [], s = 0; s < a.maxp.numGlyphs; s++) o.push(null);
        return o;
    }, Ye.glyf._parseGlyf = function(e, t) {
        var n = Ye._bin, a = e._data, o = Ye._tabOffset(a, "glyf") + e.loca[t];
        if (e.loca[t] == e.loca[t + 1]) return null;
        var s = {};
        if (s.noc = n.readShort(a, o), o += 2, s.xMin = n.readShort(a, o), o += 2, s.yMin = n.readShort(a, o), 
        o += 2, s.xMax = n.readShort(a, o), o += 2, s.yMax = n.readShort(a, o), o += 2, 
        s.xMin >= s.xMax || s.yMin >= s.yMax) return null;
        if (s.noc > 0) {
            s.endPts = [];
            for (var i = 0; i < s.noc; i++) s.endPts.push(n.readUshort(a, o)), o += 2;
            var r = n.readUshort(a, o);
            if (o += 2, a.length - o < r) return null;
            s.instructions = n.readBytes(a, o, r), o += r;
            var l = s.endPts[s.noc - 1] + 1;
            s.flags = [];
            for (i = 0; i < l; i++) {
                var c = a[o];
                if (o++, s.flags.push(c), 8 & c) {
                    var p = a[o];
                    o++;
                    for (var u = 0; u < p; u++) s.flags.push(c), i++;
                }
            }
            s.xs = [];
            for (i = 0; i < l; i++) {
                var d = !!(2 & s.flags[i]), m = !!(16 & s.flags[i]);
                d ? (s.xs.push(m ? a[o] : -a[o]), o++) : m ? s.xs.push(0) : (s.xs.push(n.readShort(a, o)), 
                o += 2);
            }
            s.ys = [];
            for (i = 0; i < l; i++) {
                d = !!(4 & s.flags[i]), m = !!(32 & s.flags[i]);
                d ? (s.ys.push(m ? a[o] : -a[o]), o++) : m ? s.ys.push(0) : (s.ys.push(n.readShort(a, o)), 
                o += 2);
            }
            var h = 0, f = 0;
            for (i = 0; i < l; i++) h += s.xs[i], f += s.ys[i], s.xs[i] = h, s.ys[i] = f;
        } else {
            var g;
            s.parts = [];
            do {
                g = n.readUshort(a, o), o += 2;
                var y = {
                    m: {
                        a: 1,
                        b: 0,
                        c: 0,
                        d: 1,
                        tx: 0,
                        ty: 0
                    },
                    p1: -1,
                    p2: -1
                };
                if (s.parts.push(y), y.glyphIndex = n.readUshort(a, o), o += 2, 1 & g) {
                    var w = n.readShort(a, o);
                    o += 2;
                    var v = n.readShort(a, o);
                    o += 2;
                } else {
                    w = n.readInt8(a, o);
                    o++;
                    v = n.readInt8(a, o);
                    o++;
                }
                2 & g ? (y.m.tx = w, y.m.ty = v) : (y.p1 = w, y.p2 = v), 8 & g ? (y.m.a = y.m.d = n.readF2dot14(a, o), 
                o += 2) : 64 & g ? (y.m.a = n.readF2dot14(a, o), o += 2, y.m.d = n.readF2dot14(a, o), 
                o += 2) : 128 & g && (y.m.a = n.readF2dot14(a, o), o += 2, y.m.b = n.readF2dot14(a, o), 
                o += 2, y.m.c = n.readF2dot14(a, o), o += 2, y.m.d = n.readF2dot14(a, o), o += 2);
            } while (32 & g);
            if (256 & g) {
                var b = n.readUshort(a, o);
                o += 2, s.instr = [];
                for (i = 0; i < b; i++) s.instr.push(a[o]), o++;
            }
        }
        return s;
    }, Ye.GPOS = {}, Ye.GPOS.parse = function(e, t, n, a) {
        return Ye._lctf.parse(e, t, n, a, Ye.GPOS.subt);
    }, Ye.GPOS.subt = function(e, t, n) {
        if (2 != t) return null;
        var a = Ye._bin, o = n, s = {};
        s.format = a.readUshort(e, n), n += 2;
        var i = a.readUshort(e, n);
        n += 2, s.coverage = Ye._lctf.readCoverage(e, i + o), s.valFmt1 = a.readUshort(e, n), 
        n += 2, s.valFmt2 = a.readUshort(e, n), n += 2;
        var r = Ye._lctf.numOfOnes(s.valFmt1), l = Ye._lctf.numOfOnes(s.valFmt2);
        if (1 == s.format) {
            s.pairsets = [];
            var c = a.readUshort(e, n);
            n += 2;
            for (var p = 0; p < c; p++) {
                var u = a.readUshort(e, n);
                n += 2, u += o;
                var d = a.readUshort(e, u);
                u += 2;
                for (var m = [], h = 0; h < d; h++) {
                    var f = a.readUshort(e, u);
                    u += 2, 0 != s.valFmt1 && (x = Ye._lctf.readValueRecord(e, u, s.valFmt1), u += 2 * r), 
                    0 != s.valFmt2 && (_ = Ye._lctf.readValueRecord(e, u, s.valFmt2), u += 2 * l), m.push({
                        gid2: f,
                        val1: x,
                        val2: _
                    });
                }
                s.pairsets.push(m);
            }
        }
        if (2 == s.format) {
            var g = a.readUshort(e, n);
            n += 2;
            var y = a.readUshort(e, n);
            n += 2;
            var w = a.readUshort(e, n);
            n += 2;
            var v = a.readUshort(e, n);
            n += 2, s.classDef1 = Ye._lctf.readClassDef(e, o + g), s.classDef2 = Ye._lctf.readClassDef(e, o + y), 
            s.matrix = [];
            for (p = 0; p < w; p++) {
                var b = [];
                for (h = 0; h < v; h++) {
                    var x = null, _ = null;
                    0 != s.valFmt1 && (x = Ye._lctf.readValueRecord(e, n, s.valFmt1), n += 2 * r), 0 != s.valFmt2 && (_ = Ye._lctf.readValueRecord(e, n, s.valFmt2), 
                    n += 2 * l), b.push({
                        val1: x,
                        val2: _
                    });
                }
                s.matrix.push(b);
            }
        }
        return s;
    }, Ye.GSUB = {}, Ye.GSUB.parse = function(e, t, n, a) {
        return Ye._lctf.parse(e, t, n, a, Ye.GSUB.subt);
    }, Ye.GSUB.subt = function(e, t, n) {
        var a = Ye._bin, o = n, s = {};
        if (1 != t && 4 != t && 5 != t) return null;
        s.fmt = a.readUshort(e, n), n += 2;
        var i = a.readUshort(e, n);
        if (n += 2, s.coverage = Ye._lctf.readCoverage(e, i + o), 1 == t) {
            if (1 == s.fmt) s.delta = a.readShort(e, n), n += 2; else if (2 == s.fmt) {
                var r = a.readUshort(e, n);
                n += 2, s.newg = a.readUshorts(e, n, r), n += 2 * s.newg.length;
            }
        } else if (4 == t) {
            s.vals = [];
            r = a.readUshort(e, n);
            n += 2;
            for (var l = 0; l < r; l++) {
                var c = a.readUshort(e, n);
                n += 2, s.vals.push(Ye.GSUB.readLigatureSet(e, o + c));
            }
        } else if (5 == t) if (2 == s.fmt) {
            var p = a.readUshort(e, n);
            n += 2, s.cDef = Ye._lctf.readClassDef(e, o + p), s.scset = [];
            var u = a.readUshort(e, n);
            n += 2;
            for (l = 0; l < u; l++) {
                var d = a.readUshort(e, n);
                n += 2, s.scset.push(0 == d ? null : Ye.GSUB.readSubClassSet(e, o + d));
            }
        } else console.log("unknown table format", s.fmt);
        return s;
    }, Ye.GSUB.readSubClassSet = function(e, t) {
        var n = Ye._bin.readUshort, a = t, o = [], s = n(e, t);
        t += 2;
        for (var i = 0; i < s; i++) {
            var r = n(e, t);
            t += 2, o.push(Ye.GSUB.readSubClassRule(e, a + r));
        }
        return o;
    }, Ye.GSUB.readSubClassRule = function(e, t) {
        var n = Ye._bin.readUshort, a = {}, o = n(e, t), s = n(e, t += 2);
        t += 2, a.input = [];
        for (var i = 0; i < o - 1; i++) a.input.push(n(e, t)), t += 2;
        return a.substLookupRecords = Ye.GSUB.readSubstLookupRecords(e, t, s), a;
    }, Ye.GSUB.readSubstLookupRecords = function(e, t, n) {
        for (var a = Ye._bin.readUshort, o = [], s = 0; s < n; s++) o.push(a(e, t), a(e, t + 2)), 
        t += 4;
        return o;
    }, Ye.GSUB.readChainSubClassSet = function(e, t) {
        var n = Ye._bin, a = t, o = [], s = n.readUshort(e, t);
        t += 2;
        for (var i = 0; i < s; i++) {
            var r = n.readUshort(e, t);
            t += 2, o.push(Ye.GSUB.readChainSubClassRule(e, a + r));
        }
        return o;
    }, Ye.GSUB.readChainSubClassRule = function(e, t) {
        for (var n = Ye._bin, a = {}, o = [ "backtrack", "input", "lookahead" ], s = 0; s < o.length; s++) {
            var i = n.readUshort(e, t);
            t += 2, 1 == s && i--, a[o[s]] = n.readUshorts(e, t, i), t += 2 * a[o[s]].length;
        }
        i = n.readUshort(e, t);
        return t += 2, a.subst = n.readUshorts(e, t, 2 * i), t += 2 * a.subst.length, a;
    }, Ye.GSUB.readLigatureSet = function(e, t) {
        var n = Ye._bin, a = t, o = [], s = n.readUshort(e, t);
        t += 2;
        for (var i = 0; i < s; i++) {
            var r = n.readUshort(e, t);
            t += 2, o.push(Ye.GSUB.readLigature(e, a + r));
        }
        return o;
    }, Ye.GSUB.readLigature = function(e, t) {
        var n = Ye._bin, a = {
            chain: []
        };
        a.nglyph = n.readUshort(e, t), t += 2;
        var o = n.readUshort(e, t);
        t += 2;
        for (var s = 0; s < o - 1; s++) a.chain.push(n.readUshort(e, t)), t += 2;
        return a;
    }, Ye.head = {}, Ye.head.parse = function(e, t, n) {
        var a = Ye._bin, o = {};
        return a.readFixed(e, t), t += 4, o.fontRevision = a.readFixed(e, t), t += 4, a.readUint(e, t), 
        t += 4, a.readUint(e, t), t += 4, o.flags = a.readUshort(e, t), t += 2, o.unitsPerEm = a.readUshort(e, t), 
        t += 2, o.created = a.readUint64(e, t), t += 8, o.modified = a.readUint64(e, t), 
        t += 8, o.xMin = a.readShort(e, t), t += 2, o.yMin = a.readShort(e, t), t += 2, 
        o.xMax = a.readShort(e, t), t += 2, o.yMax = a.readShort(e, t), t += 2, o.macStyle = a.readUshort(e, t), 
        t += 2, o.lowestRecPPEM = a.readUshort(e, t), t += 2, o.fontDirectionHint = a.readShort(e, t), 
        t += 2, o.indexToLocFormat = a.readShort(e, t), t += 2, o.glyphDataFormat = a.readShort(e, t), 
        t += 2, o;
    }, Ye.hhea = {}, Ye.hhea.parse = function(e, t, n) {
        var a = Ye._bin, o = {};
        return a.readFixed(e, t), t += 4, o.ascender = a.readShort(e, t), t += 2, o.descender = a.readShort(e, t), 
        t += 2, o.lineGap = a.readShort(e, t), t += 2, o.advanceWidthMax = a.readUshort(e, t), 
        t += 2, o.minLeftSideBearing = a.readShort(e, t), t += 2, o.minRightSideBearing = a.readShort(e, t), 
        t += 2, o.xMaxExtent = a.readShort(e, t), t += 2, o.caretSlopeRise = a.readShort(e, t), 
        t += 2, o.caretSlopeRun = a.readShort(e, t), t += 2, o.caretOffset = a.readShort(e, t), 
        t += 2, t += 8, o.metricDataFormat = a.readShort(e, t), t += 2, o.numberOfHMetrics = a.readUshort(e, t), 
        t += 2, o;
    }, Ye.hmtx = {}, Ye.hmtx.parse = function(e, t, n, a) {
        for (var o = Ye._bin, s = {
            aWidth: [],
            lsBearing: []
        }, i = 0, r = 0, l = 0; l < a.maxp.numGlyphs; l++) l < a.hhea.numberOfHMetrics && (i = o.readUshort(e, t), 
        t += 2, r = o.readShort(e, t), t += 2), s.aWidth.push(i), s.lsBearing.push(r);
        return s;
    }, Ye.kern = {}, Ye.kern.parse = function(e, t, n, a) {
        var o = Ye._bin, s = o.readUshort(e, t);
        if (t += 2, 1 == s) return Ye.kern.parseV1(e, t - 2, n, a);
        var i = o.readUshort(e, t);
        t += 2;
        for (var r = {
            glyph1: [],
            rval: []
        }, l = 0; l < i; l++) {
            t += 2;
            n = o.readUshort(e, t);
            t += 2;
            var c = o.readUshort(e, t);
            t += 2;
            var p = c >>> 8;
            if (0 != (p &= 15)) throw "unknown kern table format: " + p;
            t = Ye.kern.readFormat0(e, t, r);
        }
        return r;
    }, Ye.kern.parseV1 = function(e, t, n, a) {
        var o = Ye._bin;
        o.readFixed(e, t), t += 4;
        var s = o.readUint(e, t);
        t += 4;
        for (var i = {
            glyph1: [],
            rval: []
        }, r = 0; r < s; r++) {
            o.readUint(e, t), t += 4;
            var l = o.readUshort(e, t);
            t += 2, o.readUshort(e, t), t += 2;
            var c = l >>> 8;
            if (0 != (c &= 15)) throw "unknown kern table format: " + c;
            t = Ye.kern.readFormat0(e, t, i);
        }
        return i;
    }, Ye.kern.readFormat0 = function(e, t, n) {
        var a = Ye._bin, o = -1, s = a.readUshort(e, t);
        t += 2, a.readUshort(e, t), t += 2, a.readUshort(e, t), t += 2, a.readUshort(e, t), 
        t += 2;
        for (var i = 0; i < s; i++) {
            var r = a.readUshort(e, t);
            t += 2;
            var l = a.readUshort(e, t);
            t += 2;
            var c = a.readShort(e, t);
            t += 2, r != o && (n.glyph1.push(r), n.rval.push({
                glyph2: [],
                vals: []
            }));
            var p = n.rval[n.rval.length - 1];
            p.glyph2.push(l), p.vals.push(c), o = r;
        }
        return t;
    }, Ye.loca = {}, Ye.loca.parse = function(e, t, n, a) {
        var o = Ye._bin, s = [], i = a.head.indexToLocFormat, r = a.maxp.numGlyphs + 1;
        if (0 == i) for (var l = 0; l < r; l++) s.push(o.readUshort(e, t + (l << 1)) << 1);
        if (1 == i) for (l = 0; l < r; l++) s.push(o.readUint(e, t + (l << 2)));
        return s;
    }, Ye.maxp = {}, Ye.maxp.parse = function(e, t, n) {
        var a = Ye._bin, o = {}, s = a.readUint(e, t);
        return t += 4, o.numGlyphs = a.readUshort(e, t), t += 2, 65536 == s && (o.maxPoints = a.readUshort(e, t), 
        t += 2, o.maxContours = a.readUshort(e, t), t += 2, o.maxCompositePoints = a.readUshort(e, t), 
        t += 2, o.maxCompositeContours = a.readUshort(e, t), t += 2, o.maxZones = a.readUshort(e, t), 
        t += 2, o.maxTwilightPoints = a.readUshort(e, t), t += 2, o.maxStorage = a.readUshort(e, t), 
        t += 2, o.maxFunctionDefs = a.readUshort(e, t), t += 2, o.maxInstructionDefs = a.readUshort(e, t), 
        t += 2, o.maxStackElements = a.readUshort(e, t), t += 2, o.maxSizeOfInstructions = a.readUshort(e, t), 
        t += 2, o.maxComponentElements = a.readUshort(e, t), t += 2, o.maxComponentDepth = a.readUshort(e, t), 
        t += 2), o;
    }, Ye.name = {}, Ye.name.parse = function(e, t, n) {
        var a = Ye._bin, o = {};
        a.readUshort(e, t), t += 2;
        var s = a.readUshort(e, t);
        t += 2, a.readUshort(e, t);
        for (var i, r = t += 2, l = 0; l < s; l++) {
            var c = a.readUshort(e, t);
            t += 2;
            var p = a.readUshort(e, t);
            t += 2;
            var u = a.readUshort(e, t);
            t += 2;
            var d = a.readUshort(e, t);
            t += 2;
            n = a.readUshort(e, t);
            t += 2;
            var m = a.readUshort(e, t);
            t += 2;
            var h = "p" + c;
            null == o[h] && (o[h] = {});
            var f, g = [ "copyright", "fontFamily", "fontSubfamily", "ID", "fullName", "version", "postScriptName", "trademark", "manufacturer", "designer", "description", "urlVendor", "urlDesigner", "licence", "licenceURL", "---", "typoFamilyName", "typoSubfamilyName", "compatibleFull", "sampleText", "postScriptCID", "wwsFamilyName", "wwsSubfamilyName", "lightPalette", "darkPalette" ][d], y = r + 12 * s + m;
            if (0 == c) f = a.readUnicode(e, y, n / 2); else if (3 == c && 0 == p) f = a.readUnicode(e, y, n / 2); else if (0 == p) f = a.readASCII(e, y, n); else if (1 == p) f = a.readUnicode(e, y, n / 2); else if (3 == p) f = a.readUnicode(e, y, n / 2); else {
                if (1 != c) throw "unknown encoding " + p + ", platformID: " + c;
                f = a.readASCII(e, y, n), console.log("reading unknown MAC encoding " + p + " as ASCII");
            }
            o[h][g] = f, o[h]._lang = u;
        }
        for (var w in o) if (null != o[w].postScriptName && 1033 == o[w]._lang) return o[w];
        for (var w in o) if (null != o[w].postScriptName && 3084 == o[w]._lang) return o[w];
        for (var w in o) if (null != o[w].postScriptName) return o[w];
        for (var w in o) {
            i = w;
            break;
        }
        return console.log("returning name table with languageID " + o[i]._lang), o[i];
    }, Ye["OS/2"] = {}, Ye["OS/2"].parse = function(e, t, n) {
        var a = Ye._bin.readUshort(e, t);
        t += 2;
        var o = {};
        if (0 == a) Ye["OS/2"].version0(e, t, o); else if (1 == a) Ye["OS/2"].version1(e, t, o); else if (2 == a || 3 == a || 4 == a) Ye["OS/2"].version2(e, t, o); else {
            if (5 != a) throw "unknown OS/2 table version: " + a;
            Ye["OS/2"].version5(e, t, o);
        }
        return o;
    }, Ye["OS/2"].version0 = function(e, t, n) {
        var a = Ye._bin;
        return n.xAvgCharWidth = a.readShort(e, t), t += 2, n.usWeightClass = a.readUshort(e, t), 
        t += 2, n.usWidthClass = a.readUshort(e, t), t += 2, n.fsType = a.readUshort(e, t), 
        t += 2, n.ySubscriptXSize = a.readShort(e, t), t += 2, n.ySubscriptYSize = a.readShort(e, t), 
        t += 2, n.ySubscriptXOffset = a.readShort(e, t), t += 2, n.ySubscriptYOffset = a.readShort(e, t), 
        t += 2, n.ySuperscriptXSize = a.readShort(e, t), t += 2, n.ySuperscriptYSize = a.readShort(e, t), 
        t += 2, n.ySuperscriptXOffset = a.readShort(e, t), t += 2, n.ySuperscriptYOffset = a.readShort(e, t), 
        t += 2, n.yStrikeoutSize = a.readShort(e, t), t += 2, n.yStrikeoutPosition = a.readShort(e, t), 
        t += 2, n.sFamilyClass = a.readShort(e, t), t += 2, n.panose = a.readBytes(e, t, 10), 
        t += 10, n.ulUnicodeRange1 = a.readUint(e, t), t += 4, n.ulUnicodeRange2 = a.readUint(e, t), 
        t += 4, n.ulUnicodeRange3 = a.readUint(e, t), t += 4, n.ulUnicodeRange4 = a.readUint(e, t), 
        t += 4, n.achVendID = [ a.readInt8(e, t), a.readInt8(e, t + 1), a.readInt8(e, t + 2), a.readInt8(e, t + 3) ], 
        t += 4, n.fsSelection = a.readUshort(e, t), t += 2, n.usFirstCharIndex = a.readUshort(e, t), 
        t += 2, n.usLastCharIndex = a.readUshort(e, t), t += 2, n.sTypoAscender = a.readShort(e, t), 
        t += 2, n.sTypoDescender = a.readShort(e, t), t += 2, n.sTypoLineGap = a.readShort(e, t), 
        t += 2, n.usWinAscent = a.readUshort(e, t), t += 2, n.usWinDescent = a.readUshort(e, t), 
        t += 2;
    }, Ye["OS/2"].version1 = function(e, t, n) {
        var a = Ye._bin;
        return t = Ye["OS/2"].version0(e, t, n), n.ulCodePageRange1 = a.readUint(e, t), 
        t += 4, n.ulCodePageRange2 = a.readUint(e, t), t += 4;
    }, Ye["OS/2"].version2 = function(e, t, n) {
        var a = Ye._bin;
        return t = Ye["OS/2"].version1(e, t, n), n.sxHeight = a.readShort(e, t), t += 2, 
        n.sCapHeight = a.readShort(e, t), t += 2, n.usDefault = a.readUshort(e, t), t += 2, 
        n.usBreak = a.readUshort(e, t), t += 2, n.usMaxContext = a.readUshort(e, t), t += 2;
    }, Ye["OS/2"].version5 = function(e, t, n) {
        var a = Ye._bin;
        return t = Ye["OS/2"].version2(e, t, n), n.usLowerOpticalPointSize = a.readUshort(e, t), 
        t += 2, n.usUpperOpticalPointSize = a.readUshort(e, t), t += 2;
    }, Ye.post = {}, Ye.post.parse = function(e, t, n) {
        var a = Ye._bin, o = {};
        return o.version = a.readFixed(e, t), t += 4, o.italicAngle = a.readFixed(e, t), 
        t += 4, o.underlinePosition = a.readShort(e, t), t += 2, o.underlineThickness = a.readShort(e, t), 
        t += 2, o;
    }, Ye.SVG = {}, Ye.SVG.parse = function(e, t, n) {
        var a = Ye._bin, o = {
            entries: []
        }, s = t;
        a.readUshort(e, t), t += 2;
        var i = a.readUint(e, t);
        t += 4, a.readUint(e, t), t += 4, t = i + s;
        var r = a.readUshort(e, t);
        t += 2;
        for (var l = 0; l < r; l++) {
            var c = a.readUshort(e, t);
            t += 2;
            var p = a.readUshort(e, t);
            t += 2;
            var u = a.readUint(e, t);
            t += 4;
            var d = a.readUint(e, t);
            t += 4;
            for (var m = new Uint8Array(e.buffer, s + u + i, d), h = a.readUTF8(m, 0, m.length), f = c; f <= p; f++) o.entries[f] = h;
        }
        return o;
    }, Ye.SVG.toPath = function(e) {
        var t = {
            cmds: [],
            crds: []
        };
        if (null == e) return t;
        for (var n = (new DOMParser).parseFromString(e, "image/svg+xml").firstChild; "svg" != n.tagName; ) n = n.nextSibling;
        var a = n.getAttribute("viewBox");
        a = a ? a.trim().split(" ").map(parseFloat) : [ 0, 0, 1e3, 1e3 ], Ye.SVG._toPath(n.children, t);
        for (var o = 0; o < t.crds.length; o += 2) {
            var s = t.crds[o], i = t.crds[o + 1];
            s -= a[0], i = -(i -= a[1]), t.crds[o] = s, t.crds[o + 1] = i;
        }
        return t;
    }, Ye.SVG._toPath = function(e, t, n) {
        for (var a = 0; a < e.length; a++) {
            var o = e[a], s = o.tagName, i = o.getAttribute("fill");
            if (null == i && (i = n), "g" == s) Ye.SVG._toPath(o.children, t, i); else if ("path" == s) {
                t.cmds.push(i || "#000000");
                var r = o.getAttribute("d"), l = Ye.SVG._tokens(r);
                Ye.SVG._toksToPath(l, t), t.cmds.push("X");
            } else "defs" == s || console.log(s, o);
        }
    }, Ye.SVG._tokens = function(e) {
        for (var t = [], n = 0, a = !1, o = ""; n < e.length; ) {
            var s = e.charCodeAt(n), i = e.charAt(n);
            n++;
            var r = 48 <= s && s <= 57 || "." == i || "-" == i;
            a ? "-" == i ? (t.push(parseFloat(o)), o = i) : r ? o += i : (t.push(parseFloat(o)), 
            "," != i && " " != i && t.push(i), a = !1) : r ? (o = i, a = !0) : "," != i && " " != i && t.push(i);
        }
        return a && t.push(parseFloat(o)), t;
    }, Ye.SVG._toksToPath = function(e, t) {
        for (var n = 0, a = 0, o = 0, s = 0, i = 0, r = {
            M: 2,
            L: 2,
            H: 1,
            V: 1,
            S: 4,
            C: 6
        }, l = t.cmds, c = t.crds; n < e.length; ) {
            var p = e[n];
            if (n++, "z" == p) l.push("Z"), a = s, o = i; else for (var u = p.toUpperCase(), d = r[u], m = Ye.SVG._reps(e, n, d), h = 0; h < m; h++) {
                var f = 0, g = 0;
                if (p != u && (f = a, g = o), "M" == u) a = f + e[n++], o = g + e[n++], l.push("M"), 
                c.push(a, o), s = a, i = o; else if ("L" == u) a = f + e[n++], o = g + e[n++], l.push("L"), 
                c.push(a, o); else if ("H" == u) a = f + e[n++], l.push("L"), c.push(a, o); else if ("V" == u) o = g + e[n++], 
                l.push("L"), c.push(a, o); else if ("C" == u) {
                    var y = f + e[n++], w = g + e[n++], v = f + e[n++], b = g + e[n++], x = f + e[n++], _ = g + e[n++];
                    l.push("C"), c.push(y, w, v, b, x, _), a = x, o = _;
                } else if ("S" == u) {
                    var k = Math.max(c.length - 4, 0);
                    y = a + a - c[k], w = o + o - c[k + 1], v = f + e[n++], b = g + e[n++], x = f + e[n++], 
                    _ = g + e[n++];
                    l.push("C"), c.push(y, w, v, b, x, _), a = x, o = _;
                } else console.log("Unknown SVG command " + p);
            }
        }
    }, Ye.SVG._reps = function(e, t, n) {
        for (var a = t; a < e.length && "string" != typeof e[a]; ) a += n;
        return (a - t) / n;
    }, null == Ye && (Ye = {}), null == Ye.U && (Ye.U = {}), Ye.U.codeToGlyph = function(e, t) {
        var n = e.cmap, a = -1;
        if (null != n.p0e4 ? a = n.p0e4 : null != n.p3e1 ? a = n.p3e1 : null != n.p1e0 && (a = n.p1e0), 
        -1 == a) throw "no familiar platform and encoding!";
        var o = n.tables[a];
        if (0 == o.format) return t >= o.map.length ? 0 : o.map[t];
        if (4 == o.format) {
            for (var s = -1, i = 0; i < o.endCount.length; i++) if (t <= o.endCount[i]) {
                s = i;
                break;
            }
            if (-1 == s) return 0;
            if (o.startCount[s] > t) return 0;
            return 65535 & (0 != o.idRangeOffset[s] ? o.glyphIdArray[t - o.startCount[s] + (o.idRangeOffset[s] >> 1) - (o.idRangeOffset.length - s)] : t + o.idDelta[s]);
        }
        if (12 == o.format) {
            if (t > o.groups[o.groups.length - 1][1]) return 0;
            for (i = 0; i < o.groups.length; i++) {
                var r = o.groups[i];
                if (r[0] <= t && t <= r[1]) return r[2] + (t - r[0]);
            }
            return 0;
        }
        throw "unknown cmap table format " + o.format;
    }, Ye.U.glyphToPath = function(e, t) {
        var n = {
            cmds: [],
            crds: []
        };
        if (e.SVG && e.SVG.entries[t]) {
            var a = e.SVG.entries[t];
            return null == a ? n : ("string" == typeof a && (a = Ye.SVG.toPath(a), e.SVG.entries[t] = a), 
            a);
        }
        if (e.CFF) {
            var o = {
                x: 0,
                y: 0,
                stack: [],
                nStems: 0,
                haveWidth: !1,
                width: e.CFF.Private ? e.CFF.Private.defaultWidthX : 0,
                open: !1
            };
            Ye.U._drawCFF(e.CFF.CharStrings[t], o, e.CFF, n);
        } else e.glyf && Ye.U._drawGlyf(t, e, n);
        return n;
    }, Ye.U._drawGlyf = function(e, t, n) {
        var a = t.glyf[e];
        null == a && (a = t.glyf[e] = Ye.glyf._parseGlyf(t, e)), null != a && (a.noc > -1 ? Ye.U._simpleGlyph(a, n) : Ye.U._compoGlyph(a, t, n));
    }, Ye.U._simpleGlyph = function(e, t) {
        for (var n = 0; n < e.noc; n++) {
            for (var a = 0 == n ? 0 : e.endPts[n - 1] + 1, o = e.endPts[n], s = a; s <= o; s++) {
                var i = s == a ? o : s - 1, r = s == o ? a : s + 1, l = 1 & e.flags[s], c = 1 & e.flags[i], p = 1 & e.flags[r], u = e.xs[s], d = e.ys[s];
                if (s == a) if (l) {
                    if (!c) {
                        Ye.U.P.moveTo(t, u, d);
                        continue;
                    }
                    Ye.U.P.moveTo(t, e.xs[i], e.ys[i]);
                } else c ? Ye.U.P.moveTo(t, e.xs[i], e.ys[i]) : Ye.U.P.moveTo(t, (e.xs[i] + u) / 2, (e.ys[i] + d) / 2);
                l ? c && Ye.U.P.lineTo(t, u, d) : p ? Ye.U.P.qcurveTo(t, u, d, e.xs[r], e.ys[r]) : Ye.U.P.qcurveTo(t, u, d, (u + e.xs[r]) / 2, (d + e.ys[r]) / 2);
            }
            Ye.U.P.closePath(t);
        }
    }, Ye.U._compoGlyph = function(e, t, n) {
        for (var a = 0; a < e.parts.length; a++) {
            var o = {
                cmds: [],
                crds: []
            }, s = e.parts[a];
            Ye.U._drawGlyf(s.glyphIndex, t, o);
            for (var i = s.m, r = 0; r < o.crds.length; r += 2) {
                var l = o.crds[r], c = o.crds[r + 1];
                n.crds.push(l * i.a + c * i.b + i.tx), n.crds.push(l * i.c + c * i.d + i.ty);
            }
            for (r = 0; r < o.cmds.length; r++) n.cmds.push(o.cmds[r]);
        }
    }, Ye.U._getGlyphClass = function(e, t) {
        var n = Ye._lctf.getInterval(t, e);
        return -1 == n ? 0 : t[n + 2];
    }, Ye.U.getPairAdjustment = function(e, t, n) {
        if (e.GPOS) {
            for (var a = null, o = 0; o < e.GPOS.featureList.length; o++) {
                var s = e.GPOS.featureList[o];
                if ("kern" == s.tag) for (var i = 0; i < s.tab.length; i++) 2 == e.GPOS.lookupList[s.tab[i]].ltype && (a = e.GPOS.lookupList[s.tab[i]]);
            }
            if (a) for (o = 0; o < a.tabs.length; o++) {
                var r = a.tabs[o], l = Ye._lctf.coverageIndex(r.coverage, t);
                if (-1 != l) {
                    if (1 == r.format) {
                        var c = r.pairsets[l];
                        for (i = 0; i < c.length; i++) c[i].gid2 == n && (d = c[i]);
                        if (null == d) continue;
                    } else if (2 == r.format) var p = Ye.U._getGlyphClass(t, r.classDef1), u = Ye.U._getGlyphClass(n, r.classDef2), d = r.matrix[p][u];
                    return d.val1[2];
                }
            }
        }
        if (e.kern) {
            var m = e.kern.glyph1.indexOf(t);
            if (-1 != m) {
                var h = e.kern.rval[m].glyph2.indexOf(n);
                if (-1 != h) return e.kern.rval[m].vals[h];
            }
        }
        return 0;
    }, Ye.U.stringToGlyphs = function(e, t) {
        for (var n = [], a = 0; a < t.length; a++) {
            var o = t.codePointAt(a);
            o > 65535 && a++, n.push(Ye.U.codeToGlyph(e, o));
        }
        var s = e.GSUB;
        if (null == s) return n;
        for (var i = s.lookupList, r = s.featureList, l = '\n\t" ,.:;!?()  \u060c', c = "\u0622\u0623\u0624\u0625\u0627\u0629\u062f\u0630\u0631\u0632\u0648\u0671\u0672\u0673\u0675\u0676\u0677\u0688\u0689\u068a\u068b\u068c\u068d\u068e\u068f\u0690\u0691\u0692\u0693\u0694\u0695\u0696\u0697\u0698\u0699\u06c0\u06c3\u06c4\u06c5\u06c6\u06c7\u06c8\u06c9\u06ca\u06cb\u06cd\u06cf\u06d2\u06d3\u06d5\u06ee\u06ef\u0710\u0715\u0716\u0717\u0718\u0719\u071e\u0728\u072a\u072c\u072f\u074d\u0759\u075a\u075b\u076b\u076c\u0771\u0773\u0774\u0778\u0779\u0840\u0846\u0847\u0849\u0854\u0867\u0869\u086a\u08aa\u08ab\u08ac\u08ae\u08b1\u08b2\u08b9\u0ac5\u0ac7\u0ac9\u0aca\u0ace\u0acf\u0ad0\u0ad1\u0ad2\u0add\u0ae1\u0ae4\u0aef\u0b81\u0b83\u0b84\u0b85\u0b89\u0b8c\u0b8e\u0b8f\u0b91\u0ba9\u0baa\u0bab\u0bac", p = 0; p < n.length; p++) {
            var u = n[p], d = 0 == p || -1 != l.indexOf(t[p - 1]), m = p == n.length - 1 || -1 != l.indexOf(t[p + 1]);
            d || -1 == c.indexOf(t[p - 1]) || (d = !0), m || -1 == c.indexOf(t[p]) || (m = !0), 
            m || -1 == "\ua872\u0acd\u0ad7".indexOf(t[p + 1]) || (m = !0), d || -1 == "\ua872\u0acd\u0ad7".indexOf(t[p]) || (d = !0);
            var h = null;
            h = d ? m ? "isol" : "init" : m ? "fina" : "medi";
            for (var f = 0; f < r.length; f++) if (r[f].tag == h) for (var g = 0; g < r[f].tab.length; g++) {
                1 == (b = i[r[f].tab[g]]).ltype && Ye.U._applyType1(n, p, b);
            }
        }
        var y = [ "rlig", "liga", "mset" ];
        for (p = 0; p < n.length; p++) {
            u = n[p];
            var w = Math.min(3, n.length - p - 1);
            for (f = 0; f < r.length; f++) {
                var v = r[f];
                if (-1 != y.indexOf(v.tag)) for (g = 0; g < v.tab.length; g++) for (var b = i[v.tab[g]], x = 0; x < b.tabs.length; x++) if (null != b.tabs[x]) {
                    var _ = Ye._lctf.coverageIndex(b.tabs[x].coverage, u);
                    if (-1 != _) if (4 == b.ltype) for (var k = b.tabs[x].vals[_], q = 0; q < k.length; q++) {
                        var C = k[q], T = C.chain.length;
                        if (!(T > w)) {
                            for (var A = !0, S = 0; S < T; S++) C.chain[S] != n[p + (1 + S)] && (A = !1);
                            if (A) {
                                n[p] = C.nglyph;
                                for (S = 0; S < T; S++) n[p + S + 1] = -1;
                            }
                        }
                    } else if (5 == b.ltype) {
                        var H = b.tabs[x];
                        if (2 != H.fmt) continue;
                        var U = Ye._lctf.getInterval(H.cDef, u), E = H.cDef[U + 2], z = H.scset[E];
                        for (a = 0; a < z.length; a++) {
                            var $ = z[a], j = $.input;
                            if (!(j.length > w)) {
                                for (A = !0, S = 0; S < j.length; S++) {
                                    var I = Ye._lctf.getInterval(H.cDef, n[p + 1 + S]);
                                    if (-1 == U && H.cDef[I + 2] != j[S]) {
                                        A = !1;
                                        break;
                                    }
                                }
                                if (A) {
                                    var L = $.substLookupRecords;
                                    for (q = 0; q < L.length; q += 2) L[q], L[q + 1];
                                }
                            }
                        }
                    }
                }
            }
        }
        return n;
    }, Ye.U._applyType1 = function(e, t, n) {
        for (var a = e[t], o = 0; o < n.tabs.length; o++) {
            var s = n.tabs[o], i = Ye._lctf.coverageIndex(s.coverage, a);
            -1 != i && (1 == s.fmt ? e[t] = e[t] + s.delta : e[t] = s.newg[i]);
        }
    }, Ye.U.glyphsToPath = function(e, t, n) {
        for (var a = {
            cmds: [],
            crds: []
        }, o = 0, s = 0; s < t.length; s++) {
            var i = t[s];
            if (-1 != i) {
                for (var r = s < t.length - 1 && -1 != t[s + 1] ? t[s + 1] : 0, l = Ye.U.glyphToPath(e, i), c = 0; c < l.crds.length; c += 2) a.crds.push(l.crds[c] + o), 
                a.crds.push(l.crds[c + 1]);
                n && a.cmds.push(n);
                for (c = 0; c < l.cmds.length; c++) a.cmds.push(l.cmds[c]);
                n && a.cmds.push("X"), o += e.hmtx.aWidth[i], s < t.length - 1 && (o += Ye.U.getPairAdjustment(e, i, r));
            }
        }
        return a;
    }, Ye.U.pathToSVG = function(e, t) {
        null == t && (t = 5);
        for (var n = [], a = 0, o = {
            M: 2,
            L: 2,
            Q: 4,
            C: 6
        }, s = 0; s < e.cmds.length; s++) {
            var i = e.cmds[s], r = a + (o[i] ? o[i] : 0);
            for (n.push(i); a < r; ) {
                var l = e.crds[a++];
                n.push(parseFloat(l.toFixed(t)) + (a == r ? "" : " "));
            }
        }
        return n.join("");
    }, Ye.U.pathToContext = function(e, t) {
        for (var n = 0, a = e.crds, o = 0; o < e.cmds.length; o++) {
            var s = e.cmds[o];
            "M" == s ? (t.moveTo(a[n], a[n + 1]), n += 2) : "L" == s ? (t.lineTo(a[n], a[n + 1]), 
            n += 2) : "C" == s ? (t.bezierCurveTo(a[n], a[n + 1], a[n + 2], a[n + 3], a[n + 4], a[n + 5]), 
            n += 6) : "Q" == s ? (t.quadraticCurveTo(a[n], a[n + 1], a[n + 2], a[n + 3]), n += 4) : "#" == s.charAt(0) ? (t.beginPath(), 
            t.fillStyle = s) : "Z" == s ? t.closePath() : "X" == s && t.fill();
        }
    }, Ye.U.P = {}, Ye.U.P.moveTo = function(e, t, n) {
        e.cmds.push("M"), e.crds.push(t, n);
    }, Ye.U.P.lineTo = function(e, t, n) {
        e.cmds.push("L"), e.crds.push(t, n);
    }, Ye.U.P.curveTo = function(e, t, n, a, o, s, i) {
        e.cmds.push("C"), e.crds.push(t, n, a, o, s, i);
    }, Ye.U.P.qcurveTo = function(e, t, n, a, o) {
        e.cmds.push("Q"), e.crds.push(t, n, a, o);
    }, Ye.U.P.closePath = function(e) {
        e.cmds.push("Z");
    }, Ye.U._drawCFF = function(e, t, n, a) {
        for (var o = t.stack, s = t.nStems, i = t.haveWidth, r = t.width, l = t.open, c = 0, p = t.x, u = t.y, d = 0, m = 0, h = 0, f = 0, g = 0, y = 0, w = 0, v = 0, b = 0, x = 0, _ = {
            val: 0,
            size: 0
        }; c < e.length; ) {
            Ye.CFF.getCharString(e, c, _);
            var k = _.val;
            if (c += _.size, "o1" == k || "o18" == k) o.length % 2 != 0 && !i && (r = o.shift() + n.Private.nominalWidthX), 
            s += o.length >> 1, o.length = 0, i = !0; else if ("o3" == k || "o23" == k) {
                o.length % 2 != 0 && !i && (r = o.shift() + n.Private.nominalWidthX), s += o.length >> 1, 
                o.length = 0, i = !0;
            } else if ("o4" == k) o.length > 1 && !i && (r = o.shift() + n.Private.nominalWidthX, 
            i = !0), l && Ye.U.P.closePath(a), u += o.pop(), Ye.U.P.moveTo(a, p, u), l = !0; else if ("o5" == k) for (;o.length > 0; ) p += o.shift(), 
            u += o.shift(), Ye.U.P.lineTo(a, p, u); else if ("o6" == k || "o7" == k) for (var q = o.length, C = "o6" == k, T = 0; T < q; T++) {
                var A = o.shift();
                C ? p += A : u += A, C = !C, Ye.U.P.lineTo(a, p, u);
            } else if ("o8" == k || "o24" == k) {
                q = o.length;
                for (var S = 0; S + 6 <= q; ) d = p + o.shift(), m = u + o.shift(), h = d + o.shift(), 
                f = m + o.shift(), p = h + o.shift(), u = f + o.shift(), Ye.U.P.curveTo(a, d, m, h, f, p, u), 
                S += 6;
                "o24" == k && (p += o.shift(), u += o.shift(), Ye.U.P.lineTo(a, p, u));
            } else {
                if ("o11" == k) break;
                if ("o1234" == k || "o1235" == k || "o1236" == k || "o1237" == k) "o1234" == k && (m = u, 
                h = (d = p + o.shift()) + o.shift(), x = f = m + o.shift(), y = f, v = u, p = (w = (g = (b = h + o.shift()) + o.shift()) + o.shift()) + o.shift(), 
                Ye.U.P.curveTo(a, d, m, h, f, b, x), Ye.U.P.curveTo(a, g, y, w, v, p, u)), "o1235" == k && (d = p + o.shift(), 
                m = u + o.shift(), h = d + o.shift(), f = m + o.shift(), b = h + o.shift(), x = f + o.shift(), 
                g = b + o.shift(), y = x + o.shift(), w = g + o.shift(), v = y + o.shift(), p = w + o.shift(), 
                u = v + o.shift(), o.shift(), Ye.U.P.curveTo(a, d, m, h, f, b, x), Ye.U.P.curveTo(a, g, y, w, v, p, u)), 
                "o1236" == k && (d = p + o.shift(), m = u + o.shift(), h = d + o.shift(), x = f = m + o.shift(), 
                y = f, w = (g = (b = h + o.shift()) + o.shift()) + o.shift(), v = y + o.shift(), 
                p = w + o.shift(), Ye.U.P.curveTo(a, d, m, h, f, b, x), Ye.U.P.curveTo(a, g, y, w, v, p, u)), 
                "o1237" == k && (d = p + o.shift(), m = u + o.shift(), h = d + o.shift(), f = m + o.shift(), 
                b = h + o.shift(), x = f + o.shift(), g = b + o.shift(), y = x + o.shift(), w = g + o.shift(), 
                v = y + o.shift(), Math.abs(w - p) > Math.abs(v - u) ? p = w + o.shift() : u = v + o.shift(), 
                Ye.U.P.curveTo(a, d, m, h, f, b, x), Ye.U.P.curveTo(a, g, y, w, v, p, u)); else if ("o14" == k) {
                    if (o.length > 0 && !i && (r = o.shift() + n.nominalWidthX, i = !0), 4 == o.length) {
                        var H = o.shift(), U = o.shift(), E = o.shift(), z = o.shift(), $ = Ye.CFF.glyphBySE(n, E), j = Ye.CFF.glyphBySE(n, z);
                        Ye.U._drawCFF(n.CharStrings[$], t, n, a), t.x = H, t.y = U, Ye.U._drawCFF(n.CharStrings[j], t, n, a);
                    }
                    l && (Ye.U.P.closePath(a), l = !1);
                } else if ("o19" == k || "o20" == k) {
                    o.length % 2 != 0 && !i && (r = o.shift() + n.Private.nominalWidthX), s += o.length >> 1, 
                    o.length = 0, i = !0, c += s + 7 >> 3;
                } else if ("o21" == k) o.length > 2 && !i && (r = o.shift() + n.Private.nominalWidthX, 
                i = !0), u += o.pop(), p += o.pop(), l && Ye.U.P.closePath(a), Ye.U.P.moveTo(a, p, u), 
                l = !0; else if ("o22" == k) o.length > 1 && !i && (r = o.shift() + n.Private.nominalWidthX, 
                i = !0), p += o.pop(), l && Ye.U.P.closePath(a), Ye.U.P.moveTo(a, p, u), l = !0; else if ("o25" == k) {
                    for (;o.length > 6; ) p += o.shift(), u += o.shift(), Ye.U.P.lineTo(a, p, u);
                    d = p + o.shift(), m = u + o.shift(), h = d + o.shift(), f = m + o.shift(), p = h + o.shift(), 
                    u = f + o.shift(), Ye.U.P.curveTo(a, d, m, h, f, p, u);
                } else if ("o26" == k) for (o.length % 2 && (p += o.shift()); o.length > 0; ) d = p, 
                m = u + o.shift(), p = h = d + o.shift(), u = (f = m + o.shift()) + o.shift(), Ye.U.P.curveTo(a, d, m, h, f, p, u); else if ("o27" == k) for (o.length % 2 && (u += o.shift()); o.length > 0; ) m = u, 
                h = (d = p + o.shift()) + o.shift(), f = m + o.shift(), p = h + o.shift(), u = f, 
                Ye.U.P.curveTo(a, d, m, h, f, p, u); else if ("o10" == k || "o29" == k) {
                    var I = "o10" == k ? n.Private : n;
                    if (0 == o.length) console.log("error: empty stack"); else {
                        var L = o.pop(), O = I.Subrs[L + I.Bias];
                        t.x = p, t.y = u, t.nStems = s, t.haveWidth = i, t.width = r, t.open = l, Ye.U._drawCFF(O, t, n, a), 
                        p = t.x, u = t.y, s = t.nStems, i = t.haveWidth, r = t.width, l = t.open;
                    }
                } else if ("o30" == k || "o31" == k) {
                    var F = o.length, P = (S = 0, "o31" == k);
                    for (S += F - (q = -3 & F); S < q; ) P ? (m = u, h = (d = p + o.shift()) + o.shift(), 
                    u = (f = m + o.shift()) + o.shift(), q - S == 5 ? (p = h + o.shift(), S++) : p = h, 
                    P = !1) : (d = p, m = u + o.shift(), h = d + o.shift(), f = m + o.shift(), p = h + o.shift(), 
                    q - S == 5 ? (u = f + o.shift(), S++) : u = f, P = !0), Ye.U.P.curveTo(a, d, m, h, f, p, u), 
                    S += 4;
                } else {
                    if ("o" == (k + "").charAt(0)) throw console.log("Unknown operation: " + k, e), 
                    k;
                    o.push(k);
                }
            }
        }
        t.x = p, t.y = u, t.nStems = s, t.haveWidth = i, t.width = r, t.open = l;
    };

    const Xe = getDefaultExportFromCjs(Ye), decode = async () => {
        var e;
        const t = $e.document.querySelectorAll("style");
        let n = null;
        if (t.forEach((e => {
            var t;
            -1 !== (null == (t = e.textContent) ? void 0 : t.indexOf("font-cxsecret")) && (n = e);
        })), !n) return !0;
        const a = null == (e = n.textContent) ? void 0 : e.match(/base64,([\w\W]+?)'/);
        if (!a) return;
        const o = base64ToUint8Array(a[1]), s = Xe.parse(o);
        let i = await ttfDownload1("https://www.forestpolice.org/ttf/2.0/table.json") || await ttfDownload1("https://jsd.vxo.im/gh/chengbianruan/staticfile/c.json") || await ttfDownload1("https://cdn.jsdelivr.net/gh/chengbianruan/staticfile/c.json");
        if (!i) return !1;
        let r = {};
        for (let l = 19968; l < 40870; l++) {
            let e = Xe.U.codeToGlyph(s, l);
            e && (e = Xe.U.glyphToPath(s, e), e = somd5(JSON.stringify(e)).slice(24), r[l] = i[e]);
        }
        return $e.document.querySelectorAll(".font-cxsecret").forEach((e => {
            let t = e.innerHTML;
            Object.keys(r).forEach((e => {
                const n = new RegExp(String.fromCharCode(e), "g");
                t = t.replace(n, String.fromCharCode(r[e]));
            })), e.innerHTML = t, e.classList.remove("font-cxsecret");
        })), !0;
    }, base64ToUint8Array = e => {
        const t = atob(e), n = new Uint8Array(t.length);
        for (let a = 0; a < t.length; a++) n[a] = t.charCodeAt(a);
        return n;
    }, Ze = [ {
        type: "save",
        name: "\u5b66\u4e60\u901a\u8003\u8bd5\u65b0\u7248\u6536\u5f55",
        match: () => location.href.includes("work/view") || location.href.includes("test/reVersionPaperMarkContentNew"),
        question: {
            html: ".questionLi",
            question: "h3.mark_name",
            options: "ul.mark_letter.colorDeep > li",
            type: ".colorShallow",
            workType: "zj",
            pageType: "cx"
        },
        answerHook: e => {
            let t = removeHtml(R(e.html).find('span[class="colorShallow"]').html());
            if ("" === t) return null;
            let n = t.match(/^\((.+?)\)/);
            if (null === n) return null;
            e.type = n[1].split(",")[0], e.question = titleClean(e.question.split(t)[1].trim()).trim(), 
            e.options = removeStartChar(e.options);
            const a = R(e.html).find(".mark_score>.totalScore>i").text(), o = t.match(/(\d+(\.\d+)?)/);
            let s, i = R(e.html).find(".marking_dui").length > 0 || Number(a) == ((null == o ? void 0 : o[0]) || 0) && 0 != Number(a), r = typeMatch(t);
            if (!i) switch (r) {
              case "0":
              case "1":
              case "3":
                0 != Number(a) && (i = !0);
            }
            switch (r) {
              case "0":
              case "1":
                e.type = r, e.answer = R(e.html).find(".mark_answer>div>span.colorGreen:eq(0)").text().replace("\u6b63\u786e\u7b54\u6848:", "").trim().split("").map((t => e.options[t.charCodeAt(0) - 65])), 
                e.answer = e.answer.filter((e => "" !== e)), 0 === e.answer.length && i && (e.answer = R(e.html).find(".mark_answer>div>span.colorDeep:eq(0)").text().replace("\u6211\u7684\u7b54\u6848:", "").trim().split("").map((t => e.options[t.charCodeAt(0) - 65])), 
                e.answer = e.answer.filter((e => "" !== e)));
                break;

              case "3":
                if (e.type = "3", e.options = [], e.answer = judgeAnswer(R(e.html).find(".mark_answer>div>span.colorGreen:eq(0)").text().replace("\u6b63\u786e\u7b54\u6848", "")), 
                e.answer, 0 === e.answer.length) {
                    if (s = removeHtml(R(e.html).find(".mark_answer>div>span.colorDeep:eq(0)").html()), 
                    e.answer = judgeAnswer(s), 0 === e.answer.length) return null;
                    if (0 == Number(a) && !i && "3" == r) return null;
                    i || (e.answer = "\u6b63\u786e" === e.answer[0] ? [ "\u9519\u8bef" ] : [ "\u6b63\u786e" ]);
                }
                break;

              case "4":
                if (e.type = "4", e.answer = removeHtml(R(e.html).find(".mark_answer>div>.colorGreen:eq(0)").html()).replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim(), 
                e.answer.length < 10) return null;
                e.answer = [ e.answer ];
                break;

              case "5":
                if (e.type = "5", e.answer = removeHtml(R(e.html).find(".mark_answer>div>.colorGreen:eq(0)").html()).replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim(), 
                e.answer.length < 10) return null;
                e.answer = [ e.answer ];
                break;

              case "7":
                if (e.type = "7", e.answer = removeHtml(R(e.html).find(".mark_answer>div>.colorGreen:eq(0)").html()).replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim(), 
                e.answer.length < 10) return null;
                e.answer = [ e.answer ];
                break;

              case "6":
                if (e.type = "6", e.answer = removeHtml(R(e.html).find(".mark_answer>div>.colorGreen:eq(0)").html()).replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim(), 
                e.answer.length < 10) return null;
                e.answer = [ e.answer ];
                break;

              case "2":
                if (e.type = "2", e.answer = R(e.html).find(".mark_answer>div>.colorGreen:eq(0)>dd").map(((e, t) => removeHtml(R(t).html()).replace(`(${e + 1})`, "").trim())).get(), 
                0 == e.answer.length) {
                    const t = R(e.html).find(".mark_answer>div>.colorDeep:eq(0)>dd").map(((e, t) => removeHtml(R(t).html()).replace(`(${e + 1})`, "").trim())).get();
                    R(e.html).find(".mark_answer>div>.colorDeep:eq(0)>dd>.marking_dui").length == t.length && (e.answer = t);
                }
                break;

              default:
                return null;
            }
            return e;
        },
        paper: async e => {
            const t = {
                platform: "cx"
            }, n = R("#courseId").val(), a = ($e.document.body.innerHTML.match(/(?:examId|relationId)=(\d+)/) || [])[1] || "", o = `https://mobilelearn.chaoxing.com/v2/apis/class/getClassDetail?courseId=${n}&classId=${R("#classId").val()}`;
            await request(o, "GET").then((e => {
                const n = JSON.parse(e[0].responseText).data.course.data[0];
                t.name = n.name, t.info = {}, t.info.imageurl = n.imageurl;
            })), t.hash = n, t.info = {}, t.chapter = [ {
                hash: `${a}`,
                name: R(".mark_title").text().trim(),
                question: e
            } ], Ke.setPaper(t.hash, t);
        }
    }, {
        type: "hook",
        name: "hook",
        match: location.href.includes("work/selectWorkQuestionYiPiYue") && location.href.includes("mooc2=0"),
        main: e => {
            location.href.includes("mooc2=0") ? $e.location.href = location.href.replace("mooc2=0", "mooc2=1") : $e.location.href = location.href + "&mooc2=1";
        }
    }, {
        type: "save",
        name: "\u5b66\u4e60\u901a\u4f5c\u4e1a\u6536\u5f55\u65b0",
        match: () => location.href.includes("work/selectWorkQuestionYiPiYue") && location.href.includes("mooc2=1"),
        question: {
            html: ".TiMu",
            question: ".Zy_TItle .clearfix",
            options: "ul.Zy_ulTop li",
            type: ".newZy_TItle",
            workType: "zj",
            pageType: "cx"
        },
        answerHook: e => {
            e.type = R(e.html).find(".newZy_TItle").text().replace(/\u3010|\u3011/g, "").trim();
            let t, n = R(e.html).find(".marking_dui").length > 0;
            switch (removeHtml(R(e.html).find(".Py_addpy:eq(0)").html()), e.question = titleClean(e.question).trim(), 
            e.type) {
              case "\u5355\u9009\u9898":
              case "\u591a\u9009\u9898":
                e.type = "\u5355\u9009\u9898" === e.type ? "0" : "1", e.options = R(e.html).find("ul.Zy_ulTop li").map(((e, t) => {
                    let n = R(t).find("i.fl").text().trim(), a = removeHtml(R(t).html());
                    return "" === n ? a.trim() : a.split(n)[1].trim();
                })).get(), e.answer = R(e.html).find(".correctAnswer >.fl.answerCon").text().trim().split("").map((t => e.options[t.charCodeAt(0) - 65])), 
                0 === e.answer.length && n && (e.answer = R(e.html).find(".myAnswer > .fl.answerCon").text().trim().split("").map((t => e.options[t.charCodeAt(0) - 65])));
                break;

              case "\u5224\u65ad\u9898":
                if (e.type = "3", e.answer = R(e.html).find(".correctAnswer > .fl.answerCon").text().trim().split("").map((e => e.includes("\u6b63\u786e") || e.includes("\u5bf9") || e.includes("\u221a") ? "\u6b63\u786e" : e.includes("\u9519\u8bef") || e.includes("\u9519") || e.includes("\xd7") ? "\u9519\u8bef" : null)).filter((e => null !== e)), 
                0 === e.answer.length) {
                    t = removeHtml(R(e.html).find(".fl.answerCon").html());
                    let [n, a] = [ ".marking_dui", ".marking_cuo" ].map((t => R(e.html).find(t).length));
                    if (n + a === 0) return null;
                    if (t.includes("\u6b63\u786e") || t.includes("\u5bf9") || t.includes("\u221a")) e.answer = [ "\u6b63\u786e" ]; else {
                        if (!(t.includes("\u9519\u8bef") || t.includes("\u9519") || t.includes("\xd7"))) return null;
                        e.answer = [ "\u9519\u8bef" ];
                    }
                    0 === n && 0 !== a && (e.answer = "\u6b63\u786e" === e.answer[0] ? "\u9519\u8bef" : "\u6b63\u786e");
                }
                break;

              case "\u586b\u7a7a\u9898":
                e.type = "2", e.answer = R(e.html).find(".correctAnswerBx>.correctAnswer>p:not(.clear)").map(((e, t) => removeHtml(R(t).html()).replace(`(${e + 1})`, "").trim())).get().filter((e => "" !== e)), 
                0 == e.answer.length && (e.answer = R(e.html).find(".myAllAnswerBx>.myAnswerBx>.myAnswer").map(((e, t) => removeHtml(R(t).html()).replace(/\u7b2c[\u4e00\u4e8c\u4e09\u56db\u4e94\u516d\u4e03\u516b\u4e5d]+\u7a7a\uff1a/, "").trim())).get(), 
                e.answer.length !== R(e.html).find(".marking_dui").length && (e.answer = []));
                break;

              case "\u5206\u5f55\u9898":
                if (e.type = "9", e.answer = R(e.html).find(".correctAnswerBx>.correctAnswer>p:not(.clear)").map(((e, t) => removeHtml(R(t).html()))).get().filter((e => "" !== e)), 
                e.answer.length != R(e.html).find(".CorrectOrNot").length) {
                    if (R(e.html).find(".marking_cuo").length > 0) return null;
                    if (e.answer = R(e.html).find(".myAnswerBx>.myAnswer>p:not(.clear)").map(((e, t) => removeHtml(R(t).html()))).get().filter((e => "" !== e)), 
                    e.answer.length != R(e.html).find(".CorrectOrNot").length) return null;
                }
                e.answer;
                break;

              case "\u8fde\u7ebf\u9898":
                e.type = "11";
                let a = R(e.html).find("ul.firstUlList>li:not(.groupTitile)").map(((e, t) => {
                    let n = R(t).clone();
                    return n.find(".fl").remove(), removeHtml(n.html());
                })).get(), o = R(e.html).find("ul.secondUlList>li:not(.groupTitile)").map(((e, t) => {
                    let n = R(t).clone();
                    return n.find(".fl").remove(), removeHtml(n.html());
                })).get();
                t = R(e.html).find(".correctAnswer >.fl.answerCon >.collectAnswer").map(((e, t) => removeHtml(R(t).text()))).get(), 
                e.options = [ a, o ];
                let s = {};
                t.forEach((e => {
                    let [t, n] = e.split("-");
                    t.charCodeAt(0) >= 65 ? t = (t.charCodeAt(0) - 65).toString() : /^\d+$/.test(t) && (t = (parseInt(t) - 1).toString()), 
                    n.charCodeAt(0) >= 65 ? n = (n.charCodeAt(0) - 65).toString() : /^\d+$/.test(n) && (n = (parseInt(n) - 1).toString()), 
                    s[a[t]] = o[n];
                })), e.answer = s, e.answer;
                break;

              default:
                return e.type, null;
            }
            return e;
        },
        paper: async e => {
            const t = {
                platform: "cx"
            }, n = $e.courseId, a = $e.jobid, o = `https://mobilelearn.chaoxing.com/v2/apis/class/getClassDetail?courseId=${n}&classId=${$e.classId}`;
            await request(o, "GET").then((e => {
                const n = JSON.parse(e[0].responseText).data.course.data[0];
                t.name = n.name, t.info = {}, t.info.imageurl = n.imageurl;
            })), t.hash = n, t.info = {}, t.chapter = [ {
                hash: `${a}`,
                name: R(".ceyan_name>h3").text().trim(),
                question: e
            } ], Ke.setPaper(t.hash, t);
        }
    }, {
        type: "ask",
        name: "\u5b66\u4e60\u901a\u65b0\u7248\u4f5c\u4e1a",
        match: /\/mooc2\/work\/dowork/i.test(location.pathname),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "9" ],
        question: {
            html: ".questionLi",
            question: "h3",
            options: "ul:eq(0) li .after, .answer_p",
            type: "input[name^=answertype]:eq(0)",
            workType: "zy",
            pageType: "cx"
        },
        questionHook: e => {
            const t = removeHtml(R(e.html).find(".colorShallow").html());
            return e.question = titleClean(e.question.split(t)[1].trim()).trim(), e.$options = R(e.html).find(".answerBg"), 
            e;
        },
        setAnswerHook: e => {
            qc(e.html), qc1(e.html);
        }
    }, {
        type: "ask",
        name: "\u5b66\u4e60\u901a\u65b0\u7248\u8003\u8bd5",
        match: /exam\/preview/i.test(location.pathname) || /exam\/test\/reVersionTestStartNew/i.test(location.pathname),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "9" ],
        question: {
            html: ".questionLi",
            question: "h3",
            options: "ul:eq(0) li .after, .answer_p",
            type: "input[name^=type]:not([name=type])",
            workType: "ks",
            pageType: "cx"
        },
        questionHook: e => {
            const t = removeHtml(R(e.html).find(".colorShallow").html());
            if (e.question = titleClean(e.question.split(t)[1].trim()).trim(), e.$options = R(e.html).find(".answerBg"), 
            "3" === e.type) e.options = [];
            return e;
        },
        setAnswerHook: e => {
            qc(e.html), qc1(e.html);
        },
        next: () => {
            R('.nextDiv .jb_btn:contains("\u4e0b\u4e00\u9898")').click();
        }
    }, {
        type: "ask",
        name: "\u5b66\u4e60\u901a\u65e7\u7248\u4f5c\u4e1a",
        match: /work\/doHomeWorkNew/i.test(location.pathname) && 0 == location.href.includes("mooc2=1"),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "9" ],
        init: async () => {
            if (!(await decode())) return msg("\u9875\u9762\u89e3\u5bc6\u5931\u8d25\uff0c\u65e0\u6cd5\u7b54\u9898\uff0c\u8bf7\u5c1d\u8bd5\u5207\u6362\u7f51\u7edc\u6216\u53cd\u9988\u7ed9\u4f5c\u8005\u5427", "error"), 
            !1;
        },
        question: {
            html: ".TiMu",
            question: ".clearfix.fontLabel",
            options: "ul:eq(0) li .after",
            type: "input[name^=answertype]:eq(0), .answer_p",
            workType: "zy",
            pageType: "cx"
        },
        questionHook: e => {
            switch (e.question = titleClean(e.question).trim(), e.$options = R(e.html).find(".fl.before"), 
            e.type) {
              case "3":
                e.options = R(e.html).find("ul:eq(0) li").map(((e, t) => R(t).find(".ri").length > 0 ? "\u6b63\u786e" : R(t).find(".wr").length > 0 ? "\u9519\u8bef" : isTrue(R(t).attr("aria-label") || "") ? "\u6b63\u786e" : isFalse(R(t).attr("aria-label") || "") ? "\u9519\u8bef" : void 0)).get(), 
                e.$options = R(e.html).find("ul>li");
                break;

              case "11":
                let t = R(e.html).find("ul.firstUlList>li:not(.groupTitile)").map(((e, t) => {
                    let n = R(t).clone();
                    return n.find(".fl").remove(), removeHtml(n.html());
                })).get(), n = R(e.html).find("ul.secondUlList>li:not(.groupTitile)").map(((e, t) => {
                    let n = R(t).clone();
                    return n.find(".fl").remove(), removeHtml(n.html());
                })).get();
                e.options = [ t, n ], e.$options = R(e.html).find("ul.thirdUlList>li:not(.groupTitile)");
            }
            return e;
        },
        setAnswerHook: e => {
            qc(e.html), qc1(e.html);
        },
        setAnswer: e => {
            switch (e.type) {
              case "11":
                return e.ques.$options.each(((t, n) => {
                    let a = e.ques.options[0], o = e.ques.options[1], s = e.answer[a[t]], i = o.indexOf(s);
                    s = String.fromCharCode(i + 65), R(n).find("select>option").each(((e, t) => {
                        R(t).val(), R(t).val() == s && R(t).prop("selected", !0);
                    }));
                })), e.answer, !1;

              case "3":
                let t = e.answer;
                return e.ques.$options.each(((e, n) => {
                    isTrue(t) && (isTrue(removeHtml(R(n).html())) || R(n).find(".ri").length > 0) && R(n).find("input").click(), 
                    isFalse(t) && (isFalse(removeHtml(R(n).html())) || R(n).find(".wr").length > 0) && R(n).find("input").click();
                })), !1;

              default:
                return !0;
            }
        }
    }, {
        type: "ask",
        name: "\u5b66\u4e60\u901a\u65b0\u7248\u7ae0\u8282",
        match: /work\/doHomeWorkNew/i.test(location.pathname) && location.href.includes("mooc2=1"),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "9" ],
        init: async () => {
            if (!(await decode())) return msg("\u9875\u9762\u89e3\u5bc6\u5931\u8d25\uff0c\u65e0\u6cd5\u7b54\u9898\uff0c\u8bf7\u5c1d\u8bd5\u5207\u6362\u7f51\u7edc\u6216\u53cd\u9988\u7ed9\u4f5c\u8005\u5427", "error"), 
            !1;
        },
        question: {
            html: ".TiMu",
            question: ".clearfix.fontLabel",
            options: "ul:eq(0) li .after, .answer_p",
            type: "input[name^=answertype]:eq(0)",
            workType: "zj",
            pageType: "cx"
        },
        questionHook: e => {
            switch (e.question = titleClean(e.question).trim(), e.type) {
              case "3":
                e.options = R(e.html).find("ul:eq(0) li").map(((e, t) => "true" === R(t).find(".num_option").attr("data") ? "\u6b63\u786e" : "false" === R(t).find(".num_option").attr("data") ? "\u9519\u8bef" : void 0)).get(), 
                e.options = [];
                break;

              case "11":
                let t = R(e.html).find("ul.firstUlList>li:not(.groupTitile)").map(((e, t) => {
                    let n = R(t).clone();
                    return n.find(".fl").remove(), removeHtml(n.html());
                })).get(), n = R(e.html).find("ul.secondUlList>li:not(.groupTitile)").map(((e, t) => {
                    let n = R(t).clone();
                    return n.find(".fl").remove(), removeHtml(n.html());
                })).get();
                e.options = [ t, n ], e.$options = R(e.html).find("ul.thirdUlList>li:not(.groupTitile)");
                break;

              default:
                e.type;
            }
            return e;
        },
        setAnswerHook: e => {
            qc(e.html), qc1(e.html);
        },
        setAnswer: e => (e.ques.options, "11" !== e.type || (e.ques.$options.each(((t, n) => {
            let a = e.ques.options[0], o = e.ques.options[1], s = e.answer[a[t]], i = o.indexOf(s);
            s = String.fromCharCode(i + 65), $e.$(n).find(".dept_select").chosen().val(s).trigger("chosen:updated");
        })), e.answer, !1))
    } ], et = [ {
        type: "ask",
        name: "\u667a\u6167\u6811\u7ae0\u8282",
        tips: "\u667a\u6167\u6811\u5fc5\u987b\u5f00\u81ea\u52a8\u8df3\u8f6c\uff0c\u5426\u5219\u7b54\u6848\u53ef\u80fd\u65e0\u6cd5\u4fdd\u5b58\u5bfc\u81f4\u4f4e\u5206\uff01",
        match: location.href.includes("zhihuishu.com") && !location.href.includes("checkHomework") && location.host.includes("zhihuishu") && ("/stuExamWeb.html" === location.pathname || location.href.includes("/webExamList/dohomework/") || location.href.includes("/webExamList/doexamination/")),
        types: [ "0", "1", "2", "3" ],
        question: {
            html: ".examPaper_box > div:eq(1) >div:not(.examPaper_partTit)",
            question: ".subject_describe.dynamic-fonts:eq(0) div:eq(0)",
            options: ".subject_node .nodeLab .label.clearfix .node_detail",
            type: ".subject_type span:first-child",
            workType: "zhs",
            pageType: "zhs"
        },
        init: async () => {
            await waitUntil((function() {
                return !R(".yidun_popup").hasClass("yidun_popup--light") && $e.zhsques;
            }));
        },
        next: () => {
            R(".switch-btn-box button:eq(1)").click();
        },
        questionHook: (e, t) => {
            const n = $e.zhsques.examBase.workExamParts.map((e => e.questionDtos)).flat()[t];
            return e.type = typeConvert(n.questionType.name), e.question = removeHtml(n.name), 
            e.options = n.questionOptions ? n.questionOptions.map((e => removeHtml(e.content))) : [], 
            "3" == e.type && (e.options = []), e;
        }
    }, {
        type: "save",
        name: "\u667a\u6167\u6811\u4f5c\u4e1a\u6536\u5f55",
        match: location.href.includes("zhihuishu.com") && location.href.includes("checkHomework") && location.host.includes("zhihuishu") && ("/stuExamWeb.html" === location.pathname || location.href.includes("/webExamList/checkHomework/")),
        question: {
            html: ".questionType",
            question: ".subject_describe",
            options: ".examquestions-answer",
            type: ".newZy_TItle",
            workType: "zhs",
            pageType: "zhs"
        },
        init: async () => {
            await waitUntil((function() {
                return R(".questionType").length > 0 && $e.zhsques && $e.zhsimgAnswer;
            }));
        },
        answerHook: e => {
            let t = R(e.html).find(".examPaper_subject").attr("data-questionid");
            const n = $e.zhsimgAnswer;
            let a = $e.zhsques.examBase.workExamParts.map((e => e.questionDtos)).flat().find((e => e.id == t));
            return a.answer = n[a.id], e.question = removeHtml(a.name), e.type = typeConvert(a.questionType.name), 
            e.options = a.questionOptions.map((e => removeHtml(e.content))), e.answer = a.answer.split("").map((t => e.options[t.charCodeAt(0) - 65])), 
            "3" == e.type && (e.options = [], e.answer = isTrue(e.answer[0]) ? [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? [ "\u9519\u8bef" ] : []), 
            e;
        }
    } ], tt = [ {
        type: "hook",
        name: "\u82af\u4f4d\u6559\u80b2hook",
        match: "www.beeline-ai.com" === location.host,
        main: async e => {
            const getPageIdentifier = () => R(".el-main > div:eq(0)").attr("class");
            $e.mainClass = getPageIdentifier();
            const t = new MutationObserver((async e => {
                const n = getPageIdentifier();
                $e.mainClass !== n && ($e.mainClass = n, "homework-detail-container" === n && await waitUntil((() => 0 === R(".el-loading-mask").length)), 
                vuePageChange$1(), t.disconnect());
                for (const a of e) if ("attributes" === a.type && "class" === a.attributeName) {
                    const e = a.target.textContent;
                    if (e && (e.includes("\u4e0b\u4e00\u9898") || e.includes("\u4e0a\u4e00\u9898"))) {
                        vuePageChange$1(), t.disconnect();
                        break;
                    }
                }
            }));
            R("body").length >= 1 && t.observe(R("body")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u82af\u4f4d\u6559\u80b2\u4f5c\u4e1a",
        tips: "\u82af\u4f4d\u6559\u80b2\u4ec5\u652f\u6301\u9009\u62e9\u5224\u65ad\uff0c\u5176\u4ed6\u9898\u578b\u5f85\u9002\u914d",
        match: () => "www.beeline-ai.com" === location.host && (/student\/#\/courseInfo\/[A-Za-z0-9]+\/homework/i.test(location.href) || /student\/#\/courseInfo\/[A-Za-z0-9]+\/exam/i.test(location.href)),
        types: [ "0", "1", "3" ],
        question: {
            html: ".content-area > div.content",
            question: ".content",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "xinwei",
            pageType: "xinwei"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".question-box").length;
            }));
        },
        next: () => {
            R('.toggle-box > button:contains("\u4e0b\u4e00\u9898")').click();
        },
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => (e.type = typeMatch(R(e.html).find(".question-box>.tag").text()), 
        e)
    }, {
        type: "save",
        name: "\u82af\u4f4d\u6559\u80b2\u6536\u5f55",
        match: () => "www.beeline-ai.com" === location.host && location.href.includes("/homeworkDetailPage"),
        question: {
            html: ".question-content-body",
            question: ".topic-title",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "xinwei",
            pageType: "xinwei"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".question-content-body").length;
            }));
        },
        answerHook: e => {
            e.type = typeMatch(R(e.html).find(".question-box>.tag").text());
            let t = R(e.html).find(".answer-area > span:eq(1)").text();
            switch (e.type) {
              case "0":
              case "1":
                let n = t.split(",");
                if (e.answer = n.map((t => e.options[t.charCodeAt(0) - 65])), 0 === e.answer.length) return;
                break;

              case "3":
                "T" == t && (e.answer = [ "\u6b63\u786e" ]), "F" == t && (e.answer = [ "\u9519\u8bef" ]);
            }
            return e;
        }
    } ], nt = [ {
        type: "hook",
        name: "\u667a\u666e\u6e05\u8a00token\u83b7\u53d6",
        match: /chatglm.cn\/main\//i.test(location.href),
        main: e => {
            const t = e.app, n = document.cookie.split(";");
            let a = "";
            n.forEach((e => {
                /chatglm_refresh_token/i.test(e) && (a = e.split("=")[1]);
            })), a && (t.app.gpt.forEach((e => {
                "GLM" === e.name && (e.key = a);
            })), t.setConfig(t.app), msg("\u667a\u666e\u6e05\u8a00token\u83b7\u53d6\u6210\u529f"));
        }
    }, {
        type: "hook",
        name: "\u8baf\u98de\u661f\u706btoken\u83b7\u53d6",
        match: /xinghuo.xfyun.cn\/desk/i.test(location.href),
        main: e => {
            const t = e.app, n = document.cookie.split(";");
            let a = "";
            n.forEach((e => {
                /ssoSessionId/i.test(e) && (a = e.split("=")[1]);
            })), a && (t.app.gpt.forEach((e => {
                "spark" === e.name && (e.key = a);
            })), t.setConfig(t.app), msg("\u8baf\u98de\u661f\u706btoken\u83b7\u53d6\u6210\u529f"));
        }
    } ], at = {
        single_selection: "\u5355\u9009\u9898",
        multiple_selection: "\u591a\u9009\u9898",
        true_or_false: "\u5224\u65ad\u9898",
        fill_in_blank: "\u586b\u7a7a\u9898",
        short_answer: "\u7b80\u7b54\u9898",
        text: "\u6587\u672c",
        analysis: "\u7efc\u5408\u9898",
        matching: "\u5339\u914d\u9898",
        random: "\u968f\u673a\u9898",
        cloze: "\u5b8c\u5f62\u586b\u7a7a\u9898"
    }, ot = [ {
        type: "hook",
        name: "\u56fd\u5f00hook",
        match: location.host.includes("ouchn.cn"),
        main: e => {
            $e.mainClass = getUrl();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getUrl() && ($e.mainClass = getUrl(), "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 !== R(".selectDan").length;
                })), vuePageChange$1(), t.disconnect());
            }));
            R("body").length >= 1 && t.observe(R("body")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "save",
        name: "\u56fd\u5f00\u7b54\u6848\u6536\u5f55\u65e7",
        match: /\/exam\/([0-9]+)\/subjects#\/submission\/([0-9]+)/i.test(location.href),
        question: {
            html: "li.subject",
            question: ".summary-title .subject-description",
            options: ".subject-options li .option-content",
            type: ".subject-point > span:eq(0)",
            workType: "guokai",
            pageType: "guokai"
        },
        init: async () => {
            await waitUntil((function() {
                return R(".loading-gif").hasClass("ng-hide");
            }));
        },
        answerHook: e => {
            const t = $e.angular.element(e.html).scope().subject;
            if ("text" === t.type) return;
            let n = !1;
            const a = parseFloat(t.point), o = parseFloat(t.score), s = 0 !== a && a === o;
            let i = R(`<div>${t.description}</div>`).clone();
            if (i.find("span.__blank__").remove(), e.question = removeHtml(i.html()), e.options = t.options.map((e => removeHtml(e.content))), 
            e.type = typeConvert(at[t.type]), t.correctOptions && t.correctOptions.length > 0 && (e.answer = t.correctOptions.map((e => removeHtml(e.content))), 
            n = !0), t.correct_answers && t.correct_answers.length > 0 && (e.answer = t.correct_answers.map((e => e.content)), 
            n = !0), n || s) {
                switch (t.type) {
                  case "single_selection":
                  case "multiple_selection":
                  case "true_or_false":
                    if (n) "true_or_false" === t.type && (e.answer = judgeAnswer(e.answer[0]), e.options = []); else {
                        if (t.options, e.answer = t.options.filter((e => e.isChosen)).map((e => removeHtml(e.content))), 
                        0 === e.answer.length) return;
                        "true_or_false" === t.type && (e.answer = judgeAnswer(e.answer[0]), e.options = []);
                    }
                    break;

                  case "analysis":
                    break;

                  case "cloze":
                    t.sub_subjects, e.options = t.sub_subjects.map((e => e.options.map((e => removeHtml(e.content)))));
                    break;

                  case "fill_in_blank":
                    n || (e.answer = t.answers.map((e => e.content)));
                }
                return e;
            }
        },
        paper: e => {
            const t = $e.globalData.course, n = $e.angular.element(R("body")).scope(), a = $e.angular.element(R(".hd")).scope().exam, o = n.submissionData.id;
            if (!n.examSubmissions.find((e => (e.id, String(e.id) === String(o))))) return;
            const s = {
                platform: "guokai"
            };
            s.hash = t.id, s.name = t.name, s.info = {}, s.info.school = t.orgName, s.chapter = [ {
                hash: `${a.id}`,
                name: a.title,
                question: e
            } ], Ke.setPaper(s.hash, s);
        }
    }, {
        type: "save",
        name: "\u5e7f\u5f00\u7b54\u6848\u6536\u5f55",
        match: /mod\/quiz\/review\.php/i.test(location.pathname),
        question: {
            html: ".que",
            question: ".qtext",
            options: ".answer > div",
            type: "",
            answer: ".rightanswer",
            workType: "ougd",
            pageType: "ougd"
        },
        init: async () => {
            R(".specificfeedback").remove();
        },
        next: async () => {
            !R(".qn_buttons > a").last().hasClass("thispage") && R(".arrow_text").click();
        },
        answerHook: e => {
            const t = R(e.html).find(".info .state").text();
            if (e.type = (R(e.html).attr("class") || "").split(" ")[1], R(e.html).find(".qtext .accesshide").remove(), 
            e.question = removeHtml(R(e.html).find(".qtext").html()), e.question.includes("egg")) {
                let t = R(e.html).clone();
                t.find("img").each((function() {
                    var e;
                    (null == (e = R(this).attr("src")) ? void 0 : e.includes("egg")) && R(this).remove();
                })), e.question = removeHtml(t.find(".qtext").html());
            }
            switch (e.type, e.type) {
              case "truefalse":
                e.type = "3", e.$options = R(e.html).find("input[type=radio]"), e.options = R(e.html).find(".answer > div").map(((e, t) => removeHtml(R(t).html()).trim())).get(), 
                e.answer = [], e.answer = R(e.html).find(".answer > div").map(((t, n) => e.$options.eq(t).prop("checked") ? e.options[t] : "")).get(), 
                e.answer = e.answer.filter((e => "" !== e)), 0 === e.answer.length ? (e.temp = removeHtml(R(e.html).find(".rightanswer").html()).replace("\u6b63\u786e\u7b54\u6848\u662f", "").trim(), 
                e.answer = [ e.temp ]) : t.includes("\u6b63\u786e") || (e.answer = e.options.filter((t => !t.includes(e.answer[0])))), 
                isTrue(e.answer[0]) ? e.answer = [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? e.answer = [ "\u9519\u8bef" ] : e.answer = [], 
                e.options = [];
                break;

              case "multichoice":
              case "multichoiceset":
                if (e.type = "1", e.$options = R(e.html).find("input[type=checkbox]"), 0 === e.$options.length && (e.type = "0", 
                e.$options = R(e.html).find("input[type=radio]")), e.options = R(e.html).find(".answer > div").map(((e, t) => {
                    let n = R(t).find(".answernumber").text().trim(), a = removeHtml(R(t).html());
                    return "" === n ? a.trim() : a.split(n)[1].trim();
                })).get(), t.includes("\u6b63\u786e") && !t.includes("\u90e8\u5206\u6b63\u786e")) e.answer = [], 
                e.answer = R(e.html).find(".answer > div").map(((t, n) => {
                    let a = R(n).find(".answernumber").text().trim(), o = removeHtml(R(n).html());
                    return e.$options.eq(t).prop("checked") && R(n).find(".text-success").length > 0 ? "" === a ? o.trim() : o.split(a)[1].trim() : "";
                })).get(), e.answer = e.answer.filter((e => "" !== e)); else {
                    e.temp = removeHtml(R(e.html).find(".rightanswer").html(), !1).replace("\u6b63\u786e\u7b54\u6848\u662f\uff1a", "").trim();
                    const t = e.options.slice(0);
                    t.sort(((e, t) => t.length - e.length)), e.answer = t.map((t => e.temp.includes(t) ? (e.temp = e.temp.replace(t, ""), 
                    t) : "")), e.answer = e.answer.filter((e => "" !== e)), e.answer.length;
                }
                break;

              case "shortanswer":
                e.type = "4", e.$options = R(e.html).find("input[type=text]"), e.answer = removeHtml(R(e.html).find(".rightanswer").html()).replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim();
                break;

              case "match":
                e.type = "24", e.match = R(".answer tr td.text").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.$options = R(".answer tr td.control select"), e.selects = R(".answer tr td.control select").map(((e, t) => [ R(t).find("option").map(((e, t) => ({
                    value: R(t).val(),
                    text: R(t).text()
                }))).get() ])).get();
                break;

              case "multianswer":
                e.type = "14";
                let n = R(e.html).find(".formulation").clone();
                n.find(".subquestion").remove(), n.find(".accesshide").remove(), e.question = removeHtml(n.html());
                let a = [], o = [];
                R(e.html).find(".subquestion").map(((e, t) => {
                    let n = R(t).find("select>option").map(((e, t) => removeHtml(R(t).html()))).get();
                    n = n.filter((e => "" !== e)), a.push(n);
                    let s = R(t).find("select>option:selected").map(((e, t) => removeHtml(R(t).html()))).get();
                    o.push(s[0]);
                })), e.options = a;
                R(e.html).find(".text-success").length == e.options.length && (e.answer = o);
                break;

              case "description":
                return;
            }
            return e;
        },
        paper: async e => {
            const t = {
                platform: "ougd"
            };
            t.hash = ($e.document.body.innerHTML.match(/(?:courseid)=(\d+)/) || [])[1] || "";
            const n = ($e.document.body.innerHTML.match(/(?:cmid)=(\d+)/) || [])[1] || "";
            "" !== t.hash && "" !== n && (t.info = {}, t.name = R("h1").text().trim(), t.chapter = [ {
                hash: `${n}`,
                name: $e.document.title.trim(),
                question: e
            } ], Ke.setPaper(t.hash, t));
        }
    }, {
        type: "ask",
        name: "\u5e7f\u5f00\u5f62\u8003",
        tips: "\u5e7f\u5f00\u4ec5\u652f\u6301\u57fa\u7840\u9898\u578b\uff0c\u7279\u6b8a\u9898\u578b\u8bf7\u624b\u52a8\u5b8c\u6210",
        match: /mod\/quiz\/attempt\.php/i.test(location.pathname),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "9", "14", "24" ],
        question: {
            html: ".que",
            question: ".qtext",
            options: ".answer > div",
            type: "",
            workType: "ougd",
            pageType: "ougd"
        },
        ischecked: e => Boolean(e.prop("checked")),
        questionHook: e => {
            if (e.type = (R(e.html).attr("class") || "").split(" ")[1], R(e.html).find(".qtext .accesshide").remove(), 
            e.question = removeHtml(R(e.html).find(".qtext").html()), e.question.includes("egg")) {
                let t = R(e.html).clone();
                t.find("img").each((function() {
                    var e;
                    (null == (e = R(this).attr("src")) ? void 0 : e.includes("egg")) && R(this).remove();
                })), e.question = removeHtml(t.find(".qtext").html());
            }
            switch (e.type) {
              case "truefalse":
                e.type = "3", e.$options = R(e.html).find("input[type=radio]"), e.options = [];
                break;

              case "multichoice":
              case "multichoiceset":
                e.type = "1", e.$options = R(e.html).find("input[type=checkbox]"), 0 === e.$options.length && (e.type = "0", 
                e.$options = R(e.html).find("input[type=radio]")), e.options = R(e.html).find(".answer > div").map(((e, t) => {
                    let n = R(t).find(".answernumber").text().trim(), a = removeHtml(R(t).html());
                    return "" === n ? a.trim() : a.split(n)[1].trim();
                })).get();
                break;

              case "shortanswer":
                e.type = "4", e.$options = R(e.html).find("input[type=text]");
                break;

              case "match":
                e.type = "24", e.match = R(".answer tr td.text").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.$options = R(".answer tr td.control select"), e.selects = R(".answer tr td.control select").map(((e, t) => [ R(t).find("option").map(((e, t) => ({
                    value: R(t).val(),
                    text: R(t).text()
                }))).get() ])).get();

              case "essay":
                e.type = "4", e.$options = R(e.html).find("iframe");
                break;

              case "multianswer":
                e.type = "14";
                let t = R(e.html).find(".formulation").clone();
                t.find(".subquestion").remove(), t.find(".accesshide").remove(), e.question = removeHtml(t.html());
                let n = [];
                R(e.html).find(".subquestion").map(((e, t) => {
                    let a = R(t).find("select>option").map(((e, t) => removeHtml(R(t).html()))).get();
                    a = a.filter((e => "" !== e)), n.push(a), R(t).find("select>option:selected").map(((e, t) => removeHtml(R(t).html()))).get();
                })), e.$options = R(e.html).find("select"), e.options = n;
                break;

              case "description":
                return;
            }
            return e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "4":
                return R(e.html).find("input.form-control").each((function(t, n) {
                    R(n).val(e.answer[t]);
                })), R(e.html).find("iframe:eq(0)").contents().find("body").html(e.answer[0]), !1;

              case "3":
                e.ques.$options.each(((t, n) => {
                    const a = R(n).parent().find("label").text();
                    return "object" == typeof e.answer && (e.answer = e.answer[0]), isTrue(e.answer) && isTrue(a) ? (R(n).click(), 
                    !1) : !isFalse(e.answer) || !isFalse(a) || (R(n).click(), !1);
                }));

              case "14":
                return R(e.html).find("select").each(((t, n) => {
                    const a = e.answer[t];
                    R(n).find(`option:contains("${a}")`).prop("selected", !0);
                })), !1;

              default:
                return !0;
            }
        },
        finish: e => {
            R(".submitbtns .btn-primary").click();
        }
    }, {
        type: "ask",
        name: "\u56fd\u5f00\u4e13\u9898\u6d4b\u9a8c",
        match: /\/exam\/([0-9]+)\/subjects/i.test(location.pathname) && !/\/exam\/([0-9]+)\/subjects#\/submission\/([0-9]+)/i.test(location.href),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "9", "14", "24" ],
        question: {
            html: "li.subject",
            question: ".summary-title .subject-description",
            options: ".subject-options li .option-content",
            type: ".summary-sub-title span:eq(0)",
            workType: "guokai",
            pageType: "guokai"
        },
        init: async () => {
            await waitUntil((function() {
                return R(".loading-gif").hasClass("ng-hide") && "" === R(".hd .examinee .submit-label").eq(0).text();
            })), await waitUntil((function() {
                return 0 !== R("li.subject").length;
            }));
        },
        ischecked: e => Boolean(e.parent().find("input").eq(-1).prop("checked")),
        questionHook: e => {
            const t = $e.angular.element(e.html).scope(), n = t.subject;
            if ("text" === n.type) return;
            e.type = typeConvert(at[n.type]);
            let a = R(`<div>${n.description}</div>`).clone();
            switch (a.find("span.__blank__").remove(), e.question = removeHtml(a.html()), n.options = n.options.sort(((e, t) => e.sort - t.sort)), 
            e.options = n.options.map((e => removeHtml(e.content))), e.type, n.type, n.type) {
              case "cloze":
                e.options = n.sub_subjects.map((e => e.options.map((e => removeHtml(e.content))))), 
                e.$options = R(e.html).find("select");

              case "true_or_false":
                e.options = [];
            }
            return e.subject = n, e.scope = t, e;
        },
        setAnswer: e => {
            switch (e.ques, e.type) {
              case "2":
                return R(e.html).find(".___answer"), R(e.html).find(".___answer").each(((t, n) => {
                    R(n).html(e.answer[t]), e.ques.scope.subject.answers[t].content = e.answer[t], e.ques.scope.onChangeSubmission(e.ques.subject);
                })), !1;

              case "4":
                return R(e.html).find(".simditor-body.needsclick>p").each((function(t, n) {
                    R(n).html(e.answer[t]), e.ques.subject.answered_content = e.answer[t];
                })), e.ques.scope.onChangeSubmission(e.ques.subject), !1;

              case "14":
                return e.ques.subject.sub_subjects.forEach(((t, n) => {
                    let a = e.answer[n];
                    t.options.forEach(((o, s) => {
                        o.content === a && (t.answeredOption = String(o.id), e.ques.scope.onChangeSubmission(t), 
                        R(e.html).find(`input[value="${o.id}"]`).click(), R(e.html).find(`button:eq(${n})>span:eq(1)`).text(a));
                    }));
                })), !1;
            }
            return !0;
        }
    }, {
        type: "save",
        name: "\u4e0a\u6d77\u5f00\u653e\u6536\u5f55",
        match: () => "l.shou.org.cn" === location.host && location.href.includes("assignment/history.aspx?homeWorkId"),
        question: {
            html: ".e-q-body",
            question: ".ErichText",
            options: "ul>li>.ErichText",
            type: ".question-box .tag",
            workType: "shou",
            pageType: "shou"
        },
        init: async () => {},
        answerHook: e => {
            e.$options = R(e.html).find("ul>li");
            let t = R(e.html).find("ul>li.checked").map(((e, t) => removeHtml(R(t).find(".ErichText").html() || R(t).html()))).get();
            const n = R(e.html).find(".e-q-right").length > 0;
            e.answer = t.filter((e => "" !== e));
            let a = R(e.html).find(".e-ans-ref .e-ans-r").map(((e, t) => removeHtml(R(t).html()))).get().map((t => {
                let n = t.charCodeAt() - 65;
                return e.options[n];
            })).filter((e => "" !== e && void 0 !== e));
            switch (e.options = removeStartChar(e.options), R(e.html).attr("data-questiontype")) {
              case "2":
                e.type = "1";
                break;

              case "1":
                e.type = "0";
                break;

              case "3":
                e.type = "3", e.answer = R(e.html).find("ul>li.checked").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.options = [], isTrue(e.answer[0]) ? e.answer = [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? e.answer = [ "\u9519\u8bef" ] : e.answer = [];
                break;

              case "8":
                e.type = "15";
                const t = R(e.html).find(".e-q-quest form").map(((e, t) => {
                    let n = removeHtml(R(t).find(".e-q-q .ErichText").html()), a = R(t).find("ul>li").map(((e, t) => removeHtml(R(t).find(".ErichText").html() || R(t).html()))).get(), o = "0";
                    a = removeStartChar(a);
                    const s = R(t).find(".e-a-right").length > 0, i = R(t).find(".e-ans-ref .e-ans-r").map(((e, t) => removeHtml(R(t).html()))).get();
                    let r = i.map((e => {
                        let t = e.charCodeAt() - 65;
                        return a[t];
                    })).filter((e => "" !== e && void 0 !== e));
                    if (2 === a.length && 1 === i.length) {
                        let e = judgeAnswer(i[0]);
                        e.length > 0 && (r = e, a = [], o = "3");
                    }
                    return r.length > 1 && (o = "1"), {
                        question: n,
                        options: a,
                        answer: r,
                        isT: s,
                        type: o
                    };
                })).get();
                if (t.some((e => !e.isT))) return;
                a = t.map((e => e.answer)).flat(), e.options = t.map((e => ({
                    question: e.question,
                    options: e.options,
                    type: e.type
                })));
                break;

              case "11":
                e.type = "19";
                const n = R(e.html).find("form").map(((e, t) => ({
                    type: "0",
                    question: removeHtml(R(t).find(".e-q-q .ErichText").html()),
                    options: R(t).find("ul li .ErichText").map(((e, t) => removeHtml(R(t).html()))).get()
                }))).get();
                a = a.length > 0 ? judgeAnswer(a[0]) : [], e.options = n;
                break;

              default:
                return void R(e.html).attr("data-questiontype");
            }
            return a.length > 0 ? (e.answer = a, e) : !n && "3" === e.type && e.answer.length > 0 || !n ? void 0 : e;
        },
        paper: async e => {
            const t = {
                platform: "shou"
            }, n = R("input[name=CourseOpenId]").val(), a = R("input[name=WorkId]").val();
            await request("https://l.shou.org.cn/student/CourseScoreNew-inside.aspx", "GET").then((e => {
                const a = R(e[0].responseText);
                t.name = a.find(`#courseSelect>option[data-xid="${n}"]`).text().trim(), t.info = {};
            })), t.hash = n, t.info = {}, t.chapter = [ {
                hash: `${a}`,
                name: R(".mark_title").text().trim(),
                question: e
            } ], Ke.setPaper(t.hash, t);
        }
    }, {
        type: "ask",
        name: "\u4e0a\u6d77\u5f00\u653e\u4f5c\u4e1a",
        tips: "",
        match: () => "l.shou.org.cn" === location.host && (location.href.includes("assignment/preview.aspx?homeWorkId") || location.href.includes("study/assignment/continuation.aspx")),
        types: [ "0", "1", "3" ],
        question: {
            html: ".e-q-body",
            question: ".ErichText",
            options: "ul>li>.ErichText",
            type: ".question-box .tag",
            workType: "shou",
            pageType: "shou"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".e-q-body").length;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            switch (R(e.html).attr("data-questiontype")) {
              case "2":
                e.type = "1";
                break;

              case "1":
                e.type = "0";
                break;

              case "3":
                e.type = "3", e.$options = R(e.html).find("ul>li");
                break;

              case "8":
                e.type = "15", e.quesList = R(e.html).find("form").map(((e, t) => ({
                    type: "0",
                    question: removeHtml(R(t).find(".e-q-q .ErichText").html()),
                    options: R(t).find("ul li .ErichText").map(((e, t) => removeHtml(R(t).html()))).get()
                }))).get();
                break;

              default:
                return void R(e.html).attr("data-questiontype");
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], st = [ {
        type: "ask",
        name: "\u6210\u6559\u4e91\u8003\u8bd5",
        tips: "",
        match: () => location.href.includes("student/exam/resource/paper_card"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".ui-question",
            question: ".ui-question-content-wrapper",
            options: ".ui-question-options li .ui-question-content-wrapper",
            type: ".ui-question-group-title",
            workType: "chengjiaoyun",
            pageType: "chengjiaoyun"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".ui-question");
            })), !$e.top.location.href.includes("student/exam2/doexam")) return !1;
        },
        toquestion: e => {
            R(`.ui-card-questions ul li:eq(${e - 1})`).click();
        },
        next: async () => {
            R("#next-btn").click();
        },
        ischecked: e => e.hasClass("ui-option-selected"),
        questionHook: e => {
            let t = R(e.html).parent().find(".ui-question-group-title").text().split(".")[1].trim();
            switch (e.$options = R(e.html).find(".ui-question-options li>span"), t) {
              case "\u5355\u9009\u9898":
                e.type = "0";
                break;

              case "\u591a\u9009\u9898":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
                e.type = "3", e.options = [];
            }
            return e;
        },
        setAnswer: e => {
            if ("3" === e.type) {
                let t = e.answer;
                return e.ques.$options.each(((e, n) => {
                    isTrue(t) && isTrue(removeHtml(R(n).parent().html())) && R(n).click(), isFalse(t) && isFalse(removeHtml(R(n).parent().html())) && R(n).click();
                })), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u6210\u6559\u4e91\u6536\u5f55",
        match: () => location.href.includes("student/exam/resource/paper_card"),
        question: {
            html: ".ui-question",
            question: ".ui-question-content-wrapper",
            options: ".ui-question-options li .ui-question-content-wrapper",
            type: ".ui-question-group-title",
            workType: "chengjiaoyun",
            pageType: "chengjiaoyun"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".ui-question");
            })), $e.top.location.href.includes("student/exam2/doexam")) return !1;
        },
        answerHook: e => {
            let t = R(e.html).parent().find(".ui-question-group-title").text().split(".")[1].trim();
            switch (e.$options = R(e.html).find(".ui-question-options li>span"), e.answer = R(e.html).find(".ui-question-options li.ui-correct-answer .ui-question-content-wrapper").map(((e, t) => removeHtml(R(t).html()))).get(), 
            t) {
              case "\u5355\u9009\u9898":
                e.type = "0";
                break;

              case "\u591a\u9009\u9898":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
                e.type = "3", e.options = [], e.answer = isTrue(e.answer[0]) ? [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? [ "\u9519\u8bef" ] : [];
            }
            return e;
        }
    } ], it = [ {
        type: "hook",
        name: "hook",
        match: () => "xuexi.jsou.cn" === location.host && location.href.includes("newHomework/showHomeworkByStatus") && location.href.includes("checked=true"),
        main: e => {
            $e.mainClass = R("#homeworkHistory").find(".active").attr("id");
            let t = new MutationObserver((async e => {
                $e.mainClass !== R("#homeworkHistory").find(".active").attr("id") && ($e.mainClass = R("#homeworkHistory").find(".active").attr("id"), 
                await waitUntil((function() {
                    return 0 === R(".layui-layer-shade").length;
                })), vuePageChange$1(), t.disconnect());
                for (let n of e) "attributes" === n.type && "class" === n.attributeName && n.target.textContent && (n.target.textContent.includes("\u4e0b\u4e00\u9898") || n.target.textContent.includes("\u4e0a\u4e00\u9898")) && (t.disconnect(), 
                vuePageChange$1());
            }));
            R("body").length >= 1 && t.observe(R("body")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u6c5f\u82cf\u5f00\u653e\u5927\u5b66\u7b54\u9898",
        tips: "",
        match: () => "xuexi.jsou.cn" === location.host && location.href.includes("/showHomeworkByStatus") && location.href.includes("checked=false"),
        types: [ "0", "1", "2", "3" ],
        question: {
            html: ".insert",
            question: ".window-title",
            options: ".questionId-option li > div:not(.numberCover)",
            type: ".questionDiv >div:eq(0)",
            workType: "jsou",
            pageType: "jsou"
        },
        init: async () => {
            document.addEventListener("copy", (function(e) {
                e.stopImmediatePropagation(), layer.msg("\u590d\u5236\u6210\u529f", {
                    icon: 4
                }), e.clipboardData.setData("text/plain", window.getSelection().toString());
            })), document.addEventListener("paste", (() => {
                event.stopImmediatePropagation();
                let e = (event.clipboardData || window.clipboardData).getData("text");
                layer.msg("\u7c98\u8d34\u6210\u529f", {
                    icon: 4
                }), document.execCommand("insertText", !1, e);
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => (e.type = R(e.html).find(".questionDiv >div:eq(1)").text().trim(), 
        e.type = typeConvert(e.type), e.$options = R(e.html).find(".questionId-option li .numberCover"), 
        "3" == e.type && (e.options = []), e),
        setAnswer: e => {
            switch (e.type) {
              case "2":
                if (e.$options = R(e.html).find(".questionTitle input"), e.$options.length == e.answer.length) return e.$options.each(((t, n) => {
                    R(n).val(e.answer[t]);
                })), !1;
                break;

              case "3":
                let t = e.answer;
                return R(e.html).find(".questionId-option>.default-option").each(((e, n) => {
                    isTrue(t) && isTrue(removeHtml(R(n).find(".option-title>div:eq(1)").html())) && R(n).find("div.numberCover").click(), 
                    isFalse(t) && isFalse(removeHtml(R(n).find(".option-title>div:eq(1)").html())) && R(n).find("div.numberCover").click();
                })), !1;

              case "4":
                const n = R(e.html).find(".jianda-answer>div").attr("id");
                return $e.UE.getEditor(`${n}`).setContent(e.answer), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u6c5f\u82cf\u5f00\u653e\u5927\u5b66\u6536\u5f55",
        match: () => "xuexi.jsou.cn" === location.host && location.href.includes("newHomework/showHomeworkByStatus") && location.href.includes("checked=true"),
        question: {
            html: ".insert",
            question: ".window-title",
            options: "#questionId-option li > div:not(.numberCover)",
            type: ".questionDiv >div:eq(0)",
            workType: "jsou",
            pageType: "jsou"
        },
        init: async () => {},
        answerHook: e => {
            const t = R(e.html).find(".questionDiv >div").text(), n = t.match(/\u5206\u503c(\d+)\u5206/), a = t.match(/\u5f97\u5206\uff1a(\d+)/);
            if (!n || !a) return null;
            e.type = typeConvert(R(e.html).find(".questionDiv >div:eq(1)").text());
            if (!(n[1] === a[1] && "0" !== a[1]) && "3" !== e.type) return null;
            switch (e.type) {
              case "0":
              case "1":
              case "3":
                if (e.answer = R(e.html).find(".answer .correctAnswer").text().trim().split("\uff1b").map((t => e.options[t.charCodeAt(0) - 65])), 
                e.answer = e.answer.filter((e => e)), 0 == e.answer.length && (e.answer = R(e.html).find(".answer .studentAnswer").text().trim().split("\uff1b").map((t => e.options[t.charCodeAt(0) - 65]))), 
                e.answer = e.answer.filter((e => e)), 3 == e.type) {
                    e.options = [];
                    let t = e.answer[0];
                    if (isFalse(t)) e.answer = "\u9519\u8bef"; else {
                        if (!isTrue(t)) return;
                        e.answer = "\u6b63\u786e";
                    }
                }
                break;

              case "2":
                e.options = [], e.answer = R(e.html).find(".answer .correctAnswer").text().trim().split("\uff1b"), 
                e.answer = e.answer.filter((e => e)), 0 == e.answer.length && (e.answer = R(e.html).find(".answer .studentAnswer").text().trim().split("\uff1b")), 
                e.answer = e.answer.filter((e => e));
                break;

              default:
                return;
            }
            return e;
        },
        paper: e => {
            const t = $e.homework, n = {
                platform: "jsou"
            };
            n.hash = t.courseId, n.name = t.courseName, n.info = {}, n.chapter = [ {
                hash: `${t.homeworkId}`,
                name: t.title,
                question: e
            } ], Ke.setPaper(n.hash, n);
        }
    } ], rt = [ {
        type: "hook",
        name: "hook",
        match: "spoc-exam.icve.com.cn" === location.host || location.host.includes("exam.courshare.cn") || location.host.includes("webtrn.cn"),
        main: e => {
            $e.mainClass = R(".q_content").first().attr("id");
            let t = new MutationObserver((async e => {
                $e.mainClass !== R(".q_content").first().attr("id") && ($e.mainClass = R(".q_content").first().attr("id"), 
                "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 !== R(".q_content").length;
                })), vuePageChange$1(), t.disconnect());
                for (let n of e) "attributes" === n.type && "class" === n.attributeName && n.target.textContent && (n.target.textContent.includes("\u4e0b\u4e00\u9898") || n.target.textContent.includes("\u4e0a\u4e00\u9898")) && (t.disconnect(), 
                vuePageChange$1());
            }));
            R("#examPage").length >= 1 && t.observe(R("#examPage")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "hook",
        name: "hook",
        match: "zjy2.icve.com.cn" === location.host || "zyk.icve.com.cn" === location.host || "ai.icve.com.cn" === location.host,
        main: e => {
            R(".minimized-dialog img").css({
                "z-index": "999999"
            }), $e.mainClass = R("#app")[0].__vue__.$route.name;
            let t = new MutationObserver((async e => {
                $e.mainClass !== R("#app")[0].__vue__.$route.name && ($e.mainClass = R("#app")[0].__vue__.$route.name, 
                "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 !== R(".q_content").length;
                })), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u804c\u6559\u4e91\u4f5c\u4e1a",
        tips: "",
        match: () => location.href.includes("examflow_index.action"),
        types: [ "0", "2", "1", "3", "4" ],
        question: {
            html: ".q_content",
            question: ".divQuestionTitle",
            options: ".questionOptions > div",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".q_content").length;
            }));
        },
        next: () => {},
        finish: e => {
            R('.paging_next:contains("\u4e0b\u4e00\u9875")').click();
        },
        ischecked: e => 0 !== e.parent().find(".checkbox_on").length,
        questionHook: e => {
            var t, n;
            e.question = removeHtml(R(e.html).find(".divQuestionTitle").html());
            let a = R(e.html).find("[name='quesId']").attr("id"), o = null == (n = null == (t = document.getElementById(`questionId[${a}]`)) ? void 0 : t.getAttribute("answertype")) ? void 0 : n.trim(), s = R(e.html).find("span[name^='questionIndex']").text().trim() + "\u3001", i = R(e.html).find(".q_score").text().trim();
            switch (e.question = e.question.replace(s, "").replace(i, "").trim(), e.options = R(e.html).find(".questionOptions>div").map(((e, t) => {
                let n = R(t).find(".option_index").text().trim();
                return removeHtml(R(t).html()).replace(n, "").trim();
            })).get(), e.$options = R(e.html).find(".questionOptions>div input"), o) {
              case "\u5355\u9879\u9009\u62e9\u9898":
              case "\u5355\u9009\u9898":
              case "singlechoice":
                e.type = "0";
                break;

              case "\u591a\u9879\u9009\u62e9\u9898":
              case "\u591a\u9009\u9898":
              case "multichoice":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
              case "bijudgement":
                e.type = "3", e.options = [];
                break;

              case "fillblank":
                e.type = "2", e.question = removeHtml(R(e.html).find("[name='fillblankTitle']").html());
                break;

              case "cloze":
                e.type = "14", e.options = R(e.html).find(".questionOptions>.exam_cloze_choice").map(((e, t) => [ R(t).find(".optionContent").map(((e, t) => removeHtml(R(t).html()))).get() ])).get();
                break;

              case "textarea":
                e.type = "4", e.options = [];
            }
            return e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "2":
                return R(e.html).find(".fillblank_input > input").each(((t, n) => {
                    R(n).val(e.answer[t]);
                })), !1;

              case "3":
                let t = e.answer;
                return e.ques.$options.each(((e, n) => {
                    isTrue(t) && isTrue(removeHtml(R(n).parent().html())) && R(n).click(), isFalse(t) && isFalse(removeHtml(R(n).parent().html())) && R(n).click();
                })), !1;

              case "4":
                let n = R(e.html).find("[name='quesId']").attr("id");
                return $e.UE.getEditor(`_baidu_editor_${n}`).setContent(`<p>${e.answer}</p>`), !1;
            }
            return !0;
        }
    }, {
        type: "save",
        name: "\u804c\u6559\u4e91\u6536\u5f55",
        match: () => location.href.includes("examrecord_recordDetail.action"),
        question: {
            html: ".q_content",
            question: ".divQuestionTitle",
            options: ".questionOptions>div.q_option_readonly",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".q_content").length;
            }));
        },
        answerHook: e => {
            const t = R(e.html).find(".exam.icon_examright").length, n = R(e.html).find("input[name='quesId']:not([id='']").attr("id"), a = R(`input#qId${n}`).attr("qtype"), o = R(e.html).find("span[name^='questionIndex']").text().trim() + "\u3001", s = R(e.html).find(".q_score").text().trim();
            switch (e.question = e.question.replace(o, "").replace(s, "").trim(), e.options = R(e.html).find(".questionOptions>div.q_option_readonly").map(((e, t) => {
                let n = R(t).find("span[name='optionIndexName']").text().trim();
                return removeHtml(R(t).html()).replace(n, "").trim();
            })).get(), a) {
              case "\u5355\u9879\u9009\u62e9\u9898":
              case "\u5355\u9009\u9898":
              case "singlechoice":
                e.type = "0";
                break;

              case "\u591a\u9879\u9009\u62e9\u9898":
              case "\u591a\u9009\u9898":
              case "multichoice":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
              case "bijudgement":
                e.type = "3";
                break;

              case "fillblank":
              case "\u586b\u7a7a\u9898":
                e.type = "2";
                const t = R(e.html).find(".answerOption>span:eq(0)").clone();
                t.find(".exam_answers").remove(), e.question = titleClean(removeHtml(t.html())).replace(/\uff08.*?\u5206\uff09/g, "").trim();
                break;

              case "cloze":
              case "\u5b8c\u5f62\u586b\u7a7a":
                e.type = "14", e.options = R(e.html).find(".questionOptions>.exam_cloze_choice").map(((e, t) => [ R(t).find(".optionContent").map(((e, t) => removeHtml(R(t).html()))).get() ])).get(), 
                e.answer = R(e.html).find(".exam_rightAnswer .answer_table .one_answer>span").map(((t, n) => {
                    const a = R(n).text().trim();
                    return e.options[t][a.charCodeAt(0) - 65];
                })).get();
                break;

              case "textarea":
                e.type = "4", e.options = [], e.answer = removeHtml(R(e.html).find(".exam_rightAnswer .has_standard_answer").html());
            }
            switch (e.type) {
              case "0":
              case "1":
                if (e.answer = R(e.html).find('.exam_rightAnswer .exam_answers_tit>span[name="rightAnswer"]').text().trim().split("").map((t => e.options[t.charCodeAt(0) - 65])), 
                e.answer, 0 == e.answer.length) {
                    if (0 == t) return;
                    e.answer = R(e.html).find('.exam_stu_answer span[name="stuAnswer"]').text().trim().split("").map((t => e.options[t.charCodeAt(0) - 65]));
                }
                break;

              case "2":
                e.answer = 0 == t ? R(e.html).find(".exam_rightAnswer span.fillblank_answer").map(((e, t) => removeHtml(R(t).html()))).get() : R(e.html).find(".exam_stu_answer span.fillblank_answer").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.answer;
                break;

              case "3":
                e.options = [];
                let n = R(e.html).find('.exam_stu_answer span[name="stuAnswer"]').text().trim();
                [ "\u6b63\u786e", "\u9519\u8bef" ].includes(n) && t && (e.answer = [ n ]);
            }
            return e;
        }
    }, {
        type: "save",
        name: "\u667a\u6167\u804c\u6559\u6536\u5f55",
        match: () => "zjy2.icve.com.cn" === location.host && (location.href.includes("/spocviewsJob") || location.href.includes("/viewExam")),
        question: {
            html: ".subjectDet",
            question: ".seeTitle .htmlP.ql-editor",
            options: ".optionList .htmlP.ql-editor",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".subjectDet").length;
            }));
        },
        answerHook: e => {
            const t = R(e.html).find(".xvhao").text().trim();
            e.type = typeConvert(t.match(/\u3010(.*)\u3011/)[1].trim().replace("\u586b\u7a7a\u9898(\u5ba2\u89c2)", "\u586b\u7a7a\u9898"));
            let n = R(e.html).find(".answer").text().trim();
            switch (e.answer = n.split(",").map((t => e.options[t.charCodeAt(0) - 65])), e.type) {
              case "2":
                e.options = [], e.answer = R(e.html).find(".answer>span").map(((e, t) => removeHtml(R(t).html()))).get();
                break;

              case "3":
                e.options = R(e.html).find(".optionList>div").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.answer = n.split(",").map((t => e.options[t.charCodeAt(0) - 65])), e.answer = judgeAnswer(e.answer[0]), 
                e.options = [];
                break;

              case "11":
                const t = R(e.html).find(".optionList .matching>.htmlP.ql-editor").map(((e, t) => removeHtml(R(t).html()))).get(), a = R(e.html).find(".optionList>.text .htmlP.ql-editor").map(((e, t) => removeHtml(R(t).html()))).get();
                e.options = [ t, a ];
                let o = {};
                n = R(e.html).find(".answer>span").map(((e, n) => {
                    let [s, i] = R(n).text().trim().split(".");
                    s.charCodeAt(0) >= 65 ? s = (s.charCodeAt(0) - 65).toString() : /^\d+$/.test(s) && (s = (parseInt(s) - 1).toString()), 
                    i.charCodeAt(0) >= 65 ? i = (i.charCodeAt(0) - 65).toString() : /^\d+$/.test(i) && (i = (parseInt(i) - 1).toString()), 
                    o[t[s]] = a[i];
                })), e.answer = o;
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u667a\u6167\u804c\u6559+\u7b54\u9898",
        tips: "\u8be5\u5e73\u53f0\u95ee\u9898\u8f83\u591a\uff0c\u9047\u5230\u8bf7\u53cd\u9988\u7ed9\u4f5c\u8005",
        match: () => location.href.includes("coursePreview/jobTest") || location.href.includes("spockeepTest") || location.href.includes("spocjobTest"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".subjectDet",
            question: ".ql-editor",
            options: ".optionList .ql-editor",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".subjectDet").length;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().parent().hasClass("is-checked"),
        questionHook: e => {
            const t = R(e.html).find(".title.titleTwo").text().trim();
            if (e.type = typeConvert(t.match(/\u3010(.*)\u3011/)[1].trim().replace("\u586b\u7a7a\u9898(\u5ba2\u89c2)", "\u586b\u7a7a\u9898")), 
            "3" === e.type) e.options = [], e.$options = R(e.html).find(".optionList>div label");
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u667a\u6167\u804c\u6559+\u6536\u5f55",
        match: () => "zyk.icve.com.cn" === location.host && (location.href.includes("/coursePreview/viewJob1") || location.href.includes("/viewExam")),
        question: {
            html: ".subjectDet",
            question: ".seeTitle>span:eq(1)",
            options: ".optionList>div",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".subjectDet").length;
            }));
        },
        answerHook: e => {
            e.options = removeStartChar(e.options);
            const t = R(e.html).find(".xvhao").text().trim();
            e.type = typeConvert(t.match(/\u3010(.*)\u3011/)[1].trim().replace("\u586b\u7a7a\u9898(\u5ba2\u89c2)", "\u586b\u7a7a\u9898"));
            let n = R(e.html).find(".answer").text().trim();
            switch (e.answer = n.split(",").map((t => e.options[t.charCodeAt(0) - 65])), e.type) {
              case "2":
                e.options = [], e.answer = R(e.html).find(".answer>span").map(((e, t) => removeHtml(R(t).html()))).get();
                break;

              case "3":
                e.options = R(e.html).find(".optionList>div").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.answer = n.split(",").map((t => e.options[t.charCodeAt(0) - 65])), e.answer = judgeAnswer(e.answer[0]), 
                e.options = [];
            }
            return e;
        }
    }, {
        type: "save",
        name: "ai\u4f18\u8bfe\u6536\u5f55",
        match: () => "ai.icve.com.cn" === location.host && location.href.includes("/view-exams/"),
        question: {
            html: () => {
                let e = R(".examination-paper")[0].__vue__.$refs.Questions.sjtmtxlist, t = [];
                return e.sort(((e, t) => e.txdm - t.txdm)), e.forEach((e => {
                    e.sjtmlist.forEach((e => {
                        t.push(e);
                    }));
                })), t;
            },
            question: ".seeTitle>span:eq(1)",
            options: ".optionList>div",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".examination-paper")[0].__vue__.$refs.Questions.sjtmtxlist.length;
            }));
            let e = R(".examination-paper")[0].__vue__.$refs.Questions.sjtmtxlist, t = [];
            e.sort(((e, t) => e.txdm - t.txdm)), e.forEach((e => {
                e.sjtmlist.forEach((e => {
                    t.push(e);
                }));
            })), $e.quesList = t;
        },
        answerHook: (e, t) => {
            const n = e.html;
            e.type = typeMatch(n.txdmmc), e.question = titleClean(n.tmmc);
            let a = [];
            const o = n.sjtmxxlist.map((e => {
                let t = removeHtml(e.xxnr);
                return "1" === e.sfzqda && a.push(t), t;
            }));
            return e.options = o, e.answer = a, e;
        },
        paper: async e => {
            const t = R(".examination-paper")[0].__vue__.sjAllInfo, n = {
                platform: "icve"
            };
            n.hash = t.sskcid, n.info = {};
            const a = "https://ai.icve.com.cn/gjspxpt/jsjkKcgl/getKcjbxx?id=" + t.sskcid;
            await request(a, "GET").then((e => {
                const t = JSON.parse(e[0].responseText).content;
                n.name = t.kcmc, n.info = {}, n.info.imageurl = t.kctpfm;
            })), n.chapter = [ {
                hash: `${t.sjid}`,
                name: t.sjmc,
                question: e
            } ], Ke.setPaper(n.hash, n);
        }
    }, {
        type: "ask",
        name: "ai\u4f18\u8bfe\u7b54\u9898",
        tips: "",
        match: () => "ai.icve.com.cn" === location.host && location.href.includes("/preview-exam/"),
        types: [ "0", "1" ],
        question: {
            html: () => {
                let e = R(".examination-paper")[0].__vue__.$refs.Questions.sjtmtxlist, t = [];
                return e.sort(((e, t) => e.txdm - t.txdm)), e.forEach((e => {
                    e.sjtmlist.forEach((e => {
                        t.push(e);
                    }));
                })), t;
            },
            question: ".seeTitle>span:eq(1)",
            options: "label",
            type: ".question-box .tag",
            workType: "zhijiaoyun",
            pageType: "zhijiaoyun"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".examination-paper")[0].__vue__.$refs.Questions.sjtmtxlist.length;
            }));
        },
        toquestion: e => {
            R(".topic-zpx-list>.topic-zpx>div>span:eq(" + e + ")").click();
        },
        next: () => {},
        ischecked: e => e.hasClass("wrongXz"),
        questionHook: e => {
            const t = e.html;
            e.type = typeMatch(t.txdmmc), e.question = titleClean(t.tmmc);
            let n = [];
            const a = t.sjtmxxlist.map((e => {
                let t = removeHtml(e.xxnr);
                return "1" === e.sfzqda && n.push(t), t;
            }));
            return e.options = a, e.answer = n, e.html = R(".content-center"), e.$options = () => R("label"), 
            e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], lt = [ {
        type: "ask",
        name: "\u5ddd\u519c\u5728\u7ebf\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("cnzx.info") && location.href.includes("KaoShi/ShiTiYe.aspx"),
        types: [ "0", "1", "3" ],
        question: {
            html: "li.question",
            question: ".wenti >p.stem",
            options: ".wenti > ol > li",
            type: ".question_head > span:eq(0)",
            workType: "cnzx",
            pageType: "cnzx"
        },
        init: async () => {},
        ischecked: e => e.find("input").prop("checked"),
        questionHook: e => (e.$options = R(e.html).find(".wenti > ol > li input"), 0 !== e.options.length && (e.type = "radio" === e.$options.eq(0).attr("type") ? "0" : "1", 
        2 === e.options.length && e.options.includes("\u6b63\u786e") && e.options.includes("\u9519\u8bef") && (e.type = "3", 
        e.options = [])), e),
        setAnswer: e => "3" !== e.type || (R(e.html).find(".wenti > ol > li").each(((t, n) => {
            isTrue(e.answer) && isTrue(removeHtml(R(n).html())) && e.ques.$options.eq(t).click(), 
            isFalse(e.answer) && isFalse(removeHtml(R(n).html())) && e.ques.$options.eq(t).click();
        })), !1),
        finish: e => {
            R("li.paginationjs-next.J-paginationjs-next").click();
        }
    }, {
        type: "save",
        name: "\u5ddd\u519c\u5728\u7ebf\u6536\u5f55",
        match: () => location.host.includes("cnzx.info") && location.href.includes("ZaiXianLianXi.aspx"),
        question: {
            html: ".ShiTi>.ShiTiMiaoShu",
            question: ".ShiTiMiaoShu",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "cnzx",
            pageType: "cnzx"
        },
        init: async () => {},
        answerHook: e => {
            R(e.html).text(), e.question = removeHtml(titleClean(removeHtml(R(e.html).html())));
            let t = R("ul.TiXing>li.DangQianTiXing:eq(0)>a").text(), n = [], a = R(e.html).next();
            switch (e.options = removeStartChar(a.find("ul li").map(((e, t) => (R(t).hasClass("DaAn1") && n.push(e), 
            titleClean(removeHtml(R(t).html()))))).get()), e.answer = n.map((t => e.options[t])), 
            t) {
              case "\u5355\u9009\u9898":
              case "\u8bcd\u6c47\u4e0e\u7ed3\u6784":
              case "\u4ea4\u9645\u7528\u8bed":
                e.type = "0";
                break;

              case "\u591a\u9009\u9898":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
                e.type = "3", e.options = [], e.answer = isTrue(e.answer[0]) ? [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? [ "\u9519\u8bef" ] : [];
            }
            return e;
        }
    } ], ct = [ {
        type: "ask",
        name: "\u5b89\u5fbd\u7ee7\u7eed\u6559\u80b2\u7b54\u9898(\u65e7\u7248)",
        tips: "",
        match: () => location.href.includes("study/html/content/studying/?courseOpenId=") || location.href.includes("study/html/content/sxsk/?courseOpenId=") || location.href.includes("study/html/content/tkOnline/?courseOpenId=") || location.href.includes("study/html/content/bkExam/?courseOpenId="),
        types: [ "0", "1", "3" ],
        question: {
            html: ".e-q-body>.e-q",
            question: ".ErichText",
            options: "ul>li>.ErichText",
            type: ".question-box .tag",
            workType: "ahjxjy",
            pageType: "ahjxjy"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".e-q-body>.e-q") && isExist(".e-item");
            })), !isExist(".photo-time") && !isExist(".btn_save")) return !1;
        },
        ischecked: e => e.parent().hasClass("checked"),
        questionHook: e => {
            var t;
            const n = R(e.html).parent().parent();
            switch (e.type = n ? null == (t = n.attr("id")) ? void 0 : t.trim() : "", e.type) {
              case "2":
                e.type = "1";
                break;

              case "1":
                e.type = "0";
                break;

              case "3":
                e.type = "3", e.$options = R(e.html).find("ul>li");
                break;

              case "4":
                e.type = "2";
                break;

              case "5":
                e.type = "4";
                break;

              default:
                e.type, e.type = "8";
            }
            return e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "4":
              case "2":
                return R(e.html).find("textarea.answer-input").focus(), R(e.html).find(" textarea.answer-input"), 
                R(e.html).find(".answer-input.edui-default").each(((t, n) => {
                    let a = R(n).attr("id"), o = $e.UE.getEditor(a);
                    o.ready((function() {
                        o.setContent(`<p>${e.answer[t]}</p>`);
                    }));
                })), R(e.html).find(".answer-input").blur(), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u5b89\u5fbd\u7ee7\u7eed\u6559\u80b2\u6536\u5f55(\u65e7\u7248)",
        tips: "\u8be5\u5e73\u53f0\u4ec5\u652f\u6301\u5355\u9009\u3001\u591a\u9009\u3001\u5224\u65ad\u9898\u578b\uff0c\u5176\u4ed6\u9898\u578b\u6682\u4e0d\u652f\u6301",
        match: () => location.href.includes("study/html/content/studying/?courseOpenId=") || location.href.includes("study/html/content/sxsk/?courseOpenId=") || location.href.includes("study/html/content/tkOnline/?courseOpenId=") || location.href.includes("study/html/content/bkExam/?courseOpenId="),
        question: {
            html: ".e-q-body>.e-q",
            question: ".ErichText",
            options: "ul>li>.ErichText",
            type: ".question-box .tag",
            workType: "ahjxjy",
            pageType: "ahjxjy"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".e-save"), isExist(".e-q-body>.e-q") && isExist(".w_e-q-panel");
            })), !isExist(".e-quest-review")) return !1;
        },
        answerHook: e => {
            var t;
            const n = R(e.html).parent().parent();
            e.type = n ? null == (t = n.attr("id")) ? void 0 : t.trim() : "", e.$options = R(e.html).find("ul>li");
            let a = R(e.html).find("ul>li.checked").map(((e, t) => removeHtml(R(t).find(".ErichText").html()))).get();
            const o = R(e.html).find(".e-q-right").length > 0;
            e.answer = a.filter((e => "" !== e));
            let s = R(e.html).find(".e-ans-ref .e-ans-r").map(((e, t) => removeHtml(R(t).html()))).get();
            1 === s.length && s[0].length > 1 && (s = s[0].split("\u3001"));
            let i = s.map((t => {
                let n = t.charCodeAt() - 65;
                return e.options[n];
            })).filter((e => "" !== e && void 0 !== e));
            switch (e.type) {
              case "2":
                e.type = "1";
                break;

              case "1":
                e.type = "0";
                break;

              case "3":
                e.type = "3", e.answer = R(e.html).find("ul>li.checked").map(((e, t) => removeHtml(R(t).html()))).get(), 
                e.options = [], isTrue(e.answer[0]) ? e.answer = [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? e.answer = [ "\u9519\u8bef" ] : e.answer = [];
                break;

              case "4":
                e.type = "2", e.options = [];
                break;

              case "5":
                e.type = "4", i = [ removeHtml(R(e.html).find(".e-ans-ref>.e-ans-r").html()) ], 
                e.options = [];
                break;

              case "11":
                e.type = "19";
                const t = R(e.html).find("form").map(((e, t) => ({
                    type: "0",
                    question: removeHtml(R(t).find(".e-q-q .ErichText").html()),
                    options: R(t).find("ul li .ErichText").map(((e, t) => removeHtml(R(t).html()))).get()
                }))).get();
                i = i.length > 0 ? judgeAnswer(i[0]) : [], e.options = t;

              default:
                return void e.type;
            }
            if (i.length > 0) return e.answer = i, e;
            if (!o && "3" === e.type && e.answer.length > 0) {
                if (e.answer = function(e) {
                    if (!isTrue(e[0]) && !isFalse(e[0])) return e[0], [];
                    return isTrue(e[0]) ? [ "\u9519\u8bef" ] : isFalse(e[0]) ? [ "\u6b63\u786e" ] : [];
                }(e.answer), 0 === e.answer.length) return;
            } else if (!o) return;
            return e;
        },
        paper: e => {
            const t = $e.online, n = {
                platform: "ahjxjy"
            };
            n.hash = t.courseOpenId, n.name = $e.localStorage.courseNmae, n.info = {}, n.chapter = [ {
                hash: `${t.cell.id}`,
                name: t.cell.title,
                question: e
            } ], Ke.setPaper(n.hash, n);
        }
    }, {
        type: "save",
        name: "\u5b89\u5fbd\u7ee7\u7eed\u6559\u80b2\u6536\u5f55(\u65b0\u7248)",
        tips: "\u8be5\u5e73\u53f0\u4ec5\u652f\u6301\u5355\u9009\u3001\u591a\u9009\u3001\u5224\u65ad\u9898\u578b\uff0c\u5176\u4ed6\u9898\u578b\u6682\u4e0d\u652f\u6301",
        match: () => location.href.includes("/myHomework/answerRecord") || location.href.includes("/myHomework/assignment") || location.href.includes("/myExam/examDetails") || location.href.includes("/myExam/examHistory"),
        question: {
            html: ".option>div[id='answer-card-area']",
            question: ".ErichText",
            options: "ul>li>.ErichText",
            type: ".question-box .tag",
            workType: "ahjxjy",
            pageType: "ahjxjy"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".option>div[id='answer-card-area']");
            }));
        },
        answerHook: (e, t) => {
            const n = R("micro-app-body>#app>div")[0].__vue__.hierarchyList[t];
            e.type = typeMatch(n.name), e.question = titleClean(removeHtml(n.Content));
            const {options: a, answer: o} = n.CourseQuestionOptionList.reduce(((e, t) => {
                const n = removeHtml(t.Content);
                return t.IsAnswer && e.answer.push(n), e.options.push(n), e;
            }), {
                options: [],
                answer: []
            });
            return e.options = a, e.answer = "3" === e.type ? [ judgeAnswer(o[0]) ] : o, "3" === e.type && (e.options = []), 
            e;
        }
    }, {
        type: "ask",
        name: "\u5b89\u5fbd\u7ee7\u7eed\u6559\u80b2\u7b54\u9898(\u65b0\u7248)",
        tips: "\u5355\u9898\u95f4\u9694\u5fc5\u987b\u5927\u4e8e 3 \u79d2\uff01\uff01\u5426\u5219\u5bb9\u6613\u5f02\u5e38\uff01\uff01",
        match: () => location.href.includes("/myHomework/assignment") || location.href.includes("/myExam/examDetails"),
        types: [ "0", "1", "3" ],
        minDelay: 3e3,
        answerDelay: 1e3,
        question: {
            html: ".option>div[id='answer-card-area']",
            question: ".ErichText",
            options: "ul.answer-list>li",
            type: ".question-box .tag",
            workType: "ahjxjy",
            pageType: "ahjxjy"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".option>div[id='answer-card-area']");
            })), !R(".submit-area").text().includes("\u63d0\u4ea4")) return !1;
            const e = R("micro-app-body>#app>div")[0].__vue__, t = e.hierarchyList[0];
            e.goAnchor(t.Id);
        },
        toquestion: e => {
            const t = R("micro-app-body>#app>div")[0].__vue__, n = t.hierarchyList[e];
            (null == n ? void 0 : n.Id) && t.goAnchor(n.Id);
        },
        ischecked: e => e.hasClass("on"),
        questionHook: (e, t) => {
            const n = R("micro-app-body>#app>div")[0].__vue__.hierarchyList[t];
            e.type = typeMatch(n.name), e.question = titleClean(removeHtml(n.Content));
            let a = [];
            return n.CourseQuestionOptionList.forEach((e => {
                const t = removeHtml(e.Content);
                e.IsAnswer, a.push(t);
            })), e.options = a, e.html = "body", e.$options = () => R("ul.answer-list>li"), 
            e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "ask",
        name: "\u5b89\u5fbd\u7ee7\u7eed\u6559\u80b2\u7b54\u9898(\u81ea\u8003)",
        tips: "",
        match: () => location.href.includes("/userinfo/testPaper"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".item-card-area",
            question: ".desc",
            options: "ul>li",
            type: ".question-box .tag",
            workType: "ahjxjy",
            pageType: "ahjxjy"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".exam-paper-wrap");
            })), isExist(".exam-process-area")) return !1;
            const e = R(".exam-paper-wrap")[0].__vue__.topicList.map((e => e.getPaperList)).flat();
            window.Zques = e;
        },
        ischecked: e => e.parent().hasClass("checked"),
        questionHook: (e, t) => {
            const n = Zques[t];
            e.type = typeMatch(n.questionTypeName), e.question = titleClean(removeHtml(n.content));
            const {options: a, answer: o} = n.courseQuestionOptionList.reduce(((e, t) => {
                const n = removeHtml(t.content);
                return t.isAnswer && e.answer.push(n), e.options.push(n), e;
            }), {
                options: [],
                answer: []
            });
            return e.options = a, e.answer = "3" === e.type ? [ judgeAnswer(o[0]) ] : o, "3" === e.type && (e.options = []), 
            e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "4":
              case "2":
                return R(e.html).find("textarea.answer-input").focus(), R(e.html).find(" textarea.answer-input"), 
                R(e.html).find(".answer-input.edui-default").each(((t, n) => {
                    let a = R(n).attr("id"), o = $e.UE.getEditor(a);
                    o.ready((function() {
                        o.setContent(`<p>${e.answer[t]}</p>`);
                    }));
                })), R(e.html).find(".answer-input").blur(), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u5b89\u5fbd\u7ee7\u7eed\u6559\u80b2\u6536\u5f55(\u81ea\u8003)",
        tips: "\u8be5\u5e73\u53f0\u4ec5\u652f\u6301\u5355\u9009\u3001\u591a\u9009\u3001\u5224\u65ad\u9898\u578b\uff0c\u5176\u4ed6\u9898\u578b\u6682\u4e0d\u652f\u6301",
        match: () => location.href.includes("/userinfo/testPaper"),
        question: {
            html: ".item-card-area",
            question: ".ErichText",
            options: "ul>li>.ErichText",
            type: ".question-box .tag",
            workType: "ahjxjy",
            pageType: "ahjxjy"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".exam-paper-wrap");
            })), !isExist(".score-describe")) return !1;
            const e = R(".exam-paper-wrap")[0].__vue__.topicList.map((e => e.getPaperList)).flat();
            window.Zques = e;
        },
        answerHook: (e, t) => {
            const n = Zques[t];
            e.type = typeMatch(n.questionTypeName), e.question = titleClean(removeHtml(n.content));
            const {options: a, answer: o} = n.courseQuestionOptionList.reduce(((e, t) => {
                const n = removeHtml(t.content);
                return t.isAnswer && e.answer.push(n), e.options.push(n), e;
            }), {
                options: [],
                answer: []
            });
            return e.options = a, e.answer = "3" === e.type ? [ judgeAnswer(o[0]) ] : o, "3" === e.type && (e.options = []), 
            e;
        }
    } ], pt = [ {
        type: "save",
        name: "\u9752\u4e66\u4f5c\u4e1a\u7b54\u9898\u6536\u5f55",
        match: () => location.host.includes("qingshuxuetang.com") && (location.href.includes("Student/ExercisePaper?courseId=") || location.href.includes("Student/ViewQuiz?quizId=") || location.href.includes("Student/SimulationExercise/Detail?id=") || location.href.includes("Student/Quiz/Detail?id=")),
        question: {
            html: ".paper-container > .question-detail-container",
            question: ".question-detail-description",
            options: ".question-detail-options .question-detail-option .option-description-preview",
            type: ".question-detail-type-desc",
            workType: "qingshu",
            pageType: "qingshu"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".question-detail-container") && $e.qsques;
            }));
        },
        answerHook: (e, t) => {
            const n = $e.qsques[t];
            switch (e.question = removeHtml(n.description), e.options = n.options ? n.options.map((e => removeHtml(e.description))) : [], 
            e.type = typeConvert(n.typeDesc), e.answer = n.solution.split("").map((t => e.options[t.charCodeAt(0) - 65])), 
            e.type) {
              case "3":
                e.options = [], e.answer = isTrue(e.answer[0]) ? [ "\u6b63\u786e" ] : isFalse(e.answer[0]) ? [ "\u9519\u8bef" ] : [ "" ];
                break;

              case "15":
                e.options = [], e.answer = [], n.subQuestions.forEach((t => {
                    let n = t.options ? t.options.map((e => removeHtml(e.description))) : [], a = t.solution.split("").map((e => n[e.charCodeAt(0) - 65]));
                    e.answer.push(a), e.options.push(n);
                }));
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u9752\u4e66\u5b66\u5802\u4f5c\u4e1a\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("qingshuxuetang.com") && (location.href.includes("/Student/ExercisePaper") || location.href.includes("Student/ExamPaper") || location.href.includes("Student/ViewQuiz") || location.href.includes("Student/SimulationExercise/Detail") || location.href.includes("Student/Quiz/Detail")),
        types: [ "0", "1", "3" ],
        question: {
            html: ".paper-container > .question-detail-container",
            question: ".question-detail-description",
            options: ".question-detail-options .question-detail-option .option-description",
            type: ".question-detail-type-desc",
            workType: "qingshu",
            pageType: "qingshu"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".question-detail-container") && $e.qsques;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().find("input").prop("checked"),
        toquestion: e => {
            R(`.group_item:eq(${e})`), R(`.group_item:eq(${e})`).click();
        },
        questionHook: (e, t) => {
            const n = $e.qsques[t];
            if (e.question = removeHtml(n.description), e.options = n.options ? n.options.map((e => removeHtml(e.description))) : [], 
            e.type = typeConvert(n.typeDesc), "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], ut = [ {
        type: "save",
        name: "\u4f18\u8bfe\u5728\u7ebf\u6536\u5f55",
        match: () => "cce.org.uooconline.com" === location.host && (location.href.includes("/exam/paper") || location.href.includes("/exam/")),
        question: {
            html: ".queContainer",
            question: ".topic-title",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "uooc",
            pageType: "uooc"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".queContainer").length;
            }));
        },
        answerHook: e => {
            const t = $e.angular.element(e.html).scope().question;
            if (e.type = typeConvert(t.type_text), e.question = t.question, e.options = t.options_app.map((e => e.value)), 
            e.answer = t.answer.map((e => t.options[e])), "3" === e.type) e.options = [], e.answer = judgeAnswer(e.answer[0]);
            return e;
        }
    } ], dt = [ {
        type: "ask",
        name: "\u4eac\u4eba\u5e73\u53f0\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("cj-edu.com") && (location.href.includes("/Examination") || location.href.includes("/ExamInfo")),
        types: [ "0", "1", "3" ],
        question: {
            html: ".el-main>.all_subject>div.el-row",
            question: "div.stem",
            options: "ul li > label > span.el-radio__label > div:nth-child(2),ul li > label > span.el-checkbox__label > div:nth-child(2)",
            type: ".question-box .tag",
            workType: "cjedu",
            pageType: "cjedu"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".el-main>.all_subject>div.el-row").length;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            switch (R(e.html).prevAll("h1").first().text().trim()) {
              case "\u5355\u9009\u9898":
                e.type = "0";
                break;

              case "\u591a\u9009\u9898":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
                e.$options = R(e.html).find("ul li>label"), e.options = [], e.type = "3";
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u4eac\u4eba\u5e73\u53f0\u4f5c\u4e1a\u6536\u5f55",
        match: () => location.host.includes("cj-edu.com") && location.href.includes("/ViewAnswerSheet"),
        question: {
            html: ".el-main>.all_subject>div.el-row",
            question: "p.stem",
            options: "ul li > label > span.el-radio__label > div:nth-child(2),ul li > label > span.el-checkbox__label > div:nth-child(2)",
            type: ".question-box .tag",
            workType: "cjedu",
            pageType: "cjedu"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".el-main>.all_subject>div.el-row").length;
            }));
        },
        answerHook: e => {
            let t = R(e.html).find(".seeStudentAnswer>p.answer").text().replace("\u53c2\u8003\u7b54\u6848\uff1a", "").trim(), n = R(e.html).prevAll("h1").first().text().trim();
            switch (e.options.length > 0 && (e.answer = t.split(",").map((t => e.options[t.charCodeAt(0) - 65]))), 
            n) {
              case "\u5355\u9009\u9898":
                e.type = "0";
                break;

              case "\u591a\u9009\u9898":
                e.type = "1";
                break;

              case "\u5224\u65ad\u9898":
                e.options = [], e.answer = judgeAnswer(t), e.type = "3";
            }
            return e;
        }
    } ], mt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("ytccr.com"),
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u7ece\u901a\u7ee7\u6559\u4e91\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("ytccr.com") && location.href.includes("learning-work") && location.href.includes("type=3"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".border-item",
            question: ".title.qa-title",
            options: ".opts-list .opt-title-cnt",
            type: ".question-box .tag",
            workType: "ytccr",
            pageType: "ytccr"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".border-item").length;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            if (e.type = typeConvert(R(e.html).find(".qtype").text().trim()), "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u7ece\u901a\u7ee7\u6559\u4e91\u6536\u5f55",
        match: () => location.host.includes("ytccr.com") && location.href.includes("learning-work") && location.href.includes("type=5"),
        question: {
            html: ".border-item",
            question: ".title.qa-title",
            options: ".opts-list .opt-title-cnt",
            type: ".question-box .tag",
            workType: "ytccr",
            pageType: "ytccr"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".border-item").length;
            }));
        },
        answerHook: e => {
            e.type = typeConvert(R(e.html).find(".qtype").text().trim());
            let t = R(e.html).find(".u-text-success,.u-text-danger").text().split("\uff0c")[0].trim();
            if (t = t.match(/[A-Z]+$/)[0].trim(), e.answer = t.split("").map((t => e.options[t.charCodeAt(0) - 65])), 
            0 === e.answer.length) return e;
            if ("3" === e.type) e.options = [], e.answer = judgeAnswer(e.answer[0]);
            return e;
        }
    } ], ht = [ {
        type: "ask",
        name: "\u5b66\u8d77\u8003\u8bd5",
        tips: "",
        match: () => location.href.includes("oxer/page/ots/examIndex.html"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".queItemClass",
            question: "dt > div.din:eq(1)",
            options: "dd > div",
            type: ".question-box .tag",
            workType: "xueqi",
            pageType: "xueqi"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".queItemClass");
            })), $e.document.onkeydown = null, $e.oncontextmenu = null;
        },
        next: () => {},
        ischecked: e => e.parent().hasClass("cur"),
        questionHook: e => {
            let t = R(e.html).parent().find("div .fb:eq(0)").text().split("\u3001")[1];
            if (t.includes("\u5224\u65ad") && (t = "\u5224\u65ad\u9898"), e.type = typeMatch(t), 
            "3" === e.type) e.options = [], e.$options = R(e.html).find("input");
            return e;
        },
        setAnswer: e => {
            if ("3" === e.type) {
                let t = e.answer;
                return e.ques.$options.each(((e, n) => {
                    isTrue(t) && isTrue(removeHtml(R(n).val())) && R(n).click(), isFalse(t) && isFalse(removeHtml(R(n).val())) && R(n).click();
                })), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u5b66\u671f\u8003\u8bd5\u6536\u5f55",
        match: () => location.href.includes("OTS-UniverDetail.html"),
        question: {
            html: ".dl_list",
            question: "dt > div.fl:eq(1)",
            options: "dd > var",
            type: ".question-box .tag",
            workType: "xueqi",
            pageType: "xueqi"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".dl_list");
            }));
        },
        answerHook: e => {
            var t, n, a, o, s;
            const i = R(e.html).attr("queid"), r = e.html._ms_context_.el.questions.find((e => e.id === i));
            r.questionTypeName.includes("\u5224\u65ad") && (r.questionTypeName = "\u5224\u65ad\u9898"), 
            e.type = typeMatch(r.questionTypeName), e.question = removeHtml(r.stem), console.log(r), 
            e.options = (null == (n = null == (t = r.answerArea) ? void 0 : t.optionList) ? void 0 : n.sort(((e, t) => e.sequence - t.sequence)).map((e => removeHtml(e.content)))) || [];
            let l = r.answer.ans || (null == (a = r.answer.ansL) ? void 0 : a.join("")) || null;
            if (l) e.answer = l.split("").map((t => e.options[t.charCodeAt(0) - 65])); else {
                const t = (null == (s = null == (o = r.answerArea) ? void 0 : o.optionList) ? void 0 : s.filter((e => e.isTrue)).map((e => removeHtml(e.content)))) || [];
                if (0 === r.answerScore) return;
                e.answer = t;
            }
            return "3" === e.type && (e.options = [], e.answer = judgeAnswer(l)), e;
        },
        paper: e => {
            const t = R(".dl_list:eq(0)")[0]._ms_context_.loop.category, n = R(".dl_list:eq(0)")[0]._ms_context_.oAnswerDetailInfo, a = {
                platform: "xueqi"
            };
            a.hash = t.code, a.name = t.value, a.info = {}, a.chapter = [ {
                hash: `${n.arrangementid}`,
                name: n.arrangementname,
                question: e
            } ], Ke.setPaper(a.hash, a);
        }
    } ], ft = [ {
        type: "hook",
        name: "hook",
        match: "gdrtvu.exam-cloud.cn" === location.host,
        main: e => {
            unsafeWindow.mainClass = getUrl();
            let t = new MutationObserver((async e => {
                unsafeWindow.mainClass !== getUrl() && (unsafeWindow.mainClass = getUrl(), vuePageChange(), 
                t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u7b54\u9898",
        tips: "\u516c\u544a",
        match: () => location.host.includes("exam-cloud.cn") && location.href.includes("oe-web/online-exam/exam"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".question-container",
            question: ".question-body:first",
            options: ".option .question-options",
            type: ".question-header .container",
            workType: "guangkai",
            pageType: "guangkai"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".question-container");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            let t = R(".list .current-question").parent().parent().find(".title").text();
            if (console.log(t), t = t.split("\u3001")[1], t = t.replace(/\(.*\)/, "").trim(), 
            console.log(t), e.type = typeConvert(t), "8" == e.type ? e.type = typeMatch(t) : e.type, 
            "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => !0,
        finish: e => {
            R(".next .qm-primary-button").length && R(".next .qm-primary-button")[0].click();
        }
    } ], gt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("open.ha.cn"),
        main: e => {
            const getHash = () => R(".stuHomeworkVersionId.active").attr("id");
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                getHash(), $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), 
                t.disconnect());
            }));
            R(".homeworkBody").length >= 1 && t.observe(R(".homeworkBody")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u4e91\u4e0a\u6cb3\u5f00\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("open.ha.cn") && location.href.includes("/homework/showHomeworkByStatus") && location.href.includes("checked=false"),
        types: [ "0", "1" ],
        question: {
            html: ".layui-colla-content > .insert",
            question: ".window-title",
            options: ".option-title",
            type: ".question-box .tag",
            workType: "openha",
            pageType: "openha"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".layui-colla-content > .insert");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => (e.options = e.$options.map(((t, n) => {
            let a = R(n).find(".numberCover").text().trim();
            return removeHtml(e.$options.eq(t).html()).replace(a, "").trim();
        })).get(), e.type = typeConvert(R(e.html).find(".questionDiv>.float-l:eq(1)").text().trim()), 
        e.$options = R(e.html).find(".option-title .numberCover"), e),
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u4e91\u4e0a\u6cb3\u5f00\u6536\u5f55",
        match: () => location.host.includes("open.ha.cn") && location.href.includes("/homework/showHomeworkByStatus") && location.href.includes("checked=true"),
        question: {
            html: ".layui-colla-content > .insert",
            question: ".window-title",
            options: ".option-title",
            type: ".question-box .tag",
            workType: "openha",
            pageType: "openha"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".layui-colla-content > .insert");
            }));
        },
        answerHook: e => {
            let t = [];
            const n = 0 == R(e.html).find(".option-title.error2").length;
            if (e.options = e.$options.map(((n, a) => {
                let o = R(a).find(".numberCover").text().trim(), s = removeHtml(e.$options.eq(n).html()).replace(o, "").trim();
                return R(a).hasClass("answer-title") && t.push(s), s;
            })).get(), e.type = typeConvert(R(e.html).find(".questionDiv>.float-l:eq(1)").text().trim()), 
            n) return e.answer = t, R(e.html).find(".option-title.error2"), e;
        },
        paper: e => {
            const t = $e.homework, n = {
                platform: "openha"
            };
            n.hash = t.courseId, n.name = t.courseName, n.info = {}, n.chapter = [ {
                hash: `${t.homeworkId}`,
                name: t.title,
                question: e
            } ], Ke.setPaper(n.hash, n);
        }
    } ], yt = [ {
        type: "ask",
        name: "\u6cb3\u5357\u7ee7\u7eed\u6559\u80b2\u7b54\u9898",
        tips: "",
        match: () => location.href.includes("uc/task/startTask"),
        types: [ "0", "1" ],
        answerDelay: 1e3,
        minDelay: 1e3,
        question: {
            html: ".carousel-inner>.item.changeless-box",
            question: ".exam-tg-txt__wrap.e-tg-box",
            options: ".ic-options-list address",
            type: ".question-box .tag",
            workType: "cloudwis",
            pageType: "cloudwis"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".carousel-inner>.item.changeless-box");
            })), !isExist("#finish")) return !1;
            await waitUntil((function() {
                let e = R(".carousel-inner>article").filter(((e, t) => R(t).hasClass("temporary-box"))).eq(0).index();
                return e > 0 ? (R(".slide-tihao:eq(" + e + ")")[0].click(), !1) : (R(".slide-tihao:eq(0)")[0].click(), 
                !0);
            }));
        },
        toquestion: e => {
            R(".slide-tihao:eq(" + e + ")")[0].click();
        },
        ischecked: e => e.find(".checked").length > 0,
        questionHook: e => (e.type = typeConvert(R(e.html).attr("data-name") || ""), e.$options = R(e.html).find(".ic-options__wrap label"), 
        e.question = e.question.replace(/^\(\d+\)/, "").trim(), e.question = e.question.replace(/\(\d+\u5206\)$/, "").trim(), 
        e),
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "ask",
        name: "\u6cb3\u5357\u7ee7\u7eed\u6559\u80b2\u8003\u8bd5\u7b54\u9898",
        tips: "",
        match: () => location.href.includes("uc/exam/record/startExamination"),
        types: [ "0", "1" ],
        question: {
            html: ".trunk-box",
            question: ".exam-tg-txt__wrap.e-tg-box",
            options: ".ic-options-list address",
            type: ".question-box .tag",
            workType: "cloudwis",
            pageType: "cloudwis"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".trunk-box") && isExist(".ic-ac-checkbox-ol");
            })), await waitUntil((function() {
                return window.scrollTo(0, document.body.scrollHeight), R(".ic-ac-checkbox-ol li").length == R(".trunk-box").length;
            })), !isExist("#submit-btn")) return !1;
        },
        next: () => {
            R("#carousel-professional").carousel("next");
        },
        ischecked: e => e.find(".checked").length > 0,
        questionHook: e => {
            const t = R(e.html).attr("data-type");
            switch (console.log(t), t) {
              case "1":
                e.type = "0";
                break;

              case "2":
                e.type = "1";
                break;

              case "3":
                e.type = "3", e.options = [];
            }
            return e.question = e.question.replace(/^\d+\u3001/, "").trim(), e.question = e.question.replace(/\(\d+\u5206\)$/, "").trim(), 
            e.question = e.question.replace(/\[\S+\]$/, "").trim(), e.$options = R(e.html).find(".ic-options__wrap label"), 
            e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u6cb3\u5357\u7ee7\u7eed\u6559\u80b2\u6536\u5f55",
        match: () => location.href.includes("uc/task/startTask"),
        question: {
            html: ".carousel-inner>.item.changeless-box",
            question: ".exam-tg-txt__wrap.e-tg-box",
            options: ".ic-options-list address",
            type: ".question-box .tag",
            workType: "cloudwis",
            pageType: "cloudwis"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".carousel-inner>.item.changeless-box") && isExist(".slide-tihao");
            })), isExist("#finish")) return !1;
            await waitUntil((function() {
                let e = R(".carousel-inner>article").filter(((e, t) => R(t).hasClass("temporary-box"))).eq(0).index();
                return e > 0 ? (R(".slide-tihao:eq(" + e + ")")[0].click(), !1) : (R(".slide-tihao:eq(0)")[0].click(), 
                !0);
            }));
        },
        next: () => {},
        answerHook: e => {
            const t = R(e.html).find(".analysis-box .fs20.c-primary.vam").text().trim().split("");
            return e.type = typeConvert(R(e.html).attr("data-name") || ""), e.answer = t.map((t => e.options[t.charCodeAt(0) - 65])), 
            e.question = e.question.replace(/^\(\d+\)/, "").trim(), e.question = e.question.replace(/\(\d+\u5206\)$/, "").trim(), 
            e;
        }
    }, {
        type: "save",
        name: "\u6cb3\u5357\u7ee7\u7eed\u6559\u80b2\u8003\u8bd5\u6536\u5f55",
        match: () => location.href.includes("uc/exam/record/startExamination"),
        question: {
            html: ".trunk-box.answer-question",
            question: ".exam-tg-txt__wrap.e-tg-box",
            options: ".ic-options-list address",
            type: ".question-box .tag",
            workType: "cloudwis",
            pageType: "cloudwis"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".trunk-box") && isExist(".ic-ac-correct");
            })), await waitUntil((function() {
                return window.scrollTo(0, document.body.scrollHeight), R(".ic-ac-correct,.ic-ac-error").length == R(".trunk-box").length;
            })), isExist("#submit-btn")) return !1;
        },
        next: () => {
            R(".next-slide").click();
        },
        answerHook: e => {
            const t = R(e.html).attr("data-type");
            console.log(t);
            const n = R(e.html).find(".ic-options__wrap label").filter(((e, t) => R(t).find(".checked").length > 0)).map(((e, t) => removeHtml(R(t).html()))).get();
            switch (e.answer = n.map((t => e.options[t.charCodeAt(0) - 65])), e.question = e.question.replace(/^\d+\u3001/, "").trim(), 
            e.question = e.question.replace(/\(\d+\u5206\)$/, "").trim(), e.question = e.question.replace(/\[\S+\]$/, "").trim(), 
            t) {
              case "1":
                e.type = "0";
                break;

              case "2":
                e.type = "1";
                break;

              case "3":
                e.type = "3", e.options = [], e.answer = judgeAnswer(e.answer[0]);
            }
            return e;
        }
    } ], wt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("sclecb.cn"),
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u56db\u5ddd\u5f00\u653e\u5927\u5b66\u7b54\u9898",
        tips: "",
        match: () => "study.sclecb.cn" === location.host && /\/[0-9]+\/show/i.test(location.href),
        types: [ "0", "1", "3" ],
        question: {
            html: ".testpaper-question.js-testpaper-question",
            question: ".testpaper-question-stem",
            options: ".testpaper-question-choices li",
            type: ".question-box .tag",
            workType: "sclecb",
            pageType: "sclecb"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".testpaper-question.js-testpaper-question");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("checked"),
        questionHook: e => {
            switch (e.options = removeStartChar(e.options), e.$options = R(e.html).find(".testpaper-question-choice-inputs > label > input"), 
            e.type = typeConvert(R(e.html).parent().parent().find(".panel-heading>strong").text().trim()), 
            e.type, e.type) {
              case "0":
              case "1":
                break;

              case "3":
                e.$options = R(e.html).find(".radio-inline");
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "ask",
        name: "\u56db\u5ddd\u5f00\u653e\u5927\u5b66\u7b54\u9898\u65e7",
        tips: "",
        match: () => location.host.includes("sclecb.cn") && /student\/course\/study\/[0-9a-zA-Z]+\/test\/redo/i.test(location.href),
        types: [ "0", "1" ],
        question: {
            html: ".questiono-item",
            question: ".clearfix.questiono-header h6",
            options: ".common_test_option .processing_img",
            type: ".question-box .tag",
            workType: "sclecb",
            pageType: "sclecb"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".questiono-item");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("checked"),
        questionHook: e => {
            const t = R(e.html).parent().parent().find("div:eq(0)").text().trim();
            switch (!0) {
              case t.includes("\u5355\u9009\u9898"):
                e.type = "0";
                break;

              case t.includes("\u591a\u9009\u9898"):
                e.type = "1";
                break;

              case t.includes("\u5224\u65ad\u9898"):
                e.type = "3", e.options = [], e.$options = R(e.html).find(".common_test_option > label");
                break;

              default:
                return;
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u56db\u5ddd\u5f00\u653e\u5927\u5b66\u6536\u5f55",
        match: () => "study.sclecb.cn" === location.host && (/task\/[0-9]+\/activity_show/i.test(location.href) || /result\/[0-9]+\/show/i.test(location.href)),
        question: {
            html: ".testpaper-question.js-testpaper-question",
            question: ".testpaper-question-stem",
            options: ".testpaper-question-choices li",
            type: ".question-box .tag",
            workType: "sclecb",
            pageType: "sclecb"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".testpaper-question.js-testpaper-question");
            }));
        },
        answerHook: (e, t) => {
            let n = [];
            e.options = e.$options.map(((e, t) => {
                const a = removeHtml(R(t).clone().find(".testpaper-question-choice-index").remove().end().html());
                return R(t).hasClass("testpaper-question-choice-right") && n.push(a), a;
            })).get(), e.answer = n, e.type = typeConvert(R(".js-panel-card>span").eq(t).prevAll("p").first().text().trim());
            const a = R(".js-panel-card>span").eq(t).hasClass("bg-success");
            switch (e.type) {
              case "0":
              case "1":
                break;

              case "3":
                let t = "";
                t = R(e.html).find(".testpaper-question-result").text().replace("\u4f60\u7684\u7b54\u6848\u662f", "").trim(), 
                e.answer = judgeAnswer(t);
            }
            if ((a || !(e.answer.length > 0) || "3" != e.type) && a) return e;
        }
    } ], vt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("superchutou.com"),
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#root").length >= 1 && t.observe(R("#root")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u51fa\u5934\u7cfb\u7edf\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("superchutou.com") && location.href.includes("onlineclass/exam/"),
        types: [ "0", "1" ],
        question: {
            html: "[class^='single_excer_item']",
            question: "[class^='title_content'] > [class^='title_content_text']:eq(1)",
            options: "[class^='options_content'] label",
            type: ".question-box .tag",
            workType: "chutou",
            pageType: "chutou"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("[class^='single_excer_item']");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            let t = R(e.html).find("[class^='title_content'] > span:eq(1)").text();
            if (t = t.replace(/\u3010|\u3011/g, "").trim(), e.type = typeConvert(t), e.options = removeStartChar(e.options), 
            "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u51fa\u5934\u6536\u5f55",
        match: () => location.host.includes("superchutou.com") && location.href.includes("/onlineclass/analysis/"),
        question: {
            html: "[class^='single_excer_item']",
            question: "[class^='title_content'] > [class^='title_content_text']:eq(1)",
            options: "[class^='options_content'] label",
            type: ".question-box .tag",
            workType: "chutou",
            pageType: "chutou"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("dl>dd>span");
            }));
        },
        answerHook: e => {
            let t = R(e.html).find("[class^='title_content'] > span:eq(1)").text();
            t = t.replace(/\u3010|\u3011/g, "").trim(), e.type = typeConvert(t), e.options = removeStartChar(e.options);
            const n = R(e.html).find(".ant-collapse-header>div.ant-row>div.ant-col.ant-col-18>div:eq(1)").text().replace("\u53c2\u8003\u7b54\u6848\uff1a", "").trim();
            switch (e.type) {
              case "0":
              case "1":
                e.answer = n.split("").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case "3":
                e.options = [], e.answer = judgeAnswer(n);
            }
            return e;
        }
    } ], bt = [ {
        type: "ask",
        name: "\u826f\u5e08\u5728\u7ebf\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("ls365.net") && (location.href.includes("student/examing.aspx") || location.href.includes("Student/myhomework.aspx")),
        types: [ "0", "1" ],
        question: {
            html: ".exam_question",
            question: ".exam_question_title",
            options: ".question_select .select_detail",
            type: ".exam_question_title strong",
            workType: "ls365",
            pageType: "ls365"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".exam_question");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            let t = R(e.html).find(".exam_question_title").clone();
            t.find(".question_number").remove(), t.find("strong").remove(), t.find(".exam_feed_back").remove(), 
            e.question = removeHtml(t.html());
            let n = R(e.html).find(".exam_question_title strong").text();
            return n = n.replace(/\[|\]/g, "").trim(), e.type = typeConvert(n), e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u826f\u5e08\u5728\u7ebf\u8003\u8bd5\u6536\u5f55",
        match: () => location.host.includes("ls365.net") && location.href.includes("User/Student/ViewPaper.aspx"),
        question: {
            html: "[name^='anchor_']",
            question: ".title-img-ctr",
            options: ".pold .phtml",
            type: ".QuestionsType",
            workType: "ls365",
            pageType: "ls365"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("[name^='anchor_']");
            }));
        },
        answerHook: e => {
            let t = R(e.html).find(".QuestionsType").text();
            t = t.replace(/\[|\]/g, "").trim(), e.type = typeConvert(t);
            let n = R(e.html).find(".my-work-answer>p").filter(((e, t) => t.innerText.includes("\u53c2\u8003\u7b54\u6848"))).map(((e, t) => R(t).find(".two").text())).get();
            if (0 !== n.length) return e.answer = n[0].split("").map((t => e.options[t.charCodeAt(0) - 65])), 
            e;
        }
    }, {
        type: "save",
        name: "\u826f\u5e08\u5728\u7ebf\u4f5c\u4e1a\u6536\u5f55",
        match: () => location.host.includes("ls365.net") && location.href.includes("Student/myhomework_after.aspx"),
        question: {
            html: "[name^='anchor_']",
            question: ".my-work-nav>.col-md-10",
            options: ".pold .phtml",
            type: ".QuestionsType",
            workType: "ls365",
            pageType: "ls365"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("[name^='anchor_']");
            }));
        },
        answerHook: e => {
            let t = R(e.html).find(".my-work-nav>div:eq(0)>span:eq(0)").text();
            t = t.replace(/\[|\]/g, "").trim(), e.type = typeConvert(t);
            let n = R(e.html).find(".my-work-answer>p").filter(((e, t) => t.innerText.includes("\u53c2\u8003\u7b54\u6848"))).map(((e, t) => R(t).find(".two").text())).get();
            if (0 !== n.length) return e.answer = n[0].split("").map((t => e.options[t.charCodeAt(0) - 65])), 
            e;
        }
    }, {
        type: "hook",
        name: "hook",
        match: "hbnun.lsedu.vip" === location.host,
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u826f\u5e08\u5728\u7ebf\u4f5c\u4e1a\u7b54\u9898",
        tips: "",
        match: () => location.href.includes("/#/homework/") && !location.href.includes("scene=history"),
        types: [ "0", "1" ],
        question: {
            html: "[id^='question-']",
            question: ".question-content",
            options: "button .flex-1.text-left",
            type: ".self-start.text-3.self-end",
            workType: "ls365",
            pageType: "ls365"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("[id^='question-']");
            }));
        },
        next: () => {},
        ischecked: e => R(e).closest("button").hasClass("is-checked") || R(e).closest("button").hasClass("el-button--primary"),
        questionHook: e => {
            let t = R(e.html).find(".self-start.text-3.self-end").text();
            return t && (t = t.replace(/\[|\]/g, "").trim(), e.type = typeMatch(t)), e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u826f\u5e08\u5728\u7ebf\u4f5c\u4e1a\u6536\u5f55",
        match: () => location.href.includes("/#/homework/") && location.href.includes("scene=history"),
        question: {
            html: "[id^='question-']",
            question: ".question-content",
            options: ".flex.flex-col.space-y-2 .f-c-c.space-x-3 .flex-1",
            type: ".self-start.text-3.self-end",
            workType: "ls365",
            pageType: "ls365"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("[id^='question-']");
            }));
        },
        answerHook: e => {
            let t = R(e.html).find(".self-start.text-3.self-end").text();
            t && (t = t.replace(/\[|\]/g, "").trim(), e.type = typeMatch(t));
            let n = "";
            if (R(e.html).find("div").each(((e, t) => {
                const a = R(t);
                if ((a.find("span").filter(((e, t) => R(t).text().trim().includes("\u6807\u51c6\u7b54\u6848\uff1a"))).length > 0 || a.text().trim().includes("\u6807\u51c6\u7b54\u6848\uff1a")) && (n = a.find(".question-content").text().trim(), 
                n)) return !1;
            })), n) return e.answer = n.split("").map((t => {
                const n = t.charCodeAt(0) - 65;
                return e.options && e.options[n] ? e.options[n] : null;
            })).filter((e => null !== e)), e;
        }
    } ], xt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("jijiaox.com"),
        main: e => {
            $e.mainClass = R("#app")[0].__vue__.$route.path;
            let t = new MutationObserver((async e => {
                $e.mainClass !== R("#app")[0].__vue__.$route.path && ($e.mainClass = R("#app")[0].__vue__.$route.path, 
                vuePageChange(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u7ee7\u6559\u4e91\u8003\u8bd5\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("jijiaox.com") && (location.href.includes("/mg/studentindexexam/") || !location.href.includes("examrec")),
        types: [ "0", "1", "3", "4" ],
        question: {
            html: ".question>div",
            question: ".topic-title",
            options: ".ml_2 label",
            type: ".question-box .tag",
            workType: "jijiaox",
            pageType: "jijiaox"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".question>div");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("is-checked"),
        questionHook: (e, t) => {
            const n = R(".page")[0].__vue__.$data.testInfo.studentPraxisList[t];
            switch (e.options = n.options ? n.options : [], "string" == typeof e.options && (e.options = []), 
            e.question = removeHtml(n.title), n.type) {
              case "single":
                e.type = "0";
                break;

              case "muti":
                e.type = "1";
                break;

              case "charge":
                e.type = "3";
                break;

              case "text":
                e.type = "4";
                break;

              default:
                console.log(n.type, "\u672a\u77e5\u7c7b\u578b");
            }
            return e;
        },
        setAnswer: e => "4" !== e.type || (R(e.html).find(".editor")[0].__vue__.editor.txt.html(e.answer[0]), 
        !1),
        finish: e => {}
    }, {
        type: "save",
        name: "\u7ee7\u6559\u4e91\u8003\u8bd5\u6536\u5f55",
        match: () => location.host.includes("jijiaox.com") && location.href.includes("/mg/studentindexexam/examrec/"),
        question: {
            html: ".question>div",
            question: ".topic-title",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "jijiaox",
            pageType: "jijiaox"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".question>div");
            }));
        },
        answerHook: (e, t) => {
            const n = R(".page")[0].__vue__.$data.testInfo.studentPraxisList[t], a = n.answer;
            switch (e.options = n.options ? n.options : [], "string" == typeof e.options && (e.options = []), 
            e.question = removeHtml(n.title), n.type) {
              case "single":
                e.type = "0";
                break;

              case "muti":
                e.type = "1";
                break;

              case "charge":
                e.type = "3", e.answer = "1" == a ? [ "\u6b63\u786e" ] : "-1" == a ? [ "\u9519\u8bef" ] : [];
                break;

              case "text":
                e.type = "4", e.answer = [ removeHtml(a) ];
                break;

              default:
                console.log(n.type, "\u672a\u77e5\u7c7b\u578b");
            }
            switch (e.type) {
              case "0":
              case "1":
                console.log("________", a), e.answer = "string" == typeof a ? a.split("").map((t => e.options[t.charCodeAt(0) - 65])) : a.map((t => (console.log(t), 
                e.options[t.charCodeAt(0) - 65])));
            }
            return console.log(e), e;
        }
    } ], _t = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("wencaischool.net") && R("#app").length,
        main: e => {
            $e.mainClass = R("#app")[0].__vue__.$route.path;
            let t = new MutationObserver((async e => {
                $e.mainClass !== R("#app")[0].__vue__.$route.path && ($e.mainClass = R("#app")[0].__vue__.$route.path, 
                vuePageChange(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
            const n = document.createElement("style");
            n.type = "text/css", n.innerHTML = "* {\n              font-size: 13px !important;\n            }", 
            document.head.appendChild(n);
        }
    }, {
        type: "ask",
        name: "\u67e0\u6aac\u6587\u624d\u8003\u8bd5\u7b54\u9898",
        tips: "\u6b64\u5e73\u53f0\u7b54\u9898\u95f4\u9694\u5c3d\u91cf3s\u5de6\u53f3\uff0c\u5426\u5219\u53ef\u80fd\u9009\u4e0d\u4e0a\u7b54\u6848",
        match: () => location.host.includes("wencaischool.net") && location.href.includes("/separation/exam/index.html"),
        types: [ "0", "1", "2", "3", "4", "5", "6", "7", "14" ],
        minDelay: 2e3,
        answerDelay: 1e3,
        question: {
            html: ".tmList",
            question: ".tmTitleTxt",
            options: ".perRad .opCont",
            type: ".question-box .tag",
            workType: "wencai",
            pageType: "wencai"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".tmList") && R("#onlineExamArea")[0].__vue__._data.itemsList.length > 0;
            }));
        },
        next: () => {},
        ischecked: e => e[0].checked,
        questionHook: e => {
            let t = R(e.html).find(".tmc.tm").attr("ttype");
            return e.type = typeConvert({
                1: "\u586b\u7a7a\u9898",
                2: "\u7b80\u7b54\u9898",
                3: "\u5355\u9009\u9898",
                4: "\u591a\u9009\u9898",
                5: "\u9605\u8bfb\u7406\u89e3",
                12: "\u5b8c\u5f62\u586b\u7a7a"
            }[t]), e.$options = R(e.html).find(".perRad input"), e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "4":
                return R(e.html).find("textarea").focus(), document.execCommand("selectAll"), document.execCommand("insertText", !1, e.answer[0]), 
                !1;

              case "2":
                R(e.html).find(".ansbox.inputAnswer input").each((async (t, n) => {
                    n.focus(), document.execCommand("selectAll");
                    let a = e.answer[t];
                    document.execCommand("insertText", !1, a), await sleep(1e3);
                }));
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u67e0\u6aac\u6587\u624d\u8003\u8bd5\u6536\u5f55",
        match: () => location.host.includes("wencaischool.net") && location.href.includes("/separation/exam/index.html"),
        question: {
            html: ".tmList",
            question: ".tmTitleTxt",
            options: ".perRad .opCont",
            type: ".question-box .tag",
            workType: "wencai",
            pageType: "wencai"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".tmList") && R("#onlineExamArea")[0].__vue__._data.itemsList.length > 0;
            }));
        },
        answerHook: (e, t) => {
            const n = R("#onlineExamArea")[0].__vue__._data.itemsList[t];
            e.question = removeHtml(n.itemName), e.options = n.optionNodes.map((e => removeHtml(e.optionContent)));
            e.type = typeConvert({
                1: "\u586b\u7a7a\u9898",
                2: "\u7b80\u7b54\u9898",
                3: "\u5355\u9009\u9898",
                4: "\u591a\u9009\u9898",
                5: "\u9605\u8bfb\u7406\u89e3",
                12: "\u5b8c\u5f62\u586b\u7a7a"
            }[n.itemType]);
            let a = n.itemAnswer[0].optionContent;
            switch (e.type) {
              case "0":
              case "1":
                e.answer = a.split("").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case "4":
                e.answer = removeHtml(a);
                break;

              case "2":
                e.answer = n.itemAnswer.map((e => removeHtml(e.optionContent)));
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u67e0\u6aac\u6587\u624d\u4f5c\u4e1a\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("wencaischool.net") && location.href.includes("/exam/portal/exam.jsp"),
        types: [ "0", "1", "2", "3" ],
        question: {
            html: "table[id^='tblItem_'][islabel='0']",
            question: "table>tbody>tr:eq(0)>td:eq(0)",
            options: "table>tbody>tr:eq(1)>td:eq(0) table>tbody>tr>td>label",
            type: ".question-box .tag",
            workType: "wencai",
            pageType: "wencai"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist("table[id^='tblItem_'][islabel=0]");
            })), R(".aah_wrapper>div").css("z-index", 9999);
        },
        next: () => {},
        ischecked: e => e[0].checked,
        questionHook: e => {
            let t = removeHtml(R(e.html).parent().parent().prevAll("tr").filter((function() {
                return R(this).find("table[islabel='1']").length > 0;
            })).first().html());
            if (e.type = typeMatch(t), "8" == e.type && t.includes("\u9009\u62e9\u9898") && (e.type = "0"), 
            "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => {
            if ("2" === e.type) {
                const t = R(e.html).find("table>tbody>tr:eq(0)>td:eq(0)>input");
                t.length == e.answer.length && t.each((async (t, n) => {
                    n.value = "", n.focus(), document.execCommand("selectAll");
                    let a = e.answer[t];
                    document.execCommand("insertText", !1, a), await sleep(1e3);
                }));
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u67e0\u6aac\u6587\u624d\u4f5c\u4e1a\u6536\u5f55",
        match: () => location.host.includes("wencaischool.net") && location.href.includes("/openlearning/exam/portal/view_answer.jsp"),
        question: {
            html: "tr[id^='trScore_']",
            question: "table>tbody>tr:eq(0)>td:eq(0)",
            options: "table>tbody>tr:eq(1)>td:eq(0) table>tbody>tr>td>label",
            type: ".question-box .tag",
            workType: "wencai",
            pageType: "wencai"
        },
        init: async () => {},
        answerHook: (e, t) => {
            const n = removeHtml(R(e.html).prevAll("tr:not([id])").first().html());
            switch (e.type = typeMatch(n), "8" == e.type && n.includes("\u9009\u62e9\u9898") && (e.type = "0"), 
            e.type) {
              case "0":
              case "1":
              case "3":
                const t = R(e.html).find("table>tbody>tr:eq(1)>td:eq(0)>div[style='color:darkred;font-size:10pt']").text().split("\u7b54\u6848\uff1a")[1].split("]")[0];
                e.answer = t.split("").map((t => e.options[t.charCodeAt(0) - 65])), "3" == e.type && (e.options = [], 
                e.answer = judgeAnswer(e.answer[0]));
                break;

              case "2":
                const n = R(e.html).find("table>tbody>tr:eq(0)>td:eq(0)").clone();
                n.find("input").remove(), e.answer = n.find("nobr").map(((e, t) => {
                    const n = removeHtml(R(t).html());
                    return /\[\u53c2\u8003\u7b54\u6848\uff1a(.+?)\]/.exec(n)[1];
                })).get(), n.find("nobr").remove(), n.find("font").remove(), e.question = removeHtml(n.html());
            }
            return e;
        }
    } ], kt = [ {
        type: "save",
        name: "yxlearning\u6536\u5f55",
        match: () => location.host.includes("yxlearning.com") && location.href.includes("exam/start?myExamRecordId"),
        question: {
            html: ".subject>.mb20.sub",
            question: ".ls1.lh30.text-f666",
            options: "ul.options>li.cursor-p",
            type: ".question-box .tag",
            workType: "yxlearning",
            pageType: "yxlearning"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".mb20.sub");
            })), !$e.yxques) return !1;
        },
        answerHook: (e, t) => {
            const n = [];
            $e.yxques.questionStemRPS.forEach(((e, t) => {
                e.listPaperQuestionRP.forEach(((e, t) => {
                    n.push(e);
                }));
            }));
            const a = n[t];
            e.question = titleClean(removeHtml(a.questionName));
            const o = a.type, s = [];
            switch (e.options = removeStartChar(a.paperOptionRPS.map((e => removeHtml(e.context)))), 
            a.paperOptionRPS.forEach(((t, n) => {
                1 == t.standardAnswer && s.push(e.options[n]);
            })), e.answer = s, o) {
              case 1:
                e.type = "3", e.options = [], e.answer = judgeAnswer(e.answer[0]);
                break;

              case 2:
                e.type = "0";
                break;

              case 3:
                e.type = "1";
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u65e5\u7167\u4e13\u4e1a\u6280\u672f\u4eba\u5458\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("yxlearning.com") && location.href.includes("exam/start?myExamRecordId"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".mb20.sub",
            question: ".ls1.lh30.text-f666",
            options: ".cursor-p",
            type: ".question-box .tag",
            workType: "yxlearning",
            pageType: "yxlearning"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".mb20.sub");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("active"),
        questionHook: e => {
            if (e.options = removeStartChar(R(e.html).find("ul>li").map(((e, t) => removeHtml(R(t).html()))).get()), 
            e.$options = R(e.html).find("ul>li"), e.type = typeConvert(R(e.html).parent().prevAll(".title").first().find("[du-html='questionStemName']").text().trim()), 
            "3" === e.type) e.options = [], e.$options = R(e.html).find("ul>li");
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], qt = [ {
        type: "ask",
        name: "\u9ea6\u80fd\u7f51\u7b54\u9898",
        tips: "",
        match: () => location.href.includes("lms/web/onlineexam/exambegin"),
        types: [ "0", "1", "3" ],
        question: {
            html: "#exam_form>.sdiv",
            question: ".eptimu_name",
            options: ".ansdiv > .optiondiv",
            type: ".eptimu_title",
            workType: "cjnep",
            pageType: "cjnep"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".sdiv");
            }));
        },
        toquestion: e => {
            R(`.controldiv > a:eq(${e})`), R(`.epcl_circle:eq(${e})`)[0].click();
        },
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            if (e.question = e.question.replace(/^[0-9]+\u3001/, "").trim(), e.question = titleClean(e.question), 
            e.options = removeStartChar(e.options), e.type = typeMatch(R(e.html).find(".eptimu_title").text().trim()), 
            e.$options = R(e.html).find(".ansdiv input"), "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "3":
                let t = e.answer;
                return R(e.html).find(".ansdiv input").each(((e, n) => {
                    isTrue(t) && "1" == R(n).val() && R(n).click(), isFalse(t) && "0" == R(n).val() && R(n).click();
                })), !1;

              case "2":
              case "4":
              case "5":
              case "6":
                const n = R(e.html).find(".ansdiv textarea"), a = e.answer.join(";");
                n.val(a), n.trigger("input"), n.trigger("keydown"), n.trigger("change"), n.trigger("blur"), 
                n.trigger("focus");
                const o = n[0];
                if (o) {
                    [ "input", "change", "blur", "focus" ].forEach((e => {
                        const t = new Event(e, {
                            bubbles: !0
                        });
                        o.dispatchEvent(t);
                    }));
                }
                return !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u9ea6\u80fd\u7f51\u7b54\u9898\u6536\u5f55",
        match: () => location.href.includes("lms/web/exam/examshow"),
        question: {
            html: "#exam_form>.sdiv",
            question: ".eptimu_name",
            options: ".ansdiv > .optiondiv",
            type: ".eptimu_title",
            workType: "cjnep",
            pageType: "cjnep"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".sdiv");
            }));
        },
        answerHook: e => {
            switch (e.type = typeMatch(R(e.html).find(".eptimu_title").text().trim()), e.question = e.question.replace(/^[0-9]+\u3001/, "").trim(), 
            e.question = titleClean(e.question), e.options = removeStartChar(e.$options.map(((e, t) => {
                let n = R(t).clone();
                return R(n).find("img").remove(), removeHtml(R(n).html()).trim();
            })).get()), e.type) {
              case "0":
              case "1":
                e.answer = e.$options.map(((t, n) => {
                    var a;
                    return (null == (a = R(n).find("img").attr("src")) ? void 0 : a.includes("exam-yes")) && e.options[t];
                })).get().filter((e => void 0 !== e));
                break;

              case "3":
                e.answer = e.$options.map(((t, n) => {
                    var a;
                    return (null == (a = R(n).find("img").attr("src")) ? void 0 : a.includes("exam-yes")) && e.options[t];
                })).get().filter((e => void 0 !== e)), e.answer = judgeAnswer(e.answer), e.options = [];
                break;

              case "4":
                e.options = [];
                let t = removeHtml(R(e.html).find(".eptimu_answer.ansdiv").html()).trim();
                t.includes("\u6b63\u786e\u7b54\u6848\uff1a") ? e.answer = t.split("\u6b63\u786e\u7b54\u6848\uff1a")[1].trim() : e.answer = [];
            }
            return e;
        }
    } ], Ct = [ {
        type: "ask",
        name: "\u9ea6\u80fd\u7f51\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("mynep.com") && location.href.includes("my-exam/exambegin"),
        types: [ "0", "1" ],
        question: {
            html: ".et_test",
            question: ".et_title",
            options: "ul>.et_answer>label",
            type: ".question-box .tag",
            workType: "mynep",
            pageType: "mynep"
        },
        init: async () => {},
        toquestion: e => {
            $e.select_num(e + 1);
        },
        next: () => {},
        ischecked: e => e.parent().find("input").prop("checked"),
        questionHook: e => {
            e.question = e.question.replace(/\u7b2c\d+\u9898\uff1a/, ""), e.options = removeStartChar(e.options);
            switch (R(e.html).find('input[id^="question-num-isdone"]').attr("question_num_type_id")) {
              case "1":
                e.type = "0";
                break;

              case "2":
                e.type = "1";
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u9ea6\u80fd\u7f51\u6536\u5f55",
        match: () => location.host.includes("mynep.com") && location.href.includes("web/my-exam/examshow"),
        question: {
            html: ".et_test",
            question: ".et_title",
            options: "ul>.et_answer>label",
            type: ".question-box .tag",
            workType: "mynep",
            pageType: "mynep"
        },
        init: async () => {},
        answerHook: e => {
            const t = R(e.html).find(".et_title").clone();
            t.find(".exam-btn").remove(), t.find("div").remove(), e.question = removeHtml(t.html()).replace(/\u7b2c\d+\u9898\uff1a/, "").trim(), 
            e.options = [];
            const n = [];
            R(e.html).find(".et_answer>.et_answer>.et_answer>label").map(((t, a) => {
                e.options.push(removeHtml(R(a).html()).trim()), R(a).parent().find("input").prop("checked") && n.push(t);
            })).get(), e.options = removeStartChar(e.options), e.answer = n.map((t => e.options[t]));
            switch (R(e.html).find('input[id^="question-num-isdone"]').attr("question_num_type_id")) {
              case "1":
                e.type = "0";
                break;

              case "2":
                e.type = "1";
                break;

              default:
                return !1;
            }
            return e;
        }
    } ], Tt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("91huayi.com"),
        main: e => {
            const getHash = () => R(".dd_01").attr("questionid");
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 === R(".el-loading-mask").length;
                })), vuePageChange$1(), t.disconnect());
            }));
            R(".box").length >= 1 && t.observe(R(".box")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u534e\u533b\u7f51\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("91huayi.com") && location.href.includes("/ExamInterface/ComputerExamIndex"),
        types: [ "0", "1" ],
        question: {
            html: "#exampage",
            question: ".dd_01",
            options: ".dd_02",
            type: ".big_type",
            workType: "huayi",
            pageType: "huayi"
        },
        init: async () => {},
        next: () => {
            var e;
            null == (e = R("#btnNext")) || e.click();
        },
        ischecked: e => e.prop("checked"),
        questionHook: e => {
            const t = R(e.html).find(".dd_01").clone();
            return t.find(".dd_01_red").remove(), e.question = removeHtml(t.html()), e.options = removeStartChar(e.options), 
            e.type = typeMatch(R(e.html).find(".big_type").text()), e.$options = R(e.html).find("dd.q-content input"), 
            e;
        },
        setAnswer: e => {
            switch (console.log(e), e.type) {
              case "0":
              case "1":
                return e.ques.$options.each(((t, n) => {
                    if (e.answer.includes(t)) {
                        if (e.rule.ischecked && e.rule.ischecked(R(n))) return;
                        n.click();
                    } else e.rule.ischecked && e.rule.ischecked(R(n)) && n.click();
                })), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "ask",
        name: "\u534e\u533b\u7f51\u8003\u8bd5",
        tips: "",
        match: () => location.host.includes("91huayi.com") && location.href.includes("/pages/exam.aspx?cwid="),
        types: [ "0" ],
        question: {
            html: ".test>table",
            question: "thead",
            options: "tbody>tr>td>label",
            type: ".big_type",
            workType: "huayi",
            pageType: "huayi"
        },
        init: async () => {},
        next: () => {
            var e;
            null == (e = R("#btnNext")) || e.click();
        },
        ischecked: e => e.prop("checked"),
        questionHook: e => (e.question = titleClean(e.question), e.question = e.question.replace(/^\d+\u3001/, ""), 
        e.options = removeStartChar(e.options), 0 !== e.options.length && (e.type = "0"), 
        e),
        setAnswer: e => !0,
        finish: e => {}
    } ], At = [ {
        type: "ask",
        name: "\u4e91\u5357\u5f00\u653e\u5927\u5b66\u7b54\u9898",
        tips: "",
        match: () => location.href.includes("hw/student/studentStartHomework.action") && location.host.includes("teach.ynou.edu.cn"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".e_juan02biaoti",
            question: ".qcontent > p:first",
            options: ".signDefault>.label",
            type: ".question-box .tag",
            workType: "ynou",
            pageType: "ynou"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".e_juan02biaoti").length;
            })), R("body").css("text-align", "left");
        },
        next: () => {},
        ischecked: e => (e.find("input").is(":checked"), e.find("input").is(":checked")),
        questionHook: e => {
            e.options = [];
            const t = R(e.html).find(".e_juan02daan").clone();
            t.find(".clear").nextAll().remove();
            const n = removeHtml(t.html()), a = n.split(/[A][\u3001\.\uff0e]/)[0].trim();
            null !== a && (e.question = a), e.question = a, e.question = a;
            const o = n.match(/(?:[A-G](?:[\u3001.]|\s)?\s?.*?)(?=\s*[A-G](?:[\u3001.]|\s)?|\s*$)/gs);
            if (null !== o) {
                const t = removeOptionsStartChar(o.map((e => e.trim())));
                !1 !== t && (e.options = t);
            }
            const s = R(e.html).find(".signDefault").attr("answer_control");
            return "radio" === s && e.options.length > 1 && (e.type = "0"), "checkbox" === s && e.options.length > 1 && (e.type = "1"), 
            "radio" === s && 0 === e.options.length && (e.type = "3"), e;
        },
        setAnswer: e => {
            if (console.log(e), "3" === e.type) {
                let t = e.answer;
                return e.ques.$options.each(((e, n) => {
                    isTrue(t) && isTrue(removeHtml(R(n).html())) && R(n).click(), isFalse(t) && isFalse(removeHtml(R(n).html())) && R(n).click();
                })), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u6536\u5f55",
        match: () => location.href.includes("/hw/student/studentViewHomework.action") && location.host.includes("teach.ynou.edu.cn"),
        question: {
            html: ".e_juan02biaoti",
            question: ".qcontent > p:first",
            options: ".signDefault>.label",
            type: ".question-box .tag",
            workType: "ynou",
            pageType: "ynou"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".e_juan02biaoti").length;
            })), R("body").css("text-align", "left");
        },
        answerHook: e => {
            e.options = [];
            const t = R(e.html).find(".e_juan02daan").clone();
            t.find(".clear").nextAll().remove();
            const n = removeHtml(t.html()), a = n.split(/[A][\u3001\.\uff0e]/)[0].trim();
            if (null === a) return null;
            e.question = a;
            const o = n.match(/(?:[A-G](?:[\u3001.]|\s)?\s?.*?)(?=\s*[A-G](?:[\u3001.]|\s)?|\s*$)/gs);
            if (null !== o) {
                const t = removeOptionsStartChar(o.map((e => e.trim())));
                if (0 == t) return null;
                e.options = t;
            }
            const s = R(e.html).find(".signDefault").attr("answer_control");
            "radio" === s && e.options.length > 1 && (e.type = "0"), "checkbox" === s && e.options.length > 1 && (e.type = "1"), 
            "radio" === s && 0 === e.options.length && (e.type = "3");
            const i = R(e.html).find(".right_answer>font").text();
            switch (e.type) {
              case "0":
              case "1":
                e.answer = i.split("").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case "3":
                e.answer = isTrue(i) ? "\u6b63\u786e" : isFalse(i) ? "\u9519\u8bef" : "";
            }
            return e;
        }
    } ], St = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("21tb.com"),
        main: e => {
            const getHash = () => R("#examIngEmsRightPanel").attr("class");
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#examIngEmsRightPanel").length >= 1 && t.observe(R("#examIngEmsRightPanel")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "21tb\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("21tb.com") && location.href.includes("exercise/newExercise.fullExerciseTemp.do"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".paper-content > .question-panel-middle",
            question: ".question-stem>.name",
            options: "ul.question-options>li>label",
            type: ".question-box .tag",
            workType: "21tb",
            pageType: "21tb"
        },
        init: async () => {
            if (R(".view-paper-content").length > 0) return !1;
        },
        next: () => {},
        ischecked: e => e.parent().find("input").prop("checked"),
        questionHook: e => {
            e.question = titleClean(e.question), e.question = e.question.replace(/\uff08\d+\u5206\uff09$/, "").trim(), 
            e.options = e.options.map((e => e.replace(/^[A-Z]\s*\.\s*/, ""))), e.options = removeStartChar(e.options);
            const t = R(e.html).attr("class") || "";
            switch (console.log(t), !0) {
              case t.includes("SINGLE"):
                e.type = "0";
                break;

              case t.includes("MULTIPLE"):
                e.type = "1";
                break;

              case t.includes("JUDGMENT"):
                e.type = "3", e.options = [];
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "21tb\u6536\u5f55",
        match: () => location.host.includes("21tb.com") && location.href.includes("exercise/newExercise.fullExerciseTemp.do"),
        question: {
            html: "form > .question-panel-middle",
            question: ".question-stem>.name",
            options: "ul.question-options>li>label",
            type: ".question-box .tag",
            workType: "21tb",
            pageType: "21tb"
        },
        init: async () => {
            if (console.log(R(".view-paper-content").length), 0 == R(".view-paper-content").length) return !1;
        },
        answerHook: e => {
            e.question = titleClean(e.question), e.question = e.question.replace(/\uff08\d+\u5206\uff09$/, "").trim(), 
            e.options = e.options.map((e => e.replace(/^[A-Z]\s*\.\s*/, ""))), e.options = removeStartChar(e.options);
            const t = R(e.html).attr("questtype") || "", n = R(e.html).find(".true-answer").text().split("\uff1a")[1].trim();
            switch (!0) {
              case t.includes("SINGLE"):
                e.type = "0", e.answer = n.split(", ").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case t.includes("MULTIPLE"):
                e.type = "1", e.answer = n.split(", ").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case t.includes("JUDGMENT"):
                e.type = "3", e.options = [], e.answer = judgeAnswer(n);
            }
            return console.log(e), e;
        }
    }, {
        type: "ask",
        name: "21tb\u8003\u8bd5\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("21tb.com") && location.href.includes("ems/html/examCenter/fullExamTemp.do"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".paper-content > .question-panel-middle",
            question: ".question-stem",
            options: "ul.question-options>li>label",
            type: ".question-box .tag",
            workType: "21tb",
            pageType: "21tb"
        },
        init: async () => {
            if (R(".view-paper-content").length > 0) return !1;
        },
        next: () => {},
        ischecked: e => e.parent().find("input").prop("checked"),
        questionHook: e => {
            const t = R(e.html).find(".question-stem").clone();
            t.find(".num").remove(), e.question = titleClean(removeHtml(t.html())).replace(/^\./, ""), 
            e.question = e.question.replace(/\uff08\d+\u5206\uff09$/, "").trim(), e.options = e.options.map((e => e.replace(/^[A-Z]\s*\.\s*/, ""))), 
            e.options = removeStartChar(e.options);
            const n = R(e.html).attr("class") || "";
            switch (console.log(n), !0) {
              case n.includes("SINGLE"):
                e.type = "0";
                break;

              case n.includes("MULTIPLE"):
                e.type = "1";
                break;

              case n.includes("JUDGMENT"):
                e.type = "3", e.options = [];
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], Ht = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("168wangxiao.com"),
        main: e => {
            const getHash = () => (R(".question-submit-btn").text(), R(".question-submit-btn").text() || R(".listTit>span").text());
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 === R(".el-loading-mask").length;
                })), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && (R("#app")[0], t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            }));
        }
    }, {
        type: "ask",
        name: "168\u7f51\u6821\u7b54\u9898",
        tips: "168\u7f51\u6821\u76ee\u524d\u652f\u6301\u9009\u62e9\u3001\u5224\u65ad\u3001\u586b\u7a7a\u3001\u7b80\u7b54\uff0c\u5176\u4ed6\u9898\u578b\u8bf7\u53cd\u9988\u7ed9\u4f5c\u8005",
        match: () => location.host.includes("168wangxiao.com") && location.href.includes("/web/learningCenter/details/"),
        types: [ "0", "1", "2", "3", "4" ],
        question: {
            html: ".question-item-container",
            question: ".title-content",
            options: ".options .opt-content",
            type: ".type",
            workType: "168wx",
            pageType: "168wx"
        },
        init: async () => (await waitUntil((function() {
            return 0 !== R(".question-item-container").length;
        })), !R(".question-submit-btn").text().includes("\u91cd\u65b0\u7b54\u9898")),
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            const t = R(e.html).find(".type").text();
            return e.type = typeMatch(t), e;
        },
        setAnswer: e => "4" !== e.type || (R(e.html).find(".ql-editor"), R(e.html).find(".ql-editor")[0].innerHTML = e.answer[0], 
        !1),
        finish: e => {}
    }, {
        type: "save",
        name: "168\u7f51\u6821\u7b54\u9898",
        match: () => location.host.includes("168wangxiao.com") && location.href.includes("/web/learningCenter/details/"),
        question: {
            html: ".question-item-container",
            question: ".title-content",
            options: ".options .opt-content",
            type: ".type",
            workType: "168wx",
            pageType: "168wx"
        },
        init: async () => (await waitUntil((function() {
            return 0 !== R(".question-item-container").length;
        })), R(".question-submit-btn").text().includes("\u91cd\u65b0\u7b54\u9898")),
        answerHook: e => {
            const t = R(e.html).find(".type").text();
            switch (e.type = typeMatch(t), e.answer = R(e.html).find(".options .opt-content.is-correct-answer").map(((e, t) => removeHtml(R(t).html()))).get(), 
            e.type) {
              case "2":
                e.options = [], e.answer = R(e.html).find(".analyze-container>.answer>.text-container>p").map(((e, t) => removeHtml(R(t).html()))).get();
                break;

              case "3":
                e.options = [], e.answer = [ judgeAnswer(e.answer[0]) ];
                break;

              case "4":
                e.options = [], e.answer = R(e.html).find(".analyze-container>.answer>.text-container").map(((e, t) => removeHtml(R(t).html()))).get();
            }
            return e;
        }
    }, {
        type: "ask",
        name: "168\u7f51\u6821\u8003\u8bd5",
        tips: "",
        match: () => location.host.includes("168wangxiao.com") && location.href.includes("/web/examination/answer"),
        types: [ "0", "1", "2", "3", "4" ],
        question: {
            html: ".Answer-area",
            question: ".listTit>span",
            options: ".el-checkbox-group>label",
            type: ".type",
            workType: "168wx",
            pageType: "168wx"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".Answer-area").length;
            }));
        },
        next: () => {
            R('button:contains("\u4e0b\u4e00\u9898")').click();
        },
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => (e.options = removeOptionsStartChar(e.options), e.type = typeMatch(R(".tit-type").text()), 
        e),
        setAnswer: e => "4" !== e.type || (R(e.html).find(".ql-editor"), R(e.html).find(".ql-editor")[0].innerHTML = e.answer[0], 
        !1),
        finish: e => {}
    } ], Ut = [ {
        type: "ask",
        name: "\u4e91\u73ed\u8bfe\u7b54\u9898",
        tips: "",
        match: () => "www.mosoteach.cn" === location.host && location.href.includes("/web/index.php?c=interaction_quiz&m=reply"),
        types: [ "0", "1" ],
        question: {
            html: ".topic-item",
            question: ".t-subject",
            options: ".t-option.t-item label,.t-judge.t-item label",
            type: ".t-type",
            workType: "mosoteach",
            pageType: "mosoteach"
        },
        init: async () => {
            await waitUntil((function() {
                var e;
                return 0 !== (null == (e = R("#app")[0]) ? void 0 : e.__vue__.$data.topics.length);
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("is-checked"),
        questionHook: (e, t) => {
            const n = R("#app")[0].__vue__.$data.topics[t];
            e.question = titleClean(removeHtml(n.subject));
            const a = n.options;
            switch (a.sort(((e, t) => e.item_no - t.item_no)), e.options = a.map((e => removeHtml(e.content))), 
            n.type) {
              case "SINGLE":
                e.type = "0";
                break;

              case "MULTI":
                e.type = "1";
                break;

              case "TF":
                e.type = "3";
            }
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u4e91\u73ed\u8bfe\u6536\u5f55",
        match: () => "www.mosoteach.cn" === location.host && location.href.includes("/web/index.php?c=interaction_quiz&m=person_quiz_result"),
        question: {
            html: ".topic-list > .topic-item",
            question: ".topic-title",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "mosoteach",
            pageType: "mosoteach"
        },
        init: async () => {
            await waitUntil((function() {
                var e;
                return 0 !== (null == (e = R("#app")[0]) ? void 0 : e.__vue__.$data.topics.length);
            }));
        },
        answerHook: (e, t) => {
            const n = R("#app")[0].__vue__.$data.topics[t];
            e.question = titleClean(removeHtml(n.subject));
            const a = n.options;
            switch (a.sort(((e, t) => e.item_no - t.item_no)), e.options = a.map((e => removeHtml(e.content))), 
            e.answer = n.answers.map((t => e.options[t])), n.type) {
              case "SINGLE":
                e.type = "0";
                break;

              case "MULTI":
                e.type = "1";
                break;

              case "TF":
                e.type = "3", e.answer = "F" === n.tfAnswer ? "\u9519\u8bef" : "T" === n.tfAnswer ? "\u6b63\u786e" : "";
                break;

              default:
                return null;
            }
            return e;
        }
    } ], Et = [ {
        type: "hook",
        name: "hook",
        match: "www.learnin.com.cn" === location.host,
        main: e => {
            const getHash = () => {
                try {
                    return R(".page-student-course-topic-do-container")[0].__vue__.$data.topic.studentTopic.id;
                } catch (e) {
                    return "";
                }
            };
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "save",
        name: "learnin\u6536\u5f55",
        match: () => "www.learnin.com.cn" === location.host && location.href.includes("/user/#/user/student/course/") && 0 == R("button:contains('\u63d0\u4ea4\u4f5c\u4e1a')").length,
        question: {
            html: ".store-question-item-container",
            question: ".question-title",
            options: ".question-info>.question-option-list>.option-item",
            type: ".item-question-header>.header-left",
            workType: "learnin",
            pageType: "learnin"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".store-question-item-container");
            }));
        },
        answerHook: (e, t) => {
            const n = R(".page-student-course-topic-do-container")[0].__vue__.$data.topic.topicItems[0].childList, a = n[t];
            switch (n[t], a.questionTypeCode) {
              case "judgment":
                e.type = "3";
                break;

              case "single":
                e.type = "0";
                break;

              case "multiple":
                e.type = "1";
                break;

              default:
                return e;
            }
            e.question = titleClean(removeHtml(a.questionTitle));
            let o = [], s = [];
            return a.optionList.forEach((e => {
                const t = removeHtml(e.content);
                e.isAnswer && s.push(t), o.push(t);
            })), e.options = o, e.answer = s, "3" == e.type && (e.options = [], e.answer = judgeAnswer(s[0])), 
            e;
        }
    }, {
        type: "ask",
        name: "learnin\u7b54\u9898",
        tips: "",
        match: () => "www.learnin.com.cn" === location.host && location.href.includes("/user/#/user/student/course/") && 1 == R("button:contains('\u63d0\u4ea4\u4f5c\u4e1a')").length,
        types: [ "0", "1", "3" ],
        question: {
            html: ".store-question-item-container",
            question: ".question-title",
            options: ".question-info>.question-option-list>.option-item>.option-index",
            type: ".item-question-header>.header-left",
            workType: "learnin",
            pageType: "learnin"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".store-question-item-container");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("active"),
        questionHook: (e, t) => {
            const n = R(".page-student-course-topic-do-container")[0].__vue__.$data.topic.topicItems[0].childList, a = n[t];
            switch (n[t], a.questionTypeCode) {
              case "judgment":
                e.type = "3";
                break;

              case "single":
                e.type = "0";
                break;

              case "multiple":
                e.type = "1";
                break;

              default:
                return e;
            }
            e.question = titleClean(removeHtml(a.questionTitle));
            let o = [];
            return a.optionList.forEach((e => {
                const t = removeHtml(e.content);
                o.push(t);
            })), e.options = o, "3" == e.type && (e.options = []), e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], zt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("ouchn.edu.cn"),
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u7535\u5927\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("ouchn.edu.cn") && location.href.includes("learningPlatform/#/myExamDetails/examQuestion"),
        types: [ "0" ],
        question: {
            html: ".everyQuest",
            question: ".topicTitle",
            options: ".optionList .topicTitle",
            type: ".question-box .tag",
            workType: "ouchn",
            pageType: "ouchn"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".everyQuest");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => (e.type = "0", e),
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u7535\u5927\u6536\u5f55",
        match: () => location.host.includes("ouchn.edu.cn") && location.href.includes("learningPlatform/#/myExamDetails/testPaper"),
        question: {
            html: ".everyQuest",
            question: ".topicTitle",
            options: ".optionList .topicTitle",
            type: ".question-box .tag",
            workType: "ouchn",
            pageType: "ouchn"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".everyQuest");
            }));
        },
        answerHook: e => {
            const t = R(e.html).find('.rightAndWrong>span:contains("\u6b63\u786e\u7b54\u6848")').text().replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim(), n = e.options;
            let a = [];
            return t.split("").forEach((e => {
                a.push(n[e.charCodeAt(0) - 65]);
            })), 1 == a.length ? e.type = "0" : e.type = "1", e.answer = a, e;
        }
    } ], $t = [ {
        type: "hook",
        name: "mooc",
        match: "www.icourse163.org" === location.host,
        main: e => {
            $e.mainClass = R("#courseLearn-inner-box > div:eq(0)").attr("class");
            let t = new MutationObserver((async e => {
                $e.mainClass !== R("#courseLearn-inner-box > div:eq(0)").attr("class") && ($e.mainClass = R("#courseLearn-inner-box > div:eq(0)").attr("class"), 
                "homework-detail-container" === $e.mainClass && await waitUntil((function() {
                    return 0 === R(".el-loading-mask").length;
                })), vuePageChange$1(), t.disconnect());
            }));
            R("#courseLearn-inner-box").length >= 1 && t.observe(R("#courseLearn-inner-box")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "mooc\u7b54\u9898",
        tips: "\u4e2d\u56fd\u5927\u5b66MOOC\u9650\u5236\u7b54\u9898\u901f\u5ea6\uff0c\u8bf7\u4e0d\u8981\u8fc7\u5feb",
        match: () => "www.icourse163.org" === location.host && location.href.includes("#/learn/quiz?id="),
        types: [ "0", "1", "2", "3" ],
        question: {
            html: ".u-questionItem",
            question: ".f-richEditorText",
            options: "ul.choices>li>input",
            type: ".qaCate.j-qacate.f-fl",
            workType: "mooc",
            pageType: "mooc"
        },
        init: async () => {
            await waitUntil((function() {
                return R(".u-questionItem").length, 0 !== R(".u-questionItem").length;
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: (e, t) => {
            R(e.html).find(".qaCate.j-qacate.f-fl > span:eq(0)").attr("class");
            const n = $e.learnUtilQuestionList[t];
            switch (e.question = removeHtml(n.title), e.options = n.options.map((e => removeHtml(e.content))), 
            n.type) {
              case 1:
                e.type = "0";
                break;

              case 2:
                e.type = "1";
                break;

              case 3:
                e.type = "2";
                break;

              case 4:
                e.type = "3", e.options = [];
                break;

              default:
                n.type, e.type = "8";
            }
            return e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "2":
                return R(e.html).find(".u-baseinputui>textarea").each(((t, n) => {
                    R(n).val(e.answer[t]), R(n).focus(), R(n).blur();
                })), !1;

              case "3":
                let t = e.answer;
                R(e.html).find("ul.choices>li").each(((e, n) => {
                    isTrue(t) && R(n).find(".u-icon-correct").length > 0 && R(n).find("input").click(), 
                    isFalse(t) && R(n).find(".u-icon-wrong").length > 0 && R(n).find("input").click();
                }));
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "save",
        name: "\u4e2d\u56fd\u5927\u5b66mooc\u6536\u5f55",
        match: () => "www.icourse163.org" === location.host && location.href.includes("#/learn/quizscore?id="),
        question: {
            html: ".u-questionItem",
            question: ".f-richEditorText",
            options: "ul.choices li>input",
            type: ".qaCate.j-qacate.f-fl",
            workType: "mooc",
            pageType: "mooc"
        },
        init: async () => {
            await waitUntil((function() {
                return R(".u-questionItem").length, 0 !== R(".u-questionItem").length;
            }));
        },
        answerHook: (e, t) => {
            const n = $e.learnUtilQuestionList[t];
            e.question = removeHtml(n.title);
            let a = [], o = [];
            switch (n.options.forEach((e => {
                a.push(removeHtml(e.content)), e.answer && o.push(removeHtml(e.content));
            })), e.options = a, e.answer = o, n.type) {
              case 1:
                e.type = "0";
                break;

              case 2:
                e.type = "1";
                break;

              case 3:
                e.type = "2", e.answer = [ n.stdAnswer ];
                break;

              case 4:
                e.type = "3", e.options = [];
                break;

              default:
                n.type;
            }
            return e;
        }
    } ], jt = [ {
        type: "ask",
        name: "\u897f\u8d22\u5728\u7ebf\u7b54\u9898",
        tips: "",
        match: () => (location.host.includes("swufe-online.com") || location.host.includes("webtrn.cn")) && (location.href.includes("learnspace/course/test/coursewareTest_intoRedoTestPage.action") || location.href.includes("learnspace/learn/learn/templateeight/index.action") || location.href.includes("learnspace/course/test/coursewareTest_intoTestPage.action")),
        types: [ "0", "1", "3" ],
        question: {
            html: ".bank_test > .test_item",
            question: ".test_item_tit",
            options: ".test_item_theme>ul>li>label, .test_item_theme>label",
            type: ".question-box .tag",
            workType: "swufe",
            pageType: "swufe"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".bank_test > .test_item");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            const t = R(e.html).find(".test_item_tit").clone();
            if (t.find(".tipNodo").remove(), e.question = removeHtml(t.html()), e.question = titleClean(e.question), 
            e.type = typeMatch(R(e.html).prevAll(".test_item_type").first().text()), e.question = e.question.replace(/^[.*?]\s*/, "").replace(/^\u3010.*?\u3011\s*/, "").replace(/\s*\uff08\d+\.\d+\u5206\uff09$/, "").replace(/^\d+\./, "").trim().replace(/^\d+\uff0e/, "").trim().replace(/^\d+ ./, "").trim(), 
            e.options = removeStartChar(e.options), "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u897f\u8d22\u5728\u7ebf\u9636\u6bb5\u6d4b\u9a8c\u6536\u5f55",
        match: () => (location.host.includes("swufe-online.com") || location.host.includes("webtrn.cn")) && (location.href.includes("learnspace/course/test/coursewareTest_intoTestAnswerPage.action") || location.href.includes("learnspace/learn/learn/templateeight/index.action")),
        question: {
            html: ".bank_test > .test_item",
            question: ".test_item_tit",
            options: ".test_item_theme>ul>li>.zdh_op_con",
            type: ".question-box .tag",
            workType: "swufe",
            pageType: "swufe"
        },
        init: async () => {},
        answerHook: e => {
            e.type = typeMatch(R(e.html).prevAll(".test_item_type").first().text()), e.question = e.question.replace(/^[.*?]\s*/, "").replace(/^\u3010.*?\u3011\s*/, "").replace(/\s*\uff08\d+\.\d+\u5206\uff09$/, "").replace(/^\d+\./, "").trim().replace(/^\d+\uff0e/, "").trim().replace(/^\d+ ./, "").trim(), 
            e.options = removeStartChar(e.options);
            const t = R(e.html).find(".test_item_key_tit").text().replace("\u53c2\u8003\u7b54\u6848\uff1a", "").trim();
            switch (e.type) {
              case "0":
              case "1":
                e.answer = t.split("").map((t => {
                    let n = t.charCodeAt() - 65;
                    return e.options[n];
                }));
                break;

              case "3":
                e.answer = judgeAnswer(t), e.options = [];
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u897f\u8d22\u5728\u7ebf\u7efc\u5408\u7ec3\u4e60\u7b54\u9898",
        tips: "\u897f\u8d22\u5728\u7ebf\u6536\u5f55\u8bf7\u91cd\u65b0\u70b9\u51fb\u9898\u578b\u5207\u6362\u89e6\u53d1",
        match: () => location.host.includes("swufe-online.com") && location.href.includes("/learnspace/userDefine/t_test.jsp?courseId="),
        types: [ "0", "1", "3" ],
        question: {
            html: ".timu_title",
            question: ".timu_title",
            options: ".test_item_theme>ul>li",
            type: ".question-box .tag",
            workType: "swufe",
            pageType: "swufe"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".timu_title");
            })), !document.body.innerHTML.includes("\u63d0\u4ea4\u7b54\u9898\u540e\u663e\u793a")) return !1;
            R(".layui-tab-title>li").on("click", (function() {
                vuePageChange$1();
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: (e, t) => {
            const n = R(e.html).attr("id");
            return e.type = typeMatch(R(".layui-this").text()), e.question = removeHtml(R(e.html).html()), 
            e.options = R(`#${n}`).map((function() {
                let t = [], n = R(this).next(), a = [];
                for (;n.length && n.hasClass("question-item-opt"); ) a.push(removeHtml(n[0].outerHTML)), 
                t.push(n), n = n.next();
                return e.$options = R(t.map((e => e[0]))).find("label"), a;
            })).get(), e.options = removeStartChar(e.options), e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u897f\u8d22\u5728\u7ebf\u7efc\u5408\u4f5c\u4e1a\u6536\u5f55",
        match: () => location.host.includes("swufe-online.com") && location.href.includes("/learnspace/userDefine/t_test.jsp?courseId="),
        question: {
            html: ".timu_title",
            question: ".timu_title",
            options: ".test_item_theme>ul>li",
            type: ".question-box .tag",
            workType: "swufe",
            pageType: "swufe"
        },
        init: async () => {
            if (await waitUntil((function() {
                return isExist(".timu_title");
            })), document.body.innerHTML.includes("\u63d0\u4ea4\u7b54\u9898\u540e\u663e\u793a")) return !1;
            R(".layui-tab-title>li").on("click", (function() {
                vuePageChange$1();
            }));
        },
        answerHook: e => {
            const t = R(e.html).attr("id");
            switch (e.type = typeMatch(R(".layui-this").text()), e.question = removeHtml(R(e.html).html()), 
            e.options = R(`#${t}`).map((function() {
                let t = [], n = R(this).next(), a = [];
                for (;n.length && n.hasClass("question-item-opt"); ) a.push(removeHtml(n[0].outerHTML)), 
                t.push(n), n = n.next();
                return e.$options = R(t.map((e => e[0]))).find("label"), a;
            })).get(), e.options = removeStartChar(e.options), e.type) {
              case "0":
              case "1":
                const n = R(`#${t}`).nextAll(".ans").first().find("span:eq(0)").text();
                e.answer = n.trim().split("").map((t => {
                    let n = t.charCodeAt() - 65;
                    return e.options[n];
                }));
                break;

              case "3":
                e.answer = judgeAnswer(R(`#${t}`).nextAll(".ans").first().find("span:eq(0)").text().trim()), 
                e.options = [];
                break;

              case "7":
              case "4":
                e.answer = removeHtml(R(`#${t}`).nextAll(".ans").first().html()).replace("\u6b63\u786e\u7b54\u6848\uff1a", "").trim(), 
                e.options = [];
                break;

              default:
                e.type;
            }
            return e;
        }
    } ], It = [ {
        type: "ask",
        name: "\u91cd\u5e86\u6cd5\u6cbb\u8003\u8bd5\u7b54\u9898",
        tips: "\u672c\u5e73\u53f0\u65e0\u7b54\u6848\u6536\u5f55\uff0c\u9700\u8981\u81ea\u884c\u8865\u5145\u9898\u5e93\uff0c\u5efa\u8bae\u4f7f\u7528\u9898\u5e93\u5bfc\u5165\u529f\u80fd",
        match: () => "ks.cqsdx.cn" === location.host && location.pathname.includes("/exam/user/bind"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".qlist",
            question: "span:eq(1)",
            options: "label",
            type: ".badge.badge-danger",
            workType: "cqsdx",
            pageType: "cqsdx"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".qlist");
            }));
        },
        toquestion: e => {
            R(`#question_card button:eq(${e})`).click();
        },
        next: () => {},
        ischecked: e => e.find("div").hasClass("checked"),
        questionHook: e => {
            const t = R(e.html).find(".badge.badge-danger").text();
            if (e.type = typeMatch(t), e.question = e.question.replace(/\u206B/g, "").trim(), 
            e.options = e.options.map((e => e.replace(/\u206B/g, "").trim())), "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => !0,
        finish: e => {}
    } ], Lt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("telfri-edu.com"),
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "olearn\u7b54\u9898",
        tips: "",
        match: () => location.host.includes("telfri-edu.com") && location.href.includes("/learn/homework/do/"),
        types: [ "0", "1", "3" ],
        question: {
            html: ".topic-group>.topic-container",
            question: ".topic-title",
            options: ".topic-answer .radio-wrap .radio-text",
            type: ".question-box .tag",
            workType: "olearn",
            pageType: "olearn"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".topic-group>.topic-container");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("is-active"),
        questionHook: e => {
            let t = R(e.html).prevAll(".topic-title").first().find(".title-bold").text().trim();
            return e.$options = R(e.html).find(".topic-answer .radio-wrap>label"), e.type = typeMatch(t), 
            e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "olearn\u6536\u5f55",
        match: () => location.host.includes("telfri-edu.com") && location.href.includes("/learn/homework/show/"),
        question: {
            html: ".topic-group>.topic-container",
            question: ".topic-title",
            options: ".topic-answer .radio-wrap .radio-text",
            type: ".question-box .tag",
            workType: "olearn",
            pageType: "olearn"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".topic-group>.topic-container");
            }));
        },
        answerHook: e => {
            let t = R(e.html).prevAll(".topic-title").first().find(".title-bold").text().trim();
            e.type = typeMatch(t);
            const n = R(e.html).find(".standard-answer>.analysis-text").text().trim();
            switch (e.type) {
              case "0":
              case "1":
                e.answer = n.split("").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case "3":
                e.options = [], e.answer = judgeAnswer(n);
            }
            return e;
        }
    } ], Ot = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("yxbyun.com"),
        main: e => {
            const getHash = () => R("#app")[0].__vue__.$route.path;
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "save",
        name: "\u4ebf\u5b66\u5b9d\u6536\u5f55",
        match: () => location.host.includes("yxbyun.com") && (location.href.includes("yxbstudent/#/testPaper") || location.href.includes("yxbstudent/#/finalExam")),
        question: {
            html: ".test_wrap",
            question: ".content",
            options: ".el-radio-group input",
            type: ".question-box .tag",
            workType: "yxbyun",
            pageType: "yxbyun"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".test_wrap");
            }));
        },
        answerHook: e => {
            var t;
            const n = R(e.html).find("div:eq(0)")[0].__vue__, a = (null == (t = n.pagerData) ? void 0 : t.question) || n.smallPaper.questionTopic;
            return e.type = typeMatch(n.queTypeName), e.question = titleClean(removeHtml(a.questionTitle)), 
            e.options = (a.optionList || a.questionOptionList).map((e => removeHtml(e.questionContent))), 
            [ "0", "1", "3" ].includes(e.type) && (e.answer = a.questionAnswer.split(",").map((t => e.options[t.charCodeAt(0) - 65]))), 
            "3" === e.type && (e.options = [], e.answer = judgeAnswer(e.answer)), e;
        }
    }, {
        type: "ask",
        name: "\u4ebf\u5b66\u5b9d\u7b54\u9898",
        match: () => location.host.includes("yxbyun.com") && (location.href.includes("yxbstudent/#/testPaper") || location.href.includes("yxbstudent/#/finalExam")),
        types: [ "0", "1", "3" ],
        question: {
            html: ".test_wrap",
            question: ".content",
            options: ".answer>.daan,.el-radio-group>label",
            type: ".question-box .tag",
            workType: "yxbyun",
            pageType: "yxbyun"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".test_wrap");
            }));
        },
        next: () => {},
        ischecked: e => e.hasClass("active"),
        questionHook: e => {
            var t;
            const n = R(e.html).find("div:eq(0)")[0].__vue__, a = (null == (t = n.pagerData) ? void 0 : t.question) || n.smallPaper.questionTopic;
            if (e.type = typeMatch(n.queTypeName), e.question = titleClean(removeHtml(a.questionTitle)), 
            e.options = (a.optionList || a.questionOptionList).map((e => removeHtml(e.questionContent))), 
            "3" === e.type) e.options = [];
            return e;
        },
        setAnswer: e => {
            if ("3" === e.type) {
                let t = e.answer;
                return e.ques.$options.each(((e, n) => {
                    isTrue(t) && isTrue(removeHtml(R(n).parent().html())) && R(n).click(), isFalse(t) && isFalse(removeHtml(R(n).parent().html())) && R(n).click(), 
                    removeHtml(R(n).parent().html());
                })), !1;
            }
            return !0;
        },
        finish: e => {}
    } ], Ft = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("wdjycj.com") || location.host.includes("iwdjy.com"),
        main: e => {
            const getHash = () => getUrl();
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R("#app").length >= 1 && t.observe(R("#app")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "save",
        name: "\u6587\u9876\u5728\u7ebf\u6536\u5f55",
        match: () => location.href.includes("/testpaper-test-result?resultId=") || location.href.includes("/testpaper-test?id"),
        question: {
            html: ".st-item",
            question: ".st-title",
            options: ".st-main>p",
            type: ".question-box .tag",
            workType: "wdzx",
            pageType: "wdzx"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".st-item");
            }));
            let e = [];
            try {
                R(".exam-html")[0].__vue__.test.lists.forEach(((t, n) => {
                    t.question_lists.forEach(((t, n) => {
                        e.push(t);
                    }));
                }));
            } catch (t) {}
            $e.ques = e;
        },
        answerHook: (e, t) => {
            var n;
            const a = $e.ques[t], o = [];
            switch (e.question = titleClean(removeHtml(a.content)), e.options = (null == (n = a.appanswer) ? void 0 : n.map((e => {
                const t = removeHtml(e.text);
                return e.right && o.push(t), removeHtml(t);
            }))) || [], a.tm_type) {
              case 4:
                e.type = "3", e.answer = judgeAnswer("1" == a.answer ? "\u6b63\u786e" : "0" == a.answer ? "\u9519\u8bef" : "");
                break;

              case 5:
                e.type = "2", e.question = e.question.replace(/{#answer}/g, "_____"), e.answer = a.answer.split("|").map((e => e.includes("\u203b") ? e.split("\u203b")[0] : e));
                break;

              case 2:
                e.type = "0", e.answer = o;
                break;

              case 3:
                e.type = "1", e.answer = o;
                break;

              case 1:
                e.type = "4", e.answer = removeHtml(a.answer);
                break;

              default:
                a.tm_type;
            }
            return e;
        }
    }, {
        type: "ask",
        name: "\u6587\u9876\u5728\u7ebf\u7b54\u9898",
        tips: "",
        match: () => location.href.includes("/testpaper-test?id=") || location.href.includes("/final-exam"),
        types: [ "0", "1", "2", "3" ],
        question: {
            html: ".st-item",
            question: ".st-title",
            options: ".st-main>p",
            type: ".question-box .tag",
            workType: "wdzx",
            pageType: "wdzx"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".st-item");
            }));
        },
        next: () => {},
        toquestion: e => {
            R(`.card-box .bj:eq(${e})`).click();
        },
        ischecked: e => R(e).find("input").prop("checked"),
        questionHook: (e, t) => {
            e.options = removeOptionsStartChar(e.options);
            const n = R(e.html).find(".st-title").clone();
            R(n).find("strong").remove(), e.question = removeHtml(R(n).html());
            let a = R(e.html).prevAll(".title").first().text().trim();
            return e.type = typeMatch(a), e.$options = R(e.html).find(".answer-box>.answer>label"), 
            e;
        },
        setAnswer: e => {
            switch (e.type) {
              case "4":
              case "5":
              case "6":
              case "7":
                return R(e.html).find(".answer-text>div")[0].__vue__.msg.yourAnswer = e.answer[0], 
                R(e.html).find(".quill-editor").map(((t, n) => {
                    n.__vue__.value = e.answer[t];
                })), !1;

              case "2":
                let setYourAnswerById = function(e, t, n) {
                    for (let a of e) if (Array.isArray(a.itemlists)) for (let e of a.itemlists) if (e.id === t) return e.yourAnswer = n, 
                    !0;
                    return !1;
                };
                const t = R(e.html).find("span.bj input").attr("name");
                return setYourAnswerById(R(".exam-html")[0].__vue__.answerCard, Number(t), e.answer), 
                e.answer, !1;
            }
            return !0;
        },
        finish: e => {}
    } ], Pt = [ {
        type: "ask",
        name: "\u6b66\u6c49\u7406\u5de5\u7ee7\u7eed\u6559\u80b2\u7b54\u9898",
        tips: "\u6b66\u6c49\u7406\u5de5\u7ee7\u7eed\u6559\u80b2\u4ec5\u652f\u6301\u9009\u62e9\u3001\u5224\u65ad\u9898\u5176\u4ed6\u9898\u578b\u6682\u4e0d\u652f\u6301\uff0c\u82e5\u6709\u9700\u8981\u8bf7\u53cd\u9988\u7ed9\u4f5c\u8005",
        match: () => location.href.includes("/web/exercise.htm"),
        question: {
            html: ".pad_top",
            question: "div:eq(0)",
            options: ".radio>label",
            type: ".question-box .tag",
            workType: "whut",
            pageType: "whut"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".pad_top").length;
            }));
        },
        next: () => {},
        ischecked: e => e.find("input").is(":checked"),
        questionHook: e => {
            e.question = titleClean(e.question), e.question = e.question.replace(/^\d+\s*[\u3001.\uff09)]/, "").trim(), 
            e.options = removeOptionsStartChar(e.options);
            let t = R(e.html).prevAll(".p-title").first().clone();
            return t = t.remove("span"), e.type = typeMatch(t.text()), e.type, e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u6b66\u6c49\u7406\u5de5\u7ee7\u7eed\u6559\u80b2\u6536\u5f55",
        match: () => location.href.includes("/web/showexercise.htm"),
        question: {
            html: ".pad_top",
            question: "div:eq(0)",
            options: ".radio>label",
            type: ".question-box .tag",
            workType: "whut",
            pageType: "whut"
        },
        init: async () => {
            await waitUntil((function() {
                return 0 !== R(".pad_top").length;
            }));
        },
        answerHook: e => {
            e.question = titleClean(e.question), e.question = e.question.replace(/^\d+\s*[\u3001.\uff09)]/, "").trim(), 
            e.options = removeOptionsStartChar(e.options);
            const t = !R(e.html).children("p").first().text().includes("\u9519\u8bef:");
            let n = [], a = R(e.html).prevAll(".p-title").first().clone();
            switch (a = a.remove("span"), e.type = typeMatch(a.text()), e.type) {
              case "0":
              case "1":
                if (e.$options.each(((t, a) => {
                    R(a).find("input").is(":checked") && n.push(e.options[t]);
                })), t) e.answer = n; else {
                    let t = R(e.html).children("p").first().text().match(/\u3010(.*?)\u3011/);
                    n = [], t && t[1].split(";").forEach((t => {
                        n.push(e.options[t.charCodeAt(0) - 65]);
                    })), e.answer = n;
                }
                break;

              case "3":
                if (e.$options.each(((t, a) => {
                    R(a).find("input").is(":checked") && n.push(e.options[t]);
                })), t) e.answer = n[0]; else {
                    let t = R(e.html).children("p").first().text().match(/\u3010(.*?)\u3011/);
                    n = [], t && t[1].split(";").forEach((t => {
                        n.push(e.options[t.charCodeAt(0) - 65]);
                    })), e.answer = n[0];
                }
                e.options = [];
            }
            return e;
        }
    } ], Mt = [ {
        type: "save",
        name: "\u4e1c\u5317\u8d22\u7ecf\u5927\u5b66\u6210\u6559\u6536\u5f55",
        match: () => location.host.includes("dufe.edu.cn") && (location.href.includes("/HomeWorkPaper") || location.href.includes("/HomeWorkHistoryPaper") || location.href.includes("/ExercisesPaper")),
        question: {
            html: ".QuestTrunk,.HistoryQuestTrunk",
            question: ".CBTPaperMain-divInline",
            options: ".CBTPaperMain-options li",
            type: ".question-box .tag",
            workType: "dufe",
            pageType: "dufe"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".QuestTrunk,.HistoryQuestTrunk");
            }));
        },
        answerHook: e => {
            const t = e.html.vtree[0].vmodel._trunks[0], n = e.html.vtree[0].vmodel._type;
            let a = [], o = [];
            const getOption = () => {
                t.QUESTION_OPTIONS.forEach((e => {
                    const t = removeHtml(e.OPTION_CONTENT);
                    "1" === e.ISTRUE && a.push(t), o.push(t);
                }));
            };
            switch (n) {
              case "001":
                e.type = "0", getOption();
                break;

              case "002":
                e.type = "1", getOption();
                break;

              case "004":
                e.type = "3", e.options = [], a = "1" === t.QUESTION_OPTIONS[0].ISTRUE ? [ "\u6b63\u786e" ] : "0" === t.QUESTION_OPTIONS[0].ISTRUE ? [ "\u9519\u8bef" ] : [];
                break;

              case "005":
                e.type = "4", a = [ removeHtml(t.QUESTION_OPTIONS[0].OPTION_CONTENT) ];
            }
            return e.question = titleClean(t.QUESTION_TITLE), e.options = o, e.answer = a, e;
        }
    }, {
        type: "ask",
        name: "\u4e1c\u5317\u8d22\u7ecf\u5927\u5b66\u6210\u6559\u7b54\u9898",
        match: () => location.host.includes("dufe.edu.cn") && (location.href.includes("/HomeWorkPaper") || location.href.includes("/ExercisesPaper")),
        types: [ "0", "1", "3", "4" ],
        question: {
            html: ".QuestTrunk",
            question: ".CBTPaperMain-divInline",
            options: ".CBTPaperMain-options li>label",
            type: ".question-box .tag",
            workType: "dufe",
            pageType: "dufe"
        },
        init: async () => {},
        next: () => {},
        ischecked: e => e.parent().find("input").prop("checked"),
        questionHook: e => {
            const t = e.html.vtree[0].vmodel._trunks[0], n = e.html.vtree[0].vmodel._type;
            let a = [], o = [];
            const getOption = () => {
                t.QUESTION_OPTIONS.forEach((e => {
                    const t = removeHtml(e.OPTION_CONTENT);
                    "1" === e.ISTRUE && a.push(t), o.push(t);
                }));
            };
            switch (n) {
              case "001":
                e.type = "0", getOption();
                break;

              case "002":
                e.type = "1", getOption();
                break;

              case "004":
                e.type = "3", e.options = [], a = "1" === t.QUESTION_OPTIONS[0].ISTRUE ? [ "\u6b63\u786e" ] : "0" === t.QUESTION_OPTIONS[0].ISTRUE ? [ "\u9519\u8bef" ] : [];
                break;

              case "005":
                e.type = "4", a = [ removeHtml(t.QUESTION_OPTIONS[0].OPTION_CONTENT) ];
            }
            return e.question = titleClean(t.QUESTION_TITLE), e.options = o, e.answer = a, e;
        },
        setAnswer: e => {
            if ("4" === e.type) {
                const t = R(e.html).find("textarea")[0];
                return t._ms_context_._answer = e.answer[0], t._ms_context_._save(), !1;
            }
            return !0;
        },
        finish: e => {}
    }, {
        type: "ask",
        name: "\u4e1c\u5317\u8d22\u7ecf\u5927\u5b66\u6210\u6559\u7b54\u9898(\u7efc\u5408)",
        match: () => location.host.includes("dufe.edu.cn") && location.href.includes("/CompHomeworkPaper"),
        types: [ "0", "1", "3", "4" ],
        question: {
            html: ".Question",
            question: ".CBTPaperMain-trunkTitle",
            options: "ul.Question-options>li",
            type: ".question-box .tag",
            workType: "dufe",
            pageType: "dufe"
        },
        init: async () => {},
        next: () => {},
        ischecked: e => e.parent().find("input").prop("checked"),
        questionHook: e => {
            const t = (e => {
                var t;
                if (e) {
                    const n = Object.keys(e).find((e => e.startsWith("__reactEventHandlers")));
                    if (n) {
                        const t = e[n];
                        return console.log("React \u4e8b\u4ef6\u5904\u7406\u5bf9\u8c61:", t), t;
                    }
                    if (!n) {
                        const n = Object.keys(e).find((e => e.startsWith("__reactInternalInstance$") || e.startsWith("__reactFiber$")));
                        if (n && (null == (t = e[n]) ? void 0 : t.memoizedProps)) return console.log("React \u5185\u90e8\u6570\u636e:", e[n].memoizedProps), 
                        e[n].memoizedProps;
                    }
                } else console.error("\u672a\u627e\u5230 .Question \u5143\u7d20");
            })(e.html).children[0]._owner.memoizedProps;
            return e.type = {
                SingleChoice: "0",
                MultipleChoice: "1"
            }[t.type], e.options = removeStartChar(e.options), e;
        },
        setAnswer: e => {
            if ("4" === e.type) {
                const t = R(e.html).find("textarea")[0];
                return t._ms_context_._answer = e.answer[0], t._ms_context_._save(), !1;
            }
            return !0;
        },
        finish: e => {}
    } ], Vt = {
        single: "0",
        multiple: "1",
        judge: "3"
    }, Dt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("lygtc.edu.cn"),
        main: () => {
            const getHash = () => R("#app")[0].__vue__.$route.path;
            $e.mainClass = getHash();
            const e = new MutationObserver((async () => {
                const t = getHash();
                $e.mainClass !== t && ($e.mainClass = t, vuePageChange$1(), e.disconnect());
            })), t = R("#app")[0];
            t && e.observe(t, {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "save",
        name: "\u6625\u98ce\u96e8\u6536\u5f55",
        match: () => location.host.includes("lygtc.edu.cn") && (location.href.includes("/student/#/my-study/homework/records/detail") || location.href.includes("/student/#/my-study/homework")),
        question: {
            html: ".questions>div>div[id],.question>div>div[id]",
            question: ".topic-title",
            options: ".el-radio-group label .label,.el-checkbox-group label .label",
            type: ".question-box .tag",
            workType: "cfy",
            pageType: "cfy"
        },
        init: async () => {
            await waitUntil((() => 0 !== R(".questions>div>div[id],.question>div>div[id]").length));
        },
        answerHook: e => {
            const t = R(e.html).find(">div")[0].__vue__.question;
            return e.question = titleClean(removeHtml(t.title)), e.options = JSON.parse(t.options).map((e => e.content)), 
            e.answer = t.answer.split("").map((t => e.options[t.charCodeAt(0) - 65])).filter(Boolean), 
            e.type = Vt[t.type] || "", "judge" === t.type && (e.options = [], e.answer = [ judgeAnswer(t.answer) ]), 
            t.type, e;
        }
    }, {
        type: "ask",
        name: "\u6625\u98ce\u96e8\u7b54\u9898",
        tips: "\u516c\u544a",
        match: () => location.host.includes("lygtc.edu.cn") && location.href.includes("/student/#/my-study/homework"),
        types: Object.values(Vt),
        question: {
            html: ".question>div>div[id]",
            question: ".question-title>.title",
            options: ".radio-option",
            type: ".question-box .tag",
            workType: "cfy",
            pageType: "cfy"
        },
        init: async () => {
            await waitUntil((() => 0 !== R(".question>div>div[id]").length));
        },
        next: () => {},
        ischecked: e => e.find(".el-radio__input.is-checked").length > 0,
        questionHook: e => {
            e.options = removeStartChar(e.options);
            const t = R(e.html).find(">div")[0].__vue__.question;
            return e.question = titleClean(removeHtml(t.title)), e.options = JSON.parse(t.options).map((e => e.content)), 
            e.type = Vt[t.type] || "", "judge" === t.type && (e.options = [], e.answer = [ judgeAnswer(t.answer) ]), 
            e;
        },
        setAnswer: () => !0,
        finish: () => {}
    } ], Nt = [ {
        type: "hook",
        name: "hook",
        match: location.host.includes("jijiaool.com"),
        main: e => {
            const getHash = () => R(".contentIframe").attr("src");
            $e.mainClass = getHash();
            let t = new MutationObserver((async e => {
                $e.mainClass !== getHash() && ($e.mainClass = getHash(), vuePageChange$1(), t.disconnect());
            }));
            R(".contentIframe").length >= 1 && t.observe(R(".contentIframe")[0], {
                subtree: !0,
                attributes: !0,
                childList: !0
            });
        }
    }, {
        type: "ask",
        name: "\u7ee7\u6559\u5728\u7ebf\u7b54\u9898",
        match: () => location.href.includes("jijiaool.com") && location.href.includes("/Learning/CourseOnlineExamination"),
        types: [ "0", "1" ],
        question: {
            html: ".bank_test>.test_item",
            question: ".test_item_tit",
            options: ".test_item_theme>ul>li>label",
            type: ".question-box .tag",
            workType: "jijiaool",
            pageType: "jijiaool"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".bank_test>.test_item");
            }));
        },
        next: () => {},
        ischecked: e => e.parent().parent().hasClass("is-checked"),
        questionHook: e => {
            e.options = removeOptionsStartChar(e.options);
            const t = R(e.html).prevAll(".test_item_type").first().text().trim();
            return e.type = typeMatch(t), e;
        },
        setAnswer: e => !0,
        finish: e => {}
    }, {
        type: "save",
        name: "\u7ee7\u6559\u5728\u7ebf\u6536\u5f55",
        match: () => location.href.includes("jijiaool.com") && location.href.includes("/Learning/CourseExamWorkPageDetail"),
        question: {
            html: ".bank_test>.test_item",
            question: ".test_item_tit",
            options: ".test_item_theme>ul>li>label",
            type: ".question-box .tag",
            workType: "jijiaool",
            pageType: "jijiaool"
        },
        init: async () => {
            await waitUntil((function() {
                return isExist(".bank_test>.test_item");
            }));
        },
        answerHook: e => {
            const t = R(e.html).find(".test_item_tit").clone();
            t.find(".tipNodo").remove(), e.question = titleClean(removeHtml(t.html())), e.options = removeOptionsStartChar(e.options);
            const n = removeHtml(R(e.html).find(".test_item_tit:eq(1)").html().replace(/ \u6b63\u786e\u7b54\u6848\uff1a/g, "").trim()), a = R(e.html).prevAll(".test_item_type").first().text().trim();
            switch (e.type = typeMatch(a), e.type) {
              case "0":
              case "1":
                e.answer = n.split("").map((t => e.options[t.charCodeAt(0) - 65]));
                break;

              case "3":
                e.answer = judgeAnswer(n), e.options = [];
            }
            return e;
        }
    } ], Bt = Object.freeze(Object.defineProperty({
        __proto__: null,
        a21tb: St,
        ahjxjy: ct,
        cfy: Dt,
        chaoxing: Ze,
        chatglm: nt,
        chengjiaoyun: st,
        chutou: vt,
        cjedu: dt,
        cjnep: qt,
        cloudwis: yt,
        cnzx: lt,
        cqsdx: It,
        dufe: Mt,
        gkks: ft,
        guokai: ot,
        huayi: Tt,
        jijiaool: Nt,
        jijiaox: xt,
        jsou: it,
        learnin: Et,
        ls365: bt,
        mooc: $t,
        mosoteach: Ut,
        mynep: Ct,
        olearn: Lt,
        openha: gt,
        ouchn: zt,
        qingshu: pt,
        sclecb: wt,
        swufe: jt,
        uooc: ut,
        wdjycj: Ft,
        wencai: _t,
        whut: Pt,
        wx168: Ht,
        xinwei: tt,
        xueqi: ht,
        ynou: At,
        ytccr: mt,
        yunmuxueyuan: Qe,
        yxbyun: Ot,
        yxlearning: kt,
        zhihuishu: et,
        zhijiaoyun: rt
    }, Symbol.toStringTag, {
        value: "Module"
    })), Gt = [];

    for (const xr in Bt) Gt.push(...Bt[xr]);

    const parseRule = async e => {
        await waitUntil((() => void 0 !== $e[Kt + "app"]));
        const t = e.filter((e => "function" == typeof e.match ? e.match() : e.match)), n = getAppStore(), a = {
            app: n,
            ask: getAskStore()
        };
        if (!t.length) return n.app.alert = "\u5f53\u524d\u6ca1\u6709\u4efb\u52a1", console.log("\u6ca1\u6709\u5339\u914d\u5230\u89c4\u5219", "error"), 
        void addLog("\u6ca1\u6709\u5339\u914d\u5230\u89c4\u5219", "error");
        for (const o of t) {
            if (console.log(`\u5339\u914d\u5230\u89c4\u5219\uff1a${o.name}`, "success"), addLog(`\u5339\u914d\u5230\u89c4\u5219\uff1a${o.name}`, "success"), 
            o.init) {
                let e = await o.init();
                if ("boolean" == typeof e && !1 === e) continue;
            }
            n.alert = `\u5f53\u524d\u4efb\u52a1:${o.name}`, "hook" === o.type && o.main(a), 
            "ask" === o.type && askParser(o, a), "save" === o.type && saveParser(o, a);
        }
    }, saveParser = (e, t) => {
        const n = t.app, a = t.ask;
        a.rule = e, e.tips && (a.tips = e.tips);
        const o = questionSaveParser(e.question, e.answerHook || null).filter((e => null != e && 0 !== e.answer.length && "" !== e.answer && "8" != e.type)).map((e => (e.question = titleClean(e.question), 
        e)));
        if (a.saveQuestionData = o, o.forEach((e => {
            0 !== e.answer.length && Answer.cacheAnswer(e);
        })), e.paper && "function" == typeof e.paper) try {
            e.paper(o);
        } catch (i) {
            addLog("\u6574\u5377\u7f13\u5b58\u5f02\u5e38", "error");
        }
        const s = {
            questionList: o,
            pageType: e.question.pageType
        };
        n.setPage("question"), o.length && Answer.syncQuestionList(s), n.app.alert = `\u9898\u5e93\u6536\u5f55\u5b8c\u6210\uff0c\u5171\u7f13\u5b58${o.length}\u9053\u9898\u76ee`, 
        msg(`\u9898\u5e93\u6536\u5f55\u5b8c\u6210\uff0c\u5171\u7f13\u5b58${o.length}\u9053\u9898\u76ee`, "success"), 
        e.next && e.next();
    }, askParser = (e, t) => {
        const n = t.app, a = t.ask;
        a.rule = e, e.minDelay && (a.minDelay = e.minDelay, a.delay < a.minDelay && (a.delay = a.minDelay)), 
        e.tips && (a.tips = e.tips), n.app.showFloat = !n.app.hideFloat, n.setPage("ask"), 
        a.clearQuestion();
        questionParser(e.question, e.questionHook || null).map((e => (e.question = titleClean(e.question), 
        "3" == e.type && (e.options = []), e))).forEach((e => {
            a.addQuestion(e);
        })), a.autoAnswer && a.toggleStart();
    }, questionSaveParser = (e, t) => {
        "function" == typeof e.html && (e.html = e.html());
        return R(e.html).map(((n, a) => {
            const o = removeHtml(R(a).find(e.question).html()), s = R(a).find(e.options).map(((e, t) => removeHtml(R(t).html()))).get(), i = R(a).find(e.type).val(), r = R(a)[0];
            let l = {
                question: titleClean(o ?? ""),
                options: s,
                $options: R(a).find(e.options),
                $answer: R(a).find(e.answer),
                answer: [],
                type: i,
                html: r
            };
            try {
                t && (l = t(l, n));
            } catch (c) {
                console.log("\u6536\u5f55hook\u62a5\u9519", c);
            }
            return null == l || null == l ? null : (l.question && "" != l.question && (l.question = titleClean(l.question)), 
            l.options && l.options.length > 0 && (l.options = removeStartChar(l.options)), {
                question: l.question,
                options: l.options,
                answer: l.answer,
                type: l.type,
                hash: questionHash(l.type, l.question, l.options)
            });
        })).get();
    }, questionParser = (e, t) => {
        "function" == typeof e.html && (e.html = e.html());
        return R(e.html).map(((n, a) => {
            const o = removeHtml(R(a).find(e.question).html()), s = R(a).find(e.options).map(((e, t) => removeHtml(R(t).html()))).get(), i = R(a).find(e.type).val(), r = e.workType, l = R(a)[0];
            let c = {
                question: titleClean(o ?? ""),
                options: s,
                $options: R(a).find(e.options),
                type: i,
                html: l,
                workType: r,
                pageType: e.pageType
            };
            return t && (c = t(c, n)), c;
        })).get();
    };

    class AnonymousIdentityOptimized {
        static generateShortId() {
            return Date.now().toString(36).padStart(8, "0").slice(-8) + Array.from({
                length: 8
            }, (() => "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"[Math.floor(62 * Math.random())])).join("");
        }
        static validateId(e) {
            return /^[0-9A-Za-z]{16}$/.test(e);
        }
        static getAnonymousId() {
            if (this.cachedAnonymousId) return this.cachedAnonymousId;
            let e = Se(this.STORAGE_KEY);
            return e && this.validateId(e) || (e = this.generateShortId(), Ee(this.STORAGE_KEY, e)), 
            this.cachedAnonymousId = e, e;
        }
        static getStableCanvasFingerprint() {
            try {
                const e = document.createElement("canvas");
                e.width = 220, e.height = 30;
                const t = e.getContext("2d", {
                    willReadFrequently: !0
                });
                if (!t) return "";
                t.textBaseline = "alphabetic", t.fillStyle = "#000", t.font = "16px Arial", t.fillText("AiAsk,\ud83c\udf10.\ud83d\ude00", 2, 20);
                const n = t.getImageData(0, 0, 220, 30).data;
                let a = 0;
                for (let o = 0; o < n.length; o += 40) a = (a << 5) - a + n[o], a |= 0;
                return a.toString(36);
            } catch (e) {
                return "";
            }
        }
        static getWebGLFingerprint() {
            try {
                const e = document.createElement("canvas"), t = e.getContext("webgl") || e.getContext("experimental-webgl");
                if (!t) return "";
                const n = t.getExtension("WEBGL_debug_renderer_info");
                if (!n) return t.getParameter(t.VERSION) + "|" + t.getParameter(t.VENDOR);
                const a = t.getParameter(n.UNMASKED_VENDOR_WEBGL);
                return a + "|" + t.getParameter(n.UNMASKED_RENDERER_WEBGL);
            } catch (e) {
                return "";
            }
        }
        static getDeviceFingerprint() {
            if (this.cachedFingerprint) return this.cachedFingerprint;
            const e = Se(this.FINGERPRINT_KEY);
            if (e && e.version === this.FP_VERSION && e.value) return this.cachedFingerprint = e.value, 
            e.value, e.value;
            const t = [ this.normalizeUserAgent(navigator.userAgent), navigator.language, navigator.platform, screen.colorDepth, screen.pixelDepth || screen.colorDepth, (new Date).getTimezoneOffset(), navigator.hardwareConcurrency || 0, navigator.maxTouchPoints || 0, navigator.deviceMemory || 0, this.getWebGLFingerprint(), this.getStableCanvasFingerprint() ].filter(Boolean).join("|"), n = Je(t).substring(0, 12);
            return Ee(this.FINGERPRINT_KEY, {
                value: n,
                version: this.FP_VERSION,
                createdAt: Date.now()
            }), this.cachedFingerprint = n, n;
        }
        static normalizeUserAgent(e) {
            return e.includes("Chrome") ? "Chrome" : e.includes("Firefox") ? "Firefox" : e.includes("Safari") ? "Safari" : e.includes("Edge") ? "Edge" : e.includes("Opera") ? "Opera" : "Unknown";
        }
        static getIdentity() {
            return {
                anonymous_id: this.getAnonymousId(),
                device_fingerprint: this.getDeviceFingerprint()
            };
        }
        static clear() {
            Ee(this.STORAGE_KEY, null), Ee(this.FINGERPRINT_KEY, null), this.cachedAnonymousId = null, 
            this.cachedFingerprint = null;
        }
        static regenerateFingerprint() {
            return Ee(this.FINGERPRINT_KEY, null), this.cachedFingerprint = null, this.getDeviceFingerprint();
        }
        static getDebugInfo() {
            return {
                anonymous_id: this.getAnonymousId(),
                device_fingerprint: this.getDeviceFingerprint(),
                fingerprint_components: {
                    browser: this.normalizeUserAgent(navigator.userAgent),
                    language: navigator.language,
                    platform: navigator.platform,
                    screen_color: screen.colorDepth,
                    timezone: (new Date).getTimezoneOffset(),
                    hardware: navigator.hardwareConcurrency,
                    webgl: this.getWebGLFingerprint()
                },
                storage: {
                    fp_stored: Se(this.FINGERPRINT_KEY),
                    id_stored: Se(this.STORAGE_KEY)
                }
            };
        }
        static async testStability(e = 10) {
            const t = [];
            for (let a = 0; a < e; a++) {
                this.cachedFingerprint = null;
                const e = this.getDeviceFingerprint();
                t.push(e), await new Promise((e => setTimeout(e, 100)));
            }
            const n = new Set(t);
            n.size, n.size, Array.from(n), n.size, 1 === n.size || n.size;
        }
    }

    __publicField(AnonymousIdentityOptimized, "STORAGE_KEY", "anonymous_id"), __publicField(AnonymousIdentityOptimized, "FINGERPRINT_KEY", "device_fingerprint"), 
    __publicField(AnonymousIdentityOptimized, "FP_VERSION", "v2"), __publicField(AnonymousIdentityOptimized, "cachedAnonymousId", null), 
    __publicField(AnonymousIdentityOptimized, "cachedFingerprint", null);

    const Rt = 864e5, Jt = [ {
        id: "492563",
        name: "GreasyFork",
        home: "https://greasyfork.org/zh-CN/scripts/492563-%E7%88%B1%E9%97%AE%E7%AD%94%E5%8A%A9%E6%89%8B",
        updateurl: "https://greasyfork.org/zh-CN/scripts/492563.json",
        getdata: e => {
            const t = JSON.parse(e[0].responseText);
            return {
                version: t.version,
                code_updated_at: formatDate(t.code_updated_at)
            };
        }
    }, {
        id: "2384",
        name: "\u811a\u672c\u732b",
        home: "https://scriptcat.org/zh-CN/script-show-page/2384",
        updateurl: "https://scriptcat.org/api/v2/scripts/2384",
        getdata: e => {
            const t = JSON.parse(e[0].responseText);
            return {
                version: t.data.script.version,
                code_updated_at: formatDate(new Date(1e3 * t.data.updatetime).toISOString())
            };
        }
    } ];

    function getAppStore() {
        return $e[Kt + "app"];
    }

    function getAskStore() {
        return $e[Kt + "ask"];
    }

    function request(e, t, n = void 0, a = void 0, o = 5e3) {
        "GET" === t && n && (e += `?${new URLSearchParams(n).toString()}`), "POST" === t && (a = {
            ...a
        });
        const s = {
            "User-Agent": $e.navigator.userAgent,
            "Content-Type": "application/json",
            referer: location.href,
            ...a
        };
        return new Promise(((a, i) => {
            const r = Date.now();
            ze({
                method: t,
                url: e,
                headers: s,
                data: "GET" !== t ? JSON.stringify(n) : void 0,
                timeout: o,
                onload: function(e) {
                    const t = Date.now();
                    a([ e, t - r ]);
                },
                ontimeout: () => i(new Error("\u63a5\u53e3\u8bf7\u6c42\u8d85\u65f6")),
                onerror: e => {
                    i(e);
                }
            });
        }));
    }

    function requestApi(e, t, n = void 0, a = void 0, o = 5e3) {
        return "GET" === t && n && (e += `?${new URLSearchParams(n).toString()}`), new Promise((async (s, i) => {
            const r = Cache.get("user", {}), l = r && r.user && r.api_key;
            let c;
            if ("POST" === t) {
                if (!l) {
                    const e = AnonymousIdentityOptimized.getIdentity();
                    n = {
                        ...n,
                        anonymous_id: e.anonymous_id,
                        device_fingerprint: e.device_fingerprint
                    };
                }
                const e = get_t(n);
                a = {
                    ...a,
                    aka: e
                }, c = await encrypt(JSON.stringify(n), e);
            } else a = {
                ...a,
                aka: get_t({})
            };
            const p = {
                "User-Agent": $e.navigator.userAgent,
                "Content-Type": "application/json",
                referer: location.href,
                v: Yt.script.version,
                ...a
            };
            if (l) p.Authorization = `Bearer ${r.api_key}`; else {
                const e = AnonymousIdentityOptimized.getIdentity();
                p["X-Anonymous-ID"] = e.anonymous_id, p["X-Device-FP"] = e.device_fingerprint;
            }
            const u = Date.now();
            JSON.stringify(n), ze({
                method: t,
                url: e,
                headers: p,
                data: "GET" !== t ? JSON.stringify({
                    data: c
                }) : void 0,
                timeout: o,
                onload: async function(e) {
                    const t = Date.now() - u;
                    let n = JSON.parse(e.responseText);
                    if (n.encrypted) {
                        n = await decrypt(n.data);
                        const a = {
                            ...e,
                            responseText: n
                        };
                        s([ a, t ]);
                    } else s([ e, t ]);
                },
                ontimeout: () => i(new Error("\u63a5\u53e3\u8bf7\u6c42\u8d85\u65f6")),
                onerror: e => {
                    i(e);
                }
            });
        }));
    }

    const vuePageChange$1 = async () => {
        if ($e.vuePageChangeLock) return;
        $e.vuePageChangeLock = !0;
        const e = getAppStore(), t = getAskStore();
        t.questionInx = 0, e.app.showFloat = !1, e.setPage("home"), t.clearQuestion(), await parseRule(Gt), 
        $e.vuePageChangeLock = !1;
    }, addLog = (e, t = "info") => {
        const n = getAppStore(), a = (new Date).toLocaleString();
        try {
            n.addLog({
                time: a,
                type: t,
                content: e
            });
        } catch (o) {
            console.log(e);
        }
    }, compareVersions = (e, t) => {
        const normalize = e => e.split(".").map(Number), n = normalize(e), a = normalize(t);
        for (let o = 0; o < Math.max(n.length, a.length); o++) {
            const e = n[o] || 0, t = a[o] || 0;
            if (t > e) return !0;
            if (t < e) return !1;
        }
        return !1;
    }, updateFn = async (e = !0) => {
        if (!getAppStore().app.checkUpdate) return;
        const t = Cache.get("lastCheckTime");
        if (e && t && Date.now() - t < Rt) {
            new Date(t + Rt).toLocaleString();
        } else try {
            const e = await Promise.allSettled(Jt.map((async e => {
                try {
                    e.name, e.updateurl, addLog(`[${e.name}] \u5f00\u59cb\u68c0\u6d4b\u66f4\u65b0`, "info");
                    const t = await request(e.updateurl, "GET", {}, {}), n = e.getdata(t);
                    return e.name, {
                        script: e,
                        updateInfo: n
                    };
                } catch (t) {
                    throw e.name, String(t), addLog(`[${e.name}] \u66f4\u65b0\u68c0\u6d4b\u5931\u8d25: ${String(t)}`, "error"), 
                    t;
                }
            })));
            Cache.set("lastCheckTime", Date.now());
            const t = e.filter((e => "fulfilled" === e.status));
            e.filter((e => "rejected" === e.status));
            if (0 === t.length) return void msg("\u6240\u6709\u66f4\u65b0\u6e90\u68c0\u6d4b\u5931\u8d25\uff0c\u8bf7\u53cd\u9988\u7ed9\u4f5c\u8005\u3002", "error");
            let n = !1, a = !0;
            for (const {value: o} of t) {
                const {script: e, updateInfo: t} = o;
                if (compareVersions(Yt.script.version, t.version)) {
                    msg(`\n          <div style="line-height: 1.5; font-size: 14px;">\n            <p>\u68c0\u6d4b\u5230\u65b0\u7248\u672c\uff1a<span style="color: red; font-weight: bold;">${t.version}</span></p>\n            <p>\u811a\u672c\u6e90\uff1a<strong>${e.name}</strong></p>\n            <p>\u66f4\u65b0\u65f6\u95f4\uff1a<span style="color: #555;">${t.code_updated_at}</span></p>\n            <p><a target="_blank" href="${e.home}" style="color: #007bff; text-decoration: underline;">>> \u70b9\u6211\u5feb\u6377\u8df3\u8f6c\u66f4\u65b0 <<</a></p>\n          </div>`, "warning"), 
                    addLog(`[${e.name}] \u68c0\u6d4b\u5230\u65b0\u7248\u672c\uff1a${t.version}`, "warning"), 
                    n = !0, a = !1;
                } else e.name, t.version, addLog(`[${e.name}] \u5df2\u662f\u6700\u65b0\u7248\uff1a${t.version}`, "info");
            }
            !n && a && (msg("\u5f53\u524d\u5df2\u662f\u6700\u65b0\u7248", "success"), addLog("\u5f53\u524d\u5df2\u662f\u6700\u65b0\u7248", "success"));
        } catch (n) {
            console.error("\u66f4\u65b0\u68c0\u6d4b\u6d41\u7a0b\u5f02\u5e38", n), addLog(`\u66f4\u65b0\u68c0\u6d4b\u5931\u8d25: ${String(n)}`, "error"), 
            msg("\u6240\u6709\u66f4\u65b0\u6e90\u5747\u68c0\u6d4b\u5931\u8d25\uff0c\u8bf7\u5c1d\u8bd5\u5207\u6362\u7f51\u7edc\u6216\u8005\u53cd\u9988\u7ed9\u4f5c\u8005", "error");
        }
    }, ttfDownload1 = async e => new Promise((t => {
        ze({
            method: "GET",
            url: e,
            onload: function(e) {
                try {
                    const n = e.responseText, a = JSON.parse(n);
                    t(a);
                } catch (n) {
                    msg("\u5b57\u4f53\u6587\u4ef6\u4e0b\u8f7d\u5931\u8d25", "error"), t(null);
                }
            },
            onerror: function(e) {
                msg("\u5b57\u4f53\u6587\u4ef6\u4e0b\u8f7d\u5931\u8d25", "error"), t(null);
            }
        });
    })), Qt = He;

    function somd5(e) {
        return Je(e);
    }

    function removeHtml(e, t = !0) {
        const n = document.createElement("textarea");
        n.innerHTML = e, e = (e = (e = (e = n.value).replace(/[\t\r\xa0]/g, " ")).replace(/[\u2000-\u200a]/g, " ")).replace(/<br\s*\/?>/g, "\n"), 
        t && (e = e.replace(/<(\/)?(p|div).*?>/g, "\n")), e = (e = (e = (e = e.replace(/ {2,}/g, " ")).replace(/\n{2,}/g, "\n")).replace(/<xmp.*?>/g, "<pre>")).replace(/<\/xmp>/g, "</pre>");
        let a = (e = V.sanitize(e, {
            ALLOWED_TAGS: [ "img", "br", "sub", "sup" ],
            ALLOWED_ATTR: [ "src", "href" ],
            ALLOW_DATA_ATTR: !1,
            KEEP_CONTENT: !0
        })).match(/<img.*?src="(.*?)".*?>/g);
        return a && a.forEach((t => {
            let n = t.match(/src="(.*?)"/);
            if (n && -1 == n[1].indexOf("http") && !n[1].includes("data:image")) if (n[1].startsWith("/")) e = e.replace(n[1], location.origin + n[1]); else {
                const t = new URL(n[1], document.baseURI).href;
                e = e.replace(n[1], t);
            }
        })), e.trim();
    }

    function titleClean(e) {
        return e.replace(/^[.*?]\s*/, "").replace(/^\u3010.*?\u3011\s*/, "").replace(/\s*\uff08\d+\.\d+\u5206\uff09$/, "").replace(/^\d+\./, "").trim().replace(/^\d+\uff0e/, "").trim();
    }

    function sleep(e) {
        return new Promise((t => setTimeout(t, e)));
    }

    function typeConvert(e, t = !0) {
        return t ? Wt[e] || "8" : Object.keys(Wt).find((t => Wt[t] === e)) || "\u5176\u5b83";
    }

    function typeMatch(e) {
        const t = {
            0: [ "\u5355\u9009", "\u5355\u9879\u9009\u62e9", "A2", "A1" ],
            1: [ "\u591a\u9009", "\u591a\u9879\u9009\u62e9" ],
            2: [ "\u586b\u7a7a" ],
            3: [ "\u5224\u65ad" ],
            4: [ "\u7b80\u7b54", "\u95ee\u7b54", "\u7efc\u5408\u9898" ],
            5: [ "\u540d\u8bcd\u89e3\u91ca" ],
            6: [ "\u8bba\u8ff0", "\u4e3b\u89c2" ],
            7: [ "\u8ba1\u7b97" ],
            9: [ "\u5206\u5f55" ],
            14: [ "\u5b8c\u5f62\u586b\u7a7a" ],
            24: [ "\u9009\u8bcd\u586b\u7a7a" ]
        };
        return Object.keys(t).find((n => t[n].some((t => e.includes(t))))) || "8";
    }

    function matchAnswer(e, t) {
        const preprocess = e => e.map((e => function(e) {
            if (/^[+-]?\d+(\.\d+)?$/.test(e)) return e;
            const t = e.replace(/\s+/g, "");
            return t.replace(new RegExp("\\p{P}", "gu"), "") || t;
        }(removeHtml(e))));
        e = preprocess(e), t = preprocess(t);
        const n = e.map((e => {
            const n = t.findIndex((t => t === e));
            return -1 !== n ? n : t.findIndex((t => t.includes(e)));
        }));
        return n.includes(-1) ? [] : n;
    }

    function msg(e, t = "info") {
        try {
            D.ElNotification({
                title: `${Qt.script.name} v${Qt.script.version}`,
                message: e,
                type: t,
                dangerouslyUseHTMLString: !0,
                appendTo: document.getElementById("AiAskApp")
            }), addLog(e, "success");
        } catch (n) {
            addLog(`\u6d88\u606f\u901a\u77e5\u5931\u8d25\u3010${e}\u3011`, "error");
        }
    }

    function isTrue(e) {
        return !isFalse(e) && /(\u6b63\u786e|\u662f|\u5bf9|\u221a|T|ri|true)/i.test(e);
    }

    function isFalse(e) {
        return /(\u4e0d\u6b63\u786e|\u9519\u8bef|\u5426|\u9519|\xd7|F|wr|false)/i.test(e);
    }

    const questionHash = (e, t, n, a = !0) => {
        let o = Array.from(n);
        a && o.sort();
        let s = `${e}${t}${o.join("")}`;
        s = s.replace(/\s/g, "");
        return Je(s);
    };

    function get_t(e = {}) {
        const {html: t, ...n} = e || {}, flatten = (e, t = "") => {
            const n = [];
            return Object.keys(e).sort().forEach((a => {
                const o = t ? `${t}.${a}` : a, s = e[a];
                null != s && (Array.isArray(s) && 0 === s.length || ("object" != typeof s || Array.isArray(s) || 0 !== Object.keys(s).length) && (Array.isArray(s) ? s.every((e => "object" != typeof e)) ? n.push(`${o}=${s.sort().join(",")}`) : n.push(`${o}=${JSON.stringify(s)}`) : "object" == typeof s ? n.push(...flatten(s, o)) : n.push(`${o}=${s}`)));
            })), n;
        }, a = flatten(n).join("&");
        return Je(a);
    }

    async function encrypt(e = "", t = "asdgdfghfghfghfg", n = "1234567890123456") {
        try {
            if (!e) return "";
            if (t = t.substring(0, 16), n = n.substring(0, 16), !window.crypto || !window.crypto.subtle) {
                const a = J.enc.Utf8.parse(t), o = J.enc.Utf8.parse(n);
                return J.AES.encrypt(e, a, {
                    iv: o,
                    mode: J.mode.CBC,
                    padding: J.pad.Pkcs7
                }).toString();
            }
            const o = new TextEncoder, s = o.encode(e), i = o.encode(t), r = o.encode(n), l = await crypto.subtle.importKey("raw", i, {
                name: "AES-CBC"
            }, !1, [ "encrypt" ]), c = await crypto.subtle.encrypt({
                name: "AES-CBC",
                iv: r
            }, l, s), p = new Uint8Array(c), u = 1024;
            let d, m = "";
            for (let e = 0; e < p.length; e += u) {
                const t = p.slice(e, Math.min(e + u, p.length));
                m += String.fromCharCode.apply(null, Array.from(t));
            }
            try {
                d = btoa(m);
            } catch (a) {
                d = m.split("").map((e => ("0" + e.charCodeAt(0).toString(16)).slice(-2))).join("");
            }
            return d;
        } catch (o) {
            return addLog(`\u52a0\u5bc6\u5f02\u5e38: ${o instanceof Error ? o.message : "\u672a\u77e5\u9519\u8bef"}`, "error"), 
            "";
        }
    }

    async function decrypt(e = "", t = "asdgdfghfghfghfg", n = "1234567890123456") {
        try {
            if (!e) return "";
            if (t = t.substring(0, 16), n = n.substring(0, 16), !window.crypto || !window.crypto.subtle) {
                const a = J.enc.Utf8.parse(t), o = J.enc.Utf8.parse(n);
                return J.AES.decrypt(e, a, {
                    iv: o,
                    mode: J.mode.CBC,
                    padding: J.pad.Pkcs7
                }).toString(J.enc.Utf8);
            }
            /^[A-Za-z0-9+/]*={0,2}$/.test(e);
            const o = new TextEncoder, s = o.encode(t), i = o.encode(n);
            let r;
            try {
                r = atob(e);
            } catch (a) {
                throw new Error("Base64 \u89e3\u7801\u5931\u8d25\uff0c\u6570\u636e\u683c\u5f0f\u4e0d\u6b63\u786e");
            }
            const l = new Uint8Array(r.length);
            for (let e = 0; e < r.length; e++) l[e] = r.charCodeAt(e);
            if (l.length % 16 != 0) throw new Error("\u52a0\u5bc6\u6570\u636e\u957f\u5ea6\u4e0d\u6b63\u786e\uff0c\u4e0d\u662f16\u7684\u500d\u6570");
            const c = await crypto.subtle.importKey("raw", s, {
                name: "AES-CBC"
            }, !1, [ "decrypt" ]), p = await crypto.subtle.decrypt({
                name: "AES-CBC",
                iv: i
            }, c, l);
            return new TextDecoder("utf-8", {
                fatal: !0
            }).decode(p);
        } catch (o) {
            return addLog(`\u89e3\u5bc6\u5f02\u5e38: ${o instanceof Error ? o.message : "\u672a\u77e5\u9519\u8bef"}`, "error"), 
            "";
        }
    }

    function simpleMarkdownToHtml(e) {
        if (!e) return "";
        let t = e;
        const n = [], protect = e => {
            const t = `{{{{PLACEHOLDER${n.length}}}}}`;
            return n.push(e), t;
        }, escapeHtml = e => e.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;").replace(/"/g, "&quot;").replace(/'/g, "&#039;");
        return t = t.replace(/```(\w*)\n([\s\S]*?)```/g, ((e, t, n) => protect(`<pre><code class="hljs">${escapeHtml(n.trim())}</code></pre>`))), 
        t = t.replace(/`([^`]+)`/g, ((e, t) => protect(`<code>${escapeHtml(t)}</code>`))), 
        t = t.replace(/\[([^\]]+)\]\(([^)]+)\)/g, ((e, t, n) => protect(`<a href="${n}" target="_blank" rel="noopener noreferrer">${t}</a>`))), 
        t = t.replace(/\*\*(.+?)\*\*/g, "<strong>$1</strong>"), t = t.replace(/__(.+?)__/g, "<strong>$1</strong>"), 
        t = t.replace(/\*(.+?)\*/g, "<em>$1</em>"), t = t.replace(/_(.+?)_/g, "<em>$1</em>"), 
        t = t.replace(/^### (.+)$/gm, "<h3>$1</h3>"), t = t.replace(/^## (.+)$/gm, "<h2>$1</h2>"), 
        t = t.replace(/^# (.+)$/gm, "<h1>$1</h1>"), t = t.replace(/^\- (.+)$/gm, "<li>$1</li>"), 
        t = t.replace(/(<li>.*<\/li>\n?)+/g, "<ul>$&</ul>"), t = t.replace(/^\d+\. (.+)$/gm, "<li>$1</li>"), 
        t = t.replace(/\n/g, "<br>"), t = t.replace(/<br><(pre|h1|h2|h3|ul|ol)/g, "<$1"), 
        t = t.replace(/<\/(pre|h1|h2|h3|ul|ol)><br>/g, "</$1>"), t = t.replace(/\{\{\{\{PLACEHOLDER(\d+)\}\}\}\}/g, ((e, t) => n[parseInt(t)])), 
        t;
    }

    function judgeAnswer(e) {
        return isTrue(e) ? [ "\u6b63\u786e" ] : isFalse(e) ? [ "\u9519\u8bef" ] : [];
    }

    function removeStartChar(e) {
        return e.map(((e, t) => {
            let n = String.fromCharCode(65 + t) + " .", a = String.fromCharCode(65 + t) + ".", o = String.fromCharCode(65 + t) + "\u3001", s = String.fromCharCode(65 + t) + "\uff0e", i = String.fromCharCode(65 + t);
            return e.replace(new RegExp(`^${n}|^${a}|^${o}|^${s}|^${i}`), "").trim();
        }));
    }

    function qc(e) {
        R(e).find(".answerBg, .textDIV, .eidtDiv").each((function() {
            (R(this).find(".check_answer").length || R(this).find(".check_answer_dx").length) && R(this).click();
        })), R(e).find(".answerBg, .textDIV, .eidtDiv").find("textarea").each((function() {
            $e.UE.getEditor(R(this).attr("name")).ready((function() {
                this.setContent("");
            }));
        })), R(e).find(":radio, :checkbox").prop("checked", !1), R(e).find("textarea").each((function() {
            $e.UE.getEditor(R(this).attr("name")).ready((function() {
                this.setContent("");
            }));
        }));
    }

    function qc1(e) {
        R(e).find(".before-after,.before-after-checkbox, .textDIV, .eidtDiv").each((function() {
            (R(this).find(".check_answer").length || R(this).find(".check_answer_dx").length) && R(this).click();
        })), R(e).find(".before-after, .textDIV, .eidtDiv").find("textarea").each((function() {
            $e.UE.getEditor(R(this).attr("name")).ready((function() {
                this.setContent("");
            }));
        })), R(e).find(":radio, :checkbox").prop("checked", !1), R(e).find("textarea").each((function() {
            $e.UE.getEditor(R(this).attr("name")).ready((function() {
                this.setContent("");
            }));
        }));
    }

    const waitUntil = (e, t = 100) => new Promise((n => {
        const a = setInterval((() => {
            e() && (clearInterval(a), n());
        }), t);
    }));

    function isExist(e) {
        return R(e).length > 0;
    }

    function getUrl() {
        return location.href;
    }

    function removeOptionsStartChar(e) {
        for (let t = 0; t < e.length; t++) {
            let n = String.fromCharCode(65 + t) + ".", a = String.fromCharCode(65 + t) + "\u3001", o = String.fromCharCode(65 + t) + "\uff0e", s = String.fromCharCode(65 + t);
            const i = new RegExp(`^${n}|^${a}|^${o}|^${s}`);
            if (!e[t].match(i)) return !1;
            e[t] = e[t].replace(i, "").trim();
        }
        return e;
    }

    const formatDate = e => new Date(e).toISOString().replace("T", " ").substring(0, 19);

    const Wt = {
        "\u5355\u9009\u9898": "0",
        "\u591a\u9009\u9898": "1",
        "\u586b\u7a7a\u9898": "2",
        "\u5224\u65ad\u9898": "3",
        "\u7b80\u7b54\u9898": "4",
        "\u95ee\u7b54\u9898": "4",
        "\u540d\u8bcd\u89e3\u91ca": "5",
        "\u8bba\u8ff0\u9898": "6",
        "\u8ba1\u7b97\u9898": "7",
        "\u5206\u5f55\u9898": "9",
        "\u8d44\u6599\u9898": "10",
        "\u8fde\u7ebf\u9898": "11",
        "\u5339\u914d\u9898": "11",
        "\u6392\u5e8f\u9898": "13",
        "\u5b8c\u578b\u586b\u7a7a": "14",
        "\u5b8c\u5f62\u586b\u7a7a\u9898": "14",
        "\u9605\u8bfb\u7406\u89e3": "15",
        "\u7a0b\u5e8f\u9898": "17",
        "\u53e3\u8bed\u9898": "18",
        "\u542c\u529b\u9898": "19",
        "\u5171\u7528\u9009\u9879\u9898": "20",
        "\u6d4b\u8bc4\u9898": "21",
        "\u949f\u8868\u9898": "23",
        "\u9009\u8bcd\u586b\u7a7a": "24",
        "\u9009\u505a\u9898": "25",
        "\u5176\u5b83": "8"
    }, Kt = function(e) {
        let t = "";
        for (;t.length < e; t += Math.random().toString(36).substr(2)) ;
        return t.substr(0, e);
    }(9) + "_", Yt = He;

    $e.ksv = Je(Yt.script.author + Yt.script.name.replace(/server:/, "").trim());

    const Xt = {
        debug: !0,
        searchApi: [],
        defaultShowFloat: !1,
        showFloat: !1,
        showBoard: !0,
        checkUpdate: !0,
        hideFloat: !1,
        alert: "\u70b9\u6211\u6709\u60ca\u559c",
        alertBubble: !0,
        iframe: !1,
        key: "",
        gpt: [ {
            name: "GLM",
            desc: "\u667a\u666e\u6e05\u8a004.0",
            api: "http://82.157.105.20:8002/v1/chat/completions",
            key: "",
            msg: "AI\u54cd\u5e94\u5f02\u5e38\uff0c\u53ef\u80fd\u662f\u6ca1\u6709\u83b7\u53d6cookie,\u8bf7\u6309\u4e0b\u65b9\u6b65\u9aa4\u64cd\u4f5c\n1. \u6253\u5f00[\u667a\u666e\u6e05\u8a00](https://chatglm.cn/main/alltoolsdetail)\n2. \u767b\u5f55\u540e\u968f\u4fbf\u53d1\u4e00\u6761\u6d88\u606f\u5373\u53ef\n3. \u8fd4\u56de\u7b54\u9898\u9875\u5237\u65b0\u9875\u9762",
            home: "https://chatglm.cn/main/alltoolsdetail",
            recommend: 3,
            model: "gpt-4o"
        }, {
            name: "spark",
            desc: "\u8baf\u98de\u661f\u706b",
            api: "http://82.157.105.20:8000/v1/chat/completions",
            key: "",
            msg: "AI\u54cd\u5e94\u5f02\u5e38\uff0c\u53ef\u80fd\u662f\u6ca1\u6709\u83b7\u53d6cookie,\u8bf7\u6309\u4e0b\u65b9\u6b65\u9aa4\u64cd\u4f5c\n1. \u6253\u5f00[\u8baf\u98de\u661f\u706b](https://xinghuo.xfyun.cn/desk)\n2. \u767b\u5f55\u540e\u968f\u4fbf\u53d1\u4e00\u6761\u6d88\u606f\u5373\u53ef\n3. \u8fd4\u56de\u7b54\u9898\u9875\u5237\u65b0\u9875\u9762",
            home: "https://xinghuo.xfyun.cn/desk",
            recommend: 5,
            model: "gpt-4o"
        } ],
        gptIndex: 1,
        askGpt: !1,
        hotkey: "Ctrl+Shift+H",
        hotkeyEnabled: !0
    };

    const Zt = function() {
        const e = Cache.get("app") || {}, t = {
            ...Xt
        };
        for (const [n, a] of Object.entries(e)) "gpt" !== n && "alert" !== n && void 0 !== a && (t[n] = a);
        if (e.gpt) {
            const n = new Map;
            e.gpt.forEach((e => {
                n.set(e.name, e.key);
            })), t.gpt = Xt.gpt.map((e => ({
                ...e,
                key: n.get(e.name) || ""
            })));
        }
        return t.alert = Xt.alert, t.gptIndex >= t.gpt.length && (t.gptIndex = 0), t;
    }();

    function getApp() {
        return Cache.get("app") || Xt;
    }

    !function(e) {
        const t = {
            ...Cache.get("app"),
            ...e
        };
        Cache.set("app", t);
    }(Zt);

    const en = {
        display: [ {
            type: "switch",
            label: "\u9ed8\u8ba4\u663e\u793a\u60ac\u6d6e",
            name: "defaultShowFloat",
            value: Zt.defaultShowFloat,
            desc: "\u6253\u5f00\u9875\u9762\u65f6\u662f\u5426\u663e\u793a\u60ac\u6d6e\u7a97",
            options: []
        }, {
            type: "switch",
            label: "\u5f3a\u5236\u9690\u85cf",
            name: "hideFloat",
            value: Zt.hideFloat,
            desc: "\u4ec5\u70ed\u952e\u6216\u70b9\u51fb\u53f3\u4e0b\u89d2\u56fe\u7247\u624d\u663e\u793a\u60ac\u6d6e\u7a97",
            options: []
        }, {
            type: "switch",
            label: "\u6c14\u6ce1\u63d0\u793a",
            name: "alertBubble",
            value: Zt.alertBubble,
            desc: "\u53f3\u4e0b\u89d2\u6c14\u6ce1\u63d0\u793a\u662f\u5426\u5f00\u542f",
            options: []
        } ],
        system: [ {
            type: "switch",
            label: "\u68c0\u6d4b\u66f4\u65b0",
            name: "checkUpdate",
            value: Zt.checkUpdate,
            desc: "\u6253\u5f00\u9875\u9762\u65f6\u662f\u5426\u68c0\u6d4b\u66f4\u65b0",
            options: []
        }, {
            type: "switch",
            label: "iframe\u4f18\u5316(\u6d4b\u8bd5)",
            name: "iframe",
            value: Zt.iframe,
            desc: "\u9488\u5bf9\u6df1\u5ea6\u5d4c\u5957\u7f51\u9875\u7684\u4f18\u5316\uff0c\u9002\u5408\u5355\u4efb\u52a1\u9875\u4f7f\u7528\uff0c\u591a\u4efb\u52a1\u53ef\u80fd\u4f1a\u5bfc\u81f4\u5f39\u7a97\u8fc7\u591a\u3002\n \u6ce8\u610f\uff1a\u8be5\u529f\u80fd\u4e3a\u6d4b\u8bd5\u529f\u80fd\uff0c\u53ef\u80fd\u5b58\u5728\u672a\u77e5\u95ee\u9898\uff0c\u8bf7\u8c28\u614e\u4f7f\u7528",
            options: []
        } ],
        ai: [ {
            type: "select",
            label: "AI\u6a21\u578b\u9009\u62e9",
            name: "gptIndex",
            value: Zt.gptIndex,
            desc: "\u9009\u62e9AI\u6a21\u578b",
            options: Zt.gpt.map(((e, t) => ({
                label: e.desc,
                value: t
            })))
        }, {
            type: "switch",
            label: "AI\u8f85\u52a9\u7b54\u9898",
            name: "askGpt",
            value: Zt.askGpt,
            desc: "\u5f53\u6240\u6709\u9898\u5e93\u5747\u65e0\u7b54\u6848\u65f6\uff0c\u5c06\u4f7f\u7528AI\u8f85\u52a9\u81ea\u52a8\u7b54\u9898\uff0c\u6b63\u786e\u7387\u65e0\u6cd5\u4fdd\u8bc1\uff0c\u8c28\u614e\u4f7f\u7528",
            options: []
        } ],
        hotkey: [ {
            type: "switch",
            label: "\u542f\u7528\u5feb\u6377\u952e",
            name: "hotkeyEnabled",
            value: Zt.hotkeyEnabled,
            desc: "\u662f\u5426\u542f\u7528\u5feb\u6377\u952e\u663e\u9690\u60ac\u6d6e\u7a97",
            options: []
        }, {
            type: "hotkey",
            label: "\u5feb\u6377\u952e\u8bbe\u7f6e",
            name: "hotkey",
            value: Zt.hotkey,
            desc: "\u70b9\u51fb\u8f93\u5165\u6846\u540e\u6309\u4e0b\u60f3\u8981\u8bbe\u7f6e\u7684\u5feb\u6377\u952e\u7ec4\u5408\uff08\u652f\u6301Ctrl\u3001Shift\u3001Alt\u7ec4\u5408\u952e\uff09",
            options: []
        } ]
    }, tn = defineStore("app", {
        state: () => ({
            app: Zt,
            script: Yt.script,
            page: "home",
            ConfigInput: en,
            logs: [ {
                time: (new Date).toLocaleString(),
                type: "success",
                content: "\u521d\u59cb\u5316\u65e5\u5fd7\u6210\u529f"
            } ]
        }),
        actions: {
            setConfig(e) {
                this.app = {
                    ...this.app,
                    ...e
                }, Cache.set("app", this.app);
            },
            setPage(e) {
                this.page = e;
            },
            addLog(e) {
                this.logs.length > 100 && this.logs.shift(), this.logs.push(e);
            }
        }
    }), nn = Cache.get("apiList", []), an = [ {
        name: "\u4e00\u4e4b\u9898\u5e93",
        url: "http://cx.icodef.com/wyn-nb?v=4",
        method: "POST",
        type: "json",
        headers: {},
        params: [],
        data: {
            question: "$question",
            options: "$options",
            type: "$type"
        },
        response: {
            type: "field",
            value: "data"
        },
        weight: 0
    } ], on = defineStore("api", {
        state: () => ({
            apiList: nn,
            defApiList: an
        }),
        actions: {},
        getters: {
            getApiList() {
                return this.apiList.forEach(((e, t) => {
                    e.name === this.defApiList[t].name && (this.defApiList[t] = e);
                })), this.apiList.concat(this.defApiList);
            }
        }
    }), markToHtml = e => simpleMarkdownToHtml(e), sn = {
        0: '\u4f60\u662f\u4e00\u4e2aJSON\u8f93\u51fa\u673a\u5668\uff0c\u53ea\u80fd\u8f93\u51faJSON\u683c\u5f0f\uff0c\u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u5176\u4ed6\u5185\u5bb9\u3002\n\n\u3010\u9898\u578b\u3011\u5355\u9009\u9898\n\n\u3010\u8f93\u51fa\u683c\u5f0f\u3011\u4e25\u683c\u6309\u7167\u4ee5\u4e0bJSON\u683c\u5f0f\u8f93\u51fa\uff1a\n{"answer":["\u9009\u9879\u5b57\u6bcd"]}\n\n\u3010\u5f3a\u5236\u89c4\u5219\u3011\n1. \u53ea\u8f93\u51fa\u4e00\u884cJSON\uff0c\u4e0d\u5f97\u6709\u4efb\u4f55\u524d\u540e\u6587\u5b57\u3001\u89e3\u91ca\u3001\u7a7a\u884c\n2. \u9009\u9879\u5b57\u6bcd\u5fc5\u987b\u5927\u5199\uff08A\u3001B\u3001C\u3001D\u7b49\uff09\n3. \u6570\u7ec4\u4e2d\u53ea\u80fd\u6709\u4e00\u4e2a\u5143\u7d20\uff08\u5355\u9009\uff09\n4. \u7f6e\u4fe1\u5ea6\u4f4e\u4e8e60%\u65f6\u5fc5\u987b\u8fd4\u56de\uff1a{"answer":[]}\n5. \u7edd\u5bf9\u7981\u6b62\u8f93\u51famarkdown\u4ee3\u7801\u5757\uff08\u5982```json\uff09\n6. \u7edd\u5bf9\u7981\u6b62\u8f93\u51fa"\u7b54\u6848\u662f"\u3001"\u9009\u62e9"\u7b49\u6587\u5b57\n\n\u3010\u8f93\u51fa\u793a\u4f8b\u3011\n\u6b63\u786e\u793a\u4f8b1\uff1a{"answer":["B"]}\n\u6b63\u786e\u793a\u4f8b2\uff1a{"answer":[]}\n\u9519\u8bef\u793a\u4f8b\uff1a```json{"answer":["B"]}```\n\u9519\u8bef\u793a\u4f8b\uff1a\u7b54\u6848\u662fB\uff0c\u6240\u4ee5{"answer":["B"]}\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":["b"]}\n\n\u3010\u6700\u540e\u8b66\u544a\u3011\u4f60\u7684\u8f93\u51fa\u4f1a\u88abJSON.parse()\u76f4\u63a5\u89e3\u6790\uff0c\u4efb\u4f55\u975eJSON\u5185\u5bb9\u90fd\u4f1a\u5bfc\u81f4\u7cfb\u7edf\u5d29\u6e83\u3002',
        1: '\u4f60\u662f\u4e00\u4e2aJSON\u8f93\u51fa\u673a\u5668\uff0c\u53ea\u80fd\u8f93\u51faJSON\u683c\u5f0f\uff0c\u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u5176\u4ed6\u5185\u5bb9\u3002\n\n\u3010\u9898\u578b\u3011\u591a\u9009\u9898\n\n\u3010\u8f93\u51fa\u683c\u5f0f\u3011\u4e25\u683c\u6309\u7167\u4ee5\u4e0bJSON\u683c\u5f0f\u8f93\u51fa\uff1a\n{"answer":["\u9009\u9879\u5b57\u6bcd"]}\n\n\u3010\u5f3a\u5236\u89c4\u5219\u3011\n1. \u53ea\u8f93\u51fa\u4e00\u884cJSON\uff0c\u4e0d\u5f97\u6709\u4efb\u4f55\u524d\u540e\u6587\u5b57\u3001\u89e3\u91ca\u3001\u7a7a\u884c\n2. \u9009\u9879\u5b57\u6bcd\u5fc5\u987b\u5927\u5199\uff08A\u3001B\u3001C\u3001D\u7b49\uff09\n3. \u9009\u9879\u5fc5\u987b\u6309\u5b57\u6bcd\u5347\u5e8f\u6392\u5217\uff08\u5982["A","C","D"]\u800c\u975e["C","A","D"]\uff09\n4. \u81f3\u5c11\u5305\u542b2\u4e2a\u9009\u9879\u624d\u7b97\u6709\u6548\uff0c\u5426\u5219\u8fd4\u56de\u7a7a\u6570\u7ec4\n5. \u7f6e\u4fe1\u5ea6\u4f4e\u4e8e60%\u65f6\u5fc5\u987b\u8fd4\u56de\uff1a{"answer":[]}\n6. \u7edd\u5bf9\u7981\u6b62\u8f93\u51famarkdown\u4ee3\u7801\u5757\uff08\u5982```json\uff09\n7. \u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u89e3\u91ca\u6027\u6587\u5b57\n\n\u3010\u8f93\u51fa\u793a\u4f8b\u3011\n\u6b63\u786e\u793a\u4f8b1\uff1a{"answer":["A","C","D"]}\n\u6b63\u786e\u793a\u4f8b2\uff1a{"answer":["B","D"]}\n\u6b63\u786e\u793a\u4f8b3\uff1a{"answer":[]}\n\u9519\u8bef\u793a\u4f8b\uff1a```json{"answer":["A","C"]}```\n\u9519\u8bef\u793a\u4f8b\uff1a\u7b54\u6848\u662fACD\uff0c{"answer":["A","C","D"]}\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":["C","A"]}\uff08\u672a\u6392\u5e8f\uff09\n\n\u3010\u6700\u540e\u8b66\u544a\u3011\u4f60\u7684\u8f93\u51fa\u4f1a\u88abJSON.parse()\u76f4\u63a5\u89e3\u6790\uff0c\u4efb\u4f55\u975eJSON\u5185\u5bb9\u90fd\u4f1a\u5bfc\u81f4\u7cfb\u7edf\u5d29\u6e83\u3002',
        2: '\u4f60\u662f\u4e00\u4e2aJSON\u8f93\u51fa\u673a\u5668\uff0c\u53ea\u80fd\u8f93\u51faJSON\u683c\u5f0f\uff0c\u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u5176\u4ed6\u5185\u5bb9\u3002\n\n\u3010\u9898\u578b\u3011\u586b\u7a7a\u9898\n\n\u3010\u8f93\u51fa\u683c\u5f0f\u3011\u4e25\u683c\u6309\u7167\u4ee5\u4e0bJSON\u683c\u5f0f\u8f93\u51fa\uff1a\n{"answer":["\u7b54\u68481","\u7b54\u68482"]}\n\n\u3010\u5f3a\u5236\u89c4\u5219\u3011\n1. \u53ea\u8f93\u51fa\u4e00\u884cJSON\uff0c\u4e0d\u5f97\u6709\u4efb\u4f55\u524d\u540e\u6587\u5b57\u3001\u89e3\u91ca\u3001\u7a7a\u884c\n2. \u6570\u7ec4\u5143\u7d20\u4e2a\u6570\u5fc5\u987b\u4e0e\u9898\u76ee\u7a7a\u683c\u6570\u5b8c\u5168\u4e00\u81f4\n3. \u6bcf\u4e2a\u7b54\u6848\u957f\u5ea6\u4e0d\u8d85\u8fc715\u4e2a\u5b57\u7b26\n4. \u7b54\u6848\u8981\u7cbe\u7b80\u3001\u51c6\u786e\uff0c\u53bb\u9664\u591a\u4f59\u7684\u4fee\u9970\u8bcd\n5. \u4fdd\u6301\u7b54\u6848\u7684\u539f\u59cb\u683c\u5f0f\uff08\u6570\u5b57\u3001\u5355\u4f4d\u3001\u4e13\u4e1a\u672f\u8bed\u7b49\uff09\n6. \u65e0\u6cd5\u786e\u5b9a\u65f6\u8fd4\u56de\u7a7a\u6570\u7ec4\uff1a{"answer":[]}\n7. \u7edd\u5bf9\u7981\u6b62\u8f93\u51famarkdown\u4ee3\u7801\u5757\uff08\u5982```json\uff09\n8. \u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u89e3\u91ca\u6027\u6587\u5b57\n\n\u3010\u8f93\u51fa\u793a\u4f8b\u3011\n\u9898\u76ee\u67092\u4e2a\u7a7a\uff0c\u6b63\u786e\u793a\u4f8b1\uff1a{"answer":["\u5149\u5408\u4f5c\u7528","\u53f6\u7eff\u4f53"]}\n\u9898\u76ee\u67091\u4e2a\u7a7a\uff0c\u6b63\u786e\u793a\u4f8b2\uff1a{"answer":["DNA"]}\n\u4e0d\u786e\u5b9a\u65f6\uff0c\u6b63\u786e\u793a\u4f8b3\uff1a{"answer":[]}\n\u9519\u8bef\u793a\u4f8b\uff1a```json{"answer":["\u5149\u5408\u4f5c\u7528"]}```\n\u9519\u8bef\u793a\u4f8b\uff1a\u7b2c\u4e00\u4e2a\u7a7a\u662f"\u5149\u5408\u4f5c\u7528"\uff0c\u7b2c\u4e8c\u4e2a\u7a7a\u662f"\u53f6\u7eff\u4f53"\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":["\u5149\u5408\u4f5c\u7528"]}\uff08\u9898\u76ee\u67092\u4e2a\u7a7a\u4f46\u53ea\u7b541\u4e2a\uff09\n\n\u3010\u6700\u540e\u8b66\u544a\u3011\u4f60\u7684\u8f93\u51fa\u4f1a\u88abJSON.parse()\u76f4\u63a5\u89e3\u6790\uff0c\u4efb\u4f55\u975eJSON\u5185\u5bb9\u90fd\u4f1a\u5bfc\u81f4\u7cfb\u7edf\u5d29\u6e83\u3002',
        3: '\u4f60\u662f\u4e00\u4e2aJSON\u8f93\u51fa\u673a\u5668\uff0c\u53ea\u80fd\u8f93\u51faJSON\u683c\u5f0f\uff0c\u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u5176\u4ed6\u5185\u5bb9\u3002\n\n\u3010\u9898\u578b\u3011\u5224\u65ad\u9898\n\n\u3010\u8f93\u51fa\u683c\u5f0f\u3011\u4e25\u683c\u6309\u7167\u4ee5\u4e0bJSON\u683c\u5f0f\u8f93\u51fa\uff1a\n{"answer":"\u6b63\u786e"}\n\u6216\n{"answer":"\u9519\u8bef"}\n\n\u3010\u5f3a\u5236\u89c4\u5219\u3011\n1. \u53ea\u8f93\u51fa\u4e00\u884cJSON\uff0c\u4e0d\u5f97\u6709\u4efb\u4f55\u524d\u540e\u6587\u5b57\u3001\u89e3\u91ca\u3001\u7a7a\u884c\n2. answer\u7684\u503c\u53ea\u80fd\u662f"\u6b63\u786e"\u6216"\u9519\u8bef"\uff0c\u4e0d\u80fd\u662f\u5176\u4ed6\u4efb\u4f55\u6587\u5b57\n3. \u4e0d\u80fd\u662f"\u5bf9"\u3001"\u221a"\u3001"true"\u3001"T"\u7b49\u5176\u4ed6\u8868\u8ff0\n4. \u5b58\u5728\u6b67\u4e49\u6216\u4e0d\u786e\u5b9a\u65f6\u8fd4\u56de\uff1a{"answer":""}\n5. \u7edd\u5bf9\u7981\u6b62\u8f93\u51famarkdown\u4ee3\u7801\u5757\uff08\u5982```json\uff09\n6. \u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u5224\u65ad\u4f9d\u636e\u6216\u89e3\u91ca\n\n\u3010\u8f93\u51fa\u793a\u4f8b\u3011\n\u6b63\u786e\u793a\u4f8b1\uff1a{"answer":"\u6b63\u786e"}\n\u6b63\u786e\u793a\u4f8b2\uff1a{"answer":"\u9519\u8bef"}\n\u6b63\u786e\u793a\u4f8b3\uff1a{"answer":""}\n\u9519\u8bef\u793a\u4f8b\uff1a```json{"answer":"\u6b63\u786e"}```\n\u9519\u8bef\u793a\u4f8b\uff1a\u8fd9\u9053\u9898\u662f\u6b63\u786e\u7684\uff0c{"answer":"\u6b63\u786e"}\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":"\u5bf9"}\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":"true"}\n\n\u3010\u6700\u540e\u8b66\u544a\u3011\u4f60\u7684\u8f93\u51fa\u4f1a\u88abJSON.parse()\u76f4\u63a5\u89e3\u6790\uff0c\u4efb\u4f55\u975eJSON\u5185\u5bb9\u90fd\u4f1a\u5bfc\u81f4\u7cfb\u7edf\u5d29\u6e83\u3002',
        4: '\u4f60\u662f\u4e00\u4e2aJSON\u8f93\u51fa\u673a\u5668\uff0c\u53ea\u80fd\u8f93\u51faJSON\u683c\u5f0f\uff0c\u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u5176\u4ed6\u5185\u5bb9\u3002\n\n\u3010\u9898\u578b\u3011\u7b80\u7b54\u9898\n\n\u3010\u8f93\u51fa\u683c\u5f0f\u3011\u4e25\u683c\u6309\u7167\u4ee5\u4e0bJSON\u683c\u5f0f\u8f93\u51fa\uff1a\n{"answer":"\u7cbe\u7b80\u7684\u7b54\u6848"}\n\n\u3010\u5f3a\u5236\u89c4\u5219\u3011\n1. \u53ea\u8f93\u51fa\u4e00\u884cJSON\uff0c\u4e0d\u5f97\u6709\u4efb\u4f55\u524d\u540e\u6587\u5b57\u3001\u89e3\u91ca\u3001\u7a7a\u884c\n2. \u7b54\u6848\u957f\u5ea6\u4e0d\u8d85\u8fc730\u4e2a\u5b57\u7b26\n3. \u4f18\u5148\u4f7f\u7528\u9898\u5e72\u4e2d\u5df2\u6709\u7684\u4e13\u4e1a\u672f\u8bed\n4. \u7b54\u6848\u8981\u76f4\u63a5\u3001\u7cbe\u51c6\uff0c\u4e0d\u8981\u6709\u4fee\u8f9e\u3001\u6bd4\u55bb\u7b49\u4fee\u9970\n5. \u4e0d\u8981\u6dfb\u52a0\u6807\u70b9\u7b26\u53f7\uff08\u53e5\u53f7\u3001\u9017\u53f7\u7b49\uff09\n6. \u65e0\u6cd5\u56de\u7b54\u65f6\u8fd4\u56de\uff1a{"answer":""}\n7. \u7edd\u5bf9\u7981\u6b62\u8f93\u51famarkdown\u4ee3\u7801\u5757\uff08\u5982```json\uff09\n8. \u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u89e3\u6790\u8fc7\u7a0b\u6216\u601d\u8003\u6b65\u9aa4\n\n\u3010\u8f93\u51fa\u793a\u4f8b\u3011\n\u6b63\u786e\u793a\u4f8b1\uff1a{"answer":"\u5149\u5408\u4f5c\u7528\u5c06\u5149\u80fd\u8f6c\u5316\u4e3a\u5316\u5b66\u80fd"}\n\u6b63\u786e\u793a\u4f8b2\uff1a{"answer":"\u91cf\u5b50\u7ea0\u7f20"}\n\u6b63\u786e\u793a\u4f8b3\uff1a{"answer":""}\n\u9519\u8bef\u793a\u4f8b\uff1a```json{"answer":"\u5149\u5408\u4f5c\u7528"}```\n\u9519\u8bef\u793a\u4f8b\uff1a\u7b54\u6848\u662f\u5149\u5408\u4f5c\u7528\uff0c\u89e3\u6790\uff1a...\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":"\u5149\u5408\u4f5c\u7528\u3002"}\uff08\u6709\u6807\u70b9\uff09\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":"\u8fd9\u4e2a\u95ee\u9898\u6d89\u53ca\u7684\u662f\u5149\u5408\u4f5c\u7528\u7684\u76f8\u5173\u77e5\u8bc6\u70b9"}\uff08\u592a\u5197\u957f\uff09\n\n\u3010\u6700\u540e\u8b66\u544a\u3011\u4f60\u7684\u8f93\u51fa\u4f1a\u88abJSON.parse()\u76f4\u63a5\u89e3\u6790\uff0c\u4efb\u4f55\u975eJSON\u5185\u5bb9\u90fd\u4f1a\u5bfc\u81f4\u7cfb\u7edf\u5d29\u6e83\u3002'
    }, aiAsk = async (e, t, n, a = '\u4f60\u662f\u4e00\u4e2aJSON\u8f93\u51fa\u673a\u5668\uff0c\u53ea\u80fd\u8f93\u51faJSON\u683c\u5f0f\uff0c\u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u4efb\u4f55\u5176\u4ed6\u5185\u5bb9\u3002\n\n\u3010\u8f93\u51fa\u683c\u5f0f\u3011\u4e25\u683c\u6309\u7167\u4ee5\u4e0bJSON\u683c\u5f0f\u8f93\u51fa\uff1a\n{"answer":"\u7cbe\u7b80\u7684\u7b54\u6848"}\n\n\u3010\u5f3a\u5236\u89c4\u5219\u3011\n1. \u53ea\u8f93\u51fa\u4e00\u884cJSON\uff0c\u4e0d\u5f97\u6709\u4efb\u4f55\u524d\u540e\u6587\u5b57\u3001\u89e3\u91ca\u3001\u7a7a\u884c\n2. \u7b54\u6848\u957f\u5ea6\u63a7\u5236\u572850\u5b57\u7b26\u4ee5\u5185\uff08\u53ef\u6bd4\u7b80\u7b54\u9898\u7a0d\u957f\uff09\n3. \u76f4\u63a5\u56de\u7b54\u95ee\u9898\u7684\u6838\u5fc3\u8981\u70b9\uff0c\u4e0d\u8981\u5c55\u5f00\u8bba\u8ff0\n4. \u4f18\u5148\u4f7f\u7528\u9898\u76ee\u4e2d\u7684\u4e13\u4e1a\u672f\u8bed\n5. \u7981\u7528\u6bd4\u55bb\u3001\u4fee\u8f9e\u7b49\u6587\u5b66\u6027\u8868\u8fbe\n6. \u4fdd\u8bc1\u9648\u8ff0\u7684\u76f4\u63a5\u6027\u548c\u51c6\u786e\u6027\n7. \u7edd\u5bf9\u7981\u6b62\u8f93\u51famarkdown\u4ee3\u7801\u5757\uff08\u5982```json\uff09\n8. \u7edd\u5bf9\u7981\u6b62\u8f93\u51fa\u89e3\u6790\u3001\u89e3\u91ca\u3001\u601d\u8003\u8fc7\u7a0b\n\n\u3010\u8f93\u51fa\u793a\u4f8b\u3011\n\u6b63\u786e\u793a\u4f8b1\uff1a{"answer":"\u901a\u8fc7\u589e\u52a0\u9176\u6d53\u5ea6\u548c\u63d0\u9ad8\u53cd\u5e94\u6e29\u5ea6\u6765\u52a0\u901f\u5316\u5b66\u53cd\u5e94"}\n\u6b63\u786e\u793a\u4f8b2\uff1a{"answer":"\u91cf\u5b50\u7ea0\u7f20\u73b0\u8c61\u7684\u975e\u5c40\u57df\u6027\u7279\u5f81"}\n\u6b63\u786e\u793a\u4f8b3\uff1a{"answer":""}\n\u9519\u8bef\u793a\u4f8b\uff1a```json{"answer":"\u7b54\u6848\u5185\u5bb9"}```\n\u9519\u8bef\u793a\u4f8b\uff1a\u8fd9\u4e2a\u95ee\u9898\u7684\u7b54\u6848\u662f...\uff0c\u6240\u4ee5{"answer":"..."}\n\u9519\u8bef\u793a\u4f8b\uff1a{"answer":"\u8fd9\u5c31\u50cf...\uff08\u4f7f\u7528\u6bd4\u55bb\uff09"}\n\n\u3010\u6700\u540e\u8b66\u544a\u3011\u4f60\u7684\u8f93\u51fa\u4f1a\u88abJSON.parse()\u76f4\u63a5\u89e3\u6790\uff0c\u4efb\u4f55\u975eJSON\u5185\u5bb9\u90fd\u4f1a\u5bfc\u81f4\u7cfb\u7edf\u5d29\u6e83\u3002') => {
        const o = getApp(), s = o.gpt[o.gptIndex];
        if (!s.key) return t(`${s.msg}`), Promise.resolve("\u6682\u65e0KEY");
        const i = JSON.stringify({
            model: s.model,
            messages: [ {
                role: "system",
                content: a
            }, {
                role: "user",
                content: e
            } ],
            stream: !0
        });
        return new Promise(((e, a) => {
            ze({
                method: "POST",
                url: s.api,
                data: i,
                headers: {
                    Accept: "application/json",
                    Authorization: `Bearer ${s.key}`,
                    "Content-Type": "application/json"
                },
                responseType: "stream",
                onloadstart: async o => {
                    try {
                        const a = o.response.getReader(), s = new TextDecoder;
                        let i = "";
                        const processStream = async () => {
                            for (;;) {
                                const {done: o, value: r} = await a.read(), l = [ ...s.decode(r).matchAll(/data:\s*({.*?})\s*\n/g) ].map((e => {
                                    try {
                                        return JSON.parse(e[1]);
                                    } catch {
                                        return null;
                                    }
                                })).filter(Boolean) || [];
                                if (l.some((e => {
                                    var t;
                                    return null == (t = e.choices) ? void 0 : t.some((e => "stop" === e.finish_reason));
                                })) || o) return n(), e(i);
                                l.flatMap((e => {
                                    var t;
                                    return (null == (t = e.choices) ? void 0 : t.map((e => e.delta.content)).filter(Boolean)) || [];
                                })).forEach((e => {
                                    i += e, t(e);
                                }));
                            }
                        };
                        await processStream();
                    } catch (s) {
                        console.error("Error reading stream:", s), n(), a(s);
                    }
                }
            });
        }));
    }, rn = defineStore("ask", {
        state: () => ({
            questionList: [],
            questionInx: 0,
            inx: 0,
            Interval: 0,
            start: !1,
            skipFinish: Cache.get("skipFinish", !1),
            autoNext: Cache.get("autoNext", !1),
            autoAnswer: Cache.get("autoAnswer", !0),
            freeFirst: !0,
            randomAnswer: Cache.get("randomAnswer", !1),
            lock: !1,
            formMap: {},
            type: "cx",
            loading: !1,
            loadingText: "\u52a0\u8f7d\u4e2d....",
            tips: "\u672c\u811a\u672c\u4ec5\u4f9b\u5b66\u4e60\u7814\u7a76\uff0c\u8bf7\u52ff\u7528\u4e8e\u975e\u6cd5\u7528\u9014",
            delay: Cache.get("delay", 1e3),
            minDelay: Cache.get("minDelay", 0),
            saveQuestionData: []
        }),
        actions: {
            addQuestion(e) {
                this.questionList.push({
                    ...e,
                    answer: [],
                    status: 0,
                    aiMsg: ""
                });
            },
            clearQuestion() {
                this.questionList = [];
            },
            getQuestion() {
                return this.questionList[this.questionInx];
            },
            nextQuestion() {
                if (this.questionInx === this.questionList.length - 1) return clearInterval(this.Interval), 
                void (this.start = !1);
                this.questionInx++;
            },
            prevQuestion() {
                0 !== this.questionInx && this.questionInx--;
            },
            toQuestion(e) {
                this.questionInx = e;
                let t = this.questionList[e];
                this.rule.toquestion && this.rule.toquestion(e);
                try {
                    if (t.html.scrollIntoView({
                        block: "center"
                    }), $e.self !== $e.top) {
                        let n = document.querySelector(".el-dialog");
                        if (n) {
                            n.style.transform = "none";
                            let a = t.html.getBoundingClientRect();
                            n.style.top = a.top - 700 + "px", 0 === e && (n.style.top = "0px"), e === this.questionList.length - 1 && document.documentElement.scrollHeight > 2e3 && (n.style.top = a.top - 900 + "px");
                        }
                    }
                    t.html.style.boxShadow = "0 0 10px rgba(0, 0, 0, 0.15)", setTimeout((() => {
                        t.html.style.boxShadow = "";
                    }), 500);
                } catch (n) {}
            },
            setQuestionStatus(e, t) {
                this.questionList[e] && null != this.questionList[e].status && (this.questionList[e].status = t);
            },
            async toggleStart() {
                var e;
                const t = getAppStore();
                if (!this.lock && (this.start = !this.start, this.start)) {
                    this.lock = !0;
                    for (let n = this.questionInx; n < this.questionList.length && this.start; n++) {
                        if (this.skipFinish && 1 === this.questionList[n].status) continue;
                        this.questionInx = n, "8" !== this.questionList[n].type ? ((null == (e = this.rule) ? void 0 : e.answerDelay) && await sleep(this.rule.answerDelay), 
                        await this.reAnswer(n), t.app.alert = `\u5f53\u524d\u8fdb\u5ea6:${n + 1}/${this.questionList.length}`, 
                        await sleep(this.delay + 1e3 * Math.random()), this.rule.toquestion && this.rule.toquestion(this.questionInx + 1), 
                        this.autoNext && this.rule.next && this.rule.next()) : this.setQuestionStatus(n, 2);
                    }
                    this.autoNext && this.rule.finish && this.rule.finish({
                        question: this.questionList
                    }), this.start = !1, this.lock = !1, this.formMap = {}, this.questionList.forEach((e => {
                        var n;
                        if (null == (n = e.form) ? void 0 : n.form) {
                            let t = e.form.form;
                            t && (this.formMap[t] = this.formMap[t] ? this.formMap[t] + 1 : 1);
                        } else this.formMap["\u65e0\u7b54\u6848"] = this.formMap["\u65e0\u7b54\u6848"] ? this.formMap["\u65e0\u7b54\u6848"] + 1 : 1;
                        t.app.alert = "\u7b54\u9898\u5b8c\u6210~";
                    }));
                }
            },
            async reAnswer(e) {
                const t = getAppStore();
                let n = this.questionList[e], a = [];
                this.loading = !0, this.loadingText = "\u52a0\u8f7d\u4e2d....";
                let o = await Answer.getCacheAnswer(n), s = ApiAnswerMatch([ o ], n);
                if (!s.haveAnswer && (this.loadingText = "\u6b63\u5728\u4ece\u63a5\u53e3\u4e2d\u83b7\u53d6\u7b54\u6848", 
                o = await Answer.getAnswersFree(n), s = ApiAnswerMatch(o, n), a = o, !s.haveAnswer && t.app.askGpt)) {
                    this.loadingText = "\u6b63\u5728\u4eceAI\u4e2d\u83b7\u53d6\u7b54\u6848";
                    let e = this.buildAIQuestionText(n);
                    if (!e.includes("<img")) {
                        const i = await this.fetchAIAnswer(e, n.type, t);
                        o = i.res, s = i.matchResult, a.push(o);
                    }
                }
                n.answer = a, n.form = s.form, s.haveAnswer ? this.setQuestionStatus(e, 1) : (this.randomAnswer && ((e, t) => {
                    const n = getAskStore();
                    let a = !0, o = t.type, s = t.html, i = [ "", [], t, n.rule ];
                    switch (o) {
                      case "0":
                      case "1":
                        let e = [ Math.floor(Math.random() * t.options.length) ];
                        i[0] = "xx", i[1] = e;
                        break;

                      case "3":
                        let n = Math.random() > .5 ? "\u6b63\u786e" : "\u9519\u8bef";
                        i[0] = "pd", i[1] = n;
                        break;

                      default:
                        return;
                    }
                    n.rule.setAnswerHook && "function" == typeof n.rule.setAnswerHook && n.rule.setAnswerHook({
                        type: o,
                        answer: i[1],
                        html: t.html,
                        ques: t
                    }), n.rule.setAnswer && "function" == typeof n.rule.setAnswer && (a = n.rule.setAnswer({
                        type: o,
                        answer: i[1],
                        html: s,
                        ques: t,
                        rule: n.rule
                    })), a && defaultSetAnswer(i[0], i[1], t, n.rule);
                })(0, n), this.setQuestionStatus(e, 2)), this.loading = !1;
            },
            buildAIQuestionText(e) {
                var t;
                let n = `[${typeConvert(e.type, !1)}]${e.question}\n`;
                return e.options && e.options.forEach(((e, t) => {
                    n += `${String.fromCharCode(65 + t)}\u3001${e}\n`;
                })), "24" === e.type && (e.match.forEach((e => {
                    n += `\u7b2c\u4e00\u5217${e}\n`;
                })), null == (t = e.selects[0]) || t.forEach((e => {
                    n += `\u7b2c\u4e8c\u5217${e.text}\n`;
                }))), n;
            },
            async fetchAIAnswer(e, t, n) {
                let a = Date.now(), o = {}, s = {};
                try {
                    let r = await aiAsk(e, (e => {}), (() => {}), (e => sn[e] || sn[4])(t));
                    r = r.replace("```json", "").replace("```", "").trim();
                    try {
                        o = JSON.parse(r);
                    } catch (i) {
                        o = {
                            answer: r,
                            msg: "",
                            form: "",
                            duration: 5e3
                        };
                    }
                    o.form = n.app.gpt[n.app.gptIndex].desc, o.duration = Date.now() - a, o.answer || (o.msg = "AI\u8bf4\u4ed6\u4e0d\u4f1a"), 
                    s = ApiAnswerMatch([ o ], this.questionList[this.questionInx], !0);
                } catch (r) {
                    o = {
                        answer: "",
                        msg: markToHtml(n.app.gpt[n.app.gptIndex].msg),
                        form: n.app.gpt[n.app.gptIndex].desc,
                        duration: 5e3
                    };
                }
                return {
                    res: o,
                    matchResult: s
                };
            },
            aiAnswer(e) {
                let t = this.questionList[e];
                this.loadingText = "AI\u601d\u8003\u4e2d.....", this.loading = !0;
                let n = `[${typeConvert(t.type, !1)}]${t.question}\n`;
                t.aiMsg = "", t.options.forEach((e => {
                    n += `${e}\n`;
                })), "24" === t.type && (t.match.forEach(((e, t) => {
                    n += `\u7b2c\u4e00\u5217${e}\n`;
                })), t.selects[0].forEach(((e, t) => {
                    n += `\u7b2c\u4e8c\u5217${e.text}\n`;
                }))), aiAsk(n, (e => {
                    t.aiMsg += e, this.loading = !1;
                }), (() => {
                    this.loading = !1, t.aiMsg.length <= 0 && (t.aiMsg = "AI\u54cd\u5e94\u5f02\u5e38\uff0c\u53ef\u80fd\u662f\u6ca1\u6709\u83b7\u53d6KEY,\u8bf7\u6309\u4e0b\u65b9\u6b65\u9aa4\u64cd\u4f5c  \n            1. \u6253\u5f00[\u667a\u666e\u6e05\u8a00](https://chatglm.cn/main/alltoolsdetail)  \n            2. \u767b\u5f55\u540e\u968f\u4fbf\u53d1\u4e00\u6761\u6d88\u606f\u5373\u53ef  \n            3. \u8fd4\u56de\u7b54\u9898\u9875\u5237\u65b0\u9875\u9762  ");
                }));
            },
            pause() {
                this.start = !1;
            },
            restart() {
                this.questionInx = 0, this.start = !0, this.toggleStart();
            }
        },
        getters: {
            current() {
                return this.questionList[this.questionInx];
            },
            currentAiMd() {
                return markToHtml(this.questionList[this.questionInx].aiMsg);
            },
            tipsMd() {
                const e = this.rule;
                if (!e) return '<span style="color:red">\u8be5\u9875\u9762\u6682\u65e0\u89c4\u5219</span>';
                const t = [];
                return t.push(`<span style="color:blue">${e.name}</span><span style="color:red">${e.tips || "\u6709\u95ee\u9898\u53ef\u4ee5\u53cd\u9988\u7ed9\u4f5c\u8005"}</span>`), 
                t.join("<br />");
            },
            typesMd() {
                const e = this.rule;
                if (!e || !e.types) return '<span style="color:red">\u8be5\u9875\u9762\u6682\u65e0\u89c4\u5219</span>';
                const t = e.types, n = [];
                for (const a in t) {
                    const e = t[a];
                    n.push(`<span style="color:blue">${typeConvert(e, !1)}&nbsp;\u2705</span>`);
                }
                return n.push('<span style="color:red">\u4e0d\u652f\u6301\u7684\u9898\u578b\u53ef\u4ee5\u53cd\u9988\u7ed9\u4f5c\u8005\u517c\u5bb9</span>'), 
                n.join("<br />");
            }
        }
    }), ln = Cache.get("user", {}), cn = defineStore("user", {
        state: () => ({
            user: ln.user || null,
            apiKey: ln.api_key || "",
            stats: {
                course_count: 0,
                chapter_count: 0,
                question_count: 0
            },
            isLoggedIn: !!ln.user,
            loginTime: ln.login_time || 0
        }),
        getters: {
            username: e => {
                var t;
                return (null == (t = e.user) ? void 0 : t.username) || "\u672a\u767b\u5f55";
            },
            nickname: e => {
                var t;
                return (null == (t = e.user) ? void 0 : t.nickname) || "\u6e38\u5ba2";
            },
            avatar: () => "",
            score: e => {
                var t;
                return (null == (t = e.user) ? void 0 : t.score) || 0;
            },
            level: e => {
                var t;
                return (null == (t = e.user) ? void 0 : t.level) || 0;
            },
            isVip: e => {
                var t;
                return ((null == (t = e.user) ? void 0 : t.level) || 0) > 0;
            }
        },
        actions: {
            async loginByPassword(e, t) {
                try {
                    const n = "https://www.aiask.site/v1/user/login", [a] = await requestApi(n, "POST", {
                        username: e,
                        password: t,
                        login_type: "password"
                    }), o = JSON.parse(a.responseText);
                    return 200 === o.code ? (this.user = o.data.user, this.apiKey = o.data.api_key, 
                    this.isLoggedIn = !0, this.loginTime = Date.now(), this.saveToCache(), await this.fetchUserInfo(), 
                    o.data, {
                        success: !0,
                        message: "\u767b\u5f55\u6210\u529f"
                    }) : {
                        success: !1,
                        message: o.message || "\u767b\u5f55\u5931\u8d25"
                    };
                } catch (n) {
                    return {
                        success: !1,
                        message: n.message || "\u767b\u5f55\u5931\u8d25\uff0c\u8bf7\u68c0\u67e5\u7f51\u7edc\u8fde\u63a5"
                    };
                }
            },
            async loginByApiKey(e) {
                try {
                    const t = "https://www.aiask.site/v1/user/login", [n] = await requestApi(t, "POST", {
                        api_key: e,
                        login_type: "apikey"
                    }), a = JSON.parse(n.responseText);
                    return 200 === a.code ? (this.user = a.data.user, this.apiKey = a.data.api_key, 
                    this.isLoggedIn = !0, this.loginTime = Date.now(), this.saveToCache(), await this.fetchUserInfo(), 
                    a.data, {
                        success: !0,
                        message: "\u767b\u5f55\u6210\u529f"
                    }) : {
                        success: !1,
                        message: a.message || "API Key \u767b\u5f55\u5931\u8d25"
                    };
                } catch (t) {
                    return {
                        success: !1,
                        message: t.message || "API Key \u767b\u5f55\u5931\u8d25\uff0c\u8bf7\u68c0\u67e5\u7f51\u7edc\u8fde\u63a5"
                    };
                }
            },
            async register(e) {
                try {
                    const t = "https://www.aiask.site/v1/user/register", [n] = await requestApi(t, "POST", e), a = JSON.parse(n.responseText);
                    return 200 === a.code ? (this.user = a.data.user, this.apiKey = a.data.api_key, 
                    this.isLoggedIn = !0, this.loginTime = Date.now(), this.saveToCache(), a.data, {
                        success: !0,
                        message: "\u6ce8\u518c\u6210\u529f"
                    }) : {
                        success: !1,
                        message: a.message || "\u6ce8\u518c\u5931\u8d25"
                    };
                } catch (t) {
                    return {
                        success: !1,
                        message: t.message || "\u6ce8\u518c\u5931\u8d25\uff0c\u8bf7\u68c0\u67e5\u7f51\u7edc\u8fde\u63a5"
                    };
                }
            },
            async fetchUserInfo() {
                if (this.isLoggedIn) try {
                    const e = "https://www.aiask.site/v1/user/info", [t] = await requestApi(e, "GET", void 0, {
                        Authorization: `Bearer ${this.apiKey}`
                    }), n = JSON.parse(t.responseText);
                    200 === n.code && (this.user = n.data.user, this.stats = n.data.stats, this.saveToCache(), 
                    n.data);
                } catch (e) {}
            },
            async logout() {
                try {
                    if (this.apiKey) {
                        const e = "https://www.aiask.site/v1/user/logout";
                        await requestApi(e, "POST", void 0, {
                            Authorization: `Bearer ${this.apiKey}`
                        });
                    }
                } catch (e) {} finally {
                    this.user = null, this.apiKey = "", this.stats = {
                        course_count: 0,
                        chapter_count: 0,
                        question_count: 0
                    }, this.isLoggedIn = !1, this.loginTime = 0, Cache.remove("user");
                }
            },
            async refreshApiKey() {
                try {
                    const e = "https://www.aiask.site/v1/user/refresh-apikey", [t] = await requestApi(e, "POST", void 0, {
                        Authorization: `Bearer ${this.apiKey}`
                    }), n = JSON.parse(t.responseText);
                    return 200 === n.code ? (this.apiKey = n.data.api_key, this.saveToCache(), n.data.api_key, 
                    {
                        success: !0,
                        message: "API Key \u5237\u65b0\u6210\u529f",
                        api_key: n.data.api_key
                    }) : {
                        success: !1,
                        message: n.message || "API Key \u5237\u65b0\u5931\u8d25"
                    };
                } catch (e) {
                    return {
                        success: !1,
                        message: e.message || "API Key \u5237\u65b0\u5931\u8d25"
                    };
                }
            },
            async updateUserInfo(e) {
                try {
                    const t = "https://www.aiask.site/v1/user/update", [n] = await requestApi(t, "POST", e, {
                        Authorization: `Bearer ${this.apiKey}`
                    }), a = JSON.parse(n.responseText);
                    return 200 === a.code ? (this.user && (this.user = {
                        ...this.user,
                        ...a.data.user
                    }), this.saveToCache(), a.data, {
                        success: !0,
                        message: "\u66f4\u65b0\u6210\u529f"
                    }) : {
                        success: !1,
                        message: a.message || "\u66f4\u65b0\u5931\u8d25"
                    };
                } catch (t) {
                    return {
                        success: !1,
                        message: t.message || "\u66f4\u65b0\u5931\u8d25"
                    };
                }
            },
            async changePassword(e, t) {
                try {
                    const n = "https://www.aiask.site/v1/user/change-password", [a] = await requestApi(n, "POST", {
                        old_password: e,
                        new_password: t
                    }, {
                        Authorization: `Bearer ${this.apiKey}`
                    }), o = JSON.parse(a.responseText);
                    return 200 === o.code ? {
                        success: !0,
                        message: "\u5bc6\u7801\u4fee\u6539\u6210\u529f"
                    } : {
                        success: !1,
                        message: o.message || "\u5bc6\u7801\u4fee\u6539\u5931\u8d25"
                    };
                } catch (n) {
                    return {
                        success: !1,
                        message: n.message || "\u5bc6\u7801\u4fee\u6539\u5931\u8d25"
                    };
                }
            },
            async fuzzySearchQuestion(e) {
                var t;
                try {
                    const t = "https://www.aiask.site/v1/question/fuzzy", n = {
                        question: e.question,
                        type: e.type ?? 8,
                        options: e.options ?? []
                    }, [a] = await requestApi(t, "POST", n), o = JSON.parse(a.responseText), s = 401 === o.code || 401 === a.status;
                    return 200 === o.code ? {
                        success: !0,
                        message: o.message || "success",
                        data: o.data || []
                    } : s ? {
                        success: !1,
                        message: o.message || "\u767b\u5f55\u540e\u624d\u53ef\u4ee5\u4f7f\u7528\u5b98\u65b9\u9898\u5e93\uff0c\u8bf7\u5148\u767b\u5f55",
                        data: [],
                        needLogin: !0
                    } : {
                        success: !1,
                        message: o.message || "\u5b98\u65b9\u9898\u5e93\u641c\u7d22\u5931\u8d25",
                        data: []
                    };
                } catch (n) {
                    const e = 401 === (null == n ? void 0 : n.status) || 401 === (null == (t = null == n ? void 0 : n.response) ? void 0 : t.status);
                    return {
                        success: !1,
                        message: e ? "\u767b\u5f55\u540e\u624d\u53ef\u4ee5\u4f7f\u7528\u5b98\u65b9\u9898\u5e93\uff0c\u8bf7\u5148\u767b\u5f55" : (null == n ? void 0 : n.message) || "\u5b98\u65b9\u9898\u5e93\u641c\u7d22\u5931\u8d25\uff0c\u8bf7\u7a0d\u540e\u91cd\u8bd5",
                        data: [],
                        needLogin: e
                    };
                }
            },
            saveToCache() {
                const e = {
                    user: this.user || void 0,
                    api_key: this.apiKey || void 0,
                    login_time: this.loginTime || void 0
                };
                Cache.set("user", e);
            },
            loadFromCache() {
                const e = Cache.get("user", {});
                e.user && (this.user = e.user, this.apiKey = e.api_key || "", this.loginTime = e.login_time || 0, 
                this.isLoggedIn = !0);
            }
        }
    }), pn = {
        class: "home-container"
    }, un = {
        class: "user-status"
    }, dn = {
        class: "user-info"
    }, mn = {
        class: "user-details"
    }, hn = {
        key: 0
    }, fn = {
        key: 1,
        style: {
            color: "#86868b",
            "font-size": "13px"
        }
    }, gn = {
        class: "user-actions"
    }, yn = vue.createElementVNode("span", {
        style: {
            "font-size": "15px",
            "font-weight": "500",
            color: "#1d1d1f"
        }
    }, "\u529f\u80fd\u5217\u8868", -1), wn = {
        key: 1,
        class: "pages-grid"
    }, vn = vue.createElementVNode("span", {
        style: {
            "font-size": "15px",
            "font-weight": "500",
            color: "#1d1d1f"
        }
    }, "\u7248\u672c\u4fe1\u606f", -1), bn = {
        class: "version-section"
    }, xn = vue.createElementVNode("span", {
        style: {
            color: "#86868b",
            "font-size": "14px"
        }
    }, "\u5f53\u524d\u7248\u672c:", -1), _n = vue.createElementVNode("p", {
        style: {
            color: "#86868b",
            "font-size": "13px",
            "margin-top": "8px"
        }
    }, " \ud83d\udca1 \u4fdd\u6301\u6700\u65b0\u7248\u672c\u53ef\u4ee5\u51cf\u5c11BUG\u7684\u51fa\u73b0\u54e6~ ", -1), kn = vue.defineComponent({
        __name: "Home",
        setup(e) {
            const t = tn(), s = cn();
            Yt.script.downloadURL;
            const r = vue.ref(!0), l = [ {
                name: "\u57fa\u7840\u914d\u7f6e",
                page: "Base",
                icon: he,
                desc: "\u7cfb\u7edf\u57fa\u7840\u8bbe\u7f6e\u4e0e\u53c2\u6570\u914d\u7f6e",
                color: "#667eea"
            }, {
                name: "\u7b54\u9898\u754c\u9762",
                page: "ask",
                icon: ae,
                desc: "\u5f00\u59cb\u7b54\u9898\uff0c\u652f\u6301\u81ea\u52a8\u7b54\u9898",
                color: "#f093fb"
            }, {
                name: "\u672c\u5730\u9898\u5e93",
                page: "preview",
                icon: te,
                desc: "\u9884\u89c8\u548c\u7ba1\u7406\u672c\u5730\u9898\u5e93",
                color: "#4facfe"
            }, {
                name: "\u8bd5\u5377\u5e93",
                page: "paperLibrary",
                icon: X,
                desc: "\u67e5\u770b\u5df2\u7f13\u5b58\u8bfe\u7a0b\u7684\u8bd5\u5377\u548c\u7ae0\u8282",
                color: "#f093fb"
            }, {
                name: "\u9898\u5e93\u7f13\u5b58",
                page: "question",
                icon: se,
                desc: "\u67e5\u770b\u548c\u6e05\u7406\u9898\u5e93\u7f13\u5b58",
                color: "#fa709a"
            }, {
                name: "\u9898\u5e93\u5bfc\u5165",
                page: "questionTool",
                icon: ge,
                desc: "\u5bfc\u5165\u5916\u90e8\u9898\u5e93\u6570\u636e",
                color: "#fee140"
            }, {
                name: "\u65e5\u5fd7\u8bb0\u5f55",
                page: "log",
                icon: pe,
                desc: "\u67e5\u770b\u7cfb\u7edf\u8fd0\u884c\u65e5\u5fd7",
                color: "#30cfd0"
            }, {
                name: "AI\u641c\u9898",
                page: "ai",
                icon: K,
                desc: "AI\u667a\u80fd\u641c\u9898\u4e0e\u89e3\u7b54",
                color: "#a8edea"
            } ];
            return (e, i) => {
                const c = vue.resolveComponent("el-alert"), p = vue.resolveComponent("el-icon"), u = vue.resolveComponent("el-avatar"), d = vue.resolveComponent("el-tag"), m = vue.resolveComponent("el-button"), h = vue.resolveComponent("el-card"), f = vue.resolveComponent("el-divider");
                return vue.openBlock(), vue.createElementBlock("div", pn, [ vue.createVNode(c, {
                    type: "info",
                    closable: !1,
                    style: {
                        "margin-top": "15px"
                    }
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" \u672c\u811a\u672c\u4ec5\u4f9b\u5b66\u4e60\u4ea4\u6d41\uff0c\u8bf7\u52ff\u7528\u4f5c\u4efb\u4f55\u975e\u6cd5\u7528\u9014\u3002\u5982\u9700\u6dfb\u52a0\u5176\u4ed6\u5e73\u53f0\u7b54\u9898\u529f\u80fd\uff0c\u8bf7\u53cd\u9988\u7ed9\u4f5c\u8005\u3002 ") ])),
                    _: 1
                }), vue.createVNode(h, {
                    class: "user-status-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", un, [ vue.createElementVNode("div", dn, [ vue.createVNode(u, {
                        size: 56,
                        src: vue.unref(s).avatar
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, null, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(ye)) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }, 8, [ "src" ]), vue.createElementVNode("div", mn, [ vue.createElementVNode("h3", null, vue.toDisplayString(vue.unref(s).nickname || "\u6e38\u5ba2"), 1), vue.unref(s).isLoggedIn ? (vue.openBlock(), 
                    vue.createElementBlock("p", hn, [ vue.createVNode(d, {
                        type: "success",
                        size: "small",
                        effect: "plain"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u79ef\u5206: " + vue.toDisplayString(vue.unref(s).score), 1) ])),
                        _: 1
                    }), vue.unref(s).isVip ? (vue.openBlock(), vue.createBlock(d, {
                        key: 0,
                        type: "warning",
                        size: "small",
                        effect: "plain",
                        style: {
                            "margin-left": "6px"
                        }
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" VIP Lv." + vue.toDisplayString(vue.unref(s).level), 1) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0) ])) : (vue.openBlock(), vue.createElementBlock("p", fn, "\u672a\u767b\u5f55\uff0c\u767b\u5f55\u540e\u53ef\u4eab\u53d7\u66f4\u591a\u529f\u80fd")) ]) ]), vue.createElementVNode("div", gn, [ vue.unref(s).isLoggedIn ? (vue.openBlock(), 
                    vue.createBlock(m, {
                        key: 1,
                        type: "primary",
                        plain: "",
                        onClick: i[1] || (i[1] = e => vue.unref(t).setPage("user"))
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u4e2a\u4eba\u4e2d\u5fc3 ") ])),
                        _: 1
                    })) : (vue.openBlock(), vue.createBlock(m, {
                        key: 0,
                        type: "primary",
                        onClick: i[0] || (i[0] = e => vue.unref(t).setPage("user"))
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u767b\u5f55 / \u6ce8\u518c ") ])),
                        _: 1
                    })) ]) ]) ])),
                    _: 1
                }), r.value ? (vue.openBlock(), vue.createBlock(f, {
                    key: 0
                }, {
                    default: vue.withCtx((() => [ yn ])),
                    _: 1
                })) : vue.createCommentVNode("", !0), r.value ? (vue.openBlock(), vue.createElementBlock("div", wn, [ (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(l, ((e, a) => vue.createVNode(m, {
                    key: a,
                    type: "primary",
                    plain: "",
                    class: "page-button",
                    onClick: n => vue.unref(t).setPage(e.page)
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(p, null, {
                        default: vue.withCtx((() => [ (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(e.icon))) ])),
                        _: 2
                    }, 1024), vue.createElementVNode("span", null, vue.toDisplayString(e.name), 1) ])),
                    _: 2
                }, 1032, [ "onClick" ]))), 64)) ])) : vue.createCommentVNode("", !0), vue.createVNode(f, null, {
                    default: vue.withCtx((() => [ vn ])),
                    _: 1
                }), vue.createElementVNode("div", bn, [ vue.createElementVNode("p", null, [ xn, vue.createVNode(d, {
                    type: "primary",
                    effect: "plain"
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(vue.unref(Yt).script.version), 1) ])),
                    _: 1
                }), vue.createVNode(m, {
                    size: "small",
                    type: "primary",
                    onClick: i[2] || (i[2] = e => vue.unref(updateFn)(!1))
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" \u68c0\u6d4b\u66f4\u65b0 ") ])),
                    _: 1
                }) ]), _n ]) ]);
            };
        }
    }), qn = {
        class: "base-container"
    }, Cn = {
        class: "card-header"
    }, Tn = vue.createElementVNode("span", {
        class: "card-title"
    }, "\ud83c\udfa8 \u663e\u793a\u8bbe\u7f6e", -1), An = {
        class: "config-list"
    }, Sn = {
        class: "config-item-content"
    }, Hn = {
        class: "config-label"
    }, Un = {
        class: "label-text"
    }, En = {
        class: "config-control"
    }, zn = {
        key: 4,
        class: "hotkey-input-wrapper"
    }, $n = {
        class: "card-header"
    }, jn = vue.createElementVNode("span", {
        class: "card-title"
    }, "\u2699\ufe0f \u7cfb\u7edf\u8bbe\u7f6e", -1), In = {
        class: "config-list"
    }, Ln = {
        class: "config-item-content"
    }, On = {
        class: "config-label"
    }, Fn = {
        class: "label-text"
    }, Pn = {
        class: "config-control"
    }, Mn = {
        key: 4,
        class: "hotkey-input-wrapper"
    }, Vn = {
        class: "card-header"
    }, Dn = vue.createElementVNode("span", {
        class: "card-title"
    }, "\ud83e\udd16 AI\u8bbe\u7f6e", -1), Nn = {
        class: "config-list"
    }, Bn = {
        class: "config-item-content"
    }, Gn = {
        class: "config-label"
    }, Rn = {
        class: "label-text"
    }, Jn = {
        class: "config-control"
    }, Qn = {
        key: 4,
        class: "hotkey-input-wrapper"
    }, Wn = {
        class: "card-header"
    }, Kn = vue.createElementVNode("span", {
        class: "card-title"
    }, "\u2328\ufe0f \u5feb\u6377\u952e\u8bbe\u7f6e", -1), Yn = {
        class: "config-list"
    }, Xn = {
        class: "config-item-content"
    }, Zn = {
        class: "config-label"
    }, ea = {
        class: "label-text"
    }, ta = {
        class: "config-control"
    }, na = {
        key: 4,
        class: "hotkey-input-wrapper"
    }, aa = vue.defineComponent({
        __name: "Base",
        setup(e) {
            const t = tn(), s = vue.ref(null), handleHotkeyKeydown = (e, t) => {
                if (e.preventDefault(), e.stopPropagation(), [ "Control", "Shift", "Alt", "Meta" ].includes(e.key)) return;
                const n = [];
                e.ctrlKey && n.push("Ctrl"), e.shiftKey && n.push("Shift"), e.altKey && n.push("Alt");
                let a = e.key;
                a = " " === a ? "Space" : e.code.startsWith("Key") ? e.code.replace("Key", "") : e.code.startsWith("Digit") ? e.code.replace("Digit", "") : e.code.startsWith("Arrow") ? e.code : e.key.toUpperCase(), 
                n.push(a);
                const o = n.join("+");
                t.value = o, s.value = null, msg(`\u5feb\u6377\u952e\u5df2\u8bbe\u7f6e\u4e3a: ${o}`, "success");
            }, startRecording = e => {
                s.value = e;
            };
            vue.watch(t.app, (e => {
                t.setConfig(e);
            })), vue.watch(t.ConfigInput, (e => {
                for (let n in e) for (let a in e[n]) {
                    let o = e[n][a];
                    t.app[o.name] = o.value;
                }
                msg("\u914d\u7f6e\u4fee\u6539\u6210\u529f", "success"), t.app, t.setConfig(t.app);
            }));
            const r = t.ConfigInput;
            return (e, t) => {
                const i = vue.resolveComponent("el-alert"), l = vue.resolveComponent("el-card"), c = vue.resolveComponent("el-tag"), p = vue.resolveComponent("el-icon"), u = vue.resolveComponent("el-tooltip"), d = vue.resolveComponent("el-switch"), m = vue.resolveComponent("el-input"), h = vue.resolveComponent("el-input-number"), f = vue.resolveComponent("el-option"), g = vue.resolveComponent("el-select"), y = vue.resolveComponent("el-checkbox"), w = vue.resolveComponent("el-checkbox-group");
                return vue.openBlock(), vue.createElementBlock("div", qn, [ vue.createVNode(l, {
                    class: "tips-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(i, {
                        title: "\u914d\u7f6e\u4fee\u6539\u540e\u4f1a\u81ea\u52a8\u4fdd\u5b58\uff0c\u76f4\u63a5\u5237\u65b0\u9875\u9762\u5373\u53ef\u751f\u6548",
                        type: "info",
                        closable: !1,
                        "show-icon": ""
                    }) ])),
                    _: 1
                }), vue.createVNode(l, {
                    class: "config-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ vue.createElementVNode("div", Cn, [ Tn, vue.createVNode(c, {
                        type: "success",
                        size: "small"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u81ea\u52a8\u4fdd\u5b58") ])),
                        _: 1
                    }) ]) ])),
                    default: vue.withCtx((() => [ vue.createElementVNode("div", An, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(r).display, ((e, t) => (vue.openBlock(), 
                    vue.createElementBlock("div", {
                        key: t,
                        class: "config-item"
                    }, [ vue.createElementVNode("div", Sn, [ vue.createElementVNode("div", Hn, [ vue.createElementVNode("span", Un, vue.toDisplayString(e.label), 1), e.desc ? (vue.openBlock(), 
                    vue.createBlock(u, {
                        key: 0,
                        effect: "dark",
                        content: e.desc,
                        placement: "top"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            class: "info-icon"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(de)) ])),
                            _: 1
                        }) ])),
                        _: 2
                    }, 1032, [ "content" ])) : vue.createCommentVNode("", !0) ]), vue.createElementVNode("div", En, [ "switch" === e.type ? (vue.openBlock(), 
                    vue.createBlock(d, {
                        key: 0,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        size: "large"
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "input" === e.type ? (vue.openBlock(), 
                    vue.createBlock(m, {
                        key: 1,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        style: {
                            "max-width": "300px"
                        }
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "number" === e.type ? (vue.openBlock(), 
                    vue.createBlock(h, {
                        key: 2,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        controls: !0
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "select" === e.type ? (vue.openBlock(), 
                    vue.createBlock(g, {
                        key: 3,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        placeholder: "\u8bf7\u9009\u62e9",
                        style: {
                            "min-width": "200px"
                        }
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(f, {
                            key: e.value,
                            label: e.label,
                            value: e.value
                        }, null, 8, [ "label", "value" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : "hotkey" === e.type ? (vue.openBlock(), 
                    vue.createElementBlock("div", zn, [ vue.createVNode(m, {
                        "model-value": e.value,
                        placeholder: s.value === e.name ? "\u8bf7\u6309\u4e0b\u5feb\u6377\u952e..." : "\u70b9\u51fb\u540e\u6309\u4e0b\u5feb\u6377\u952e\u7ec4\u5408",
                        readonly: "",
                        onFocus: t => startRecording(e.name),
                        onKeydown: t => handleHotkeyKeydown(t, e),
                        style: {
                            "max-width": "300px"
                        },
                        class: vue.normalizeClass({
                            recording: s.value === e.name
                        })
                    }, {
                        suffix: vue.withCtx((() => [ s.value === e.name ? (vue.openBlock(), vue.createBlock(c, {
                            key: 0,
                            type: "danger",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u5f55\u5236\u4e2d... ") ])),
                            _: 1
                        })) : (vue.openBlock(), vue.createBlock(c, {
                            key: 1,
                            type: "info",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u70b9\u51fb\u5f55\u5236 ") ])),
                            _: 1
                        })) ])),
                        _: 2
                    }, 1032, [ "model-value", "placeholder", "onFocus", "onKeydown", "class" ]) ])) : "checkbox" === e.type ? (vue.openBlock(), 
                    vue.createBlock(w, {
                        key: 5,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        class: "checkbox-group"
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(y, {
                            key: e.value,
                            label: e.value,
                            name: e.value
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                            _: 2
                        }, 1032, [ "label", "name" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : vue.createCommentVNode("", !0) ]) ]) ])))), 128)) ]) ])),
                    _: 1
                }), vue.createVNode(l, {
                    class: "config-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ vue.createElementVNode("div", $n, [ jn, vue.createVNode(c, {
                        type: "success",
                        size: "small"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u81ea\u52a8\u4fdd\u5b58") ])),
                        _: 1
                    }) ]) ])),
                    default: vue.withCtx((() => [ vue.createElementVNode("div", In, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(r).system, ((e, t) => (vue.openBlock(), 
                    vue.createElementBlock("div", {
                        key: t,
                        class: "config-item"
                    }, [ vue.createElementVNode("div", Ln, [ vue.createElementVNode("div", On, [ vue.createElementVNode("span", Fn, vue.toDisplayString(e.label), 1), e.desc ? (vue.openBlock(), 
                    vue.createBlock(u, {
                        key: 0,
                        effect: "dark",
                        content: e.desc,
                        placement: "top"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            class: "info-icon"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(de)) ])),
                            _: 1
                        }) ])),
                        _: 2
                    }, 1032, [ "content" ])) : vue.createCommentVNode("", !0) ]), vue.createElementVNode("div", Pn, [ "switch" === e.type ? (vue.openBlock(), 
                    vue.createBlock(d, {
                        key: 0,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        size: "large"
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "input" === e.type ? (vue.openBlock(), 
                    vue.createBlock(m, {
                        key: 1,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        style: {
                            "max-width": "300px"
                        }
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "number" === e.type ? (vue.openBlock(), 
                    vue.createBlock(h, {
                        key: 2,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        controls: !0
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "select" === e.type ? (vue.openBlock(), 
                    vue.createBlock(g, {
                        key: 3,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        placeholder: "\u8bf7\u9009\u62e9",
                        style: {
                            "min-width": "200px"
                        }
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(f, {
                            key: e.value,
                            label: e.label,
                            value: e.value
                        }, null, 8, [ "label", "value" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : "hotkey" === e.type ? (vue.openBlock(), 
                    vue.createElementBlock("div", Mn, [ vue.createVNode(m, {
                        "model-value": e.value,
                        placeholder: s.value === e.name ? "\u8bf7\u6309\u4e0b\u5feb\u6377\u952e..." : "\u70b9\u51fb\u540e\u6309\u4e0b\u5feb\u6377\u952e\u7ec4\u5408",
                        readonly: "",
                        onFocus: t => startRecording(e.name),
                        onKeydown: t => handleHotkeyKeydown(t, e),
                        style: {
                            "max-width": "300px"
                        },
                        class: vue.normalizeClass({
                            recording: s.value === e.name
                        })
                    }, {
                        suffix: vue.withCtx((() => [ s.value === e.name ? (vue.openBlock(), vue.createBlock(c, {
                            key: 0,
                            type: "danger",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u5f55\u5236\u4e2d... ") ])),
                            _: 1
                        })) : (vue.openBlock(), vue.createBlock(c, {
                            key: 1,
                            type: "info",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u70b9\u51fb\u5f55\u5236 ") ])),
                            _: 1
                        })) ])),
                        _: 2
                    }, 1032, [ "model-value", "placeholder", "onFocus", "onKeydown", "class" ]) ])) : "checkbox" === e.type ? (vue.openBlock(), 
                    vue.createBlock(w, {
                        key: 5,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        class: "checkbox-group"
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(y, {
                            key: e.value,
                            label: e.value,
                            name: e.value
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                            _: 2
                        }, 1032, [ "label", "name" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : vue.createCommentVNode("", !0) ]) ]) ])))), 128)) ]) ])),
                    _: 1
                }), vue.createVNode(l, {
                    class: "config-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ vue.createElementVNode("div", Vn, [ Dn, vue.createVNode(c, {
                        type: "success",
                        size: "small"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u81ea\u52a8\u4fdd\u5b58") ])),
                        _: 1
                    }) ]) ])),
                    default: vue.withCtx((() => [ vue.createElementVNode("div", Nn, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(r).ai, ((e, t) => (vue.openBlock(), 
                    vue.createElementBlock("div", {
                        key: t,
                        class: "config-item"
                    }, [ vue.createElementVNode("div", Bn, [ vue.createElementVNode("div", Gn, [ vue.createElementVNode("span", Rn, vue.toDisplayString(e.label), 1), e.desc ? (vue.openBlock(), 
                    vue.createBlock(u, {
                        key: 0,
                        effect: "dark",
                        content: e.desc,
                        placement: "top"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            class: "info-icon"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(de)) ])),
                            _: 1
                        }) ])),
                        _: 2
                    }, 1032, [ "content" ])) : vue.createCommentVNode("", !0) ]), vue.createElementVNode("div", Jn, [ "switch" === e.type ? (vue.openBlock(), 
                    vue.createBlock(d, {
                        key: 0,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        size: "large"
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "input" === e.type ? (vue.openBlock(), 
                    vue.createBlock(m, {
                        key: 1,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        style: {
                            "max-width": "300px"
                        }
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "number" === e.type ? (vue.openBlock(), 
                    vue.createBlock(h, {
                        key: 2,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        controls: !0
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "select" === e.type ? (vue.openBlock(), 
                    vue.createBlock(g, {
                        key: 3,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        placeholder: "\u8bf7\u9009\u62e9",
                        style: {
                            "min-width": "200px"
                        }
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(f, {
                            key: e.value,
                            label: e.label,
                            value: e.value
                        }, null, 8, [ "label", "value" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : "hotkey" === e.type ? (vue.openBlock(), 
                    vue.createElementBlock("div", Qn, [ vue.createVNode(m, {
                        "model-value": e.value,
                        placeholder: s.value === e.name ? "\u8bf7\u6309\u4e0b\u5feb\u6377\u952e..." : "\u70b9\u51fb\u540e\u6309\u4e0b\u5feb\u6377\u952e\u7ec4\u5408",
                        readonly: "",
                        onFocus: t => startRecording(e.name),
                        onKeydown: t => handleHotkeyKeydown(t, e),
                        style: {
                            "max-width": "300px"
                        },
                        class: vue.normalizeClass({
                            recording: s.value === e.name
                        })
                    }, {
                        suffix: vue.withCtx((() => [ s.value === e.name ? (vue.openBlock(), vue.createBlock(c, {
                            key: 0,
                            type: "danger",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u5f55\u5236\u4e2d... ") ])),
                            _: 1
                        })) : (vue.openBlock(), vue.createBlock(c, {
                            key: 1,
                            type: "info",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u70b9\u51fb\u5f55\u5236 ") ])),
                            _: 1
                        })) ])),
                        _: 2
                    }, 1032, [ "model-value", "placeholder", "onFocus", "onKeydown", "class" ]) ])) : "checkbox" === e.type ? (vue.openBlock(), 
                    vue.createBlock(w, {
                        key: 5,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        class: "checkbox-group"
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(y, {
                            key: e.value,
                            label: e.value,
                            name: e.value
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                            _: 2
                        }, 1032, [ "label", "name" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : vue.createCommentVNode("", !0) ]) ]) ])))), 128)) ]) ])),
                    _: 1
                }), vue.createVNode(l, {
                    class: "config-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ vue.createElementVNode("div", Wn, [ Kn, vue.createVNode(c, {
                        type: "success",
                        size: "small"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u81ea\u52a8\u4fdd\u5b58") ])),
                        _: 1
                    }) ]) ])),
                    default: vue.withCtx((() => [ vue.createElementVNode("div", Yn, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(r).hotkey, ((e, t) => (vue.openBlock(), 
                    vue.createElementBlock("div", {
                        key: t,
                        class: "config-item"
                    }, [ vue.createElementVNode("div", Xn, [ vue.createElementVNode("div", Zn, [ vue.createElementVNode("span", ea, vue.toDisplayString(e.label), 1), e.desc ? (vue.openBlock(), 
                    vue.createBlock(u, {
                        key: 0,
                        effect: "dark",
                        content: e.desc,
                        placement: "top"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            class: "info-icon"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(de)) ])),
                            _: 1
                        }) ])),
                        _: 2
                    }, 1032, [ "content" ])) : vue.createCommentVNode("", !0) ]), vue.createElementVNode("div", ta, [ "switch" === e.type ? (vue.openBlock(), 
                    vue.createBlock(d, {
                        key: 0,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        size: "large"
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "input" === e.type ? (vue.openBlock(), 
                    vue.createBlock(m, {
                        key: 1,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        style: {
                            "max-width": "300px"
                        }
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "number" === e.type ? (vue.openBlock(), 
                    vue.createBlock(h, {
                        key: 2,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        controls: !0
                    }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : "select" === e.type ? (vue.openBlock(), 
                    vue.createBlock(g, {
                        key: 3,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        placeholder: "\u8bf7\u9009\u62e9",
                        style: {
                            "min-width": "200px"
                        }
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(f, {
                            key: e.value,
                            label: e.label,
                            value: e.value
                        }, null, 8, [ "label", "value" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : "hotkey" === e.type ? (vue.openBlock(), 
                    vue.createElementBlock("div", na, [ vue.createVNode(m, {
                        "model-value": e.value,
                        placeholder: s.value === e.name ? "\u8bf7\u6309\u4e0b\u5feb\u6377\u952e..." : "\u70b9\u51fb\u540e\u6309\u4e0b\u5feb\u6377\u952e\u7ec4\u5408",
                        readonly: "",
                        onFocus: t => startRecording(e.name),
                        onKeydown: t => handleHotkeyKeydown(t, e),
                        style: {
                            "max-width": "300px"
                        },
                        class: vue.normalizeClass({
                            recording: s.value === e.name
                        })
                    }, {
                        suffix: vue.withCtx((() => [ s.value === e.name ? (vue.openBlock(), vue.createBlock(c, {
                            key: 0,
                            type: "danger",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u5f55\u5236\u4e2d... ") ])),
                            _: 1
                        })) : (vue.openBlock(), vue.createBlock(c, {
                            key: 1,
                            type: "info",
                            size: "small"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u70b9\u51fb\u5f55\u5236 ") ])),
                            _: 1
                        })) ])),
                        _: 2
                    }, 1032, [ "model-value", "placeholder", "onFocus", "onKeydown", "class" ]) ])) : "checkbox" === e.type ? (vue.openBlock(), 
                    vue.createBlock(w, {
                        key: 5,
                        modelValue: e.value,
                        "onUpdate:modelValue": t => e.value = t,
                        class: "checkbox-group"
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, (e => (vue.openBlock(), vue.createBlock(y, {
                            key: e.value,
                            label: e.value,
                            name: e.value
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                            _: 2
                        }, 1032, [ "label", "name" ])))), 128)) ])),
                        _: 2
                    }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : vue.createCommentVNode("", !0) ]) ]) ])))), 128)) ]) ])),
                    _: 1
                }) ]);
            };
        }
    }), oa = [ "innerHTML" ], sa = [ "innerHTML" ], ia = vue.createElementVNode("div", {
        class: "aah_bomHet50"
    }, [ vue.createElementVNode("span", {
        class: "dq"
    }, [ vue.createElementVNode("i"), vue.createTextVNode("\u5f53\u524d\u9898\u76ee") ]), vue.createElementVNode("span", {
        class: "yp"
    }, [ vue.createElementVNode("i"), vue.createTextVNode("\u5df2\u4f5c\u7b54") ]), vue.createElementVNode("span", {
        class: "wp"
    }, [ vue.createElementVNode("i"), vue.createTextVNode("\u65e0\u7b54\u6848") ]), vue.createElementVNode("span", {
        class: "zp"
    }, [ vue.createElementVNode("i"), vue.createTextVNode("\u672a\u4f5c\u7b54") ]) ], -1), ra = [ "innerHTML" ], la = [ "innerHTML" ], ca = {
        key: 0
    }, pa = {
        style: {
            width: "100%"
        }
    }, ua = [ "innerHTML" ], da = [ "value" ], ma = {
        key: 1,
        style: {
            color: "green"
        }
    }, ha = {
        key: 2,
        style: {
            color: "red"
        }
    }, fa = {
        key: 0
    }, ga = {
        key: 1
    }, ya = {
        key: 0
    }, wa = [ "innerHTML" ], va = [ "innerHTML" ], ba = {
        key: 0
    }, xa = [ "innerHTML" ], _a = vue.defineComponent({
        __name: "Ask",
        setup(e) {
            const t = rn(), s = tn(), getOptionIndex = e => String.fromCharCode(65 + e), formatTooltip = e => `\u7b54\u9898\u95f4\u9694\uff1a${e}ms`;
            vue.watch(s.app, (e => {
                s.setConfig(e);
            }));
            const watchAutoNext = () => {
                Cache.set("autoNext", t.autoNext);
            }, watchSkipFinish = () => {
                Cache.set("skipFinish", t.skipFinish);
            }, watchAutoAnswer = () => {
                Cache.set("autoAnswer", t.autoAnswer);
            }, watchRandomAnswer = () => {
                Cache.set("randomAnswer", t.randomAnswer);
            }, watchAskGpt = () => {
                msg("\u8bf7\u5148\u53bbAI\u641c\u9898\u9875\u9762\u6d4b\u8bd5AI\u662f\u5426\u53ef\u7528\uff0c\u518d\u542f\u7528\u7b54\u9898\uff0c\u7b54\u9898\u6b63\u786e\u7387\u65e0\u6cd5\u4fdd\u8bc1"), 
                Cache.set("askGpt", s.app.askGpt);
            }, watchDelay = () => {
                Cache.set("delay", t.delay);
            };
            return (e, i) => {
                const r = vue.resolveComponent("el-popover"), l = vue.resolveComponent("el-alert"), c = vue.resolveComponent("el-button"), p = vue.resolveComponent("el-col"), u = vue.resolveComponent("el-checkbox"), d = vue.resolveComponent("el-tooltip"), m = vue.resolveComponent("el-slider"), h = vue.resolveComponent("el-form-item"), f = vue.resolveComponent("el-form"), g = vue.resolveComponent("el-tag"), y = vue.resolveComponent("el-divider"), w = vue.resolveComponent("el-input"), v = vue.resolveComponent("el-link"), U = vue.resolveComponent("el-row"), I = vue.resolveComponent("el-empty"), L = vue.resolveDirective("loading");
                return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [ vue.createVNode(l, {
                    style: {
                        "margin-bottom": "10px"
                    },
                    type: "info",
                    closable: !1
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(r, {
                        placement: "bottom",
                        title: "\u652f\u6301\u7684\u9898\u578b",
                        trigger: "hover"
                    }, {
                        default: vue.withCtx((() => [ vue.createElementVNode("div", {
                            innerHTML: vue.unref(t).typesMd
                        }, null, 8, oa) ])),
                        reference: vue.withCtx((() => [ vue.createElementVNode("div", {
                            innerHTML: vue.unref(t).tipsMd
                        }, null, 8, sa) ])),
                        _: 1
                    }) ])),
                    _: 1
                }), vue.createVNode(U, null, {
                    default: vue.withCtx((() => [ vue.unref(t).current ? (vue.openBlock(), vue.createBlock(p, {
                        key: 0,
                        span: 12
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(c, {
                            onClick: i[0] || (i[0] = e => vue.unref(t).start ? vue.unref(t).pause() : vue.unref(t).toggleStart()),
                            size: "small",
                            class: "aah_btn",
                            type: "primary",
                            plain: ""
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(vue.unref(t).start ? "\u6682\u505c\u7b54\u9898" : "\u5f00\u59cb\u7b54\u9898"), 1) ])),
                            _: 1
                        }) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.unref(t).current ? (vue.openBlock(), vue.createBlock(p, {
                        key: 1,
                        span: 12
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(c, {
                            onClick: i[1] || (i[1] = e => vue.unref(t).restart()),
                            size: "small",
                            class: "aah_btn",
                            type: "primary",
                            plain: ""
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u91cd\u65b0\u7b54\u9898") ])),
                            _: 1
                        }) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.unref(t).current ? (vue.openBlock(), vue.createBlock(p, {
                        key: 2,
                        span: 24
                    }, {
                        default: vue.withCtx((() => [ ia ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.unref(t).current ? (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, {
                        key: 3
                    }, vue.renderList(vue.unref(t).questionList, ((e, a) => (vue.openBlock(), vue.createBlock(p, {
                        span: 3
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(), vue.createBlock(c, {
                            class: vue.normalizeClass(a == vue.unref(t).questionInx ? "aah_active" : ""),
                            style: {
                                width: "30px",
                                "margin-bottom": "4px"
                            },
                            key: a,
                            onClick: e => vue.unref(t).toQuestion(a),
                            size: "small",
                            type: 1 == e.status ? "primary" : 2 == e.status ? "danger" : "",
                            plain: ""
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(a + 1), 1) ])),
                            _: 2
                        }, 1032, [ "class", "onClick", "type" ])) ])),
                        _: 2
                    }, 1024)))), 256)) : vue.createCommentVNode("", !0), vue.createVNode(p, {
                        span: 24
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(f, {
                            "label-width": "auto"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(u, {
                                onChange: watchSkipFinish,
                                modelValue: vue.unref(t).skipFinish,
                                "onUpdate:modelValue": i[2] || (i[2] = e => vue.unref(t).skipFinish = e),
                                label: "\u8df3\u8fc7\u5df2\u4f5c\u7b54"
                            }, null, 8, [ "modelValue" ]), vue.createVNode(u, {
                                onChange: watchAutoAnswer,
                                modelValue: vue.unref(t).autoAnswer,
                                "onUpdate:modelValue": i[3] || (i[3] = e => vue.unref(t).autoAnswer = e),
                                label: "\u81ea\u52a8\u7b54\u9898"
                            }, null, 8, [ "modelValue" ]), vue.createVNode(u, {
                                onChange: watchAutoNext,
                                modelValue: vue.unref(t).autoNext,
                                "onUpdate:modelValue": i[4] || (i[4] = e => vue.unref(t).autoNext = e),
                                label: "\u81ea\u52a8\u8df3\u8f6c"
                            }, null, 8, [ "modelValue" ]), vue.createVNode(u, {
                                onChange: watchRandomAnswer,
                                modelValue: vue.unref(t).randomAnswer,
                                "onUpdate:modelValue": i[5] || (i[5] = e => vue.unref(t).randomAnswer = e),
                                label: "\u65e0\u7b54\u6848\u968f\u673a\u7b54\u9898"
                            }, null, 8, [ "modelValue" ]), vue.createVNode(d, {
                                class: "box-item",
                                effect: "dark",
                                content: "AI\u65e0\u6cd5\u4fdd\u8bc1\u6b63\u786e\u7387\uff0c\u4e14\u4e0d\u540c\u6a21\u578b\u6548\u679c\u4e5f\u5404\u4e0d\u76f8\u540c\uff0c\u8bf7\u81ea\u884c\u5224\u65ad\u662f\u5426\u542f\u7528",
                                placement: "top-start"
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(u, {
                                    onChange: watchAskGpt,
                                    modelValue: vue.unref(s).app.askGpt,
                                    "onUpdate:modelValue": i[6] || (i[6] = e => vue.unref(s).app.askGpt = e),
                                    label: "\u4f7f\u7528AI\u8f85\u52a9\u7b54\u9898"
                                }, null, 8, [ "modelValue" ]) ])),
                                _: 1
                            }), vue.unref(t).minDelay > 0 ? (vue.openBlock(), vue.createBlock(l, {
                                key: 0,
                                type: "warning",
                                closable: !1
                            }, {
                                title: vue.withCtx((() => [ vue.createElementVNode("span", null, "\u7531\u4e8e\u89c4\u5219\u9650\u5236\uff0c\u5f53\u524d\u5e73\u53f0\u7b54\u9898\u95f4\u9694\u6700\u5c0f\u4e3a" + vue.toDisplayString(vue.unref(t).minDelay) + "ms", 1) ])),
                                _: 1
                            })) : vue.createCommentVNode("", !0), vue.createVNode(h, {
                                label: "\u95f4\u9694"
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(m, {
                                    onChange: watchDelay,
                                    modelValue: vue.unref(t).delay,
                                    "onUpdate:modelValue": i[7] || (i[7] = e => vue.unref(t).delay = e),
                                    max: 5e3,
                                    min: vue.unref(t).minDelay,
                                    "format-tooltip": formatTooltip
                                }, null, 8, [ "modelValue", "min" ]) ])),
                                _: 1
                            }) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }), vue.unref(t).formMap ? (vue.openBlock(), vue.createBlock(p, {
                        key: 4,
                        span: 24
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t).formMap, ((e, t) => (vue.openBlock(), vue.createBlock(g, {
                            key: t,
                            style: {
                                "margin-right": "10px"
                            }
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(t) + ":" + vue.toDisplayString(e) + " \u6b21", 1) ])),
                            _: 2
                        }, 1024)))), 128)) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.unref(t).current ? (vue.openBlock(), vue.createBlock(y, {
                        key: 5
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(c, {
                            onClick: i[8] || (i[8] = e => vue.unref(t).reAnswer(vue.unref(t).questionInx)),
                            style: {
                                color: "red",
                                "font-size": "10px"
                            },
                            link: ""
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u91cd\u7b54") ])),
                            _: 1
                        }), vue.createVNode(y, {
                            direction: "vertical"
                        }), vue.createVNode(c, {
                            onClick: i[9] || (i[9] = e => vue.unref(t).aiAnswer(vue.unref(t).questionInx)),
                            style: {
                                color: "red",
                                "font-size": "10px"
                            },
                            link: ""
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("AI\u7b54\u9898") ])),
                            _: 1
                        }) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.unref(t).current ? (vue.openBlock(), vue.createBlock(p, {
                        key: 6,
                        span: 24
                    }, {
                        default: vue.withCtx((() => [ vue.createElementVNode("div", {
                            class: "aah_title",
                            innerHTML: "[" + vue.unref(typeConvert)(vue.unref(t).current.type ?? "", !1) + "]" + vue.unref(t).current.question
                        }, null, 8, ra), (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t).current.options, ((e, o) => (vue.openBlock(), vue.createElementBlock("p", {
                            style: vue.normalizeStyle(vue.unref(t).current.form && vue.unref(t).current.form.match && vue.unref(t).current.form.match.includes(o) ? "color:green;" : ""),
                            class: "aah_options",
                            innerHTML: getOptionIndex(o) + ". " + e
                        }, null, 12, la)))), 256)), "24" == vue.unref(t).current.type ? (vue.openBlock(), vue.createElementBlock("p", ca, [ vue.createElementVNode("table", pa, [ (vue.openBlock(!0), 
                        vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t).current.match, ((e, s) => (vue.openBlock(), vue.createElementBlock("tr", null, [ vue.createElementVNode("td", {
                            innerHTML: e
                        }, null, 8, ua), vue.createElementVNode("td", null, [ vue.createElementVNode("select", null, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t).current.selects[s], (e => (vue.openBlock(), 
                        vue.createElementBlock("option", {
                            value: e.value
                        }, vue.toDisplayString(e.text), 9, da)))), 256)) ]) ]) ])))), 256)) ]) ])) : vue.createCommentVNode("", !0), vue.unref(t).current.form ? (vue.openBlock(), 
                        vue.createElementBlock("p", ma, " \u91c7\u7528\u3010" + vue.toDisplayString(vue.unref(t).current.form.form) + "\u3011\u7684\u7b54\u6848 ", 1)) : vue.createCommentVNode("", !0), "8" == vue.unref(t).current.type || null == vue.unref(t).current.type || "" == vue.unref(t).current.type ? (vue.openBlock(), 
                        vue.createElementBlock("p", ha, " \u5f53\u524d\u9898\u578b\u6682\u4e0d\u652f\u6301\uff0c\u8bf7\u53cd\u9988\u7ed9\u4f5c\u8005\u5427 ")) : vue.createCommentVNode("", !0) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.unref(t).current ? vue.withDirectives((vue.openBlock(), vue.createBlock(p, {
                        key: 7,
                        span: 24,
                        "element-loading-text": vue.unref(t).loadingText
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t).current.answer, (e => (vue.openBlock(), vue.createElementBlock("div", null, [ vue.createVNode(y, null, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(`${e.form}(${e.duration}ms)`), 1) ])),
                            _: 2
                        }, 1024), "object" == typeof e.answer ? (vue.openBlock(), vue.createElementBlock("div", fa, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.answer, (e => (vue.openBlock(), 
                        vue.createElementBlock("p", null, [ vue.createVNode(w, {
                            value: e,
                            readonly: "",
                            style: {
                                width: "100%"
                            }
                        }, null, 8, [ "value" ]) ])))), 256)) ])) : (vue.openBlock(), vue.createElementBlock("div", ga, [ e.needLogin ? (vue.openBlock(), 
                        vue.createElementBlock("div", ya, [ vue.createElementVNode("span", {
                            innerHTML: e.msg
                        }, null, 8, wa), vue.createVNode(v, {
                            type: "primary",
                            onClick: i[10] || (i[10] = e => vue.unref(s).setPage("user")),
                            style: {
                                "margin-left": "8px"
                            }
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u70b9\u51fb\u767b\u5f55 ") ])),
                            _: 1
                        }) ])) : (vue.openBlock(), vue.createElementBlock("div", {
                            key: 1,
                            innerHTML: e.answer ? e.answer : e.msg ?? "\u6682\u65e0\u7b54\u6848"
                        }, null, 8, va)) ])) ])))), 256)), vue.unref(t).current.aiMsg ? (vue.openBlock(), vue.createElementBlock("div", ba, [ vue.createVNode(y, null, {
                            default: vue.withCtx((() => [ vue.createTextVNode("AI\u56de\u7b54(\u4ec5\u4f9b\u53c2\u8003)") ])),
                            _: 1
                        }), vue.createElementVNode("div", {
                            innerHTML: vue.unref(t).currentAiMd
                        }, null, 8, xa) ])) : vue.createCommentVNode("", !0) ])),
                        _: 1
                    }, 8, [ "element-loading-text" ])), [ [ L, vue.unref(t).loading ] ]) : vue.createCommentVNode("", !0) ])),
                    _: 1
                }), vue.unref(t).current ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createBlock(I, {
                    key: 0,
                    description: "\u6682\u65e0\u9898\u76ee\u6570\u636e"
                })) ], 64);
            };
        }
    }), ka = vue.createElementVNode("br", null, null, -1), qa = vue.createElementVNode("br", null, null, -1), Ca = vue.createElementVNode("p", {
        style: {
            color: "red"
        }
    }, "\u4e14\u5e76\u975e\u6240\u6709\u7f51\u7ad9\u90fd\u652f\u6301\uff0c\u9700\u8981\u4f5c\u8005\u9002\u914d\uff0c\u82e5\u60a8\u7684\u5e73\u53f0\u4e0d\u652f\u6301\u53ef\u4ee5\u53cd\u9988\u7ed9\u4f5c\u8005", -1), Ta = vue.createElementVNode("div", {
        class: "el-upload__text"
    }, [ vue.createTextVNode(" \u62d6\u62fd\u5907\u4efd\u6587\u4ef6\u6216 "), vue.createElementVNode("em", null, "\u70b9\u51fb\u4e0a\u4f20"), vue.createTextVNode("\u6062\u590d\u5907\u4efd ") ], -1), Aa = {
        style: {
            "margin-top": "20px",
            "margin-bottom": "20px"
        }
    }, Sa = [ "innerHTML" ], Ha = [ "innerHTML" ], Ua = [ "innerHTML" ], Ea = vue.defineComponent({
        __name: "Question",
        setup(e) {
            const t = vue.ref(0);
            let s;
            window.addEventListener("keydown", (e => {
                "`" === e.key && t.value++;
            }));
            try {
                Yt.script, s = Yt.script.updateURL.match(/scripts\/(\d+)/)[1];
            } catch (p) {
                s = "492563";
            }
            const r = `https://greasyfork.org/zh-CN/scripts/${s}`, l = rn(), c = Cache.match("ques1_"), clearCache = () => {
                Cache.matchRemove("ques1_"), msg("\u6e05\u9664\u6210\u529f", "success");
            }, exportHtml = async e => {
                const t = e.map(((e, t) => {
                    return `\n        <p><a href="${r}">\u7231\u95ee\u7b54\u52a9\u624b</a></p>\n        <p>${t + 1}\u3001[${typeConvert(e.type, !1)}]${e.question}</p>\n        <p>${n = e.options, 
                "object" != typeof n ? "" : n.map(((e, t) => String.fromCharCode(65 + t) + "." + e)).join("<br>")}</p>\n        <p style="color:green;">\u7b54\u6848\uff1a${answerFormat(e.answer)}</p>\n        \n        `;
                    var n;
                })).join("<br/>"), n = new Blob([ `<HtML> <head> <meta charset="utf-8"> <title>\u7231\u95ee\u7b54\u52a9\u624b\u7b54\u6848\u5bfc\u51fa</title> </head> <body> ${t} </body> </HtML>` ], {
                    type: "text/html"
                }), a = document.createElement("a");
                a.href = URL.createObjectURL(n), a.download = "\u7231\u95ee\u7b54\u52a9\u624b.html", 
                a.click();
            }, exportData = async () => {
                try {
                    const e = Cache.matchGet("ques1_") || [];
                    if (0 === e.length) return void msg("\u6682\u65e0\u9898\u76ee\u53ef\u5bfc\u51fa", "warning");
                    msg(`\u6b63\u5728\u6253\u5305${e.length}\u9898\uff0c\u8bf7\u7a0d\u540e...`, "info");
                    const t = await encrypt(JSON.stringify(e));
                    if (!t) return void msg("\u52a0\u5bc6\u5931\u8d25\uff0c\u8bf7\u91cd\u8bd5\u6216\u8054\u7cfb\u5f00\u53d1\u8005", "error");
                    const n = new Blob([ t ], {
                        type: "application/text"
                    });
                    msg(`\u6253\u5305\u5b8c\u6210\uff0c\u5171\u8ba1${e.length}\u9898\uff0c\u51c6\u5907\u4e0b\u8f7d`, "success");
                    const a = document.createElement("a");
                    a.href = URL.createObjectURL(n);
                    const o = (new Date).toLocaleDateString().replace(/\//g, "-");
                    a.download = `\u7231\u95ee\u7b54\u52a9\u624b\u5907\u4efd-${o}.bak`, a.click(), setTimeout((() => URL.revokeObjectURL(a.href)), 100);
                } catch (e) {
                    msg(`\u5bfc\u51fa\u5931\u8d25\uff1a${e}`, "error");
                }
            }, exportDocx = async () => {
                exportHtml(l.saveQuestionData);
            }, exportDocx1 = async () => {
                const e = Cache.matchGet("ques1_") || [];
                exportHtml(e);
            }, changeT = e => typeConvert(e.type, !1), answerFormat = e => Array.isArray(e) ? e.join("<br/>") : "string" == typeof e ? e : "object" == typeof e ? JSON.stringify(e) : e, beforeUpload = e => {
                const t = new FileReader;
                return t.onload = async e => {
                    var t;
                    const n = null == (t = e.target) ? void 0 : t.result;
                    try {
                        const e = JSON.parse(await decrypt(n));
                        e.forEach((e => {
                            Answer.cacheAnswer(e);
                        })), msg(`\u9898\u5e93\u5bfc\u5165\u6210\u529f\uff0c\u5171\u8ba1${e.length}\u9898\n            \u8fc7\u591a\u9898\u76ee\u5bfc\u5165\u540e\u9875\u9762\u4f1a\u5361\u4e3b\u8bf7\u76f4\u63a5\u5173\u95ed\u9875\u9762\u91cd\u65b0\u6253\u5f00`, "success");
                    } catch (a) {
                        msg("\u6587\u4ef6\u683c\u5f0f\u9519\u8bef", "error");
                    }
                }, t.readAsText(e), !1;
            };
            return (e, s) => {
                const i = vue.resolveComponent("el-alert"), r = vue.resolveComponent("el-statistic"), p = vue.resolveComponent("el-col"), u = vue.resolveComponent("el-row"), d = vue.resolveComponent("el-upload"), m = vue.resolveComponent("el-button"), h = vue.resolveComponent("el-popconfirm"), f = vue.resolveComponent("el-table-column"), g = vue.resolveComponent("el-table"), y = vue.resolveComponent("el-watermark");
                return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [ vue.createVNode(i, {
                    type: "info",
                    closable: !1
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" \u672c\u811a\u672c\u652f\u6301\u5c06\u5b58\u5728\u7b54\u6848\u7684\u9898\u76ee\u6536\u5f55\u5230\u672c\u5730\uff0c\u4ee5\u4f9b\u540e\u7eed\u7b54\u9898\u68c0\u7d22\uff0c\u53ef\u51cf\u5c11\u63a5\u53e3\u8bf7\u6c42\u6b21\u6570\uff0c\u4ee5\u53ca\u63d0\u9ad8\u7b54\u6848\u6b63\u786e\u7387"), ka, vue.createTextVNode(" \u5728\u652f\u6301\u91cd\u590d\u7b54\u9898\u4e14\u7b54\u5b8c\u9898\u663e\u793a\u7b54\u6848\u7684\u60c5\u51b5\u4e0b\u53ef\u4ee5\u65e0\u9700\u4f7f\u7528\u63a5\u53e3\u641c\u7d22\u7b54\u6848"), qa, Ca ])),
                    _: 1
                }), vue.createVNode(y, {
                    content: [ "\u7231\u95ee\u7b54\u52a9\u624b", "AiAskHelper" ]
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(u, {
                        style: {
                            "margin-top": "20px",
                            "margin-bottom": "20px"
                        }
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            span: 24
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(r, {
                                title: "\u7f13\u5b58\u9898\u76ee\u6570\u91cf",
                                value: vue.unref(c).length
                            }, null, 8, [ "value" ]) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }), vue.createVNode(d, {
                        drag: "",
                        accept: ".bak",
                        "show-file-list": !1,
                        "before-upload": beforeUpload,
                        class: "mb-4"
                    }, {
                        tip: vue.withCtx((() => [])),
                        default: vue.withCtx((() => [ Ta ])),
                        _: 1
                    }), vue.createElementVNode("div", Aa, [ vue.createVNode(h, {
                        title: "\u786e\u5b9a\u8981\u6e05\u7a7a\u672c\u5730\u7f13\u5b58\u5417\uff1f",
                        "confirm-button-text": "\u786e\u5b9a",
                        "cancel-button-text": "\u53d6\u6d88",
                        onConfirm: clearCache,
                        "hide-after": 0
                    }, {
                        reference: vue.withCtx((() => [ vue.createVNode(m, {
                            type: "danger"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u6e05\u9664\u7f13\u5b58") ])),
                            _: 1
                        }) ])),
                        _: 1
                    }), vue.createVNode(m, {
                        type: "primary",
                        onClick: exportData
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u5bfc\u51fa\u5907\u4efd") ])),
                        _: 1
                    }) ]), t.value > 10 ? (vue.openBlock(), vue.createBlock(m, {
                        key: 0,
                        type: "primary",
                        onClick: exportDocx
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u5bfc\u51fa\u5f53\u524d") ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), t.value > 10 ? (vue.openBlock(), vue.createBlock(m, {
                        key: 1,
                        type: "primary",
                        onClick: exportDocx1
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u5bfc\u51fa\u6240\u6709") ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), vue.createVNode(g, {
                        data: vue.unref(l).saveQuestionData,
                        style: {
                            width: "100%"
                        },
                        "empty-text": "\u5f53\u524d\u9875\u6682\u65e0\u6570\u636e"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(f, {
                            prop: "type",
                            label: "\u9898\u578b",
                            formatter: changeT
                        }), vue.createVNode(f, {
                            prop: "question",
                            label: "\u9898\u76ee"
                        }, {
                            default: vue.withCtx((e => [ vue.createElementVNode("div", {
                                innerHTML: e.row.question
                            }, null, 8, Sa) ])),
                            _: 1
                        }), vue.createVNode(f, {
                            prop: "options",
                            label: "\u9009\u9879"
                        }, {
                            default: vue.withCtx((e => [ vue.createElementVNode("div", {
                                innerHTML: e.row.options.join("<br/>")
                            }, null, 8, Ha) ])),
                            _: 1
                        }), vue.createVNode(f, {
                            prop: "answer",
                            label: "\u7b54\u6848"
                        }, {
                            default: vue.withCtx((e => [ vue.createElementVNode("div", {
                                innerHTML: answerFormat(e.row.answer)
                            }, null, 8, Ua) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }, 8, [ "data" ]) ])),
                    _: 1
                }) ], 64);
            };
        }
    }), za = {
        class: "flex justify-right mt-4 mr-10"
    }, $a = vue.defineComponent({
        __name: "QuestionEdit",
        props: {
            ques: {},
            visible: {
                type: Boolean
            }
        },
        emits: [ "handleClose" ],
        setup(e, {emit: t}) {
            const s = e, r = vue.ref(s.visible);
            vue.watch((() => s.visible), (e => {
                r.value = e;
            }));
            const l = t, handleClose = e => {
                l("handleClose"), e();
            }, handleCancel = () => {
                handleClose((() => {
                    r.value = !1;
                }));
            }, handleSave = () => {
                Answer.cacheAnswer(s.ques), Cache.matchRemove(s.ques.key), msg("\u9898\u76ee\u4fee\u6539\u6210\u529f", "success"), 
                handleClose((() => {
                    r.value = !1;
                }));
            }, handleDelete = e => {
                s.ques.options.splice(e, 1), s.ques.answer.includes(s.ques.options[e]) && (s.ques.answer = s.ques.answer.filter((t => t !== s.ques.options[e])));
            }, handleAdd = () => {
                s.ques.options.push("");
            };
            return (e, t) => {
                var i;
                const l = vue.resolveComponent("el-option"), c = vue.resolveComponent("el-select"), p = vue.resolveComponent("el-form-item"), u = vue.resolveComponent("el-input"), d = vue.resolveComponent("el-button"), m = vue.resolveComponent("el-form"), h = vue.resolveComponent("el-dialog");
                return vue.openBlock(), vue.createBlock(h, {
                    modelValue: r.value,
                    "onUpdate:modelValue": t[2] || (t[2] = e => r.value = e),
                    title: `\u9898\u76ee\u7f16\u8f91:[${null == (i = e.ques) ? void 0 : i.type}]`,
                    width: "90%",
                    style: {
                        "max-width": "600px"
                    },
                    "before-close": handleClose
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(m, null, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            label: "\u9898\u578b"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(c, {
                                modelValue: e.ques.type,
                                "onUpdate:modelValue": t[0] || (t[0] = t => e.ques.type = t),
                                placeholder: "\u8bf7\u9009\u62e9"
                            }, {
                                default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(Wt), ((e, t) => (vue.openBlock(), vue.createBlock(l, {
                                    key: e,
                                    label: t,
                                    value: e
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(t), 1) ])),
                                    _: 2
                                }, 1032, [ "label", "value" ])))), 128)) ])),
                                _: 1
                            }, 8, [ "modelValue" ]) ])),
                            _: 1
                        }), vue.createVNode(p, {
                            label: "\u9898\u5e72"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(u, {
                                modelValue: e.ques.question,
                                "onUpdate:modelValue": t[1] || (t[1] = t => e.ques.question = t),
                                type: "textarea",
                                autosize: {
                                    minRows: 3,
                                    maxRows: 8
                                }
                            }, null, 8, [ "modelValue" ]) ])),
                            _: 1
                        }), e.ques.options && Array.isArray(e.ques.options) && e.ques.options.length > 0 ? (vue.openBlock(), 
                        vue.createBlock(p, {
                            key: 0,
                            label: "\u9009\u9879"
                        }, {
                            default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.ques.options, ((t, o) => (vue.openBlock(), vue.createElementBlock("div", {
                                key: o,
                                class: "flex mb-4 w-[90%] items-center space-x-2"
                            }, [ vue.createVNode(d, {
                                type: "primary",
                                circle: "",
                                style: {
                                    "flex-shrink": "0"
                                },
                                plain: !e.ques.answer.includes(t),
                                onClick: e => (e => {
                                    s.ques.answer = s.ques.answer.includes(e) ? s.ques.answer.filter((t => t !== e)) : [ ...s.ques.answer, e ], 
                                    s.ques.answer.sort(((e, t) => s.ques.options.indexOf(e) - s.ques.options.indexOf(t)));
                                })(t)
                            }, {
                                default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(String.fromCharCode(65 + o)), 1) ])),
                                _: 2
                            }, 1032, [ "plain", "onClick" ]), vue.createVNode(u, {
                                modelValue: e.ques.options[o],
                                "onUpdate:modelValue": t => e.ques.options[o] = t,
                                class: "option-input flex-grow"
                            }, null, 8, [ "modelValue", "onUpdate:modelValue" ]), vue.createVNode(d, {
                                size: "small",
                                type: 0 == o ? "success" : "danger",
                                icon: vue.unref(0 != o ? ce : ue),
                                circle: "",
                                plain: "",
                                onClick: e => 0 != o ? handleDelete(o) : handleAdd()
                            }, null, 8, [ "type", "icon", "onClick" ]) ])))), 128)) ])),
                            _: 1
                        })) : Array.isArray(e.ques.answer) && 0 == e.ques.options.length ? (vue.openBlock(), vue.createBlock(p, {
                            key: 1,
                            label: "\u7b54\u6848"
                        }, {
                            default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.ques.answer, ((t, o) => (vue.openBlock(), vue.createElementBlock("div", {
                                key: o,
                                class: "flex mb-4 w-[90%] items-center space-x-2"
                            }, [ vue.createVNode(u, {
                                modelValue: e.ques.answer[o],
                                "onUpdate:modelValue": t => e.ques.answer[o] = t,
                                class: "option-input flex-grow"
                            }, null, 8, [ "modelValue", "onUpdate:modelValue" ]), vue.createVNode(d, {
                                size: "small",
                                type: 0 == o ? "success" : "danger",
                                icon: vue.unref(0 != o ? ce : ue),
                                circle: "",
                                plain: "",
                                onClick: e => 0 != o ? handleDelete(o) : handleAdd()
                            }, null, 8, [ "type", "icon", "onClick" ]) ])))), 128)) ])),
                            _: 1
                        })) : vue.createCommentVNode("", !0), vue.createElementVNode("div", za, [ vue.createVNode(d, {
                            type: "danger",
                            onClick: handleCancel
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u53d6\u6d88") ])),
                            _: 1
                        }), vue.createVNode(d, {
                            type: "primary",
                            onClick: handleSave
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u4fdd\u5b58") ])),
                            _: 1
                        }) ]) ])),
                        _: 1
                    }) ])),
                    _: 1
                }, 8, [ "modelValue", "title" ]);
            };
        }
    }), ja = {
        class: "preview-container"
    }, Ia = {
        class: "preview-header"
    }, La = {
        class: "header-content"
    }, Oa = vue.createElementVNode("div", {
        class: "header-title"
    }, [ vue.createElementVNode("h2", null, "\ud83d\udcda \u672c\u5730\u9898\u5e93"), vue.createElementVNode("p", null, "\u667a\u80fd\u641c\u7d22 \xb7 \u5feb\u901f\u9884\u89c8 \xb7 \u4fbf\u6377\u7ba1\u7406") ], -1), Fa = {
        class: "header-stats"
    }, Pa = {
        class: "stat-item"
    }, Ma = {
        class: "stat-number"
    }, Va = vue.createElementVNode("span", {
        class: "stat-label"
    }, "\u9898\u76ee\u603b\u6570", -1), Da = vue.createElementVNode("div", {
        class: "stat-divider"
    }, null, -1), Na = {
        class: "stat-item"
    }, Ba = {
        class: "stat-number"
    }, Ga = vue.createElementVNode("span", {
        class: "stat-label"
    }, "\u5f53\u524d\u9875\u7801", -1), Ra = vue.createElementVNode("span", {
        style: {
            color: "#f59e0b",
            "margin-left": "8px"
        }
    }, "\ud83d\udca1 \u70b9\u51fb\u9898\u76ee\u5361\u7247\u53ef\u67e5\u770b\u8be6\u60c5", -1), Ja = {
        class: "search-section"
    }, Qa = {
        key: 0,
        class: "search-result-info"
    }, Wa = {
        key: 0,
        class: "empty-state"
    }, Ka = vue.createElementVNode("div", {
        class: "empty-icon"
    }, "\ud83d\udcdd", -1), Ya = {
        key: 1,
        class: "questions-list"
    }, Xa = {
        class: "question-item-card"
    }, Za = {
        class: "question-badge"
    }, eo = {
        class: "badge-number"
    }, to = {
        class: "question-actions-top"
    }, no = {
        class: "question-main"
    }, ao = {
        class: "question-header-section"
    }, oo = [ "innerHTML" ], so = {
        key: 0,
        class: "options-section"
    }, io = {
        key: 0,
        class: "complex-question-tip"
    }, ro = {
        key: 1,
        class: "options-list"
    }, lo = {
        class: "option-letter"
    }, co = [ "innerHTML" ], po = {
        key: 0,
        class: "correct-badge"
    }, uo = {
        class: "answer-section"
    }, mo = {
        class: "answer-header"
    }, ho = vue.createElementVNode("svg", {
        viewBox: "0 0 1024 1024",
        xmlns: "http://www.w3.org/2000/svg"
    }, [ vue.createElementVNode("path", {
        fill: "currentColor",
        d: "M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896zm-55.808 536.384-99.52-99.584a38.4 38.4 0 1 0-54.336 54.336l126.72 126.72a38.272 38.272 0 0 0 54.336 0l262.4-262.464a38.4 38.4 0 1 0-54.272-54.336L456.192 600.384z"
    }) ], -1), fo = vue.createElementVNode("span", null, "\u6b63\u786e\u7b54\u6848", -1), go = {
        class: "answer-content-wrapper"
    }, yo = {
        key: 0,
        class: "answer-tags"
    }, wo = {
        key: 1,
        class: "answer-tags"
    }, vo = [ "innerHTML" ], bo = {
        key: 3,
        class: "no-answer"
    }, xo = vue.createElementVNode("svg", {
        viewBox: "0 0 1024 1024",
        xmlns: "http://www.w3.org/2000/svg"
    }, [ vue.createElementVNode("path", {
        fill: "currentColor",
        d: "M512 64a448 448 0 1 1 0 896 448 448 0 0 1 0-896zM288 416a48 48 0 1 0 0 96h448a48 48 0 1 0 0-96H288z"
    }) ], -1), _o = vue.createElementVNode("span", null, "\u6682\u65e0\u7b54\u6848", -1), ko = {
        key: 0,
        class: "pagination-wrapper"
    }, qo = vue.defineComponent({
        __name: "Preview",
        setup(e) {
            const t = vue.ref(Cache.matchGet("ques1_") || []), s = vue.ref(!1), r = vue.ref(""), l = vue.ref(1), c = vue.ref(10), p = function(e) {
                const t = new Blob([ `(${e.toString()})()` ], {
                    type: "application/javascript"
                }), n = URL.createObjectURL(t);
                return new Worker(n);
            }((() => {
                self.importScripts("https://cdn.bootcdn.net/ajax/libs/fuse.js/7.1.0/fuse.min.js"), 
                self.onmessage = function(e) {
                    const {data: t, options: n} = e.data, a = new Fuse(t, n).search(e.data.keyword).map((e => e.item));
                    a.forEach((t => {
                        t.question1 = t.question, e.data.keyword.split("").forEach((e => {
                            /[\u4e00-\u9fa5a-zA-Z0-9]/.test(e) && (t.question1 = t.question1.replace(new RegExp(e, "g"), `<span style="color:red">${e}</span>`));
                        }));
                    })), self.postMessage(a);
                };
            })), u = vue.computed((() => {
                const e = (l.value - 1) * c.value, n = e + c.value;
                return t.value.slice(e, n);
            })), cl_img_format = e => {
                if (!e.trim()) return e;
                return e.replace(/<img\b(?!.*?\breferrerPolicy\b)[^>]*>/gi, (e => e.replace(/\/?>$/, ' referrerPolicy="no-referrer">')));
            }, d = vue.computed((() => t.value.length)), getOptionIndex = e => String.fromCharCode(65 + e), handlePageChange = e => {
                l.value = e;
            }, search = () => {
                const e = {
                    keys: [ "question" ],
                    threshold: .3
                }, n = r.value.trim();
                s.value = !0, n ? (p.onmessage = e => {
                    const n = e.data;
                    t.value = n, s.value = !1, l.value = 1;
                }, p.postMessage({
                    data: Cache.matchGet("ques1_"),
                    options: e,
                    keyword: n
                })) : (t.value = Cache.matchGet("ques1_") || [], s.value = !1, l.value = 1);
            }, m = vue.ref(null), h = vue.ref(!1), handleClose = () => {
                h.value = !1;
            };
            return (e, i) => {
                const p = vue.resolveComponent("el-alert"), f = vue.resolveComponent("el-icon"), g = vue.resolveComponent("el-input"), y = vue.resolveComponent("el-tag"), w = vue.resolveComponent("el-empty"), v = vue.resolveComponent("el-button"), U = vue.resolveComponent("el-watermark"), $ = vue.resolveComponent("el-pagination"), I = vue.resolveDirective("loading");
                return vue.openBlock(), vue.createElementBlock("div", ja, [ vue.createVNode($a, {
                    visible: h.value,
                    ques: m.value,
                    onHandleClose: handleClose
                }, null, 8, [ "visible", "ques" ]), vue.createElementVNode("div", Ia, [ vue.createElementVNode("div", La, [ Oa, vue.createElementVNode("div", Fa, [ vue.createElementVNode("div", Pa, [ vue.createElementVNode("span", Ma, vue.toDisplayString(d.value), 1), Va ]), Da, vue.createElementVNode("div", Na, [ vue.createElementVNode("span", Ba, vue.toDisplayString(l.value), 1), Ga ]) ]) ]) ]), vue.createVNode(p, {
                    class: "preview-alert",
                    type: "info",
                    closable: !1,
                    "show-icon": ""
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" \u672c\u5730\u9898\u5e93\u652f\u6301\u9884\u89c8\u3001\u641c\u7d22\u3001\u7f16\u8f91\u7b49\u529f\u80fd\u3002\u641c\u7d22\u652f\u6301\u9898\u76ee\u5173\u952e\u8bcd\u6a21\u7cca\u5339\u914d "), Ra ])),
                    _: 1
                }), vue.createElementVNode("div", Ja, [ vue.createVNode(g, {
                    modelValue: r.value,
                    "onUpdate:modelValue": i[0] || (i[0] = e => r.value = e),
                    size: "large",
                    placeholder: "\ud83d\udd0d \u8f93\u5165\u5173\u952e\u8bcd\uff0c\u667a\u80fd\u641c\u7d22\u9898\u76ee...",
                    clearable: "",
                    onInput: search
                }, {
                    prefix: vue.withCtx((() => [ vue.createVNode(f, null, {
                        default: vue.withCtx((() => [ vue.createVNode(vue.unref(me)) ])),
                        _: 1
                    }) ])),
                    _: 1
                }, 8, [ "modelValue" ]), r.value ? (vue.openBlock(), vue.createElementBlock("div", Qa, [ vue.createVNode(y, {
                    type: "primary",
                    effect: "dark",
                    size: "large"
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" \u627e\u5230 " + vue.toDisplayString(t.value.length) + " \u9053\u76f8\u5173\u9898\u76ee ", 1) ])),
                    _: 1
                }) ])) : vue.createCommentVNode("", !0) ]), vue.withDirectives((vue.openBlock(), vue.createBlock(U, {
                    content: [ "\u7231\u95ee\u7b54\u52a9\u624b", "AiAskHelper" ]
                }, {
                    default: vue.withCtx((() => [ 0 === u.value.length ? (vue.openBlock(), vue.createElementBlock("div", Wa, [ vue.createVNode(w, {
                        description: "\u6682\u65e0\u9898\u76ee\u6570\u636e"
                    }, {
                        image: vue.withCtx((() => [ Ka ])),
                        _: 1
                    }) ])) : (vue.openBlock(), vue.createElementBlock("div", Ya, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(u.value, ((e, s) => (vue.openBlock(), vue.createElementBlock("div", {
                        key: s,
                        class: "question-item-wrapper"
                    }, [ vue.createElementVNode("div", Xa, [ vue.createElementVNode("div", Za, [ vue.createElementVNode("span", eo, vue.toDisplayString((l.value - 1) * c.value + s + 1), 1) ]), vue.createElementVNode("div", to, [ vue.createVNode(v, {
                        type: "primary",
                        size: "small",
                        circle: "",
                        onClick: t => (e => {
                            m.value = e, h.value = !0;
                        })(e)
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(f, null, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(oe)) ])),
                            _: 1
                        }) ])),
                        _: 2
                    }, 1032, [ "onClick" ]), vue.createVNode(v, {
                        type: "danger",
                        size: "small",
                        circle: "",
                        onClick: n => (e => {
                            t.value = t.value.filter((t => t.key !== e.key)), Cache.matchRemove(e.key);
                        })(e)
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(f, null, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(ee)) ])),
                            _: 1
                        }) ])),
                        _: 2
                    }, 1032, [ "onClick" ]) ]), vue.createElementVNode("div", no, [ vue.createElementVNode("div", ao, [ vue.createVNode(y, {
                        class: "question-type-tag",
                        type: "primary"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(vue.unref(typeConvert)(e.type ?? "", !1)), 1) ])),
                        _: 2
                    }, 1024) ]), vue.createElementVNode("div", {
                        class: "question-text",
                        innerHTML: cl_img_format(e.question1 || e.question)
                    }, null, 8, oo), e.options && e.options.length > 0 ? (vue.openBlock(), vue.createElementBlock("div", so, [ "object" == typeof e.options[0] ? (vue.openBlock(), 
                    vue.createElementBlock("div", io, [ vue.createVNode(p, {
                        type: "warning",
                        closable: !1
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u8be5\u9898\u578b\u6682\u4e0d\u652f\u6301\u5b8c\u6574\u663e\u793a ") ])),
                        _: 1
                    }) ])) : (vue.openBlock(), vue.createElementBlock("div", ro, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, ((t, s) => (vue.openBlock(), vue.createElementBlock("div", {
                        key: s,
                        class: vue.normalizeClass([ "option-item", {
                            "option-correct": e.answer && e.answer.includes(t)
                        } ])
                    }, [ vue.createElementVNode("div", lo, vue.toDisplayString(getOptionIndex(s)), 1), vue.createElementVNode("div", {
                        class: "option-text",
                        innerHTML: cl_img_format(t)
                    }, null, 8, co), e.answer && e.answer.includes(t) ? (vue.openBlock(), vue.createElementBlock("div", po, " \u2713 ")) : vue.createCommentVNode("", !0) ], 2)))), 128)) ])) ])) : vue.createCommentVNode("", !0), vue.createElementVNode("div", uo, [ vue.createElementVNode("div", mo, [ vue.createVNode(f, null, {
                        default: vue.withCtx((() => [ ho ])),
                        _: 1
                    }), fo ]), vue.createElementVNode("div", go, [ Array.isArray(e.answer) && 0 === e.options.length ? (vue.openBlock(), 
                    vue.createElementBlock("div", yo, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.answer, ((e, t) => (vue.openBlock(), vue.createBlock(y, {
                        key: t,
                        type: "success",
                        effect: "dark",
                        size: "large"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e), 1) ])),
                        _: 2
                    }, 1024)))), 128)) ])) : Array.isArray(e.answer) ? (vue.openBlock(), vue.createElementBlock("div", wo, [ (vue.openBlock(!0), 
                    vue.createElementBlock(vue.Fragment, null, vue.renderList(e.answer, ((e, t) => (vue.openBlock(), vue.createBlock(y, {
                        key: t,
                        type: "success",
                        effect: "dark",
                        size: "large"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e), 1) ])),
                        _: 2
                    }, 1024)))), 128)) ])) : e.answer ? (vue.openBlock(), vue.createElementBlock("div", {
                        key: 2,
                        class: "answer-text",
                        innerHTML: cl_img_format(e.answer)
                    }, null, 8, vo)) : (vue.openBlock(), vue.createElementBlock("div", bo, [ vue.createVNode(f, null, {
                        default: vue.withCtx((() => [ xo ])),
                        _: 1
                    }), _o ])) ]) ]) ]) ]) ])))), 128)) ])) ])),
                    _: 1
                })), [ [ I, s.value ] ]), d.value > 0 ? (vue.openBlock(), vue.createElementBlock("div", ko, [ vue.createVNode($, {
                    size: "default",
                    background: "",
                    layout: "total, prev, pager, next, jumper",
                    total: d.value,
                    "page-size": c.value,
                    "current-page": l.value,
                    "onUpdate:currentPage": i[1] || (i[1] = e => l.value = e),
                    onCurrentChange: handlePageChange
                }, null, 8, [ "total", "page-size", "current-page" ]) ])) : vue.createCommentVNode("", !0) ]);
            };
        }
    }), Co = {
        class: "paper-library-container"
    }, To = {
        key: 0,
        class: "paper-list-view"
    }, Ao = vue.createElementVNode("div", null, [ vue.createTextVNode(" \u8bd5\u5377\u5e93\u5c55\u793a\u6240\u6709\u5df2\u7f13\u5b58\u7684\u8bfe\u7a0b\u8bd5\u5377\uff0c\u60a8\u53ef\u4ee5\u67e5\u770b\u6bcf\u4e2a\u8bfe\u7a0b\u7684\u7ae0\u8282\u548c\u9898\u76ee\u8be6\u60c5 "), vue.createElementVNode("p", {
        style: {
            color: "#0071e3",
            "margin-top": "8px",
            "margin-bottom": "0"
        }
    }, " \ud83d\udca1 \u70b9\u51fb\u8bfe\u7a0b\u5361\u7247\u53ef\u67e5\u770b\u8be6\u7ec6\u7684\u7ae0\u8282\u548c\u9898\u76ee\u4fe1\u606f ") ], -1), So = {
        class: "search-header"
    }, Ho = {
        class: "search-stats"
    }, Uo = {
        class: "papers-grid"
    }, Eo = {
        class: "paper-header"
    }, zo = {
        class: "paper-info"
    }, $o = {
        class: "paper-title"
    }, jo = {
        class: "paper-meta"
    }, Io = {
        class: "paper-footer"
    }, Lo = {
        class: "paper-actions"
    }, Oo = {
        key: 1,
        class: "chapter-list-view"
    }, Fo = {
        class: "header-content"
    }, Po = {
        class: "header-actions"
    }, Mo = {
        class: "course-info"
    }, Vo = {
        class: "course-stats"
    }, Do = {
        class: "chapters-list"
    }, No = {
        class: "chapter-header"
    }, Bo = {
        class: "chapter-number"
    }, Go = {
        class: "chapter-info"
    }, Ro = {
        class: "chapter-title"
    }, Jo = {
        class: "chapter-meta"
    }, Qo = {
        class: "chapter-actions"
    }, Wo = {
        key: 2,
        class: "question-list-view"
    }, Ko = {
        class: "header-content"
    }, Yo = {
        class: "chapter-info-header"
    }, Xo = {
        class: "questions-container"
    }, Zo = {
        class: "question-number"
    }, es = [ "innerHTML" ], ts = {
        key: 0,
        class: "question-options"
    }, ns = {
        key: 0
    }, as = [ vue.createElementVNode("p", {
        style: {
            color: "#999"
        }
    }, "\u590d\u6742\u9898\u578b\uff0c\u6682\u65f6\u65e0\u6cd5\u5b8c\u6574\u663e\u793a", -1) ], os = {
        key: 1
    }, ss = {
        class: "option-label"
    }, is = [ "innerHTML" ], rs = {
        class: "question-answer"
    }, ls = vue.createElementVNode("span", {
        style: {
            color: "#67c23a",
            "font-weight": "bold"
        }
    }, "\u2713 \u7b54\u6848", -1), cs = {
        key: 0
    }, ps = {
        key: 1
    }, us = [ "innerHTML" ], ds = {
        key: 3,
        style: {
            color: "#999"
        }
    }, ms = vue.defineComponent({
        __name: "PaperLibrary",
        setup(e) {
            const t = vue.ref([]), s = vue.ref(!1), r = vue.ref(""), l = vue.ref(null), c = vue.ref(null), loadPapers = () => {
                s.value = !0;
                try {
                    const e = Cache.matchGet("paper__");
                    t.value = e.map((e => {
                        var t;
                        let n = 0;
                        return e.chapter && Array.isArray(e.chapter) && e.chapter.forEach((e => {
                            e.question && Array.isArray(e.question) && (n += e.question.length);
                        })), {
                            ...e,
                            totalQuestions: n,
                            chapterCount: (null == (t = e.chapter) ? void 0 : t.length) || 0
                        };
                    }));
                } finally {
                    s.value = !1;
                }
            };
            loadPapers();
            const p = vue.computed((() => {
                if (!r.value.trim()) return t.value;
                const e = r.value.toLowerCase();
                return t.value.filter((t => {
                    var n, a;
                    return (null == (n = t.name) ? void 0 : n.toLowerCase().includes(e)) || (null == (a = t.courseName) ? void 0 : a.toLowerCase().includes(e));
                }));
            })), backToPaperList = () => {
                l.value = null, c.value = null;
            }, backToChapterList = () => {
                c.value = null;
            }, cl_img_format = e => {
                if (!e || !e.trim()) return e;
                return e.replace(/<img\b(?!.*?\breferrerPolicy\b)[^>]*>/gi, (e => e.replace(/\/?>$/, ' referrerPolicy="no-referrer">')));
            }, exportPaperToHtml = e => {
                try {
                    const t = generatePaperHtml(e);
                    downloadHtml(t, `${e.name || e.courseName || "\u8bfe\u7a0b\u8bd5\u5377"}.html`), 
                    D.ElMessage.success("\u5bfc\u51fa\u6210\u529f\uff01");
                } catch (t) {
                    D.ElMessage.error("\u5bfc\u51fa\u5931\u8d25\uff0c\u8bf7\u91cd\u8bd5"), console.error("\u5bfc\u51fa\u9519\u8bef:", t);
                }
            }, generatePaperHtml = e => {
                const t = e.name || e.courseName || "\u672a\u547d\u540d\u8bfe\u7a0b";
                var n;
                !(n = e.createTime) || new Date(n).toLocaleString("zh-CN");
                let a = "";
                return e.chapter && e.chapter.length > 0 && e.chapter.forEach(((e, t) => {
                    a += `\n        <div class="chapter">\n          <h2 class="chapter-title">\n            <span class="chapter-number">${t + 1}</span>\n            ${e.name || e.title || "\u672a\u547d\u540d\u7ae0\u8282"}\n          </h2>\n          ${generateQuestionsHtml(e.question || [])}\n        </div>\n      `;
                })), `\n<!DOCTYPE html>\n<html lang="zh-CN">\n<head>\n  <meta charset="UTF-8">\n  <meta name="viewport" content="width=device-width, initial-scale=1.0">\n  <title>${t} - \u8bd5\u5377</title>\n  <style>\n    ${getHtmlStyles()}\n  </style>\n</head>\n<body>\n  <div class="container">\n    <header class="header">\n      <h1 class="course-title">${t}</h1>\n      <div class="meta-info">\n        <span class="badge">\u5171 ${e.chapterCount || 0} \u4e2a\u7ae0\u8282</span>\n        <span class="badge">\u5171 ${e.totalQuestions || 0} \u9053\u9898\u76ee</span>\n      </div>\n      <div class="watermark">\u5bfc\u51fa\u81ea\u7231\u95ee\u7b54\u52a9\u624b</div>\n    </header>\n    \n    <main class="content">\n      ${a || '<p class="empty">\u6682\u65e0\u7ae0\u8282\u6570\u636e</p>'}\n    </main>\n    \n    <footer class="footer">\n      <p>\u672c\u6587\u6863\u7531\u7231\u95ee\u7b54\u52a9\u624b\u751f\u6210 | \u5bfc\u51fa\u65f6\u95f4: ${(new Date).toLocaleString("zh-CN")}</p>\n    </footer>\n  </div>\n</body>\n</html>\n  `;
            }, generateChapterHtml = (e, t) => {
                var n;
                const a = e.name || e.courseName || "\u672a\u547d\u540d\u8bfe\u7a0b", o = t.name || t.title || "\u672a\u547d\u540d\u7ae0\u8282";
                return `\n<!DOCTYPE html>\n<html lang="zh-CN">\n<head>\n  <meta charset="UTF-8">\n  <meta name="viewport" content="width=device-width, initial-scale=1.0">\n  <title>${a} - ${o}</title>\n  <style>\n    ${getHtmlStyles()}\n  </style>\n</head>\n<body>\n  <div class="container">\n    <header class="header">\n      <h1 class="course-title">${a}</h1>\n      <h2 class="chapter-subtitle">${o}</h2>\n      <div class="meta-info">\n        <span class="badge">\u5171 ${(null == (n = t.question) ? void 0 : n.length) || 0} \u9053\u9898\u76ee</span>\n      </div>\n      <div class="watermark">\u5bfc\u51fa\u81ea\u7231\u95ee\u7b54\u52a9\u624b</div>\n    </header>\n    \n    <main class="content">\n      ${generateQuestionsHtml(t.question || [])}\n    </main>\n    \n    <footer class="footer">\n      <p>\u672c\u6587\u6863\u7531\u7231\u95ee\u7b54\u52a9\u624b\u751f\u6210 | \u5bfc\u51fa\u65f6\u95f4: ${(new Date).toLocaleString("zh-CN")}</p>\n    </footer>\n  </div>\n</body>\n</html>\n  `;
            }, generateQuestionsHtml = e => e && 0 !== e.length ? e.map(((e, t) => {
                const n = typeConvert(e.type ?? "", !1);
                let a = "";
                e.options && e.options.length > 0 && ("object" == typeof e.options[0] ? a = '<p class="note">\u590d\u6742\u9898\u578b\uff0c\u90e8\u5206\u5185\u5bb9\u53ef\u80fd\u65e0\u6cd5\u5b8c\u6574\u663e\u793a</p>' : (a = '<div class="options">', 
                e.options.forEach(((t, n) => {
                    const o = e.answer && e.answer.includes(t), s = String.fromCharCode(65 + n);
                    a += `\n            <div class="option ${o ? "is-answer" : ""}">\n              <span class="option-label">${s}.</span>\n              <span class="option-content">${t}</span>\n            </div>\n          `;
                })), a += "</div>"));
                let o = '<div class="answer-section"><h4>\u7b54\u6848</h4>';
                return Array.isArray(e.answer) ? (e.options && e.options.length, o += e.answer.map((e => `<span class="answer-tag">${e}</span>`)).join("")) : e.answer ? o += `<div class="answer-content">${e.answer}</div>` : o += '<span class="no-answer">\u6682\u65e0\u7b54\u6848</span>', 
                o += "</div>", `\n      <div class="question">\n        <div class="question-header">\n          <span class="question-number">\u7b2c ${t + 1} \u9898</span>\n          <span class="question-type">[${n}]</span>\n        </div>\n        <div class="question-content">${e.question}</div>\n        ${a}\n        ${o}\n      </div>\n    `;
            })).join("") : '<p class="empty">\u6682\u65e0\u9898\u76ee\u6570\u636e</p>', getHtmlStyles = () => "\n  * {\n    margin: 0;\n    padding: 0;\n    box-sizing: border-box;\n  }\n\n  body {\n    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Hiragino Sans GB', \n                 'Microsoft YaHei', 'Helvetica Neue', Helvetica, Arial, sans-serif;\n    line-height: 1.6;\n    color: #333;\n    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);\n    padding: 20px;\n  }\n\n  .container {\n    max-width: 1200px;\n    margin: 0 auto;\n    background: white;\n    border-radius: 12px;\n    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);\n    overflow: hidden;\n  }\n\n  .header {\n    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);\n    color: white;\n    padding: 40px;\n    position: relative;\n  }\n\n  .course-title {\n    font-size: 32px;\n    margin-bottom: 10px;\n    font-weight: 600;\n  }\n\n  .chapter-subtitle {\n    font-size: 24px;\n    margin-top: 10px;\n    opacity: 0.95;\n  }\n\n  .meta-info {\n    display: flex;\n    gap: 12px;\n    flex-wrap: wrap;\n    margin-top: 16px;\n  }\n\n  .badge {\n    display: inline-block;\n    padding: 6px 16px;\n    background: rgba(255, 255, 255, 0.2);\n    border-radius: 20px;\n    font-size: 14px;\n    backdrop-filter: blur(10px);\n  }\n\n  .date {\n    padding: 6px 16px;\n    font-size: 14px;\n    opacity: 0.9;\n  }\n\n  .watermark {\n    position: absolute;\n    top: 20px;\n    right: 40px;\n    opacity: 0.3;\n    font-size: 14px;\n  }\n\n  .content {\n    padding: 40px;\n  }\n\n  .chapter {\n    margin-bottom: 40px;\n    page-break-inside: avoid;\n  }\n\n  .chapter-title {\n    font-size: 24px;\n    color: #667eea;\n    margin-bottom: 24px;\n    padding-bottom: 12px;\n    border-bottom: 3px solid #667eea;\n    display: flex;\n    align-items: center;\n    gap: 12px;\n  }\n\n  .chapter-number {\n    display: inline-flex;\n    align-items: center;\n    justify-content: center;\n    width: 40px;\n    height: 40px;\n    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);\n    color: white;\n    border-radius: 50%;\n    font-size: 18px;\n    font-weight: bold;\n  }\n\n  .question {\n    margin-bottom: 30px;\n    padding: 24px;\n    background: #f8f9fa;\n    border-radius: 12px;\n    border-left: 4px solid #667eea;\n    page-break-inside: avoid;\n  }\n\n  .question-header {\n    display: flex;\n    gap: 12px;\n    margin-bottom: 12px;\n    align-items: center;\n  }\n\n  .question-number {\n    display: inline-block;\n    padding: 4px 12px;\n    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);\n    color: white;\n    border-radius: 12px;\n    font-size: 14px;\n    font-weight: 600;\n  }\n\n  .question-type {\n    color: #667eea;\n    font-weight: 600;\n    font-size: 14px;\n  }\n\n  .question-content {\n    font-size: 16px;\n    margin-bottom: 16px;\n    line-height: 1.8;\n    color: #2c3e50;\n    font-weight: 500;\n  }\n\n  .options {\n    margin: 16px 0;\n  }\n\n  .option {\n    display: flex;\n    padding: 12px 16px;\n    margin-bottom: 8px;\n    background: white;\n    border-radius: 8px;\n    border: 1px solid #e0e0e0;\n    transition: all 0.2s;\n  }\n\n  .option:hover {\n    border-color: #667eea;\n    transform: translateX(4px);\n  }\n\n  .option.is-answer {\n    background: #f0f9ff;\n    border: 2px solid #67c23a;\n    color: #67c23a;\n    font-weight: 500;\n  }\n\n  .option-label {\n    font-weight: 600;\n    margin-right: 12px;\n    min-width: 24px;\n  }\n\n  .option-content {\n    flex: 1;\n  }\n\n  .answer-section {\n    margin-top: 16px;\n    padding: 16px;\n    background: white;\n    border-radius: 8px;\n    border: 2px solid #67c23a;\n  }\n\n  .answer-section h4 {\n    color: #67c23a;\n    margin-bottom: 12px;\n    font-size: 16px;\n  }\n\n  .answer-tag {\n    display: inline-block;\n    padding: 6px 16px;\n    background: #67c23a;\n    color: white;\n    border-radius: 16px;\n    margin-right: 8px;\n    margin-bottom: 8px;\n    font-size: 14px;\n  }\n\n  .answer-content {\n    padding: 12px;\n    background: #f0f9ff;\n    border-radius: 8px;\n    color: #409eff;\n    line-height: 1.6;\n  }\n\n  .no-answer {\n    color: #999;\n    font-style: italic;\n  }\n\n  .note {\n    color: #999;\n    font-size: 14px;\n    font-style: italic;\n  }\n\n  .empty {\n    text-align: center;\n    color: #999;\n    padding: 40px;\n    font-size: 16px;\n  }\n\n  .footer {\n    background: #f8f9fa;\n    padding: 24px;\n    text-align: center;\n    color: #666;\n    border-top: 1px solid #e0e0e0;\n  }\n\n  img {\n    max-width: 100%;\n    height: auto;\n    border-radius: 8px;\n    margin: 8px 0;\n  }\n\n  @media print {\n    body {\n      background: white;\n      padding: 0;\n    }\n    \n    .container {\n      box-shadow: none;\n    }\n    \n    .question, .chapter {\n      page-break-inside: avoid;\n    }\n  }\n\n  @media (max-width: 768px) {\n    .container {\n      border-radius: 0;\n    }\n    \n    .header, .content {\n      padding: 20px;\n    }\n    \n    .course-title {\n      font-size: 24px;\n    }\n  }\n", downloadHtml = (e, t) => {
                const n = new Blob([ e ], {
                    type: "text/html;charset=utf-8"
                }), a = URL.createObjectURL(n), o = document.createElement("a");
                o.href = a, o.download = t, document.body.appendChild(o), o.click(), document.body.removeChild(o), 
                URL.revokeObjectURL(a);
            }, deletePaper = async (e, t) => {
                t && t.stopPropagation();
                try {
                    await D.ElMessageBox.confirm(`\u786e\u5b9a\u8981\u5220\u9664\u8bfe\u7a0b"${e.name || e.courseName || "\u672a\u547d\u540d\u8bfe\u7a0b"}"\u5417\uff1f\u6b64\u64cd\u4f5c\u4e0d\u53ef\u6062\u590d\uff01`, "\u5220\u9664\u786e\u8ba4", {
                        confirmButtonText: "\u786e\u5b9a\u5220\u9664",
                        cancelButtonText: "\u53d6\u6d88",
                        type: "warning",
                        confirmButtonClass: "el-button--danger"
                    }), Cache.remove(e.key), l.value && l.value.key === e.key && backToPaperList(), 
                    loadPapers(), D.ElMessage.success("\u5220\u9664\u6210\u529f\uff01");
                } catch (n) {
                    "cancel" !== n && console.error("\u5220\u9664\u9519\u8bef:", n);
                }
            }, clearAllPapers = async () => {
                if (0 !== t.value.length) try {
                    await D.ElMessageBox.confirm(`\u786e\u5b9a\u8981\u6e05\u7a7a\u6240\u6709\u8bd5\u5377\u5417\uff1f\u5171 ${t.value.length} \u95e8\u8bfe\u7a0b\u5c06\u88ab\u5220\u9664\uff0c\u6b64\u64cd\u4f5c\u4e0d\u53ef\u6062\u590d\uff01`, "\u6e05\u7a7a\u786e\u8ba4", {
                        confirmButtonText: "\u786e\u5b9a\u6e05\u7a7a",
                        cancelButtonText: "\u53d6\u6d88",
                        type: "error",
                        confirmButtonClass: "el-button--danger"
                    }), Cache.matchRemove("paper__"), backToPaperList(), loadPapers(), D.ElMessage.success("\u5df2\u6e05\u7a7a\u6240\u6709\u8bd5\u5377\uff01");
                } catch (e) {
                    "cancel" !== e && console.error("\u6e05\u7a7a\u9519\u8bef:", e);
                } else D.ElMessage.warning("\u5f53\u524d\u6ca1\u6709\u8bd5\u5377\u6570\u636e");
            };
            return (e, i) => {
                const u = vue.resolveComponent("el-alert"), d = vue.resolveComponent("el-card"), m = vue.resolveComponent("el-icon"), h = vue.resolveComponent("el-input"), f = vue.resolveComponent("el-button"), g = vue.resolveComponent("el-tag"), y = vue.resolveComponent("el-empty"), w = vue.resolveComponent("el-divider"), v = vue.resolveDirective("loading");
                return vue.openBlock(), vue.createElementBlock("div", Co, [ l.value ? l.value && !c.value ? (vue.openBlock(), vue.createElementBlock("div", Oo, [ vue.createVNode(d, {
                    class: "header-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", Fo, [ vue.createElementVNode("div", Po, [ vue.createVNode(f, {
                        type: "primary",
                        onClick: backToPaperList,
                        plain: ""
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(m, null, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(W), {
                                style: {
                                    transform: "rotate(180deg)"
                                }
                            }) ])),
                            _: 1
                        }), vue.createTextVNode(" \u8fd4\u56de\u8bfe\u7a0b\u5217\u8868 ") ])),
                        _: 1
                    }), vue.createVNode(f, {
                        type: "success",
                        onClick: i[1] || (i[1] = e => exportPaperToHtml(l.value)),
                        icon: vue.unref(ne)
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u5bfc\u51fa\u6574\u4e2a\u8bfe\u7a0b ") ])),
                        _: 1
                    }, 8, [ "icon" ]), vue.createVNode(f, {
                        type: "danger",
                        onClick: i[2] || (i[2] = e => deletePaper(l.value)),
                        icon: vue.unref(ee)
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u5220\u9664\u6b64\u8bfe\u7a0b ") ])),
                        _: 1
                    }, 8, [ "icon" ]) ]), vue.createElementVNode("div", Mo, [ vue.createElementVNode("h2", null, vue.toDisplayString(l.value.name || l.value.courseName || "\u672a\u547d\u540d\u8bfe\u7a0b"), 1), vue.createElementVNode("div", Vo, [ vue.createVNode(g, {
                        type: "success"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(l.value.chapterCount) + " \u4e2a\u7ae0\u8282", 1) ])),
                        _: 1
                    }), vue.createVNode(g, {
                        type: "warning"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(l.value.totalQuestions) + " \u9053\u9898\u76ee", 1) ])),
                        _: 1
                    }) ]) ]) ]) ])),
                    _: 1
                }), vue.createElementVNode("div", Do, [ l.value.chapter && 0 !== l.value.chapter.length ? vue.createCommentVNode("", !0) : (vue.openBlock(), 
                vue.createBlock(y, {
                    key: 0,
                    description: "\u6682\u65e0\u7ae0\u8282\u6570\u636e"
                })), (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(l.value.chapter, ((e, t) => (vue.openBlock(), vue.createBlock(d, {
                    key: t,
                    class: "chapter-card",
                    shadow: "hover",
                    onClick: t => (e => {
                        c.value = e;
                    })(e)
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", No, [ vue.createElementVNode("div", Bo, vue.toDisplayString(t + 1), 1), vue.createElementVNode("div", Go, [ vue.createElementVNode("h3", Ro, vue.toDisplayString(e.name || e.title || "\u672a\u547d\u540d\u7ae0\u8282"), 1), vue.createElementVNode("div", Jo, [ vue.createVNode(g, {
                        size: "small",
                        type: "primary"
                    }, {
                        default: vue.withCtx((() => {
                            var t;
                            return [ vue.createTextVNode(vue.toDisplayString((null == (t = e.question) ? void 0 : t.length) || 0) + " \u9053\u9898\u76ee ", 1) ];
                        })),
                        _: 2
                    }, 1024) ]) ]), vue.createElementVNode("div", Qo, [ vue.createVNode(f, {
                        type: "success",
                        size: "small",
                        onClick: vue.withModifiers((t => ((e, t) => {
                            try {
                                const n = generateChapterHtml(e, t);
                                downloadHtml(n, `${e.name || e.courseName}-${t.name || t.title || "\u7ae0\u8282"}.html`), 
                                D.ElMessage.success("\u5bfc\u51fa\u6210\u529f\uff01");
                            } catch (n) {
                                D.ElMessage.error("\u5bfc\u51fa\u5931\u8d25\uff0c\u8bf7\u91cd\u8bd5"), console.error("\u5bfc\u51fa\u9519\u8bef:", n);
                            }
                        })(l.value, e)), [ "stop" ]),
                        icon: vue.unref(ne)
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u5bfc\u51fa ") ])),
                        _: 2
                    }, 1032, [ "onClick", "icon" ]), vue.createVNode(m, {
                        class: "chapter-arrow"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(vue.unref(W)) ])),
                        _: 1
                    }) ]) ]) ])),
                    _: 2
                }, 1032, [ "onClick" ])))), 128)) ]) ])) : c.value ? (vue.openBlock(), vue.createElementBlock("div", Wo, [ vue.createVNode(d, {
                    class: "header-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", Ko, [ vue.createVNode(f, {
                        type: "primary",
                        onClick: backToChapterList,
                        plain: ""
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(m, null, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(W), {
                                style: {
                                    transform: "rotate(180deg)"
                                }
                            }) ])),
                            _: 1
                        }), vue.createTextVNode(" \u8fd4\u56de\u7ae0\u8282\u5217\u8868 ") ])),
                        _: 1
                    }), vue.createElementVNode("div", Yo, [ vue.createElementVNode("h2", null, vue.toDisplayString(c.value.name || c.value.title || "\u672a\u547d\u540d\u7ae0\u8282"), 1), vue.createVNode(g, {
                        type: "primary"
                    }, {
                        default: vue.withCtx((() => {
                            var e;
                            return [ vue.createTextVNode(vue.toDisplayString((null == (e = c.value.question) ? void 0 : e.length) || 0) + " \u9053\u9898\u76ee", 1) ];
                        })),
                        _: 1
                    }) ]) ]) ])),
                    _: 1
                }), vue.createElementVNode("div", Xo, [ c.value.question && 0 !== c.value.question.length ? vue.createCommentVNode("", !0) : (vue.openBlock(), 
                vue.createBlock(y, {
                    key: 0,
                    description: "\u6682\u65e0\u9898\u76ee\u6570\u636e"
                })), (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(c.value.question, ((e, t) => (vue.openBlock(), vue.createBlock(d, {
                    key: t,
                    class: "question-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", Zo, "\u7b2c " + vue.toDisplayString(t + 1) + " \u9898", 1), vue.createElementVNode("div", {
                        class: "question-title",
                        innerHTML: "[" + vue.unref(typeConvert)(e.type ?? "", !1) + "] " + cl_img_format(e.question)
                    }, null, 8, es), e.options && e.options.length > 0 ? (vue.openBlock(), vue.createElementBlock("div", ts, [ "object" == typeof e.options[0] ? (vue.openBlock(), 
                    vue.createElementBlock("div", ns, as)) : (vue.openBlock(), vue.createElementBlock("div", os, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, ((t, s) => {
                        return vue.openBlock(), vue.createElementBlock("div", {
                            key: s,
                            class: vue.normalizeClass([ "option-item", {
                                "is-answer": e.answer && e.answer.includes(t)
                            } ])
                        }, [ vue.createElementVNode("span", ss, vue.toDisplayString((i = s, String.fromCharCode(65 + i))) + ".", 1), vue.createElementVNode("span", {
                            class: "option-content",
                            innerHTML: cl_img_format(t)
                        }, null, 8, is) ], 2);
                        var i;
                    })), 128)) ])) ])) : vue.createCommentVNode("", !0), vue.createElementVNode("div", rs, [ vue.createVNode(w, {
                        "content-position": "left"
                    }, {
                        default: vue.withCtx((() => [ ls ])),
                        _: 1
                    }), Array.isArray(e.answer) && e.options && 0 === e.options.length ? (vue.openBlock(), vue.createElementBlock("div", cs, [ (vue.openBlock(!0), 
                    vue.createElementBlock(vue.Fragment, null, vue.renderList(e.answer, ((e, t) => (vue.openBlock(), vue.createBlock(g, {
                        key: t,
                        type: "success",
                        innerHTML: cl_img_format(e),
                        style: {
                            margin: "4px"
                        }
                    }, null, 8, [ "innerHTML" ])))), 128)) ])) : Array.isArray(e.answer) ? (vue.openBlock(), vue.createElementBlock("div", ps, [ (vue.openBlock(!0), 
                    vue.createElementBlock(vue.Fragment, null, vue.renderList(e.answer, ((e, t) => (vue.openBlock(), vue.createElementBlock("span", {
                        key: t
                    }, [ vue.createVNode(g, {
                        type: "success",
                        style: {
                            margin: "4px"
                        },
                        innerHTML: cl_img_format(e)
                    }, null, 8, [ "innerHTML" ]) ])))), 128)) ])) : e.answer ? (vue.openBlock(), vue.createElementBlock("div", {
                        key: 2,
                        class: "answer-content",
                        innerHTML: cl_img_format(e.answer)
                    }, null, 8, us)) : (vue.openBlock(), vue.createElementBlock("div", ds, "\u6682\u65e0\u7b54\u6848")) ]) ])),
                    _: 2
                }, 1024)))), 128)) ]) ])) : vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createElementBlock("div", To, [ vue.createVNode(d, {
                    class: "tips-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(u, {
                        type: "info",
                        closable: !1,
                        "show-icon": ""
                    }, {
                        default: vue.withCtx((() => [ Ao ])),
                        _: 1
                    }) ])),
                    _: 1
                }), vue.createVNode(d, {
                    class: "search-card",
                    shadow: "hover"
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", So, [ vue.createVNode(h, {
                        modelValue: r.value,
                        "onUpdate:modelValue": i[0] || (i[0] = e => r.value = e),
                        size: "large",
                        placeholder: "\ud83d\udd0d \u641c\u7d22\u8bfe\u7a0b\u540d\u79f0...",
                        clearable: "",
                        style: {
                            flex: "1"
                        }
                    }, {
                        prefix: vue.withCtx((() => [ vue.createVNode(m, null, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(me)) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }, 8, [ "modelValue" ]), vue.createVNode(f, {
                        type: "danger",
                        size: "large",
                        onClick: clearAllPapers,
                        icon: vue.unref(ee),
                        disabled: 0 === t.value.length
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u6e05\u7a7a\u6240\u6709 ") ])),
                        _: 1
                    }, 8, [ "icon", "disabled" ]) ]), vue.createElementVNode("div", Ho, [ vue.createVNode(g, {
                        type: "info",
                        effect: "plain"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u5171 " + vue.toDisplayString(t.value.length) + " \u95e8\u8bfe\u7a0b ", 1) ])),
                        _: 1
                    }), r.value ? (vue.openBlock(), vue.createBlock(g, {
                        key: 0,
                        type: "primary",
                        effect: "plain"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u641c\u7d22\u7ed3\u679c: " + vue.toDisplayString(p.value.length) + " \u95e8 ", 1) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0) ]) ])),
                    _: 1
                }), vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", Uo, [ 0 === p.value.length ? (vue.openBlock(), vue.createBlock(y, {
                    key: 0,
                    description: "\u6682\u65e0\u8bd5\u5377\u6570\u636e"
                })) : vue.createCommentVNode("", !0), (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(p.value, ((e, t) => (vue.openBlock(), vue.createBlock(d, {
                    key: t,
                    class: "paper-card",
                    shadow: "hover",
                    onClick: t => (e => {
                        l.value = e, c.value = null;
                    })(e)
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", Eo, [ vue.createVNode(m, {
                        class: "paper-icon",
                        size: 32,
                        color: "#409EFF"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(vue.unref(ie)) ])),
                        _: 1
                    }), vue.createElementVNode("div", zo, [ vue.createElementVNode("h3", $o, vue.toDisplayString(e.name || e.courseName || "\u672a\u547d\u540d\u8bfe\u7a0b"), 1), vue.createElementVNode("div", jo, [ vue.createVNode(g, {
                        size: "small",
                        type: "success"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.chapterCount) + " \u4e2a\u7ae0\u8282 ", 1) ])),
                        _: 2
                    }, 1024), vue.createVNode(g, {
                        size: "small",
                        type: "warning"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.totalQuestions) + " \u9053\u9898\u76ee ", 1) ])),
                        _: 2
                    }, 1024) ]) ]) ]), vue.createElementVNode("div", Io, [ vue.createElementVNode("div", Lo, [ vue.createVNode(f, {
                        type: "success",
                        size: "small",
                        onClick: vue.withModifiers((t => exportPaperToHtml(e)), [ "stop" ]),
                        icon: vue.unref(ne)
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u5bfc\u51fa ") ])),
                        _: 2
                    }, 1032, [ "onClick", "icon" ]), vue.createVNode(f, {
                        type: "danger",
                        size: "small",
                        onClick: vue.withModifiers((t => deletePaper(e, t)), [ "stop" ]),
                        icon: vue.unref(ee)
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(" \u5220\u9664 ") ])),
                        _: 2
                    }, 1032, [ "onClick", "icon" ]) ]), vue.createVNode(m, null, {
                        default: vue.withCtx((() => [ vue.createVNode(vue.unref(W)) ])),
                        _: 1
                    }) ]) ])),
                    _: 2
                }, 1032, [ "onClick" ])))), 128)) ])), [ [ v, s.value ] ]) ])) ]);
            };
        }
    }), hs = vue.defineComponent({
        __name: "Log",
        setup(e) {
            const t = tn(), getColor = e => {
                switch (e) {
                  case "warn":
                    return "orange";

                  case "error":
                    return "red";

                  case "success":
                    return "green";

                  default:
                    return "blue";
                }
            };
            return (e, a) => {
                const s = vue.resolveComponent("el-table-column"), i = vue.resolveComponent("el-table");
                return vue.openBlock(), vue.createBlock(i, {
                    data: vue.unref(t).logs,
                    style: {
                        width: "100%"
                    }
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(s, {
                        prop: "time",
                        label: "\u65f6\u95f4",
                        width: "180"
                    }, {
                        default: vue.withCtx((({row: e}) => [ vue.createElementVNode("span", null, vue.toDisplayString(e.time), 1) ])),
                        _: 1
                    }), vue.createVNode(s, {
                        prop: "content",
                        label: "\u5185\u5bb9"
                    }, {
                        default: vue.withCtx((({row: e}) => [ vue.createElementVNode("span", {
                            style: vue.normalizeStyle({
                                color: getColor(e.type)
                            })
                        }, vue.toDisplayString(e.content), 5) ])),
                        _: 1
                    }) ])),
                    _: 1
                }, 8, [ "data" ]);
            };
        }
    }), fs = defineStore("ai", {
        state: () => ({
            aiMsg: "",
            aiLoading: !1
        }),
        actions: {
            currentAiMd() {
                return simpleMarkdownToHtml(this.aiMsg);
            },
            resetAi() {
                this.aiMsg = "", this.aiLoading = !1;
            }
        }
    }), gs = {
        class: "ai-container"
    }, ys = vue.createElementVNode("div", {
        class: "card-header"
    }, [ vue.createElementVNode("span", {
        class: "card-title"
    }, "\ud83e\udd16 AI\u667a\u80fd\u641c\u9898") ], -1), ws = {
        class: "search-type"
    }, vs = {
        key: 0,
        class: "question-type-select"
    }, bs = vue.createElementVNode("p", {
        class: "helper-text"
    }, "\u7c98\u8d34\u9898\u5e72\u53ca\u9009\u9879\uff0c\u7cfb\u7edf\u4f1a\u81ea\u52a8\u89e3\u6790\u5e76\u641c\u7d22\u5b98\u65b9\u9898\u5e93", -1), xs = {
        class: "card-header"
    }, _s = vue.createElementVNode("span", {
        class: "card-title"
    }, "\ud83d\udca1 AI\u89e3\u7b54", -1), ks = {
        class: "result-content"
    }, qs = [ "innerHTML" ], Cs = {
        class: "card-header"
    }, Ts = vue.createElementVNode("span", {
        class: "card-title"
    }, "\ud83d\udcda \u7231\u95ee\u7b54\u9898\u5e93", -1), As = {
        class: "result-content"
    }, Ss = [ "innerHTML" ], Hs = [ "innerHTML" ], Us = {
        class: "option-label"
    }, Es = [ "innerHTML" ], zs = {
        class: "official-result-header"
    }, $s = {
        class: "official-result-title"
    }, js = vue.createElementVNode("span", {
        class: "official-result-subtitle"
    }, "\u6839\u636e\u9898\u5e72\u76f8\u4f3c\u5ea6\u6392\u5e8f", -1), Is = {
        class: "official-section"
    }, Ls = vue.createElementVNode("div", {
        class: "section-label"
    }, "\u9898\u5e72", -1), Os = [ "innerHTML" ], Fs = {
        key: 0,
        class: "official-section"
    }, Ps = vue.createElementVNode("div", {
        class: "section-label"
    }, "\u9009\u9879", -1), Ms = {
        class: "official-options"
    }, Vs = {
        class: "option-label"
    }, Ds = [ "innerHTML" ], Ns = {
        class: "official-section"
    }, Bs = vue.createElementVNode("div", {
        class: "section-label"
    }, "\u53c2\u8003\u7b54\u6848", -1), Gs = {
        class: "answer-chips"
    }, Rs = {
        key: 0,
        class: "answer-empty"
    }, Js = vue.createElementVNode("div", {
        class: "card-header"
    }, [ vue.createElementVNode("span", {
        class: "card-title"
    }, "\u2139\ufe0f \u670d\u52a1\u8bf4\u660e") ], -1), Qs = [ "innerHTML" ], Ws = vue.defineComponent({
        __name: "Ai",
        setup(e) {
            const t = getApp(), s = t.gpt[t.gptIndex], r = fs(), l = tn(), c = cn(), u = vue.ref(""), d = vue.ref("1"), m = [ {
                label: "\u5355\u9009\u9898",
                value: "0"
            }, {
                label: "\u591a\u9009\u9898",
                value: "1"
            }, {
                label: "\u586b\u7a7a\u9898",
                value: "2"
            }, {
                label: "\u5224\u65ad\u9898",
                value: "3"
            }, {
                label: "\u7b80\u7b54\u9898",
                value: "4"
            }, {
                label: "\u5176\u5b83/\u81ea\u52a8",
                value: "8"
            } ], h = vue.ref(m[0].value), f = vue.ref(!1), g = vue.ref([]), y = vue.ref(!1), w = vue.ref(""), U = vue.ref(!1), E = vue.ref({
                question: "",
                options: []
            }), $ = vue.ref(!1), I = vue.computed((() => "1" === d.value)), O = vue.computed((() => I.value ? r.aiLoading : y.value)), F = vue.computed((() => O.value ? "\u641c\u7d22\u4e2d..." : "\u5f00\u59cb\u641c\u7d22")), P = m.reduce(((e, t) => (e[t.value] = t.label.replace("/\u81ea\u52a8", ""), 
            e)), {}), formatAnswer = e => {
                if (Array.isArray(e)) return e.map((e => "string" == typeof e ? e.trim() : String(e).trim())).filter(Boolean);
                if ("object" == typeof e && null !== e) return Object.values(e).map((e => "string" == typeof e ? e.trim() : String(e).trim())).filter(Boolean);
                if ("string" == typeof e) {
                    const t = e.replace(/[\r\n]+/g, " ").trim();
                    return t ? /[,\uff0c\u3001/;\uff1b\s]/.test(t) ? t.split(/[,\uff0c\u3001/;\uff1b\s]+/).map((e => e.trim())).filter(Boolean) : [ t ] : [];
                }
                return [];
            };
            vue.watch(d, (e => {
                "1" === e ? (g.value = [], w.value = "", U.value = !1, E.value = {
                    question: "",
                    options: []
                }, y.value = !1, f.value = !1, h.value = m[0].value, $.value = !1) : r.resetAi();
            }));
            const handleOfficialSearch = async e => {
                const t = (e => {
                    const t = e.replace(/\r/g, "\n").split("\n").map((e => e.trim())).filter(Boolean), n = /^[A-Ha-h][\.\u3001\)\uff0e\u3002]?\s*/, a = [], o = [];
                    let s = !1;
                    return t.forEach((e => {
                        n.test(e) ? (s = !0, o.push(e.replace(n, "").trim())) : s && o.length ? o[o.length - 1] = `${o[o.length - 1]} ${e}`.trim() : a.push(e);
                    })), {
                        question: a.join(" ").replace(/^\d+[\.\u3001\uff0e\s]+/, "").trim(),
                        options: o.filter(Boolean)
                    };
                })(e);
                if (t.question) {
                    var n, a;
                    n = t.question, a = t.options, f.value || (h.value = ((e, t) => {
                        const n = e.replace(/\s/g, "");
                        return /\u591a\u9009|\u591a\u9879|\u9009\u62e9[\u4e24\u4e8c\u4e8c]?/.test(n) ? "1" : /\u5224\u65ad|\u6b63\u8bef|\u5bf9\u9519|\u662f\u975e/.test(n) ? "3" : /\u586b\u7a7a|\u7a7a\u683c|\u586b\u8865|\uff08\s*\uff09/.test(e) || /\(\s*\)/.test(e) ? "2" : /\u7b80\u7b54|\u7b80\u8ff0|\u8bba\u8ff0|\u8bf4\u660e|\u5206\u6790|\u4e3a\u4f55|\u4e3a\u4ec0\u4e48/.test(n) ? "4" : t.length >= 1 ? 2 === t.length && t.every((e => /(\u6b63\u786e|\u9519\u8bef|\u5bf9|\u9519)/.test(e))) ? "3" : t.length > 1 && /\u591a\u9009/.test(e) ? "1" : "0" : "8";
                    })(n, a)), E.value = t, U.value = !0, y.value = !0, w.value = "", $.value = !1, 
                    g.value = [];
                    try {
                        const {success: e, message: n, data: a, needLogin: o} = await c.fuzzySearchQuestion({
                            question: t.question,
                            type: Number(h.value),
                            options: t.options
                        });
                        e ? (g.value = a, a.length || (w.value = "\u5b98\u65b9\u9898\u5e93\u6682\u672a\u6536\u5f55\u8be5\u9898\uff0c\u53ef\u5c1d\u8bd5\u8865\u5145\u9898\u5e72\u6216\u8c03\u6574\u9898\u578b"), 
                        $.value = !1) : (w.value = n, $.value = !!o || /\u767b\u5f55/.test(n), msg(n, "warning"));
                    } catch (o) {
                        const e = (null == o ? void 0 : o.message) || "\u5b98\u65b9\u9898\u5e93\u641c\u7d22\u5931\u8d25\uff0c\u8bf7\u7a0d\u540e\u91cd\u8bd5";
                        w.value = e, $.value = /\u767b\u5f55/.test(e), msg(e, "error");
                    } finally {
                        y.value = !1;
                    }
                } else msg("\u8bf7\u5148\u8f93\u5165\u5b8c\u6574\u7684\u9898\u5e72\u5185\u5bb9", "warning");
            }, search = async () => {
                const e = u.value.trim();
                e ? I.value ? await (async e => {
                    r.resetAi(), r.aiLoading = !0;
                    try {
                        await aiAsk(e, (e => {
                            r.aiLoading = !1, r.aiMsg += e, console.log(r.aiMsg);
                        }), (() => {
                            r.aiMsg.length <= 0 && (r.aiMsg = s.msg);
                        }), "\u4f60\u662f\u4e00\u4e2a\u4e13\u4e1a\u7684\u7b54\u9898\u52a9\u624b\uff0c\u8bf7\u6839\u636e\u7528\u6237\u63d0\u4f9b\u7684\u9898\u76ee\u8fdb\u884c\u89e3\u7b54\u3002\n\n\u8981\u6c42\uff1a\n1. \u4ed4\u7ec6\u5206\u6790\u9898\u76ee\u5185\u5bb9\uff0c\u7406\u89e3\u9898\u76ee\u8981\u6c42\n2. \u63d0\u4f9b\u51c6\u786e\u3001\u7b80\u6d01\u7684\u7b54\u6848\n3. \u5982\u679c\u662f\u9009\u62e9\u9898\uff0c\u8bf7\u76f4\u63a5\u7ed9\u51fa\u6b63\u786e\u9009\u9879\uff08\u5982\uff1aA\u3001B\u3001C\u3001D\u6216\u591a\u9009\u7ec4\u5408\uff09\n4. \u5982\u679c\u662f\u586b\u7a7a\u9898\u6216\u7b80\u7b54\u9898\uff0c\u8bf7\u7ed9\u51fa\u7b80\u660e\u627c\u8981\u7684\u7b54\u6848\n5. \u5982\u679c\u9898\u76ee\u4e0d\u6e05\u6670\u6216\u65e0\u6cd5\u786e\u5b9a\u7b54\u6848\uff0c\u8bf7\u8bf4\u660e\u539f\u56e0\n6. \u56de\u7b54\u8981\u6709\u6761\u7406\uff0c\u5fc5\u8981\u65f6\u53ef\u4ee5\u7b80\u8981\u8bf4\u660e\u7406\u7531\n\n\u8bf7\u5f00\u59cb\u89e3\u7b54\uff1a");
                    } catch (t) {
                        console.error("AI\u68c0\u7d22\u8d85\u65f6\uff0c\u53ef\u80fd\u662f\u7f51\u7edc\u95ee\u9898\u6216\u8005\u5bf9\u5e94GPT\u7684cookie\u5931\u6548", t), 
                        r.aiMsg = s.msg;
                    } finally {
                        r.aiLoading = !1;
                    }
                })(e) : await handleOfficialSearch(e) : msg("\u8bf7\u8f93\u5165\u9898\u76ee\u6216\u95ee\u9898\u5185\u5bb9", "warning");
            }, onQuestionTypeChange = () => {
                f.value = !0;
            }, M = [ {
                label: "AI\u68c0\u7d22",
                value: "1",
                key: "ai"
            }, {
                label: "\u7231\u95ee\u7b54\u9898\u5e93",
                value: "2",
                key: "ask"
            } ];
            return (e, t) => {
                const i = vue.resolveComponent("el-input"), c = vue.resolveComponent("el-radio-button"), p = vue.resolveComponent("el-radio-group"), f = vue.resolveComponent("el-option"), v = vue.resolveComponent("el-select"), I = vue.resolveComponent("el-icon"), V = vue.resolveComponent("el-button"), D = vue.resolveComponent("el-card"), N = vue.resolveComponent("el-tag"), B = vue.resolveComponent("el-empty"), G = vue.resolveComponent("el-link"), R = vue.resolveComponent("el-alert"), J = vue.resolveComponent("el-descriptions-item"), Q = vue.resolveComponent("el-descriptions"), W = vue.resolveDirective("loading");
                return vue.openBlock(), vue.createElementBlock("div", gs, [ vue.createVNode(D, {
                    class: "search-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ ys ])),
                    default: vue.withCtx((() => [ vue.createVNode(i, {
                        modelValue: u.value,
                        "onUpdate:modelValue": t[0] || (t[0] = e => u.value = e),
                        type: "textarea",
                        placeholder: "\u8bf7\u8f93\u5165\u9898\u76ee\u6216\u95ee\u9898\uff0cAI\u5c06\u4e3a\u60a8\u63d0\u4f9b\u8be6\u7ec6\u89e3\u7b54...",
                        rows: 5,
                        autosize: {
                            minRows: 5,
                            maxRows: 10
                        },
                        style: {
                            "margin-bottom": "16px"
                        }
                    }, null, 8, [ "modelValue" ]), vue.createElementVNode("div", ws, [ vue.createVNode(p, {
                        modelValue: d.value,
                        "onUpdate:modelValue": t[1] || (t[1] = e => d.value = e),
                        size: "default"
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(M, (e => vue.createVNode(c, {
                            value: e.value,
                            key: e.value
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                            _: 2
                        }, 1032, [ "value" ]))), 64)) ])),
                        _: 1
                    }, 8, [ "modelValue" ]) ]), "2" === d.value ? (vue.openBlock(), vue.createElementBlock("div", vs, [ vue.createVNode(v, {
                        modelValue: h.value,
                        "onUpdate:modelValue": t[2] || (t[2] = e => h.value = e),
                        placeholder: "\u8bf7\u9009\u62e9\u9898\u578b",
                        size: "default",
                        onChange: onQuestionTypeChange
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(m, (e => vue.createVNode(f, {
                            key: e.value,
                            label: e.label,
                            value: e.value
                        }, null, 8, [ "label", "value" ]))), 64)) ])),
                        _: 1
                    }, 8, [ "modelValue" ]), bs ])) : vue.createCommentVNode("", !0), vue.createVNode(V, {
                        type: "primary",
                        size: "large",
                        style: {
                            width: "100%",
                            "margin-top": "16px"
                        },
                        onClick: search,
                        loading: O.value
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(I, {
                            style: {
                                "margin-right": "8px"
                            }
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(vue.unref(me)) ])),
                            _: 1
                        }), vue.createTextVNode(" " + vue.toDisplayString(F.value), 1) ])),
                        _: 1
                    }, 8, [ "loading" ]) ])),
                    _: 1
                }), "1" === d.value && (vue.unref(r).aiMsg || vue.unref(r).aiLoading) ? (vue.openBlock(), vue.createBlock(D, {
                    key: 0,
                    class: "result-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ vue.createElementVNode("div", xs, [ _s, vue.unref(r).aiLoading ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createBlock(N, {
                        key: 0,
                        type: "success",
                        size: "small"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode("\u89e3\u7b54\u5b8c\u6210") ])),
                        _: 1
                    })) ]) ])),
                    default: vue.withCtx((() => [ vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", ks, [ !vue.unref(r).aiLoading && vue.unref(r).aiMsg ? (vue.openBlock(), 
                    vue.createElementBlock("div", {
                        key: 0,
                        innerHTML: vue.unref(r).currentAiMd(),
                        class: "markdown-body"
                    }, null, 8, qs)) : vue.unref(r).aiLoading ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createBlock(B, {
                        key: 1,
                        description: "AI\u7b54\u9898\u4ec5\u4f9b\u53c2\u8003\uff0c\u4e0d\u4fdd\u8bc1\u51c6\u786e\u6027"
                    })) ])), [ [ W, vue.unref(r).aiLoading ] ]) ])),
                    _: 1
                })) : vue.createCommentVNode("", !0), "2" === d.value ? (vue.openBlock(), vue.createBlock(D, {
                    key: 1,
                    class: "result-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ vue.createElementVNode("div", Cs, [ Ts, y.value ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createBlock(N, {
                        key: 0,
                        type: g.value.length ? "success" : "info",
                        size: "small"
                    }, {
                        default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(g.value.length ? "\u5339\u914d\u5b8c\u6210" : "\u7b49\u5f85\u641c\u7d22"), 1) ])),
                        _: 1
                    }, 8, [ "type" ])) ]) ])),
                    default: vue.withCtx((() => [ vue.withDirectives((vue.openBlock(), vue.createElementBlock("div", As, [ w.value ? (vue.openBlock(), vue.createBlock(R, {
                        key: 0,
                        type: "warning",
                        "show-icon": "",
                        closable: !1,
                        class: "official-alert"
                    }, {
                        title: vue.withCtx((() => [ vue.createElementVNode("span", {
                            innerHTML: w.value
                        }, null, 8, Ss), $.value ? (vue.openBlock(), vue.createBlock(G, {
                            key: 0,
                            type: "primary",
                            onClick: t[3] || (t[3] = e => vue.unref(l).setPage("user")),
                            style: {
                                "margin-left": "8px"
                            }
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u70b9\u51fb\u767b\u5f55 ") ])),
                            _: 1
                        })) : vue.createCommentVNode("", !0) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), E.value.question ? (vue.openBlock(), vue.createBlock(Q, {
                        key: 1,
                        column: 1,
                        size: "small",
                        border: "",
                        class: "official-meta"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(J, {
                            label: "\u89e3\u6790\u9898\u5e72"
                        }, {
                            default: vue.withCtx((() => [ vue.createElementVNode("span", {
                                innerHTML: E.value.question
                            }, null, 8, Hs) ])),
                            _: 1
                        }), E.value.options.length ? (vue.openBlock(), vue.createBlock(J, {
                            key: 0,
                            label: "\u89e3\u6790\u9009\u9879"
                        }, {
                            default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(E.value.options, ((e, t) => (vue.openBlock(), vue.createElementBlock("div", {
                                key: `parsed-${t}`,
                                class: "meta-option"
                            }, [ vue.createElementVNode("span", Us, vue.toDisplayString(String.fromCharCode(65 + t)) + ".", 1), vue.createElementVNode("span", {
                                class: "option-text",
                                innerHTML: e
                            }, null, 8, Es) ])))), 128)) ])),
                            _: 1
                        })) : vue.createCommentVNode("", !0) ])),
                        _: 1
                    })) : vue.createCommentVNode("", !0), g.value.length ? (vue.openBlock(), vue.createBlock(vue.TransitionGroup, {
                        key: 2,
                        name: "fade-slide",
                        tag: "div",
                        class: "official-result-list"
                    }, {
                        default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(g.value, ((e, t) => (vue.openBlock(), vue.createElementBlock("div", {
                            key: `official-${t}`,
                            class: "official-result-item"
                        }, [ vue.createElementVNode("div", zs, [ vue.createElementVNode("div", null, [ vue.createElementVNode("span", $s, "\u5339\u914d\u9898\u76ee " + vue.toDisplayString(t + 1), 1), js ]), vue.createVNode(N, {
                            size: "small",
                            effect: "plain"
                        }, {
                            default: vue.withCtx((() => {
                                return [ vue.createTextVNode(vue.toDisplayString((t = e.type, P[String(t)] || "\u5176\u5b83\u9898\u578b")), 1) ];
                                var t;
                            })),
                            _: 2
                        }, 1024) ]), vue.createElementVNode("div", Is, [ Ls, vue.createElementVNode("div", {
                            class: "official-question",
                            innerHTML: e.question
                        }, null, 8, Os) ]), e.options && e.options.length ? (vue.openBlock(), vue.createElementBlock("div", Fs, [ Ps, vue.createElementVNode("ul", Ms, [ (vue.openBlock(!0), 
                        vue.createElementBlock(vue.Fragment, null, vue.renderList(e.options, ((e, s) => (vue.openBlock(), vue.createElementBlock("li", {
                            key: `opt-${t}-${s}`
                        }, [ vue.createElementVNode("span", Vs, vue.toDisplayString(String.fromCharCode(65 + s)) + ".", 1), vue.createElementVNode("span", {
                            class: "option-text",
                            innerHTML: e
                        }, null, 8, Ds) ])))), 128)) ]) ])) : vue.createCommentVNode("", !0), vue.createElementVNode("div", Ns, [ Bs, vue.createElementVNode("div", Gs, [ (vue.openBlock(!0), 
                        vue.createElementBlock(vue.Fragment, null, vue.renderList(formatAnswer(e.answer), ((e, a) => (vue.openBlock(), vue.createBlock(N, {
                            key: `answer-${t}-${a}`,
                            size: "small",
                            type: "success",
                            effect: "dark"
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e), 1) ])),
                            _: 2
                        }, 1024)))), 128)), formatAnswer(e.answer).length ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createElementBlock("span", Rs, "\u6682\u65e0\u7b54\u6848\u4fe1\u606f")) ]) ]) ])))), 128)) ])),
                        _: 1
                    })) : U.value && !w.value ? (vue.openBlock(), vue.createBlock(B, {
                        key: 3,
                        description: "\u5b98\u65b9\u9898\u5e93\u6682\u672a\u5339\u914d\u5230\u7ed3\u679c\uff0c\u5c1d\u8bd5\u4f18\u5316\u9898\u5e72\u6216\u8c03\u6574\u9898\u578b"
                    })) : w.value ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createBlock(B, {
                        key: 4,
                        description: "\u8f93\u5165\u9898\u5e72\u5e76\u70b9\u51fb\u641c\u7d22\uff0c\u5373\u53ef\u5339\u914d\u5b98\u65b9\u9898\u5e93"
                    })) ])), [ [ W, y.value ] ]) ])),
                    _: 1
                })) : vue.createCommentVNode("", !0), "1" === d.value ? (vue.openBlock(), vue.createBlock(D, {
                    key: 2,
                    class: "copyright-card",
                    shadow: "hover"
                }, {
                    header: vue.withCtx((() => [ Js ])),
                    default: vue.withCtx((() => [ vue.createElementVNode("div", {
                        class: "copyright-content",
                        innerHTML: vue.unref(markToHtml)(`\u5f53\u524d\u91c7\u7528\u7684\u662f **${vue.unref(s).name}** \u670d\u52a1\uff0c\u4ec5\u4f9b\u6d4b\u8bd5\u4f7f\u7528\uff0c\u4e0d\u4fdd\u8bc1\u51c6\u786e\u6027\u3002\n    \n\u5982\u6709\u4fb5\u6743\uff0c\u8bf7\u8054\u7cfb\u6211\u4eec\u5220\u9664\u3002\n    \n\u8bf7\u5927\u5bb6\u591a\u591a\u652f\u6301\u5b98\u65b9\uff1a[${vue.unref(s).home}](${vue.unref(s).home})`)
                    }, null, 8, Qs) ])),
                    _: 1
                })) : vue.createCommentVNode("", !0) ]);
            };
        }
    }), Ks = {
        key: 2,
        style: {
            width: "calc(100% - 130px)",
            "margin-left": "10px"
        }
    }, Ys = {
        key: 0,
        style: {
            color: "red",
            "margin-top": "5px"
        }
    }, Xs = vue.defineComponent({
        __name: "ParamTable",
        props: {
            data: {},
            presetValues: {}
        },
        setup(e) {
            const t = e.presetValues || [];
            return (e, o) => {
                const s = vue.resolveComponent("el-input"), i = vue.resolveComponent("el-table-column"), r = vue.resolveComponent("el-option"), l = vue.resolveComponent("el-select"), c = vue.resolveComponent("el-button"), p = vue.resolveComponent("el-table");
                return vue.openBlock(), vue.createElementBlock("div", null, [ vue.createVNode(p, {
                    data: e.data,
                    border: ""
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(i, {
                        label: "Key",
                        width: "200"
                    }, {
                        default: vue.withCtx((({row: e}) => [ vue.createVNode(s, {
                            modelValue: e.key,
                            "onUpdate:modelValue": t => e.key = t,
                            placeholder: "Key",
                            style: {
                                width: "100%"
                            }
                        }, null, 8, [ "modelValue", "onUpdate:modelValue" ]) ])),
                        _: 1
                    }), vue.createVNode(i, {
                        label: "Value"
                    }, {
                        default: vue.withCtx((({row: e}) => [ vue.createVNode(l, {
                            modelValue: e.valueType,
                            "onUpdate:modelValue": t => e.valueType = t,
                            placeholder: "Value Type",
                            style: {
                                width: "120px"
                            }
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(r, {
                                label: "\u5185\u7f6e\u503c",
                                value: "preset"
                            }), vue.createVNode(r, {
                                label: "\u81ea\u5b9a\u4e49",
                                value: "custom"
                            }) ])),
                            _: 2
                        }, 1032, [ "modelValue", "onUpdate:modelValue" ]), "custom" === e.valueType ? (vue.openBlock(), 
                        vue.createBlock(s, {
                            key: 0,
                            modelValue: e.value,
                            "onUpdate:modelValue": t => e.value = t,
                            placeholder: "Value",
                            style: {
                                width: "calc(100% - 130px)",
                                "margin-left": "10px"
                            }
                        }, null, 8, [ "modelValue", "onUpdate:modelValue" ])) : vue.createCommentVNode("", !0), "preset" === e.valueType ? (vue.openBlock(), 
                        vue.createBlock(l, {
                            key: 1,
                            modelValue: e.value,
                            "onUpdate:modelValue": t => e.value = t,
                            placeholder: "\u9009\u62e9\u5185\u7f6e\u503c",
                            style: {
                                width: "calc(100% - 130px)",
                                "margin-left": "10px"
                            }
                        }, {
                            default: vue.withCtx((() => [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t), (e => (vue.openBlock(), vue.createBlock(r, {
                                key: e.key,
                                label: e.label,
                                value: e.value
                            }, null, 8, [ "label", "value" ])))), 128)) ])),
                            _: 2
                        }, 1032, [ "modelValue", "onUpdate:modelValue" ])) : vue.createCommentVNode("", !0), "code" === e.valueType ? (vue.openBlock(), 
                        vue.createElementBlock("div", Ks, [ vue.createVNode(s, {
                            modelValue: e.value,
                            "onUpdate:modelValue": t => e.value = t,
                            placeholder: "\u8bf7\u8f93\u5165\u4ee3\u7801",
                            type: "textarea",
                            style: {
                                width: "100%"
                            }
                        }, null, 8, [ "modelValue", "onUpdate:modelValue" ]), vue.createVNode(c, {
                            size: "small",
                            type: "primary",
                            style: {
                                "margin-top": "5px"
                            },
                            onClick: t => (e => {
                                if ("code" === e.valueType) try {
                                    e.error = "";
                                    const t = new Function(`return ${e.value}`)();
                                    console.log("\u4ee3\u7801\u8fd0\u884c\u7ed3\u679c\uff1a", t), e.error = "";
                                } catch (t) {
                                    console.error("\u4ee3\u7801\u8fd0\u884c\u9519\u8bef\uff1a", t), e.error = `\u4ee3\u7801\u8fd0\u884c\u9519\u8bef: ${t.message}`;
                                }
                            })(e)
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" \u8fd0\u884c\u4ee3\u7801 ") ])),
                            _: 2
                        }, 1032, [ "onClick" ]), e.error ? (vue.openBlock(), vue.createElementBlock("div", Ys, vue.toDisplayString(e.error), 1)) : vue.createCommentVNode("", !0) ])) : vue.createCommentVNode("", !0) ])),
                        _: 1
                    }), vue.createVNode(i, {
                        label: "\u64cd\u4f5c",
                        width: "100"
                    }, {
                        default: vue.withCtx((({$index: t}) => [ vue.createVNode(c, {
                            size: "small",
                            onClick: n => e.$emit("remove", t)
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u5220\u9664") ])),
                            _: 2
                        }, 1032, [ "onClick" ]) ])),
                        _: 1
                    }) ])),
                    _: 1
                }, 8, [ "data" ]), vue.createVNode(c, {
                    size: "small",
                    onClick: o[0] || (o[0] = t => e.$emit("add"))
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode("\u6dfb\u52a0") ])),
                    _: 1
                }) ]);
            };
        }
    }), Zs = {
        key: 0
    }, ei = {
        key: 1
    }, ti = {
        key: 0,
        class: "error-message"
    }, ni = {
        key: 2
    }, ai = {
        class: "mt-30"
    }, oi = {
        key: 0
    }, si = {
        class: "json-preview",
        style: {
            "max-height": "300px",
            "overflow-y": "auto"
        }
    }, ii = {
        key: 1
    }, ri = [ "innerHTML" ], li = {
        key: 2
    }, ci = {
        style: {
            "max-height": "300px",
            "overflow-y": "auto"
        }
    }, pi = {
        style: {
            "max-height": "300px",
            "overflow-y": "auto"
        }
    }, ui = {
        style: {
            "max-height": "300px",
            "overflow-y": "auto"
        }
    }, di = {
        style: {
            "max-height": "300px",
            "overflow-y": "auto"
        }
    }, mi = {
        key: 2,
        class: "mt-10"
    }, hi = vue.createElementVNode("strong", null, "\u63d0\u53d6\u7684\u7b54\u6848\uff1a", -1), fi = {
        key: 3,
        class: "mt-10"
    }, gi = vue.defineComponent({
        __name: "ApiComponent",
        setup(e) {
            const t = [ "GET", "POST" ], s = vue.ref("POST"), r = vue.ref("http://cx.icodef.com/wyn-nb?v=4"), l = vue.ref([]), c = vue.ref([]), p = vue.ref('{\n    "question": "$question",\n    "options": "$options",\n    "type": "$type"\n}'), u = vue.ref([ {
                key: "question",
                value: "$question",
                valueType: "preset"
            }, {
                key: "options",
                value: "$options",
                valueType: "preset"
            }, {
                key: "type",
                value: "$type",
                valueType: "preset"
            } ]), d = vue.ref("json"), m = [ {
                label: "None",
                value: "none"
            }, {
                label: "JSON",
                value: "json"
            }, {
                label: "x-www-form-urlencoded",
                value: "urlencoded"
            } ], h = [ {
                key: "timestamp",
                label: "\u5f53\u524d\u65f6\u95f4\u6233",
                value: "$timestamp"
            }, {
                key: "random",
                label: "\u968f\u673a\u6570",
                value: "$random"
            }, {
                key: "question",
                label: "\u9898\u5e72",
                value: "$question"
            }, {
                key: "options",
                label: "\u9009\u9879",
                value: "$options"
            }, {
                key: "type",
                label: "\u9898\u578b",
                value: "$type"
            }, {
                key: "typename",
                label: "\u9898\u578b\u540d",
                value: "$typename"
            } ], f = {
                timestamp: Date.now(),
                random: Math.random(),
                question: "\u6025\u6027\u5417\u5561\u4e2d\u6bd2\u7684\u62ee\u6297\u5242\u662f:",
                options: [ "\u7eb3\u916a\u916e", "\u66f2\u9a6c\u6735", "\u5c3c\u83ab\u5730\u5e73", "\u963f\u6258\u54c1", "\u80be\u4e0a\u817a\u7d20" ],
                type: "0",
                typename: "\u5355\u9009\u9898"
            }, g = vue.ref({
                data: "",
                headers: "",
                raw: "",
                contentType: ""
            }), y = vue.ref(""), w = vue.ref("body"), q = vue.ref("body"), U = vue.ref(!0), z = vue.ref(!1), $ = vue.computed((() => [ "GET", "DELETE" ].includes(s.value)));
            function replacePresetValues(e, t) {
                if ("string" == typeof e) return e.replace(/\$(\w+)/g, ((e, n) => void 0 !== t[n] ? t[n] : `$${n}`));
                if (Array.isArray(e)) return e.map((e => replacePresetValues(e, t)));
                if ("object" == typeof e && null !== e) {
                    const n = {};
                    for (const a in e) n[a] = replacePresetValues(e[a], t);
                    return n;
                }
                return e;
            }
            function generateGMConfig() {
                const e = c.value.filter((e => e.key)).map((e => {
                    const t = replacePresetValues(e.value, f);
                    return `${encodeURIComponent(e.key)}=${encodeURIComponent(t)}`;
                })).join("&"), t = e ? `${r.value}?${e}` : r.value, n = {};
                l.value.forEach((({key: e, value: t}) => {
                    e && (n[e] = t);
                })), n["Content-Type"] = "json" === d.value ? "application/json" : "application/x-www-form-urlencoded";
                let a = null;
                if ("json" === d.value) try {
                    const e = replacePresetValues(JSON.parse(p.value || "{}"), f);
                    a = JSON.stringify(e);
                } catch (o) {
                    console.error("JSON \u89e3\u6790\u5931\u8d25\uff1a", o);
                } else if ("urlencoded" === d.value) {
                    a = u.value.map((e => ({
                        key: e.key,
                        value: replacePresetValues(e.value, f)
                    }))).filter((e => e.key)).map((e => `${encodeURIComponent(e.key)}=${encodeURIComponent(e.value)}`)).join("&");
                }
                return {
                    method: s.value,
                    url: t,
                    headers: n,
                    data: a
                };
            }
            function validateJson() {
                try {
                    JSON.parse(p.value), U.value = !0;
                } catch {
                    U.value = !1;
                }
            }
            function formatJson() {
                if (!U.value) return msg("JSON \u683c\u5f0f\u65e0\u6548\uff0c\u8bf7\u68c0\u67e5\uff01");
                p.value = JSON.stringify(JSON.parse(p.value), null, 2);
            }
            function addRow(e) {
                e.push({
                    key: "",
                    value: ""
                });
            }
            function removeRow(e, t) {
                e.splice(t, 1);
            }
            function sendRequest() {
                if ("json" === d.value && !U.value) return msg("JSON \u683c\u5f0f\u65e0\u6548\uff0c\u8bf7\u68c0\u67e5\uff01");
                z.value = !0;
                const e = generateGMConfig();
                ze({
                    method: e.method,
                    url: e.url,
                    headers: e.headers,
                    data: e.data || void 0,
                    onload: e => {
                        !function(e) {
                            var t;
                            const n = (null == (t = e.responseHeaders.match(/content-type:\s?([\w/+-]+)/i)) ? void 0 : t[1]) || "", a = function(e, t) {
                                if (t.includes("application/json")) try {
                                    return JSON.stringify(JSON.parse(e), null, 2);
                                } catch {
                                    return "\u65e0\u6cd5\u89e3\u6790\u7684 JSON \u6570\u636e";
                                }
                                return t.includes("text/html") || t.includes("text/plain") ? e : `\u65e0\u6cd5\u89e3\u6790\u7684\u54cd\u5e94\u7c7b\u578b\uff1a${t}`;
                            }(e.responseText, n);
                            y.value = JSON.stringify(generateGMConfig(), null, 2), g.value = {
                                data: a,
                                headers: e.responseHeaders,
                                raw: e.responseText,
                                contentType: n
                            };
                        }(e), z.value = !1;
                    },
                    onerror: e => {
                        !function(e) {
                            g.value = {
                                data: e.message || "\u8bf7\u6c42\u5931\u8d25",
                                headers: "",
                                raw: "",
                                contentType: ""
                            }, msg(`\u8bf7\u6c42\u9519\u8bef: ${e.message || "\u672a\u77e5\u9519\u8bef"}`);
                        }(e), z.value = !1;
                    }
                });
            }
            const j = vue.ref("data"), I = vue.ref('(res) => res.code === 1 ? /\u53db\u9006|\u516c\u4f17\u53f7|\u674e\u6052\u96c5|\u4e00\u4e4b/.test(res.data) ? null : res.data.replace(/javascript:void\\(0\\);/g, "").trim().replace(/\\n/g, "").split("#") : null'), L = vue.ref("field"), O = vue.ref("");
            function extractAnswer() {
                if (j.value || I.value) try {
                    const e = JSON.parse(g.value.data);
                    if ("function" === L.value) {
                        const t = new Function("res", `return (${I.value})(res);`);
                        O.value = t(e);
                    } else if (j.value) {
                        const t = function(e, t) {
                            const n = t.split(/\.|\[|\]/).filter((e => e));
                            let a = e;
                            for (const o of n) {
                                if (null == a) return;
                                a = isNaN(Number(o)) ? a[o] : a[Number(o)];
                            }
                            return a;
                        }(e, j.value);
                        O.value = void 0 !== t ? JSON.stringify(t, null, 2) : "\u63d0\u53d6\u7b54\u6848\u5931\u8d25\uff0c\u65e0\u6cd5\u627e\u5230\u5bf9\u5e94\u5b57\u6bb5\u7684\u7b54\u6848";
                    }
                } catch (e) {
                    O.value = "\u63d0\u53d6\u7b54\u6848\u5931\u8d25\uff0c\u8bf7\u68c0\u67e5 JSON \u6570\u636e\u6216\u63d0\u53d6\u903b\u8f91" + e;
                } else msg("\u8bf7\u586b\u5199\u7b54\u6848\u5b57\u6bb5\u8def\u5f84\u6216\u81ea\u5b9a\u4e49\u63d0\u53d6\u51fd\u6570\uff01");
            }
            function saveApi() {
                if (O.value.includes("\u63d0\u53d6\u7b54\u6848\u5931\u8d25")) return void msg("\u63d0\u53d6\u7b54\u6848\u5931\u8d25\uff0c\u65e0\u6cd5\u4fdd\u5b58\u63a5\u53e3\uff01");
                let e = {
                    method: s.value,
                    url: r.value
                };
                const t = {};
                if (l.value.forEach((({key: e, value: n}) => {
                    e && (t[e] = n);
                })), e.headers = t, "GET" === e.method) {
                    e.params = c.value, e.type = "get";
                    const t = c.value.filter((e => e.key)).map((e => {
                        const t = replacePresetValues(e.value, f);
                        return `${encodeURIComponent(e.key)}=${encodeURIComponent(t)}`;
                    })).join("&");
                    e.url = t ? `${r.value}?${t}` : r.value;
                } else if ("json" === d.value) e.data = JSON.parse(p.value), e.type = "json"; else if ("urlencoded" === d.value) {
                    const t = {};
                    for (const e of u.value) t[e.key] = e.value;
                    e.data = t, e.type = "urlencoded";
                }
                "field" === L.value ? e.response = {
                    type: "field",
                    value: j.value
                } : I.value && (e.response = {
                    type: "function",
                    value: I.value
                });
            }
            return (e, i) => {
                const f = vue.resolveComponent("el-alert"), v = vue.resolveComponent("el-option"), F = vue.resolveComponent("el-select"), P = vue.resolveComponent("el-col"), M = vue.resolveComponent("el-input"), V = vue.resolveComponent("el-button"), D = vue.resolveComponent("el-row"), N = vue.resolveComponent("el-tab-pane"), B = vue.resolveComponent("el-tabs"), G = vue.resolveComponent("el-divider"), R = vue.resolveComponent("el-radio"), J = vue.resolveComponent("el-radio-group"), Q = vue.resolveComponent("el-main"), W = vue.resolveComponent("el-container");
                return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [ vue.createVNode(f, {
                    title: "\u5f00\u53d1\u4e2d.....\u6682\u4e0d\u53ef\u7528",
                    type: "error"
                }), vue.createVNode(W, null, {
                    default: vue.withCtx((() => [ vue.createVNode(Q, {
                        class: "request-builder"
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(D, {
                            gutter: 20,
                            class: "mb-20"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(P, {
                                span: 6
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(F, {
                                    modelValue: s.value,
                                    "onUpdate:modelValue": i[0] || (i[0] = e => s.value = e),
                                    placeholder: "Method"
                                }, {
                                    default: vue.withCtx((() => [ (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(t, (e => vue.createVNode(v, {
                                        key: e,
                                        label: e,
                                        value: e
                                    }, null, 8, [ "label", "value" ]))), 64)) ])),
                                    _: 1
                                }, 8, [ "modelValue" ]) ])),
                                _: 1
                            }), vue.createVNode(P, {
                                span: 12
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(M, {
                                    modelValue: r.value,
                                    "onUpdate:modelValue": i[1] || (i[1] = e => r.value = e),
                                    placeholder: "URL",
                                    clearable: ""
                                }, null, 8, [ "modelValue" ]) ])),
                                _: 1
                            }), vue.createVNode(P, {
                                span: 6
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(V, {
                                    type: "primary",
                                    loading: z.value,
                                    onClick: sendRequest,
                                    class: "full-width"
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(" \u53d1\u9001\u8bf7\u6c42 ") ])),
                                    _: 1
                                }, 8, [ "loading" ]) ])),
                                _: 1
                            }) ])),
                            _: 1
                        }), vue.createVNode(B, {
                            modelValue: w.value,
                            "onUpdate:modelValue": i[10] || (i[10] = e => w.value = e),
                            class: "mb-20"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(N, {
                                label: "Query",
                                name: "query"
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(Xs, {
                                    data: c.value,
                                    "preset-values": h,
                                    onAdd: i[2] || (i[2] = e => addRow(c.value)),
                                    onRemove: i[3] || (i[3] = e => removeRow(c.value, e))
                                }, null, 8, [ "data" ]) ])),
                                _: 1
                            }), vue.createVNode(N, {
                                label: "Headers",
                                name: "headers"
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(Xs, {
                                    data: l.value,
                                    "preset-values": h,
                                    onAdd: i[4] || (i[4] = e => addRow(l.value)),
                                    onRemove: i[5] || (i[5] = e => removeRow(l.value, e))
                                }, null, 8, [ "data" ]) ])),
                                _: 1
                            }), vue.createVNode(N, {
                                label: "Body",
                                name: "body"
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(F, {
                                    modelValue: d.value,
                                    "onUpdate:modelValue": i[6] || (i[6] = e => d.value = e),
                                    placeholder: "Body \u7c7b\u578b",
                                    disabled: $.value,
                                    class: "mb-10"
                                }, {
                                    default: vue.withCtx((() => [ (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, vue.renderList(m, (e => vue.createVNode(v, {
                                        key: e.value,
                                        label: e.label,
                                        value: e.value
                                    }, null, 8, [ "label", "value" ]))), 64)) ])),
                                    _: 1
                                }, 8, [ "modelValue", "disabled" ]), "none" === d.value ? (vue.openBlock(), vue.createElementBlock("div", Zs, "\u65e0\u8bf7\u6c42\u4f53")) : "json" === d.value ? (vue.openBlock(), 
                                vue.createElementBlock("div", ei, [ vue.createVNode(M, {
                                    modelValue: p.value,
                                    "onUpdate:modelValue": i[7] || (i[7] = e => p.value = e),
                                    type: "textarea",
                                    placeholder: "JSON \u683c\u5f0f\u7684\u8bf7\u6c42\u4f53",
                                    rows: 10,
                                    class: vue.normalizeClass({
                                        "is-error": !U.value
                                    }),
                                    onInput: validateJson
                                }, null, 8, [ "modelValue", "class" ]), vue.createVNode(V, {
                                    type: "success",
                                    size: "small",
                                    onClick: formatJson
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode("\u683c\u5f0f\u5316 JSON") ])),
                                    _: 1
                                }), U.value ? vue.createCommentVNode("", !0) : (vue.openBlock(), vue.createElementBlock("p", ti, "JSON \u683c\u5f0f\u65e0\u6548\uff0c\u8bf7\u68c0\u67e5\uff01")) ])) : "urlencoded" === d.value ? (vue.openBlock(), 
                                vue.createElementBlock("div", ni, [ vue.createVNode(Xs, {
                                    data: u.value,
                                    "preset-values": h,
                                    onAdd: i[8] || (i[8] = e => addRow(u.value)),
                                    onRemove: i[9] || (i[9] = e => removeRow(u.value, e))
                                }, null, 8, [ "data" ]) ])) : vue.createCommentVNode("", !0) ])),
                                _: 1
                            }) ])),
                            _: 1
                        }, 8, [ "modelValue" ]), vue.createElementVNode("div", ai, [ vue.createVNode(B, {
                            modelValue: q.value,
                            "onUpdate:modelValue": i[11] || (i[11] = e => q.value = e)
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(N, {
                                label: "Body",
                                name: "body"
                            }, {
                                default: vue.withCtx((() => [ g.value.contentType.includes("application/json") ? (vue.openBlock(), vue.createElementBlock("div", oi, [ vue.createElementVNode("pre", si, vue.toDisplayString(g.value.data), 1) ])) : g.value.contentType.includes("text/html") ? (vue.openBlock(), 
                                vue.createElementBlock("div", ii, [ vue.createElementVNode("div", {
                                    innerHTML: g.value.data,
                                    style: {
                                        "max-height": "300px",
                                        "overflow-y": "auto"
                                    }
                                }, null, 8, ri) ])) : (vue.openBlock(), vue.createElementBlock("div", li, [ vue.createElementVNode("pre", ci, vue.toDisplayString(g.value.data), 1) ])) ])),
                                _: 1
                            }), vue.createVNode(N, {
                                label: "\u8bf7\u6c42\u53c2\u6570",
                                name: "request-headers"
                            }, {
                                default: vue.withCtx((() => [ vue.createElementVNode("pre", pi, vue.toDisplayString(y.value), 1) ])),
                                _: 1
                            }), vue.createVNode(N, {
                                label: "\u54cd\u5e94\u5934",
                                name: "response-headers"
                            }, {
                                default: vue.withCtx((() => [ vue.createElementVNode("pre", ui, vue.toDisplayString(g.value.headers), 1) ])),
                                _: 1
                            }), vue.createVNode(N, {
                                label: "\u539f\u59cb\u54cd\u5e94",
                                name: "raw"
                            }, {
                                default: vue.withCtx((() => [ vue.createElementVNode("pre", di, vue.toDisplayString(g.value.raw), 1) ])),
                                _: 1
                            }) ])),
                            _: 1
                        }, 8, [ "modelValue" ]) ]), vue.createVNode(G), vue.createElementVNode("div", null, [ vue.createVNode(f, {
                            title: "\u8bf7\u9009\u62e9\u63d0\u53d6\u7b54\u6848\u7684\u65b9\u5f0f\uff08\u5b57\u6bb5\u8def\u5f84\u6216\u81ea\u5b9a\u4e49\u51fd\u6570\uff09",
                            type: "info",
                            class: "mb-10"
                        }), vue.createVNode(J, {
                            modelValue: L.value,
                            "onUpdate:modelValue": i[12] || (i[12] = e => L.value = e),
                            class: "mb-10"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(R, {
                                value: "field"
                            }, {
                                default: vue.withCtx((() => [ vue.createTextVNode("\u5b57\u6bb5\u8def\u5f84") ])),
                                _: 1
                            }), vue.createVNode(R, {
                                value: "function"
                            }, {
                                default: vue.withCtx((() => [ vue.createTextVNode("\u81ea\u5b9a\u4e49\u51fd\u6570") ])),
                                _: 1
                            }) ])),
                            _: 1
                        }, 8, [ "modelValue" ]), "field" === L.value ? (vue.openBlock(), vue.createBlock(M, {
                            key: 0,
                            modelValue: j.value,
                            "onUpdate:modelValue": i[13] || (i[13] = e => j.value = e),
                            placeholder: "\u5b57\u6bb5\u8def\u5f84\uff08\u5982\uff1adata.answer \u6216 data[0].answer\uff09",
                            clearable: ""
                        }, null, 8, [ "modelValue" ])) : vue.createCommentVNode("", !0), "function" === L.value ? (vue.openBlock(), vue.createBlock(M, {
                            key: 1,
                            modelValue: I.value,
                            "onUpdate:modelValue": i[14] || (i[14] = e => I.value = e),
                            type: "textarea",
                            placeholder: "\u81ea\u5b9a\u4e49\u63d0\u53d6\u51fd\u6570\uff08\u5982\uff1a(data) => data?.data?.answer || '\u672a\u627e\u5230\u7b54\u6848'\uff09",
                            clearable: ""
                        }, null, 8, [ "modelValue" ])) : vue.createCommentVNode("", !0), vue.createVNode(V, {
                            type: "primary",
                            size: "small",
                            onClick: extractAnswer
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u63d0\u53d6\u7b54\u6848") ])),
                            _: 1
                        }), O.value ? (vue.openBlock(), vue.createElementBlock("p", mi, [ hi, vue.createTextVNode(" " + vue.toDisplayString(O.value), 1) ])) : vue.createCommentVNode("", !0), O.value ? (vue.openBlock(), 
                        vue.createElementBlock("p", fi, [ vue.createVNode(V, {
                            type: "success",
                            size: "small",
                            onClick: saveApi
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode("\u4fdd\u5b58\u63a5\u53e3") ])),
                            _: 1
                        }) ])) : vue.createCommentVNode("", !0) ]) ])),
                        _: 1
                    }) ])),
                    _: 1
                }) ], 64);
            };
        }
    }), yi = vue.createElementVNode("h1", {
        class: "text-4xl font-bold"
    }, "\u63a5\u53e3\u5217\u8868", -1), wi = {
        key: 1,
        class: "text-center"
    }, vi = [ vue.createElementVNode("h1", {
        class: "text-4xl font-bold"
    }, "\u5f00\u53d1\u4e2d...", -1), vue.createElementVNode("p", {
        class: "text-lg text-gray-500"
    }, "\u656c\u8bf7\u671f\u5f85", -1) ], bi = vue.defineComponent({
        __name: "Api",
        setup(e) {
            const t = $e[Kt + "api"];
            return vue.ref([ {
                id: 1,
                name: "\u5f20\u4e09",
                age: 25,
                address: "\u4e0a\u6d77"
            }, {
                id: 2,
                name: "\u674e\u56db",
                age: 30,
                address: "\u5317\u4eac"
            }, {
                id: 3,
                name: "\u738b\u4e94",
                age: 28,
                address: "\u5e7f\u5dde"
            } ]), (e, s) => (vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [ vue.createElementVNode("div", null, [ yi, vue.createElementVNode("ul", null, [ (vue.openBlock(!0), 
            vue.createElementBlock(vue.Fragment, null, vue.renderList(vue.unref(t).getApiList, (e => (vue.openBlock(), vue.createElementBlock("li", {
                key: e.id
            }, vue.toDisplayString(e.name), 1)))), 128)) ]) ]), vue.unref(false) ? (vue.openBlock(), vue.createBlock(gi, {
                key: 0
            })) : (vue.openBlock(), vue.createElementBlock("div", wi, vi)) ], 64));
        }
    }), xi = {
        class: "user-page"
    }, _i = {
        key: 0,
        class: "user-page__login-box"
    }, ki = {
        class: "user-page__login-header"
    }, qi = vue.createElementVNode("h2", null, "\u7528\u6237\u767b\u5f55", -1), Ci = vue.createElementVNode("p", null, "\u767b\u5f55\u540e\u5373\u53ef\u4f7f\u7528\u5b8c\u6574\u529f\u80fd", -1), Ti = {
        class: "user-page__register-tip"
    }, Ai = {
        key: 1,
        class: "user-page__dashboard"
    }, Si = {
        class: "user-page__header-card"
    }, Hi = {
        class: "user-page__info-text"
    }, Ui = {
        class: "user-page__username"
    }, Ei = {
        class: "user-page__stats-grid"
    }, zi = {
        class: "user-page__stat-card"
    }, $i = {
        class: "user-page__stat-icon user-page__stat-icon--coin"
    }, ji = {
        class: "user-page__stat-content"
    }, Ii = vue.createElementVNode("p", {
        class: "user-page__stat-label"
    }, "\u79ef\u5206", -1), Li = {
        class: "user-page__stat-value"
    }, Oi = {
        class: "user-page__stat-card"
    }, Fi = {
        class: "user-page__stat-icon user-page__stat-icon--money"
    }, Pi = {
        class: "user-page__stat-content"
    }, Mi = vue.createElementVNode("p", {
        class: "user-page__stat-label"
    }, "\u4f59\u989d", -1), Vi = {
        class: "user-page__stat-value"
    }, Di = {
        class: "user-page__stat-card"
    }, Ni = {
        class: "user-page__stat-icon user-page__stat-icon--course"
    }, Bi = {
        class: "user-page__stat-content"
    }, Gi = vue.createElementVNode("p", {
        class: "user-page__stat-label"
    }, "\u8d21\u732e\u8bfe\u7a0b", -1), Ri = {
        class: "user-page__stat-value"
    }, Ji = {
        class: "user-page__stat-card"
    }, Qi = {
        class: "user-page__stat-icon user-page__stat-icon--question"
    }, Wi = {
        class: "user-page__stat-content"
    }, Ki = vue.createElementVNode("p", {
        class: "user-page__stat-label"
    }, "\u8d21\u732e\u9898\u76ee", -1), Yi = {
        class: "user-page__stat-value"
    }, Xi = {
        class: "user-page__actions"
    }, Zi = vue.createElementVNode("div", {
        class: "user-page__tips"
    }, [ vue.createElementVNode("p", null, "\u5f53\u524d\u7528\u6237\u4f53\u7cfb\u4ec5\u7528\u4e8e\u9898\u5e93\u7f13\u5b58\u4e91\u540c\u6b65\uff0c\u66f4\u591a\u529f\u80fd\u5f00\u53d1\u4e2d") ], -1), er = vue.defineComponent({
        __name: "User",
        setup(e) {
            const t = cn(), s = vue.ref({
                username: "",
                password: ""
            }), r = vue.ref(!1), l = vue.computed((() => t.isLoggedIn)), handleLogin = async () => {
                r.value = !0;
                try {
                    if (!s.value.username || !s.value.password) return void D.ElMessage.warning("\u8bf7\u8f93\u5165\u7528\u6237\u540d\u548c\u5bc6\u7801");
                    const e = await t.loginByPassword(s.value.username, s.value.password);
                    e.success ? (D.ElMessage.success(e.message), s.value = {
                        username: "",
                        password: ""
                    }) : D.ElMessage.error(e.message);
                } finally {
                    r.value = !1;
                }
            }, handleLogout = async () => {
                D.ElMessageBox.confirm("\u786e\u5b9a\u8981\u9000\u51fa\u767b\u5f55\u5417\uff1f", "\u63d0\u793a", {
                    confirmButtonText: "\u786e\u5b9a",
                    cancelButtonText: "\u53d6\u6d88",
                    type: "warning"
                }).then((async () => {
                    await t.logout(), D.ElMessage.success("\u5df2\u9000\u51fa\u767b\u5f55");
                })).catch((() => {}));
            }, goToRegister = () => {
                window.open("https://www.aiask.site/user/register", "_blank");
            };
            return vue.onMounted((() => {
                l.value && t.fetchUserInfo();
            })), (e, i) => {
                var c;
                const p = vue.resolveComponent("el-icon"), u = vue.resolveComponent("el-input"), d = vue.resolveComponent("el-form-item"), m = vue.resolveComponent("el-form"), h = vue.resolveComponent("el-button"), f = vue.resolveComponent("el-link"), g = vue.resolveComponent("el-avatar"), y = vue.resolveComponent("el-tag");
                return vue.openBlock(), vue.createElementBlock("div", xi, [ l.value ? (vue.openBlock(), vue.createElementBlock("div", Ai, [ vue.createElementVNode("div", Si, [ vue.createVNode(g, {
                    size: 60,
                    src: vue.unref(t).avatar,
                    class: "user-page__avatar"
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(p, null, {
                        default: vue.withCtx((() => [ vue.createVNode(vue.unref(ye)) ])),
                        _: 1
                    }) ])),
                    _: 1
                }, 8, [ "src" ]), vue.createElementVNode("div", Hi, [ vue.createElementVNode("h2", null, vue.toDisplayString(vue.unref(t).nickname), 1), vue.createElementVNode("p", Ui, "@" + vue.toDisplayString(vue.unref(t).username), 1), vue.unref(t).isVip ? (vue.openBlock(), 
                vue.createBlock(y, {
                    key: 0,
                    type: "warning",
                    size: "small"
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" VIP Lv." + vue.toDisplayString(vue.unref(t).level), 1) ])),
                    _: 1
                })) : (vue.openBlock(), vue.createBlock(y, {
                    key: 1,
                    type: "info",
                    size: "small"
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode("\u666e\u901a\u7528\u6237") ])),
                    _: 1
                })) ]) ]), vue.createElementVNode("div", Ei, [ vue.createElementVNode("div", zi, [ vue.createElementVNode("div", $i, [ vue.createVNode(p, null, {
                    default: vue.withCtx((() => [ vue.createVNode(vue.unref(Y)) ])),
                    _: 1
                }) ]), vue.createElementVNode("div", ji, [ Ii, vue.createElementVNode("p", Li, vue.toDisplayString(vue.unref(t).score), 1) ]) ]), vue.createElementVNode("div", Oi, [ vue.createElementVNode("div", Fi, [ vue.createVNode(p, null, {
                    default: vue.withCtx((() => [ vue.createVNode(vue.unref(Y)) ])),
                    _: 1
                }) ]), vue.createElementVNode("div", Pi, [ Mi, vue.createElementVNode("p", Vi, "\xa5" + vue.toDisplayString((null == (c = vue.unref(t).user) ? void 0 : c.money) || "0.00"), 1) ]) ]), vue.createElementVNode("div", Di, [ vue.createElementVNode("div", Ni, [ vue.createVNode(p, null, {
                    default: vue.withCtx((() => [ vue.createVNode(vue.unref(fe)) ])),
                    _: 1
                }) ]), vue.createElementVNode("div", Bi, [ Gi, vue.createElementVNode("p", Ri, vue.toDisplayString(vue.unref(t).stats.course_count), 1) ]) ]), vue.createElementVNode("div", Ji, [ vue.createElementVNode("div", Qi, [ vue.createVNode(p, null, {
                    default: vue.withCtx((() => [ vue.createVNode(vue.unref(Z)) ])),
                    _: 1
                }) ]), vue.createElementVNode("div", Wi, [ Ki, vue.createElementVNode("p", Yi, vue.toDisplayString(vue.unref(t).stats.question_count), 1) ]) ]) ]), vue.createElementVNode("div", Xi, [ vue.createVNode(h, {
                    type: "danger",
                    plain: "",
                    onClick: handleLogout,
                    size: "small"
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode("\u9000\u51fa\u767b\u5f55") ])),
                    _: 1
                }) ]) ])) : (vue.openBlock(), vue.createElementBlock("div", _i, [ vue.createElementVNode("div", ki, [ vue.createVNode(p, {
                    class: "user-page__login-icon"
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(vue.unref(ye)) ])),
                    _: 1
                }), qi, Ci ]), vue.createVNode(m, {
                    class: "user-page__login-form"
                }, {
                    default: vue.withCtx((() => [ vue.createVNode(d, null, {
                        default: vue.withCtx((() => [ vue.createVNode(u, {
                            modelValue: s.value.username,
                            "onUpdate:modelValue": i[0] || (i[0] = e => s.value.username = e),
                            placeholder: "\u8bf7\u8f93\u5165\u7528\u6237\u540d",
                            size: "large",
                            "prefix-icon": vue.unref(ye)
                        }, null, 8, [ "modelValue", "prefix-icon" ]) ])),
                        _: 1
                    }), vue.createVNode(d, null, {
                        default: vue.withCtx((() => [ vue.createVNode(u, {
                            modelValue: s.value.password,
                            "onUpdate:modelValue": i[1] || (i[1] = e => s.value.password = e),
                            type: "password",
                            placeholder: "\u8bf7\u8f93\u5165\u5bc6\u7801",
                            size: "large",
                            "prefix-icon": vue.unref(le),
                            "show-password": "",
                            onKeyup: vue.withKeys(handleLogin, [ "enter" ])
                        }, null, 8, [ "modelValue", "prefix-icon" ]) ])),
                        _: 1
                    }) ])),
                    _: 1
                }), vue.createVNode(h, {
                    type: "primary",
                    size: "large",
                    loading: r.value,
                    onClick: handleLogin,
                    class: "user-page__login-btn"
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(r.value ? "\u767b\u5f55\u4e2d..." : "\u7acb\u5373\u767b\u5f55"), 1) ])),
                    _: 1
                }, 8, [ "loading" ]), vue.createElementVNode("div", Ti, [ vue.createTextVNode(" \u8fd8\u6ca1\u6709\u8d26\u53f7\uff1f "), vue.createVNode(f, {
                    type: "primary",
                    onClick: goToRegister,
                    underline: !1
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode(" \u524d\u5f80\u5b98\u7f51\u6ce8\u518c ") ])),
                    _: 1
                }) ]) ])), Zi ]);
            };
        }
    }), mk_block = (e, t = "\n\n", n) => {
        var a = new String(e);
        return a.trailing = t, a.lineNumber = n, (a = a.substr(0, 1).toUpperCase() + a.substr(1)).replace(/^([A-H]|\d+|\s+\d)[\u3001|\uff0e|\s\.|\s\uff0e|:|\uff1a]/, "$1.");
    }, getlineDetail = e => {
        for (var t = [], n = [ {
            key: "default",
            reg: /\*/
        }, {
            key: "title",
            reg: /^\s*(([0-9]+\.))\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "answer",
            reg: /^\s*((\[|\u3010?)(\u6b63\u786e|\u53c2\u8003|\u6807\u51c6|)\u7b54\u6848(\]|\u3011|\s+|)[:\uff1a\s])\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "analysis",
            reg: /^\s*(((\[|\u3010?)(\u8bd5\u9898|\u7b54\u6848?|)\u89e3\u6790(\]|\u3011|\s+|))[:\uff1a\s])\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_A",
            reg: /^\s*([A])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_B",
            reg: /^\s*([B])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_C",
            reg: /^\s*([C])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_D",
            reg: /^\s*([D])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_E",
            reg: /^\s*([E])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_F",
            reg: /^\s*([F])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_G",
            reg: /^\s*([G])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "options_H",
            reg: /^\s*([H])(\.)\s*(.*?)\s*(?:\n|$)/
        }, {
            key: "parent_question",
            reg: /\[\u6848\u4f8b\u5206\u6790\]/
        }, {
            key: "parent_question_wanxing",
            reg: /\[\u5b8c\u578b\u586b\u7a7a\]/
        }, {
            key: "parent_question_wanxing_end",
            reg: /\[\u5b8c\u578b\u586b\u7a7a\u7ed3\u675f\]/
        }, {
            key: "parent_question_end",
            reg: /\[\u6848\u4f8b\u5206\u6790\u7ed3\u675f\]/
        }, {
            key: "parent_question_b1",
            reg: /\[B1\]/
        }, {
            key: "parent_question_b1_end",
            reg: /\[B1\u7ed3\u675f\]/
        }, {
            key: "child_answer",
            reg: /\[\u7b54\u6848\]/
        } ], a = {}, o = "default", s = 0; s < e.length; s++) {
            var i = e[s], r = !1;
            (i.match(n[1].reg) || i.match(/\[\u6848\u4f8b\u5206\u6790\]/) || i.match(/\[\u5b8c\u578b\u586b\u7a7a\]/) || i.match(/\[B1\]/)) && a.title && (t.push(a), 
            a = {});
            for (var l = 0; l < n.length; l++) {
                var c = n[l];
                if (i.match(c.reg)) {
                    a[o = c.key] && (a.data_err = i), a[o] = i, r = !0;
                    break;
                }
                r = !1;
            }
            r || (a[o] = (a[o] || "") + "\n" + i);
        }
        return a.title && t.push(a), (e => {
            var t = !1, n = "", a = !1, o = "", s = [], i = "", r = !1;
            return e.forEach((function(e) {
                if (e.parent_question && (i = e.parent_question, r = !0, e.is_first_child = "1"), 
                r && (a = !1, t = !1, e.is_anli = "1", e.is_anli_child = "1", e.is_wanxing_child = "", 
                e.is_b1_child = "", e.parent_question = i), e.parent_question_end && (r = !1, i = ""), 
                e.parent_question_wanxing && (n = e.parent_question_wanxing, t = !0, e.is_first_child = "1"), 
                t && (r = !1, a = !1, e.is_anli_child = "", e.is_b1_child = "", e.is_wanxing_child = "1", 
                e.title += "\u586b\u7a7a\uff08" + e.title.substr(0, e.title.length - 1) + "\uff09", 
                e.parent_question_wanxing = n), e.parent_question_wanxing_end && (t = !1, n = ""), 
                e.parent_question_b1) {
                    for (var l in s = [], e) if (Object.hasOwnProperty.call(e, l)) {
                        var c = e[l];
                        if (l.indexOf("options_") > -1) {
                            var p = {};
                            p[l] = c, s.push(p);
                        }
                    }
                    a = !0, t = !1, r = !1, e.is_first_child = "1";
                }
                a && (r = !1, t = !1, e.is_b1_child = "1", e.is_wanxing_child = "", e.is_anli_child = "", 
                e.parent_question_b1 = o, s.forEach((function(t) {
                    Object.assign(e, t);
                }))), e.parent_question_b1_end && (a = !1, o = "");
            })), e;
        })(t);
    }, tr = {
        title: /^\s*([0-9]+\.)/,
        answer: /(&nbsp;)*\s*(\[|\u3010?)(\u7b54\u6848|\u6b63\u786e\u7b54\u6848|\u53c2\u8003\u7b54\u6848|\u6807\u51c6\u7b54\u6848)(\]|\u3011|\s+|)[:\uff1a\s]/,
        analysis: /(&nbsp;)*\s*(\[|\u3010?)(\u8bd5\u9898|\u7b54\u6848?|)\u89e3\u6790(\]|\u3011|\s+|)[:\uff1a\s]/,
        options_A: /A./,
        options_B: /B./,
        options_C: /C./,
        options_D: /D./,
        options_E: /E./,
        options_F: /F./,
        options_G: /G./,
        options_H: /H./
    }, nr = /^\s*(\u6b63\u786e|\u9519\u8bef|\u5bf9|\u9519|\u221a|\xd7|\u2713|X|x|T|F|true|TRUE|FALSE|false|YES|yes|NO|no|N|Y|n|y)\s*(?:\n|$)/i, ar = [ "A", "B", "C", "D", "E", "F", "G", "H" ], calcStatus = e => {
        if (e.title_value && (e.title_value = e.title_value.trim()), !e.title || e.title_value || e.parent_question) if (e.data_err) e.err_text = "\u8bf7\u68c0\u67e5\u8bd5\u9898\u5185\u5bb9"; else {
            var t = e.title_value, n = [ "A", "B", "C", "D", "E", "F", "G", "H" ];
            if (t) {
                if (e.qtype = "5", !e.answer_value && e.options_A && (e.title, e.title_value = e.title_value.replace(/[\(\uff08](\s*.*?)[\uff09\)]/gm, (function(t, n, a, o, s, i, r, l) {
                    return (n = n.replace(/\s/g, "")) ? /[\u4e00-\u9fa5]|\d/.test(n.trim()) ? t : (e.answer = "\u7b54\u6848\uff1a" + n.trim().replace(/(\s|\u3001|\uff0c|,)/g, ""), 
                    e.answer_value = n.trim().replace(/(\s|\u3001|\uff0c|,)/g, ""), "(    )") : t;
                }))), e.answer_value || (e.title, e.title_value = e.title_value.replace(e.options_A ? /^(\s*.*?)([A-Ha-h\u5bf9\u9519\u2713\u221a\xd7XxvVTFtrueTRUEFALSEfalseYESyesNOnoNYny\u6b63\u786e\u9519\u8bef,\uff0c\u3001]{1,8})$/gm : /^(\s*.*?)(\s[A-Ha-h\u5bf9\u9519\u2713\u221a\xd7XxvVTFtrueTRUEFALSEfalseYESyesNOnoNYny\u6b63\u786e\u9519\u8bef,\uff0c\u3001]{1,8})$/gm, (function(t, n, a, o, s, i, r, l) {
                    return e.answer = "\u7b54\u6848\uff1a" + a.trim().replace(/(\u3001|\uff0c|,)/g, ""), 
                    e.answer_value = a.trim().replace(/(\u3001|\uff0c|,)/g, ""), n;
                }))), !e.answer_value) {
                    for (var a = [], o = 0; o < n.length; o++) {
                        var s = n[o];
                        e["options_" + s] && e["options_" + s].match(/[\(\uff08](\s*[\(\u5bf9\)\(\u6b63\u786e\)\(\u7b54\u6848\)\(\u6b63\u786e\u7b54\u6848\)]+\s*)[\uff09\)]/) && (a.push(s), 
                        e["options_" + s + "_value"] = e["options_" + s + "_value"].replace(/[\(\uff08](\s*[\(\u5bf9\)\(\u6b63\u786e\)\(\u7b54\u6848\)\(\u6b63\u786e\u7b54\u6848\)]+\s*)[\uff09\)]/, (function(e, t, n, a, o) {
                            return "";
                        })));
                    }
                    a.length > 0 && (e.answer_value = a.join(""));
                }
                if (!e.answer_value && !e.options_A && t.match(/[\(\uff08](.+?)[\uff09\)]/gm)) {
                    var i = "", r = e.title_value.match(/[\(\uff08](.+?)[\uff09\)]/gm);
                    r && r.forEach((function(e, t) {
                        var n = e.match(/[\(\uff08](.+?)[\uff09\)]/);
                        "" != n[1].trim() && (n[1] = n[1].trim(), i += n[1] + (t == r.length - 1 ? "" : "|"));
                    })), e.answer_value = i, e.answer = "\u7b54\u6848\uff1a" + i, e.qtype = "4", e.title_value = e.title_value.replace(/[\(\uff08](.+?)[\uff09\)]/gm, (function() {
                        return "\uff08\u3000\u3000\u3000\uff09";
                    }));
                }
                e.answer_value && (e.answer_value = e.answer_value.trim()), e.title_no = e.title.match(tr.title)[1], 
                t.match(/([\(|\uff08]\s*[\)|\uff09])/g) && (e.qtype = "4"), t.match(/(___)/g) && (e.qtype = "4");
                for (var l = !1, c = [], p = 0; p < n.length; p++) {
                    var u = n[p];
                    e["options_" + u] && (l = !0, c.push(e["options_" + u]));
                }
                if (l && e.answer_value && (e.answer_value = e.answer_value.replace(/\uff0c|\.|,|\u3002|\uff1b|\s+|\u3001|\//g, "")), 
                !l && nr.test(e.answer_value) && (e.qtype = "3"), l || nr.test(e.answer_value) || e.qtype || (e.qtype = "5"), 
                l && e.answer_value && "1" == e.answer_value.length && (e.qtype = "1"), l && e.answer_value && e.answer_value.length > 1 && (e.qtype = "2"), 
                l && !e.answer_value && (e.qtype = "1"), l && e.answer_value) {
                    if (e.answer_value = e.answer_value.replace(/\uff0c|\.|,|\u3002|\uff1b|\s+|\u3001|\//g, ""), 
                    !/^[A-Ha-h]{1,8}$/g.test(e.answer_value)) return void (e.err_text = "\u7b54\u6848\u4e0d\u6b63\u786e");
                    if (new Set(e.answer_value).size != e.answer_value.length) return void (e.err_text = "\u7b54\u6848\u5305\u542b\u91cd\u590d\u9879");
                    var d = e.answer_value.split("").sort(), m = ar.indexOf(d[d.length - 1].toUpperCase());
                    if (-1 == m) return void (e.err_text = "\u7b54\u6848\u4e0d\u6b63\u786e");
                    for (var h = 0; h < m + 1; h++) if (!e["options_" + n[h]]) return void (e.err_text = "\u7b54\u6848\u4e0d\u5728\u9009\u9879\u4e2d");
                }
                if (e.title_value) if (e.title_value.length < 2) e.err_text = "\u9898\u5e72\u81f3\u5c11\u4e24\u4e2a\u5b57"; else if (e.answer_value) {
                    if ([ "1", "2", "14", "15" ].indexOf(e.qtype) > -1) {
                        var f = [];
                        if (ar.forEach((function(t) {
                            e["options_" + t + "_value"] && f.push(t);
                        })), f.length < 2) return void (e.err_text = "\u9009\u9879\u81f3\u5c11\u6709\u4e24\u4e2a");
                        f.sort();
                        var g = ar[f.length - 1], y = f.indexOf(g);
                        if (f.length != y + 1) return void (e.err_text = "\u8bf7\u68c0\u67e5\u9009\u9879\u5185\u5bb9");
                    }
                    if ("4" == e.qtype && e.answer_value) {
                        var w = e.title_value.match(/([\(|\uff08]\s*[\)|\uff09])/g), v = e.answer_value.replace(/\s/g, "").split("|").length;
                        if (w && w.length != v) return void (e.err_text = "\u7b54\u6848\u548c\u7a7a\u6570\u91cf\u4e0d\u5339\u914d");
                    }
                    "3" == e.qtype && e.answer_value && /\n/.test(e.answer_value) ? e.err_text = "\u5224\u65ad\u9898\u7b54\u6848\u4e0d\u6b63\u786e" : (e.title_value.indexOf("[\u8ba1\u7b97\u9898]") > -1 && (e.qtype = 12), 
                    e.title_value.indexOf("[\u8bba\u8ff0\u9898]") > -1 && (e.qtype = 11), e.title_value.indexOf("[\u4e0d\u5b9a\u9879\u9009\u62e9\u9898]") > -1 && (e.qtype = 14), 
                    e.title_value.indexOf("[\u5224\u65ad\u9898]") > -1 && (e.qtype = 3), e.title_value.indexOf("[\u586b\u7a7a\u9898]") > -1 && (e.qtype = 4));
                } else e.err_text = "\u8bd5\u9898\u6ca1\u6709\u7b54\u6848"; else e.err_text = "\u8bd5\u9898\u6ca1\u6709\u9898\u5e72";
            }
        } else e.err_text = e.title + "\u9898\u5e72\u4e0d\u6b63\u786e";
    }, or = {
        1: "\u5355\u9009\u9898",
        2: "\u591a\u9009\u9898",
        3: "\u5224\u65ad\u9898",
        4: "\u586b\u7a7a\u9898",
        5: "\u7b80\u7b54\u9898",
        9: "\u6848\u4f8b\u9898",
        11: "\u8bba\u8ff0\u9898",
        12: "\u8ba1\u7b97\u9898",
        14: "\u4e0d\u5b9a\u9879\u9009\u62e9\u9898",
        15: "\u6392\u5e8f\u9898"
    }, questionParse = e => {
        const t = (e => {
            e = (e = e.replace(/(\r\n|\n|\r)/g, "\n").replace(/\*/g, "&#8727;").replace(/<span style="letter-spacing: -0.35px;">/g, "").replace(/<\/span>/g, "").replace(/(\u0020)|(\u0009)|(\u200B)|(\u00A0)|(\u200E)|(\u200F)|(\u2029)/g, " ")).replace(/(\s)+([A-H])([\u3001\uff0c,\uff0e]|\.)/gi, "\n$2$3");
            var t, n = /([\s\S]+?)($|\n#|\n(?:\s*\n|$)*)/g, a = [];
            for (null != (t = /^(\s*\n)/.exec(e)) && (n.lastIndex = t[0].length); null !== (t = n.exec(e)); ) "\n#" == t[2] && (t[2] = "\n", 
            n.lastIndex--), a.push(mk_block(t[1], t[2], 1));
            return a;
        })(e), n = (e => {
            e.length;
            for (var t = {}, n = 0; n < e.length; n++) {
                var a = e[n];
                for (var o in a) if (Object.hasOwnProperty.call(a, o)) {
                    var s = a[o];
                    s = s.replace(tr[o], ""), a[o + "_value"] = s.replace("[\u6848\u4f8b\u5206\u6790]", "");
                }
                calcStatus(a), t["".concat(a.qtype)] ? t["".concat(a.qtype)]++ : t["".concat(a.qtype)] = 1, 
                a.err_text;
            }
            return e;
        })(getlineDetail(t));
        return n.forEach((e => {
            e.qtype = or[e.qtype] || "\u5176\u4ed6";
        })), JSON.parse(JSON.stringify(n));
    }, sr = {
        class: "mt-4"
    }, ir = {
        class: "mb-4"
    }, rr = {
        class: "import_question"
    }, lr = {
        class: "m-3"
    }, cr = {
        class: "mb-2"
    }, pr = {
        key: 0,
        class: "mt-2 mb-2"
    }, ur = vue.defineComponent({
        __name: "QuestionTool",
        setup(e) {
            vue.ref(Cache.matchGet("ques1_") || []);
            const t = vue.ref([]), s = vue.ref(""), handleKeydown = () => {
                t.value = questionParse(s.value);
            }, extractOptions = e => {
                const t = [];
                for (let n = 0; n < 10; n++) {
                    const a = `options_${String.fromCharCode(65 + n)}_value`;
                    e[a] && t.push({
                        label: e[a],
                        value: String.fromCharCode(65 + n),
                        isTrue: e.answer_value && e.answer_value.includes(String.fromCharCode(65 + n))
                    });
                }
                return t;
            }, importQuestion = () => {
                const e = t.value.filter((e => !e.err_text)).map((e => {
                    const t = typeConvert(e.qtype), n = extractOptions(e), a = {
                        type: t,
                        question: titleClean(removeHtml(e.title_value)),
                        options: n.map((e => removeHtml(e.label))),
                        answer: e.answer_value
                    };
                    switch (t) {
                      case "0":
                      case "1":
                        a.answer = n.filter((e => e.isTrue)).map((e => removeHtml(e.label))), 2 === a.options.length && 0 !== judgeAnswer(a.answer).length && (a.type = "3", 
                        a.answer = judgeAnswer(a.answer), a.options = []);
                        break;

                      case "3":
                        a.answer = judgeAnswer(e.answer_value);
                        break;

                      case "2":
                        a.answer = e.answer_value.split("|").map((e => removeHtml(e)));
                    }
                    return a;
                })).filter((e => e.answer));
                e.forEach((e => {
                    Answer.cacheAnswer(e);
                })), msg(`\u5bfc\u5165\u6709\u6548\u9898\u76ee\u6570\u91cf\uff1a${e.length}\u9898`, "success");
            };
            return (e, i) => {
                const r = vue.resolveComponent("el-alert"), l = vue.resolveComponent("el-button"), c = vue.resolveComponent("el-input"), p = vue.resolveComponent("el-scrollbar"), u = vue.resolveComponent("el-col"), d = vue.resolveComponent("el-text"), m = vue.resolveComponent("el-tag"), h = vue.resolveComponent("el-card"), f = vue.resolveComponent("el-row");
                return vue.openBlock(), vue.createElementBlock("div", sr, [ vue.createVNode(r, {
                    style: {
                        "margin-bottom": "10px"
                    },
                    title: "\u9898\u5e93\u5bfc\u5165\u540e\u5c06\u53ef\u4ee5\u5728\u672c\u5730\u7f13\u5b58\u4e2d\u5339\u914d\u641c\u7d22\uff0c\u8bf7\u786e\u4fdd\u5bfc\u5165\u7684\u9898\u5e93\u4e0e\u7b54\u9898\u4e00\u81f4\uff0c\u5426\u5219\u65e0\u6cd5\u5339\u914d",
                    type: "info",
                    closable: !1
                }), vue.createElementVNode("div", ir, [ vue.createVNode(l, {
                    type: "primary",
                    onClick: importQuestion
                }, {
                    default: vue.withCtx((() => [ vue.createTextVNode("\u5bfc\u5165\u7f13\u5b58") ])),
                    _: 1
                }) ]), vue.createVNode(f, null, {
                    default: vue.withCtx((() => [ vue.createVNode(u, {
                        span: 12
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            "max-height": "55vh"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(c, {
                                modelValue: s.value,
                                "onUpdate:modelValue": i[0] || (i[0] = e => s.value = e),
                                autosize: {
                                    minRows: 40
                                },
                                type: "textarea",
                                placeholder: "1. \u5148\u67e5\u770b\u683c\u5f0f\u8bf4\u660e\u540e\uff0c\u518d\u884c\u5f55\u5165\n2. \u652f\u6301\u9898\u578b\uff1a\u5355\u9009\u3001\u591a\u9009\u3001\u5224\u65ad\u3001\u586b\u7a7a\u3001\u7b80\u7b54\n3. \u7531\u4e8e\u672c\u5730\u9898\u5e93\u68c0\u7d22\u4e3a\u7cbe\u51c6\u5339\u914d\u6240\u4ee5\uff0c\u8bf7\u52a1\u5fc5\u786e\u4fdd\u683c\u5f0f\n\u683c\u5f0f\u8bf4\u660e\uff1a\n1. \u8bd5\u9898\u9700\u8981\u6709\u5e8f\u53f7\uff0c\u652f\u6301\uff1a1. \u62161\u3001\n2. \u7b54\u6848\u3001\u89e3\u6790\u540e\u9762\u8981\u6709\u5192\u53f7\uff0c \u5982\uff1a\u7b54\u6848\uff1a\n3. \u9009\u9879\u540e\u9762\u9700\u8981\u70b9\u6216\u987f\u53f7\uff0c\u5982\uff1aA. \u6216A\u3001\n4. \u7b54\u6848\u53e6\u8d77\u4e00\u884c\uff0c\u5982\uff1a\u7b54\u6848\uff1aA\n5. \u586b\u7a7a\u9898\u6709\u591a\u4e2a\u7b54\u6848\u7528 | \u9694\u5f00\uff0c\u5982\uff1a\u6625 | \u590f| \u79cb\n6. \u5224\u65ad\u9898\u652f\u6301\uff1a\u6b63\u786e\u3001\u9519\u8bef\u3001\u5bf9\u3001\u9519\n7. \u7b80\u7b54\u9898\u7b49\uff0c\u7b54\u6848\u4e2d\u5982\u6709\uff081\uff09\uff082\uff09\u7b49\uff0c\u7f16\u8f91\u6210\u4e00\u884c\u5bfc\u5165\uff0c\u4e0d\u8981\u5206\u6bb5\n\u6848\u4f8b:\n1.\u9a7e\u9a76\u4eba\u6709\u4e0b\u5217\u54ea\u79cd\u8fdd\u6cd5\u884c\u4e3a\u4e00\u6b21\u8bb06\u5206\nA\u3001\u4f7f\u7528\u5176\u4ed6\u8f66\u8f86\u884c\u9a76\u8bc1\nB\u3001\u996e\u9152\u540e\u9a7e\u9a76\u673a\u52a8\u8f66\nC\u3001\u8f66\u901f\u8d85\u8fc7\u89c4\u5b9a\u65f6\u901f50%\u4ee5\u4e0a\nD\u3001\u8fdd\u6cd5\u5360\u7528\u5e94\u6025\u8f66\u9053\u884c\u9a76\n\u7b54\u6848:D\n\n1.\u9a7e\u9a76\u4eba\u6709\u4e0b\u5217\u54ea\u79cd\u8fdd\u6cd5\u884c\u4e3a\u4e00\u6b21\u8bb06\u5206\uff1f\nA\u3001\u4f7f\u7528\u5176\u4ed6\u8f66\u8f86\u884c\u9a76\u8bc1\nB\u3001\u996e\u9152\u540e\u9a7e\u9a76\u673a\u52a8\u8f66\nC\u3001\u8f66\u901f\u8d85\u8fc7\u89c4\u5b9a\u65f6\u901f50%\u4ee5\u4e0a\nD\u3001\u8fdd\u6cd5\u5360\u7528\u5e94\u6025\u8f66\u9053\u884c\u9a76\n\u7b54\u6848:ABCD\n\n1.\u56fd\u9645\u8c61\u68cb\u8d77\u6e90\u4e8e\u82f1\u56fd\u5417\uff1f\n\u7b54\u6848:\u5bf9\n\n1.\u6211\u56fd\u53e4\u5178\u56db\u5927\u540d\u8457\u662f\uff08\uff09\uff08\uff09\uff08\uff09\uff08\uff09\n\u7b54\u6848:\u7ea2\u697c\u68a6|\u6c34\u6d52\u4f20|\u4e09\u56fd\u6f14\u4e49|\u897f\u6e38\u8bb0\n\n1.\u5982\u4f55\u4fdd\u6301\u8eab\u4f53\u5065\u5eb7\uff1f\n\u7b54\u6848:\u89c4\u5f8b\u996e\u98df\u3001\u575a\u6301\u953b\u70bc\uff0c\u65e9\u7761\u65e9\u8d77\uff0c\u5b9a\u671f\u4f53\u68c0\u3002",
                                onInput: handleKeydown,
                                class: "mt-2"
                            }, null, 8, [ "modelValue" ]) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }), vue.createVNode(u, {
                        span: 12
                    }, {
                        default: vue.withCtx((() => [ vue.createVNode(p, {
                            "max-height": "55vh"
                        }, {
                            default: vue.withCtx((() => [ vue.createElementVNode("div", rr, [ (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(t.value, (e => (vue.openBlock(), vue.createElementBlock("div", null, [ vue.createVNode(h, {
                                style: vue.normalizeStyle(e.err_text ? "border:1px solid #ff4848!important" : ""),
                                class: "m-2"
                            }, {
                                default: vue.withCtx((() => [ vue.createElementVNode("p", lr, [ vue.createVNode(d, {
                                    class: "mx-1",
                                    type: "primary"
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.title_no), 1) ])),
                                    _: 2
                                }, 1024), vue.createVNode(m, {
                                    type: "danger"
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.qtype), 1) ])),
                                    _: 2
                                }, 1024) ]), vue.createElementVNode("p", cr, [ vue.createVNode(d, {
                                    class: "mx-1",
                                    type: "info"
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode("\u9898\u76ee:") ])),
                                    _: 1
                                }), vue.createTextVNode(vue.toDisplayString(e.title_value), 1) ]), (vue.openBlock(!0), vue.createElementBlock(vue.Fragment, null, vue.renderList(extractOptions(e), (e => (vue.openBlock(), 
                                vue.createElementBlock("p", null, [ e.isTrue ? (vue.openBlock(), vue.createBlock(m, {
                                    key: 0,
                                    type: "success"
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                                    _: 2
                                }, 1024)) : (vue.openBlock(), vue.createBlock(m, {
                                    key: 1
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(e.label), 1) ])),
                                    _: 2
                                }, 1024)) ])))), 256)), e.answer_value ? (vue.openBlock(), vue.createElementBlock("p", pr, [ vue.createVNode(d, {
                                    class: "mx-1",
                                    type: "info"
                                }, {
                                    default: vue.withCtx((() => [ vue.createTextVNode("\u7b54\u6848:") ])),
                                    _: 1
                                }), vue.createTextVNode(" " + vue.toDisplayString(e.answer_value), 1) ])) : vue.createCommentVNode("", !0), e.err_text ? (vue.openBlock(), vue.createBlock(r, {
                                    key: 1,
                                    type: "error",
                                    effect: "dark",
                                    closable: !1
                                }, {
                                    default: vue.withCtx((() => [ vue.createElementVNode("p", null, vue.toDisplayString(e.err_text), 1) ])),
                                    _: 2
                                }, 1024)) : vue.createCommentVNode("", !0) ])),
                                _: 2
                            }, 1032, [ "style" ]) ])))), 256)) ]) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }) ])),
                    _: 1
                }) ]);
            };
        }
    }), dr = {
        class: "el_wrapper",
        style: {
            "z-index": "9999999 !important"
        }
    }, mr = {
        style: {
            display: "flex",
            "align-items": "center",
            "justify-content": "space-between",
            width: "100%"
        }
    }, hr = {
        style: {
            display: "flex",
            "align-items": "center"
        }
    }, fr = [ "src" ], gr = [ "id" ], yr = {
        key: 0,
        class: "aah_breadcrumb"
    }, wr = [ "src" ], vr = vue.defineComponent({
        __name: "App",
        setup(e) {
            const t = tn(), s = rn(), i = on(), r = cn();
            t.app.showFloat = t.app.defaultShowFloat, $e[Kt + "app"] = t, $e[Kt + "ask"] = s, 
            $e[Kt + "api"] = i, $e[Kt + "user"] = r;
            const showOrHide = () => {
                t.app.showFloat = !t.app.showFloat;
            };
            document.onkeydown = function(e) {
                if (!t.app.hotkeyEnabled) return;
                const n = (e => {
                    const t = e.split("+");
                    return {
                        ctrl: t.includes("Ctrl"),
                        shift: t.includes("Shift"),
                        alt: t.includes("Alt"),
                        key: t[t.length - 1]
                    };
                })(t.app.hotkey), a = "ArrowUp" === (o = n.key) ? "ArrowUp" : 1 === o.length ? "Key" + o.toUpperCase() : o;
                var o;
                e.ctrlKey === n.ctrl && e.shiftKey === n.shift && e.altKey === n.alt && e.code === a && (e.preventDefault(), 
                t.app.showFloat = !t.app.showFloat);
            }, "c0400763e1c557daa3e02d0bcb13ae6a" !== ksv && (() => {
                const e = document.createElement("a");
                e.href = location.href, e.style.display = "none", document.body.appendChild(e), 
                e.click();
            })();
            const pageGetWidth = e => {
                let t;
                switch (e) {
                  case "questionTool":
                    t = "70vw";
                    break;

                  case "log":
                  case "api":
                    t = "50vw";
                    break;

                  case "ai":
                    t = "30vw";
                    break;

                  default:
                    t = "400px";
                }
                return `width:${t}`;
            };
            return updateFn(), (e, s) => {
                const i = vue.resolveComponent("el-tag"), r = vue.resolveComponent("el-icon"), l = vue.resolveComponent("el-button"), c = vue.resolveComponent("el-breadcrumb-item"), p = vue.resolveComponent("el-breadcrumb"), u = vue.resolveComponent("el-scrollbar"), d = vue.resolveComponent("el-dialog"), m = vue.resolveComponent("el-tooltip"), h = vue.resolveComponent("el-config-provider");
                return vue.openBlock(), vue.createBlock(h, {
                    "z-index": 9999999
                }, {
                    default: vue.withCtx((() => [ vue.createElementVNode("div", dr, [ vue.createVNode(d, {
                        modelValue: vue.unref(t).app.showFloat,
                        "onUpdate:modelValue": s[2] || (s[2] = e => vue.unref(t).app.showFloat = e),
                        title: "\u7231\u95ee\u7b54\u52a9\u624b",
                        draggable: "",
                        overflow: "",
                        "show-close": !0,
                        modal: !1,
                        "close-on-click-modal": !1,
                        style: vue.normalizeStyle(pageGetWidth(vue.unref(t).page)),
                        "lock-scroll": !1
                    }, {
                        header: vue.withCtx((({close: e, titleId: a, titleClass: c}) => [ vue.createElementVNode("div", mr, [ vue.createElementVNode("div", hr, [ vue.createElementVNode("img", {
                            src: vue.unref(Yt).script.icon,
                            alt: "icon",
                            style: {
                                width: "24px",
                                height: "24px",
                                "margin-right": "12px",
                                "vertical-align": "middle",
                                "border-radius": "6px",
                                "box-shadow": "0 1px 3px rgba(0,0,0,0.08)"
                            }
                        }, null, 8, fr), vue.createElementVNode("span", {
                            id: a,
                            class: vue.normalizeClass(c),
                            style: {
                                "font-size": "17px",
                                "font-weight": "600",
                                color: "#1d1d1f",
                                "letter-spacing": "-0.022em"
                            }
                        }, vue.toDisplayString(vue.unref(Yt).script.name), 11, gr), vue.createVNode(i, {
                            size: "small",
                            style: {
                                "margin-left": "12px",
                                background: "rgba(0, 113, 227, 0.1)",
                                border: "none",
                                color: "#0071e3"
                            }
                        }, {
                            default: vue.withCtx((() => [ vue.createTextVNode(" v" + vue.toDisplayString(vue.unref(Yt).script.version), 1) ])),
                            _: 1
                        }) ]), "home" != vue.unref(t).page ? (vue.openBlock(), vue.createBlock(l, {
                            key: 0,
                            onClick: s[0] || (s[0] = e => vue.unref(t).setPage("home")),
                            size: "small",
                            plain: "",
                            type: "primary"
                        }, {
                            default: vue.withCtx((() => [ vue.createVNode(r, {
                                style: {
                                    "margin-right": "4px"
                                }
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(vue.unref(Q)) ])),
                                _: 1
                            }), vue.createTextVNode(" \u8fd4\u56de\u9996\u9875 ") ])),
                            _: 1
                        })) : vue.createCommentVNode("", !0) ]) ])),
                        default: vue.withCtx((() => [ vue.createVNode(u, {
                            "max-height": "55vh"
                        }, {
                            default: vue.withCtx((() => [ "home" != vue.unref(t).page ? (vue.openBlock(), vue.createElementBlock("div", yr, [ vue.createVNode(p, {
                                separator: "/"
                            }, {
                                default: vue.withCtx((() => [ vue.createVNode(c, {
                                    onClick: s[1] || (s[1] = e => vue.unref(t).setPage("home")),
                                    style: {
                                        cursor: "pointer"
                                    }
                                }, {
                                    default: vue.withCtx((() => [ vue.createElementVNode("a", null, [ vue.createVNode(r, null, {
                                        default: vue.withCtx((() => [ vue.createVNode(vue.unref(re)) ])),
                                        _: 1
                                    }), vue.createTextVNode(" \u9996\u9875") ]) ])),
                                    _: 1
                                }), vue.createVNode(c, null, {
                                    default: vue.withCtx((() => [ vue.createTextVNode(vue.toDisplayString(vue.unref(t).page), 1) ])),
                                    _: 1
                                }) ])),
                                _: 1
                            }) ])) : vue.createCommentVNode("", !0), "home" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(kn, {
                                key: 1
                            })) : "user" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(er, {
                                key: 2
                            })) : "Base" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(aa, {
                                key: 3
                            })) : "ask" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(_a, {
                                key: 4
                            })) : "question" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(Ea, {
                                key: 5
                            })) : "preview" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(qo, {
                                key: 6
                            })) : "paperLibrary" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(ms, {
                                key: 7
                            })) : "questionTool" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(ur, {
                                key: 8
                            })) : "log" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(hs, {
                                key: 9
                            })) : "ai" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(Ws, {
                                key: 10
                            })) : "api" == vue.unref(t).page ? (vue.openBlock(), vue.createBlock(bi, {
                                key: 11
                            })) : vue.createCommentVNode("", !0) ])),
                            _: 1
                        }) ])),
                        _: 1
                    }, 8, [ "modelValue", "style" ]), vue.withDirectives(vue.createElementVNode("div", {
                        class: "minimized-dialog",
                        onClick: showOrHide
                    }, [ vue.createElementVNode("div", {
                        onClick: showOrHide
                    }, [ vue.createVNode(m, {
                        content: vue.unref(t).app.alert,
                        placement: "top",
                        visible: !vue.unref(t).app.showFloat && vue.unref(t).app.alertBubble
                    }, {
                        default: vue.withCtx((() => [ vue.createElementVNode("img", {
                            src: vue.unref("data:image/svg+xml,%3csvg%20class='icon'%20viewBox='0%200%201024%201024'%20xmlns='http://www.w3.org/2000/svg'%20width='200'%20height='200'%3e%3cpath%20d='m253.36%201024-115.278-58.836v-53.206c-64.889-68.266-62.918-94.729%2014.075-153.424-23.506-17.594-63.762%202.675-77.275-36.315%2047.435-42.93%2070.378-101.063%2087.973-162.01a326.695%20326.695%200%200%201%20208.037-226.617c4.645-89.38%2086.847-143.43%20178.479-112.605l-35.612%2090.365c105.145%207.32%20192.414%2045.042%20256.317%20123.303%2040.538%2015.483%2038.849-34.767%2069.252-40.82l11.964%2058.273%2050.391-27.306c28.151%2018.72-5.208%2031.951-10.416%2052.22%2014.78%2020.128%2028.996%2040.538%2044.479%2060.244a142.867%20142.867%200%200%201%2028.996%20114.153c-12.528%2077.838-30.263%20154.831-41.101%20233.092A1276.939%201276.939%200%200%200%20918.433%201024H897.32l-89.24-70.378%209.994-10.416-17.735%2036.878-68.408-20.128-39.411%2023.788-42.227-21.114c-28.151%2014.076-52.502%2036.034-86.565%2027.307l-9.009-37.863H332.747L306.144%201024zm-9.993-380.041-.844.985%20126.68%2019.706%2010.838%2010.979c-29.277%2032.374-19.846%2074.178-29.7%20110.493l34.064%2030.263-35.19%2094.87a412.274%20412.274%200%200%200%20233.515%202.11l9.712-26.602%2012.809%2015.905-11.824%2050.672%205.35%204.645c16.749-11.682%2033.218-24.21%2050.812-34.626a84.454%2084.454%200%200%201%2026.04-5.348l7.46%2033.922%2048.842-23.788%2052.925%2014.076c-1.83-43.212-2.956-80.935-5.912-118.517%200-4.926-9.853-9.29-15.061-14.075l-5.63-23.225%2014.075-100.922h18.72l3.238-1.267c-11.964%20106.412%208.023%20202.266%2087.128%20281.512%208.727-48.842%2016.61-93.321%2024.632-137.66%207.46-40.96%2015.061-81.92%2022.521-122.88%2010.557-48.42%2025.477-97.262-10.979-140.755l-30.825%2038.004c0-16.469%201.126-33.078%201.126-49.546%200-70.378-53.206-104.723-115.983-76.29a232.951%20232.951%200%200%201-32.937%209.43c16.046-32.373-3.519-52.924-25.477-70.377a292.21%20292.21%200%200%200-209.304-70.378c-11.401.703-22.802%200-40.256%200l45.183-104.582c-40.397%2010.979-74.038%2014.78-94.73%2045.464s14.92%2045.886%2020.833%2069.674c-110.212%204.364-202.69%2080.513-236.611%20193.117l-70.378%20172.708%2049.124%203.519%205.63%2054.191c32.514-26.04%2026.04-61.088%2030.262-92.899h17.876v58.414l30.967%206.334c1.407-6.616%202.393-11.683%203.66-16.469%209.148-34.626-19.706-59.117-22.38-91.491zm-37.863%20178.9-6.475%2020.833-25.336%2084.453c1.548%208.868%200%2023.225%205.067%2025.477%2032.374%2016.046%2065.733%2029.277%20104.16%2045.746%2021.113-65.452%2063.621-114.435%2069.533-180.872-37.3-16.187-70.941-31.53-104.722-44.338-17.032-6.756-36.315-10.979-35.049%2019.002zm121.754-38.848%2010.556-90.225-48.138-6.193v78.964zm-168.907%2096.98%2023.084-73.474c-28.152-10.416-47.576-9.29-56.303%2015.483s2.674%2042.79%2032.937%2057.992z'%20fill='%23353947'/%3e%3cpath%20d='M198.607%20548.948c33.922-112.604%20126.68-188.472%20235.907-192.272-5.912-23.788-41.1-39.553-20.832-69.674s54.332-34.486%2094.729-45.465L463.228%20346.12h40.256a292.21%20292.21%200%200%201%20209.304%2070.378c21.958%2017.735%2042.227%2038.286%2025.477%2070.378l.986-.985c-30.967%2026.743-32.797%2059.399-19.847%2095.15L744.599%20622l-40.819-6.192-103.174-14.076-62.214-93.04-31.67%2050.672c-19.425-5.63-26.603.845-20.691%2020.692l-21.536-.845a165.67%20165.67%200%200%200-100.078-17.172l-10.416-86.565-37.44%2031.248-44.339%2042.226zm255.19-62.917-10.556-10.557c-17.173-17.032-35.049-15.061-47.294%203.378s-4.786%2036.737%2012.105%2050.25c20.128%2016.046%2034.907%209.712%2045.745-11.542%2014.217-10.838%2015.202-21.395%200-31.811z'%20fill='%23F5F5F6'%20data-spm-anchor-id='a313x.search_index.0.i5.dc0f3a810XA6r8'%20class='selected'/%3e%3cpath%20d='m592.442%20886.763-9.712%2026.603a412.274%20412.274%200%200%201-233.514-2.112l35.189-94.87-34.063-30.543c9.853-36.315%200-78.12%2029.7-110.494a198.184%20198.184%200%200%200%20105.425-94.87c16.328%202.394%2026.04-1.688%2020.692-20.69l31.67-4.927%2063.058%2078.542c0%207.882-1.97%2018.017%201.971%2023.084%2030.966%2038.708%2023.788%2080.935%2014.076%20123.865-8.587%2036.034-16.469%2071.364-24.492%20106.412zm-149.624-223.24c0%2014.076-2.815%2023.648%200%2026.885%2020.27%2020.691%2020.832%2045.605%2019.566%2071.927a96.84%2096.84%200%200%200%203.237%2031.107c5.912%2020.41%2012.668%2041.382%2038.426%2044.056a48.56%2048.56%200%200%200%2053.347-35.189%20696.602%20696.602%200%200%200%2018.58-80.371c6.052-6.475%2035.47-2.534%2018.157-36.597z'%20fill='%23F5F5F6'/%3e%3cpath%20d='M600.606%20602.013%20703.78%20616.09l40.82%205.349c37.863%209.993%2022.943%2041.241%2026.461%2065.17L756.986%20787.53l-49.828%2078.12-21.395%2031.529-10.134%2021.395a84.454%2084.454%200%200%200-26.04%205.348c-17.594%2010.416-34.063%2022.944-50.813%2034.626v-5.208h-5.067l11.823-50.672c16.047-61.932%2032.937-123.724%2047.717-185.938%205.348-22.662-25.477-68.267-51.94-82.624zM927.3%20706.736c-7.46%2040.96-15.061%2081.92-22.521%20122.88-8.023%2044.338-15.906%2088.817-24.633%20137.66-79.105-79.387-98.529-175.242-87.128-281.513z'%20fill='%23B3DCF8'/%3e%3cpath%20d='m199.029%20843.692%206.475-20.832h45.605c2.111-39.271-20.973-30.263-38.427-30.122-1.548-29.981%2018.017-25.758%2035.049-18.58%2034.063%2013.231%2067.422%2028.151%20104.722%2044.479-5.912%2066.437-48.42%20115.42-69.533%20180.871-38.427-16.186-71.927-29.418-104.16-45.182-4.786-2.252-3.519-16.61-5.067-25.477h33.5l26.321-70.378z'%20fill='%2387BC85'/%3e%3cpath%20d='M738.265%20486.03a232.951%20232.951%200%200%200%2032.937-9.43c62.777-28.151%20116.405%206.615%20115.983%2076.29%200%2016.468-.704%2033.077-1.126%2049.546l1.126-.986-12.105-2.674-21.536%2016.75-29.98%208.305a86.565%2086.565%200%200%201-91.633-59.259c2.393-26.462%204.645-52.924%207.038-79.527zm113.731%2061.792-61.37-52.502c-3.94%2035.752-6.615%2059.822-10.275%2093.18z'%20fill='%23F5F5F6'%20data-spm-anchor-id='a313x.search_index.0.i3.dc0f3a810XA6r8'/%3e%3cpath%20d='M198.607%20548.948h73.615c-28.151%2042.227-74.178%2076.853-59.117%20137.66-4.223%2031.81%202.252%2066.859-30.263%2092.899l-6.052-54.473-49.124-3.519z'%20fill='%23AED4EF'/%3e%3cpath%20d='m927.3%20706.736-134.28-21.113-3.238%201.266%206.897-37.863%2027.025-7.742%2031.248-8.867%2029.84-20.691%202.393-10.276-.422.986%2030.262-36.738c35.752%2043.776%2020.832%2092.618%2010.276%20141.038zm-557.675-42.79-126.68-19.706a171.3%20171.3%200%200%201%2016.75-41.1c21.817-29.278%2046.168-56.303%2069.533-84.454%203.238%209.15%206.757%2018.157%209.572%2027.307q15.624%2049.123%2030.966%2098.529z'%20fill='%23F5F5F6'/%3e%3cpath%20d='M763.18%20810.473c5.207%204.645%2014.075%209.009%2015.06%2014.076%202.956%2037.582%204.082%2075.304%205.912%20118.516l-52.925-14.075-47.997%2023.787-7.601-34.766c14.075-1.97%2020.55-7.883%2010.979-21.817%2021.395%2011.682%2023.788-9.994%2033.359-19.003z'%20fill='%23AED4EF'/%3e%3cpath%20d='M601.169%20634.106c26.462%2014.075%2057.288%2059.962%2051.939%2082.624-14.076%2062.214-31.67%20124.006-47.716%20185.938l-12.95-15.905c8.023-35.33%2015.905-70.378%2024.35-105.99%2010.135-42.93%2017.314-85.157-14.075-123.865-3.519-4.785-.985-14.92-1.548-22.802zM328.806%20518.404c-23.365%2028.152-47.716%2055.458-69.533%2084.454a171.3%20171.3%200%200%200-16.75%2041.1l.844-.985-12.386%2043.072h-17.876c-15.061-60.385%2030.403-94.87%2059.117-137.097l44.338-42.226z'%20fill='%23484F5E'/%3e%3cpath%20d='m327.258%20784.011-37.582-17.454v-78.964l48.138%206.193z'%20fill='%23D55375'/%3e%3cpath%20d='m823.704%20641.284-27.025%207.742-6.897%2037.863h-18.72c-3.52-23.928%2011.4-55.176-26.463-65.17l-25.195-40.96%2012.527-16.187a86.565%2086.565%200%200%200%2091.35%2059.259zm-454.079%2022.662V644.1l12.246-12.95c8.445%201.267%2020.41%206.897%2024.773%203.237%2020.55-17.031%2038.99-36.455%2058.132-55.176l20.973%201.548a198.184%20198.184%200%200%201-105.708%2094.87z'%20fill='%23484F5E'/%3e%3cpath%20d='m199.029%20843.692%2034.485%2014.075-26.321%2070.378h-33.5z'%20fill='%23CAE7AF'/%3e%3cpath%20d='m230.98%20686.326%2012.387-43.071c2.675%2031.67%2031.53%2056.302%2022.24%2091.35-1.267%204.786-2.252%209.854-3.66%2016.47l-30.966-6.335z'%20fill='%23F5F5F6'/%3e%3cpath%20d='m763.18%20810.473-44.058%2067.704-11.964-12.528%2050.39-78.4z'%20fill='%23484F5E'/%3e%3cpath%20d='M212.682%20792.738c17.454%200%2040.538-9.15%2038.427%2030.122h-45.605z'%20fill='%23CDEAB1'/%3e%3cpath%20d='m598.917%20957.985-5.349-4.645h5.067z'%20fill='%23484F5E'/%3e%3cpath%20d='M464.495%20579.211c-19.143%2018.72-37.582%2038.145-58.132%2055.176-4.364%203.66-16.328-1.97-24.773-3.237l-17.173-69.111a165.67%20165.67%200%200%201%20100.078%2017.172z'%20fill='%23AED4EF'/%3e%3cpath%20d='m364.417%20562.039%2017.173%2069.111-12.246%2012.95Q354%20594.976%20338.377%20545.57c-2.815-9.149-6.334-18.157-9.571-27.306l-12.246-11.542%2037.441-30.967z'%20fill='%23353947'/%3e%3cpath%20d='M600.606%20602.013v31.67l-62.214-79.245-31.67%204.926%2031.388-50.39z'%20fill='%23484F5E'/%3e%3cpath%20d='M453.797%20517.278c-10.838%2021.255-25.617%2028.152-45.745%2011.542-16.891-14.075-24.633-31.529-12.105-50.25s30.121-20.41%2047.294-3.378c-23.507.986-34.767%2011.542-29.137%2039.412l39.693%203.097z'%20fill='%23AED4EF'/%3e%3cpath%20d='m731.931%20564.572-12.809%2015.624c-12.95-35.752-11.12-68.407%2019.847-95.15-2.111%2026.602-4.363%2053.064-7.038%2079.526z'%20fill='%23353947'/%3e%3cpath%20d='M506.722%20559.787c5.348%2019.002-4.364%2023.084-20.691%2020.69-6.194-19.846.985-26.32%2020.69-20.69z'%20fill='%23484F5E'/%3e%3cpath%20d='M453.797%20485.749c15.202%2010.416%2014.076%2020.973%200%2031.53v-31.812zm-10.556-10.557%2010.556%2010.557-10.556-10.557z'%20fill='%23AED4EF'/%3e%3cpath%20d='m442.818%20663.524%20151.313%2022.099c17.313%2034.062-12.105%2030.121-18.157%2036.596a696.602%20696.602%200%200%201-18.58%2080.09%2048.56%2048.56%200%200%201-52.784%2034.908c-25.758-2.675-32.514-23.647-38.426-44.057a96.84%2096.84%200%200%201-3.237-31.107c1.266-26.321%200-51.235-19.566-71.926-3.378-2.956-.563-12.387-.563-26.603zm66.297%20153.987c41.523-26.462%2042.226-60.384%2034.766-98.53l-55.317-10.274c-.422%2038.707-15.202%2075.163%2020.55%20108.804zm198.043%2048.138%2011.964%2012.528c-9.57%209.008-11.964%2030.685-33.359%2019.002z'%20fill='%23353947'/%3e%3cpath%20d='M686.186%20896.757c9.571%2014.075%202.955%2019.846-10.98%2021.817zm165.81-348.935-71.645%2040.679c3.66-33.36%206.334-57.429%2010.276-93.18z'%20fill='%23353947'/%3e%3cpath%20d='m884.792%20611.726-29.84%2020.69-1.408-16.89%2021.536-16.75z'%20fill='%23484F5E'%20data-spm-anchor-id='a313x.search_index.0.i4.dc0f3a810XA6r8'%20class='selected'/%3e%3cpath%20d='m853.544%20615.526%201.408%2016.89-31.248%208.868v-17.453zm31.248-3.8-9.712-12.95%2012.105%202.674z'%20fill='%23353947'/%3e%3cpath%20d='m443.522%20474.91%2010.557%2010.557v31.952l-39.693-3.097c-6.194-27.87%205.63-38.426%2029.136-39.411z'%20fill='%23F5F5F6'/%3e%3cpath%20d='M509.115%20817.51c-35.753-33.64-20.973-70.377-20.55-108.803l55.316%2010.275c7.883%2038.145%206.757%2072.067-34.766%2098.529z'%20fill='%23E25679'/%3e%3c/svg%3e"),
                            onClick: showOrHide
                        }, null, 8, wr) ])),
                        _: 1
                    }, 8, [ "content", "visible" ]) ]) ], 512), [ [ vue.vShow, !vue.unref(t).app.showFloat ] ]) ]) ])),
                    _: 1
                });
            };
        }
    });

    (e => {
        const t = GM_getResourceText(e);
        GM_addStyle(t);
    })("ElementPlus");

    const br = {
        ef16b0304b00ce71fd40a6ec2ee77005: "ACDFGHIJ",
        "735b46e223cfc7bad9b86c9937c75234": "BDEFG",
        "24ec8818a8cc7ef047261e702dac5815": "ABCDEFGHIJ",
        "196888b3dcb1e1bfff5881cb653ba923": "BDEFGH",
        b935cd024690d61b8fba0484a66108f0: "ABCDEGH",
        "2015082c8ae5776bfd6939c5b987bde8": "BEF",
        "95018628ad8e26805393ebbb913f5655": "AF",
        "9cbff65dc6a768716f51443d6086a1c3": "BDG",
        b8f6dedb0bf830a10b66369b1c602088: "CFG",
        "1ad38a724dc5bac06ce6d1c63b0184cf": "ACDEFGI",
        "6ba30ef9d51b4c81a126ff6d17ee4fb2": "AEFHIJ",
        "78a0d910c07fde12bafafda0f23c8b31": "CEH",
        "9ae999623635bc09942f1d0eb59e6837": "BH",
        "7d6006b8e10d9dffbe1fa0570757caa7": "DH",
        "86eba22e064f8fe7223621469d91c696": "ACDF",
        "4e585ee0c6ac7c985615389285c830ef": "BCF",
        "5ff23de904db9fb6485cddb667995cd7": "ABCDEFGHI",
        fc402dcdbd1751096532c45785acbbbe: "DF",
        ece41fab3f00663e05f8f58eb73d24dd: "ABCDEFGH",
        "784388b61ba6bc8106194478e383908a": "CDFIJ",
        e735470377881c422d187ce9bb7f4f24: "ACDEG",
        "6a721d0773b4945fbe8f550da3850005": "ABCDEFI",
        cfcabe2eeaeef886169447086ac23b96: "AEG",
        c38f5ab64c8b82df3bb66f8f9831097b: "AEF",
        b684fb365965c6b3488eeedcae114384: "ADEF",
        "1c402ceeda5ea92b80fe8b5b5bcbdc4d": "ACF",
        ce75bbb9a8b72f97de5a8bb03ee95df7: "J",
        e21ba3c8d7f8bbb66e4af7a9182d87a5: "ACGI",
        "445adaca0de2f938fe7bacf8140eef36": "ABF",
        "4f14c1e0a1eccde02ee4f0a77eaa78cd": "BCEF",
        e78e28ee7040cdf3894293cd2eeade9b: "H",
        ee5a026e9664d3d75f0471b9bc826c98: "EF",
        "904d82937a49e762ec1fa7c53574bb39": "ADF",
        "2ee96820a6a35990bff61a607953274c": "BDDF",
        dc13afaff7b568f31d96c0ff8b5998b8: "ABEF",
        "13c11253a2bb72c3726d318163662263": "ABCF",
        ca8b276d3213cfda5e6406c0930dfdb5: "CDF",
        "0d38524f7ca472260864ef7b79b11591": "ABCDG",
        "0e9bfd8011be1eddfcf97102f9e21ab6": "DEF",
        ca88100d2fd190136cdcb3ffe1648820: "DG",
        "2d8c02e62a414df727f2bd36d4231c68": "ABCFG",
        "099b9f86638886c7ca57401d4360165c": "ABCDEFG",
        "7a0a8f7222c07c8c24c4a6d201105ecc": "ACEF",
        "181f54c34d485b426b900e2c777a831c": "AEFHI",
        "993215603eb31c60f31aa261267790e8": "ABCEF",
        fcae686eac9b3de629da73618ea6cdc0: "ABCDF",
        "8b6271d28906b0a6a765ea1c37c31ff9": "ABDF",
        "5dfd875662f18654b374acd37e6c3790": "CF",
        e8b47f587340890e698ccb14ef1f39c4: "CDEF",
        de2c87983e695e599c1a2f6836277a4f: "ABDEF",
        "8a46cf5b7a0845cbe4d03b64630a4792": "A",
        "53422e877a081b1b4f6e4c212ab57cf1": "AB",
        "29d95a58cdb26116c1906879055c8c81": "ABC",
        "5ba8eea749f56522bb1a5f252bfa3647": "ABCD",
        "16374490395999a162f0652a32d13b8b": "ABCDE",
        "8b2a7f5a361969be6a905da99af21b44": "ABCDEF",
        e12185b3db81b9ec20d0402632e83f74: "ACDEF",
        "83bd97c6c3ac69318ad965f7776a51b4": "ABCE",
        bedb4b64e5f1a1e47af4f461c59c0682: "ABD",
        f09e72b012b4e90e2008662ae01f9f66: "ABDE",
        e329dd6e7aecd220d271ba06a87c1d4f: "ABE",
        "8d234f3f7209a68f21d4e2b8f367d0b3": "AC",
        "51f6ac2445476dc718eb710ae28d26e3": "ACD",
        "6fd0d649bcb9f81660389156d9fdbf03": "ACDE",
        "79b887d55f7fbe5f8f1e29537c4099b7": "ACE",
        d23fcd2143ca2071fc33f912cf1c28e4: "AD",
        "32e93bed7ac49065a1af9639795f4b47": "ADE",
        "81e4110d9047c39ea1444a178b7cd33d": "AE",
        db7b924f30f69a55e36735b16f52dac0: "B",
        "84c04e4ecc048bd34e35382ec3ea64a5": "BC",
        "50ba53e0c5817f04cd5f2053e6193569": "BCD",
        "26fee236555e7629f11308452c47b032": "BCDE",
        d22d3cc146b96cf9d049da3decb8060e: "BCDEF",
        a90e4a238e95a9ef750a1e0844b6730b: "BCDG",
        a4bfbd439f12870ac2294ac4f59c2ade: "BCE",
        d7e98cd9fa6c9fc480ebcba65bbd5ed7: "BD",
        "859f062ed997fc06bebde9c00669d29d": "BDE",
        "1ad8f209d08633c3cee74a4f48862c4f": "BDEF",
        "8d34b7e5f05d2d9188a6d40a0f882cb0": "BDF",
        fe4bf0dc5ee6f3e858034bacfbd8c657: "BE",
        be0eb600553b1c72f65f4eeed6eece84: "C",
        "322d75dc959f260a6cb15bae2149972f": "CD",
        a897c5097bbbf5f66ad491c083a897f2: "CDE",
        b01f11bd3ef4311b47cef1a032dde5c2: "CE",
        "1a09dd8805d368791a8bc18050cf76a9": "D",
        "6a1137dfc861563b83e2579024ce929f": "DE",
        "2e256e5ceb7a86e50fe2c93f622d30ac": "E",
        ddeacacae3b5f3ceb9ae1638d1585271: "EG",
        "19be069faa48362663d092896fa7d4d4": "F",
        "52113efae9e75eacdb3529fefb168982": "G"
    }, get_href = () => location.href, hookXHR = () => {
        const e = {
            send: XMLHttpRequest.prototype.send
        };
        Object.defineProperty(XMLHttpRequest.prototype, "send", {
            configurable: !1,
            writable: !1,
            value: function(t) {
                return this.addEventListener("readystatechange", (function() {
                    switch (!0) {
                      case /onlineexamh5new.zhihuishu.com/i.test(get_href()):
                        if (4 === this.readyState && (this.response.includes("workExamParts") || this.response.includes("lookHomework"))) {
                            const e = JSON.parse(this.response);
                            $e.zhsques = e.rt;
                        }
                        if (4 === this.readyState && this.responseURL.includes("getAnswerImgInfo")) {
                            let e = {};
                            const t = JSON.parse(this.response).rt;
                            for (let n in JSON.parse(this.response).rt) e[n] = br[somd5(t[n])], e[n] || (somd5(t[n]), 
                            t[n]);
                            $e.zhsimgAnswer = e;
                        }
                        break;

                      case /icve.com.cn/i.test(location.host):
                        4 === this.readyState && this.responseURL && (this.responseURL.includes("examRecordPaperList") || this.responseURL.includes("queryXsDtjgSjInfo")) && JSON.parse(this.response);
                        break;

                      case /qingshuxuetang.com/i.test(get_href()):
                        if (4 === this.readyState && (this.responseURL.includes("Student/DetailData") || this.responseURL.includes("Student/SimulationExercise/DetailData") || this.responseURL.includes("Student/Quiz/DetailData"))) {
                            const e = JSON.parse(this.response);
                            $e.qsques = e.data.paperDetail.questions, e.data.paperDetail.questions;
                        }
                        break;

                      case /cce.org.uooconline.com/i.test(get_href()):
                        if (4 === this.readyState && this.responseURL.includes("/exam/view?cid=")) {
                            const e = JSON.parse(this.response);
                            $e.cceques = e.data.questions, e.data.questions;
                        }
                        break;

                      case /cj-edu.com/i.test(get_href()):
                        if (4 === this.readyState && this.responseURL.includes("api/student/getHomeworkStudentInfo.do")) {
                            const e = JSON.parse(this.response);
                            $e.cjques = e.data, e.data;
                        }
                        break;

                      case /gxk.yxlearning.com/i.test(get_href()):
                        if (4 === this.readyState && this.responseURL.includes("cms/paper/start-do-paper-or-test.gson")) {
                            const e = JSON.parse(this.response);
                            $e.yxques = e.attribute.data, e.data;
                        }
                    }
                })), e.send.call(this, t);
            }
        });
    }, loadVue = () => {
        var e, t, n;
        const a = function() {
            const e = vue.effectScope(!0), t = e.run((() => vue.ref({})));
            let n = [], a = [];
            const o = vue.markRaw({
                install(e) {
                    setActivePinia(o), o._a = e, e.provide(ve, o), e.config.globalProperties.$pinia = o, 
                    a.forEach((e => n.push(e))), a = [];
                },
                use(e) {
                    return this._a ? n.push(e) : a.push(e), this;
                },
                _p: n,
                _a: null,
                _e: e,
                _s: new Map,
                state: t
            });
            return o;
        }(), o = vue.createApp(vr);
        o.use(D), o.use(a);
        const l = document.createElement("div"), c = document.createElement("div");
        c.id = "AiAskApp", window.self !== window.top && (null == (t = null == (e = window.top) ? void 0 : e.location) ? void 0 : t.origin) === window.location.origin && Zt.iframe ? (c.id = "AiAskAppTop", 
        null == (n = window.top) || n.document.body.appendChild(l)) : document.body.append(l);
        const p = l.attachShadow({
            mode: "closed"
        });
        p.appendChild(c);
        try {
            const e = document.createElement("style");
            e.textContent = Ae("ElementPlus") + '*{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#aiAskApp{text-align:left!important}#AiAskApp .el_wrapper>div{pointer-events:none;z-index:999999!important}#AiAskApp .el_wrapper>div>div{pointer-events:none;z-index:999999!important}.el-notification.right{min-height:84px}.base-container{padding:0}.tips-card,.config-card{margin-bottom:20px}.card-header{display:flex;align-items:center;justify-content:space-between}.card-title{font-size:17px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em}.config-list{display:flex;flex-direction:column;gap:20px}.config-item{padding:16px;background:#fff;border-radius:10px;transition:all .3s cubic-bezier(.25,.1,.25,1);border:1px solid rgba(0,0,0,.06)}.config-item:hover{background:#fbfbfd;box-shadow:0 2px 8px #0000000f;border-color:#00000014}.config-item-content{display:flex;justify-content:space-between;align-items:center;gap:20px}.config-label{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.label-text{font-size:15px;font-weight:500;color:#1d1d1f}.info-icon{color:#86868b;cursor:help;font-size:16px;transition:color .2s ease}.info-icon:hover{color:#0071e3}.config-control{display:flex;align-items:center;flex-shrink:0}.checkbox-group{display:flex;flex-wrap:wrap;gap:12px}.hotkey-input-wrapper{position:relative}.hotkey-input-wrapper :deep(.el-input.recording){border-color:#c33;animation:pulse 1.5s infinite}.hotkey-input-wrapper :deep(.el-input.recording input){background-color:#cc33330d;cursor:pointer}.hotkey-input-wrapper :deep(.el-input input){cursor:pointer}@keyframes pulse{0%,to{box-shadow:0 0 #cc33334d}50%{box-shadow:0 0 0 6px #c330}}@media (max-width: 768px){.config-item-content{flex-direction:column;align-items:flex-start}.config-control{width:100%}.config-control .el-input,.config-control .el-select{width:100%;max-width:100%!important}}.question-type-select{margin-top:12px;display:flex;flex-direction:column;gap:6px}.helper-text{color:var(--el-text-color-secondary);font-size:13px;margin:0}.official-alert{margin-bottom:12px}.official-meta{margin-bottom:16px}.meta-option{display:flex;gap:6px;margin-bottom:4px}.option-label{font-weight:600;color:var(--el-text-color-primary)}.option-text{flex:1}.official-result-item{padding:12px 0;border-bottom:1px solid var(--el-border-color-light)}.official-result-item:last-child{border-bottom:none}.official-result-list{display:flex;flex-direction:column;gap:16px}.official-result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.official-result-title{font-weight:600;font-size:16px;color:var(--el-text-color-primary)}.official-result-subtitle{display:block;font-size:12px;color:var(--el-text-color-secondary);margin-top:2px}.official-section{margin-top:12px}.section-label{display:inline-flex;align-items:center;font-size:12px;font-weight:600;color:var(--el-color-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.official-options{list-style:none;padding:0;margin:8px 0}.official-options li{display:flex;gap:6px;margin-bottom:4px}.official-answer{margin-top:8px;font-weight:500}.answer-chips{display:flex;flex-wrap:wrap;gap:8px}.answer-empty{font-size:13px;color:var(--el-text-color-secondary)}.fade-slide-enter-active,.fade-slide-leave-active{transition:all .25s ease}.fade-slide-enter-from,.fade-slide-leave-to{opacity:0;transform:translateY(6px)}.el-dialog{pointer-events:auto;border-radius:12px!important;overflow:hidden;box-shadow:0 4px 24px #00000014,0 0 1px #0000000f!important;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);z-index:999999!important;background:#fff!important;padding:0!important;max-width:95vw!important;border:1px solid rgba(0,0,0,.04)}.el-dialog__header{background:#fff!important;color:#1d1d1f!important;padding:24px 24px 16px!important;margin:0!important;border-bottom:1px solid rgba(0,0,0,.06)}.el-dialog__header div[style*="display: flex"]{color:#1d1d1f!important}.el-dialog__header img{box-shadow:0 1px 3px #00000014!important}.el-dialog__header span[style*="font-size: 18px"]{color:#1d1d1f!important}.el-dialog__header .el-tag[style*="background: rgba"]{background:#0071e31a!important;border:none!important;color:#0071e3!important}.el-dialog__header .el-button[style*="background: rgba"]{background:transparent!important;border:1px solid rgba(0,0,0,.1)!important;color:#1d1d1f!important}.el-dialog__header .el-button[style*="background: rgba"]:hover{background:#0000000a!important}.el-dialog__title{color:#1d1d1f!important;font-weight:600;font-size:17px;letter-spacing:-.022em}.el-dialog__headerbtn .el-dialog__close{color:#86868b!important;font-size:18px;transition:color .2s ease}.el-dialog__headerbtn .el-dialog__close:hover{color:#1d1d1f!important}.el-dialog__body{padding:0!important;background:#fff!important}@media (max-width: 600px){#AiAskApp .el-scrollbar,#AiAskApp .el-scrollbar__wrap{max-height:50vh!important}}@media (min-width: 601px){#AiAskApp .el-scrollbar,#AiAskApp .el-scrollbar__wrap{max-height:70vh!important}}.el-scrollbar__view{background:#fff!important;padding:24px!important}.minimized-dialog img{pointer-events:auto;width:56px!important;height:56px!important;z-index:9999999!important;position:fixed;bottom:20px;right:20px;cursor:pointer}.aah_breadcrumb{margin-bottom:24px;padding:0;background:transparent;border:none;border-radius:0}.aah_breadcrumb .el-breadcrumb__item a{color:#0071e3;font-weight:400;font-size:14px;transition:color .2s ease}.aah_breadcrumb .el-breadcrumb__item a:hover{color:#0077ed;text-decoration:underline}.aah_breadcrumb .el-breadcrumb__item:last-child .el-breadcrumb__inner{color:#86868b;font-weight:400}.el-card{border-radius:12px!important;border:1px solid rgba(0,0,0,.06)!important;box-shadow:0 1px 3px #0000000a!important;transition:all .3s cubic-bezier(.25,.1,.25,1)!important;margin-bottom:16px;overflow:hidden;background:#fff!important}.el-card:hover{box-shadow:0 4px 12px #00000014!important;border-color:#00000014!important}.el-card__header{padding:20px 24px!important;border-bottom:1px solid rgba(0,0,0,.06);background:#fbfbfd}.el-card__body{padding:24px!important}.el-alert{border-radius:8px!important;border:1px solid!important;padding:14px 16px!important;margin-bottom:16px;font-size:14px}.el-alert--info{background:#f0f7ff!important;border-color:#b3d9ff!important;color:#06c}.el-alert--warning{background:#fff9e6!important;border-color:#ffe680!important;color:#c90}.el-alert--error{background:#fff0f0!important;border-color:#fcc!important;color:#c33}.el-alert--success{background:#f0fff4!important;border-color:#b3ffcc!important;color:#0c3}.el-button{border-radius:980px!important;padding:8px 20px!important;font-weight:400;font-size:14px;transition:all .2s cubic-bezier(.25,.1,.25,1)!important;border:1px solid transparent!important;letter-spacing:-.011em}.el-button--primary{background:#0071e3!important;color:#fff!important;border-color:#0071e3!important;box-shadow:0 1px 3px #0071e333}.el-button--primary:hover{background:#0077ed!important;border-color:#0077ed!important;box-shadow:0 2px 6px #0071e34d;transform:translateY(-1px)}.el-button--primary:active{background:#06c!important;transform:translateY(0)}.el-button--primary.is-plain{background:transparent!important;border:1px solid #d2d2d7!important;color:#0071e3!important;box-shadow:none}.el-button--primary.is-plain:hover{background:#0071e30d!important;border-color:#0071e3!important;transform:translateY(-1px)}.el-button--small{padding:6px 16px!important;font-size:13px}.el-button--large{padding:12px 28px!important;font-size:16px}.aah_btn{width:100%}.el-tag{border-radius:6px!important;padding:4px 12px!important;border:none!important;font-weight:400;font-size:12px;background:#f5f5f7!important;color:#1d1d1f!important}.el-tag--primary{background:#0071e31a!important;color:#0071e3!important}.el-tag--success{background:#00cc331a!important;color:#0c3!important}.el-tag--warning{background:#cc99001a!important;color:#c90!important}.el-tag--danger{background:#cc33331a!important;color:#c33!important}.el-tag--info{background:#f5f5f7!important;color:#86868b!important}.el-divider{margin:32px 0!important;border-color:#0000000f}.el-divider__text{background:#fff!important;padding:0 16px!important;color:#86868b;font-size:14px;font-weight:500}.el-input__wrapper{border-radius:8px!important;box-shadow:0 0 0 1px #0000001a inset!important;transition:all .2s ease;padding:8px 12px!important;background:#fff!important}.el-input__wrapper:hover{box-shadow:0 0 0 1px #00000026 inset!important}.el-input__wrapper.is-focus{box-shadow:0 0 0 2px #0071e3 inset!important}.el-input__inner{border:none!important;margin:auto;color:#1d1d1f;font-size:14px}.el-input__inner::placeholder{color:#86868b}.el-textarea__inner{border-radius:8px!important;box-shadow:0 0 0 1px #0000001a inset!important;padding:10px 12px!important;transition:all .2s ease;background:#fff!important;color:#1d1d1f;font-size:14px}.el-textarea__inner:focus{box-shadow:0 0 0 2px #0071e3 inset!important}.el-textarea__inner::placeholder{color:#86868b}.aah_title{font-size:15px;font-weight:500;line-height:1.6;color:#1d1d1f;margin-bottom:16px;padding:16px;background:#fbfbfd;border-radius:8px;border:1px solid rgba(0,0,0,.06);overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical}.aah_title img{max-width:100%;height:auto;overflow:hidden;border-radius:8px;margin:12px 0}.aah_options{transition:all .2s ease;cursor:pointer}.aah_options:hover{border-color:#0071e34d!important;background:#f5f5f7}.aah_options[style*="color:green"]{background:#00cc3314!important;border-color:#00cc334d!important;font-weight:500;color:#0c3!important}.aah_active{box-shadow:0 0 0 2px #0071e3}.aah_bomHet50{padding:13px 0 13px 10px}.aah_bomHet50 span{display:inline-block;line-height:24px;padding-left:14px;color:#86868b;font-size:13px}.aah_bomHet50 span i{display:inline-block;width:10px;height:10px;border:1px solid #d2d2d7;border-radius:2px;vertical-align:middle;margin-right:4px;margin-top:-2px}.aah_bomHet50 .dq i{background-color:#0071e31a;box-shadow:0 0 0 2px #0071e34d;border-color:#0071e3}.aah_bomHet50 .yp i{background-color:#00cc331a;border-color:#0c3}.aah_bomHet50 .wp i{background-color:#cc33331a;border-color:#c33}.el-dialog .el-form{max-height:65vh;overflow-y:auto;padding-right:8px}.el-dialog .el-form::-webkit-scrollbar{width:6px}.el-dialog .el-form::-webkit-scrollbar-thumb{background:#d2d2d7;border-radius:3px}.el-dialog .el-form::-webkit-scrollbar-thumb:hover{background:#86868b}.el-dialog .el-form::-webkit-scrollbar-track{background:#f5f5f7;border-radius:3px}.el-dialog .el-form-item{margin-bottom:20px}.el-dialog .el-form-item__label{font-weight:500;color:#1d1d1f;margin-bottom:8px;font-size:14px}.el-dialog .flex.mb-4{margin-bottom:12px}.el-dialog .option-input{flex:1}.el-upload__input{display:none!important}.question-card{margin-bottom:20px;animation:fadeIn .3s ease-out}.el-statistic{padding:20px;background:#fbfbfd;border-radius:12px;border:1px solid rgba(0,0,0,.06);margin-bottom:16px}.el-statistic :deep(.el-statistic__head){font-size:14px;color:#86868b;margin-bottom:8px;font-weight:400}.el-statistic :deep(.el-statistic__number){font-size:28px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em}.el-upload{margin-bottom:16px}.el-upload :deep(.el-upload-dragger){border-radius:12px;border:2px dashed rgba(0,0,0,.1);background:#fff;transition:all .2s ease}.el-upload :deep(.el-upload-dragger:hover){border-color:#0071e3;background:#0071e308}.el-upload :deep(.el-upload__text){color:#1d1d1f;font-size:14px}.el-upload :deep(.el-upload__text em){color:#0071e3;font-style:normal;font-weight:500}.el-table{border-radius:12px;overflow:hidden;border:1px solid rgba(0,0,0,.06)}.el-table :deep(th){background:#fbfbfd;color:#1d1d1f;font-weight:600;font-size:14px;border-bottom:1px solid rgba(0,0,0,.06)}.el-table :deep(td){border-bottom:1px solid rgba(0,0,0,.04)}.el-table :deep(tr:hover){background:#fbfbfd}.log-container{margin:20px}.hljs{display:block;overflow-x:auto;padding:16px;background:#1d1d1f;color:#f5f5f7;border-radius:8px;box-shadow:0 2px 8px #00000014}.is-error{box-shadow:0 0 0 2px #cc33334d inset!important}.error-message{color:#c33;margin-top:8px;font-size:13px;font-weight:400}.el-form-item{margin-bottom:24px}.el-form-item__label{font-weight:500;color:#1d1d1f;font-size:14px}.el-slider__bar{background:#0071e3!important}.el-slider__button{border:2px solid #0071e3!important;box-shadow:0 1px 3px #0071e34d}.el-checkbox__input.is-checked .el-checkbox__inner,.el-radio__input.is-checked .el-radio__inner{background:#0071e3!important;border-color:#0071e3!important}.el-radio-button__inner{border-radius:8px!important;border:1px solid #d2d2d7!important;color:#1d1d1f!important;transition:all .2s ease}.el-radio-button__inner:hover{color:#0071e3!important;border-color:#0071e3!important}.el-radio-button__orig-radio:checked+.el-radio-button__inner{background:#0071e3!important;border-color:#0071e3!important;color:#fff!important;box-shadow:0 1px 3px #0071e333}.el-empty{padding:60px 0}.el-empty__description{color:#86868b;font-size:14px}.el-watermark{border-radius:12px}.el-pagination{margin-top:32px;display:flex;justify-content:center}.el-pagination.is-background .el-pager li{border-radius:6px!important;margin:0 4px;border:1px solid #d2d2d7;color:#1d1d1f;transition:all .2s ease}.el-pagination.is-background .el-pager li:hover{color:#0071e3;border-color:#0071e3}.el-pagination.is-background .el-pager li.is-active{background:#0071e3!important;border-color:#0071e3!important;color:#fff!important}.el-dropdown-menu{border-radius:8px!important;border:1px solid rgba(0,0,0,.06)!important;box-shadow:0 4px 16px #0000001a!important;padding:8px!important;background:#fff!important}.el-dropdown-menu__item{border-radius:6px!important;margin:2px 0;transition:all .2s ease;color:#1d1d1f;font-size:14px}.el-dropdown-menu__item:hover{background:#f5f5f7!important;color:#0071e3!important}.el-switch.is-checked .el-switch__core{background:#0071e3!important}.el-select__wrapper{border-radius:8px!important;box-shadow:0 0 0 1px #0000001a inset!important;transition:all .2s ease}.el-select__wrapper:hover{box-shadow:0 0 0 1px #00000026 inset!important}.el-select__wrapper.is-focused{box-shadow:0 0 0 2px #0071e3 inset!important}.el-tooltip__popper{border-radius:8px!important;padding:8px 12px!important;background:#1d1d1f!important;color:#f5f5f7!important;font-size:12px;box-shadow:0 4px 12px #00000026}.el-loading-mask{border-radius:12px!important;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#fffc!important}.el-row{margin-bottom:20px}.el-scrollbar__wrap::-webkit-scrollbar{width:8px;height:8px}.el-scrollbar__wrap::-webkit-scrollbar-thumb{background:#d2d2d7;border-radius:4px}.el-scrollbar__wrap::-webkit-scrollbar-thumb:hover{background:#86868b}.el-scrollbar__wrap::-webkit-scrollbar-track{background:#f5f5f7;border-radius:4px}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:fadeIn .3s cubic-bezier(.25,.1,.25,1)}.user-page{padding:0;max-width:100%}.user-page__login-box{max-width:380px;margin:40px auto;padding:40px 32px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid rgba(0,0,0,.06)}.user-page__login-header{text-align:center;margin-bottom:32px}.user-page__login-icon{font-size:56px;margin-bottom:16px}.user-page__login-header h2{margin:12px 0 8px;font-size:28px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em}.user-page__login-header p{margin:0;color:#86868b;font-size:14px}.user-page__login-type-switch{width:100%;display:flex;margin-bottom:24px;gap:8px}.user-page__login-type-switch .el-radio-button{flex:1}.user-page__login-type-switch .el-radio-button__inner{width:100%;border-radius:8px!important}.user-page__login-form{margin-bottom:24px}.user-page__login-form .el-form-item{margin-bottom:20px}.user-page__login-btn{width:100%;height:44px;font-size:16px;font-weight:400;border-radius:980px!important}.user-page__register-tip{text-align:center;margin-top:24px;color:#86868b;font-size:14px}.user-page__register-tip .el-link{font-weight:400;margin-left:4px;color:#0071e3}.user-page__dashboard{padding:0;max-width:100%;margin:0 auto}.user-page__header-card{display:flex;align-items:center;gap:16px;padding:24px;background:#fbfbfd;border-radius:12px;margin-bottom:16px;border:1px solid rgba(0,0,0,.06)}.user-page__avatar{flex-shrink:0;border:2px solid rgba(255,255,255,.8);box-shadow:0 2px 8px #00000014}.user-page__info-text h2{margin:0 0 4px;color:#1d1d1f;font-size:22px;font-weight:600;letter-spacing:-.022em}.user-page__username{margin:0;color:#86868b;font-size:14px}.user-page__stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:16px}.user-page__stat-card{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:10px;box-shadow:0 1px 3px #0000000a;border:1px solid rgba(0,0,0,.06);transition:all .2s ease}.user-page__stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.user-page__stat-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.user-page__stat-icon--coin{background:#ffc10726;color:#f39c12}.user-page__stat-icon--money{background:#0071e326;color:#0071e3}.user-page__stat-icon--course{background:#ff572226;color:#ff5722}.user-page__stat-icon--question{background:#4caf5026;color:#4caf50}.user-page__stat-content{flex:1;min-width:0}.user-page__stat-label{margin:0 0 4px;color:#86868b;font-size:12px;font-weight:400}.user-page__stat-value{margin:0;color:#1d1d1f;font-size:20px;font-weight:600;letter-spacing:-.022em}.user-page__apikey-section{padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000a;border:1px solid rgba(0,0,0,.06);margin-bottom:16px}.user-page__section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px}.user-page__section-header .el-icon{font-size:18px;color:#0071e3}.user-page__section-header h3{margin:0;font-size:17px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em}.user-page__apikey-display{margin-top:12px}.user-page__apikey-input .el-input__inner{font-family:SF Mono,Monaco,Menlo,Courier New,monospace;font-size:13px}.user-page__actions{display:flex;justify-content:center;gap:12px;padding:20px;background:#fff;border-radius:12px;box-shadow:0 1px 3px #0000000a;border:1px solid rgba(0,0,0,.06)}@media (max-width: 768px){.user-page__dashboard{padding:0}.user-page__header-card{flex-direction:column;text-align:center;padding:20px}.user-page__stats-grid{grid-template-columns:repeat(2,1fr);gap:10px}.user-page__stat-card{padding:14px}.user-page__stat-icon{width:36px;height:36px;font-size:18px}.user-page__stat-value{font-size:18px}.user-page__apikey-section{padding:16px}.user-page__actions{flex-direction:column}.user-page__actions .el-button{width:100%}}.home-container{padding:0}.user-status-card{margin-bottom:20px}.user-status{display:flex;justify-content:space-between;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:16px;flex:1;min-width:0}.user-status-card .el-avatar{flex-shrink:0;border:2px solid rgba(0,0,0,.06)}.user-details{flex:1;min-width:0}.user-details h3{margin:0 0 8px;font-size:20px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-details p{margin:0;font-size:13px;color:#86868b;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.user-actions{flex-shrink:0}.features-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin:20px 0}.pages-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px;margin:16px 0}.page-button{min-width:0!important;width:100%;height:60px!important;display:inline-flex!important;flex-direction:column!important;justify-content:center!important;align-items:center!important;padding:8px 6px!important;border-radius:6px!important;background:#fff!important;border:1px solid rgba(0,0,0,.06)!important;box-shadow:0 1px 2px #00000008!important;transition:all .2s cubic-bezier(.25,.1,.25,1);color:#1d1d1f!important;position:relative;overflow:hidden;vertical-align:top;margin-left:0!important}.pages-grid .page-button+.page-button{margin-left:0!important}.page-button:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:#0071e3;transform:scaleX(0);transition:transform .2s ease}.page-button:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014!important;border-color:#0071e34d!important;background:#fbfbfd!important}.page-button:hover:before{transform:scaleX(1)}.page-button :deep(*){display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;gap:3px;width:100%;margin:0!important}.page-button :deep(.el-icon){font-size:16px!important;margin:0!important;padding:0!important;color:#0071e3;flex-shrink:0;width:auto;height:auto}.page-button :deep(span:not(.el-icon)){font-size:11px!important;font-weight:500;letter-spacing:-.011em;line-height:1.2;margin:0!important;padding:0!important;display:block!important}@media (max-width: 768px){.pages-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.page-button{height:68px!important;padding:8px 6px!important}.page-button :deep(.el-icon){font-size:16px!important;margin-bottom:2px}.page-button :deep(span){font-size:11px!important}.papers-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}}@media (max-width: 480px){.pages-grid{grid-template-columns:repeat(2,1fr)}.user-status{flex-direction:column;align-items:flex-start;gap:12px}.user-actions,.user-actions .el-button{width:100%}.papers-grid{grid-template-columns:1fr}.header-actions{flex-direction:column}.header-actions .el-button{width:100%}}.version-section{margin:32px 0 24px;padding:20px 24px;background:#fbfbfd;border-radius:12px;border:1px solid rgba(0,0,0,.06);text-align:center}.version-section p{margin:0;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:10px}.version-section p:first-child{font-size:14px;margin-bottom:8px}.version-section p:last-child{font-size:13px;color:#86868b;margin-top:12px;justify-content:center}.sponsor-link{color:#0071e3;text-decoration:none;font-weight:400;transition:color .2s ease}.sponsor-link:hover{color:#0077ed;text-decoration:underline}.paper-library-container{padding:0}.tips-card{margin-bottom:20px}.tips-card .el-alert{margin-bottom:0;border-radius:8px!important}.tips-card .el-alert :deep(.el-alert__content){font-size:13px;line-height:1.6}.search-card{margin-bottom:20px}.search-card .el-card__body{padding:20px!important}.search-header{display:flex;gap:12px;align-items:center;margin-bottom:12px}.search-stats{display:flex;gap:8px;margin-top:12px;justify-content:flex-start;align-items:center}.search-stats .el-tag{font-size:12px;padding:4px 10px!important}.papers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:24px}.papers-grid .el-empty{grid-column:1 / -1}.paper-card{cursor:pointer;transition:all .2s cubic-bezier(.25,.1,.25,1);height:100%;display:flex;flex-direction:column}.paper-card .el-card__body{display:flex;flex-direction:column;flex:1;padding:20px!important}.paper-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014!important;border-color:#0071e340!important}.paper-header{display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}.paper-icon{flex-shrink:0;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#0071e314;border-radius:8px;color:#0071e3}.paper-info{flex:1;min-width:0}.paper-title{margin:0 0 10px;font-size:16px;font-weight:600;color:#1d1d1f;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;letter-spacing:-.022em}.paper-meta{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}.paper-meta .el-tag{margin:0;font-size:11px;padding:3px 8px!important}.paper-footer{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:14px;border-top:1px solid rgba(0,0,0,.06)}.paper-actions{display:flex;align-items:center;gap:6px;flex:1}.paper-actions .el-button{font-size:12px;padding:6px 12px!important}.paper-footer .el-icon{color:#86868b;font-size:16px;flex-shrink:0;transition:transform .2s ease,color .2s ease}.paper-card:hover .paper-footer .el-icon{transform:translate(2px);color:#0071e3}.header-card{margin-bottom:20px}.header-card .el-card__body{padding:24px!important}.header-content{display:flex;flex-direction:column;gap:16px}.header-actions{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid rgba(0,0,0,.06)}.header-actions .el-button{font-size:13px;padding:8px 16px!important}.course-info h2,.chapter-info-header h2{margin:0 0 10px;font-size:22px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em;line-height:1.3}.course-stats,.chapter-info-header{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-top:6px}.course-stats .el-tag,.chapter-info-header .el-tag{font-size:12px;padding:4px 10px!important}.chapters-list{display:flex;flex-direction:column;gap:12px}.chapter-card{cursor:pointer;transition:all .3s cubic-bezier(.25,.1,.25,1)}.chapter-card .el-card__body{padding:18px 20px!important}.chapter-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014!important;border-color:#0071e333!important}.chapter-header{display:flex;align-items:center;gap:16px}.chapter-number{width:36px;height:36px;border-radius:8px;background:#0071e3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:600;flex-shrink:0;box-shadow:0 2px 6px #0071e340}.chapter-info{flex:1;min-width:0}.chapter-meta{margin-top:6px}.chapter-title{margin:0;font-size:17px;font-weight:600;color:#1d1d1f;letter-spacing:-.022em;line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical}.chapter-arrow{flex-shrink:0;font-size:20px;color:#86868b;transition:transform .2s ease,color .2s ease}.chapter-card:hover .chapter-arrow{transform:translate(4px);color:#0071e3}.chapter-actions{display:flex;align-items:center;gap:10px;margin-left:auto;flex-shrink:0}.questions-container{display:flex;flex-direction:column;gap:20px}.question-list-view .questions-container{margin-top:0}.question-card{transition:all .2s cubic-bezier(.25,.1,.25,1)}.question-card .el-card__body{padding:20px!important}.question-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014!important;border-color:#0071e340!important}.question-number{display:inline-block;padding:4px 12px;background:#0071e3;color:#fff;border-radius:6px;font-size:12px;font-weight:600;margin-bottom:14px;box-shadow:0 1px 4px #0071e333}.question-title{font-size:15px;line-height:1.6;color:#1d1d1f;margin-bottom:16px;font-weight:400;word-break:break-word;padding:14px;background:#f5f5f7;border-radius:8px}.question-title img{max-width:100%;height:auto;border-radius:8px;margin:12px 0}.question-options{margin-bottom:20px}.option-item{display:flex;align-items:flex-start;padding:12px 14px;margin-bottom:8px;background:#f5f5f7;border-radius:8px;transition:all .2s ease;border:1px solid transparent}.option-item:last-child{margin-bottom:0}.option-item:hover{background:#ebebed;transform:translate(2px);border-color:#0071e326}.option-item.is-answer{background:#00cc3314;border:1px solid rgba(0,204,51,.25);color:#1d1d1f;font-weight:500}.option-item.is-answer:hover{background:#00cc331f;border-color:#00cc3359}.option-label{flex-shrink:0;font-weight:600;margin-right:12px;min-width:24px;color:#86868b}.option-item.is-answer .option-label{color:#0c3}.option-content{flex:1;line-height:1.6;word-break:break-word}.option-content img{max-width:100%;height:auto;border-radius:6px;margin:8px 0}.question-answer{margin-top:16px;padding-top:16px;border-top:1px solid rgba(0,0,0,.06)}.question-answer .el-divider{margin:0 0 12px!important}.question-answer .el-divider__text{font-size:12px;color:#0c3;font-weight:600}.question-answer .el-tag{margin:4px 6px 4px 0;font-size:12px;padding:4px 10px!important}.answer-content{padding:14px;background:#00cc330d;border-radius:8px;color:#1d1d1f;line-height:1.6;word-break:break-word;border:1px solid rgba(0,204,51,.15)}.answer-content img{max-width:100%;height:auto;border-radius:6px;margin:8px 0}.ai-container{padding:0}.ai-container .search-card,.ai-container .result-card,.ai-container .copyright-card{margin-bottom:20px}.ai-container .search-card .card-header,.ai-container .result-card .card-header,.ai-container .copyright-card .card-header{display:flex;align-items:center;justify-content:space-between}.ai-container .search-type{margin-bottom:16px}.ai-container .result-content{min-height:100px;padding:8px 0}.ai-container .copyright-content{font-size:14px;line-height:1.7;color:#1d1d1f}.ai-container .copyright-content :deep(p){margin:8px 0}.ai-container .copyright-content :deep(a){color:#0071e3;text-decoration:none}.ai-container .copyright-content :deep(a):hover{text-decoration:underline}.ask-container{padding:0}.ask-container .el-row{margin-bottom:16px}.ask-container .el-col{margin-bottom:12px}.ask-container .el-form{background:#fff;padding:20px;border-radius:12px;border:1px solid rgba(0,0,0,.06)}.ask-container .el-form-item{margin-bottom:16px}.ask-container .el-checkbox{margin-right:16px;margin-bottom:12px}.ask-container .el-checkbox :deep(.el-checkbox__label){font-size:14px;color:#1d1d1f}.ask-container .el-button.aah_btn{width:100%;margin-bottom:12px}.ask-container .aah_bomHet50{background:#fbfbfd;border-radius:10px;padding:12px 16px;margin-bottom:16px;border:1px solid rgba(0,0,0,.06)}.ask-container table{width:100%;border-collapse:collapse;margin:16px 0;background:#fff;border-radius:8px;overflow:hidden;border:1px solid rgba(0,0,0,.06)}.ask-container table tr{border-bottom:1px solid rgba(0,0,0,.04)}.ask-container table tr:last-child{border-bottom:none}.ask-container table td{padding:12px 16px;font-size:14px;color:#1d1d1f}.ask-container table select{width:100%;padding:8px 12px;border-radius:6px;border:1px solid rgba(0,0,0,.1);font-size:14px;color:#1d1d1f;background:#fff}.ask-container table select:focus{outline:none;border-color:#0071e3;box-shadow:0 0 0 2px #0071e31a}.ask-container .el-divider{margin:16px 0!important}.ask-container .el-divider__text{font-size:12px}.preview-container{padding:0}.preview-header{background:#fff;border-radius:12px;padding:28px 32px;margin-bottom:20px;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.header-content{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:24px}.header-title{flex:1;min-width:0}.header-title h2{color:#1d1d1f;font-size:28px;font-weight:600;margin:0 0 6px;letter-spacing:-.022em;line-height:1.2}.header-title p{color:#86868b;font-size:14px;margin:0;font-weight:400}.header-stats{display:flex;gap:16px;align-items:center;flex-shrink:0}.stat-item{display:flex;flex-direction:column;align-items:center;padding:12px 20px;background:#f5f5f7;border-radius:8px;min-width:80px}.stat-number{font-size:24px;font-weight:600;color:#1d1d1f;line-height:1;margin-bottom:4px;letter-spacing:-.022em}.stat-label{font-size:11px;color:#86868b;font-weight:400;text-transform:uppercase;letter-spacing:.5px}.stat-divider{width:1px;height:32px;background:#00000014}.preview-alert{margin-bottom:20px;border-radius:8px!important}.preview-alert :deep(.el-alert__content){font-size:13px;line-height:1.6;color:#1d1d1f}.search-section{margin-bottom:24px;padding:20px;background:#fff;border-radius:12px;border:1px solid rgba(0,0,0,.06);box-shadow:0 1px 3px #0000000a}.search-section .el-input{margin-bottom:0}.search-result-info{margin-top:12px;text-align:left;animation:fadeIn .3s ease-out}.search-result-info .el-tag{font-size:13px;padding:6px 12px!important;background:#0071e31a!important;color:#0071e3!important;border:none!important}.empty-state{padding:80px 20px}.empty-icon{font-size:80px;margin-bottom:20px}.questions-list{display:flex;flex-direction:column;gap:20px;margin-bottom:32px}.question-item-wrapper{animation:fadeIn .4s ease-out}.question-item-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 2px #0000000a;border:1px solid rgba(0,0,0,.06);position:relative;transition:all .2s cubic-bezier(.25,.1,.25,1);overflow:visible}.question-item-card:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000014;border-color:#0071e333}.question-badge{position:absolute;top:-10px;left:20px;z-index:10}.badge-number{display:inline-flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 10px;background:#0071e3;color:#fff;font-size:15px;font-weight:600;border-radius:8px;box-shadow:0 2px 6px #0071e340}.question-actions-top{position:absolute;top:16px;right:16px;display:flex;gap:6px;z-index:10}.question-actions-top .el-button{width:32px;height:32px;padding:0;border-radius:6px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 2px #0000000f}.question-main{margin-top:24px}.question-header-section{margin-bottom:20px}.question-type-tag{font-size:13px;font-weight:500;padding:6px 12px!important;border-radius:6px!important;background:#0071e31a!important;border:none!important;color:#0071e3!important}.question-text{font-size:15px;line-height:1.6;color:#1d1d1f;margin-bottom:20px;padding:16px;background:#f5f5f7;border-radius:8px;border:none}.question-text img{max-width:100%;height:auto;border-radius:8px;margin:12px 0}.options-section{margin-bottom:24px}.complex-question-tip{margin-bottom:20px}.options-list{display:flex;flex-direction:column;gap:12px}.option-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:#f5f5f7;border:1px solid transparent;border-radius:8px;transition:all .2s ease;position:relative;cursor:pointer}.option-item:hover{background:#ebebed;border-color:#0071e326;transform:translate(2px)}.option-item.option-correct{background:#00cc3314;border-color:#00cc3340;border-width:1px}.option-item.option-correct:hover{background:#00cc331f;border-color:#00cc3359;transform:translate(2px)}.option-letter{display:flex;align-items:center;justify-content:center;min-width:28px;height:28px;background:#fff;border:1px solid #d2d2d7;border-radius:6px;color:#1d1d1f;font-size:13px;font-weight:600;flex-shrink:0;transition:all .2s ease}.option-item.option-correct .option-letter{background:#0c3;border-color:#0c3;color:#fff}.option-text{flex:1;line-height:1.6;color:#1d1d1f;padding-top:6px}.correct-badge{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:#0c3;color:#fff;border-radius:50%;font-size:16px;font-weight:600;flex-shrink:0;box-shadow:0 2px 8px #00cc334d;animation:scaleIn .3s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.answer-section{background:#00cc330d;border-radius:8px;padding:16px;border:1px solid rgba(0,204,51,.2);margin-top:20px}.answer-header{display:flex;align-items:center;gap:6px;margin-bottom:12px;color:#0c3;font-size:14px;font-weight:600}.answer-header .el-icon{font-size:20px}.answer-content-wrapper{margin-top:12px}.answer-tags{display:flex;flex-wrap:wrap;gap:8px}.answer-tags .el-tag{font-size:15px;padding:8px 16px!important;border-radius:8px!important;font-weight:500}.answer-text{padding:16px;background:#fff;border-radius:8px;line-height:1.6;color:#1d1d1f;box-shadow:0 1px 3px #0000000a}.no-answer{display:flex;align-items:center;gap:8px;color:#86868b;font-style:italic;padding:12px}.no-answer .el-icon{font-size:18px}.pagination-wrapper{display:flex;justify-content:center;padding:24px 0;background:#fff;border-radius:12px;box-shadow:0 1px 2px #0000000a;border:1px solid rgba(0,0,0,.06);margin-top:20px}.preview-container .el-watermark{min-height:200px}@media (max-width: 768px){.preview-header{padding:24px 20px}.header-content{flex-direction:column;align-items:flex-start}.header-title h2{font-size:24px}.header-stats{width:100%;justify-content:space-around}.stat-item{min-width:auto;flex:1}.question-item-card{padding:20px 16px}.question-badge{left:12px}.badge-number{min-width:40px;height:40px;font-size:16px}.question-actions-top{top:12px;right:12px}.question-text{font-size:15px;padding:16px}.option-item{padding:12px}.option-letter{min-width:28px;height:28px;font-size:13px}.answer-section{padding:16px}.pagination-wrapper{padding:24px 0}}@media print{.preview-header,.preview-alert,.search-section,.question-actions-top,.pagination-wrapper{display:none!important}.question-item-card{break-inside:avoid;box-shadow:none;border:1px solid rgba(0,0,0,.1);margin-bottom:16px}}', 
            p.appendChild(e);
        } catch (u) {
            console.error("\u5e94\u7528\u6837\u5f0f\u8868\u65f6\u51fa\u9519:", u);
        }
        o.mount(c);
    }, run = async () => {
        var e;
        (e = document.createElement("iframe")).style.display = "none", document.body.appendChild(e), 
        window.console = e.contentWindow.console;
        ($e === $e.top || [ /\/work\/doHomeWorkNew/i, /selectWorkQuestionYiPiYue/i, /uooconline.com/i, /edu-edu.com/i, /hblearning\/exam\/portal\/exam.jsp/i ].some((e => e.test(location.href))) || Gt.some((e => "hook" !== e.type && ("function" == typeof e.match ? e.match() : e.match)))) && (loadVue(), 
        parseRule(Gt));
    };

    (() => {
        if (hookXHR(), /onlineexamh5new.zhihuishu.com/i.test(get_href())) {
            const e = $e.yxyz;
            $e.yxyz = function(t, n) {
                !$e.yxyzpush && ($e.yxyzpush = []);
                let a = e(t, n);
                return $e.yxyzpush.push({
                    ...t,
                    data: a
                }), a;
            };
        }
        if (/icve.com.cn/i.test(get_href()) || /courshare.cn/i.test(get_href()) || /webtrn.cn/i.test(get_href())) {
            const e = $e.open;
            $e.open = function() {
                return arguments[2] = "", e.apply(this, arguments);
            };
        }
        if (/ytccr.com/i.test(get_href())) {
            const e = localStorage.getItem;
            localStorage.getItem = function(t) {
                if ("_debugger" === t) return !0;
                return e.apply(this, arguments);
            };
        }
        if (/91huayi.com/i.test(get_href())) {
            const e = $e.$.cookie;
            $e.$.cookie = function(t, n, a) {
                return console.log("Cookie\u64cd\u4f5c:", t, n, a), t.startsWith("switchTime") && void 0 !== n ? (n = void 0, 
                e.apply(this, [ t, n, a ])) : e.apply(this, arguments);
            };
        }
    })(), Gt.filter((e => e.match && e.hook)).forEach((e => {
        e.hook();
    })), "complete" === document.readyState ? run() : window.addEventListener("load", run);

})(Vue, DOMPurify, ElementPlus, $, CryptoJS);