// ==UserScript== // @name 中国电信网上大学知识中心自动挂课 // @namespace http://tampermonkey.net/ // @version 1.4.1 // @description 鼠标移动到左上角图标点击开始,开启无人值守自动挂课模式!增加对活动中的专题班支持!增加2.1倍数(最大2.2,可能报异常)! 参考:HuangDingYun v.0.5 // @author zsa // @match https://kc.zhixueyun.com/* // @match https://cms.myctu.cn/* // @icon  // @require https://cdn.jsdelivr.net/npm/jquery@3.6.0/dist/jquery.min.js // @require https://cdn.jsdelivr.net/npm/blueimp-md5@2.19.0/js/md5.min.js // @grant unsafeWindow // @grant GM_openInTab // @grant GM.openInTab // @grant GM_getValue // @grant GM.getValue // @grant GM_setValue // @grant GM.setValue // @grant GM_deleteValue // @grant GM.deleteValue // @grant GM_xmlhttpRequest // @grant GM.xmlHttpRequest // @grant GM_registerMenuCommand // @grant GM_addValueChangeListener // @license MIT // @downloadURL https://update.greasyfork.icu/scripts/464552/%E4%B8%AD%E5%9B%BD%E7%94%B5%E4%BF%A1%E7%BD%91%E4%B8%8A%E5%A4%A7%E5%AD%A6%E7%9F%A5%E8%AF%86%E4%B8%AD%E5%BF%83%E8%87%AA%E5%8A%A8%E6%8C%82%E8%AF%BE.user.js // @updateURL https://update.greasyfork.icu/scripts/464552/%E4%B8%AD%E5%9B%BD%E7%94%B5%E4%BF%A1%E7%BD%91%E4%B8%8A%E5%A4%A7%E5%AD%A6%E7%9F%A5%E8%AF%86%E4%B8%AD%E5%BF%83%E8%87%AA%E5%8A%A8%E6%8C%82%E8%AF%BE.meta.js // ==/UserScript== (function(g) { g.gooeymenu = function(h, q) { var rt = g(h); var k = rt.find('.gooey-menu-nav'); k.addClass("navimenu"); var b = this , a = b.options = g.extend({}, g.gooeymenu.defaults, q); b.els = { item: k.find(".gooey-menu-item"), checkbox: k.find(".gooey-menu-open"), button: k.find(".gooey-open-button") }; b.methods = { setup: function() { var d = { small: 1.4, medium: 1.8, large: 2.1 }, f = { small: 1.3, medium: 1.6, large: 2.1 }, c; for (c in d) a.margin === c ? a.margin = d[c] : null; for (var e in f) a.bounceLength === e ? a.bounceLength = f[e] : null; b.methods.responsiveStyles(); b.els.item.hover(function() { a.currentBg = b.els.item.css("background-color"); g(this).css("background-color", a.hover) }, function() { g(this).css("background-color", a.currentBg) }); !0 === a.bounce && b.methods.bounce() }, setEvents: function() { ["open", "close"].forEach(function(d, b) { k.on(d, function() { a[d] && a[d].apply(this, arguments) }) }) }, bounce: function() { if (!0 === a.bounce) { var d = b.els.item.css("transition-timing-function"); b.els.checkbox.on("change", function() { g(this).is(":checked") ? b.els.item.css({ "transition-timing-function": "cubic-bezier(0.8, 0.84, 0.44, " + a.bounceLength + ")", "-o-transition-timing-function": "cubic-bezier(0.8, 0.84, 0.44, " + a.bounceLength + ")", "-moz-transition-timing-function": "cubic-bezier(0.8, 0.84, 0.44, " + a.bounceLength + ")", "-webkit-transition-timing-function": "cubic-bezier(0.8, 0.84, 0.44, " + a.bounceLength + ")", "-ms-transition-timing-function": "cubic-bezier(0.8, 0.84, 0.44, " + a.bounceLength + ")" }) : b.els.item.css({ "transition-timing-function": d, "-moz-transition-timing-function": d, "-o-transition-timing-function": d, "-webkit-transition-timing-function": d }) }) } }, position: function(e) { var p = [[0,1],[3,2]],w = window.innerWidth, h = window.innerHeight, x = b.methods.getCss(e,"left"), y = b.methods.getCss(e,"top"); return p[parseInt(x) < w / 2 ? 0 : 1][parseInt(y) < h / 2 ? 0 : 1]; }, circle: function() { k.trigger("open"); var pt = b.methods.position(rt[0]), rr = b.els.item.length < 3 ? 180 : 360; var d, f, c, e, m, h, n, r = b.els.item.length, l = a.transitionStep, q = Math.PI, t = rr / r, p = t = rr / r; p = (p + (pt * 90) + 180) % 360; f = a.circle.radius; b.els.item.each(function() { b.els.checkbox.is(":checked") ? (d = q * p / 180, c = Math.abs(Math.cos(d)), e = f * c, m = Math.sqrt(f * f - e * e), h = b.methods.periodCalc(p).x, n = b.methods.periodCalc(p).y, g(this).css({ transform: "translate3d(" + h + e + "px," + n + m + "px,0)", "-o-transform": "translate3d(" + h + e + "px," + n + m + "px,0)", "-webkit-transform": "translate3d(" + h + e + "px," + n + m + "px,0)", "-moz-transform": "translate3d(" + h + e + "px," + n + m + "px,0)", "-ms-transform": "translate3d(" + h + e + "px," + n + m + "px,0)", "transition-duration": l + "ms", "-o-transition-duration": l + "ms", "-webkit-transition-duration": l + "ms", "-moz-transition-duration": l + "ms" }), p += t, l += a.transitionStep) : (b.els.item.css({ transform: "translate3d(0, 0, 0)", "-moz-transform": "translate3d(0, 0, 0)", "-webkit-transform": "translate3d(0, 0, 0)", "-ms-transform": "translate3d(0, 0, 0)", "-o-transform": "translate3d(0, 0, 0)" }), p = 360 / r, l = a.transitionStep, k.trigger("close")) }) }, periodCalc: function(a) { return { x: 90 > a || 270 < a ? "" : "-", y: 180 < a ? "" : "-" } }, linear: function(d) { k.trigger("open"); var f = "horizontal" === a.style ? a.horizontal.menuItemPosition : a.vertical.menuItemPosition , c = d[f].init , e = a.transitionStep; b.els.item.each(function() { b.els.checkbox.is(":checked") ? "horizontal" === a.style ? (g(this).css({ transform: "translate3d(" + c + "px, 0, 0)", "-ms-transform": "translate3d(" + c + "px, 0, 0)", "-o-transform": "translate3d(" + c + "px, 0, 0)", "-moz-transform": "translate3d(" + c + "px, 0, 0)", "-webkit-transform": "translate3d(" + c + "px, 0, 0)", "transition-duration": e + "ms", "-o-transition-duration": e + "ms", "-webkit-transition-duration": e + "ms", "-moz-transition-duration": e + "ms" }), c += d[f].init, e += a.transitionStep) : "vertical" === a.style && (g(this).css({ "transition-duration": e + "ms", "-moz-transition-duration": e + "ms", "-o-transition-duration": e + "ms", "-webkit-transition-duration": e + "ms" }), "down" === a.vertical.direction ? g(this).css({ transform: "translate3d(0, " + c + "px, 0)", "-moz-transform": "translate3d(0, " + c + "px, 0)", "-o-transform": "translate3d(0, " + c + "px, 0)", "-webkit-transform": "translate3d(0, " + c + "px, 0)", "-ms-transform": "translate3d(0, " + c + "px, 0)" }) : "up" === a.vertical.direction && g(this).css({ transform: "translate3d(0,-" + c + "px, 0)", "-moz-transform": "translate3d(0,-" + c + "px, 0)", "-webkit-transform": "translate3d(0,-" + c + "px, 0)", "-o-transform": "translate3d(0,-" + c + "px, 0)", "-ms-transform": "translate3d(0,-" + c + "px, 0)" }), c += d[f].init, e += a.transitionStep) : (b.els.item.css({ transform: "translate3d(0, 0, 0)", "-moz-transform": "translate3d(0, 0, 0)", "-webkit-transform": "translate3d(0, 0, 0)", "-ms-transform": "translate3d(0, 0, 0)", "-o-transform": "translate3d(0, 0, 0)" }), c = d[f].init, e = a.transitionStep, k.trigger("close")) }) }, translate: function() { var d = { glue: { init: a.size }, spaced: { init: a.size * a.margin } }; b.els.checkbox.on("change", function() { b._callbacks[a.style](d) }) }, createOn: function(a, b, c, e) { b = document.createElementNS("http://www.w3.org/2000/svg", b); for (var g in c) c.hasOwnProperty(g) && b.setAttribute(g, c[g]); e && b.appendChild(document.createTextNode(e)); return a.appendChild(b) }, responsiveStyles: function() { var d = 0 < window.innerWidth ? window.innerWidth : screen.width; 320 <= d && 480 >= d ? (a.size /= 1.4, a.circle.radius /= 1.2) : 480 < d && 768 >= d ? a.size /= 1.2 : 780 < d && 1024 >= d && (a.circle.radius /= 1.2, a.size /= 1.1); b.els.item.css({ width: a.size + "px", height: a.size + "px", color: a.contentColor, "background-color": a.bgColor, "line-height": a.size + "px" }); b.els.button.css({ width: a.size + "px", height: a.size + "px", "background-color": a.bgColor, "line-height": a.size + "px" }); k.find(".burger").css({ "font-size": ".8em", width: a.size / 2 + "px", height: "3px", left: a.size / 4 + "px" }) }, getCss: function(e,a) { return e.currentStyle?e.currentStyle[a]:document.defaultView.getComputedStyle(e,!1)[a]; }, openMove: function(){ var drags={down:!1,x:0,y:0,winWid:0,winHei:0,clientX:0,clientY:0}; g(b.els.button).on('mousedown', function(e) { drags.down=!0, drags.clientX=e.clientX, drags.clientY=e.clientY, drags.x=b.methods.getCss(rt[0],"left"), drags.y=b.methods.getCss(rt[0],"top"), drags.winHei=$(window).height(), drags.winWid=$(window).width(), g(document).on("mousemove",function(e){ if(drags.winWid>640&& e.clientX>=80 && e.clientX <= drags.winWid-90) //50px rt[0].style.left=parseInt(drags.x)+ (e.clientX-drags.clientX) +"px"; if(e.clientY >= 100 && e.clientY <= drags.winHei-80)//导航高度 rt[0].style.top=parseInt(drags.y)+ (e.clientY-drags.clientY) +"px"; }) }); g(document).on("mouseup",function(){drags.down==!0 && (drags.down=!1,g(document).off("mousemove"))}); }, openHover: function(){ let tt; g(b.els.button).hover(function(){ clearTimeout(tt); g(b.els.checkbox).prop("checked", true).change(); },function(){ tt = setTimeout(()=>{ g(b.els.checkbox).prop("checked", false).change(); },200); }); g(b.els.item).hover(function(){ clearTimeout(tt); g(b.els.checkbox).prop("checked", true).change(); },function(){ tt = setTimeout(()=>{ g(b.els.checkbox).prop("checked", false).change(); },200) }); } }; b._callbacks = { vertical: b.methods.linear, horizontal: b.methods.linear, circle: b.methods.circle }; b.init = function() { var a = document.createElementNS("http://www.w3.org/2000/svg", "svg") , f = g(".navimenu").index(k); a.setAttribute("id", "gooeySVG" + f); a.setAttribute("class", "gooeySVG"); k.append(a); a = document.getElementById("gooeySVG" + f); b.methods.createOn(a, "defs", { id: "defs" + f }); a = document.getElementById("defs" + f); b.methods.createOn(a, "filter", { id: "goo-shadow" + f, overflow: "hidden" }); var c = document.getElementById("goo-shadow" + f); b.methods.createOn(c, "feGaussianBlur", { "in": "SourceGraphic", result: "blur", stdDeviation: "10" }); b.methods.createOn(c, "feColorMatrix", { "in": "blur", mode: "matrix", values: "1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 18 -8", result: "goo" }); b.methods.createOn(c, "feGaussianBlur", { "in": "goo", stdDeviation: "2", result: "shadow" }); b.methods.createOn(c, "feColorMatrix", { "in": "shadow", mode: "matrix", values: "0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0", result: "shadow" }); b.methods.createOn(c, "feOffset", { "in": "shadow", dx: "1", dy: "1", result: "shadow" }); b.methods.createOn(c, "feComposite", { in2: "shadow", "in": "goo", result: "goo" }); b.methods.createOn(c, "feComposite", { in2: "goo", "in": "SourceGraphic", result: "mix" }); b.methods.createOn(a, "filter", { id: "goo" + f }); a = document.getElementById("goo" + f); b.methods.createOn(a, "feGaussianBlur", { "in": "SourceGraphic", result: "blur", stdDeviation: "10" }); b.methods.createOn(a, "feColorMatrix", { "in": "blur", mode: "matrix", values: "1 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 18 -7", result: "goo" }); b.methods.createOn(a, "feComposite", { in2: "goo", "in": "SourceGraphic", result: "mix" }); k.css({ "-webkit-filter": "url('#goo-shadow" + f + "')", filter: "url('#goo-shadow" + f + "')", "-ms-filter": "url('#goo-shadow" + f + "')", "-o-filter": "url('#goo-shadow" + f + "')" }); b.methods.setEvents(); b.methods.setup(); b.methods.translate.apply(this, arguments); b.methods.openMove(); b.methods.openHover(); g('head').append('') } ; b.init() } ; g.gooeymenu.defaults = { style: "horizontal", size: 70, margin: "medium", bgColor: "steelblue", contentColor: "white", transitionStep: 100, bounce: !1, bounceLength: "medium", hover: "white", circle: { radius: 80 }, horizontal: { menuItemPosition: "glue" }, vertical: { menuItemPosition: "spaced", direction: "up" }, open: function() {}, close: function() {} }; g.fn.gooeymenu = function(h) { void 0 === h && (h = {}); if (h && "object" === typeof h) return this.each(function() { new g.gooeymenu(this,h) }) } } )(unsafeWindow.jQuery || window.jQuery); const autoPlay = (function ($) { const CONFIG = { keys: { courseStart: '_.unique.name.course.start.', courseClose: '_.unique.name.course.close.', subject: '_.unique.name.subject.', } } function GM_onMessage(_this, label, callback) { // console.log(`增加GM_onMessage,参数为${label}`); GM_addValueChangeListener(label, function () { // console.log('onMessage', arguments[2]) callback.apply(_this, arguments[2]); }); } function GM_sendMessage(label) { let prams = Array.from(arguments).slice(1); prams.push(new Date().getTime()); // console.log(`调用GM_sendMessage,参数为${label}, ${prams}`); GM_setValue(label, prams); } function pageType() { console.log('window.location.href', window.location.href) if (window.location.href.match("/study/subject/detail/")) { return 'List'; } else if(window.location.href.match("/train-new/class-detail")){ return 'NewList'; } else if (window.location.href.match("/vue/paas-designer")) { return 'PaasList'; } else if (window.location.href.match("/study/course/detail/")) { return 'Detail'; } else if (window.location.href.match("/safe/topic/resource/")) { return 'Resource'; } return 'Unknown'; } class Filter { applyRequestFilter(url, method, params) { // 这里是接口的默认行为,可根据需要在子类中重写 return params } applyResponseFilter(url, xhr) { // 这里是接口的默认行为,可根据需要在子类中重写 } } class Filter111 extends Filter { applyRequestFilter(url, method, argument) { // 这里是接口的默认行为,可根据需要在子类中重写 console.log('applyRequestFilter', url, argument) return argument } applyResponseFilter(url, xhr) { // 这里是接口的默认行为,可根据需要在子类中重写 console.log('applyResponseFilter', url, xhr) } } class AbstractPlayPage { constructor(supportive = true) { this.targetName = new.target.name; if (new.target === AbstractPlayPage) { throw new Error("不能直接创建抽象类"); } let originalOpen = XMLHttpRequest.prototype.open let originalSend = XMLHttpRequest.prototype.send let _that = this; // 重写 XMLHttpRequest 的 open 方法 XMLHttpRequest.prototype.open = function (method, url) { // 存储请求的 URL this._url = url let _params = arguments _that.filterList().forEach(f=>{ _params = f.applyRequestFilter(url, method, _params) || _params; }); originalOpen.apply(this, _params) } // 重写 XMLHttpRequest 的 send 方法 XMLHttpRequest.prototype.send = function (body) { if (this.onreadystatechange) { let originalReadyStateChange = this.onreadystatechange this.onreadystatechange = function () { // 检查特定条件:请求完成、状态成功,并且 URL 包含特定路径 if (this.readyState === 4 && this.status === 200 && (this.responseType == '' || this.responseType == 'text')) { _that.getFilterList && (_that.getFilterList().forEach(filter => { filter.applyResponseFilter(this._url, this); })) // Object.defineProperty(this, '_responseText', this.responseText) // console.log('this.responseText', this.responseText) } originalReadyStateChange.apply(this) } } originalSend.apply(this, arguments) } if(supportive) { let uuids = window.location.href.match('[0-9a-f]{8}(-[0-9a-f]{4}){3}-[0-9a-f]{12}'); this.pageId = (uuids && uuids[0]) || ''; } } filterList() { // return [new Filter111()] return []; } addNav(menuItems) { $('body').append(`