// ==UserScript== // @name AI智能考试答题 // @version 1.3.1 // @namespace AI智能考试答题 // @description 💯【不限平台不限知识】🔍AI智能答题,不限平台不限知识💻自动联网搜索知识答题📝截图识别答题✅可选择模型规模🏆用于各类问答,网课问题,竞赛问题,专业术语,业务名称,情景问题,在线作业等。🥇操作简单🥇无需配置安装即可使用。🏆解除各类功能限制,解除字体加密。支持但不限于以下平台:支持【超星学习通】【智慧树】【职教云系列】【雨课堂】【考试星】【168网校】【u校园】【大学MOOC】【云班课】【优慕课】【继续教育类】【绎通云课堂】【九江系列】【柠檬文才】【亿学宝云】【优课学堂】【小鹅通】【安徽继续教育】【上海开放大学】【华侨大学自考网络助学平台】【良师在线】【和学在线】【人卫慕课】【国家开放大学】【山财培训网(继续教育)】【浙江省高等学校在线开放课程共享平台】【国地质大学远程与继续教育学院】【重庆大学网络教育学院】【浙江省高等教育自学考试网络助学平台】【湖南高等学历继续教育】【优学院】【学起系列】【青书学堂】【学堂在线】【英华学堂】【广开网络教学平台】【中国大学mooc】【新国开】【知到】【蓝墨云】【智慧职教】【云班课精品课】【山东专技】【西财在线绎通云】 // @author 智能考试答题 // @license GNU GPLv3 // @match *://*/* // @grant GM_getResourceText // @grant GM_info // @grant unsafeWindow // @grant GM_xmlhttpRequest // @grant GM_addStyle // @grant GM_registerMenuCommand // @grant GM_setValue // @grant GM_getValue // @grant GM_deleteValue // @grant GM_setClipboard // @grant GM_cookie // @run-at document-end // @connect baidu.com // @connect siliconflow.cn // @connect api.xunhupay.com // @connect toolchest.cn // @connect localhost // @resource Vue http://lib.baomitu.com/vue/2.6.0/vue.min.js // @resource JQ361JS https://cdn.bootcdn.net/ajax/libs/jquery/3.6.1/jquery.min.js // @resource jqueryweui https://cdn.bootcdn.net/ajax/libs/jquery-weui/1.2.1/js/jquery-weui.min.js // @resource weuiCss https://cdn.bootcdn.net/ajax/libs/weui/2.5.12/style/weui.min.css // @resource questionCss https://www.toolchest.cn/static/css/question_search.css // @resource bootstrap https://cdn.staticfile.net/twitter-bootstrap/4.3.1/css/bootstrap.min.css // @resource Table https://www.forestpolice.org/ttf/2.0/table.json // @require https://lib.baomitu.com/cryptico/0.0.1343522940/hash.min.js // @require https://lib.baomitu.com/jquery/3.6.0/jquery.min.js // @require https://www.toolchest.cn/static/js/kss.js // @icon  // ==/UserScript== (function () { 'use strict'; (function ($) { var tips = []; function handleWindowResize() { $.each(tips, function () { this.refresh(true); }); } $(window).resize(handleWindowResize); $.JPopBox = function (elm, options) { this.$elm = $(elm); this.opts = this.getOptions(options); var popBoxHtml = []; popBoxHtml.push('
'); if (this.opts.title != "") { popBoxHtml.push('
' + this.opts.title + '
'); } if (this.opts.isShowArrow) { popBoxHtml.push('
'); } popBoxHtml.push('
'), popBoxHtml.push('
'); this.$tip = $(popBoxHtml.join('')).appendTo(document.body); this.$arrow = this.$tip.find('div.JPopBox-tip-arrow'); this.$inner = this.$tip.find('div.JPopBox-tip-content'); this.disabled = false; this.content = null; this.init(); }; $.JPopBox.hideAll = function () { $.each(tips, function () { this.hide(); }); }; $.JPopBox.prototype = { getOptions: function (options) { options = $.extend({}, $.fn.jPopBox.defaults, options); if (options.delay && typeof options.delay == 'number') { options.delay = { show: options.delay, hide: options.delay }; } if (typeof options.offset == 'number') { options.offset = { X: options.offset, Y: options.offset }; } return options }, init: function () { tips.push(this); this.$elm.data('jPopBox', this); if (this.opts.trigger != 'none') { this.opts.trigger != "click" && this.$elm.on({ 'mouseenter.jPopBox': $.proxy(this.mouseenter, this), 'mouseleave.jPopBox': $.proxy(this.mouseleave, this) }); switch (this.opts.trigger) { case 'click': this.$elm.on('click.jPopBox', $.proxy(this.toggle, this)); break; case 'hover': if (this.opts.isTipHover) this.$tip.hover($.proxy(this.clearTimeouts, this), $.proxy(this.mouseleave, this)); break; case 'focus': this.$elm.on({ 'focus.jPopBox': $.proxy(this.showDelayed, this), 'blur.jPopBox': $.proxy(this.hideDelayed, this) }); break; } } }, toggle: function () { var active = this.$tip.data('active'); if (!active) this.showDelayed(); else this.hideDelayed(); }, mouseenter: function (e) { if (this.disabled) return true; this.updateCursorPos(e); this.$elm.attr('title', ''); if (this.opts.trigger == 'focus') return true; this.showDelayed(); }, mouseleave: function (e) { if (this.disabled || this.asyncAnimating && (this.$tip[0] === e.relatedTarget || jQuery.contains(this.$tip[0], e.relatedTarget))) return true; if (this.opts.trigger == 'focus') return true; this.hideDelayed(); }, mousemove: function (e) { if (this.disabled) return true; this.updateCursorPos(e); if (this.opts.isFollowCursor && this.$tip.data('active')) { this.calcPos(); this.$tip.css({ left: this.pos.l, top: this.pos.t }); } }, show: function () { this.$elm.trigger($.Event('show.jPopBox')); if (this.disabled || this.$tip.data('active')) return; this.reset(); this.update(); if (!this.content) return; this.display(); this.$elm.trigger($.Event('shown.jPopBox')); }, showDelayed: function (timeout) { this.clearTimeouts(); this.showTimeout = setTimeout($.proxy(this.show, this), typeof timeout == 'number' ? timeout : this.opts.delay.show); }, hide: function () { this.$elm.trigger($.Event('hide.jPopBox')); if (this.disabled || !this.$tip.data('active')) return; this.display(true); this.$elm.trigger($.Event('hidden.jPopBox')); }, hideDelayed: function (timeout) { this.clearTimeouts(); this.hideTimeout = setTimeout($.proxy(this.hide, this), typeof timeout == 'number' ? timeout : this.opts.delay.hide); }, reset: function () { this.$tip.queue([]).detach().css('visibility', 'hidden').data('active', false); this.$inner.find('*').jPopBox('hide'); this.$arrow.length && (this.$arrow[0].className = 'JPopBox-tip-arrow JPopBox-tip-arrow-top JPopBox-tip-arrow-right JPopBox-tip-arrow-bottom JPopBox-tip-arrow-left'); this.asyncAnimating = false; }, update: function (content, dontOverwriteOption) { if (this.disabled) return; var async = content !== undefined; if (async) { if (!dontOverwriteOption) this.opts.content = content; if (!this.$tip.data('active')) return; } else { content = this.opts.content; } // update content only if it has been changed since last time var self = this, newContent = typeof content == 'function' ? content.call(this.$elm[0], function (newContent) { self.update(newContent); }) : content; if (this.content !== newContent) { this.$inner.empty().append(newContent); this.content = newContent; } this.refresh(async); }, refresh: function (async) { if (this.disabled) return; if (async) { if (!this.$tip.data('active')) return; } this.$tip.css({ left: 0, top: 0 }).appendTo(document.body); if (this.opacity === undefined) this.opacity = this.$tip.css('opacity'); this.calcPos(); this.$tip.css({ left: this.pos.l, top: this.pos.t }); }, display: function (hide) { var active = this.$tip.data('active'); if (active && !hide || !active && hide) return; this.$tip.stop(); var from = {}, to = {}; from.opacity = hide ? this.$tip.css('opacity') : 0; to.opacity = hide ? 0 : this.opacity; this.$tip.css(from).animate(to, 300); hide ? this.$tip.queue($.proxy(this.reset, this)) : this.$tip.css('visibility', 'inherit'); this.$tip.data('active', !active); }, disable: function () { this.reset(); this.disabled = true; }, enable: function () { this.disabled = false; }, destroy: function () { this.reset(); this.$tip.remove(); delete this.$tip; this.content = null; this.$elm.off('.jPopBox').removeData('jPopBox'); tips.splice($.inArray(this, tips), 1); }, clearTimeouts: function () { if (this.showTimeout) { clearTimeout(this.showTimeout); this.showTimeout = 0; } if (this.hideTimeout) { clearTimeout(this.hideTimeout); this.hideTimeout = 0; } }, updateCursorPos: function (e) { this.eventX = e.pageX; this.eventY = e.pageY; }, calcPos: function () { this.tipOuterW = this.$tip.outerWidth(); this.tipOuterH = this.$tip.outerHeight(); var pos = { l: 0, t: 0, arrow: '' }, $win = $(window), win = { l: $win.scrollLeft(), t: $win.scrollTop(), w: $win.width(), h: $win.height() }, xL, xC, xR, yT, yC, yB, arrowOuterWH, placement, isAuto = false; var elmOffset = this.$elm.offset(), elm = { l: elmOffset.left, t: elmOffset.top, w: this.$elm.outerWidth(), h: this.$elm.outerHeight() }; xL = elm.l; // left xC = xL + Math.floor(elm.w / 2); // h center xR = xL + elm.w; // right yT = elm.t; // top yC = yT + Math.floor(elm.h / 2); // v center yB = yT + elm.h; // bottom placement = this.opts.placement; var autoReg = /\s?auto?\s?/i; isAuto = autoReg.test(placement); if (isAuto) placement = placement.replace(autoReg, '') || 'top'; //calc left position switch (placement) { case "top": case "bottom": pos.l = xC - Math.floor(this.tipOuterW / 2) - this.opts.offset.X; { if (pos.l + this.tipOuterW > win.l + win.w) pos.l = win.l + win.w - this.tipOuterW; else if (pos.l < win.l) pos.l = win.l; } break; case "right": arrowOuterWH = this.setArrowAndGetWH(placement); pos.l = xR + this.opts.offset.X + arrowOuterWH.W; if (isAuto && pos.l + this.tipOuterW > win.l + win.w) { arrowOuterWH = this.setArrowAndGetWH("left"); pos.l = xL - this.tipOuterW - this.opts.offset.X - arrowOuterWH.W; } break; case "left": arrowOuterWH = this.setArrowAndGetWH(placement); pos.l = xL - this.tipOuterW - this.opts.offset.X - arrowOuterWH.W; if (isAuto && pos.l < win.l) { arrowOuterWH = this.setArrowAndGetWH("right"); pos.l = xR + this.opts.offset.X + arrowOuterWH.W; } break; } //calc top position switch (placement) { case "top": arrowOuterWH = this.setArrowAndGetWH(placement); pos.t = yT - this.tipOuterH - this.opts.offset.Y - arrowOuterWH.H; if (isAuto && pos.t < win.t) { arrowOuterWH = this.setArrowAndGetWH("bottom"); pos.t = yB + this.opts.offset.Y + arrowOuterWH.H; } break; case "bottom": arrowOuterWH = this.setArrowAndGetWH(placement); pos.t = yB + this.opts.offset.Y + arrowOuterWH.H; if (isAuto && pos.t + this.tipOuterH > win.t + win.h) { arrowOuterWH = this.setArrowAndGetWH("top"); pos.t = yT - this.tipOuterH - this.opts.offset.Y - arrowOuterWH.H; } break; case "right": case "left": pos.t = yC - Math.floor(this.tipOuterH / 2) - this.opts.offset.Y; { if (pos.t + this.tipOuterH > win.t + win.h) { pos.t = win.t + win.h - this.tipOuterH; } else if (pos.t < win.t) pos.t = win.t; } break; } this.pos = pos; }, setArrowAndGetWH: function (placement) { var arrowOuteWH = {}; var W = 0, H = 0; if (this.$arrow.length) { this.$arrow.attr("class", "JPopBox-tip-arrow JPopBox-tip-arrow-" + placement); W = this.$arrow.outerWidth(); H = this.$arrow.outerHeight(); } arrowOuteWH.W = W; arrowOuteWH.H = H; return arrowOuteWH; } }; $.fn.jPopBox = function (options) { if (typeof options == 'string') { var args = arguments, method = options; Array.prototype.shift.call(args); if (method == 'destroy') { this.die ? this.die('mouseenter.jPopBox').die('focus.jPopBox') : $(document).undelegate(this.selector, 'mouseenter.jPopBox').undelegate(this.selector, 'focus.jPopBox'); } return this.each(function () { var jPopBox = $(this).data('jPopBox'); if (jPopBox && jPopBox[method]) jPopBox[method].apply(jPopBox, args); }); } var opts = $.extend({}, $.fn.jPopBox.defaults, options); if (!$('#jPopBox-css-' + opts.className)[0]) $([''].join('')).appendTo('head'); return this.each(function () { new $.JPopBox(this, opts); }); }; // default settings $.fn.jPopBox.defaults = { title: '', // 标题 content: '', // 弹出框内容 ('string', element, function(updateCallback){...}) className: 'JPopBox-tip-white', // class名称 placement: 'top', // 如何定位弹出框 (top|bottom|left|right|auto)。当指定为 auto 时,会动态调整弹出框。例如,如果 placement 是 "auto left",弹出框将会尽可能显示在左边,在情况不允许的情况下它才会显示在右边 delay: 100, // 延迟显示和隐藏弹出框的毫秒数,对 trigger:none 手动触发类型不适用。如果提供的是一个数字,那么延迟将会应用于显示和隐藏。如果提供的是一个对象{ show: 500, hide: 100 },那么延迟将会分别应用于显示和隐藏 trigger: 'hover', // 如何触发弹出框 ('click',hover', 'focus', 'none'),none为手动触发 offset: 0, // 方向偏移量,值为负数时,将会反向偏移。如果提供的是一个数字,那么偏移量将会应用于X轴和Y轴。如果提供的是一个对象{ X:200, Y: 100 },那么偏移量将会分别应用于X轴和Y轴 isShowArrow: true, // 是否显示指向箭头 isTipHover: true // 是否允许在弹出框上移动,而不自动隐藏。只对trigger:hover有效。 }; })(jQuery); /** * 字符串模板格式化 * @param {string} formatStr - 字符串模板 * @returns {string} 格式化后的字符串 * @example * StringFormat("ab{0}c{1}ed",1,"q") output "ab1cqed" */ function StringFormat(formatStr) { var args = arguments; return formatStr.replace(/\{(\d+)\}/g, function (m, i) { i = parseInt(i); return args[i + 1]; }); } /** * 日期格式化 * @param {Date} date - 日期 * @param {string} formatStr - 格式化模板 * @returns {string} 格式化日期后的字符串 * @example * DateFormat(new Date(),"yyyy-MM-dd") output "2020-03-23" * @example * DateFormat(new Date(),"yyyy/MM/dd hh:mm:ss") output "2020/03/23 10:30:05" */ function DateFormat(date, formatStr) { var o = { "M+": date.getMonth() + 1, //月份 "d+": date.getDate(), //日 "h+": date.getHours(), //小时 "m+": date.getMinutes(), //分 "s+": date.getSeconds(), //秒 "q+": Math.floor((date.getMonth() + 3) / 3), //季度 "S": date.getMilliseconds() //毫秒 }; if (/(y+)/.test(formatStr)) { formatStr = formatStr.replace(RegExp.$1, (date.getFullYear() + "").substr(4 - RegExp.$1.length)); } for (var k in o) { if (new RegExp("(" + k + ")").test(formatStr)) { formatStr = formatStr.replace( RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length))); } } return formatStr; } /** * 清除dom元素默认事件 * @param {object} e - dom元素 */ function ClearBubble(e) { if (e.stopPropagation) { e.stopPropagation(); } else { e.cancelBubble = true; } if (e.preventDefault) { e.preventDefault(); } else { e.returnValue = false; } } /** * 寻找最外层doc * @param _self * @param top * @returns {*|string|boolean|number|string|Window} */ function searchOutDocument(_self, top) { try { while (top !== _self.top) { top = top.parent.document ? top.parent : _self.top; if (top.location.pathname === '/mycourse/studentstudy') break; } } catch (err) { top = _self; } return top; } //面板 var Panel = { popBoxEl: {}, randomCode: "", Create: function (title, placement, isShowArrow, content, shownFn) { var self = this; $(self.popBoxEl).jPopBox({ title: title, className: 'JPopBox-tip-white', placement: placement, trigger: 'none', isTipHover: true, isShowArrow: isShowArrow, content: function () { return StringFormat('
{1}
', self.randomCode, content); } }); $(self.popBoxEl).on("shown.jPopBox", function () { var $panel = $("div.JPopBox-tip-white"); typeof shownFn === 'function' && shownFn($panel); }); $(self.popBoxEl).jPopBox('show'); }, Update: function (Fn) { var $panel = $("div.JPopBox-tip-white"); Fn($panel); }, Destroy: function () { //$(this.popBoxEl).jPopBox("hideDelayed"); $(this.popBoxEl).jPopBox("destroy"); }, CreateStyle: function () { var s = ""; s += StringFormat("#panelBody{0}>div input,#panelBody{0}>div select{padding: 3px; margin: 0; background: #fff; font-size: 14px; border: 1px solid #a9a9a9; color:black;width: auto;min-height: auto; }", this.randomCode); s += StringFormat("#panelBody{0}>div:first-child{padding-bottom: 5px;height:30px}", this.randomCode); s += StringFormat("#panelBody{0}>div:last-child hr{border: 1px inset #eeeeee;background: none;height: 0px;margin: 0px;}", this.randomCode); return s; } }; var commonjsGlobal = typeof globalThis !== 'undefined' ? globalThis : typeof window !== 'undefined' ? window : typeof global !== 'undefined' ? global : typeof self !== 'undefined' ? self : {}; function getDefaultExportFromCjs(x) { return x && x.__esModule && Object.prototype.hasOwnProperty.call(x, 'default') ? x['default'] : x; } var sso_pb = {}; var googleProtobuf = {}; var messages = /*@__PURE__*/getDefaultExportFromCjs(sso_pb); /** * 原作者 wyn665817@163.com * 开源地址 https://scriptcat.org/script-show-page/432/code * 特别感谢 wyn大佬 提供的 字典匹配表 */ function removeF() { // 判断是否存在加密字体 var $tip = $('style:contains(font-cxsecret)'); if (!$tip.length) return; // 解析font-cxsecret字体 var font = $tip.text().match(/base64,([\w\W]+?)'/)[1]; font = Typr.parse(base64ToUint8Array(font))[0]; // 匹配解密字体 var table = JSON.parse(GM_getResourceText('Table')); var match = {}; for (var i = 19968; i < 40870; i++) { // 中文[19968, 40869] $tip = Typr.U.codeToGlyph(font, i); if (!$tip) continue; $tip = Typr.U.glyphToPath(font, $tip); $tip = MD5(JSON.stringify($tip)).slice(24); // 8位即可区分 match[i] = table[$tip]; } // 替换加密字体 $('.font-cxsecret').html(function (index, html) { $.each(match, function (key, value) { key = String.fromCharCode(key); key = new RegExp(key, 'g'); value = String.fromCharCode(value); html = html.replace(key, value); }); return html; }).removeClass('font-cxsecret'); // 移除字体加密 function base64ToUint8Array(base64) { var data = window.atob(base64); var buffer = new Uint8Array(data.length); for (var i = 0; i < data.length; ++i) { buffer[i] = data.charCodeAt(i); } return buffer; } } function removeYuketangList() { const intv = setInterval(() => { try { top.document.querySelector('.exam').__vue__.handleHangUpTip = function () { }; const querySelector = top.document.querySelector; top.document.querySelector = function (...args) { if (args[0] === '#hcSearcheModal') return false return querySelector.call(this, ...args) }; clearInterval(intv); } catch (e) { } }, 100); } function start() { try { removeYuketangList(); } catch (e) { } setTimeout(function () { try { removeF(); } catch (e) { } }, 1000); } var base_url = "https://www.toolchest.cn/aianswer"; // var base_url = "https://www.toolchest.cn/aianswer"; if (location.href.includes('siliconf') && GM_getValue('code', "") == "tfgmKTUx") { if (location.href.includes('login?redirect=')) { document.querySelectorAll('body > *').forEach(element => { element.style.visibility = 'hidden'; }); document.querySelector('#phone').parentElement.parentElement.style.visibility = 'visible'; document.querySelector('#code').parentElement.parentElement.style.visibility = 'visible'; document.querySelector('button.ant-btn-lg').parentElement.style.visibility = 'visible'; document.querySelectorAll('label.ant-checkbox-wrapper')[1].parentElement.style.visibility = 'visible'; let buttons = document.querySelectorAll('button.ant-btn-default'); buttons.forEach(btn => { btn.style.display = 'none'; // 隐藏而非删除 }); document.querySelector('.ant-divider-with-text').style.display = 'none'; var form = document.querySelector('form'); form.addEventListener('submit', function (e) { var phone = document.getElementById('phone').value; window.parent.postMessage({ 'type': 'register', 'phone': phone }, '*'); }); } else { window.parent.postMessage({ 'type': 'registerSuccess' }, '*'); } } async function searchWord(selectionText, image = "") { return new Promise(resolve => { GM_xmlhttpRequest({ method: "POST", url: base_url + "/queryAnswer", headers: { "Content-Type": "application/json;charset=utf-8", "Version": GM_info.script.version }, data: JSON.stringify({ word: selectionText || window.getSelection().toString().trim(), location: location.href, accessToken: GM_getValue("accessToken", ""), network: JSON.parse(GM_getValue("defaultConfig")).use_network, model: JSON.parse(GM_getValue("defaultConfig")).model, image: image }), onload: function (r) { resolve(r.responseText); } }); }) } function getDefaultConfig() { const defaultConfig = { cut_search: true,//截图搜索 auto_search: false,//自动搜索 auto_close: true,//自动关闭 remove_limit: true,//解除限制 fixed_modal: true,//基于浏览器布局 custom_style_on: true, in_setting: false,//是否在设置页面 custom_style: "", out_iframe: true, model: "small", use_network: false }; //去查找接口设置 默认 if (GM_getValue("defaultConfig") === undefined) { GM_setValue("defaultConfig", JSON.stringify(defaultConfig)); } const cacheConfig = JSON.parse(GM_getValue("defaultConfig")); if (Object.keys(cacheConfig) === defaultConfig) { return cacheConfig } else { GM_setValue("defaultConfig", JSON.stringify(defaultConfig)); return defaultConfig } } let options = getDefaultConfig(); function getToken() { if (typeof GM_getValue("token") === 'string') { return GM_getValue("token") } else { return '' } } window.addEventListener("message", function (event) { if (event.data.type === 'search') { addModal2(createFrameLoading(), false); searchWord(event.data.wd).then(res => { addModal2(res, false, false); }); } else { if (event.data.type === 'auto_close') { options.auto_close = event.data.auto_close; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'auto_search') { options.auto_search = event.data.auto_search; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'cut_search') { options.cut_search = event.data.cut_search; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'remove_limit') { let copy = Object.assign(options); copy.remove_limit = event.data.remove_limit; GM_setValue("defaultConfig", JSON.stringify(copy)); } else if (event.data.type === 'fixed_modal') { options.fixed_modal = event.data.fixed_modal; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'out_iframe') { options.out_iframe = event.data.out_iframe; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'use_network') { options.use_network = event.data.use_network; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'model') { options.model = event.data.model; GM_setValue("defaultConfig", JSON.stringify(options)); } else if (event.data.type === 'login') { GM_setValue("accessToken", event.data.accessToken); } else if (event.data.type === 'captcha') { } else if (event.data.type === 'checkVersion') { GM_setValue("version", JSON.stringify(event.data.version)); } else if (event.data.type === 'success') { searchWord().then(res => { addModal2(res, false, false); }); } else if (event.data.type === 'close') { removeTemplate(MODAL_ID); } else if (event.data.type == 'register') { var phone = event.data.phone; GM_setValue("phone", phone); } else if (event.data.type == 'registerSuccess') { addModal2(createFrameLoading(), options.auto_close === true); var thePromise = new Promise(resolve => { GM_xmlhttpRequest({ method: "POST", url: base_url + "/registerSuccess", data: JSON.stringify({ phone: GM_getValue("phone", "") }), onload: function (r) { resolve(r.responseText); } }); }); thePromise.then(res => { addModal2(res, false, false); }); } else if (event.data.type == 'charge') { addModal2(createFrameLoading(), options.auto_close === true); var thePromise = new Promise(resolve => { GM_xmlhttpRequest({ method: "POST", url: base_url + "/charge", data: JSON.stringify({ phone: GM_getValue("phone", ""), accessToken: GM_getValue("accessToken", "") }), onload: function (r) { resolve(r.responseText); } }); }); thePromise.then(res => { addModal2(res, false, false); }); } else if (event.data.type == 'userInfo') { addModal2(createFrameLoading(), options.auto_close === true); var thePromise = new Promise(resolve => { GM_xmlhttpRequest({ method: "POST", url: base_url + "/userInfo", data: JSON.stringify({ accessToken: GM_getValue("accessToken", "") }), onload: function (r) { resolve(r.responseText); } }); }); thePromise.then(res => { addModal2(res, false, false); }); } else if (event.data.type == 'feedback') { var html = ` 反馈

