影刀自动刷课(基础)
// ==UserScript==
// @name 影刀自动刷课(基础)
// @namespace npm/vite-plugin-monkey
// @version 0.0.1
// @author monkey
// @description 影刀自动刷课,自动做选择题,自动下一节
// @license MIT
// @icon https://vitejs.dev/logo.svg
// @match https://www.yingdao.com/
// @match https://college.yingdao.com/*
// @match https://college.yingdao.com
// @require https://cdn.jsdelivr.net/npm/vue@3.4.32/dist/vue.global.prod.js
// @require https://cdn.jsdelivr.net/npm/vue-demi@0.14.10/lib/index.iife.min.js
// @require data:application/javascript,%3Bwindow.Vue%3DVue%3B
// @require https://cdn.jsdelivr.net/npm/element-plus@2.7.7/dist/index.full.min.js
// @require https://cdn.jsdelivr.net/npm/jquery@3.7.1/dist/jquery.min.js
// @resource element-plus/dist/index.css https://cdn.jsdelivr.net/npm/element-plus@2.7.7/dist/index.css
// @grant GM_addStyle
// @grant GM_getResourceText
// ==/UserScript==
(n=>{if(typeof GM_addStyle=="function"){GM_addStyle(n);return}const r=document.createElement("style");r.textContent=n,document.head.append(r)})(" :root{font-family:Inter,Avenir,Helvetica,Arial,sans-serif;font-size:16px;line-height:24px;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}#dia-box{position:fixed;top:0;right:0;z-index:2;margin:0;background-color:#9370db;display:flex;place-items:baseline;flex-direction:column;min-width:320px;min-height:100px}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.card{padding:2em}#app{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.pointer[data-v-d6e839be]{pointer-events:auto!important}.logo[data-v-d6e839be]{height:6em;padding:1.5em;will-change:filter}.logo[data-v-d6e839be]:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.vue[data-v-d6e839be]:hover{filter:drop-shadow(0 0 2em #42b883aa)}*,:before,:after{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 rgb(0 0 0 / 0);--un-ring-shadow:0 0 rgb(0 0 0 / 0);--un-shadow-inset: ;--un-shadow:0 0 rgb(0 0 0 / 0);--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgb(147 197 253 / .5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }::backdrop{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 rgb(0 0 0 / 0);--un-ring-shadow:0 0 rgb(0 0 0 / 0);--un-shadow-inset: ;--un-shadow:0 0 rgb(0 0 0 / 0);--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgb(147 197 253 / .5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }.aspect-square{aspect-ratio:1/1}.w-100\\%,.w-full{width:100%}.w-200{width:200px}.flex-row{flex-direction:row}.rounded-5{border-radius:5px}.rounded-l-20{border-top-left-radius:20px;border-bottom-left-radius:20px}.bg-blue-200{--un-bg-opacity:1;background-color:rgb(191 219 254 / var(--un-bg-opacity))}.bg-blue-300{--un-bg-opacity:1;background-color:rgb(147 197 253 / var(--un-bg-opacity))}.bg-blue-400{--un-bg-opacity:1;background-color:rgb(96 165 250 / var(--un-bg-opacity))}.bg-blue-500{--un-bg-opacity:1;background-color:rgb(59 130 246 / var(--un-bg-opacity))}.bg-gray{--un-bg-opacity:1;background-color:rgb(156 163 175 / var(--un-bg-opacity))}.bg-gray-200{--un-bg-opacity:1;background-color:rgb(229 231 235 / var(--un-bg-opacity))}.bg-slate-300{--un-bg-opacity:1;background-color:rgb(203 213 225 / var(--un-bg-opacity))}.px-5{padding-left:5px;padding-right:5px}.py-5{padding-top:5px;padding-bottom:5px}.filter{filter:var(--un-blur) var(--un-brightness) var(--un-contrast) var(--un-drop-shadow) var(--un-grayscale) var(--un-hue-rotate) var(--un-invert) var(--un-saturate) var(--un-sepia)} ");
(function (vue, jquery, ElementPlus) {
'use strict';
function okMsg(title, msg = "") {
if (msg) {
ElementPlus.ElNotification({
title,
message: msg,
type: "success"
});
} else {
ElementPlus.ElNotification({
title,
type: "success"
});
}
}
function errMsg(title, msg = "") {
if (msg) {
ElementPlus.ElNotification({
title,
message: msg,
type: "error"
});
} else {
ElementPlus.ElNotification({
title,
type: "error"
});
}
}
function warnMsg(title, msg = "") {
if (msg) {
ElementPlus.ElNotification({
title,
message: msg,
type: "warning"
});
} else {
ElementPlus.ElNotification({
title,
type: "warning"
});
}
}
function filterLogList(type) {
const logMain = jquery("#el-log-main");
logMain.empty();
let list = window.logList;
if (type !== "all") {
list = list.filter((i) => {
return i.type === type;
});
}
const dDiv = jquery("<div></div>");
list.forEach((i) => {
dDiv.append(getPByLog(i));
});
logMain.get()[0].append(dDiv.get()[0]);
}
function getPByLog(log) {
const msg = log.id + " " + log.msg;
let tex = jquery(`<p class="scrollbar-demo-item">${msg}</p>`);
if (log.type === "warn") {
tex = jquery(`<p style="color:indianred">${msg}</p>`);
}
if (log.type === "err") {
tex = jquery(`<p style="color:darkred">${msg}</p>`);
}
tex.get()[0].style.whiteSpace = "pre-wrap";
return tex;
}
function printLog(msg, type = "info") {
if (!window.logListSize) {
window.logListSize = 0;
}
let pojo = {
type,
msg,
id: window.logListSize + 1
};
window.logListSize = pojo.id;
const logMain = jquery("#el-log-main").get()[0];
let log = getPByLog(pojo);
logMain.prepend(log[0]);
window.logList.unshift(pojo);
if (type === "err") {
errMsg(msg);
}
}
function getOneByClassLike(className, eleName = "", needThrow = true) {
const eles = jquery(`[class*=${className}]`);
if (eles.length === 1) {
return eles[0];
}
if (needThrow) {
errMsg("元素获取失败", eleName);
throw new Error("元素获取失败");
}
}
function gotoOffSet(selectStr) {
var _a;
const ele = jquery(selectStr);
let top = ((_a = ele.offset()) == null ? void 0 : _a.top) || 10;
if (top > 10) {
jquery(".ant-layout-content")[0].scrollTo(0, top);
}
}
function getRandom(min, max) {
return Math.floor(Math.random() * (max - min + 1)) + min;
}
function getOneByClassFull(className, eleName = "", needThrow = true) {
const eles = jquery(className);
if (eles.length === 1) {
return eles[0];
}
if (needThrow) {
errMsg("元素获取失败", eleName);
} else {
return null;
}
}
function getOneById(id, eleName = "", needThrow = true) {
const eles = jquery(`#${id}`);
if (eles.length === 1) {
return eles[0];
}
if (needThrow) {
errMsg("元素获取失败", eleName);
} else {
return null;
}
}
function getOneBySelect(xpath, eleName = "", needThrow = true) {
const eles = jquery(xpath);
if (eles.length === 1) {
return eles[0];
}
if (needThrow) {
errMsg("元素获取失败", eleName);
} else {
return null;
}
}
function sleep(time) {
const rate = window["ydExamRate"] ? window["ydExamRate"] : 3;
time = rate * time;
return new Promise((resolve) => {
setTimeout(() => {
resolve("");
}, time);
});
}
const _hoisted_1$1 = { class: "flex-row w-full" };
const _hoisted_2$1 = { class: "bg-blue-300 px-5 py-5 rounded-l-20" };
const _hoisted_3 = /* @__PURE__ */ vue.createElementVNode("div", null, " 设置等待的倍率 ", -1);
const _hoisted_4 = /* @__PURE__ */ vue.createElementVNode("span", null, "等待倍率", -1);
const _hoisted_5 = { class: "bg-blue-400 px-5 py-5 rounded-l-20" };
const _hoisted_6 = { class: "bg-blue-500 px-5 py-5 rounded-l-20" };
const _hoisted_7 = /* @__PURE__ */ vue.createElementVNode("span", { class: "w-full" }, "1. 先进入课程", -1);
const _hoisted_8 = /* @__PURE__ */ vue.createElementVNode("span", { class: "w-full" }, "2. 点击左侧学习", -1);
const _hoisted_9 = /* @__PURE__ */ vue.createElementVNode("span", { class: "w-full" }, "3. 考试题库,全自动脚本请联系: xxdlovo", -1);
const _sfc_main$1 = /* @__PURE__ */ vue.defineComponent({
__name: "MainPage",
props: {
msg: {}
},
setup(__props) {
const helpShow = vue.ref(false);
const srcList = vue.ref([
"https://img.picui.cn/free/2024/10/14/670c7b0d13805.png",
"https://img.picui.cn/free/2024/10/14/670c7cfd42cf1.png",
"https://img.picui.cn/free/2024/10/14/670c7d91d3e70.png"
]);
const forceStop = vue.ref(false);
const showHelp = () => {
helpShow.value = !helpShow.value;
};
const autoExam = async () => {
warnMsg("全自动刷课,可接入题库,自动考试/搜题. 高级版专享,联系xxdlovo");
};
const needStop = async () => {
if (forceStop.value) {
printLog("强制停止了", "err");
throw new Error("强制停止了");
}
};
const subExamSelectMock = async (lessonSection = "") => {
await needStop();
var exams = jquery("div[class^=radio_or_checkbox_box]").children();
printLog("选择题个数: " + exams.length);
gotoOffSet("div[class^=radio_or_checkbox_box]");
for (let i = 0; i < exams.length; i++) {
printLog("操作选择题..." + i);
await needStop();
const exam = exams[i];
if (exam.style.display === "none") {
continue;
}
const options = jquery(exam).find("li");
const ele = options[getRandom(0, options.length - 1)];
const itemClassName = ele.children[0].className;
if (itemClassName.indexOf("ant-checkbox-wrapper-checked") === -1) {
ele.click();
await sleep(5);
}
if (i != exams.length - 1) {
await manyClickExam(exam);
}
await manyClickExam(exam);
await sleep(6);
}
const inputAnswer = jquery("#viewer_QuestionsAnswers .ant-input");
printLog("输入题个数 " + inputAnswer.length);
if (inputAnswer.length !== 0) {
printLog("付费开启: xxdlovo", "warn");
}
const operation = jquery("#viewer_software_operation");
printLog("操作题个数: " + operation.length);
if (operation.length != 0) {
printLog("付费开启: xxdlovo", "warn");
}
};
const manyClickExam = async (exam) => {
var _a;
await needStop();
const btnList = jquery(exam).find(".ant-btn-round");
if (btnList) {
for (let btn of btnList.children()) {
await needStop();
const btnName = btn.textContent.trim();
console.log("按钮名称", btn.textContent.trim());
if (btnName === "提 交" || btnName === "下一题" || btnName === "开启下一课") {
await sleep(200);
if ((_a = btn.parentElement) == null ? void 0 : _a.getAttributeNode("disabled")) {
warnMsg("选项不能提交,请检查!");
throw new Error("不能点击,请检查");
}
await sleep(10);
btn.click();
break;
}
}
}
console.log("不点了");
return;
};
const leftTreeLearn = async () => {
const href = window.location.href;
if (href !== "https://college.yingdao.com/course/courseDetail") {
warnMsg("请先进入学习页面");
return;
}
await sleep(200);
const leftTree = jquery("#course_detail_sidebar .list_item");
for (let i = 0; i < leftTree.length; i++) {
await needStop();
let course = leftTree[i];
const courseName = jquery(course).find(".list_item_text")[0].textContent;
const isOk = jquery(course).find(".finished_icon");
if (isOk.length === 1) {
printLog(courseName, "学完了");
} else {
printLog(courseName, "还没学");
course.click();
await sleep(500);
try {
await learnBook(i === leftTree.length - 1);
} catch (e) {
}
}
}
okMsg("恭喜,都学完了");
};
const ydExamRate = vue.ref(2);
const setExamRate = () => {
if (ydExamRate.value && ydExamRate.value > 0) {
window["ydExamRate"] = ydExamRate.value;
} else {
window["ydExamRate"] = 3;
}
okMsg("设置成功");
};
const learnBook = async (isFinal = false) => {
var _a, _b;
await needStop();
const href = window.location.href;
if (href !== "https://college.yingdao.com/course/courseDetail") {
warnMsg("请先进入学习页面");
return;
}
await sleep(30);
if (window.location.href !== "https://college.yingdao.com/course/courseDetail") {
await warnMsg("请进入课程目标后再开始学习");
return;
}
const lessonSection = (_a = getOneByClassFull(".list_item.active")) == null ? void 0 : _a.textContent;
const finished = !!getOneByClassFull(".list_item.active .finished_icon", "是否完成", false);
if (finished) {
printLog("已学习! ->" + lessonSection);
} else {
printLog("未学习! ->" + lessonSection);
await subExamSelectMock(lessonSection || "");
}
await okMsg(lessonSection || "", "完成学习");
await sleep(50);
let nextLesson = getOneByClassLike("next_lesson_button", "开启下一课/继续闯关按钮");
nextLesson.click();
if (isFinal) {
await sleep(200);
printLog("检测打分弹窗...");
const close = getOneByClassLike("close___", "关闭打分", true);
console.log("clode?", close);
if (close) {
close.click();
return;
}
} else {
for (let i = 0; i < 5; i++) {
await needStop();
const newTitle = (_b = getOneByClassFull(".list_item.active")) == null ? void 0 : _b.textContent;
if (newTitle === lessonSection) {
printLog("等待跳转...");
await sleep(300);
if (i === 4) {
warnMsg("跳转超时");
throw new Error("跳转超时");
}
} else {
printLog("成功跳转...");
break;
}
}
}
await sleep(200);
};
return (_ctx, _cache) => {
const _component_el_divider = vue.resolveComponent("el-divider");
const _component_el_button = vue.resolveComponent("el-button");
const _component_el_row = vue.resolveComponent("el-row");
const _component_el_input_number = vue.resolveComponent("el-input-number");
const _component_el_tooltip = vue.resolveComponent("el-tooltip");
const _component_el_image = vue.resolveComponent("el-image");
const _component_el_dialog = vue.resolveComponent("el-dialog");
return vue.openBlock(), vue.createElementBlock(vue.Fragment, null, [
vue.createElementVNode("div", _hoisted_1$1, [
vue.createVNode(_component_el_divider, { "content-position": "left" }, {
default: vue.withCtx(() => [
vue.createTextVNode("基本信息")
]),
_: 1
}),
vue.createElementVNode("div", _hoisted_2$1, [
vue.createVNode(_component_el_row, null, {
default: vue.withCtx(() => [
vue.createVNode(_component_el_button, {
round: "",
type: "success",
onClick: showHelp
}, {
default: vue.withCtx(() => [
vue.createTextVNode("帮助")
]),
_: 1
}),
!forceStop.value ? (vue.openBlock(), vue.createBlock(_component_el_button, {
key: 0,
round: "",
type: "warning",
onClick: _cache[0] || (_cache[0] = ($event) => forceStop.value = !forceStop.value)
}, {
default: vue.withCtx(() => [
vue.createTextVNode("暂停")
]),
_: 1
})) : vue.createCommentVNode("", true),
forceStop.value ? (vue.openBlock(), vue.createBlock(_component_el_button, {
key: 1,
round: "",
type: "success",
onClick: _cache[1] || (_cache[1] = ($event) => forceStop.value = !forceStop.value)
}, {
default: vue.withCtx(() => [
vue.createTextVNode("继续")
]),
_: 1
})) : vue.createCommentVNode("", true)
]),
_: 1
}),
vue.createVNode(_component_el_row, { class: "px-5 py-5" }, {
default: vue.withCtx(() => [
_hoisted_3,
vue.createVNode(_component_el_input_number, {
modelValue: ydExamRate.value,
"onUpdate:modelValue": _cache[2] || (_cache[2] = ($event) => ydExamRate.value = $event),
min: 1,
max: 10
}, {
prefix: vue.withCtx(() => [
_hoisted_4
]),
_: 1
}, 8, ["modelValue"]),
vue.createVNode(_component_el_button, {
round: "",
type: "danger",
onClick: setExamRate
}, {
default: vue.withCtx(() => [
vue.createTextVNode("设置")
]),
_: 1
})
]),
_: 1
})
]),
vue.createVNode(_component_el_divider, { "content-position": "left" }, {
default: vue.withCtx(() => [
vue.createTextVNode("前置课程")
]),
_: 1
}),
vue.createElementVNode("div", _hoisted_5, [
vue.createVNode(_component_el_tooltip, {
class: "box-item",
effect: "dark",
content: "进入课程页面,开始刷课",
placement: "top-start"
}, {
default: vue.withCtx(() => [
vue.createVNode(_component_el_button, {
round: "",
type: "success",
onClick: autoExam
}, {
default: vue.withCtx(() => [
vue.createTextVNode("课程学习")
]),
_: 1
})
]),
_: 1
}),
vue.createVNode(_component_el_tooltip, {
class: "box-item",
effect: "dark",
content: "找到下一个未学章节并进入",
placement: "top-start"
}, {
default: vue.withCtx(() => [
vue.createVNode(_component_el_button, {
round: "",
onClick: autoExam
}, {
default: vue.withCtx(() => [
vue.createTextVNode("继续闯关")
]),
_: 1
})
]),
_: 1
}),
vue.createVNode(_component_el_tooltip, {
class: "box-item",
effect: "dark",
content: "依次学习左侧的小节",
placement: "top-start"
}, {
default: vue.withCtx(() => [
vue.createVNode(_component_el_button, {
round: "",
onClick: leftTreeLearn
}, {
default: vue.withCtx(() => [
vue.createTextVNode("左侧学习")
]),
_: 1
})
]),
_: 1
}),
vue.createVNode(_component_el_tooltip, {
class: "box-item",
effect: "dark",
content: "只学习当前小节",
placement: "top-start"
}, {
default: vue.withCtx(() => [
vue.createVNode(_component_el_button, {
round: "",
onClick: _cache[3] || (_cache[3] = ($event) => learnBook(false))
}, {
default: vue.withCtx(() => [
vue.createTextVNode("小节学习")
]),
_: 1
})
]),
_: 1
})
]),
vue.createVNode(_component_el_divider, { "content-position": "left" }, {
default: vue.withCtx(() => [
vue.createTextVNode("考试区")
]),
_: 1
}),
vue.createElementVNode("div", _hoisted_6, [
vue.createVNode(_component_el_row, null, {
default: vue.withCtx(() => [
vue.createVNode(_component_el_button, {
round: "",
type: "success",
onClick: autoExam
}, {
default: vue.withCtx(() => [
vue.createTextVNode("自动答题")
]),
_: 1
})
]),
_: 1
})
])
]),
vue.createVNode(_component_el_dialog, {
modelValue: helpShow.value,
"onUpdate:modelValue": _cache[4] || (_cache[4] = ($event) => helpShow.value = $event),
title: "帮助",
width: "500"
}, {
default: vue.withCtx(() => [
_hoisted_7,
vue.createVNode(_component_el_image, {
style: { "width": "100%", "height": "300px" },
src: srcList.value[0],
"preview-src-list": srcList.value
}, null, 8, ["src", "preview-src-list"]),
_hoisted_8,
vue.createVNode(_component_el_image, {
style: { "width": "100%", "height": "300px" },
src: srcList.value[1],
"preview-src-list": srcList.value
}, null, 8, ["src", "preview-src-list"]),
_hoisted_9,
vue.createVNode(_component_el_image, {
style: { "width": "100%", "height": "300px" },
src: srcList.value[2],
"preview-src-list": srcList.value
}, null, 8, ["src", "preview-src-list"])
]),
_: 1
}, 8, ["modelValue"])
], 64);
};
}
});
const _hoisted_1 = { class: "w-100%" };
const _hoisted_2 = { class: "bg-gray-200 w-100% px-5 py-5 rounded-5" };
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
__name: "App",
setup(__props) {
const mainPageShow = vue.ref(false);
const clearLogHandle = () => {
okMsg("日志已清空");
window.logListSize = 0;
window.logList = [];
jquery("#el-log-main").empty();
};
const sleepLock = async () => {
await sleep(500);
console.log("清除");
window.lockInitSkip = false;
};
const init = async () => {
window.lockInit = true;
await sleep(600);
const mainInit = getOneById("mainInit", "操作按钮", false);
if (mainInit) {
window.lockInitSkip = true;
window.lockInit = false;
sleepLock();
console.log("已初始化");
return;
}
let main = null;
console.log("重新已初始化");
console.log(window.location.href);
if (window.location.href === "https://college.yingdao.com/examination") {
console.log(getOneBySelect("#examination_header > div:nth-child(3)"));
main = getOneBySelect("#examination_header > div:nth-child(3)");
} else {
main = getOneByClassLike("login_right___", "主", false);
if (!main) {
main = getOneById("course_detail_header", "课程表格", false);
if (main) {
main = main.children[1];
}
}
}
window.logList = [];
let div = document.createElement("div");
div.setAttribute("float", "right");
let aa = '<button id="mainInit" class="" style="font-weight: 600;padding-right: 10px;padding-top: 2px;padding-bottom: 2px;border-radius: 30px; background-color:#bfb2ff; color:purple">开始😀</button>';
div.innerHTML = aa;
if (main) {
main.append(div);
}
jquery("#mainInit").on("click", function() {
changeMainPage();
});
window.lockInit = false;
};
const changeMainPage = () => {
mainPageShow.value = !mainPageShow.value;
};
var _wr = function(type) {
var orig = history[type];
return function() {
var rv = orig.apply(this, arguments);
var e = new Event(type);
e.arguments = arguments;
window.dispatchEvent(e);
return rv;
};
};
history.pushState = _wr("pushState");
history.replaceState = _wr("replaceState");
vue.onMounted(() => {
init();
window.addEventListener("replaceState", function(e) {
if (window.lockInit || window.lockInitSkip) {
return;
}
init();
});
window.addEventListener("popstate", function(event) {
if (window.lockInit || window.lockInitSkip) {
return;
}
init();
});
window.addEventListener("pushState", function(e) {
if (window.lockInit || window.lockInitSkip) {
return;
}
init();
});
});
return (_ctx, _cache) => {
const _component_el_divider = vue.resolveComponent("el-divider");
const _component_el_button = vue.resolveComponent("el-button");
const _component_el_scrollbar = vue.resolveComponent("el-scrollbar");
const _component_el_dialog = vue.resolveComponent("el-dialog");
return vue.openBlock(), vue.createBlock(_component_el_dialog, {
modelValue: mainPageShow.value,
"onUpdate:modelValue": _cache[3] || (_cache[3] = ($event) => mainPageShow.value = $event),
title: "控制台(基础版)",
width: "500",
draggable: ""
}, {
default: vue.withCtx(() => [
vue.withDirectives(vue.createElementVNode("div", _hoisted_1, [
vue.createVNode(_sfc_main$1, { msg: " " }),
vue.createVNode(_component_el_divider, { "content-position": "left" }, {
default: vue.withCtx(() => [
vue.createTextVNode("日志展示")
]),
_: 1
}),
vue.createElementVNode("div", _hoisted_2, [
vue.createVNode(_component_el_button, {
onClick: _cache[0] || (_cache[0] = ($event) => vue.unref(filterLogList)("all"))
}, {
default: vue.withCtx(() => [
vue.createTextVNode("全部")
]),
_: 1
}),
vue.createVNode(_component_el_button, {
onClick: _cache[1] || (_cache[1] = ($event) => vue.unref(filterLogList)("warn")),
type: "warning"
}, {
default: vue.withCtx(() => [
vue.createTextVNode("警告")
]),
_: 1
}),
vue.createVNode(_component_el_button, {
onClick: _cache[2] || (_cache[2] = ($event) => vue.unref(filterLogList)("err")),
type: "danger"
}, {
default: vue.withCtx(() => [
vue.createTextVNode("错误")
]),
_: 1
}),
vue.createVNode(_component_el_button, {
onClick: clearLogHandle,
type: "info"
}, {
default: vue.withCtx(() => [
vue.createTextVNode("清空")
]),
_: 1
}),
vue.createVNode(_component_el_scrollbar, {
id: "el-log-main",
height: "400px"
})
])
], 512), [
[vue.vShow, mainPageShow.value]
])
]),
_: 1
}, 8, ["modelValue"]);
};
}
});
const _export_sfc = (sfc, props) => {
const target = sfc.__vccOpts || sfc;
for (const [key, val] of props) {
target[key] = val;
}
return target;
};
const App = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-d6e839be"]]);
const cssLoader = (e) => {
const t = GM_getResourceText(e);
return GM_addStyle(t), t;
};
cssLoader("element-plus/dist/index.css");
const app = vue.createApp(App);
app.use(ElementPlus);
app.mount(
(() => {
const app2 = document.createElement("div");
document.body.append(app2);
return app2;
})()
);
})(Vue, jQuery, ElementPlus);