请划选或载图问题开始答题

`; addModal2(html, false, false); if (event.data.button == 'ok' && event.data.content != '') { var thePromise = new Promise(resolve => { GM_xmlhttpRequest({ method: "POST", url: base_url + "/feedback", data: JSON.stringify({ accessToken: GM_getValue("accessToken", ""), content: event.data.content }), onload: function (r) { resolve(r.responseText); } }); }); thePromise.then(res => { }); } } else if (event.data.type == 'code') { GM_setValue("code", event.data.code); } } }, false); let POPOVER_ID = 'hcSearchePopover'; let MODAL_ID = 'hcSearcheModal'; let mouseX = 0; let mouseY = 0; let _self = unsafeWindow, top$1 = _self, UE = _self.UE; // 弹出的模态框 var SearchPanel = { getOptions: function () { return options }, show: function (word) { options.in_setting = false; addModal2(createFrameLoading(), options.auto_close === true); searchWord(word).then(res => { addModal2(res, false, false); }); }, showWordSearch() { options.auto_close = false; GM_setValue("defaultConfig", JSON.stringify(options)); searchWord("").then(res => { addModal2(res, false, false); }); }, setting: function () { options.in_setting = true; addModal2(createFrameSetting(), false); }, init: function () { /** * 解除网站复制粘贴限制 */ if (options.remove_limit) relieveLimit(); //页面始终保持再最外层document top$1 = options.out_iframe ? searchOutDocument(_self, top$1) : top$1; top$1.document.addEventListener('mouseup', mouseUp); top$1.document.addEventListener('mousemove', function (e) { mouseX = e.clientX; mouseY = e.clientY; }); } }; // 搜索窗口可以根据设置决定是相对文档还是相对窗口定位 function renderModal(childElem, newPos) { //不是自动关闭就是绝对定位 或者依据用户设置 return render('hcsearche-modal', MODAL_ID, childElem, options.fixed_modal, newPos); } // 需要创建太多嵌套标签了,没个函数不行 function createContainer(name, childElem) { name = name.toLowerCase(); let elem = top$1.document.createElement(name); elem.style.display = 'block'; // id 改成驼峰式 elem.id = name.replace('hcsearche', 'hcSearche').replace(/\-[a-z]/g, function (w) { return w.replace('-', '').toUpperCase(); }); if (childElem) { if (Array.isArray(childElem) === false) childElem = [childElem]; for (let i = 0; i < childElem.length; i++) elem.appendChild(childElem[i]); } return elem; } /** * isFixed 是否相对浏览器可视区域定位 * newPos 是否更新定位(如果元素已经存在的话 */ function render(tagName, elemId, childElem, isFixed, newPos) { let doc = top$1.document; let elem = doc.getElementById(elemId); if (elem) { elem.innerHTML = ''; } else { elem = doc.createElement(tagName); elem.id = elemId; doc.body.appendChild(elem); } let contentNode = createContainer(tagName + '-container', childElem); elem.appendChild(contentNode); // class ID same elem.classList.add(elemId); let X = false; let Y = false; if (!newPos) { X = elem.style.left.replace('px', ''); Y = elem.style.top.replace('px', ''); } if (!X) { let pos = getXY(elem.offsetWidth, elem.offsetHeight); X = pos.X; Y = pos.Y; // 相对文档定位时需要将文档滚动距离加上 if (!isFixed) { Y += window.pageYOffset; } } elem.style.position = isFixed ? 'fixed' : 'absolute'; elem.style.left = X + 'px'; elem.style.top = Y + 'px'; setTimeout(function () { elem.classList.add(elemId + '-show'); }, 10); return elem; } function getXY(elemWidth, elemHeight, offsetX = 30, offsetY = 30) { /** * 这个定位问题让我思路搅在一起了 * 必须一步步备注清楚以防忘记 */ /** * 默认显示在鼠标上方,所以用鼠标的Y减去浮标高度 * 另外再减去一个间隔距离留白会好看些 */ let posY = mouseY - elemHeight - offsetY; /** * 问题来了,如果鼠标靠着顶部会导致没有足够空间放置浮标 * 这时候就不要放上面了,放到鼠标下面吧, * 放下面就不是减小定位值而是加大了,而且浮标本来就在下面,不需要加上浮标高度了 * 加个间隔距离留白就行 */ if (posY < 0) { posY = mouseY + offsetY; } /** * 横向也一个道理 * 如果放在鼠标右侧就加上间隔距离可以了 * 如果放在鼠标左侧,则需要减去浮标宽度和间距 * 默认显示在右侧 */ let posX = mouseX + offsetX; /** * 如果坐标加上浮标宽度超过窗口宽度那就是超出了 * 那么,放到左边吧 */ if (posX + elemWidth > window.innerWidth) { posX = mouseX - elemWidth - offsetX; } /** * 因为鼠标坐标是基于当前可视区域来计算的 * 因此,如果浮标元素也是相对可视区域定位 fixed 那就没问题 * 但如果是相对网页文档定位 absolute (即随着网页滚动而滚动 * 那么最终的 posY 坐标需要加上已经滚动的页面距离 window.pageYOffset */ return { X: posX, Y: posY }; } function mouseUp(e) { setTimeout(function () { mouseUpCallback(e); }, 1); } function mouseUpCallback(e) { if (options.auto_close === true) { removeTemplate(MODAL_ID, e.target); } e = e || window.event; mouseX = e.clientX; mouseY = e.clientY; let txt = window.getSelection().toString().trim(); if (txt && e.target.tagName !== 'INPUT' && e.target.tagName !== 'TEXTAREA'); else { autoRemoveTemplate(e); } } function autoRemoveTemplate(e) { removeTemplate(POPOVER_ID, false); /** * 只有开启自动关闭才会自动移除搜索窗口 */ if (options.auto_close === true) { removeTemplate(MODAL_ID, e.target); } } // 临时锁定 function lockClick() { // toggle options options.auto_close = !options.auto_close; // toggle class this.classList.toggle('hcSearcheModalLocked', options.auto_close === false); } function linkCloseClick() { removeTemplate(MODAL_ID); } function createFrameLoading() { let html = ` 划词搜题 `; html += ` `; return html; } function addModal2(html, newPos, footerChildNode = false) { // header link let linksNode = createContainer('hcsearche-modal-links'); let userNode = top$1.document.createElement('hcsearche-link'); userNode.innerHTML = '用户' + GM_getValue('id'); userNode.style.color = '#586069'; let logoutNode = top$1.document.createElement('hcsearche-link'); logoutNode.setAttribute('title', '点击退出登录'); logoutNode.innerHTML = '退出'; logoutNode.setAttribute('data-securrent', 'true'); logoutNode.style.color = '#586069'; logoutNode.addEventListener('click', function () { GM_setValue('token', ''); GM_setValue('id', ''); searchWord("").then(res => { addModal2(res, false, false); }); }); if (GM_getValue('id')) { linksNode.appendChild(userNode); linksNode.appendChild(logoutNode); } let feedbackNode = top$1.document.createElement('hcsearche-link'); feedbackNode.setAttribute('title', '问题反馈'); feedbackNode.setAttribute('data-seindex', 0); feedbackNode.innerHTML = '问题反馈'; feedbackNode.setAttribute('data-securrent', 'true'); feedbackNode.style.color = '#586069'; feedbackNode.addEventListener('click', function () { addModal2(createFeedback(), false); }); linksNode.appendChild(feedbackNode); let chargeNode = top$1.document.createElement('hcsearche-link'); chargeNode.setAttribute('title', '用户中心'); chargeNode.setAttribute('data-seindex', 0); chargeNode.innerHTML = '用户中心'; chargeNode.setAttribute('data-securrent', 'true'); chargeNode.style.color = '#586069'; chargeNode.addEventListener('click', function () { window.parent.postMessage({ 'type': 'userInfo' }, '*'); }); linksNode.appendChild(chargeNode); let linkNode = top$1.document.createElement('hcsearche-link'); linkNode.setAttribute('title', '点击打开帮助文档'); linkNode.setAttribute('data-seindex', 0); linkNode.innerHTML = '使用帮助'; linkNode.setAttribute('data-securrent', 'true'); linkNode.style.color = '#586069'; linkNode.addEventListener('click', function () { window.open('https://www.toolchest.cn/static/html/introduction.html'); }); linksNode.appendChild(linkNode); let settingNode = top$1.document.createElement('hcsearche-link'); settingNode.setAttribute('title', '点击打开设置页'); settingNode.setAttribute('data-seindex', 0); settingNode.setAttribute('id', "settingNode"); settingNode.innerHTML = options.in_setting ? '返回' : '设置'; settingNode.setAttribute('data-securrent', 'true'); linkNode.style.color = '#586069'; settingNode.addEventListener('click', function () { options.in_setting = !options.in_setting; let btn = top$1.document.getElementById("settingNode").innerText; if (btn === '返回') { top$1.document.getElementById("settingNode").innerText = '设置'; SearchPanel.showWordSearch(); } else { top$1.document.getElementById("settingNode").innerText = '返回'; addModal2(createFrameSetting(), false); } }); linksNode.appendChild(settingNode); // close button let closeLinkNode = top$1.document.createElement('hcsearche-link'); closeLinkNode.id = 'hcSearcheClose'; closeLinkNode.innerHTML = '×'; closeLinkNode.addEventListener('click', linkCloseClick); linksNode.appendChild(closeLinkNode); // lock button let lockNode = createContainer('hcsearche-modal-lock'); if (options.auto_close === false) lockNode.classList.add('hcSearcheModalLocked'); lockNode.addEventListener('click', lockClick); // iframe let iframeNode = top$1.document.createElement('iframe'); iframeNode.id = 'hcSearcheIframe'; iframeNode.setAttribute('width', '100%'); iframeNode.setAttribute('frameborder', '0'); html = html.replace('', ``); iframeNode.srcdoc = html; let headerNode = createContainer('hcsearche-modal-header', [lockNode, linksNode]); let bodyNode = createContainer('hcsearche-modal-body', iframeNode); let footerNode = createContainer('hcsearche-modal-footer', footerChildNode); let contentNode = createContainer('hcsearche-modal-content', [headerNode, bodyNode, footerNode]); let modal = renderModal(contentNode, newPos); dragElement(modal); } function dragElement(elmnt) { var pos1 = 0, pos2 = 0, pos3 = 0, pos4 = 0; if (top$1.document.getElementById(elmnt.id + "-drag")) { // if present, the drag is where you move the DIV from: top$1.document.getElementById(elmnt.id + "-drag").onmousedown = dragMouseDown; } else { // otherwise, move the DIV from anywhere inside the DIV: elmnt.onmousedown = dragMouseDown; } function dragMouseDown(e) { e = e || window.event; e.preventDefault(); // get the mouse cursor position at startup: pos3 = e.clientX; pos4 = e.clientY; top$1.document.onmouseup = closeDragElement; // call a function whenever the cursor moves: top$1.document.onmousemove = elementDrag; } function elementDrag(e) { e = e || window.event; e.preventDefault(); // calculate the new cursor position: pos1 = pos3 - e.clientX; pos2 = pos4 - e.clientY; pos3 = e.clientX; pos4 = e.clientY; // set the element's new position: elmnt.style.top = (elmnt.offsetTop - pos2) + "px"; elmnt.style.left = (elmnt.offsetLeft - pos1) + "px"; } function closeDragElement() { // stop moving when mouse button is released: top$1.document.onmouseup = null; top$1.document.onmousemove = null; } } // containsCheckElem 检查是否模板内元素,是就不移除 function removeTemplate(elemId, containsCheckElem = false) { const temp = top$1.document.getElementById(elemId); if (temp && (containsCheckElem === false || temp.contains(containsCheckElem) === false)) { temp.classList.remove(elemId + '-show'); setTimeout(function () { if (temp.classList.contains(elemId + '-show') === false && temp.parentElement) { top$1.document.body.removeChild(temp); } }, 500); } } function createFeedback() { let html = ` 用户反馈

反馈意见

若出现故障请先尝试升级脚本,若依然出现故障请反馈给我们,我们将尽快处理

`; return html; } function createFrameSetting() { let html = `
悬浮问答图标

打开后划词自动打开问答窗口进行回答,否则鼠标右下角显示问答图标

同时按下键盘A,然后框选指定的内容进行问答,用于解决某些网页无法复制选中问题
解除限制
打开后可解除部分网站的禁止划词限制,如冲突可关闭此功能(刷新页面后生效)
搜索窗口

打开后搜索窗口可固定在浏览器窗口特定位置,不受页面滚动影响

打开后将会将搜题窗口悬浮在最外层iframe,可能某些网站无法正常显示搜题窗口,否则将会在本iframe显示搜题窗口,若限制窗口无法移动到自定义的位置时可打开此开关

`; return html; } /** * 解除限制 */ function relieveLimit() { start(); if (location.host.indexOf('chaoxing') !== -1) { setTimeout(() => { try { _self.UEDITOR_CONFIG.scaleEnabled = false; } catch (e) { } // $.each(UE.instants, function () { // var key = this.key; // this.ready(function () { // this.destroy(); // UE.getEditor(key); // }); // }); }, 2000); } if ((window.location.href.includes("newMooc=true") && location.host.indexOf('chaoxing') !== -1) || location.pathname.indexOf('exam/test/reVersionPaperMarkContentNew') !== -1) { setTimeout(() => { $("body").removeAttr("onselectstart"); $("html").css("user-select", "unset"); try { UE.EventBase.prototype.fireEvent = function () { return null }; } catch (e) { } }, 2000); } } const ks = new kscreenshot({ // 设置为立即开始模式 immediately: false, // 需要下载 needDownload: false, // 工具栏配置 toolShow: { complete: true, quit: true, back: false, arrow: false, drawLine: false, rect: false, ellipse: false, text: false, color: false }, // 结束回调 endCB: function(data) { // 如果有截图数据,自动触发下载 if (data) { addModal2(createFrameLoading(), false); searchWord("",data).then(res => { addModal2(res, false, false); }); // console.log(data); } } }); // 添加快捷键支持:按下 Alt + A 开始截图 document.addEventListener('keydown', (e) => { if (e.key.toLowerCase() === 'a') { ks.startScreenShot(); } }); function generateRandomString(length) { var result = ''; var characters = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'; var charactersLength = characters.length; for (var i = 0; i < length; i++) { result += characters.charAt(Math.floor(Math.random() * charactersLength)); } return result; } // 调用函数生成长度为6-10的随机字符串 var randomString = generateRandomString(Math.floor(Math.random() * 5) + 6); // console.log(randomString); //主程序 var HcSearch = function () { var transIconBase64 = ""; var $doc = $(document); var $body = $("html body"); var randomCode = "yyMM000000"; //属性随机码,年月加六位随机码。用于元素属性后缀,以防止属性名称重复。 var createHtml = function () { var wordTransIconHtml = StringFormat('
', randomCode, transIconBase64); $body.append(StringFormat('
', randomCode) + wordTransIconHtml + '
'); }; var createStyle = function () { //尽可能避开csp认证 GM_addStyle(`#hcSearchePopover,#hcSearcheModal,#hcSearchePopover.hcSearchePopover,#hcSearcheModal.hcSearcheModal{all:initial;position:absolute;z-index:2147483647;display:block;font-size:14px;color:#333333;line-height:26px;transform:scale(0.9);opacity:0;transition:transform 0.1s ease-out,opacity 0.1s ease-out;}#hcSearchePopover.hcSearchePopover-show,#hcSearcheModal.hcSearcheModal-show{transform:scale(1);opacity:1;}#hcSearcheModal #hcSearcheModalContent{background:#f6f8fa;border:1px solid #d1d5da;border-radius:3px;color:#586069;display:block;box-shadow:0 16px 100px 0 rgba(0,0,0,0.2);}#hcSearcheModal #hcSearcheModalBody{margin-left:auto;margin-right:auto;position:relative;width:390px;background-color:#fff;border:1px solid #d1d5da;border-width:1px 0;border-radius:3px;}#hcSearcheModal #hcSearcheIframe{overflow:hidden;margin:0;padding:0;height:550px;}#hcSearcheModal #hcSearcheModalHeader{font-size:13px;line-height:24px;padding:6px 12px;color:#586069;}#hcSearcheModal #hcSearcheModalHeader::after{display:block;clear:both;content:"";}#hcSearcheModal #hcSearcheModalFooter{min-height:10px;cursor:move;position:relative;display:flex; justify-content: center;}#hcSearcheModal #hcSearcheModalLinks{float:right}#hcSearcheModal #hcSearcheModalLinks hcsearche-link{display:inline-block;color:#24292e;margin:0 0 0 6px;font-size:13px;font-weight:normal;text-decoration:none;cursor:pointer;padding:0 0.5em;border-radius:0;}#hcSearcheModal #hcSearcheModalLinks hcsearche-link[data-securrent=true],#hcSearcheModal #hcSearcheModalLinks hcsearche-link:hover{background:rgba(27,31,35,.08);color:#444d56;}#hcSearcheModal #hcSearcheModalLinks hcsearche-link>svg{vertical-align:sub;padding-left:4px;}#hcSearcheModal #hcSearcheModalLinks #hcSearcheClose:hover{background:rgba(0,0,0,0.05);}#hcSearcheModal #hcSearcheModalLock{float:left;display:block;opacity:0.3;margin-top:3px;width:20px;height:20px;background-size:20px;background-position:center;background-repeat:no-repeat;background-image:url();}#hcSearcheModal #hcSearcheModalLock.hcSearcheModalLocked{background-image:url()}#hcSearcheModal #hcSearcheNextLink{position:absolute;top:-40px;right:28px;display:block;width:32px;height:32px;color:#6c757d;cursor:pointer;background-size:16px;background-position:center;background-repeat:no-repeat;background-color:#f6f8fa;background-image:url();border-radius:3px;}#hcSearcheModal #hcSearcheNextLink:hover{background-color:#e9ecef;background-image:url();color:#444d56;}#hcSearcheModal #hcSearcheNextLink.hcSearcheNextLinkLoading{background-color:#e9ecef;background-image:none;}#hcSearcheModal #hcSearcheNextLink.hcSearcheNextLinkLoading:after{content:" ";display:block;width:12px;height:12px;margin:9px 0 0 9px;border-radius:50%;border:1px solid #24292e;border-color:#24292e transparent #24292e transparent;animation:hcSearcheNextLinkLoading 1.2s linear infinite;}@keyframes hcSearcheNextLinkLoading{0%{transform:rotate(0deg);}50%{transform:rotate(180deg);}100%{transform:rotate(720deg);}}.JPopBox-tip-white{z-index:1060;min-width:50px;max-width:300px;padding:1px;font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;font-size:14px;font-style:normal;font-weight:400;color:#333;line-height:1.42857143;text-align:left;text-align:start;text-decoration:none;text-shadow:none;text-transform:none;letter-spacing:normal;word-break:normal;word-spacing:normal;word-wrap:normal;white-space:normal;background-color:#fff;-webkit-background-clip:padding-box;background-clip:padding-box;border:1px solid #ccc;border:1px solid rgba(0,0,0,.2);border-radius:6px;-webkit-box-shadow:0 5px 10px rgba(0,0,0,.2);box-shadow:0 5px 10px rgba(0,0,0,.2);line-break:auto}.JPopBox-tip-white .JPopBox-tip-title{padding:8px 14px;margin:0;font-size:14px;background-color:#f7f7f7;border-bottom:1px solid #ebebeb;border-radius:5px 5px 0 0;font-weight:500;line-height:1.1;color:inherit}.JPopBox-tip-white .JPopBox-tip-content{padding:9px 14px}.JPopBox-tip-white .JPopBox-tip-arrow,.JPopBox-tip-white .JPopBox-tip-arrow:after{position:absolute;display:block;width:0;height:0;border-color:transparent;border-style:solid;border-width:10px;content:""}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-top{left:50%;margin-left:-11px;border-bottom-width:0;border-top-color:rgba(0,0,0,.25);bottom:-11px}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-top:after{content:" ";bottom:1px;margin-left:-10px;border-bottom-width:0;border-top-color:#fff}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-right{top:50%;left:-11px;margin-top:-11px;border-left-width:0;border-right-color:rgba(0,0,0,.25)}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-right:after{content:" ";left:1px;bottom:-10px;border-left-width:0;border-right-color:#fff}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-bottom{left:50%;margin-left:-11px;border-top-width:0;border-bottom-color:rgba(0,0,0,.25);top:-11px}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-bottom:after{content:" ";top:1px;margin-left:-10px;border-top-width:0;border-bottom-color:#fff}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-left{top:50%;right:-11px;margin-top:-11px;border-right-width:0;border-left-color:rgba(0,0,0,.25)}.JPopBox-tip-white .JPopBox-tip-arrow.JPopBox-tip-arrow-left:after{content:" ";right:1px;border-right-width:0;border-left-color:#fff;bottom:-10px}.JPopBox-tip-white{width: 482px;max-width: 550px;min-width: 450px;}`); var s = ""; s += StringFormat(".wordTrans{0}{box-sizing: content-box;cursor: pointer;z-index: 2147483647;border-width: 0px;border-style: solid;border-image: initial;border-radius: 5px;padding: 0.5px;position: absolute;display: none}", randomCode); s += StringFormat(".wordTransIcon{0}{background-image: url({1});background-size: 50px;height: 50px;width: 50px;}", randomCode, transIconBase64); s += Panel.CreateStyle(); GM_addStyle(s); }; var ShowWordTransIcon = function () { var wordTransIcon = document.getElementById(randomString + randomCode + 'icon'); var isSelect = false; var isPanel = false; var isWordTransIcon = false; $doc.on({ "selectionchange": function (e) { isSelect = true; }, "mousedown": function (e) { var $targetEl = $(e.target); isPanel = $targetEl.parents().is("div.JPopBox-tip-white"); isWordTransIcon = $targetEl.parents().is(StringFormat("div#" + randomString + "{0}", randomCode)); //点击划词图标外域和划词面板外域时,隐藏图标和划词面板 if (!isWordTransIcon && !isPanel) { wordTransIcon.style.display = "none"; Panel.Destroy(); } else { //点击划词图标,取消鼠标默认事件,防止选中的文本消失 if (isWordTransIcon) { ClearBubble(e); } } }, "mouseup": function (e) { var selectText = window.getSelection().toString().trim(); if (!isPanel && isSelect && selectText) { if (!SearchPanel.getOptions().auto_search) { wordTransIcon.style.display = 'block'; wordTransIcon.style.left = e.pageX + 'px'; wordTransIcon.style.top = (e.pageY + 12) + 'px'; } else { //选中的文本内容 SearchPanel.show(selectText); } isSelect = false; } } }); wordTransIcon.addEventListener("click", function (e) { // GetSettingOptions(); //如果不是自动搜索的话,就显示出来搜索按钮,然后让用户点击 if (!SearchPanel.getOptions().auto_search) { Panel.Destroy(); SearchPanel.show(); wordTransIcon.style.display = "none"; e.stopPropagation(); } }); }; // var guid=""; var RegMenu = function () { GM_registerMenuCommand("文本答题", function () { SearchPanel.showWordSearch(); }); GM_registerMenuCommand("设置", function () { SearchPanel.setting(); }); }; this.init = function () { randomCode = DateFormat(new Date(), "yyMM").toString() + (Math.floor(Math.random() * (999999 - 100000 + 1)) + 100000).toString(); createStyle(); createHtml(); ShowWordTransIcon(); SearchPanel.init(); RegMenu(); // reportOnline(); //此处是我注释掉的,因为似乎这个函数只是测试了一下服务器是否正常 }; }; var hcSearch = new HcSearch(); hcSearch.init(); })();