// ==UserScript== // @name 在浙学网课助手(原在浙学题库搜索) // @namespace http://tampermonkey.net/ // @version 1.80 // @description 完全免费的在浙学脚本,支持答案显示,自动挂课,粘贴限制解除 官网:https://pages.zaizhexue.top/ // @author Miaoz // @match *://www.zjooc.cn/* // @grant GM_xmlhttpRequest // @license MIT // ==/UserScript== (() => { var __webpack_modules__ = { "./src/utils/matter.min.js": function(module, __unused_webpack_exports, __webpack_require__) { /*! * matter-js 0.18.0 by @liabru * http://brm.io/matter-js/ * License MIT */ module.exports = function(e) { var t = {}; function n(i) { if (t[i]) return t[i].exports; var o = t[i] = { i: i, l: !1, exports: {} }; return e[i].call(o.exports, o, o.exports, n), o.l = !0, o.exports; } return n.m = e, n.c = t, n.d = function(e, t, i) { n.o(e, t) || Object.defineProperty(e, t, { enumerable: !0, get: i }); }, n.r = function(e) { "undefined" != typeof Symbol && Symbol.toStringTag && Object.defineProperty(e, Symbol.toStringTag, { value: "Module" }), Object.defineProperty(e, "__esModule", { value: !0 }); }, n.t = function(e, t) { if (1 & t && (e = n(e)), 8 & t) return e; if (4 & t && "object" == typeof e && e && e.__esModule) return e; var i = Object.create(null); if (n.r(i), Object.defineProperty(i, "default", { enumerable: !0, value: e }), 2 & t && "string" != typeof e) for (var o in e) n.d(i, o, function(t) { return e[t]; }.bind(null, o)); return i; }, n.n = function(e) { var t = e && e.__esModule ? function() { return e.default; } : function() { return e; }; return n.d(t, "a", t), t; }, n.o = function(e, t) { return Object.prototype.hasOwnProperty.call(e, t); }, n.p = "", n(n.s = 21); }([ function(e, t) { var n = {}; e.exports = n, function() { n._nextId = 0, n._seed = 0, n._nowStartTime = +new Date, n._warnedOnce = {}, n._decomp = null, n.extend = function(e, t) { var i, o; "boolean" == typeof t ? (i = 2, o = t) : (i = 1, o = !0); for (var r = i; r < arguments.length; r++) { var a = arguments[r]; if (a) for (var s in a) o && a[s] && a[s].constructor === Object ? e[s] && e[s].constructor !== Object ? e[s] = a[s] : (e[s] = e[s] || {}, n.extend(e[s], o, a[s])) : e[s] = a[s]; } return e; }, n.clone = function(e, t) { return n.extend({}, t, e); }, n.keys = function(e) { if (Object.keys) return Object.keys(e); var t = []; for (var n in e) t.push(n); return t; }, n.values = function(e) { var t = []; if (Object.keys) { for (var n = Object.keys(e), i = 0; i < n.length; i++) t.push(e[n[i]]); return t; } for (var o in e) t.push(e[o]); return t; }, n.get = function(e, t, n, i) { t = t.split(".").slice(n, i); for (var o = 0; o < t.length; o += 1) e = e[t[o]]; return e; }, n.set = function(e, t, i, o, r) { var a = t.split(".").slice(o, r); return n.get(e, t, 0, -1)[a[a.length - 1]] = i, i; }, n.shuffle = function(e) { for (var t = e.length - 1; t > 0; t--) { var i = Math.floor(n.random() * (t + 1)), o = e[t]; e[t] = e[i], e[i] = o; } return e; }, n.choose = function(e) { return e[Math.floor(n.random() * e.length)]; }, n.isElement = function(e) { return "undefined" != typeof HTMLElement ? e instanceof HTMLElement : !!(e && e.nodeType && e.nodeName); }, n.isArray = function(e) { return "[object Array]" === Object.prototype.toString.call(e); }, n.isFunction = function(e) { return "function" == typeof e; }, n.isPlainObject = function(e) { return "object" == typeof e && e.constructor === Object; }, n.isString = function(e) { return "[object String]" === toString.call(e); }, n.clamp = function(e, t, n) { return e < t ? t : e > n ? n : e; }, n.sign = function(e) { return e < 0 ? -1 : 1; }, n.now = function() { if ("undefined" != typeof window && window.performance) { if (window.performance.now) return window.performance.now(); if (window.performance.webkitNow) return window.performance.webkitNow(); } return Date.now ? Date.now() : new Date - n._nowStartTime; }, n.random = function(t, n) { return n = void 0 !== n ? n : 1, (t = void 0 !== t ? t : 0) + e() * (n - t); }; var e = function() { return n._seed = (9301 * n._seed + 49297) % 233280, n._seed / 233280; }; n.colorToNumber = function(e) { return 3 == (e = e.replace("#", "")).length && (e = e.charAt(0) + e.charAt(0) + e.charAt(1) + e.charAt(1) + e.charAt(2) + e.charAt(2)), parseInt(e, 16); }, n.logLevel = 1, n.log = function() { console && n.logLevel > 0 && n.logLevel <= 3 && console.log.apply(console, [ "matter-js:" ].concat(Array.prototype.slice.call(arguments))); }, n.info = function() { console && n.logLevel > 0 && n.logLevel <= 2 && console.info.apply(console, [ "matter-js:" ].concat(Array.prototype.slice.call(arguments))); }, n.warn = function() { console && n.logLevel > 0 && n.logLevel <= 3 && console.warn.apply(console, [ "matter-js:" ].concat(Array.prototype.slice.call(arguments))); }, n.warnOnce = function() { var e = Array.prototype.slice.call(arguments).join(" "); n._warnedOnce[e] || (n.warn(e), n._warnedOnce[e] = !0); }, n.deprecated = function(e, t, i) { e[t] = n.chain((function() { n.warnOnce("🔅 deprecated 🔅", i); }), e[t]); }, n.nextId = function() { return n._nextId++; }, n.indexOf = function(e, t) { if (e.indexOf) return e.indexOf(t); for (var n = 0; n < e.length; n++) if (e[n] === t) return n; return -1; }, n.map = function(e, t) { if (e.map) return e.map(t); for (var n = [], i = 0; i < e.length; i += 1) n.push(t(e[i])); return n; }, n.topologicalSort = function(e) { var t = [], i = [], o = []; for (var r in e) i[r] || o[r] || n._topologicalSort(r, i, o, e, t); return t; }, n._topologicalSort = function(e, t, i, o, r) { var a = o[e] || []; i[e] = !0; for (var s = 0; s < a.length; s += 1) { var l = a[s]; i[l] || t[l] || n._topologicalSort(l, t, i, o, r); } i[e] = !1, t[e] = !0, r.push(e); }, n.chain = function() { for (var e = [], t = 0; t < arguments.length; t += 1) { var n = arguments[t]; n._chained ? e.push.apply(e, n._chained) : e.push(n); } var i = function() { for (var t, n = new Array(arguments.length), i = 0, o = arguments.length; i < o; i++) n[i] = arguments[i]; for (i = 0; i < e.length; i += 1) { var r = e[i].apply(t, n); void 0 !== r && (t = r); } return t; }; return i._chained = e, i; }, n.chainPathBefore = function(e, t, i) { return n.set(e, t, n.chain(i, n.get(e, t))); }, n.chainPathAfter = function(e, t, i) { return n.set(e, t, n.chain(n.get(e, t), i)); }, n.setDecomp = function(e) { n._decomp = e; }, n.getDecomp = function() { var e = n._decomp; try { e || "undefined" == typeof window || (e = window.decomp), e || void 0 === __webpack_require__.g || (e = __webpack_require__.g.decomp); } catch (t) { e = null; } return e; }; }(); }, function(e, t) { var n = {}; e.exports = n, n.create = function(e) { var t = { min: { x: 0, y: 0 }, max: { x: 0, y: 0 } }; return e && n.update(t, e), t; }, n.update = function(e, t, n) { e.min.x = 1 / 0, e.max.x = -1 / 0, e.min.y = 1 / 0, e.max.y = -1 / 0; for (var i = 0; i < t.length; i++) { var o = t[i]; o.x > e.max.x && (e.max.x = o.x), o.x < e.min.x && (e.min.x = o.x), o.y > e.max.y && (e.max.y = o.y), o.y < e.min.y && (e.min.y = o.y); } n && (n.x > 0 ? e.max.x += n.x : e.min.x += n.x, n.y > 0 ? e.max.y += n.y : e.min.y += n.y); }, n.contains = function(e, t) { return t.x >= e.min.x && t.x <= e.max.x && t.y >= e.min.y && t.y <= e.max.y; }, n.overlaps = function(e, t) { return e.min.x <= t.max.x && e.max.x >= t.min.x && e.max.y >= t.min.y && e.min.y <= t.max.y; }, n.translate = function(e, t) { e.min.x += t.x, e.max.x += t.x, e.min.y += t.y, e.max.y += t.y; }, n.shift = function(e, t) { var n = e.max.x - e.min.x, i = e.max.y - e.min.y; e.min.x = t.x, e.max.x = t.x + n, e.min.y = t.y, e.max.y = t.y + i; }; }, function(e, t) { var n = {}; e.exports = n, n.create = function(e, t) { return { x: e || 0, y: t || 0 }; }, n.clone = function(e) { return { x: e.x, y: e.y }; }, n.magnitude = function(e) { return Math.sqrt(e.x * e.x + e.y * e.y); }, n.magnitudeSquared = function(e) { return e.x * e.x + e.y * e.y; }, n.rotate = function(e, t, n) { var i = Math.cos(t), o = Math.sin(t); n || (n = {}); var r = e.x * i - e.y * o; return n.y = e.x * o + e.y * i, n.x = r, n; }, n.rotateAbout = function(e, t, n, i) { var o = Math.cos(t), r = Math.sin(t); i || (i = {}); var a = n.x + ((e.x - n.x) * o - (e.y - n.y) * r); return i.y = n.y + ((e.x - n.x) * r + (e.y - n.y) * o), i.x = a, i; }, n.normalise = function(e) { var t = n.magnitude(e); return 0 === t ? { x: 0, y: 0 } : { x: e.x / t, y: e.y / t }; }, n.dot = function(e, t) { return e.x * t.x + e.y * t.y; }, n.cross = function(e, t) { return e.x * t.y - e.y * t.x; }, n.cross3 = function(e, t, n) { return (t.x - e.x) * (n.y - e.y) - (t.y - e.y) * (n.x - e.x); }, n.add = function(e, t, n) { return n || (n = {}), n.x = e.x + t.x, n.y = e.y + t.y, n; }, n.sub = function(e, t, n) { return n || (n = {}), n.x = e.x - t.x, n.y = e.y - t.y, n; }, n.mult = function(e, t) { return { x: e.x * t, y: e.y * t }; }, n.div = function(e, t) { return { x: e.x / t, y: e.y / t }; }, n.perp = function(e, t) { return { x: (t = !0 === t ? -1 : 1) * -e.y, y: t * e.x }; }, n.neg = function(e) { return { x: -e.x, y: -e.y }; }, n.angle = function(e, t) { return Math.atan2(t.y - e.y, t.x - e.x); }, n._temp = [ n.create(), n.create(), n.create(), n.create(), n.create(), n.create() ]; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(2), r = n(0); i.create = function(e, t) { for (var n = [], i = 0; i < e.length; i++) { var o = e[i], r = { x: o.x, y: o.y, index: i, body: t, isInternal: !1 }; n.push(r); } return n; }, i.fromPath = function(e, t) { var n = []; return e.replace(/L?\s*([-\d.e]+)[\s,]*([-\d.e]+)*/gi, (function(e, t, i) { n.push({ x: parseFloat(t), y: parseFloat(i) }); })), i.create(n, t); }, i.centre = function(e) { for (var t, n, r, a = i.area(e, !0), s = { x: 0, y: 0 }, l = 0; l < e.length; l++) r = (l + 1) % e.length, t = o.cross(e[l], e[r]), n = o.mult(o.add(e[l], e[r]), t), s = o.add(s, n); return o.div(s, 6 * a); }, i.mean = function(e) { for (var t = { x: 0, y: 0 }, n = 0; n < e.length; n++) t.x += e[n].x, t.y += e[n].y; return o.div(t, e.length); }, i.area = function(e, t) { for (var n = 0, i = e.length - 1, o = 0; o < e.length; o++) n += (e[i].x - e[o].x) * (e[i].y + e[o].y), i = o; return t ? n / 2 : Math.abs(n) / 2; }, i.inertia = function(e, t) { for (var n, i, r = 0, a = 0, s = e, l = 0; l < s.length; l++) i = (l + 1) % s.length, r += (n = Math.abs(o.cross(s[i], s[l]))) * (o.dot(s[i], s[i]) + o.dot(s[i], s[l]) + o.dot(s[l], s[l])), a += n; return t / 6 * (r / a); }, i.translate = function(e, t, n) { n = void 0 !== n ? n : 1; var i, o = e.length, r = t.x * n, a = t.y * n; for (i = 0; i < o; i++) e[i].x += r, e[i].y += a; return e; }, i.rotate = function(e, t, n) { if (0 !== t) { var i, o, r, a, s = Math.cos(t), l = Math.sin(t), c = n.x, u = n.y, d = e.length; for (a = 0; a < d; a++) o = (i = e[a]).x - c, r = i.y - u, i.x = c + (o * s - r * l), i.y = u + (o * l + r * s); return e; } }, i.contains = function(e, t) { for (var n, i = t.x, o = t.y, r = e.length, a = e[r - 1], s = 0; s < r; s++) { if (n = e[s], (i - a.x) * (n.y - a.y) + (o - a.y) * (a.x - n.x) > 0) return !1; a = n; } return !0; }, i.scale = function(e, t, n, r) { if (1 === t && 1 === n) return e; var a, s; r = r || i.centre(e); for (var l = 0; l < e.length; l++) a = e[l], s = o.sub(a, r), e[l].x = r.x + s.x * t, e[l].y = r.y + s.y * n; return e; }, i.chamfer = function(e, t, n, i, a) { t = "number" == typeof t ? [ t ] : t || [ 8 ], n = void 0 !== n ? n : -1, i = i || 2, a = a || 14; for (var s = [], l = 0; l < e.length; l++) { var c = e[l - 1 >= 0 ? l - 1 : e.length - 1], u = e[l], d = e[(l + 1) % e.length], p = t[l < t.length ? l : t.length - 1]; if (0 !== p) { var f = o.normalise({ x: u.y - c.y, y: c.x - u.x }), v = o.normalise({ x: d.y - u.y, y: u.x - d.x }), y = Math.sqrt(2 * Math.pow(p, 2)), m = o.mult(r.clone(f), p), g = o.normalise(o.mult(o.add(f, v), .5)), x = o.sub(u, o.mult(g, y)), h = n; -1 === n && (h = 1.75 * Math.pow(p, .32)), (h = r.clamp(h, i, a)) % 2 == 1 && (h += 1); for (var b = Math.acos(o.dot(f, v)) / h, S = 0; S < h; S++) s.push(o.add(o.rotate(m, b * S), x)); } else s.push(u); } return s; }, i.clockwiseSort = function(e) { var t = i.mean(e); return e.sort((function(e, n) { return o.angle(t, e) - o.angle(t, n); })), e; }, i.isConvex = function(e) { var t, n, i, o, r = 0, a = e.length; if (a < 3) return null; for (t = 0; t < a; t++) if (i = (t + 2) % a, o = (e[n = (t + 1) % a].x - e[t].x) * (e[i].y - e[n].y), (o -= (e[n].y - e[t].y) * (e[i].x - e[n].x)) < 0 ? r |= 1 : o > 0 && (r |= 2), 3 === r) return !1; return 0 !== r || null; }, i.hull = function(e) { var t, n, i = [], r = []; for ((e = e.slice(0)).sort((function(e, t) { var n = e.x - t.x; return 0 !== n ? n : e.y - t.y; })), n = 0; n < e.length; n += 1) { for (t = e[n]; r.length >= 2 && o.cross3(r[r.length - 2], r[r.length - 1], t) <= 0; ) r.pop(); r.push(t); } for (n = e.length - 1; n >= 0; n -= 1) { for (t = e[n]; i.length >= 2 && o.cross3(i[i.length - 2], i[i.length - 1], t) <= 0; ) i.pop(); i.push(t); } return i.pop(), r.pop(), i.concat(r); }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(0); i.on = function(e, t, n) { for (var i, o = t.split(" "), r = 0; r < o.length; r++) i = o[r], e.events = e.events || {}, e.events[i] = e.events[i] || [], e.events[i].push(n); return n; }, i.off = function(e, t, n) { if (t) { "function" == typeof t && (n = t, t = o.keys(e.events).join(" ")); for (var i = t.split(" "), r = 0; r < i.length; r++) { var a = e.events[i[r]], s = []; if (n && a) for (var l = 0; l < a.length; l++) a[l] !== n && s.push(a[l]); e.events[i[r]] = s; } } else e.events = {}; }, i.trigger = function(e, t, n) { var i, r, a, s, l = e.events; if (l && o.keys(l).length > 0) { n || (n = {}), i = t.split(" "); for (var c = 0; c < i.length; c++) if (a = l[r = i[c]]) { (s = o.clone(n, !1)).name = r, s.source = e; for (var u = 0; u < a.length; u++) a[u].apply(e, [ s ]); } } }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(4), r = n(0), a = n(1), s = n(6); i.create = function(e) { return r.extend({ id: r.nextId(), type: "composite", parent: null, isModified: !1, bodies: [], constraints: [], composites: [], label: "Composite", plugin: {}, cache: { allBodies: null, allConstraints: null, allComposites: null } }, e); }, i.setModified = function(e, t, n, o) { if (e.isModified = t, t && e.cache && (e.cache.allBodies = null, e.cache.allConstraints = null, e.cache.allComposites = null), n && e.parent && i.setModified(e.parent, t, n, o), o) for (var r = 0; r < e.composites.length; r++) { var a = e.composites[r]; i.setModified(a, t, n, o); } }, i.add = function(e, t) { var n = [].concat(t); o.trigger(e, "beforeAdd", { object: t }); for (var a = 0; a < n.length; a++) { var s = n[a]; switch (s.type) { case "body": if (s.parent !== s) { r.warn("Composite.add: skipped adding a compound body part (you must add its parent instead)"); break; } i.addBody(e, s); break; case "constraint": i.addConstraint(e, s); break; case "composite": i.addComposite(e, s); break; case "mouseConstraint": i.addConstraint(e, s.constraint); } } return o.trigger(e, "afterAdd", { object: t }), e; }, i.remove = function(e, t, n) { var r = [].concat(t); o.trigger(e, "beforeRemove", { object: t }); for (var a = 0; a < r.length; a++) { var s = r[a]; switch (s.type) { case "body": i.removeBody(e, s, n); break; case "constraint": i.removeConstraint(e, s, n); break; case "composite": i.removeComposite(e, s, n); break; case "mouseConstraint": i.removeConstraint(e, s.constraint); } } return o.trigger(e, "afterRemove", { object: t }), e; }, i.addComposite = function(e, t) { return e.composites.push(t), t.parent = e, i.setModified(e, !0, !0, !1), e; }, i.removeComposite = function(e, t, n) { var o = r.indexOf(e.composites, t); if (-1 !== o && i.removeCompositeAt(e, o), n) for (var a = 0; a < e.composites.length; a++) i.removeComposite(e.composites[a], t, !0); return e; }, i.removeCompositeAt = function(e, t) { return e.composites.splice(t, 1), i.setModified(e, !0, !0, !1), e; }, i.addBody = function(e, t) { return e.bodies.push(t), i.setModified(e, !0, !0, !1), e; }, i.removeBody = function(e, t, n) { var o = r.indexOf(e.bodies, t); if (-1 !== o && i.removeBodyAt(e, o), n) for (var a = 0; a < e.composites.length; a++) i.removeBody(e.composites[a], t, !0); return e; }, i.removeBodyAt = function(e, t) { return e.bodies.splice(t, 1), i.setModified(e, !0, !0, !1), e; }, i.addConstraint = function(e, t) { return e.constraints.push(t), i.setModified(e, !0, !0, !1), e; }, i.removeConstraint = function(e, t, n) { var o = r.indexOf(e.constraints, t); if (-1 !== o && i.removeConstraintAt(e, o), n) for (var a = 0; a < e.composites.length; a++) i.removeConstraint(e.composites[a], t, !0); return e; }, i.removeConstraintAt = function(e, t) { return e.constraints.splice(t, 1), i.setModified(e, !0, !0, !1), e; }, i.clear = function(e, t, n) { if (n) for (var o = 0; o < e.composites.length; o++) i.clear(e.composites[o], t, !0); return t ? e.bodies = e.bodies.filter((function(e) { return e.isStatic; })) : e.bodies.length = 0, e.constraints.length = 0, e.composites.length = 0, i.setModified(e, !0, !0, !1), e; }, i.allBodies = function(e) { if (e.cache && e.cache.allBodies) return e.cache.allBodies; for (var t = [].concat(e.bodies), n = 0; n < e.composites.length; n++) t = t.concat(i.allBodies(e.composites[n])); return e.cache && (e.cache.allBodies = t), t; }, i.allConstraints = function(e) { if (e.cache && e.cache.allConstraints) return e.cache.allConstraints; for (var t = [].concat(e.constraints), n = 0; n < e.composites.length; n++) t = t.concat(i.allConstraints(e.composites[n])); return e.cache && (e.cache.allConstraints = t), t; }, i.allComposites = function(e) { if (e.cache && e.cache.allComposites) return e.cache.allComposites; for (var t = [].concat(e.composites), n = 0; n < e.composites.length; n++) t = t.concat(i.allComposites(e.composites[n])); return e.cache && (e.cache.allComposites = t), t; }, i.get = function(e, t, n) { var o, r; switch (n) { case "body": o = i.allBodies(e); break; case "constraint": o = i.allConstraints(e); break; case "composite": o = i.allComposites(e).concat(e); } return o ? 0 === (r = o.filter((function(e) { return e.id.toString() === t.toString(); }))).length ? null : r[0] : null; }, i.move = function(e, t, n) { return i.remove(e, t), i.add(n, t), e; }, i.rebase = function(e) { for (var t = i.allBodies(e).concat(i.allConstraints(e)).concat(i.allComposites(e)), n = 0; n < t.length; n++) t[n].id = r.nextId(); return e; }, i.translate = function(e, t, n) { for (var o = n ? i.allBodies(e) : e.bodies, r = 0; r < o.length; r++) s.translate(o[r], t); return e; }, i.rotate = function(e, t, n, o) { for (var r = Math.cos(t), a = Math.sin(t), l = o ? i.allBodies(e) : e.bodies, c = 0; c < l.length; c++) { var u = l[c], d = u.position.x - n.x, p = u.position.y - n.y; s.setPosition(u, { x: n.x + (d * r - p * a), y: n.y + (d * a + p * r) }), s.rotate(u, t); } return e; }, i.scale = function(e, t, n, o, r) { for (var a = r ? i.allBodies(e) : e.bodies, l = 0; l < a.length; l++) { var c = a[l], u = c.position.x - o.x, d = c.position.y - o.y; s.setPosition(c, { x: o.x + u * t, y: o.y + d * n }), s.scale(c, t, n); } return e; }, i.bounds = function(e) { for (var t = i.allBodies(e), n = [], o = 0; o < t.length; o += 1) { var r = t[o]; n.push(r.bounds.min, r.bounds.max); } return a.create(n); }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(3), r = n(2), a = n(7), s = (n(16), n(0)), l = n(1), c = n(11); !function() { i._inertiaScale = 4, i._nextCollidingGroupId = 1, i._nextNonCollidingGroupId = -1, i._nextCategory = 1, i.create = function(t) { var n = { id: s.nextId(), type: "body", label: "Body", parts: [], plugin: {}, angle: 0, vertices: o.fromPath("L 0 0 L 40 0 L 40 40 L 0 40"), position: { x: 0, y: 0 }, force: { x: 0, y: 0 }, torque: 0, positionImpulse: { x: 0, y: 0 }, constraintImpulse: { x: 0, y: 0, angle: 0 }, totalContacts: 0, speed: 0, angularSpeed: 0, velocity: { x: 0, y: 0 }, angularVelocity: 0, isSensor: !1, isStatic: !1, isSleeping: !1, motion: 0, sleepThreshold: 60, density: .001, restitution: 0, friction: .1, frictionStatic: .5, frictionAir: .01, collisionFilter: { category: 1, mask: 4294967295, group: 0 }, slop: .05, timeScale: 1, render: { visible: !0, opacity: 1, strokeStyle: null, fillStyle: null, lineWidth: null, sprite: { xScale: 1, yScale: 1, xOffset: 0, yOffset: 0 } }, events: null, bounds: null, chamfer: null, circleRadius: 0, positionPrev: null, anglePrev: 0, parent: null, axes: null, area: 0, mass: 0, inertia: 0, _original: null }, i = s.extend(n, t); return e(i, t), i; }, i.nextGroup = function(e) { return e ? i._nextNonCollidingGroupId-- : i._nextCollidingGroupId++; }, i.nextCategory = function() { return i._nextCategory = i._nextCategory << 1, i._nextCategory; }; var e = function(e, t) { t = t || {}, i.set(e, { bounds: e.bounds || l.create(e.vertices), positionPrev: e.positionPrev || r.clone(e.position), anglePrev: e.anglePrev || e.angle, vertices: e.vertices, parts: e.parts || [ e ], isStatic: e.isStatic, isSleeping: e.isSleeping, parent: e.parent || e }), o.rotate(e.vertices, e.angle, e.position), c.rotate(e.axes, e.angle), l.update(e.bounds, e.vertices, e.velocity), i.set(e, { axes: t.axes || e.axes, area: t.area || e.area, mass: t.mass || e.mass, inertia: t.inertia || e.inertia }); var n = e.isStatic ? "#14151f" : s.choose([ "#f19648", "#f5d259", "#f55a3c", "#063e7b", "#ececd1" ]), a = e.isStatic ? "#555" : "#ccc", u = e.isStatic && null === e.render.fillStyle ? 1 : 0; e.render.fillStyle = e.render.fillStyle || n, e.render.strokeStyle = e.render.strokeStyle || a, e.render.lineWidth = e.render.lineWidth || u, e.render.sprite.xOffset += -(e.bounds.min.x - e.position.x) / (e.bounds.max.x - e.bounds.min.x), e.render.sprite.yOffset += -(e.bounds.min.y - e.position.y) / (e.bounds.max.y - e.bounds.min.y); }; i.set = function(e, t, n) { var o; for (o in "string" == typeof t && (o = t, (t = {})[o] = n), t) if (Object.prototype.hasOwnProperty.call(t, o)) switch (n = t[o], o) { case "isStatic": i.setStatic(e, n); break; case "isSleeping": a.set(e, n); break; case "mass": i.setMass(e, n); break; case "density": i.setDensity(e, n); break; case "inertia": i.setInertia(e, n); break; case "vertices": i.setVertices(e, n); break; case "position": i.setPosition(e, n); break; case "angle": i.setAngle(e, n); break; case "velocity": i.setVelocity(e, n); break; case "angularVelocity": i.setAngularVelocity(e, n); break; case "parts": i.setParts(e, n); break; case "centre": i.setCentre(e, n); break; default: e[o] = n; } }, i.setStatic = function(e, t) { for (var n = 0; n < e.parts.length; n++) { var i = e.parts[n]; i.isStatic = t, t ? (i._original = { restitution: i.restitution, friction: i.friction, mass: i.mass, inertia: i.inertia, density: i.density, inverseMass: i.inverseMass, inverseInertia: i.inverseInertia }, i.restitution = 0, i.friction = 1, i.mass = i.inertia = i.density = 1 / 0, i.inverseMass = i.inverseInertia = 0, i.positionPrev.x = i.position.x, i.positionPrev.y = i.position.y, i.anglePrev = i.angle, i.angularVelocity = 0, i.speed = 0, i.angularSpeed = 0, i.motion = 0) : i._original && (i.restitution = i._original.restitution, i.friction = i._original.friction, i.mass = i._original.mass, i.inertia = i._original.inertia, i.density = i._original.density, i.inverseMass = i._original.inverseMass, i.inverseInertia = i._original.inverseInertia, i._original = null); } }, i.setMass = function(e, t) { var n = e.inertia / (e.mass / 6); e.inertia = n * (t / 6), e.inverseInertia = 1 / e.inertia, e.mass = t, e.inverseMass = 1 / e.mass, e.density = e.mass / e.area; }, i.setDensity = function(e, t) { i.setMass(e, t * e.area), e.density = t; }, i.setInertia = function(e, t) { e.inertia = t, e.inverseInertia = 1 / e.inertia; }, i.setVertices = function(e, t) { t[0].body === e ? e.vertices = t : e.vertices = o.create(t, e), e.axes = c.fromVertices(e.vertices), e.area = o.area(e.vertices), i.setMass(e, e.density * e.area); var n = o.centre(e.vertices); o.translate(e.vertices, n, -1), i.setInertia(e, i._inertiaScale * o.inertia(e.vertices, e.mass)), o.translate(e.vertices, e.position), l.update(e.bounds, e.vertices, e.velocity); }, i.setParts = function(e, t, n) { var r; for (t = t.slice(0), e.parts.length = 0, e.parts.push(e), e.parent = e, r = 0; r < t.length; r++) { var a = t[r]; a !== e && (a.parent = e, e.parts.push(a)); } if (1 !== e.parts.length) { if (n = void 0 === n || n) { var s = []; for (r = 0; r < t.length; r++) s = s.concat(t[r].vertices); o.clockwiseSort(s); var l = o.hull(s), c = o.centre(l); i.setVertices(e, l), o.translate(e.vertices, c); } var u = i._totalProperties(e); e.area = u.area, e.parent = e, e.position.x = u.centre.x, e.position.y = u.centre.y, e.positionPrev.x = u.centre.x, e.positionPrev.y = u.centre.y, i.setMass(e, u.mass), i.setInertia(e, u.inertia), i.setPosition(e, u.centre); } }, i.setCentre = function(e, t, n) { n ? (e.positionPrev.x += t.x, e.positionPrev.y += t.y, e.position.x += t.x, e.position.y += t.y) : (e.positionPrev.x = t.x - (e.position.x - e.positionPrev.x), e.positionPrev.y = t.y - (e.position.y - e.positionPrev.y), e.position.x = t.x, e.position.y = t.y); }, i.setPosition = function(e, t) { var n = r.sub(t, e.position); e.positionPrev.x += n.x, e.positionPrev.y += n.y; for (var i = 0; i < e.parts.length; i++) { var a = e.parts[i]; a.position.x += n.x, a.position.y += n.y, o.translate(a.vertices, n), l.update(a.bounds, a.vertices, e.velocity); } }, i.setAngle = function(e, t) { var n = t - e.angle; e.anglePrev += n; for (var i = 0; i < e.parts.length; i++) { var a = e.parts[i]; a.angle += n, o.rotate(a.vertices, n, e.position), c.rotate(a.axes, n), l.update(a.bounds, a.vertices, e.velocity), i > 0 && r.rotateAbout(a.position, n, e.position, a.position); } }, i.setVelocity = function(e, t) { e.positionPrev.x = e.position.x - t.x, e.positionPrev.y = e.position.y - t.y, e.velocity.x = t.x, e.velocity.y = t.y, e.speed = r.magnitude(e.velocity); }, i.setAngularVelocity = function(e, t) { e.anglePrev = e.angle - t, e.angularVelocity = t, e.angularSpeed = Math.abs(e.angularVelocity); }, i.translate = function(e, t) { i.setPosition(e, r.add(e.position, t)); }, i.rotate = function(e, t, n) { if (n) { var o = Math.cos(t), r = Math.sin(t), a = e.position.x - n.x, s = e.position.y - n.y; i.setPosition(e, { x: n.x + (a * o - s * r), y: n.y + (a * r + s * o) }), i.setAngle(e, e.angle + t); } else i.setAngle(e, e.angle + t); }, i.scale = function(e, t, n, r) { var a = 0, s = 0; r = r || e.position; for (var u = 0; u < e.parts.length; u++) { var d = e.parts[u]; o.scale(d.vertices, t, n, r), d.axes = c.fromVertices(d.vertices), d.area = o.area(d.vertices), i.setMass(d, e.density * d.area), o.translate(d.vertices, { x: -d.position.x, y: -d.position.y }), i.setInertia(d, i._inertiaScale * o.inertia(d.vertices, d.mass)), o.translate(d.vertices, { x: d.position.x, y: d.position.y }), u > 0 && (a += d.area, s += d.inertia), d.position.x = r.x + (d.position.x - r.x) * t, d.position.y = r.y + (d.position.y - r.y) * n, l.update(d.bounds, d.vertices, e.velocity); } e.parts.length > 1 && (e.area = a, e.isStatic || (i.setMass(e, e.density * a), i.setInertia(e, s))), e.circleRadius && (t === n ? e.circleRadius *= t : e.circleRadius = null); }, i.update = function(e, t, n, i) { var a = Math.pow(t * n * e.timeScale, 2), s = 1 - e.frictionAir * n * e.timeScale, u = e.position.x - e.positionPrev.x, d = e.position.y - e.positionPrev.y; e.velocity.x = u * s * i + e.force.x / e.mass * a, e.velocity.y = d * s * i + e.force.y / e.mass * a, e.positionPrev.x = e.position.x, e.positionPrev.y = e.position.y, e.position.x += e.velocity.x, e.position.y += e.velocity.y, e.angularVelocity = (e.angle - e.anglePrev) * s * i + e.torque / e.inertia * a, e.anglePrev = e.angle, e.angle += e.angularVelocity, e.speed = r.magnitude(e.velocity), e.angularSpeed = Math.abs(e.angularVelocity); for (var p = 0; p < e.parts.length; p++) { var f = e.parts[p]; o.translate(f.vertices, e.velocity), p > 0 && (f.position.x += e.velocity.x, f.position.y += e.velocity.y), 0 !== e.angularVelocity && (o.rotate(f.vertices, e.angularVelocity, e.position), c.rotate(f.axes, e.angularVelocity), p > 0 && r.rotateAbout(f.position, e.angularVelocity, e.position, f.position)), l.update(f.bounds, f.vertices, e.velocity); } }, i.applyForce = function(e, t, n) { e.force.x += n.x, e.force.y += n.y; var i = t.x - e.position.x, o = t.y - e.position.y; e.torque += i * n.y - o * n.x; }, i._totalProperties = function(e) { for (var t = { mass: 0, area: 0, inertia: 0, centre: { x: 0, y: 0 } }, n = 1 === e.parts.length ? 0 : 1; n < e.parts.length; n++) { var i = e.parts[n], o = i.mass !== 1 / 0 ? i.mass : 1; t.mass += o, t.area += i.area, t.inertia += i.inertia, t.centre = r.add(t.centre, r.mult(i.position, o)); } return t.centre = r.div(t.centre, t.mass), t; }; }(); }, function(e, t, n) { var i = {}; e.exports = i; var o = n(4); i._motionWakeThreshold = .18, i._motionSleepThreshold = .08, i._minBias = .9, i.update = function(e, t) { for (var n = t * t * t, o = 0; o < e.length; o++) { var r = e[o], a = r.speed * r.speed + r.angularSpeed * r.angularSpeed; if (0 === r.force.x && 0 === r.force.y) { var s = Math.min(r.motion, a), l = Math.max(r.motion, a); r.motion = i._minBias * s + (1 - i._minBias) * l, r.sleepThreshold > 0 && r.motion < i._motionSleepThreshold * n ? (r.sleepCounter += 1, r.sleepCounter >= r.sleepThreshold && i.set(r, !0)) : r.sleepCounter > 0 && (r.sleepCounter -= 1); } else i.set(r, !1); } }, i.afterCollisions = function(e, t) { for (var n = t * t * t, o = 0; o < e.length; o++) { var r = e[o]; if (r.isActive) { var a = r.collision, s = a.bodyA.parent, l = a.bodyB.parent; if (!(s.isSleeping && l.isSleeping || s.isStatic || l.isStatic) && (s.isSleeping || l.isSleeping)) { var c = s.isSleeping && !s.isStatic ? s : l, u = c === s ? l : s; !c.isStatic && u.motion > i._motionWakeThreshold * n && i.set(c, !1); } } } }, i.set = function(e, t) { var n = e.isSleeping; t ? (e.isSleeping = !0, e.sleepCounter = e.sleepThreshold, e.positionImpulse.x = 0, e.positionImpulse.y = 0, e.positionPrev.x = e.position.x, e.positionPrev.y = e.position.y, e.anglePrev = e.angle, e.speed = 0, e.angularSpeed = 0, e.motion = 0, n || o.trigger(e, "sleepStart")) : (e.isSleeping = !1, e.sleepCounter = 0, n && o.trigger(e, "sleepEnd")); }; }, function(e, t, n) { var i = {}; e.exports = i; var o, r, a, s = n(3), l = n(9); o = [], r = { overlap: 0, axis: null }, a = { overlap: 0, axis: null }, i.create = function(e, t) { return { pair: null, collided: !1, bodyA: e, bodyB: t, parentA: e.parent, parentB: t.parent, depth: 0, normal: { x: 0, y: 0 }, tangent: { x: 0, y: 0 }, penetration: { x: 0, y: 0 }, supports: [] }; }, i.collides = function(e, t, n) { if (i._overlapAxes(r, e.vertices, t.vertices, e.axes), r.overlap <= 0) return null; if (i._overlapAxes(a, t.vertices, e.vertices, t.axes), a.overlap <= 0) return null; var o, c, u = n && n.table[l.id(e, t)]; u ? o = u.collision : ((o = i.create(e, t)).collided = !0, o.bodyA = e.id < t.id ? e : t, o.bodyB = e.id < t.id ? t : e, o.parentA = o.bodyA.parent, o.parentB = o.bodyB.parent), e = o.bodyA, t = o.bodyB, c = r.overlap < a.overlap ? r : a; var d = o.normal, p = o.supports, f = c.axis, v = f.x, y = f.y; v * (t.position.x - e.position.x) + y * (t.position.y - e.position.y) < 0 ? (d.x = v, d.y = y) : (d.x = -v, d.y = -y), o.tangent.x = -d.y, o.tangent.y = d.x, o.depth = c.overlap, o.penetration.x = d.x * o.depth, o.penetration.y = d.y * o.depth; var m = i._findSupports(e, t, d, 1), g = 0; if (s.contains(e.vertices, m[0]) && (p[g++] = m[0]), s.contains(e.vertices, m[1]) && (p[g++] = m[1]), g < 2) { var x = i._findSupports(t, e, d, -1); s.contains(t.vertices, x[0]) && (p[g++] = x[0]), g < 2 && s.contains(t.vertices, x[1]) && (p[g++] = x[1]); } return 0 === g && (p[g++] = m[0]), p.length = g, o; }, i._overlapAxes = function(e, t, n, i) { var o, r, a, s, l, c, u = t.length, d = n.length, p = t[0].x, f = t[0].y, v = n[0].x, y = n[0].y, m = i.length, g = Number.MAX_VALUE, x = 0; for (l = 0; l < m; l++) { var h = i[l], b = h.x, S = h.y, w = p * b + f * S, A = v * b + y * S, P = w, C = A; for (c = 1; c < u; c += 1) (s = t[c].x * b + t[c].y * S) > P ? P = s : s < w && (w = s); for (c = 1; c < d; c += 1) (s = n[c].x * b + n[c].y * S) > C ? C = s : s < A && (A = s); if ((o = (r = P - A) < (a = C - w) ? r : a) < g && (g = o, x = l, o <= 0)) break; } e.axis = i[x], e.overlap = g; }, i._projectToAxis = function(e, t, n) { for (var i = t[0].x * n.x + t[0].y * n.y, o = i, r = 1; r < t.length; r += 1) { var a = t[r].x * n.x + t[r].y * n.y; a > o ? o = a : a < i && (i = a); } e.min = i, e.max = o; }, i._findSupports = function(e, t, n, i) { var r, a, s, l, c, u = t.vertices, d = u.length, p = e.position.x, f = e.position.y, v = n.x * i, y = n.y * i, m = Number.MAX_VALUE; for (c = 0; c < d; c += 1) (l = v * (p - (a = u[c]).x) + y * (f - a.y)) < m && (m = l, r = a); return m = v * (p - (s = u[(d + r.index - 1) % d]).x) + y * (f - s.y), v * (p - (a = u[(r.index + 1) % d]).x) + y * (f - a.y) < m ? (o[0] = r, o[1] = a, o) : (o[0] = r, o[1] = s, o); }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(17); i.create = function(e, t) { var n = e.bodyA, o = e.bodyB, r = { id: i.id(n, o), bodyA: n, bodyB: o, collision: e, contacts: [], activeContacts: [], separation: 0, isActive: !0, confirmedActive: !0, isSensor: n.isSensor || o.isSensor, timeCreated: t, timeUpdated: t, inverseMass: 0, friction: 0, frictionStatic: 0, restitution: 0, slop: 0 }; return i.update(r, e, t), r; }, i.update = function(e, t, n) { var i = e.contacts, r = t.supports, a = e.activeContacts, s = t.parentA, l = t.parentB, c = s.vertices.length; e.isActive = !0, e.timeUpdated = n, e.collision = t, e.separation = t.depth, e.inverseMass = s.inverseMass + l.inverseMass, e.friction = s.friction < l.friction ? s.friction : l.friction, e.frictionStatic = s.frictionStatic > l.frictionStatic ? s.frictionStatic : l.frictionStatic, e.restitution = s.restitution > l.restitution ? s.restitution : l.restitution, e.slop = s.slop > l.slop ? s.slop : l.slop, t.pair = e, a.length = 0; for (var u = 0; u < r.length; u++) { var d = r[u], p = d.body === s ? d.index : c + d.index, f = i[p]; f ? a.push(f) : a.push(i[p] = o.create(d)); } }, i.setActive = function(e, t, n) { t ? (e.isActive = !0, e.timeUpdated = n) : (e.isActive = !1, e.activeContacts.length = 0); }, i.id = function(e, t) { return e.id < t.id ? "A" + e.id + "B" + t.id : "A" + t.id + "B" + e.id; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(3), r = n(2), a = n(7), s = n(1), l = n(11), c = n(0); i._warming = .4, i._torqueDampen = 1, i._minLength = 1e-6, i.create = function(e) { var t = e; t.bodyA && !t.pointA && (t.pointA = { x: 0, y: 0 }), t.bodyB && !t.pointB && (t.pointB = { x: 0, y: 0 }); var n = t.bodyA ? r.add(t.bodyA.position, t.pointA) : t.pointA, i = t.bodyB ? r.add(t.bodyB.position, t.pointB) : t.pointB, o = r.magnitude(r.sub(n, i)); t.length = void 0 !== t.length ? t.length : o, t.id = t.id || c.nextId(), t.label = t.label || "Constraint", t.type = "constraint", t.stiffness = t.stiffness || (t.length > 0 ? 1 : .7), t.damping = t.damping || 0, t.angularStiffness = t.angularStiffness || 0, t.angleA = t.bodyA ? t.bodyA.angle : t.angleA, t.angleB = t.bodyB ? t.bodyB.angle : t.angleB, t.plugin = {}; var a = { visible: !0, lineWidth: 2, strokeStyle: "#ffffff", type: "line", anchors: !0 }; return 0 === t.length && t.stiffness > .1 ? (a.type = "pin", a.anchors = !1) : t.stiffness < .9 && (a.type = "spring"), t.render = c.extend(a, t.render), t; }, i.preSolveAll = function(e) { for (var t = 0; t < e.length; t += 1) { var n = e[t], i = n.constraintImpulse; n.isStatic || 0 === i.x && 0 === i.y && 0 === i.angle || (n.position.x += i.x, n.position.y += i.y, n.angle += i.angle); } }, i.solveAll = function(e, t) { for (var n = 0; n < e.length; n += 1) { var o = e[n], r = !o.bodyA || o.bodyA && o.bodyA.isStatic, a = !o.bodyB || o.bodyB && o.bodyB.isStatic; (r || a) && i.solve(e[n], t); } for (n = 0; n < e.length; n += 1) r = !(o = e[n]).bodyA || o.bodyA && o.bodyA.isStatic, a = !o.bodyB || o.bodyB && o.bodyB.isStatic, r || a || i.solve(e[n], t); }, i.solve = function(e, t) { var n = e.bodyA, o = e.bodyB, a = e.pointA, s = e.pointB; if (n || o) { n && !n.isStatic && (r.rotate(a, n.angle - e.angleA, a), e.angleA = n.angle), o && !o.isStatic && (r.rotate(s, o.angle - e.angleB, s), e.angleB = o.angle); var l = a, c = s; if (n && (l = r.add(n.position, a)), o && (c = r.add(o.position, s)), l && c) { var u = r.sub(l, c), d = r.magnitude(u); d < i._minLength && (d = i._minLength); var p, f, v, y, m, g = (d - e.length) / d, x = e.stiffness < 1 ? e.stiffness * t : e.stiffness, h = r.mult(u, g * x), b = (n ? n.inverseMass : 0) + (o ? o.inverseMass : 0), S = b + ((n ? n.inverseInertia : 0) + (o ? o.inverseInertia : 0)); if (e.damping) { var w = r.create(); v = r.div(u, d), m = r.sub(o && r.sub(o.position, o.positionPrev) || w, n && r.sub(n.position, n.positionPrev) || w), y = r.dot(v, m); } n && !n.isStatic && (f = n.inverseMass / b, n.constraintImpulse.x -= h.x * f, n.constraintImpulse.y -= h.y * f, n.position.x -= h.x * f, n.position.y -= h.y * f, e.damping && (n.positionPrev.x -= e.damping * v.x * y * f, n.positionPrev.y -= e.damping * v.y * y * f), p = r.cross(a, h) / S * i._torqueDampen * n.inverseInertia * (1 - e.angularStiffness), n.constraintImpulse.angle -= p, n.angle -= p), o && !o.isStatic && (f = o.inverseMass / b, o.constraintImpulse.x += h.x * f, o.constraintImpulse.y += h.y * f, o.position.x += h.x * f, o.position.y += h.y * f, e.damping && (o.positionPrev.x += e.damping * v.x * y * f, o.positionPrev.y += e.damping * v.y * y * f), p = r.cross(s, h) / S * i._torqueDampen * o.inverseInertia * (1 - e.angularStiffness), o.constraintImpulse.angle += p, o.angle += p); } } }, i.postSolveAll = function(e) { for (var t = 0; t < e.length; t++) { var n = e[t], c = n.constraintImpulse; if (!(n.isStatic || 0 === c.x && 0 === c.y && 0 === c.angle)) { a.set(n, !1); for (var u = 0; u < n.parts.length; u++) { var d = n.parts[u]; o.translate(d.vertices, c), u > 0 && (d.position.x += c.x, d.position.y += c.y), 0 !== c.angle && (o.rotate(d.vertices, c.angle, n.position), l.rotate(d.axes, c.angle), u > 0 && r.rotateAbout(d.position, c.angle, n.position, d.position)), s.update(d.bounds, d.vertices, n.velocity); } c.angle *= i._warming, c.x *= i._warming, c.y *= i._warming; } } }, i.pointAWorld = function(e) { return { x: (e.bodyA ? e.bodyA.position.x : 0) + e.pointA.x, y: (e.bodyA ? e.bodyA.position.y : 0) + e.pointA.y }; }, i.pointBWorld = function(e) { return { x: (e.bodyB ? e.bodyB.position.x : 0) + e.pointB.x, y: (e.bodyB ? e.bodyB.position.y : 0) + e.pointB.y }; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(2), r = n(0); i.fromVertices = function(e) { for (var t = {}, n = 0; n < e.length; n++) { var i = (n + 1) % e.length, a = o.normalise({ x: e[i].y - e[n].y, y: e[n].x - e[i].x }), s = 0 === a.y ? 1 / 0 : a.x / a.y; t[s = s.toFixed(3).toString()] = a; } return r.values(t); }, i.rotate = function(e, t) { if (0 !== t) for (var n = Math.cos(t), i = Math.sin(t), o = 0; o < e.length; o++) { var r, a = e[o]; r = a.x * n - a.y * i, a.y = a.x * i + a.y * n, a.x = r; } }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(3), r = n(0), a = n(6), s = n(1), l = n(2); i.rectangle = function(e, t, n, i, s) { s = s || {}; var l = { label: "Rectangle Body", position: { x: e, y: t }, vertices: o.fromPath("L 0 0 L " + n + " 0 L " + n + " " + i + " L 0 " + i) }; if (s.chamfer) { var c = s.chamfer; l.vertices = o.chamfer(l.vertices, c.radius, c.quality, c.qualityMin, c.qualityMax), delete s.chamfer; } return a.create(r.extend({}, l, s)); }, i.trapezoid = function(e, t, n, i, s, l) { l = l || {}; var c, u = n * (s *= .5), d = u + (1 - 2 * s) * n, p = d + u; c = s < .5 ? "L 0 0 L " + u + " " + -i + " L " + d + " " + -i + " L " + p + " 0" : "L 0 0 L " + d + " " + -i + " L " + p + " 0"; var f = { label: "Trapezoid Body", position: { x: e, y: t }, vertices: o.fromPath(c) }; if (l.chamfer) { var v = l.chamfer; f.vertices = o.chamfer(f.vertices, v.radius, v.quality, v.qualityMin, v.qualityMax), delete l.chamfer; } return a.create(r.extend({}, f, l)); }, i.circle = function(e, t, n, o, a) { o = o || {}; var s = { label: "Circle Body", circleRadius: n }; a = a || 25; var l = Math.ceil(Math.max(10, Math.min(a, n))); return l % 2 == 1 && (l += 1), i.polygon(e, t, l, n, r.extend({}, s, o)); }, i.polygon = function(e, t, n, s, l) { if (l = l || {}, n < 3) return i.circle(e, t, s, l); for (var c = 2 * Math.PI / n, u = "", d = .5 * c, p = 0; p < n; p += 1) { var f = d + p * c, v = Math.cos(f) * s, y = Math.sin(f) * s; u += "L " + v.toFixed(3) + " " + y.toFixed(3) + " "; } var m = { label: "Polygon Body", position: { x: e, y: t }, vertices: o.fromPath(u) }; if (l.chamfer) { var g = l.chamfer; m.vertices = o.chamfer(m.vertices, g.radius, g.quality, g.qualityMin, g.qualityMax), delete l.chamfer; } return a.create(r.extend({}, m, l)); }, i.fromVertices = function(e, t, n, i, c, u, d, p) { var f, v, y, m, g, x, h, b, S, w, A = r.getDecomp(); for (f = Boolean(A && A.quickDecomp), i = i || {}, y = [], c = void 0 !== c && c, u = void 0 !== u ? u : .01, d = void 0 !== d ? d : 10, p = void 0 !== p ? p : .01, r.isArray(n[0]) || (n = [ n ]), S = 0; S < n.length; S += 1) if (g = n[S], !(m = o.isConvex(g)) && !f && r.warnOnce("Bodies.fromVertices: Install the 'poly-decomp' library and use Common.setDecomp or provide 'decomp' as a global to decompose concave vertices."), m || !f) g = m ? o.clockwiseSort(g) : o.hull(g), y.push({ position: { x: e, y: t }, vertices: g }); else { var P = g.map((function(e) { return [ e.x, e.y ]; })); A.makeCCW(P), !1 !== u && A.removeCollinearPoints(P, u), !1 !== p && A.removeDuplicatePoints && A.removeDuplicatePoints(P, p); var C = A.quickDecomp(P); for (x = 0; x < C.length; x++) { var M = C[x].map((function(e) { return { x: e[0], y: e[1] }; })); d > 0 && o.area(M) < d || y.push({ position: o.centre(M), vertices: M }); } } for (x = 0; x < y.length; x++) y[x] = a.create(r.extend(y[x], i)); if (c) for (x = 0; x < y.length; x++) { var B = y[x]; for (h = x + 1; h < y.length; h++) { var k = y[h]; if (s.overlaps(B.bounds, k.bounds)) { var _ = B.vertices, I = k.vertices; for (b = 0; b < B.vertices.length; b++) for (w = 0; w < k.vertices.length; w++) { var T = l.magnitudeSquared(l.sub(_[(b + 1) % _.length], I[w])), R = l.magnitudeSquared(l.sub(_[b], I[(w + 1) % I.length])); T < 5 && R < 5 && (_[b].isInternal = !0, I[w].isInternal = !0); } } } } return y.length > 1 ? (v = a.create(r.extend({ parts: y.slice(0) }, i)), a.setPosition(v, { x: e, y: t }), v) : y[0]; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(0); i.create = function(e) { var t = {}; return e || o.log("Mouse.create: element was undefined, defaulting to document.body", "warn"), t.element = e || document.body, t.absolute = { x: 0, y: 0 }, t.position = { x: 0, y: 0 }, t.mousedownPosition = { x: 0, y: 0 }, t.mouseupPosition = { x: 0, y: 0 }, t.offset = { x: 0, y: 0 }, t.scale = { x: 1, y: 1 }, t.wheelDelta = 0, t.button = -1, t.pixelRatio = parseInt(t.element.getAttribute("data-pixel-ratio"), 10) || 1, t.sourceEvents = { mousemove: null, mousedown: null, mouseup: null, mousewheel: null }, t.mousemove = function(e) { var n = i._getRelativeMousePosition(e, t.element, t.pixelRatio); e.changedTouches && (t.button = 0, e.preventDefault()), t.absolute.x = n.x, t.absolute.y = n.y, t.position.x = t.absolute.x * t.scale.x + t.offset.x, t.position.y = t.absolute.y * t.scale.y + t.offset.y, t.sourceEvents.mousemove = e; }, t.mousedown = function(e) { var n = i._getRelativeMousePosition(e, t.element, t.pixelRatio); e.changedTouches ? (t.button = 0, e.preventDefault()) : t.button = e.button, t.absolute.x = n.x, t.absolute.y = n.y, t.position.x = t.absolute.x * t.scale.x + t.offset.x, t.position.y = t.absolute.y * t.scale.y + t.offset.y, t.mousedownPosition.x = t.position.x, t.mousedownPosition.y = t.position.y, t.sourceEvents.mousedown = e; }, t.mouseup = function(e) { var n = i._getRelativeMousePosition(e, t.element, t.pixelRatio); e.changedTouches && e.preventDefault(), t.button = -1, t.absolute.x = n.x, t.absolute.y = n.y, t.position.x = t.absolute.x * t.scale.x + t.offset.x, t.position.y = t.absolute.y * t.scale.y + t.offset.y, t.mouseupPosition.x = t.position.x, t.mouseupPosition.y = t.position.y, t.sourceEvents.mouseup = e; }, t.mousewheel = function(e) { t.wheelDelta = Math.max(-1, Math.min(1, e.wheelDelta || -e.detail)), e.preventDefault(); }, i.setElement(t, t.element), t; }, i.setElement = function(e, t) { e.element = t, t.addEventListener("mousemove", e.mousemove), t.addEventListener("mousedown", e.mousedown), t.addEventListener("mouseup", e.mouseup), t.addEventListener("mousewheel", e.mousewheel), t.addEventListener("DOMMouseScroll", e.mousewheel), t.addEventListener("touchmove", e.mousemove), t.addEventListener("touchstart", e.mousedown), t.addEventListener("touchend", e.mouseup); }, i.clearSourceEvents = function(e) { e.sourceEvents.mousemove = null, e.sourceEvents.mousedown = null, e.sourceEvents.mouseup = null, e.sourceEvents.mousewheel = null, e.wheelDelta = 0; }, i.setOffset = function(e, t) { e.offset.x = t.x, e.offset.y = t.y, e.position.x = e.absolute.x * e.scale.x + e.offset.x, e.position.y = e.absolute.y * e.scale.y + e.offset.y; }, i.setScale = function(e, t) { e.scale.x = t.x, e.scale.y = t.y, e.position.x = e.absolute.x * e.scale.x + e.offset.x, e.position.y = e.absolute.y * e.scale.y + e.offset.y; }, i._getRelativeMousePosition = function(e, t, n) { var i, o, r = t.getBoundingClientRect(), a = document.documentElement || document.body.parentNode || document.body, s = void 0 !== window.pageXOffset ? window.pageXOffset : a.scrollLeft, l = void 0 !== window.pageYOffset ? window.pageYOffset : a.scrollTop, c = e.changedTouches; return c ? (i = c[0].pageX - r.left - s, o = c[0].pageY - r.top - l) : (i = e.pageX - r.left - s, o = e.pageY - r.top - l), { x: i / (t.clientWidth / (t.width || t.clientWidth) * n), y: o / (t.clientHeight / (t.height || t.clientHeight) * n) }; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(0), r = n(8); i.create = function(e) { return o.extend({ bodies: [], pairs: null }, e); }, i.setBodies = function(e, t) { e.bodies = t.slice(0); }, i.clear = function(e) { e.bodies = []; }, i.collisions = function(e) { var t, n, o = [], a = e.pairs, s = e.bodies, l = s.length, c = i.canCollide, u = r.collides; for (s.sort(i._compareBoundsX), t = 0; t < l; t++) { var d = s[t], p = d.bounds, f = d.bounds.max.x, v = d.bounds.max.y, y = d.bounds.min.y, m = d.isStatic || d.isSleeping, g = d.parts.length, x = 1 === g; for (n = t + 1; n < l; n++) { var h = s[n]; if ((B = h.bounds).min.x > f) break; if (!(v < B.min.y || y > B.max.y) && (!m || !h.isStatic && !h.isSleeping) && c(d.collisionFilter, h.collisionFilter)) { var b = h.parts.length; if (x && 1 === b) (C = u(d, h, a)) && o.push(C); else for (var S = b > 1 ? 1 : 0, w = g > 1 ? 1 : 0; w < g; w++) for (var A = d.parts[w], P = (p = A.bounds, S); P < b; P++) { var C, M = h.parts[P], B = M.bounds; p.min.x > B.max.x || p.max.x < B.min.x || p.max.y < B.min.y || p.min.y > B.max.y || (C = u(A, M, a)) && o.push(C); } } } } return o; }, i.canCollide = function(e, t) { return e.group === t.group && 0 !== e.group ? e.group > 0 : !!(e.mask & t.category) && !!(t.mask & e.category); }, i._compareBoundsX = function(e, t) { return e.bounds.min.x - t.bounds.min.x; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(0); i._registry = {}, i.register = function(e) { if (i.isPlugin(e) || o.warn("Plugin.register:", i.toString(e), "does not implement all required fields."), e.name in i._registry) { var t = i._registry[e.name], n = i.versionParse(e.version).number, r = i.versionParse(t.version).number; n > r ? (o.warn("Plugin.register:", i.toString(t), "was upgraded to", i.toString(e)), i._registry[e.name] = e) : n < r ? o.warn("Plugin.register:", i.toString(t), "can not be downgraded to", i.toString(e)) : e !== t && o.warn("Plugin.register:", i.toString(e), "is already registered to different plugin object"); } else i._registry[e.name] = e; return e; }, i.resolve = function(e) { return i._registry[i.dependencyParse(e).name]; }, i.toString = function(e) { return "string" == typeof e ? e : (e.name || "anonymous") + "@" + (e.version || e.range || "0.0.0"); }, i.isPlugin = function(e) { return e && e.name && e.version && e.install; }, i.isUsed = function(e, t) { return e.used.indexOf(t) > -1; }, i.isFor = function(e, t) { var n = e.for && i.dependencyParse(e.for); return !e.for || t.name === n.name && i.versionSatisfies(t.version, n.range); }, i.use = function(e, t) { if (e.uses = (e.uses || []).concat(t || []), 0 !== e.uses.length) { for (var n = i.dependencies(e), r = o.topologicalSort(n), a = [], s = 0; s < r.length; s += 1) if (r[s] !== e.name) { var l = i.resolve(r[s]); l ? i.isUsed(e, l.name) || (i.isFor(l, e) || (o.warn("Plugin.use:", i.toString(l), "is for", l.for, "but installed on", i.toString(e) + "."), l._warned = !0), l.install ? l.install(e) : (o.warn("Plugin.use:", i.toString(l), "does not specify an install function."), l._warned = !0), l._warned ? (a.push("🔶 " + i.toString(l)), delete l._warned) : a.push("✅ " + i.toString(l)), e.used.push(l.name)) : a.push("❌ " + r[s]); } a.length > 0 && o.info(a.join(" ")); } else o.warn("Plugin.use:", i.toString(e), "does not specify any dependencies to install."); }, i.dependencies = function(e, t) { var n = i.dependencyParse(e), r = n.name; if (!(r in (t = t || {}))) { e = i.resolve(e) || e, t[r] = o.map(e.uses || [], (function(t) { i.isPlugin(t) && i.register(t); var r = i.dependencyParse(t), a = i.resolve(t); return a && !i.versionSatisfies(a.version, r.range) ? (o.warn("Plugin.dependencies:", i.toString(a), "does not satisfy", i.toString(r), "used by", i.toString(n) + "."), a._warned = !0, e._warned = !0) : a || (o.warn("Plugin.dependencies:", i.toString(t), "used by", i.toString(n), "could not be resolved."), e._warned = !0), r.name; })); for (var a = 0; a < t[r].length; a += 1) i.dependencies(t[r][a], t); return t; } }, i.dependencyParse = function(e) { return o.isString(e) ? (/^[\w-]+(@(\*|[\^~]?\d+\.\d+\.\d+(-[0-9A-Za-z-+]+)?))?$/.test(e) || o.warn("Plugin.dependencyParse:", e, "is not a valid dependency string."), { name: e.split("@")[0], range: e.split("@")[1] || "*" }) : { name: e.name, range: e.range || e.version }; }, i.versionParse = function(e) { var t = /^(\*)|(\^|~|>=|>)?\s*((\d+)\.(\d+)\.(\d+))(-[0-9A-Za-z-+]+)?$/; t.test(e) || o.warn("Plugin.versionParse:", e, "is not a valid version or range."); var n = t.exec(e), i = Number(n[4]), r = Number(n[5]), a = Number(n[6]); return { isRange: Boolean(n[1] || n[2]), version: n[3], range: e, operator: n[1] || n[2] || "", major: i, minor: r, patch: a, parts: [ i, r, a ], prerelease: n[7], number: 1e8 * i + 1e4 * r + a }; }, i.versionSatisfies = function(e, t) { t = t || "*"; var n = i.versionParse(t), o = i.versionParse(e); if (n.isRange) { if ("*" === n.operator || "*" === e) return !0; if (">" === n.operator) return o.number > n.number; if (">=" === n.operator) return o.number >= n.number; if ("~" === n.operator) return o.major === n.major && o.minor === n.minor && o.patch >= n.patch; if ("^" === n.operator) return n.major > 0 ? o.major === n.major && o.number >= n.number : n.minor > 0 ? o.minor === n.minor && o.patch >= n.patch : o.patch === n.patch; } return e === t || "*" === e; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(0), r = n(5), a = n(1), s = n(4), l = n(2), c = n(13); !function() { var e, t; "undefined" != typeof window && (e = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.msRequestAnimationFrame || function(e) { window.setTimeout((function() { e(o.now()); }), 1e3 / 60); }, t = window.cancelAnimationFrame || window.mozCancelAnimationFrame || window.webkitCancelAnimationFrame || window.msCancelAnimationFrame), i._goodFps = 30, i._goodDelta = 1e3 / 60, i.create = function(e) { var t = { controller: i, engine: null, element: null, canvas: null, mouse: null, frameRequestId: null, timing: { historySize: 60, delta: 0, deltaHistory: [], lastTime: 0, lastTimestamp: 0, lastElapsed: 0, timestampElapsed: 0, timestampElapsedHistory: [], engineDeltaHistory: [], engineElapsedHistory: [], elapsedHistory: [] }, options: { width: 800, height: 600, pixelRatio: 1, background: "#14151f", wireframeBackground: "#14151f", hasBounds: !!e.bounds, enabled: !0, wireframes: !0, showSleeping: !0, showDebug: !1, showStats: !1, showPerformance: !1, showBounds: !1, showVelocity: !1, showCollisions: !1, showSeparations: !1, showAxes: !1, showPositions: !1, showAngleIndicator: !1, showIds: !1, showVertexNumbers: !1, showConvexHulls: !1, showInternalEdges: !1, showMousePosition: !1 } }, n = o.extend(t, e); return n.canvas && (n.canvas.width = n.options.width || n.canvas.width, n.canvas.height = n.options.height || n.canvas.height), n.mouse = e.mouse, n.engine = e.engine, n.canvas = n.canvas || d(n.options.width, n.options.height), n.context = n.canvas.getContext("2d"), n.textures = {}, n.bounds = n.bounds || { min: { x: 0, y: 0 }, max: { x: n.canvas.width, y: n.canvas.height } }, n.options.showBroadphase = !1, 1 !== n.options.pixelRatio && i.setPixelRatio(n, n.options.pixelRatio), o.isElement(n.element) ? n.element.appendChild(n.canvas) : n.canvas.parentNode || o.log("Render.create: options.element was undefined, render.canvas was created but not appended", "warn"), n; }, i.run = function(t) { !function o(r) { t.frameRequestId = e(o), n(t, r), i.world(t, r), (t.options.showStats || t.options.showDebug) && i.stats(t, t.context, r), (t.options.showPerformance || t.options.showDebug) && i.performance(t, t.context, r); }(); }, i.stop = function(e) { t(e.frameRequestId); }, i.setPixelRatio = function(e, t) { var n = e.options, i = e.canvas; "auto" === t && (t = p(i)), n.pixelRatio = t, i.setAttribute("data-pixel-ratio", t), i.width = n.width * t, i.height = n.height * t, i.style.width = n.width + "px", i.style.height = n.height + "px"; }, i.lookAt = function(e, t, n, i) { i = void 0 === i || i, t = o.isArray(t) ? t : [ t ], n = n || { x: 0, y: 0 }; for (var r = { min: { x: 1 / 0, y: 1 / 0 }, max: { x: -1 / 0, y: -1 / 0 } }, a = 0; a < t.length; a += 1) { var s = t[a], l = s.bounds ? s.bounds.min : s.min || s.position || s, u = s.bounds ? s.bounds.max : s.max || s.position || s; l && u && (l.x < r.min.x && (r.min.x = l.x), u.x > r.max.x && (r.max.x = u.x), l.y < r.min.y && (r.min.y = l.y), u.y > r.max.y && (r.max.y = u.y)); } var d = r.max.x - r.min.x + 2 * n.x, p = r.max.y - r.min.y + 2 * n.y, f = e.canvas.height, v = e.canvas.width / f, y = d / p, m = 1, g = 1; y > v ? g = y / v : m = v / y, e.options.hasBounds = !0, e.bounds.min.x = r.min.x, e.bounds.max.x = r.min.x + d * m, e.bounds.min.y = r.min.y, e.bounds.max.y = r.min.y + p * g, i && (e.bounds.min.x += .5 * d - d * m * .5, e.bounds.max.x += .5 * d - d * m * .5, e.bounds.min.y += .5 * p - p * g * .5, e.bounds.max.y += .5 * p - p * g * .5), e.bounds.min.x -= n.x, e.bounds.max.x -= n.x, e.bounds.min.y -= n.y, e.bounds.max.y -= n.y, e.mouse && (c.setScale(e.mouse, { x: (e.bounds.max.x - e.bounds.min.x) / e.canvas.width, y: (e.bounds.max.y - e.bounds.min.y) / e.canvas.height }), c.setOffset(e.mouse, e.bounds.min)); }, i.startViewTransform = function(e) { var t = e.bounds.max.x - e.bounds.min.x, n = e.bounds.max.y - e.bounds.min.y, i = t / e.options.width, o = n / e.options.height; e.context.setTransform(e.options.pixelRatio / i, 0, 0, e.options.pixelRatio / o, 0, 0), e.context.translate(-e.bounds.min.x, -e.bounds.min.y); }, i.endViewTransform = function(e) { e.context.setTransform(e.options.pixelRatio, 0, 0, e.options.pixelRatio, 0, 0); }, i.world = function(e, t) { var n, u = o.now(), d = e.engine, p = d.world, f = e.canvas, y = e.context, m = e.options, g = e.timing, x = r.allBodies(p), h = r.allConstraints(p), b = m.wireframes ? m.wireframeBackground : m.background, S = [], w = [], A = { timestamp: d.timing.timestamp }; if (s.trigger(e, "beforeRender", A), e.currentBackground !== b && v(e, b), y.globalCompositeOperation = "source-in", y.fillStyle = "transparent", y.fillRect(0, 0, f.width, f.height), y.globalCompositeOperation = "source-over", m.hasBounds) { for (n = 0; n < x.length; n++) { var P = x[n]; a.overlaps(P.bounds, e.bounds) && S.push(P); } for (n = 0; n < h.length; n++) { var C = h[n], M = C.bodyA, B = C.bodyB, k = C.pointA, _ = C.pointB; M && (k = l.add(M.position, C.pointA)), B && (_ = l.add(B.position, C.pointB)), k && _ && (a.contains(e.bounds, k) || a.contains(e.bounds, _)) && w.push(C); } i.startViewTransform(e), e.mouse && (c.setScale(e.mouse, { x: (e.bounds.max.x - e.bounds.min.x) / e.options.width, y: (e.bounds.max.y - e.bounds.min.y) / e.options.height }), c.setOffset(e.mouse, e.bounds.min)); } else w = h, S = x, 1 !== e.options.pixelRatio && e.context.setTransform(e.options.pixelRatio, 0, 0, e.options.pixelRatio, 0, 0); !m.wireframes || d.enableSleeping && m.showSleeping ? i.bodies(e, S, y) : (m.showConvexHulls && i.bodyConvexHulls(e, S, y), i.bodyWireframes(e, S, y)), m.showBounds && i.bodyBounds(e, S, y), (m.showAxes || m.showAngleIndicator) && i.bodyAxes(e, S, y), m.showPositions && i.bodyPositions(e, S, y), m.showVelocity && i.bodyVelocity(e, S, y), m.showIds && i.bodyIds(e, S, y), m.showSeparations && i.separations(e, d.pairs.list, y), m.showCollisions && i.collisions(e, d.pairs.list, y), m.showVertexNumbers && i.vertexNumbers(e, S, y), m.showMousePosition && i.mousePosition(e, e.mouse, y), i.constraints(w, y), m.hasBounds && i.endViewTransform(e), s.trigger(e, "afterRender", A), g.lastElapsed = o.now() - u; }, i.stats = function(e, t, n) { for (var i = e.engine, o = i.world, a = r.allBodies(o), s = 0, l = 0, c = 0; c < a.length; c += 1) s += a[c].parts.length; var u = { Part: s, Body: a.length, Cons: r.allConstraints(o).length, Comp: r.allComposites(o).length, Pair: i.pairs.list.length }; for (var d in t.fillStyle = "#0e0f19", t.fillRect(l, 0, 302.5, 44), t.font = "12px Arial", t.textBaseline = "top", t.textAlign = "right", u) { var p = u[d]; t.fillStyle = "#aaa", t.fillText(d, l + 55, 8), t.fillStyle = "#eee", t.fillText(p, l + 55, 26), l += 55; } }, i.performance = function(e, t) { var n = e.engine, o = e.timing, r = o.deltaHistory, a = o.elapsedHistory, s = o.timestampElapsedHistory, l = o.engineDeltaHistory, c = o.engineElapsedHistory, d = n.timing.lastDelta, p = u(r), f = u(a), v = u(l), y = u(c), m = u(s) / p || 0, g = 1e3 / p || 0; t.fillStyle = "#0e0f19", t.fillRect(0, 50, 370, 34), i.status(t, 10, 69, 60, 4, r.length, Math.round(g) + " fps", g / i._goodFps, (function(e) { return r[e] / p - 1; })), i.status(t, 82, 69, 60, 4, l.length, d.toFixed(2) + " dt", i._goodDelta / d, (function(e) { return l[e] / v - 1; })), i.status(t, 154, 69, 60, 4, c.length, y.toFixed(2) + " ut", 1 - y / i._goodFps, (function(e) { return c[e] / y - 1; })), i.status(t, 226, 69, 60, 4, a.length, f.toFixed(2) + " rt", 1 - f / i._goodFps, (function(e) { return a[e] / f - 1; })), i.status(t, 298, 69, 60, 4, s.length, m.toFixed(2) + " x", m * m * m, (function(e) { return (s[e] / r[e] / m || 0) - 1; })); }, i.status = function(e, t, n, i, r, a, s, l, c) { e.strokeStyle = "#888", e.fillStyle = "#444", e.lineWidth = 1, e.fillRect(t, n + 7, i, 1), e.beginPath(), e.moveTo(t, n + 7 - r * o.clamp(.4 * c(0), -2, 2)); for (var u = 0; u < i; u += 1) e.lineTo(t + u, n + 7 - (u < a ? r * o.clamp(.4 * c(u), -2, 2) : 0)); e.stroke(), e.fillStyle = "hsl(" + o.clamp(25 + 95 * l, 0, 120) + ",100%,60%)", e.fillRect(t, n - 7, 4, 4), e.font = "12px Arial", e.textBaseline = "middle", e.textAlign = "right", e.fillStyle = "#eee", e.fillText(s, t + i, n - 5); }, i.constraints = function(e, t) { for (var n = t, i = 0; i < e.length; i++) { var r = e[i]; if (r.render.visible && r.pointA && r.pointB) { var a, s, c = r.bodyA, u = r.bodyB; if (a = c ? l.add(c.position, r.pointA) : r.pointA, "pin" === r.render.type) n.beginPath(), n.arc(a.x, a.y, 3, 0, 2 * Math.PI), n.closePath(); else { if (s = u ? l.add(u.position, r.pointB) : r.pointB, n.beginPath(), n.moveTo(a.x, a.y), "spring" === r.render.type) for (var d, p = l.sub(s, a), f = l.perp(l.normalise(p)), v = Math.ceil(o.clamp(r.length / 5, 12, 20)), y = 1; y < v; y += 1) d = y % 2 == 0 ? 1 : -1, n.lineTo(a.x + p.x * (y / v) + f.x * d * 4, a.y + p.y * (y / v) + f.y * d * 4); n.lineTo(s.x, s.y); } r.render.lineWidth && (n.lineWidth = r.render.lineWidth, n.strokeStyle = r.render.strokeStyle, n.stroke()), r.render.anchors && (n.fillStyle = r.render.strokeStyle, n.beginPath(), n.arc(a.x, a.y, 3, 0, 2 * Math.PI), n.arc(s.x, s.y, 3, 0, 2 * Math.PI), n.closePath(), n.fill()); } } }, i.bodies = function(e, t, n) { var i, o, r, a, s = n, l = (e.engine, e.options), c = l.showInternalEdges || !l.wireframes; for (r = 0; r < t.length; r++) if ((i = t[r]).render.visible) for (a = i.parts.length > 1 ? 1 : 0; a < i.parts.length; a++) if ((o = i.parts[a]).render.visible) { if (l.showSleeping && i.isSleeping ? s.globalAlpha = .5 * o.render.opacity : 1 !== o.render.opacity && (s.globalAlpha = o.render.opacity), o.render.sprite && o.render.sprite.texture && !l.wireframes) { var u = o.render.sprite, d = f(e, u.texture); s.translate(o.position.x, o.position.y), s.rotate(o.angle), s.drawImage(d, d.width * -u.xOffset * u.xScale, d.height * -u.yOffset * u.yScale, d.width * u.xScale, d.height * u.yScale), s.rotate(-o.angle), s.translate(-o.position.x, -o.position.y); } else { if (o.circleRadius) s.beginPath(), s.arc(o.position.x, o.position.y, o.circleRadius, 0, 2 * Math.PI); else { s.beginPath(), s.moveTo(o.vertices[0].x, o.vertices[0].y); for (var p = 1; p < o.vertices.length; p++) !o.vertices[p - 1].isInternal || c ? s.lineTo(o.vertices[p].x, o.vertices[p].y) : s.moveTo(o.vertices[p].x, o.vertices[p].y), o.vertices[p].isInternal && !c && s.moveTo(o.vertices[(p + 1) % o.vertices.length].x, o.vertices[(p + 1) % o.vertices.length].y); s.lineTo(o.vertices[0].x, o.vertices[0].y), s.closePath(); } l.wireframes ? (s.lineWidth = 1, s.strokeStyle = "#bbb", s.stroke()) : (s.fillStyle = o.render.fillStyle, o.render.lineWidth && (s.lineWidth = o.render.lineWidth, s.strokeStyle = o.render.strokeStyle, s.stroke()), s.fill()); } s.globalAlpha = 1; } }, i.bodyWireframes = function(e, t, n) { var i, o, r, a, s, l = n, c = e.options.showInternalEdges; for (l.beginPath(), r = 0; r < t.length; r++) if ((i = t[r]).render.visible) for (s = i.parts.length > 1 ? 1 : 0; s < i.parts.length; s++) { for (o = i.parts[s], l.moveTo(o.vertices[0].x, o.vertices[0].y), a = 1; a < o.vertices.length; a++) !o.vertices[a - 1].isInternal || c ? l.lineTo(o.vertices[a].x, o.vertices[a].y) : l.moveTo(o.vertices[a].x, o.vertices[a].y), o.vertices[a].isInternal && !c && l.moveTo(o.vertices[(a + 1) % o.vertices.length].x, o.vertices[(a + 1) % o.vertices.length].y); l.lineTo(o.vertices[0].x, o.vertices[0].y); } l.lineWidth = 1, l.strokeStyle = "#bbb", l.stroke(); }, i.bodyConvexHulls = function(e, t, n) { var i, o, r, a = n; for (a.beginPath(), o = 0; o < t.length; o++) if ((i = t[o]).render.visible && 1 !== i.parts.length) { for (a.moveTo(i.vertices[0].x, i.vertices[0].y), r = 1; r < i.vertices.length; r++) a.lineTo(i.vertices[r].x, i.vertices[r].y); a.lineTo(i.vertices[0].x, i.vertices[0].y); } a.lineWidth = 1, a.strokeStyle = "rgba(255,255,255,0.2)", a.stroke(); }, i.vertexNumbers = function(e, t, n) { var i, o, r, a = n; for (i = 0; i < t.length; i++) { var s = t[i].parts; for (r = s.length > 1 ? 1 : 0; r < s.length; r++) { var l = s[r]; for (o = 0; o < l.vertices.length; o++) a.fillStyle = "rgba(255,255,255,0.2)", a.fillText(i + "_" + o, l.position.x + .8 * (l.vertices[o].x - l.position.x), l.position.y + .8 * (l.vertices[o].y - l.position.y)); } } }, i.mousePosition = function(e, t, n) { var i = n; i.fillStyle = "rgba(255,255,255,0.8)", i.fillText(t.position.x + " " + t.position.y, t.position.x + 5, t.position.y - 5); }, i.bodyBounds = function(e, t, n) { var i = n, o = (e.engine, e.options); i.beginPath(); for (var r = 0; r < t.length; r++) if (t[r].render.visible) for (var a = t[r].parts, s = a.length > 1 ? 1 : 0; s < a.length; s++) { var l = a[s]; i.rect(l.bounds.min.x, l.bounds.min.y, l.bounds.max.x - l.bounds.min.x, l.bounds.max.y - l.bounds.min.y); } o.wireframes ? i.strokeStyle = "rgba(255,255,255,0.08)" : i.strokeStyle = "rgba(0,0,0,0.1)", i.lineWidth = 1, i.stroke(); }, i.bodyAxes = function(e, t, n) { var i, o, r, a, s = n, l = (e.engine, e.options); for (s.beginPath(), o = 0; o < t.length; o++) { var c = t[o], u = c.parts; if (c.render.visible) if (l.showAxes) for (r = u.length > 1 ? 1 : 0; r < u.length; r++) for (i = u[r], a = 0; a < i.axes.length; a++) { var d = i.axes[a]; s.moveTo(i.position.x, i.position.y), s.lineTo(i.position.x + 20 * d.x, i.position.y + 20 * d.y); } else for (r = u.length > 1 ? 1 : 0; r < u.length; r++) for (i = u[r], a = 0; a < i.axes.length; a++) s.moveTo(i.position.x, i.position.y), s.lineTo((i.vertices[0].x + i.vertices[i.vertices.length - 1].x) / 2, (i.vertices[0].y + i.vertices[i.vertices.length - 1].y) / 2); } l.wireframes ? (s.strokeStyle = "indianred", s.lineWidth = 1) : (s.strokeStyle = "rgba(255, 255, 255, 0.4)", s.globalCompositeOperation = "overlay", s.lineWidth = 2), s.stroke(), s.globalCompositeOperation = "source-over"; }, i.bodyPositions = function(e, t, n) { var i, o, r, a, s = n, l = (e.engine, e.options); for (s.beginPath(), r = 0; r < t.length; r++) if ((i = t[r]).render.visible) for (a = 0; a < i.parts.length; a++) o = i.parts[a], s.arc(o.position.x, o.position.y, 3, 0, 2 * Math.PI, !1), s.closePath(); for (l.wireframes ? s.fillStyle = "indianred" : s.fillStyle = "rgba(0,0,0,0.5)", s.fill(), s.beginPath(), r = 0; r < t.length; r++) (i = t[r]).render.visible && (s.arc(i.positionPrev.x, i.positionPrev.y, 2, 0, 2 * Math.PI, !1), s.closePath()); s.fillStyle = "rgba(255,165,0,0.8)", s.fill(); }, i.bodyVelocity = function(e, t, n) { var i = n; i.beginPath(); for (var o = 0; o < t.length; o++) { var r = t[o]; r.render.visible && (i.moveTo(r.position.x, r.position.y), i.lineTo(r.position.x + 2 * (r.position.x - r.positionPrev.x), r.position.y + 2 * (r.position.y - r.positionPrev.y))); } i.lineWidth = 3, i.strokeStyle = "cornflowerblue", i.stroke(); }, i.bodyIds = function(e, t, n) { var i, o, r = n; for (i = 0; i < t.length; i++) if (t[i].render.visible) { var a = t[i].parts; for (o = a.length > 1 ? 1 : 0; o < a.length; o++) { var s = a[o]; r.font = "12px Arial", r.fillStyle = "rgba(255,255,255,0.5)", r.fillText(s.id, s.position.x + 10, s.position.y - 10); } } }, i.collisions = function(e, t, n) { var i, o, r, a, s = n, l = e.options; for (s.beginPath(), r = 0; r < t.length; r++) if ((i = t[r]).isActive) for (o = i.collision, a = 0; a < i.activeContacts.length; a++) { var c = i.activeContacts[a].vertex; s.rect(c.x - 1.5, c.y - 1.5, 3.5, 3.5); } for (l.wireframes ? s.fillStyle = "rgba(255,255,255,0.7)" : s.fillStyle = "orange", s.fill(), s.beginPath(), r = 0; r < t.length; r++) if ((i = t[r]).isActive && (o = i.collision, i.activeContacts.length > 0)) { var u = i.activeContacts[0].vertex.x, d = i.activeContacts[0].vertex.y; 2 === i.activeContacts.length && (u = (i.activeContacts[0].vertex.x + i.activeContacts[1].vertex.x) / 2, d = (i.activeContacts[0].vertex.y + i.activeContacts[1].vertex.y) / 2), o.bodyB === o.supports[0].body || !0 === o.bodyA.isStatic ? s.moveTo(u - 8 * o.normal.x, d - 8 * o.normal.y) : s.moveTo(u + 8 * o.normal.x, d + 8 * o.normal.y), s.lineTo(u, d); } l.wireframes ? s.strokeStyle = "rgba(255,165,0,0.7)" : s.strokeStyle = "orange", s.lineWidth = 1, s.stroke(); }, i.separations = function(e, t, n) { var i, o, r, a, s, l = n, c = e.options; for (l.beginPath(), s = 0; s < t.length; s++) if ((i = t[s]).isActive) { r = (o = i.collision).bodyA; var u = 1; (a = o.bodyB).isStatic || r.isStatic || (u = .5), a.isStatic && (u = 0), l.moveTo(a.position.x, a.position.y), l.lineTo(a.position.x - o.penetration.x * u, a.position.y - o.penetration.y * u), u = 1, a.isStatic || r.isStatic || (u = .5), r.isStatic && (u = 0), l.moveTo(r.position.x, r.position.y), l.lineTo(r.position.x + o.penetration.x * u, r.position.y + o.penetration.y * u); } c.wireframes ? l.strokeStyle = "rgba(255,165,0,0.5)" : l.strokeStyle = "orange", l.stroke(); }, i.inspector = function(e, t) { e.engine; var n, i = e.selected, o = e.render, r = o.options; if (r.hasBounds) { var a = o.bounds.max.x - o.bounds.min.x, s = o.bounds.max.y - o.bounds.min.y, l = a / o.options.width, c = s / o.options.height; t.scale(1 / l, 1 / c), t.translate(-o.bounds.min.x, -o.bounds.min.y); } for (var u = 0; u < i.length; u++) { var d = i[u].data; switch (t.translate(.5, .5), t.lineWidth = 1, t.strokeStyle = "rgba(255,165,0,0.9)", t.setLineDash([ 1, 2 ]), d.type) { case "body": n = d.bounds, t.beginPath(), t.rect(Math.floor(n.min.x - 3), Math.floor(n.min.y - 3), Math.floor(n.max.x - n.min.x + 6), Math.floor(n.max.y - n.min.y + 6)), t.closePath(), t.stroke(); break; case "constraint": var p = d.pointA; d.bodyA && (p = d.pointB), t.beginPath(), t.arc(p.x, p.y, 10, 0, 2 * Math.PI), t.closePath(), t.stroke(); } t.setLineDash([]), t.translate(-.5, -.5); } null !== e.selectStart && (t.translate(.5, .5), t.lineWidth = 1, t.strokeStyle = "rgba(255,165,0,0.6)", t.fillStyle = "rgba(255,165,0,0.1)", n = e.selectBounds, t.beginPath(), t.rect(Math.floor(n.min.x), Math.floor(n.min.y), Math.floor(n.max.x - n.min.x), Math.floor(n.max.y - n.min.y)), t.closePath(), t.stroke(), t.fill(), t.translate(-.5, -.5)), r.hasBounds && t.setTransform(1, 0, 0, 1, 0, 0); }; var n = function(e, t) { var n = e.engine, o = e.timing, r = o.historySize, a = n.timing.timestamp; o.delta = t - o.lastTime || i._goodDelta, o.lastTime = t, o.timestampElapsed = a - o.lastTimestamp || 0, o.lastTimestamp = a, o.deltaHistory.unshift(o.delta), o.deltaHistory.length = Math.min(o.deltaHistory.length, r), o.engineDeltaHistory.unshift(n.timing.lastDelta), o.engineDeltaHistory.length = Math.min(o.engineDeltaHistory.length, r), o.timestampElapsedHistory.unshift(o.timestampElapsed), o.timestampElapsedHistory.length = Math.min(o.timestampElapsedHistory.length, r), o.engineElapsedHistory.unshift(n.timing.lastElapsed), o.engineElapsedHistory.length = Math.min(o.engineElapsedHistory.length, r), o.elapsedHistory.unshift(o.lastElapsed), o.elapsedHistory.length = Math.min(o.elapsedHistory.length, r); }, u = function(e) { for (var t = 0, n = 0; n < e.length; n += 1) t += e[n]; return t / e.length || 0; }, d = function(e, t) { var n = document.createElement("canvas"); return n.width = e, n.height = t, n.oncontextmenu = function() { return !1; }, n.onselectstart = function() { return !1; }, n; }, p = function(e) { var t = e.getContext("2d"); return (window.devicePixelRatio || 1) / (t.webkitBackingStorePixelRatio || t.mozBackingStorePixelRatio || t.msBackingStorePixelRatio || t.oBackingStorePixelRatio || t.backingStorePixelRatio || 1); }, f = function(e, t) { var n = e.textures[t]; return n || ((n = e.textures[t] = new Image).src = t, n); }, v = function(e, t) { var n = t; /(jpg|gif|png)$/.test(t) && (n = "url(" + t + ")"), e.canvas.style.background = n, e.canvas.style.backgroundSize = "contain", e.currentBackground = t; }; }(); }, function(e, t) { var n = {}; e.exports = n, n.create = function(e) { return { vertex: e, normalImpulse: 0, tangentImpulse: 0 }; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(7), r = n(19), a = n(14), s = n(20), l = n(4), c = n(5), u = n(10), d = n(0), p = n(6); i.create = function(e) { e = e || {}; var t = d.extend({ positionIterations: 6, velocityIterations: 4, constraintIterations: 2, enableSleeping: !1, events: [], plugin: {}, gravity: { x: 0, y: 1, scale: .001 }, timing: { timestamp: 0, timeScale: 1, lastDelta: 0, lastElapsed: 0 } }, e); return t.world = e.world || c.create({ label: "World" }), t.pairs = e.pairs || s.create(), t.detector = e.detector || a.create(), t.grid = { buckets: [] }, t.world.gravity = t.gravity, t.broadphase = t.grid, t.metrics = {}, t; }, i.update = function(e, t, n) { var p = d.now(); t = t || 1e3 / 60, n = n || 1; var f, v = e.world, y = e.detector, m = e.pairs, g = e.timing, x = g.timestamp; g.timestamp += t * g.timeScale, g.lastDelta = t * g.timeScale; var h = { timestamp: g.timestamp }; l.trigger(e, "beforeUpdate", h); var b = c.allBodies(v), S = c.allConstraints(v); for (v.isModified && a.setBodies(y, b), v.isModified && c.setModified(v, !1, !1, !0), e.enableSleeping && o.update(b, g.timeScale), i._bodiesApplyGravity(b, e.gravity), i._bodiesUpdate(b, t, g.timeScale, n, v.bounds), u.preSolveAll(b), f = 0; f < e.constraintIterations; f++) u.solveAll(S, g.timeScale); u.postSolveAll(b), y.pairs = e.pairs; var w = a.collisions(y); for (s.update(m, w, x), e.enableSleeping && o.afterCollisions(m.list, g.timeScale), m.collisionStart.length > 0 && l.trigger(e, "collisionStart", { pairs: m.collisionStart }), r.preSolvePosition(m.list), f = 0; f < e.positionIterations; f++) r.solvePosition(m.list, g.timeScale); for (r.postSolvePosition(b), u.preSolveAll(b), f = 0; f < e.constraintIterations; f++) u.solveAll(S, g.timeScale); for (u.postSolveAll(b), r.preSolveVelocity(m.list), f = 0; f < e.velocityIterations; f++) r.solveVelocity(m.list, g.timeScale); return m.collisionActive.length > 0 && l.trigger(e, "collisionActive", { pairs: m.collisionActive }), m.collisionEnd.length > 0 && l.trigger(e, "collisionEnd", { pairs: m.collisionEnd }), i._bodiesClearForces(b), l.trigger(e, "afterUpdate", h), e.timing.lastElapsed = d.now() - p, e; }, i.merge = function(e, t) { if (d.extend(e, t), t.world) { e.world = t.world, i.clear(e); for (var n = c.allBodies(e.world), r = 0; r < n.length; r++) { var a = n[r]; o.set(a, !1), a.id = d.nextId(); } } }, i.clear = function(e) { s.clear(e.pairs), a.clear(e.detector); }, i._bodiesClearForces = function(e) { for (var t = 0; t < e.length; t++) { var n = e[t]; n.force.x = 0, n.force.y = 0, n.torque = 0; } }, i._bodiesApplyGravity = function(e, t) { var n = void 0 !== t.scale ? t.scale : .001; if ((0 !== t.x || 0 !== t.y) && 0 !== n) for (var i = 0; i < e.length; i++) { var o = e[i]; o.isStatic || o.isSleeping || (o.force.y += o.mass * t.y * n, o.force.x += o.mass * t.x * n); } }, i._bodiesUpdate = function(e, t, n, i, o) { for (var r = 0; r < e.length; r++) { var a = e[r]; a.isStatic || a.isSleeping || p.update(a, t, n, i); } }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(3), r = n(1); i._restingThresh = 4, i._restingThreshTangent = 6, i._positionDampen = .9, i._positionWarming = .8, i._frictionNormalMultiplier = 5, i.preSolvePosition = function(e) { var t, n, i, o = e.length; for (t = 0; t < o; t++) (n = e[t]).isActive && (i = n.activeContacts.length, n.collision.parentA.totalContacts += i, n.collision.parentB.totalContacts += i); }, i.solvePosition = function(e, t) { var n, o, r, a, s, l, c, u, d = i._positionDampen, p = e.length; for (n = 0; n < p; n++) (o = e[n]).isActive && !o.isSensor && (a = (r = o.collision).parentA, s = r.parentB, l = r.normal, o.separation = l.x * (s.positionImpulse.x + r.penetration.x - a.positionImpulse.x) + l.y * (s.positionImpulse.y + r.penetration.y - a.positionImpulse.y)); for (n = 0; n < p; n++) (o = e[n]).isActive && !o.isSensor && (a = (r = o.collision).parentA, s = r.parentB, l = r.normal, u = (o.separation - o.slop) * t, (a.isStatic || s.isStatic) && (u *= 2), a.isStatic || a.isSleeping || (c = d / a.totalContacts, a.positionImpulse.x += l.x * u * c, a.positionImpulse.y += l.y * u * c), s.isStatic || s.isSleeping || (c = d / s.totalContacts, s.positionImpulse.x -= l.x * u * c, s.positionImpulse.y -= l.y * u * c)); }, i.postSolvePosition = function(e) { for (var t = i._positionWarming, n = e.length, a = o.translate, s = r.update, l = 0; l < n; l++) { var c = e[l], u = c.positionImpulse, d = u.x, p = u.y, f = c.velocity; if (c.totalContacts = 0, 0 !== d || 0 !== p) { for (var v = 0; v < c.parts.length; v++) { var y = c.parts[v]; a(y.vertices, u), s(y.bounds, y.vertices, f), y.position.x += d, y.position.y += p; } c.positionPrev.x += d, c.positionPrev.y += p, d * f.x + p * f.y < 0 ? (u.x = 0, u.y = 0) : (u.x *= t, u.y *= t); } } }, i.preSolveVelocity = function(e) { var t, n, i = e.length; for (t = 0; t < i; t++) { var o = e[t]; if (o.isActive && !o.isSensor) { var r = o.activeContacts, a = r.length, s = o.collision, l = s.parentA, c = s.parentB, u = s.normal, d = s.tangent; for (n = 0; n < a; n++) { var p = r[n], f = p.vertex, v = p.normalImpulse, y = p.tangentImpulse; if (0 !== v || 0 !== y) { var m = u.x * v + d.x * y, g = u.y * v + d.y * y; l.isStatic || l.isSleeping || (l.positionPrev.x += m * l.inverseMass, l.positionPrev.y += g * l.inverseMass, l.anglePrev += l.inverseInertia * ((f.x - l.position.x) * g - (f.y - l.position.y) * m)), c.isStatic || c.isSleeping || (c.positionPrev.x -= m * c.inverseMass, c.positionPrev.y -= g * c.inverseMass, c.anglePrev -= c.inverseInertia * ((f.x - c.position.x) * g - (f.y - c.position.y) * m)); } } } } }, i.solveVelocity = function(e, t) { var n, o, r, a, s = t * t, l = i._restingThresh * s, c = i._frictionNormalMultiplier, u = i._restingThreshTangent * s, d = Number.MAX_VALUE, p = e.length; for (r = 0; r < p; r++) { var f = e[r]; if (f.isActive && !f.isSensor) { var v = f.collision, y = v.parentA, m = v.parentB, g = y.velocity, x = m.velocity, h = v.normal.x, b = v.normal.y, S = v.tangent.x, w = v.tangent.y, A = f.activeContacts, P = A.length, C = 1 / P, M = y.inverseMass + m.inverseMass, B = f.friction * f.frictionStatic * c * s; for (g.x = y.position.x - y.positionPrev.x, g.y = y.position.y - y.positionPrev.y, x.x = m.position.x - m.positionPrev.x, x.y = m.position.y - m.positionPrev.y, y.angularVelocity = y.angle - y.anglePrev, m.angularVelocity = m.angle - m.anglePrev, a = 0; a < P; a++) { var k = A[a], _ = k.vertex, I = _.x - y.position.x, T = _.y - y.position.y, R = _.x - m.position.x, E = _.y - m.position.y, V = g.x - T * y.angularVelocity, L = g.y + I * y.angularVelocity, O = V - (x.x - E * m.angularVelocity), D = L - (x.y + R * m.angularVelocity), F = h * O + b * D, H = S * O + w * D, j = f.separation + F, q = Math.min(j, 1), W = (q = j < 0 ? 0 : q) * B; H > W || -H > W ? (o = H > 0 ? H : -H, (n = f.friction * (H > 0 ? 1 : -1) * s) < -o ? n = -o : n > o && (n = o)) : (n = H, o = d); var G = I * b - T * h, N = R * b - E * h, U = C / (M + y.inverseInertia * G * G + m.inverseInertia * N * N), z = (1 + f.restitution) * F * U; if (n *= U, F * F > l && F < 0) k.normalImpulse = 0; else { var X = k.normalImpulse; k.normalImpulse += z, k.normalImpulse = Math.min(k.normalImpulse, 0), z = k.normalImpulse - X; } if (H * H > u) k.tangentImpulse = 0; else { var Q = k.tangentImpulse; k.tangentImpulse += n, k.tangentImpulse < -o && (k.tangentImpulse = -o), k.tangentImpulse > o && (k.tangentImpulse = o), n = k.tangentImpulse - Q; } var Y = h * z + S * n, Z = b * z + w * n; y.isStatic || y.isSleeping || (y.positionPrev.x += Y * y.inverseMass, y.positionPrev.y += Z * y.inverseMass, y.anglePrev += (I * Z - T * Y) * y.inverseInertia), m.isStatic || m.isSleeping || (m.positionPrev.x -= Y * m.inverseMass, m.positionPrev.y -= Z * m.inverseMass, m.anglePrev -= (R * Z - E * Y) * m.inverseInertia); } } } }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(9), r = n(0); i.create = function(e) { return r.extend({ table: {}, list: [], collisionStart: [], collisionActive: [], collisionEnd: [] }, e); }, i.update = function(e, t, n) { var i, r, a, s, l = e.list, c = l.length, u = e.table, d = t.length, p = e.collisionStart, f = e.collisionEnd, v = e.collisionActive; for (p.length = 0, f.length = 0, v.length = 0, s = 0; s < c; s++) l[s].confirmedActive = !1; for (s = 0; s < d; s++) (a = (i = t[s]).pair) ? (a.isActive ? v.push(a) : p.push(a), o.update(a, i, n), a.confirmedActive = !0) : (u[(a = o.create(i, n)).id] = a, p.push(a), l.push(a)); var y = []; for (c = l.length, s = 0; s < c; s++) (a = l[s]).confirmedActive || (o.setActive(a, !1, n), f.push(a), a.collision.bodyA.isSleeping || a.collision.bodyB.isSleeping || y.push(s)); for (s = 0; s < y.length; s++) a = l[r = y[s] - s], l.splice(r, 1), delete u[a.id]; }, i.clear = function(e) { return e.table = {}, e.list.length = 0, e.collisionStart.length = 0, e.collisionActive.length = 0, e.collisionEnd.length = 0, e; }; }, function(e, t, n) { var i = e.exports = n(22); i.Axes = n(11), i.Bodies = n(12), i.Body = n(6), i.Bounds = n(1), i.Collision = n(8), i.Common = n(0), i.Composite = n(5), i.Composites = n(23), i.Constraint = n(10), i.Contact = n(17), i.Detector = n(14), i.Engine = n(18), i.Events = n(4), i.Grid = n(24), i.Mouse = n(13), i.MouseConstraint = n(25), i.Pair = n(9), i.Pairs = n(20), i.Plugin = n(15), i.Query = n(26), i.Render = n(16), i.Resolver = n(19), i.Runner = n(27), i.SAT = n(28), i.Sleeping = n(7), i.Svg = n(29), i.Vector = n(2), i.Vertices = n(3), i.World = n(30), i.Engine.run = i.Runner.run, i.Common.deprecated(i.Engine, "run", "Engine.run ➤ use Matter.Runner.run(engine) instead"); }, function(e, t, n) { var i = {}; e.exports = i; var o = n(15), r = n(0); i.name = "matter-js", i.version = "0.18.0", i.uses = [], i.used = [], i.use = function() { o.use(i, Array.prototype.slice.call(arguments)); }, i.before = function(e, t) { return e = e.replace(/^Matter./, ""), r.chainPathBefore(i, e, t); }, i.after = function(e, t) { return e = e.replace(/^Matter./, ""), r.chainPathAfter(i, e, t); }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(5), r = n(10), a = n(0), s = n(6), l = n(12), c = a.deprecated; i.stack = function(e, t, n, i, r, a, l) { for (var c, u = o.create({ label: "Stack" }), d = e, p = t, f = 0, v = 0; v < i; v++) { for (var y = 0, m = 0; m < n; m++) { var g = l(d, p, m, v, c, f); if (g) { var x = g.bounds.max.y - g.bounds.min.y, h = g.bounds.max.x - g.bounds.min.x; x > y && (y = x), s.translate(g, { x: .5 * h, y: .5 * x }), d = g.bounds.max.x + r, o.addBody(u, g), c = g, f += 1; } else d += r; } p += y + a, d = e; } return u; }, i.chain = function(e, t, n, i, s, l) { for (var c = e.bodies, u = 1; u < c.length; u++) { var d = c[u - 1], p = c[u], f = d.bounds.max.y - d.bounds.min.y, v = d.bounds.max.x - d.bounds.min.x, y = p.bounds.max.y - p.bounds.min.y, m = { bodyA: d, pointA: { x: v * t, y: f * n }, bodyB: p, pointB: { x: (p.bounds.max.x - p.bounds.min.x) * i, y: y * s } }, g = a.extend(m, l); o.addConstraint(e, r.create(g)); } return e.label += " Chain", e; }, i.mesh = function(e, t, n, i, s) { var l, c, u, d, p, f = e.bodies; for (l = 0; l < n; l++) { for (c = 1; c < t; c++) u = f[c - 1 + l * t], d = f[c + l * t], o.addConstraint(e, r.create(a.extend({ bodyA: u, bodyB: d }, s))); if (l > 0) for (c = 0; c < t; c++) u = f[c + (l - 1) * t], d = f[c + l * t], o.addConstraint(e, r.create(a.extend({ bodyA: u, bodyB: d }, s))), i && c > 0 && (p = f[c - 1 + (l - 1) * t], o.addConstraint(e, r.create(a.extend({ bodyA: p, bodyB: d }, s)))), i && c < t - 1 && (p = f[c + 1 + (l - 1) * t], o.addConstraint(e, r.create(a.extend({ bodyA: p, bodyB: d }, s)))); } return e.label += " Mesh", e; }, i.pyramid = function(e, t, n, o, r, a, l) { return i.stack(e, t, n, o, r, a, (function(t, i, a, c, u, d) { var p = Math.min(o, Math.ceil(n / 2)), f = u ? u.bounds.max.x - u.bounds.min.x : 0; if (!(c > p || a < (c = p - c) || a > n - 1 - c)) return 1 === d && s.translate(u, { x: (a + (n % 2 == 1 ? 1 : -1)) * f, y: 0 }), l(e + (u ? a * f : 0) + a * r, i, a, c, u, d); })); }, i.newtonsCradle = function(e, t, n, i, a) { for (var s = o.create({ label: "Newtons Cradle" }), c = 0; c < n; c++) { var u = l.circle(e + c * (1.9 * i), t + a, i, { inertia: 1 / 0, restitution: 1, friction: 0, frictionAir: 1e-4, slop: 1 }), d = r.create({ pointA: { x: e + c * (1.9 * i), y: t }, bodyB: u }); o.addBody(s, u), o.addConstraint(s, d); } return s; }, c(i, "newtonsCradle", "Composites.newtonsCradle ➤ moved to newtonsCradle example"), i.car = function(e, t, n, i, a) { var c = s.nextGroup(!0), u = .5 * -n + 20, d = .5 * n - 20, p = o.create({ label: "Car" }), f = l.rectangle(e, t, n, i, { collisionFilter: { group: c }, chamfer: { radius: .5 * i }, density: 2e-4 }), v = l.circle(e + u, t + 0, a, { collisionFilter: { group: c }, friction: .8 }), y = l.circle(e + d, t + 0, a, { collisionFilter: { group: c }, friction: .8 }), m = r.create({ bodyB: f, pointB: { x: u, y: 0 }, bodyA: v, stiffness: 1, length: 0 }), g = r.create({ bodyB: f, pointB: { x: d, y: 0 }, bodyA: y, stiffness: 1, length: 0 }); return o.addBody(p, f), o.addBody(p, v), o.addBody(p, y), o.addConstraint(p, m), o.addConstraint(p, g), p; }, c(i, "car", "Composites.car ➤ moved to car example"), i.softBody = function(e, t, n, o, r, s, c, u, d, p) { d = a.extend({ inertia: 1 / 0 }, d), p = a.extend({ stiffness: .2, render: { type: "line", anchors: !1 } }, p); var f = i.stack(e, t, n, o, r, s, (function(e, t) { return l.circle(e, t, u, d); })); return i.mesh(f, n, o, c, p), f.label = "Soft Body", f; }, c(i, "softBody", "Composites.softBody ➤ moved to softBody and cloth examples"); }, function(e, t, n) { var i = {}; e.exports = i; var o = n(9), r = n(0), a = r.deprecated; i.create = function(e) { return r.extend({ buckets: {}, pairs: {}, pairsList: [], bucketWidth: 48, bucketHeight: 48 }, e); }, i.update = function(e, t, n, o) { var r, a, s, l, c, u = n.world, d = e.buckets, p = !1; for (r = 0; r < t.length; r++) { var f = t[r]; if ((!f.isSleeping || o) && (!u.bounds || !(f.bounds.max.x < u.bounds.min.x || f.bounds.min.x > u.bounds.max.x || f.bounds.max.y < u.bounds.min.y || f.bounds.min.y > u.bounds.max.y))) { var v = i._getRegion(e, f); if (!f.region || v.id !== f.region.id || o) { f.region && !o || (f.region = v); var y = i._regionUnion(v, f.region); for (a = y.startCol; a <= y.endCol; a++) for (s = y.startRow; s <= y.endRow; s++) { l = d[c = i._getBucketId(a, s)]; var m = a >= v.startCol && a <= v.endCol && s >= v.startRow && s <= v.endRow, g = a >= f.region.startCol && a <= f.region.endCol && s >= f.region.startRow && s <= f.region.endRow; !m && g && g && l && i._bucketRemoveBody(e, l, f), (f.region === v || m && !g || o) && (l || (l = i._createBucket(d, c)), i._bucketAddBody(e, l, f)); } f.region = v, p = !0; } } } p && (e.pairsList = i._createActivePairsList(e)); }, a(i, "update", "Grid.update ➤ replaced by Matter.Detector"), i.clear = function(e) { e.buckets = {}, e.pairs = {}, e.pairsList = []; }, a(i, "clear", "Grid.clear ➤ replaced by Matter.Detector"), i._regionUnion = function(e, t) { var n = Math.min(e.startCol, t.startCol), o = Math.max(e.endCol, t.endCol), r = Math.min(e.startRow, t.startRow), a = Math.max(e.endRow, t.endRow); return i._createRegion(n, o, r, a); }, i._getRegion = function(e, t) { var n = t.bounds, o = Math.floor(n.min.x / e.bucketWidth), r = Math.floor(n.max.x / e.bucketWidth), a = Math.floor(n.min.y / e.bucketHeight), s = Math.floor(n.max.y / e.bucketHeight); return i._createRegion(o, r, a, s); }, i._createRegion = function(e, t, n, i) { return { id: e + "," + t + "," + n + "," + i, startCol: e, endCol: t, startRow: n, endRow: i }; }, i._getBucketId = function(e, t) { return "C" + e + "R" + t; }, i._createBucket = function(e, t) { return e[t] = []; }, i._bucketAddBody = function(e, t, n) { var i, r = e.pairs, a = o.id, s = t.length; for (i = 0; i < s; i++) { var l = t[i]; if (!(n.id === l.id || n.isStatic && l.isStatic)) { var c = a(n, l), u = r[c]; u ? u[2] += 1 : r[c] = [ n, l, 1 ]; } } t.push(n); }, i._bucketRemoveBody = function(e, t, n) { var i, a = e.pairs, s = o.id; t.splice(r.indexOf(t, n), 1); var l = t.length; for (i = 0; i < l; i++) { var c = a[s(n, t[i])]; c && (c[2] -= 1); } }, i._createActivePairsList = function(e) { var t, n, i = e.pairs, o = r.keys(i), a = o.length, s = []; for (n = 0; n < a; n++) (t = i[o[n]])[2] > 0 ? s.push(t) : delete i[o[n]]; return s; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(3), r = n(7), a = n(13), s = n(4), l = n(14), c = n(10), u = n(5), d = n(0), p = n(1); i.create = function(e, t) { var n = (e ? e.mouse : null) || (t ? t.mouse : null); n || (e && e.render && e.render.canvas ? n = a.create(e.render.canvas) : t && t.element ? n = a.create(t.element) : (n = a.create(), d.warn("MouseConstraint.create: options.mouse was undefined, options.element was undefined, may not function as expected"))); var o = { type: "mouseConstraint", mouse: n, element: null, body: null, constraint: c.create({ label: "Mouse Constraint", pointA: n.position, pointB: { x: 0, y: 0 }, length: .01, stiffness: .1, angularStiffness: 1, render: { strokeStyle: "#90EE90", lineWidth: 3 } }), collisionFilter: { category: 1, mask: 4294967295, group: 0 } }, r = d.extend(o, t); return s.on(e, "beforeUpdate", (function() { var t = u.allBodies(e.world); i.update(r, t), i._triggerEvents(r); })), r; }, i.update = function(e, t) { var n = e.mouse, i = e.constraint, a = e.body; if (0 === n.button) { if (i.bodyB) r.set(i.bodyB, !1), i.pointA = n.position; else for (var c = 0; c < t.length; c++) if (a = t[c], p.contains(a.bounds, n.position) && l.canCollide(a.collisionFilter, e.collisionFilter)) for (var u = a.parts.length > 1 ? 1 : 0; u < a.parts.length; u++) { var d = a.parts[u]; if (o.contains(d.vertices, n.position)) { i.pointA = n.position, i.bodyB = e.body = a, i.pointB = { x: n.position.x - a.position.x, y: n.position.y - a.position.y }, i.angleB = a.angle, r.set(a, !1), s.trigger(e, "startdrag", { mouse: n, body: a }); break; } } } else i.bodyB = e.body = null, i.pointB = null, a && s.trigger(e, "enddrag", { mouse: n, body: a }); }, i._triggerEvents = function(e) { var t = e.mouse, n = t.sourceEvents; n.mousemove && s.trigger(e, "mousemove", { mouse: t }), n.mousedown && s.trigger(e, "mousedown", { mouse: t }), n.mouseup && s.trigger(e, "mouseup", { mouse: t }), a.clearSourceEvents(t); }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(2), r = n(8), a = n(1), s = n(12), l = n(3); i.collides = function(e, t) { for (var n = [], i = t.length, o = e.bounds, s = r.collides, l = a.overlaps, c = 0; c < i; c++) { var u = t[c], d = u.parts.length, p = 1 === d ? 0 : 1; if (l(u.bounds, o)) for (var f = p; f < d; f++) { var v = u.parts[f]; if (l(v.bounds, o)) { var y = s(v, e); if (y) { n.push(y); break; } } } } return n; }, i.ray = function(e, t, n, r) { r = r || 1e-100; for (var a = o.angle(t, n), l = o.magnitude(o.sub(t, n)), c = .5 * (n.x + t.x), u = .5 * (n.y + t.y), d = s.rectangle(c, u, l, r, { angle: a }), p = i.collides(d, e), f = 0; f < p.length; f += 1) { var v = p[f]; v.body = v.bodyB = v.bodyA; } return p; }, i.region = function(e, t, n) { for (var i = [], o = 0; o < e.length; o++) { var r = e[o], s = a.overlaps(r.bounds, t); (s && !n || !s && n) && i.push(r); } return i; }, i.point = function(e, t) { for (var n = [], i = 0; i < e.length; i++) { var o = e[i]; if (a.contains(o.bounds, t)) for (var r = 1 === o.parts.length ? 0 : 1; r < o.parts.length; r++) { var s = o.parts[r]; if (a.contains(s.bounds, t) && l.contains(s.vertices, t)) { n.push(o); break; } } } return n; }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(4), r = n(18), a = n(0); !function() { var e, t, n; "undefined" != typeof window && (e = window.requestAnimationFrame || window.webkitRequestAnimationFrame || window.mozRequestAnimationFrame || window.msRequestAnimationFrame, t = window.cancelAnimationFrame || window.mozCancelAnimationFrame || window.webkitCancelAnimationFrame || window.msCancelAnimationFrame), e || (e = function(e) { n = setTimeout((function() { e(a.now()); }), 1e3 / 60); }, t = function() { clearTimeout(n); }), i.create = function(e) { var t = a.extend({ fps: 60, correction: 1, deltaSampleSize: 60, counterTimestamp: 0, frameCounter: 0, deltaHistory: [], timePrev: null, timeScalePrev: 1, frameRequestId: null, isFixed: !1, enabled: !0 }, e); return t.delta = t.delta || 1e3 / t.fps, t.deltaMin = t.deltaMin || 1e3 / t.fps, t.deltaMax = t.deltaMax || 1e3 / (.5 * t.fps), t.fps = 1e3 / t.delta, t; }, i.run = function(t, n) { return void 0 !== t.positionIterations && (n = t, t = i.create()), function o(r) { t.frameRequestId = e(o), r && t.enabled && i.tick(t, n, r); }(), t; }, i.tick = function(e, t, n) { var i, a = t.timing, s = 1, l = { timestamp: a.timestamp }; o.trigger(e, "beforeTick", l), e.isFixed ? i = e.delta : (i = n - e.timePrev || e.delta, e.timePrev = n, e.deltaHistory.push(i), e.deltaHistory = e.deltaHistory.slice(-e.deltaSampleSize), s = (i = (i = (i = Math.min.apply(null, e.deltaHistory)) < e.deltaMin ? e.deltaMin : i) > e.deltaMax ? e.deltaMax : i) / e.delta, e.delta = i), 0 !== e.timeScalePrev && (s *= a.timeScale / e.timeScalePrev), 0 === a.timeScale && (s = 0), e.timeScalePrev = a.timeScale, e.correction = s, e.frameCounter += 1, n - e.counterTimestamp >= 1e3 && (e.fps = e.frameCounter * ((n - e.counterTimestamp) / 1e3), e.counterTimestamp = n, e.frameCounter = 0), o.trigger(e, "tick", l), o.trigger(e, "beforeUpdate", l), r.update(t, i, s), o.trigger(e, "afterUpdate", l), o.trigger(e, "afterTick", l); }, i.stop = function(e) { t(e.frameRequestId); }, i.start = function(e, t) { i.run(e, t); }; }(); }, function(e, t, n) { var i = {}; e.exports = i; var o = n(8), r = n(0).deprecated; i.collides = function(e, t) { return o.collides(e, t); }, r(i, "collides", "SAT.collides ➤ replaced by Collision.collides"); }, function(e, t, n) { var i = {}; e.exports = i, n(1); var o = n(0); i.pathToVertices = function(e, t) { "undefined" == typeof window || "SVGPathSeg" in window || o.warn("Svg.pathToVertices: SVGPathSeg not defined, a polyfill is required."); var n, r, a, s, l, c, u, d, p, f, v, y = [], m = 0, g = 0, x = 0; t = t || 15; var h = function(e, t, n) { var i = n % 2 == 1 && n > 1; if (!p || e != p.x || t != p.y) { p && i ? (f = p.x, v = p.y) : (f = 0, v = 0); var o = { x: f + e, y: v + t }; !i && p || (p = o), y.push(o), g = f + e, x = v + t; } }, b = function(e) { var t = e.pathSegTypeAsLetter.toUpperCase(); if ("Z" !== t) { switch (t) { case "M": case "L": case "T": case "C": case "S": case "Q": g = e.x, x = e.y; break; case "H": g = e.x; break; case "V": x = e.y; } h(g, x, e.pathSegType); } }; for (i._svgPathToAbsolute(e), a = e.getTotalLength(), c = [], n = 0; n < e.pathSegList.numberOfItems; n += 1) c.push(e.pathSegList.getItem(n)); for (u = c.concat(); m < a; ) { if ((l = c[e.getPathSegAtLength(m)]) != d) { for (;u.length && u[0] != l; ) b(u.shift()); d = l; } switch (l.pathSegTypeAsLetter.toUpperCase()) { case "C": case "T": case "S": case "Q": case "A": s = e.getPointAtLength(m), h(s.x, s.y, 0); } m += t; } for (n = 0, r = u.length; n < r; ++n) b(u[n]); return y; }, i._svgPathToAbsolute = function(e) { for (var t, n, i, o, r, a, s = e.pathSegList, l = 0, c = 0, u = s.numberOfItems, d = 0; d < u; ++d) { var p = s.getItem(d), f = p.pathSegTypeAsLetter; if (/[MLHVCSQTA]/.test(f)) "x" in p && (l = p.x), "y" in p && (c = p.y); else switch ("x1" in p && (i = l + p.x1), "x2" in p && (r = l + p.x2), "y1" in p && (o = c + p.y1), "y2" in p && (a = c + p.y2), "x" in p && (l += p.x), "y" in p && (c += p.y), f) { case "m": s.replaceItem(e.createSVGPathSegMovetoAbs(l, c), d); break; case "l": s.replaceItem(e.createSVGPathSegLinetoAbs(l, c), d); break; case "h": s.replaceItem(e.createSVGPathSegLinetoHorizontalAbs(l), d); break; case "v": s.replaceItem(e.createSVGPathSegLinetoVerticalAbs(c), d); break; case "c": s.replaceItem(e.createSVGPathSegCurvetoCubicAbs(l, c, i, o, r, a), d); break; case "s": s.replaceItem(e.createSVGPathSegCurvetoCubicSmoothAbs(l, c, r, a), d); break; case "q": s.replaceItem(e.createSVGPathSegCurvetoQuadraticAbs(l, c, i, o), d); break; case "t": s.replaceItem(e.createSVGPathSegCurvetoQuadraticSmoothAbs(l, c), d); break; case "a": s.replaceItem(e.createSVGPathSegArcAbs(l, c, p.r1, p.r2, p.angle, p.largeArcFlag, p.sweepFlag), d); break; case "z": case "Z": l = t, c = n; } "M" != f && "m" != f || (t = l, n = c); } }; }, function(e, t, n) { var i = {}; e.exports = i; var o = n(5); n(0), i.create = o.create, i.add = o.add, i.remove = o.remove, i.clear = o.clear, i.addComposite = o.addComposite, i.addBody = o.addBody, i.addConstraint = o.addConstraint; } ]); } }, __webpack_module_cache__ = {}; function __webpack_require__(moduleId) { var cachedModule = __webpack_module_cache__[moduleId]; if (void 0 !== cachedModule) return cachedModule.exports; var module = __webpack_module_cache__[moduleId] = { exports: {} }; return __webpack_modules__[moduleId].call(module.exports, module, module.exports, __webpack_require__), module.exports; } __webpack_require__.n = module => { var getter = module && module.__esModule ? () => module.default : () => module; return __webpack_require__.d(getter, { a: getter }), getter; }, __webpack_require__.d = (exports, definition) => { for (var key in definition) __webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key) && Object.defineProperty(exports, key, { enumerable: !0, get: definition[key] }); }, __webpack_require__.g = function() { if ("object" == typeof globalThis) return globalThis; try { return this || new Function("return this")(); } catch (e) { if ("object" == typeof window) return window; } }(), __webpack_require__.o = (obj, prop) => Object.prototype.hasOwnProperty.call(obj, prop), (() => { "use strict"; const settings = class { static STORAGE_KEY_TOKEN="floating_window_token"; static STORAGE_KEY_POSITION="floating_window_position"; static STORAGE_KEY_MUTE="video_mute"; static STORAGE_KEY_SPEED="video_speed"; static STORAGE_KEY_EXAM_MODE="exam_mode"; static STORAGE_KEY_USERNAME="username"; static STORAGE_KEY_CREATE_TIME="create_time"; static STORAGE_KEY_DEEPSEEK_API_KEY="deepseek_api_key"; static STORAGE_KEY_DEEPSEEKPROXY="deepseekproxy"; static get createTime() { return localStorage.getItem(this.STORAGE_KEY_CREATE_TIME); } static set createTime(value) { localStorage.setItem(this.STORAGE_KEY_CREATE_TIME, value); } static get deepseekApiKey() { return localStorage.getItem(this.STORAGE_KEY_DEEPSEEK_API_KEY) || ""; } static set deepseekApiKey(value) { localStorage.setItem(this.STORAGE_KEY_DEEPSEEK_API_KEY, value); } static get deepseekProxy() { return "true" === localStorage.getItem(this.STORAGE_KEY_DEEPSEEKPROXY); } static set deepseekProxy(value) { localStorage.setItem(this.STORAGE_KEY_DEEPSEEKPROXY, value.toString()); } static get username() { return localStorage.getItem(this.STORAGE_KEY_USERNAME); } static set username(value) { localStorage.setItem(this.STORAGE_KEY_USERNAME, value); } static get token() { return localStorage.getItem(this.STORAGE_KEY_TOKEN); } static set token(value) { localStorage.setItem(this.STORAGE_KEY_TOKEN, value); } static get position() { const position = localStorage.getItem(this.STORAGE_KEY_POSITION); return position ? JSON.parse(position) : { left: 0, top: 0 }; } static set position(value) { localStorage.setItem(this.STORAGE_KEY_POSITION, JSON.stringify(value)); } static get speed() { return localStorage.getItem(this.STORAGE_KEY_SPEED) || "1"; } static set speed(value) { localStorage.setItem(this.STORAGE_KEY_SPEED, String(value)); } static get mute() { return "true" === localStorage.getItem(this.STORAGE_KEY_MUTE); } static set mute(value) { localStorage.setItem(this.STORAGE_KEY_MUTE, value.toString()); } static get examMode() { return "true" === localStorage.getItem(this.STORAGE_KEY_EXAM_MODE); } static set examMode(value) { localStorage.setItem(this.STORAGE_KEY_EXAM_MODE, value.toString()); } }, imageData = { defaultImage: "", weChatQr: "", fingerEmoji: "", zzxLogo: "" }; function findDeepestElement(element) { let deepestElement = element; for (let child of element.children) { const computedStyle = getComputedStyle(child); if ("input" === child.tagName.toLowerCase() || "center" === computedStyle.textAlign) continue; "span" === child.tagName.toLowerCase() && (deepestElement = child), "p" === child.tagName.toLowerCase() && (deepestElement = child); const deepChild = findDeepestElement(child); deepChild && deepChild !== child && (deepestElement = deepChild); } return deepestElement; } function insertIntoDeepestElement(parentElement, content) { const deepestElement = findDeepestElement(parentElement), originalText = deepestElement.textContent, newElement = document.createElement("span"); newElement.classList.add("modified"); const textContent = function(content) { const div = document.createElement("div"); return div.innerHTML = content, div.querySelectorAll("img").forEach((img => { img.style.maxWidth = "100%"; })), div.innerHTML; }(content); newElement.innerHTML = textContent, newElement.style.opacity = .2, deepestElement.appendChild(newElement), deepestElement.dataset.originalText = originalText; } var matter_min = __webpack_require__("./src/utils/matter.min.js"), matter_min_default = __webpack_require__.n(matter_min); function createFloatingImageWorld(imageKey = "defaultImage") { const imageSrc = imageData[imageKey], engine = matter_min_default().Engine.create({ gravity: { x: 0, y: 0, scale: 0 } }), world = engine.world; let runner, floatingImage, mouseConstraint; const createWalls = () => { const width = window.innerWidth, height = window.innerHeight; return [ matter_min_default().Bodies.rectangle(width / 2, -499.5, width, 999, { isStatic: !0 }), matter_min_default().Bodies.rectangle(-499.5, height / 2, 999, height, { isStatic: !0 }), matter_min_default().Bodies.rectangle(width + 499.5, height / 2, 999, height, { isStatic: !0 }), matter_min_default().Bodies.rectangle(width / 2, height + 499.5, width, 999, { isStatic: !0 }) ]; }; let currentWalls = []; const updateWalls = () => { matter_min_default().World.remove(world, currentWalls), currentWalls = createWalls(), matter_min_default().World.add(world, currentWalls); }, init = async () => { currentWalls = createWalls(), matter_min_default().World.add(world, currentWalls); try { const imageBody = await (src => { const img = document.createElement("img"); return img.src = src, img.style.position = "fixed", img.style.transform = "translate(-50%, -50%)", img.style.pointerEvents = "auto", img.style.zIndex = "9999", img.style.width = "130px", img.addEventListener("dragstart", (e => e.preventDefault())), img.addEventListener("contextmenu", (e => e.preventDefault())), document.body.appendChild(img), console.log("已经创建图片标签"), new Promise((resolve => { img.onload = () => { const body = matter_min_default().Bodies.rectangle(window.innerWidth / 2, window.innerHeight / 2, 130, 191, { restitution: .8, frictionAir: .002, render: { visible: !1 }, chamfer: { radius: 5 } }); matter_min_default().Body.setVelocity(body, { x: 5 * (Math.random() - .5), y: 5 * (Math.random() - .5) }), matter_min_default().Body.setAngularVelocity(body, .2 * (Math.random() - .5)), matter_min_default().Events.on(engine, "beforeUpdate", (() => { img.style.transform = "", img.style.left = "0", img.style.top = "0"; const angle = body.angle, translateX = body.position.x, translateY = body.position.y; img.style.transform = `\n translate(${translateX}px, ${translateY}px)\n translate(-50%, -50%)\n rotate(${angle}rad)\n `; })), resolve(body); }; })); })(imageSrc); floatingImage = imageBody, matter_min_default().World.add(world, imageBody); const mouse = matter_min_default().Mouse.create(document.body); mouseConstraint = matter_min_default().MouseConstraint.create(engine, { mouse: mouse }), matter_min_default().World.add(world, mouseConstraint), runner = matter_min_default().Runner.run(engine); } catch (error) { console.error("初始化失败:", error); } }; return init().catch((error => console.error("初始化过程出错:", error))), window.addEventListener("resize", (() => { updateWalls(), console.log("已经更新边界"), document.body.style.width = window.innerWidth + "px", document.body.style.height = window.innerHeight + "px"; })), window.addEventListener("load", init), () => { runner && matter_min_default().Runner.stop(runner), floatingImage && matter_min_default().World.remove(world, floatingImage), mouseConstraint && matter_min_default().World.remove(world, mouseConstraint), matter_min_default().World.remove(world, currentWalls), window.removeEventListener("resize", updateWalls), window.removeEventListener("load", init); document.querySelectorAll("img").forEach((img => { "fixed" === img.style.position && "9999" === img.style.zIndex && img.remove(); })); }; } let isRunning = !0, currentVideoElement = null; function findLessons() { const allITags = document.getElementsByTagName("i"); return Array.from(allITags).filter((tag => tag.classList.contains("iconfont") && "SPAN" === tag.parentElement.tagName && !tag.classList.contains("icon-bianji"))); } async function playVideo() { if (isRunning) return new Promise((resolve => { const video = document.querySelector("video"); if (!video) return console.log("跳过非视频内容"), resolve(); currentVideoElement = video, video.muted = settings.mute, video.playbackRate = parseFloat(settings.speed) || 1; const handleEnd = () => { video.removeEventListener("ended", handleEnd), video.removeEventListener("error", handleError), currentVideoElement = null, resolve(); }, handleError = () => { console.log("视频播放异常"), handleEnd(); }; video.addEventListener("ended", handleEnd, { once: !0 }), video.addEventListener("error", handleError, { once: !0 }), video.play().catch((err => { console.log("视频播放失败:", err), handleEnd(); })); })); } async function completeLesson() { for (let retry = 0; retry < 3; retry++) { const button = Array.from(document.querySelectorAll("button")).find((btn => btn.textContent.includes("完成学习"))); if (button) return button.disabled = !1, button.click(), await new Promise((r => setTimeout(r, 2e3))), !0; await new Promise((r => setTimeout(r, 1e3))); } return !1; } function setCompletedStatus(lessonElement) { lessonElement && (lessonElement.classList.add("complete"), lessonElement.classList.remove("no-start")); } function stopAutoPlay() { isRunning = !1, currentVideoElement && (currentVideoElement.pause(), currentVideoElement.removeAttribute("src"), currentVideoElement.load(), currentVideoElement = null); } async function autoPlay(parsedData, listenRouteWarpper) { isRunning = !0; const sections = Array.from(document.querySelectorAll("li span.of_eno")).filter((span => "LI" === span.parentElement.tagName)); if (!sections.length) return console.log("未找到节元素"), [ "error", "请进入 章节内容>任意课件 再尝试自动播放" ]; if (!parsedData || 0 === Object.keys(parsedData).length) return console.log("未找到数据"), [ "error", "定位未完成课件失败,可能由于页面被刷新,正在从头排查课件" ]; const tasks = function(parsedData) { return (parsedData.data || []).flatMap((chapter => chapter.children || [])).flatMap(((section, sectionIndex) => { const lessons = (section.children || []).map(((lesson, lessonIndex) => 2 !== lesson.learnStatus ? { index: lessonIndex, resourceType: lesson.resourceType } : null)).filter(Boolean); return lessons.length ? [ [ sectionIndex, lessons ] ] : []; })); }(parsedData); if (!tasks.length) return console.log("所有任务已完成"), [ "success", "所有任务已完成" ]; try { for (const [sectionIndex, lessons] of tasks) { if (!isRunning) break; listenRouteWarpper.listenRoute = !1, sections[sectionIndex]?.click(), await new Promise((r => setTimeout(r, 20))), listenRouteWarpper.listenRoute = !0, await new Promise((r => setTimeout(r, 2e3))); const lessonElements = findLessons(); console.log(lessonElements); for (const {index: index, resourceType: resourceType} of lessons) { if (console.log("正在完成第", index, "/", lessonElements.length, "课"), !isRunning) break; const lessonElement = lessonElements[index]; listenRouteWarpper.listenRoute = !1, lessonElement?.click(), await new Promise((r => setTimeout(r, 20))), listenRouteWarpper.listenRoute = !0, console.log(lessonElement), await new Promise((r => setTimeout(r, 2e3))), 1 === resourceType ? await playVideo() : await completeLesson(), setCompletedStatus(lessonElement); const currentSection = parsedData.data.flatMap((chapter => chapter.children))[sectionIndex]; currentSection && currentSection.children[index] && (currentSection.children[index].learnStatus = 2), await new Promise((r => setTimeout(r, 2e3))); } } } catch (error) { console.error("执行异常:", error); } finally { return stopAutoPlay(), [ "success", "所有任务已完成" ]; } } function createButton(text = "Get started", onClick = () => {}) { if (!createButton.styleAdded) { const style = document.createElement("style"); style.textContent = "\n .VerificationCode{\n font-size:14px;\n color:white;\n font-weight:600;\n }\n .cssbuttons-io-button {\n background: #e8e8e8;\n color: rgb(13, 13, 13);\n font-family: inherit;\n padding: 0.35em;\n padding-left: 1.2em;\n font-size: 12px;\n font-weight: 500;\n border-radius: 0.9em;\n border: none;\n letter-spacing: 0.05em;\n display: flex;\n align-items: center;\n box-shadow: inset 0 0 1.6em -0.6em #ffffff;\n overflow: hidden;\n position: relative;\n height: 2.8em;\n padding-right: 3.3em;\n cursor: pointer;\n }\n \n .cssbuttons-io-button .icon {\n background: rgb(98 177 251);\n margin-left: 1em;\n position: absolute;\n display: flex;\n align-items: center;\n justify-content: center;\n height: 2.2em;\n width: 2.2em;\n border-radius: 0.7em;\n right: 0.3em;\n transition: all 0.3s;\n }\n \n .cssbuttons-io-button:hover .icon {\n width: calc(100% - 0.6em);\n }\n \n .cssbuttons-io-button .icon svg {\n width: 1.1em;\n transition: transform 0.3s;\n color: #e8e8e8;\n }\n \n .cssbuttons-io-button:hover .icon svg {\n transform: translateX(0.1em);\n }\n \n .cssbuttons-io-button:active .icon {\n transform: scale(0.95);\n }\n\n /* 加载动画样式 */\n .cssbuttons-io-button .wrapper {\n position: relative;\n width: 4.2em;\n height: 2em;\n margin-left: 0em;\n }\n\n .cssbuttons-io-button .circle {\n width: 6px;\n height: 6px;\n position: absolute;\n border-radius: 50%;\n background: #fff;\n animation: circleBounce 0.5s alternate infinite ease;\n }\n\n @keyframes circleBounce {\n 0% { top: 15px; height: 5px; }\n 100% { top: 5px; }\n }\n\n .cssbuttons-io-button .shadow {\n width: 6px;\n height: 2px;\n background: rgba(0,0,0,0.2);\n position: absolute;\n top: 18px;\n animation: shadowScale 0.5s alternate infinite ease;\n }\n\n @keyframes shadowScale {\n 0% { transform: scaleX(1.5); }\n 100% { transform: scaleX(0.5); }\n }\n\n /* 悬停状态调整 */\n .cssbuttons-io-button.loading:hover .icon {\n width: 2.2em !important;\n }\n\n /* 定位调整 */\n .cssbuttons-io-button .circle:nth-child(1) { left: 15%; }\n .cssbuttons-io-button .circle:nth-child(2) { left: 45%; animation-delay: 0.2s; }\n .cssbuttons-io-button .circle:nth-child(3) { right: 15%; animation-delay: 0.3s; }\n .cssbuttons-io-button .shadow:nth-child(4) { left: 15%; }\n .cssbuttons-io-button .shadow:nth-child(5) { left: 45%; animation-delay: 0.2s; }\n .cssbuttons-io-button .shadow:nth-child(6) { right: 15%; animation-delay: 0.3s; }\n \n /* 加载状态下的特殊处理 */\n .cssbuttons-io-button.loading .icon {\n width: calc(100% - 0.6em) !important;\n right: 0.3em !important;\n }\n /* 保持悬停效果 */\n .cssbuttons-io-button.loading:hover .icon {\n width: calc(100% - 0.6em) !important;\n } \n ", document.head.appendChild(style), createButton.styleAdded = !0; } const button = document.createElement("button"); button.className = "cssbuttons-io-button"; const textNode = document.createTextNode(text); button.appendChild(textNode); const iconDiv = document.createElement("div"); iconDiv.className = "icon"; const svg = document.createElementNS("http://www.w3.org/2000/svg", "svg"); svg.setAttribute("height", "24"), svg.setAttribute("width", "24"), svg.setAttribute("viewBox", "0 0 24 24"); const path1 = document.createElementNS("http://www.w3.org/2000/svg", "path"); path1.setAttribute("d", "M0 0h24v24H0z"), path1.setAttribute("fill", "none"); const path2 = document.createElementNS("http://www.w3.org/2000/svg", "path"); return path2.setAttribute("d", "M16.172 11l-5.364-5.364 1.414-1.414L20 12l-7.778 7.778-1.414-1.414L16.172 13H4v-2z"), path2.setAttribute("fill", "currentColor"), svg.appendChild(path1), svg.appendChild(path2), iconDiv.appendChild(svg), button.appendChild(iconDiv), button.addEventListener("click", onClick), button; } function pollLogin(verificationCode, LoggedWarpper) { let attempts = 0; const interval = setInterval((async () => { const user = await (async () => { try { const response = await fetch("https://app.zaizhexue.top/polling", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ verification_code: verificationCode }) }); if (!response.ok) throw new Error("请求失败"); const data = await response.json(); if (data.logged_in) return LoggedWarpper.Logged = !0, data.user; } catch (error) { console.error("请求失败:", error); } if (attempts++, attempts >= 60) return console.log("已发送60次请求,停止请求"), null; })(); if (user) { clearInterval(interval), console.log("登录成功!"), settings.token = user.token.split("|")[0]; const imgContainer = document.getElementById("imgContainer"); imgContainer && (imgContainer.style.display = "none"); const username = document.getElementById("username"); username && (username.innerHTML = user.nickname), settings.username = user.nickname; const createTime = document.getElementById("createTime"), userCreatedTime = new Date(user.createdTime), formattedDate = `${userCreatedTime.getMonth() + 1}/${userCreatedTime.getDate()}/${userCreatedTime.getFullYear()}`; createTime && (createTime.innerHTML = formattedDate + "注册"), settings.createTime = formattedDate; const userInfoContainer = document.getElementById("userInfoContainer"); return userInfoContainer && (userInfoContainer.style.display = "flex"), user; } }), 3e3); } async function toggleButtonState(button, isLoading = !0, LoggedWarpper) { const iconContainer = button.querySelector(".icon"); if (!iconContainer) return; isLoading ? (iconContainer.innerHTML = '\n
\n
\n
\n
\n
\n ', button.classList.add("loading")) : (iconContainer.innerHTML = '\n \n \n \n \n ', button.classList.remove("loading")), console.log("切换状态"); const code = await async function() { try { const requestBody = {}, response = await fetch("https://app.zaizhexue.top/trigger_login", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(requestBody) }); if (!response.ok) throw new Error("网络请求失败"); return (await response.json()).verification_code; } catch (error) { return console.error("请求失败:", error), null; } }(); iconContainer.innerHTML = `
${code}
`, LoggedWarpper.code = code, button.disabled = !0, pollLogin(code, LoggedWarpper); } function createPushButton({text: text = "保存", onClick: onClick = () => console.log("Button clicked!")} = {}) { const button = document.createElement("button"); button.className = "btn", button.innerText = text, button.addEventListener("click", onClick); return createPushButton.stylesAdded || (createPushButton.stylesAdded = (() => { const style = document.createElement("style"); return style.textContent = "\n .btn {\n width: 80px;\n border-radius: 8px;\n background-color:rgb(111, 181, 255);\n color: white;\n font-weight: 800;\n transition: scale 0.2s;\n }\n .btn:active {\n scale: 0.9;\n }\n \n ", document.head.append(style), !0; })()), button; } function insertButtonAndFetchContent(element) { if (settings.examMode) return; const style = document.createElement("style"); style.textContent = "\n .deepseek-button {\n background: transparent;\n border: none;\n cursor: pointer;\n padding: 8px;\n transition: all 0.3s;\n position: relative;\n display: flex;\n align-items: center;\n }\n\n .deepseek-button svg {\n width: 24px;\n height: 24px;\n transition: transform 0.3s;\n }\n\n .deepseek-button:hover svg {\n transform: scale(1.1);\n }\n\n .deepseek-button.loading .icon {\n display: none;\n }\n\n .deepseek-button .wrapper {\n position: relative;\n width: 24px;\n height: 24px;\n display: none;\n }\n\n .deepseek-button.loading .wrapper {\n display: block;\n }\n\n .deepseek-button .circle {\n width: 4px;\n height: 4px;\n position: absolute;\n border-radius: 50%;\n background: #4D6BFE;\n animation: circleBounce 0.5s alternate infinite ease;\n }\n\n @keyframes circleBounce {\n 0% { top: 12px; height: 4px; }\n 100% { top: 4px; }\n }\n\n .deepseek-button .circle:nth-child(1) { left: 15%; }\n .deepseek-button .circle:nth-child(2) { left: 45%; animation-delay: 0.2s; }\n .deepseek-button .circle:nth-child(3) { right: 15%; animation-delay: 0.3s; }\n\n .response-container {\n display: none;\n border: 1px solid #e0e0e0;\n border-radius: 8px;\n padding: 16px;\n margin-left: 12px;\n background: #f8f9fa;\n font-size: 14px;\n line-height: 1.6;\n color: #333;\n white-space: pre-wrap;\n }\n ", document.head.appendChild(style); const button = document.createElement("button"); button.className = "deepseek-button", button.classList.add("modified"), button.innerHTML = '\n\n
\n
\n
\n
\n
\n ', element.appendChild(button); const outputElement = document.createElement("div"); outputElement.className = "response-container", outputElement.classList.add("modified"), element.appendChild(outputElement); let abortController = null; function updateButtonState(loading = !1, error = !1) { button.disabled = loading, button.classList[loading ? "add" : "remove"]("loading"); } function keepScrolledToBottom(element) { element.scrollTop = element.scrollHeight; } button.addEventListener("click", (async function() { if (!button.disabled) { updateButtonState(!0), outputElement.innerHTML = "", outputElement.style.display = "block", abortController = new AbortController; try { const textContent = element.textContent.trim(); if (!textContent) return void (outputElement.innerHTML = '
⚠️ 未找到可提取的文本内容
'); var apiUrl = "https://api.csid.cc/deepseek"; settings.deepseekProxy && (apiUrl = "http://localhost:5233"); const response = await fetch(apiUrl, { method: "POST", headers: { "Content-Type": "application/json", Authorization: `Bearer ${settings.token}`, Accept: "text/event-stream" }, body: JSON.stringify({ messages: [ { role: "system", content: "你是有用的人工智能助手,请用清晰格式回答,适当使用段落和列表,但不要使用markdown格式,并且在开头都要回答出你认为对的回答" }, { role: "user", content: textContent } ], stream: !0 }), signal: abortController.signal }); response.ok || response.json().then((data => { "Authorization limit reached" === data.error ? outputElement.innerHTML = "
请求失败:今日使用次数已用完,请尝试
DeepSeekProxy" : outputElement.textContent = `请求失败: ${response.status}`; })).catch((() => { outputElement.textContent = `请求失败: ${response.status}`; })).finally((() => { throw new Error(`请求失败: ${response.status}`); })); const reader = response.body.getReader(), decoder = new TextDecoder; for (;;) { const {done: done, value: value} = await reader.read(); if (done) break; const lines = decoder.decode(value, { stream: !0 }).split("\n"); console.log("lines:", lines), lines.forEach((line => { if (line.startsWith("data: ") && !line.includes("[DONE]")) try { const {choices: choices} = JSON.parse(line.slice(6)); choices?.[0]?.delta?.content && (outputElement.textContent += choices[0].delta.content, keepScrolledToBottom(outputElement)); } catch (e) { console.error("解析错误:", e); } })); } } catch (e) { "AbortError" !== e.name && (outputElement.innerHTML += `
⚠️ 请求中断:${e}
使用教程`); } finally { updateButtonState(!1); } } })); } createButton.styleAdded = !1, function() { (async function(fontName, fontUrl) { try { const fontFace = new FontFace(fontName, `url(${fontUrl})`), loadedFont = await fontFace.load(); return document.fonts.add(loadedFont), window[`${fontName}Loaded`] = !0, console.log(`字体 ${fontName} 加载成功`), !0; } catch (error) { return console.error(`字体加载失败: ${error}`), !1; } })("SmileySans-Oblique", "https://fastly.jsdelivr.net/gh/Miaozeqiu/fontRepository/SmileySans-Oblique.ttf.ec5470fd.woff2").then((success => { success && (document.body.style.fontFamily = "SmileySans-Oblique, sans-serif"); })); const LoggedWarpper = { Logged: !1, code: "" }; var stopAnimation, CourseChapters = {}, isPlaying = !1; const listenRouteWarpper = { listenRoute: !0 }; if (window.top != window) return void console.log("当前脚本在iframe中执行,窗口不渲染"); const style = document.createElement("style"); style.type = "text/css", style.innerHTML = '.answer {\r\n background-color: #f5f5f5;\r\n padding: 2px 8px;\r\n border-radius: 3px;\r\n cursor: pointer;\r\n transition: background-color 0.3s ease;\r\n margin: 5px;\r\n}\r\n\r\n.answer:hover {\r\n background-color: #e0e0e0;\r\n\r\n}\r\n\r\n/* 固定窗口样式 */\r\n#scriptWindow {\r\n position: fixed;\r\n top: 10px;\r\n left: 10px;\r\n width: 300px;\r\n height: 400px;\r\n background-color: #fff;\r\n z-index: 10000;\r\n box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);\r\n border-radius: 8px;\r\n overflow: hidden;\r\n}\r\n\r\n\r\n#window-header {\r\n height: 40px;\r\n background-color: #007bff;\r\n color: #fff;\r\n padding: 10px;\r\n display: flex;\r\n justify-content: space-between;\r\n cursor: move;\r\n }\r\n\r\n#window-navBar {\r\n width: 50px;\r\n background-color: #f8f9fa;\r\n border-right: 1px solid #ddd;\r\n display: flex;\r\n flex-direction: column;\r\n padding-top: 10px;\r\n padding-bottom: 10px;\r\n}\r\n\r\n#window-pageLink{\r\n padding: 12px 16px;\r\n margin-bottom: 10px;\r\n cursor: pointer;\r\n border-radius: 6px;\r\n transition: background-color 0.3s ease;\r\n}\r\n\r\n#checklist {\r\n --background: #fff;\r\n --text: #414856;\r\n --check: #4f29f0;\r\n --disabled: #c3c8de;\r\n --width: 280px;\r\n --height: 180px;\r\n --border-radius: 10px;\r\n overflow-y: auto;\r\n /* 内容超出时显示滚动条 */\r\n overflow-x: hidden;\r\n /* 内容超出时显示滚动条 */\r\n background: var(--background);\r\n width: var(--width);\r\n max-height: 180px;\r\n border-radius: var(--border-radius);\r\n position: relative;\r\n box-shadow: 0 10px 30px rgba(65, 72, 86, 0.05);\r\n display: grid;\r\n grid-template-columns: 30px auto;\r\n align-items: center;\r\n justify-content: left;\r\n}\r\n\r\n#checklist label {\r\n color: var(--text);\r\n position: relative;\r\n cursor: pointer;\r\n display: grid;\r\n align-items: center;\r\n width: fit-content;\r\n transition: color 0.3s ease;\r\n margin-right: 0px;\r\n}\r\n\r\n#checklist label::before,\r\n#checklist label::after {\r\n content: "";\r\n position: absolute;\r\n}\r\n\r\n#checklist label::before {\r\n height: 2px;\r\n width: 8px;\r\n left: -27px;\r\n background: var(--check);\r\n border-radius: 2px;\r\n transition: background 0.3s ease;\r\n}\r\n\r\n#checklist label:after {\r\n height: 4px;\r\n width: 4px;\r\n top: 8px;\r\n left: -25px;\r\n border-radius: 50%;\r\n}\r\n\r\n#checklist input[type="checkbox"] {\r\n position: relative;\r\n height: 15px;\r\n width: 15px;\r\n outline: none;\r\n border: 0;\r\n margin: 0 15px 0 0;\r\n cursor: pointer;\r\n background: var(--background);\r\n display: grid;\r\n align-items: center;\r\n margin-right: 20px;\r\n}\r\n\r\n#checklist input[type="checkbox"]::before,\r\n#checklist input[type="checkbox"]::after {\r\n content: "";\r\n position: absolute;\r\n height: 2px;\r\n top: auto;\r\n background: var(--check);\r\n border-radius: 2px;\r\n}\r\n\r\n#checklist input[type="checkbox"]::before {\r\n width: 0px;\r\n right: 60%;\r\n transform-origin: right bottom;\r\n}\r\n\r\n#checklist input[type="checkbox"]::after {\r\n width: 0px;\r\n left: 40%;\r\n transform-origin: left bottom;\r\n}\r\n\r\n#checklist input[type="checkbox"]:checked::before {\r\n animation: check-01 0.4s ease forwards;\r\n}\r\n\r\n#checklist input[type="checkbox"]:checked::after {\r\n animation: check-02 0.4s ease forwards;\r\n}\r\n\r\n#checklist input[type="checkbox"]:checked+label {\r\n color: var(--disabled);\r\n animation: move 0.3s ease 0.1s forwards;\r\n}\r\n\r\n#checklist input[type="checkbox"]:checked+label::before {\r\n background: var(--disabled);\r\n animation: slice 0.4s ease forwards;\r\n}\r\n\r\n#checklist input[type="checkbox"]:checked+label::after {\r\n animation: firework 0.5s ease forwards 0.1s;\r\n}\r\n\r\n@keyframes move {\r\n 50% {\r\n padding-left: 8px;\r\n padding-right: 0px;\r\n }\r\n\r\n 100% {\r\n padding-right: 4px;\r\n }\r\n}\r\n\r\n@keyframes slice {\r\n 60% {\r\n width: 100%;\r\n left: 4px;\r\n }\r\n\r\n 100% {\r\n width: 100%;\r\n left: -2px;\r\n padding-left: 0;\r\n }\r\n}\r\n\r\n@keyframes check-01 {\r\n 0% {\r\n width: 4px;\r\n top: auto;\r\n transform: rotate(0);\r\n }\r\n\r\n 50% {\r\n width: 0px;\r\n top: auto;\r\n transform: rotate(0);\r\n }\r\n\r\n 51% {\r\n width: 0px;\r\n top: 8px;\r\n transform: rotate(45deg);\r\n }\r\n\r\n 100% {\r\n width: 5px;\r\n top: 8px;\r\n transform: rotate(45deg);\r\n }\r\n}\r\n\r\n@keyframes check-02 {\r\n 0% {\r\n width: 4px;\r\n top: auto;\r\n transform: rotate(0);\r\n }\r\n\r\n 50% {\r\n width: 0px;\r\n top: auto;\r\n transform: rotate(0);\r\n }\r\n\r\n 51% {\r\n width: 0px;\r\n top: 8px;\r\n transform: rotate(-45deg);\r\n }\r\n\r\n 100% {\r\n width: 10px;\r\n top: 8px;\r\n transform: rotate(-45deg);\r\n }\r\n}\r\n\r\n@keyframes firework {\r\n 0% {\r\n opacity: 1;\r\n box-shadow: 0 0 0 -2px #4f29f0, 0 0 0 -2px #4f29f0, 0 0 0 -2px #4f29f0, 0 0 0 -2px #4f29f0, 0 0 0 -2px #4f29f0, 0 0 0 -2px #4f29f0;\r\n }\r\n\r\n 30% {\r\n opacity: 1;\r\n }\r\n\r\n 100% {\r\n opacity: 0;\r\n box-shadow: 0 -15px 0 0px #4f29f0, 14px -8px 0 0px #4f29f0, 14px 8px 0 0px #4f29f0, 0 15px 0 0px #4f29f0, -14px 8px 0 0px #4f29f0, -14px -8px 0 0px #4f29f0;\r\n }\r\n}\r\n\r\n.body-container {\r\n place-items: left;\r\n align-content: left;\r\n font-family: "SF Pro Text", "SF Pro Icons", "AOS Icons", "Helvetica Neue",\r\n Helvetica, Arial, sans-serif, system-ui;\r\n\r\n}\r\n\r\n.radio-input input {\r\n display: none;\r\n width: 250px;\r\n}\r\n\r\n.radio-input {\r\n justify-content: center;\r\n /* 添加这行来水平居中 */\r\n display: grid;\r\n place-items: center;\r\n align-content: center;\r\n --container_width: 185px;\r\n position: relative;\r\n display: flex;\r\n align-items: center;\r\n border-radius: 10px;\r\n background-color: #fff;\r\n color: #000000;\r\n width: calc(var(--container_width) + 40px);\r\n ;\r\n overflow: hidden;\r\n border: 1px solid rgba(53, 52, 52, 0.226);\r\n}\r\n\r\n.radio-input label {\r\n width: 100%;\r\n padding: 10px;\r\n cursor: pointer;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n z-index: 1;\r\n font-weight: 600;\r\n letter-spacing: -1px;\r\n font-size: 14px;\r\n color: gray;\r\n}\r\n\r\n.selection {\r\n position: relative;\r\n display: none;\r\n position: absolute;\r\n height: 80%;\r\n width: calc(var(--container_width) / 4);\r\n z-index: 0;\r\n left: 0;\r\n top: 10%;\r\n border-radius: 10px;\r\n transform: translateY(-50%);\r\n /* 竖直居中 */\r\n transition: 0.3s ease;\r\n background-color: #FF5733;\r\n}\r\n\r\n.radio-input label:has(input:checked) {\r\n color: #fff;\r\n}\r\n\r\n.radio-input label:has(input:checked)~.selection {\r\n background-color: #2BA8FB;\r\n display: inline-block;\r\n}\r\n\r\n.radio-input label:nth-child(1):has(input:checked)~.selection {\r\n transform: translateX(calc(var(--container_width) * 0 / 4 + 5px));\r\n}\r\n\r\n.radio-input label:nth-child(2):has(input:checked)~.selection {\r\n transform: translateX(calc(var(--container_width) * 1 / 4 + 15px));\r\n}\r\n\r\n.radio-input label:nth-child(3):has(input:checked)~.selection {\r\n transform: translateX(calc(var(--container_width) * 2 / 4 + 25px));\r\n}\r\n\r\n.radio-input label:nth-child(4):has(input:checked)~.selection {\r\n transform: translateX(calc(var(--container_width) * 3 / 4 + 35px));\r\n}\r\n\r\n.selection2 {\r\n display: none;\r\n position: absolute;\r\n height: 80%;\r\n width: calc(var(--container_width) / 4);\r\n z-index: 0;\r\n left: 0;\r\n top: 10%;\r\n border-radius: 10px;\r\n transform: translateY(-50%);\r\n /* 竖直居中 */\r\n transition: 0.2s ease;\r\n background-color: #FF5733;\r\n}\r\n\r\n.radio-input label:has(input:checked) {\r\n color: #fff;\r\n}\r\n\r\n.radio-input label:has(input:checked)~.selection2 {\r\n background-color: #2BA8FB;\r\n display: inline-block;\r\n}\r\n\r\n.radio-input label:nth-child(1):has(input:checked)~.selection2 {\r\n transform: translateX(calc(var(--container_width) * 0 / 4 + 5px));\r\n}\r\n\r\n.radio-input label:nth-child(2):has(input:checked)~.selection2 {\r\n transform: translateX(calc(var(--container_width) * 1 / 4 + 15px));\r\n}\r\n\r\n.radio-input label:nth-child(3):has(input:checked)~.selection2 {\r\n transform: translateX(calc(var(--container_width) * 2 / 4 + 25px));\r\n}\r\n\r\n.radio-input label:nth-child(4):has(input:checked)~.selection2 {\r\n transform: translateX(calc(var(--container_width) * 3 / 4 + 35px));\r\n}\r\n\r\n.selection {\r\n --ease: linear(0,\r\n 0.1641 3.52%,\r\n 0.311 7.18%,\r\n 0.4413 10.99%,\r\n 0.5553 14.96%,\r\n 0.6539 19.12%,\r\n 0.738 23.5%,\r\n 0.8086 28.15%,\r\n 0.8662 33.12%,\r\n 0.9078 37.92%,\r\n 0.9405 43.12%,\r\n 0.965 48.84%,\r\n 0.9821 55.28%,\r\n 0.992 61.97%,\r\n 0.9976 70.09%,\r\n 1);\r\n}\r\n\r\n.selection2 {\r\n --ease: linear(0,\r\n 0.1641 3.52%,\r\n 0.311 7.18%,\r\n 0.4413 10.99%,\r\n 0.5553 14.96%,\r\n 0.6539 19.12%,\r\n 0.738 23.5%,\r\n 0.8086 28.15%,\r\n 0.8662 33.12%,\r\n 0.9078 37.92%,\r\n 0.9405 43.12%,\r\n 0.965 48.84%,\r\n 0.9821 55.28%,\r\n 0.992 61.97%,\r\n 0.9976 70.09%,\r\n 1);\r\n}\r\n\r\n.response-output{\r\n background-color: #f5f5f5;\r\n border-radius: 8px;\r\n padding: 16px;\r\n}\r\n\r\n#DeepSeekProxyWrapper{\r\n display: flex;\r\n align-items: center;\r\n}\r\n\r\n.question-mark{\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n}\r\n\r\n.question-mark:hover{\r\n cursor: pointer;\r\n}\r\n', document.head.appendChild(style); var originalJson = {}; let showAnswer = !1; unsafeWindow.copyText = function(element) { const range = document.createRange(); range.selectNode(element), window.getSelection().removeAllRanges(), window.getSelection().addRange(range); try { document.execCommand("copy"), displaySuccessNotification("复制成功", "😀"); } catch (err) { alert("复制失败"); } window.getSelection().removeAllRanges(); }; const windowDiv = document.createElement("div"); windowDiv.id = "scriptWindow"; const initialPosition = function() { const position = settings.position, screenWidth = window.innerWidth, screenHeight = window.innerHeight; return position && position.left >= 0 && position.top >= 0 && position.left <= screenWidth && position.top <= screenHeight ? position : { left: 10, top: 10 }; }(); windowDiv.style.left = `${initialPosition.left}px`, windowDiv.style.top = `${initialPosition.top}px`; const header = document.createElement("div"); header.id = "window-header"; const zzxLogo = document.createElement("img"); zzxLogo.src = imageData.zzxLogo, zzxLogo.style.width = "20px"; const titleText = document.createElement("span"); titleText.innerHTML = "在浙学网课助手 v1.8", titleText.style.marginLeft = "10px"; const title = document.createElement("div"); title.style.display = "flex", title.appendChild(zzxLogo), title.appendChild(titleText), header.appendChild(title); const minimizeButton = document.createElement("button"); minimizeButton.style.backgroundColor = "transparent", minimizeButton.innerHTML = '\n \n \n \n \n ', minimizeButton.style.cursor = "pointer", header.appendChild(minimizeButton); const contentDiv = document.createElement("div"); contentDiv.style.display = "flex", contentDiv.style.height = "calc(100% - 40px)"; const navBar = document.createElement("div"); navBar.id = "window-navBar"; [ "🏠", "⚙️" ].forEach((page => { const pageLink = document.createElement("div"); pageLink.id = "window-pageLink", pageLink.textContent = page, pageLink.addEventListener("click", (() => { "⚙️" === page ? renderSettingsPage() : "🏠" === page ? renderHomePage() : "在线搜题" === page || (displayArea.innerHTML = page + " 内容"); })), pageLink.addEventListener("mouseenter", (() => { pageLink.style.backgroundColor = "#51AFEF", pageLink.style.color = "#fff"; })), pageLink.addEventListener("mouseleave", (() => { pageLink.style.backgroundColor = "transparent", pageLink.style.color = "#333"; })), navBar.appendChild(pageLink); })); const displayArea = document.createElement("div"); displayArea.style.flex = "1", displayArea.style.padding = "10px", displayArea.innerHTML = "内容显示", contentDiv.appendChild(navBar), contentDiv.appendChild(displayArea), windowDiv.appendChild(header), windowDiv.appendChild(contentDiv), document.body.appendChild(windowDiv); let isMinimized = !1; minimizeButton.addEventListener("click", (() => { isMinimized ? (contentDiv.style.display = "flex", windowDiv.style.height = "400px", minimizeButton.innerHTML = '\n \n \n \n \n ') : (contentDiv.style.display = "none", windowDiv.style.height = "50px", minimizeButton.innerHTML = '\n \n \n \n \n '), isMinimized = !isMinimized; })); let offsetX, offsetY, isDragging = !1; function onMouseMove(e) { if (isDragging) { const windowWidth = windowDiv.offsetWidth, windowHeight = windowDiv.offsetHeight, screenWidth = window.innerWidth, screenHeight = window.innerHeight; let newLeft = e.clientX - offsetX, newTop = e.clientY - offsetY; newLeft < 0 && (newLeft = 0), newLeft + windowWidth > screenWidth && (newLeft = screenWidth - windowWidth), newTop < 0 && (newTop = 0), newTop + windowHeight > screenHeight && (newTop = screenHeight - windowHeight), windowDiv.style.left = `${newLeft}px`, windowDiv.style.top = `${newTop}px`; } } function onMouseUp() { isDragging = !1, document.removeEventListener("mousemove", onMouseMove), document.removeEventListener("mouseup", onMouseUp); const newPosition = { left: windowDiv.offsetLeft, top: windowDiv.offsetTop }; settings.position = newPosition; } function toggleMute() { const videoElement = document.querySelector("video"), muteLabel = document.querySelector(".switch"), muteCheckbox = muteLabel ? muteLabel.querySelector('input[type="checkbox"]') : null; videoElement && (videoElement.muted = muteCheckbox.checked), settings.mute = muteCheckbox.checked; } function setVideoSpeed(speed) { const videoElement = document.querySelector("video"); videoElement && speed && (videoElement.playbackRate = parseFloat(speed)), settings.speed = speed; } function applySwitchStyles() { document.querySelectorAll(".switch").forEach((switchElement => { const checkbox = switchElement.querySelector(".checkbox"), slider = switchElement.querySelector(".slider"); checkbox.style.display = "none", slider.style.width = "60px", slider.style.height = "30px", slider.style.backgroundColor = "lightgray", slider.style.borderRadius = "20px", slider.style.overflow = "hidden", slider.style.display = "flex", slider.style.alignItems = "center", slider.style.border = "4px solid transparent", slider.style.transition = ".3s", slider.style.cursor = "pointer", slider.style.position = "relative"; const before = document.createElement("div"); before.style.content = '""', before.style.width = "100%", before.style.height = "100%", before.style.backgroundColor = "#fff", before.style.transform = "translateX(-30px)", before.style.borderRadius = "20px", before.style.transition = ".3s", before.style.position = "absolute", slider.appendChild(before), checkbox.addEventListener("change", (() => { checkbox.checked ? (slider.style.backgroundColor = "#2196F3", before.style.transform = "translateX(30px)") : (slider.style.backgroundColor = "lightgray", before.style.transform = "translateX(-30px)"); })), slider.addEventListener("mousedown", (() => { checkbox.checked || (before.style.transform = "translateX(0)"); })), slider.addEventListener("mouseup", (() => { checkbox.checked && (before.style.transform = "translateX(30px)"); })), checkbox.checked && (slider.style.backgroundColor = "#2196F3", before.style.transform = "translateX(30px)"); })); } function renderSettingsPage() { displayArea.innerHTML = ""; const userInfoContainer = document.createElement("div"); userInfoContainer.setAttribute("id", "userInfoContainer"), userInfoContainer.style.display = "flex", userInfoContainer.style.marginBottom = "10px"; const userInfo = document.createElement("div"); document.createElement("div").setAttribute("id", "avatarContainer"); const avatar = document.createElementNS("http://www.w3.org/2000/svg", "svg"); avatar.setAttribute("t", "1734414003129"), avatar.setAttribute("class", "icon"), avatar.setAttribute("viewBox", "0 0 1024 1024"), avatar.setAttribute("version", "1.1"), avatar.setAttribute("xmlns", "http://www.w3.org/2000/svg"), avatar.setAttribute("p-id", "15777"), avatar.setAttribute("width", "132"), avatar.setAttribute("height", "132"); const path1 = document.createElementNS("http://www.w3.org/2000/svg", "path"); path1.setAttribute("d", "M511.990738 510.660058H1.33068A510.660058 510.660058 0 1 0 511.990738 0 510.660058 510.660058 0 0 0 1.33068 510.660058z"), path1.setAttribute("fill", "#23a3f8"), path1.setAttribute("p-id", "15778"); const path2 = document.createElementNS("http://www.w3.org/2000/svg", "path"); path2.setAttribute("d", "M496.041101 430.881001h31.917798v95.753392h-31.917798z"), path2.setAttribute("fill", "#F4BAC2"), path2.setAttribute("p-id", "15779"); const path3 = document.createElementNS("http://www.w3.org/2000/svg", "path"); path3.setAttribute("d", "M287.41840599 469.33024634a223.418406 223.418406 0 1 0 223.418407-223.418407L287.41840599 245.91183934z"), path3.setAttribute("fill", "#FFFFFF"), path3.setAttribute("p-id", "15780"); const path4 = document.createElementNS("http://www.w3.org/2000/svg", "path"); path4.setAttribute("d", "M506.96055065 494.698072a15.078983 15.078983 0 0 1-15.955811-15.955812L491.00473965 414.919015a15.955811 15.955811 0 0 1 31.917797 0l0 63.835595a15.078983 15.078983 0 0 1-15.961986 15.943462z m111.709203-1e-8a15.078983 15.078983 0 0 1-15.955811-15.95581199L602.71394265 414.919015a15.955811 15.955811 0 0 1 31.917798 0l0 63.835595a15.078983 15.078983 0 0 1-15.961987 15.94346199z"), path4.setAttribute("fill", "#23a3f8"), path4.setAttribute("p-id", "15781"); const path5 = document.createElementNS("http://www.w3.org/2000/svg", "path"); path5.setAttribute("d", "M208.256063 921.250504c0-122.879506 101.069937-187.165865 223.949444-187.165865h159.582811c122.879506 0 222.072289 65.453405 222.07229 188.332911 0 0-109.486257 101.934416-300.097688 101.563925s-305.506856-102.730972-305.506857-102.730971z"), path5.setAttribute("fill", "#FFFFFF"), path5.setAttribute("p-id", "15782"), avatar.appendChild(path1), avatar.appendChild(path2), avatar.appendChild(path3), avatar.appendChild(path4), avatar.appendChild(path5), document.body.appendChild(avatar), avatar.setAttribute("id", "avatar"), avatar.style.width = "40px", avatar.style.height = "40px", avatar.style.marginLeft = "10px", userInfo.appendChild(avatar); const userTextContainer = document.createElement("div"); userTextContainer.setAttribute("id", "userTextContainer"), userTextContainer.style.display = "flex", userTextContainer.style.flexDirection = "column", userTextContainer.style.marginLeft = "10px"; const username = document.createElement("span"); username.textContent = settings.username, username.style.fontSize = "16px", username.style.fontWeight = "bold", username.setAttribute("id", "username"), userTextContainer.appendChild(username); const createTime = document.createElement("span"); createTime.setAttribute("id", "createTime"), createTime.textContent = settings.createTime + "注册", userTextContainer.appendChild(createTime); document.createElement("div").setAttribute("id", "uaerDataContainer"), LoggedWarpper.Logged ? userInfoContainer.style.display = "flex" : userInfoContainer.style.display = "none", userInfoContainer.appendChild(userInfo), userInfoContainer.appendChild(userTextContainer), displayArea.appendChild(userInfoContainer); const imgContainer = document.createElement("div"); imgContainer.setAttribute("id", "imgContainer"), LoggedWarpper.Logged ? imgContainer.style.display = "none" : imgContainer.style.display = "flex", imgContainer.style.width = "100%", imgContainer.style.marginBottom = "20px"; const imge = document.createElement("img"); imge.src = imageData.weChatQr, imge.style.width = "50%", imgContainer.appendChild(imge); const rightContainer = document.createElement("div"); rightContainer.style.width = "50%", rightContainer.style.alignContent = "center", rightContainer.style.justifyItems = "center"; const instructions = document.createElement("instructions"), span1 = document.createElement("span"), fingerImg = document.createElement("img"); fingerImg.src = imageData.fingerEmoji, fingerImg.style.width = "16.8px", instructions.appendChild(fingerImg), span1.innerHTML = "关注公众号", span1.style.fontFamily = "SmileySans-Oblique, sans-serif", span1.style.fontSize = "12px"; const span2 = document.createElement("span"); span2.innerHTML = "未耕之地", span2.style.color = "#03a9f5", span2.style.fontFamily = "SmileySans-Oblique, sans-serif", span2.style.fontSize = "12px"; const div2 = document.createElement("div"), span3 = document.createElement("span"); span3.innerHTML = "发送验证码完成登录", span3.style.fontFamily = "SmileySans-Oblique, sans-serif", span3.style.fontSize = "12px", div2.appendChild(span3), instructions.appendChild(span1), instructions.appendChild(span2), instructions.appendChild(div2); const text = document.createElement("p"); text.innerHTML = "验证码:", text.style.fontFamily = "SmileySans-Oblique, sans-serif"; const btn = createButton("点击生成", (async () => { await toggleButtonState(btn, !0, LoggedWarpper); })); if (LoggedWarpper.code) { const iconContainer = btn.querySelector(".icon"); btn.classList.add("loading"), iconContainer.innerHTML = `
${LoggedWarpper.code}
`, btn.disabled = !0; } rightContainer.appendChild(instructions), rightContainer.appendChild(text), rightContainer.appendChild(btn), imgContainer.appendChild(rightContainer); const examModeLabel = document.createElement("label"); examModeLabel.classList.add("switch"); const examModeCheckbox = document.createElement("input"); examModeCheckbox.type = "checkbox", examModeCheckbox.classList.add("checkbox"), examModeCheckbox.classList.add("examMode"); const sliderDiv = document.createElement("div"); sliderDiv.classList.add("slider"); const examModeText = document.createElement("span"); examModeText.textContent = "考试模式", examModeText.style.whiteSpace = "nowrap", examModeText.style.marginRight = "112px"; const examModeWrapper = document.createElement("div"); examModeWrapper.style.display = "flex", examModeWrapper.style.width = "89%", examModeWrapper.style.alignItems = "center", examModeWrapper.style.justifyContent = "flex-start", examModeWrapper.style.marginTop = "8px", examModeWrapper.style.marginBottom = "0px", examModeWrapper.appendChild(examModeText), examModeWrapper.appendChild(examModeLabel), examModeCheckbox.checked = settings.examMode, examModeCheckbox.addEventListener("change", toggleExamMode), examModeLabel.appendChild(examModeCheckbox), examModeLabel.appendChild(sliderDiv); const DeepSeekProxyLabel = document.createElement("label"); DeepSeekProxyLabel.classList.add("switch"); const DeepSeekProxyCheckbox = document.createElement("input"); DeepSeekProxyCheckbox.type = "checkbox", DeepSeekProxyCheckbox.classList.add("checkbox"), DeepSeekProxyCheckbox.classList.add("examMode"); const sliderDiv2 = document.createElement("div"); sliderDiv2.classList.add("slider"), DeepSeekProxyLabel.appendChild(DeepSeekProxyCheckbox), DeepSeekProxyLabel.appendChild(sliderDiv2); const DeepSeekProxyText = document.createElement("span"); DeepSeekProxyText.textContent = "DeepSeekProxy", DeepSeekProxyText.style.whiteSpace = "nowrap", DeepSeekProxyText.style.marginRight = "0px"; const DeepSeekProxyWrapper = document.createElement("div"); DeepSeekProxyWrapper.setAttribute("id", "DeepSeekProxyWrapper"), DeepSeekProxyWrapper.style.display = "flex", DeepSeekProxyWrapper.style.width = "89%", DeepSeekProxyWrapper.style.alignItems = "center", DeepSeekProxyWrapper.style.justifyContent = "flex-start", DeepSeekProxyWrapper.style.marginBottom = "0px", DeepSeekProxyWrapper.appendChild(DeepSeekProxyText); const questionMark = document.createElement("div"); questionMark.addEventListener("click", (() => { window.open("https://pages.zaizhexue.top/home/DeepSeek"); })), questionMark.classList.add("question-mark"), questionMark.innerHTML = '', questionMark.style.marginLeft = "4px", questionMark.style.marginRight = "40px", DeepSeekProxyWrapper.appendChild(questionMark), DeepSeekProxyWrapper.appendChild(DeepSeekProxyLabel), DeepSeekProxyCheckbox.checked = settings.deepseekProxy, console.log("deepseekProxy", settings.deepseekProxy), DeepSeekProxyCheckbox.addEventListener("change", (() => { console.log("deepseekProxy1", settings.deepseekProxy), settings.deepseekProxy = !settings.deepseekProxy, console.log("deepseekProxy2", settings.deepseekProxy); })), displayArea.appendChild(DeepSeekProxyWrapper); const apiSettingText = document.createElement("span"); apiSettingText.textContent = "DeepSeek API Key", apiSettingText.style.fontFamily = "SmileySans-Oblique, sans-serif", apiSettingText.style.fontSize = "14px", apiSettingText.style.paddingBottom = "10px"; const apiSettingText2 = document.createElement("span"); apiSettingText2.textContent = "(可选,用于AI解析)", apiSettingText2.style.fontFamily = "SmileySans-Oblique, sans-serif", apiSettingText2.style.color = "#888"; const apiSettingContainer = document.createElement("div"); apiSettingContainer.setAttribute("id", "apiSettingContainer"), apiSettingContainer.style.display = "flex", apiSettingContainer.style.alignContent = "center"; const deepSeekApiKey = document.createElement("input"); deepSeekApiKey.type = "text", deepSeekApiKey.style.width = "100%", deepSeekApiKey.style.padding = "8px", deepSeekApiKey.style.marginRight = "4px", deepSeekApiKey.style.boxSizing = "border-box", deepSeekApiKey.style.border = "2px solid #ccc", deepSeekApiKey.style.borderRadius = "8px", deepSeekApiKey.style.fontSize = "16px", deepSeekApiKey.style.outline = "none", deepSeekApiKey.value = settings.deepseekApiKey, deepSeekApiKey.addEventListener("focus", (() => { deepSeekApiKey.style.border = "2px solid #4A90E2"; })), deepSeekApiKey.addEventListener("blur", (() => { deepSeekApiKey.style.border = "2px solid #ccc"; })); const saveButton = createPushButton({ className: "save-btn large", text: "保存", onClick: () => settings.deepseekApiKey = deepSeekApiKey.value }); apiSettingContainer.appendChild(deepSeekApiKey), apiSettingContainer.appendChild(saveButton), displayArea.appendChild(imgContainer), displayArea.appendChild(examModeWrapper); const infoTextExam = document.createElement("p"); infoTextExam.innerHTML = '开启考试模式后窗口将默认隐藏,您可以通过快捷键F9开关窗口,F2开关答案显示,所有提示弹窗将不会显示', infoTextExam.style.marginTop = "5px", infoTextExam.style.marginBottom = "20px", infoTextExam.style.fontSize = "12px", infoTextExam.style.color = "rgb(138,138,138)", displayArea.appendChild(infoTextExam), applySwitchStyles(); } function renderHomePage() { displayArea.innerHTML = ""; const buttonContainer = document.createElement("div"); buttonContainer.style.display = "flex", buttonContainer.style.flexDirection = "column", buttonContainer.style.justifyContent = "flex-start", buttonContainer.style.gap = "20px", buttonContainer.style.marginTop = "20px"; const showAnswerButton = document.createElement("button"); showAnswerButton.textContent = showAnswer ? "隐藏答案" : "显示答案", showAnswerButton.classList.add("showAnswerButton"), showAnswerButton.style.padding = "12.5px 30px", showAnswerButton.style.border = "0", showAnswerButton.style.borderRadius = "10px", showAnswerButton.style.marginLeft = "10px", showAnswerButton.style.marginRight = "10px", showAnswerButton.style.backgroundColor = "#2ba8fb", showAnswerButton.style.color = "#ffffff", showAnswerButton.style.fontWeight = "Bold", showAnswerButton.style.transition = "all 0.2s", showAnswerButton.style.webkitTransition = "all 0.2s", showAnswerButton.addEventListener("click", (async () => { await toggleModifiedElements(); })), showAnswerButton.addEventListener("mouseenter", (() => { showAnswerButton.style.backgroundColor = "#6fc5ff", showAnswerButton.style.boxShadow = "0 0 20px #6fc5ff50", showAnswerButton.style.transform = "scale(1.1)"; })), showAnswerButton.addEventListener("mouseleave", (() => { showAnswerButton.style.backgroundColor = "#2ba8fb", showAnswerButton.style.boxShadow = "none", showAnswerButton.style.transform = "scale(1)"; })), showAnswerButton.addEventListener("mousedown", (() => { showAnswerButton.style.transform = "scale(0.98)"; })), showAnswerButton.addEventListener("mouseup", (() => { showAnswerButton.style.transform = "scale(1.1)"; })); const syncButton = document.createElement("button"); syncButton.textContent = "解除复制限制", syncButton.style.padding = "12.5px 30px", syncButton.style.border = "0", syncButton.style.borderRadius = "10px", syncButton.style.marginLeft = "10px", syncButton.style.marginRight = "10px", syncButton.style.backgroundColor = "#2ba8fb", syncButton.style.color = "#ffffff", syncButton.style.fontWeight = "Bold", syncButton.style.transition = "all 0.2s", syncButton.style.webkitTransition = "all 0.2s", syncButton.addEventListener("click", initializeEditorSync), syncButton.addEventListener("mouseenter", (() => { syncButton.style.backgroundColor = "#6fc5ff", syncButton.style.boxShadow = "0 0 20px #6fc5ff50", syncButton.style.transform = "scale(1.1)"; })), syncButton.addEventListener("mouseleave", (() => { syncButton.style.backgroundColor = "#2ba8fb", syncButton.style.boxShadow = "none", syncButton.style.transform = "scale(1)"; })), syncButton.addEventListener("mousedown", (() => { syncButton.style.transform = "scale(0.98)"; })), syncButton.addEventListener("mouseup", (() => { syncButton.style.transform = "scale(1.1)"; })); const autoplayButton = document.createElement("button"); autoplayButton.setAttribute("id", "autoplay-button-id"), autoplayButton.textContent = isPlaying ? "停止自动播放" : "自动播放", autoplayButton.style.padding = "12.5px 30px", autoplayButton.style.border = "0", autoplayButton.style.borderRadius = "10px", autoplayButton.style.marginLeft = "10px", autoplayButton.style.marginRight = "10px", autoplayButton.style.backgroundColor = "#2ba8fb", autoplayButton.style.color = "#ffffff", autoplayButton.style.fontWeight = "Bold", autoplayButton.style.transition = "all 0.2s", autoplayButton.style.webkitTransition = "all 0.2s", autoplayButton.addEventListener("click", (async function() { if ("自动播放" === autoplayButton.innerText) { isPlaying = !0, autoplayButton.innerText = "停止自动播放", CourseChapters && 0 !== Object.keys(CourseChapters).length || (CourseChapters = JSON.parse(localStorage.getItem("CourseChapters"))), stopAnimation = createFloatingImageWorld(); const msg = await autoPlay(CourseChapters, listenRouteWarpper); console.log(msg), "error" === msg[0] ? (console.log(msg[1]), displayErrorNotification("页面错误", [ msg[1] ])) : (console.log(msg[1]), displaySuccessNotification(msg[1], "")), autoplayButton.innerText = "自动播放", isPlaying = !1, stopAnimation(); } else isPlaying = !1, stopAutoPlay(), autoplayButton.innerText = "自动播放", stopAnimation(); })), autoplayButton.addEventListener("mouseenter", (() => { autoplayButton.style.backgroundColor = "#6fc5ff", autoplayButton.style.boxShadow = "0 0 20px #6fc5ff50", autoplayButton.style.transform = "scale(1.1)"; })), autoplayButton.addEventListener("mouseleave", (() => { autoplayButton.style.backgroundColor = "#2ba8fb", autoplayButton.style.boxShadow = "none", autoplayButton.style.transform = "scale(1)"; })), autoplayButton.addEventListener("mousedown", (() => { autoplayButton.style.transform = "scale(0.98)"; })), autoplayButton.addEventListener("mouseup", (() => { autoplayButton.style.transform = "scale(1.1)"; })); const muteLabel = document.createElement("label"); muteLabel.classList.add("switch"); const muteCheckbox = document.createElement("input"); muteCheckbox.type = "checkbox", muteCheckbox.classList.add("checkbox"); const sliderDiv = document.createElement("div"); sliderDiv.classList.add("slider"), muteLabel.appendChild(muteCheckbox), muteLabel.appendChild(sliderDiv); const muteText = document.createElement("span"); muteText.textContent = "视频静音", muteText.style.marginRight = "10px"; const muteWrapper = document.createElement("div"); muteWrapper.style.display = "flex", muteWrapper.style.width = "89%", muteWrapper.style.alignItems = "center", muteWrapper.style.justifyContent = "flex-start", muteWrapper.style.marginBottom = "0px", muteWrapper.appendChild(muteText), muteWrapper.appendChild(muteLabel), muteCheckbox.checked = settings.mute, muteCheckbox.addEventListener("change", toggleMute); const bodyContainer = document.createElement("div"); bodyContainer.classList.add("body-container"); const speedText = document.createElement("div"); speedText.textContent = "视频倍速", speedText.style.textAlign = "left", speedText.style.marginBottom = "8px"; const radioInputDiv = document.createElement("div"); radioInputDiv.classList.add("radio-input"); const currentSpeed = settings.speed, label1 = document.createElement("label"), input1 = document.createElement("input"); input1.type = "radio", input1.name = "fav_language", input1.id = "value-1", input1.value = "1"; const span1 = document.createElement("span"); span1.textContent = "1", label1.appendChild(input1), label1.appendChild(span1), input1.addEventListener("change", (e => { e.target.checked && setVideoSpeed(e.target.value); })), input1.value === currentSpeed && (input1.checked = !0); const label2 = document.createElement("label"), input2 = document.createElement("input"); input2.type = "radio", input2.name = "fav_language", input2.id = "value-2", input2.value = "2"; const span2 = document.createElement("span"); span2.textContent = "2", label2.appendChild(input2), label2.appendChild(span2), input2.addEventListener("change", (e => { e.target.checked && setVideoSpeed(e.target.value); })), input2.value === currentSpeed && (input2.checked = !0); const label3 = document.createElement("label"), input3 = document.createElement("input"); input3.type = "radio", input3.name = "fav_language", input3.id = "value-3", input3.value = "3"; const span3 = document.createElement("span"); span3.textContent = "3", label3.appendChild(input3), label3.appendChild(span3), input3.addEventListener("change", (e => { e.target.checked && setVideoSpeed(e.target.value); })), input3.value === currentSpeed && (input3.checked = !0); const label4 = document.createElement("label"), input4 = document.createElement("input"); input4.type = "radio", input4.name = "fav_language", input4.id = "value-4", input4.value = "4"; const span4 = document.createElement("span"); span4.textContent = "4", label4.appendChild(input4), label4.appendChild(span4), label4.appendChild(span4), input4.addEventListener("change", (e => { e.target.checked && setVideoSpeed(e.target.value); })), input4.value === currentSpeed && (input4.checked = !0); const selection1 = document.createElement("span"); selection1.classList.add("selection"); const selection2 = document.createElement("span"); selection2.classList.add("selection2"), radioInputDiv.appendChild(label1), radioInputDiv.appendChild(label2), radioInputDiv.appendChild(label3), radioInputDiv.appendChild(label4), radioInputDiv.appendChild(selection1), radioInputDiv.appendChild(selection2), bodyContainer.appendChild(speedText), bodyContainer.appendChild(radioInputDiv), buttonContainer.appendChild(showAnswerButton), buttonContainer.appendChild(syncButton), buttonContainer.appendChild(autoplayButton), buttonContainer.appendChild(muteWrapper), buttonContainer.appendChild(bodyContainer), displayArea.appendChild(buttonContainer), applySwitchStyles(); } function displaySuccessNotification(heading, prompt) { if (settings.examMode) return; const notificationContainer = document.createElement("div"); notificationContainer.className = "notifications-container"; const notificationHTML = `\n
\n
\n
\n \n
\n
\n

${heading}

\n
${prompt}
\n
\n
\n
\n `; notificationContainer.innerHTML = notificationHTML; const style = document.createElement("style"); style.textContent = "\n .notifications-container {\n width: 320px;\n height: auto;\n font-size: 0.875rem;\n line-height: 1.25rem;\n display: flex;\n flex-direction: column;\n gap: 1rem;\n position: fixed;\n top: 20px;\n right: 20px;\n z-index: 9999;\n }\n\n .flex {\n display: flex;\n }\n\n .flex-shrink-0 {\n flex-shrink: 0;\n }\n\n .success {\n padding: 1rem;\n border-radius: 0.375rem;\n background-color: rgb(240 253 244);\n box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);\n }\n\n .succes-svg {\n color: rgb(74 222 128);\n width: 1.25rem;\n height: 1.25rem;\n }\n\n .success-prompt-wrap {\n margin-left: 0.75rem;\n }\n\n .success-prompt-heading {\n font-weight: bold;\n color: rgb(22 101 52);\n }\n\n .success-prompt-prompt {\n margin-top: 0.5rem;\n color: rgb(21 128 61);\n }\n ", document.head.appendChild(style), document.body.appendChild(notificationContainer), setTimeout((() => { notificationContainer.remove(); }), 3e3); } function displayErrorNotification(heading, details) { if (settings.examMode) return; const notificationContainer = document.createElement("div"); notificationContainer.className = "notifications-container"; const notificationHTML = `\n
\n
\n
\n \n
\n
\n

${heading}

\n
\n
    \n ${details.map((item => `
  • ${item}
  • `)).join("")}\n
\n
\n
\n
\n
\n `; notificationContainer.innerHTML = notificationHTML, notificationContainer.style.cssText = "\n position: fixed;\n top: 20px;\n right: 20px;\n z-index: 9999;\n opacity: 0;\n animation: fadeIn 0.5s forwards, fadeOut 0.5s forwards 3s;\n ", document.body.appendChild(notificationContainer); const style = document.createElement("style"); style.textContent = "\n .notifications-container {\n width: 320px;\n height: auto;\n font-size: 0.875rem;\n line-height: 1.25rem;\n display: flex;\n flex-direction: column;\n gap: 1rem;\n }\n\n .flex {\n display: flex;\n }\n\n .flex-shrink-0 {\n flex-shrink: 0;\n }\n\n .error-alert {\n border-radius: 0.375rem;\n padding: 1rem;\n background-color: rgb(254 242 242);\n box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);\n }\n\n .error-svg {\n color: #F87171;\n width: 1.25rem;\n height: 1.25rem;\n }\n\n .error-prompt-heading {\n color: #991B1B;\n font-size: 0.875rem;\n line-height: 1.25rem;\n font-weight: bold;\n }\n\n .error-prompt-container {\n display: flex;\n flex-direction: column;\n margin-left: 1.25rem;\n }\n\n .error-prompt-wrap {\n margin-top: 0.5rem;\n color: #B91C1C;\n font-size: 0.875rem;\n line-height: 1.25rem;\n }\n\n .error-prompt-list {\n padding-left: 1.25rem;\n margin-top: 0.25rem;\n list-style-type: disc;\n }\n\n @keyframes fadeIn {\n from { opacity: 0; transform: translateY(-20px); }\n to { opacity: 1; transform: translateY(0); }\n }\n\n @keyframes fadeOut {\n from { opacity: 1; transform: translateY(0); }\n to { opacity: 0; transform: translateY(-20px); }\n }\n ", document.head.querySelector("#error-notification-styles") || (style.id = "error-notification-styles", document.head.appendChild(style)), setTimeout((() => { notificationContainer.remove(); }), 4e3); } function toggleExamMode() { document.querySelectorAll(".modified").forEach((element => { element.remove(); })), settings.examMode = !settings.examMode, console.log(settings.examMode), showAnswer && displayRightAnswers(); } header.addEventListener("mousedown", (e => { isDragging = !0, offsetX = e.clientX - windowDiv.offsetLeft, offsetY = e.clientY - windowDiv.offsetTop, document.addEventListener("mousemove", onMouseMove), document.addEventListener("mouseup", onMouseUp); })), settings.token ? async function(retries = 3) { const attemptFetch = async retryCount => { try { const response = await fetch("https://app.zaizhexue.top/validateToken", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify({ token: settings.token }) }); if (!response.ok) throw await response.json(); { const data = await response.json(); LoggedWarpper.Logged = !0; let userInfoContainer = document.getElementById("userInfoContainer"); userInfoContainer && (userInfoContainer.style.display = "flex"); let imgContainer = document.getElementById("imgContainer"); imgContainer && (imgContainer.style.display = "none"); const usernameElement = document.getElementById("username"); usernameElement && (usernameElement.innerHTML = data.user.nickname), settings.username = data.user.nickname; const createTimeElement = document.getElementById("createTime"), userCreatedTime = new Date(data.user.createdTime), formattedDate = `${userCreatedTime.getMonth() + 1}/${userCreatedTime.getDate()}/${userCreatedTime.getFullYear()}`; createTimeElement && (createTimeElement.innerHTML = formattedDate + "注册"), settings.createTime = formattedDate, renderHomePage(); } } catch (error) { if (console.error("Error:", error), retryCount > 0) return await new Promise((resolve => setTimeout(resolve, 1e3))), attemptFetch(retryCount - 1); "Token expired" === error.error ? displayErrorNotification("登录过期", [ "已过期,请重新登录" ]) : displayErrorNotification("登录信息出错", [ "请重新登录" ]), settings.token = "", renderSettingsPage(); } }; await attemptFetch(retries); }() : (LoggedWarpper.Logged = !1, renderSettingsPage()), function(LoggedWarpper) { const currentPath = window.location.pathname; "/dist" !== currentPath && "/dist/" !== currentPath || (console.log("跳转到根路径"), window.location.href = "/", LoggedWarpper.Logged = !0); }(); let cachedPaperSubjectList = null, alerted = 0; function displayAnswersRecursively(questions, subject, index) { if (!(subject.rightAnswer || subject.childrenList && 0 !== subject.childrenList.length || 0 != alerted)) return alert("请求中没有答案"), void (alerted = 1); if (subject.rightAnswer && questions[index]) { const answerElement = document.createElement("div"); answerElement.style.color = "green", answerElement.style.fontWeight = "bold", answerElement.className = "answer-display", answerElement.classList.add("modified"); const isHtml = /<[^>]*>/g.test(subject.rightAnswer); if (7 == subject.subjectType) { let formattedAnswers = ""; if (settings.examMode) { let rawAnswer = subject.rightAnswer.replace(/\|/g, ","); JSON.parse(rawAnswer).forEach(((answerSet, idx) => { const answerToDisplay = Array.isArray(answerSet) && answerSet.length > 0 ? answerSet[0] : answerSet; formattedAnswers += `${answerToDisplay} `; })), formattedAnswers = formattedAnswers.trim(), console.log(formattedAnswers), insertIntoDeepestElement(questions[index], formattedAnswers); } else { console.log("填空题"); let rawAnswer = subject.rightAnswer.replace(/\|/g, ","), parsedAnswers = JSON.parse(rawAnswer); const fillBlankDivs = questions[index].querySelectorAll(".el-row"); if (fillBlankDivs && fillBlankDivs.length == parsedAnswers.length) fillBlankDivs.forEach(((div, idx) => { if (parsedAnswers[idx]) { const individualAnswer = document.createElement("div"); individualAnswer.style.color = "blue", individualAnswer.classList.add("modified"), Array.isArray(parsedAnswers[idx]) && parsedAnswers[idx].length > 1 ? individualAnswer.innerHTML = `第${idx + 1}问:
${parsedAnswers[idx].map((ans => `${ans}`)).join(" ")}(只用填一个,多填不给分)` : individualAnswer.innerHTML = `第${idx + 1}问: ${parsedAnswers[idx]}`, div.appendChild(individualAnswer); } })); else { try { parsedAnswers.forEach(((answerSet, idx) => { Array.isArray(answerSet) && answerSet.length > 1 ? formattedAnswers += `第${idx + 1}问:
${answerSet.map((ans => `${ans}`)).join(" ")}(只用填一个,多填不给分)
` : formattedAnswers += `第${idx + 1}问: ${answerSet}
`; })), formattedAnswers = formattedAnswers.trim(), answerElement.innerHTML = `正确答案:
${formattedAnswers}`; } catch (e) { console.error("Failed to parse rightAnswer:", subject.rightAnswer, e), answerElement.textContent = "正确答案: 格式错误"; } questions[index].appendChild(answerElement); } } } else settings.examMode ? insertIntoDeepestElement(questions[index], subject.rightAnswer) : (isHtml ? answerElement.innerHTML = `正确答案:
${subject.rightAnswer}` : answerElement.textContent = `正确答案: ${subject.rightAnswer}`, questions[index].appendChild(answerElement)); } if (subject.childrenList && Array.isArray(subject.childrenList)) { const subquestions = questions[index].querySelectorAll(".questiono-main"); subject.childrenList.forEach(((child, index) => { displayAnswersRecursively(subquestions, child, index); })); } } function checkRightAnswer(obj) { if (!obj || !obj.data || !Array.isArray(obj.data.paperSubjectList)) return !1; for (const subject of obj.data.paperSubjectList) { if ("rightAnswer" in subject) return !0; if (subject.childrenList) for (const child of subject.childrenList) if ("rightAnswer" in child) return !0; } return !1; } async function fetchOriginalJson(id, needData = !0) { try { console.log("正在发请求"); const token = settings.token, response = await fetch(`https://app.zaizhexue.top/originalJson?id=${id}&need_data=${needData}&token=${token}`); if (!response.ok) throw new Error(`Error: ${response.statusText}`); return await response.json(); } catch (error) { return console.error("Failed to fetch original JSON:", error), null; } } async function displayRightAnswers() { if (document.querySelectorAll(".modified").length > 0) return; const questions = document.querySelectorAll(".questiono-item"); questions.length > 0 && questions.forEach((question => { insertButtonAndFetchContent(question); })); if (!settings.token) return void displayErrorNotification("请先登录", [ "未登录状态不能使用显示答案功能,其他功能不受限" ]); const originalJsonCopy = JSON.parse(localStorage.getItem("originalJsonCopy")), TitleP = document.querySelector("div.top_title p"), TitleH6 = document.querySelector("h6"), title = TitleP ? TitleP.textContent : TitleH6.textContent; if (originalJsonCopy.data.paperName.trim() == title.trim() ? (console.log("相同"), cachedPaperSubjectList = (originalJson = originalJsonCopy).data.paperSubjectList) : (console.log(originalJsonCopy.data.paperName.trim()), console.log(title.trim())), console.log("DOM中的标题:", title), !originalJson || !originalJson.data || void 0 === originalJson.data.id) return console.error("Invalid originalJson structure or missing id"), displayErrorNotification("无法获取试卷ID", [ "不用担心,这可能是因为你刷新了页面,退出后重新进入答题即可" ]), void console.log(originalJson); if (!checkRightAnswer(originalJson)) { const paperId = originalJson.data.id; try { originalJson = await fetchOriginalJson(paperId), localStorage.setItem("originalJsonCopy", JSON.stringify(originalJson)), console.log("已经存储"); } catch (error) { return console.error("Error fetching new originalJson:", error), void displayErrorNotification("很抱歉", [ "暂时没有答案" ]); } } const customOrder = [ 1, 2, 3, 10, 11, 5, 7, 8, 9 ], sortedSubjects = [ ...cachedPaperSubjectList ].sort(((a, b) => customOrder.indexOf(a.subjectType || 0) - customOrder.indexOf(b.subjectType || 0))); if (questions.length > 0) { if (!checkRightAnswer(originalJson)) return void displayErrorNotification("很抱歉", [ "暂时没有答案" ]); sortedSubjects.forEach(((subject, index) => { displayAnswersRecursively(questions, subject, index); })); } else { const indexbox = document.querySelector(".index_box"); if (!indexbox) return void displayErrorNotification("未在页面上找到题目", [ "请在答题页面中尝试显示答案" ]); if (indexbox.querySelectorAll("li").forEach((li => { if (li.classList.contains("show_select")) { const questionTitle = document.querySelector(".question_content .question_title").textContent.trim().replace(/\s+/g, ""), matchedSubject = sortedSubjects.find((subject => { const tempDiv = document.createElement("div"); return tempDiv.innerHTML = subject.subjectName, tempDiv.textContent.trim().replace(/\s+/g, ""), console.log(tempDiv.textContent.trim().replace(/\s+/g, "")), tempDiv.textContent.trim().replace(/\s+/g, "") === questionTitle; })); matchedSubject ? console.log("Found matched subject:", matchedSubject) : console.log("No matching subject found."), handleClick(matchedSubject); } })), indexbox) { const buttons = document.querySelectorAll("button"), previousButton = Array.from(buttons).find((button => "上一题" === button.textContent.trim())), nextButton = Array.from(buttons).find((button => "下一题" === button.textContent.trim())); indexbox.querySelectorAll("li").forEach((li => { li.addEventListener("click", (() => { const questionTitle = document.querySelector(".question_content .question_title").textContent.trim().replace(/\s+/g, ""); console.log(questionTitle); const matchedSubject = sortedSubjects.find((subject => { const tempDiv = document.createElement("div"); return tempDiv.innerHTML = subject.subjectName, tempDiv.textContent.trim().replace(/\s+/g, ""), console.log(tempDiv.textContent.trim().replace(/\s+/g, "")), tempDiv.textContent.trim().replace(/\s+/g, "") === questionTitle; })); if (matchedSubject) console.log("Found matched subject:", matchedSubject); else { console.log("No matching subject found."); document.querySelectorAll(".answer-display").forEach((el => el.remove())); } showAnswer && handleClick(matchedSubject); })); })); for (const button of [ previousButton, nextButton ]) button.addEventListener("click", (() => { const questionTitle = document.querySelector(".question_content .question_title").textContent.trim().replace(/\s+/g, ""); console.log(questionTitle); const matchedSubject = sortedSubjects.find((subject => { const tempDiv = document.createElement("div"); return tempDiv.innerHTML = subject.subjectName, tempDiv.textContent.trim().replace(/\s+/g, ""), console.log(tempDiv.textContent.trim().replace(/\s+/g, "")), tempDiv.textContent.trim().replace(/\s+/g, "") === questionTitle; })); if (matchedSubject) console.log("Found matched subject:", matchedSubject); else { console.log("No matching subject found."); document.querySelectorAll(".answer-display").forEach((el => el.remove())); } showAnswer && handleClick(matchedSubject); })); } else console.error("没有找到 .index_box 元素"); } } function handleClick(subject) { document.querySelectorAll(".modified").forEach((el => el.remove())); const question_content = document.querySelector(".question_content"), answerElement = document.createElement("div"); if (answerElement.style.color = "green", answerElement.style.fontWeight = "bold", answerElement.className = "answer-display", answerElement.classList.add("modified"), insertButtonAndFetchContent(question_content), !subject) return; const isHtml = /<[^>]*>/g.test(subject.rightAnswer); if (7 == subject.subjectType) { let rawAnswer = subject.rightAnswer.replace(/\|/g, ","), parsedAnswers = JSON.parse(rawAnswer), formattedAnswers = ""; if (settings.examMode) { let rawAnswer = subject.rightAnswer.replace(/\|/g, ","); JSON.parse(rawAnswer).forEach(((answerSet, idx) => { const answerToDisplay = Array.isArray(answerSet) && answerSet.length > 0 ? answerSet[0] : answerSet; formattedAnswers += `${answerToDisplay} `; })), formattedAnswers = formattedAnswers.trim(), console.log(formattedAnswers), insertIntoDeepestElement(question_content, formattedAnswers); } else console.log("正常"), console.log(question_content), setTimeout((() => { const blanks_box = question_content.querySelectorAll(".blanks_box"); if (blanks_box ? console.log(blanks_box) : console.log("元素未找到"), blanks_box) blanks_box.forEach(((div, idx) => { if (parsedAnswers[idx]) { const individualAnswer = document.createElement("div"); individualAnswer.style.color = "blue", individualAnswer.classList.add("modified"), Array.isArray(parsedAnswers[idx]) && parsedAnswers[idx].length > 1 ? individualAnswer.innerHTML = `第${idx + 1}问:
${parsedAnswers[idx].map((ans => `${ans}`)).join(" ")}(只用填一个,多填不给分)` : individualAnswer.innerHTML = `第${idx + 1}问: ${parsedAnswers[idx]}`, div.appendChild(individualAnswer); } })); else { try { parsedAnswers.forEach((answerSet => { Array.isArray(answerSet) && answerSet.length > 1 ? formattedAnswers += answerSet.join(",") + "(只用填一个,多填不给分)\n" : formattedAnswers += answerSet + "\n"; })), formattedAnswers = formattedAnswers.trim(), answerElement.innerHTML = `正确答案:
${formattedAnswers.replace(/\n/g, "
")}`; } catch (e) { console.error("Failed to parse rightAnswer:", subject.rightAnswer, e), answerElement.textContent = "正确答案: 格式错误"; } question_content.appendChild(answerElement); } }), 200); } else settings.examMode ? insertIntoDeepestElement(question_content, subject.rightAnswer) : (isHtml ? (console.log("标签"), answerElement.innerHTML = `${subject.rightAnswer}`) : answerElement.textContent = `正确答案: ${subject.rightAnswer}`, question_content.appendChild(answerElement)); if (subject.childrenList && subject.childrenList.length > 0) { const liElements = question_content.querySelectorAll("li"); subject.childrenList.forEach(((child, i) => { console.log("遍历子题"); const isHtml_ = /<[^>]*>/g.test(subject.rightAnswer); if (7 == child.subjectType) { let rawAnswer = child.rightAnswer.replace(/\|/g, ","), parsedAnswers = JSON.parse(rawAnswer), formattedAnswers = ""; if (settings.examMode) { let rawAnswer = subject.rightAnswer.replace(/\|/g, ","); JSON.parse(rawAnswer).forEach(((answerSet, idx) => { const answerToDisplay = Array.isArray(answerSet) && answerSet.length > 0 ? answerSet[0] : answerSet; formattedAnswers += `${answerToDisplay} `; })), formattedAnswers = formattedAnswers.trim(), console.log(formattedAnswers), insertIntoDeepestElement(liElements[i], formattedAnswers); } else { const blanks_box = liElements[i].querySelectorAll(".blanks_box"); if (blanks_box) blanks_box.forEach(((div, idx) => { if (parsedAnswers[idx]) { const individualAnswer = document.createElement("div"); individualAnswer.style.color = "blue", individualAnswer.classList.add("modified"), Array.isArray(parsedAnswers[idx]) && parsedAnswers[idx].length > 1 ? individualAnswer.innerHTML = `第${idx + 1}问:
${parsedAnswers[idx].map((ans => `${ans}`)).join(" ")}(只用填一个,多填不给分)` : individualAnswer.innerHTML = `第${idx + 1}问: ${parsedAnswers[idx]}`, div.appendChild(individualAnswer); } })); else { try { parsedAnswers.forEach((answerSet => { Array.isArray(answerSet) && answerSet.length > 1 ? formattedAnswers += answerSet.join(",") + "(只用填一个,多填不给分)\n" : formattedAnswers += answerSet + "\n"; })), formattedAnswers = formattedAnswers.trim(), answerElement.innerHTML = `正确答案:
${formattedAnswers.replace(/\n/g, "
")}`; } catch (e) { console.error("Failed to parse rightAnswer:", subject.rightAnswer, e), answerElement.textContent = "正确答案: 格式错误"; } liElements[i].appendChild(answerElement); } } } else { const newElement = document.createElement("span"); newElement.classList.add("modified"), settings.examMode ? insertIntoDeepestElement(question_content, subject.rightAnswer) : (isHtml_ ? newElement.innerHTML = `正确答案:
${subject.rightAnswer}` : newElement.textContent = `正确答案: ${subject.rightAnswer}`, liElements[index].appendChild(newElement)); } })); } } var open; open = XMLHttpRequest.prototype.open, XMLHttpRequest.prototype.open = function(method, url, async, user, password) { this.addEventListener("load", (async function() { try { if ("GET" === method.toUpperCase()) { const response = JSON.parse(this.responseText); if (response.data && response.data.paperSubjectList && (cachedPaperSubjectList = response.data.paperSubjectList, (originalJson = response) && originalJson.data && originalJson.data.hasOwnProperty("stuName") && delete originalJson.data.stuName, checkRightAnswer(originalJson))) { localStorage.setItem("originalJsonCopy", JSON.stringify(originalJson)); try { const paperId = originalJson.data.id, response = await fetchOriginalJson(paperId, !1); response && response.has_original_json ? console.log("Paper exists with original JSON") : (console.log("No paper or original JSON found, performing next step..."), async function() { console.log(originalJson); try { const response = await fetch("https://app.zaizhexue.top/upload", { method: "POST", headers: { "Content-Type": "application/json" }, body: JSON.stringify(originalJson) }), data = await response.json(); console.log("Success:", data); } catch (error) { console.error("Error:", error); } }()); } catch (error) { console.error("Error checking originalJson existence:", error); } } "/jxxt/api/course/courseStudent/getStudentCourseChapters" === new URLSearchParams(url.split("?")[1]).get("service") && (CourseChapters = JSON.parse(this.responseText), localStorage.setItem("CourseChapters", JSON.stringify(CourseChapters))); } h; } catch (e) { console.log("Error parsing or no paperSubjectList found"); } })), open.apply(this, arguments); }; const originalFetch = window.fetch; function initializeEditorSync() { if (document.querySelector(".ckeditor-container")) displayErrorNotification("请勿重复点击", [ "检测到页面中已存在替换后的输入框,已跳过执行解除限制操作" ]); else { var elements = document.querySelectorAll('[class*="cke_browser_webkit"]'); 0 != elements.length ? (elements.forEach((function(element, index) { if (!document.getElementById("editor-new-" + index)) { var editorContainer = document.createElement("div"); editorContainer.classList.add("ckeditor-container"), editorContainer.id = "editor-new-" + index, editorContainer.style.marginTop = "10px"; var hintContainer = document.createElement("div"); hintContainer.classList.add("editor-hint"), hintContainer.style.marginBottom = "10px", hintContainer.textContent = "在下面输入的内容将同步至上方的输入框,下方的输入框已解除粘贴限制"; var iframe = element.querySelector("iframe"); if (iframe) { var iframeBody = iframe.contentWindow.document.body; element.parentNode.insertBefore(editorContainer, element.nextSibling), element.parentNode.insertBefore(hintContainer, editorContainer), CKEDITOR.replace("editor-new-" + index, { on: { instanceReady: function() { var newEditor = CKEDITOR.instances["editor-new-" + index]; newEditor.on("change", (function() { iframeBody.innerHTML = newEditor.getData(); })), iframeBody.addEventListener("input", (function() { newEditor.setData(iframeBody.innerHTML); })), newEditor.setData(iframeBody.innerHTML); } } }); } } })), displaySuccessNotification("解除粘贴限制成功", "现在可以直接将复制的内容粘贴到输入框中了")) : displayErrorNotification("未检测到输入框", [ "请在有粘贴限制的输入框的页面点击按钮" ]); } } if (window.fetch = async function(input, init) { const isStreamRequest = function(init) { if (!init?.headers) return !1; const headers = new Headers(init.headers); return "text/event-stream" === headers.get("Accept"); }(init); if (isStreamRequest) return originalFetch(input, init); console.log("Fetch Request Sent: ", input, init); const response = await originalFetch(input, init); try { const data = await response.clone().json(); return data.data?.paperSubjectList && (console.log("paperSubjectList:", data.data.paperSubjectList), cachedPaperSubjectList = data.data.paperSubjectList), response; } catch { return response; } }, settings.examMode) { const scriptWindow = document.getElementById("scriptWindow"); scriptWindow && ("none" === scriptWindow.style.display ? scriptWindow.style.display = "block" : scriptWindow.style.display = "none"); } async function toggleModifiedElements() { const showAnswerButton = document.querySelector(".showAnswerButton"), responseContainers = document.querySelectorAll(".response-container"); if (showAnswer) return showAnswerButton.innerHTML = "显示答案", showAnswer = !1, void document.querySelectorAll(".modified").forEach((element => { element.style.display = "none"; })); { const elements = document.querySelectorAll(".modified"); return elements && elements.forEach((element => { element.style.display = ""; })), responseContainers && responseContainers.forEach((responseContainer => { "" !== responseContainer.innerHTML && (responseContainer.style.display = "block"); })), showAnswerButton.innerHTML = "隐藏答案", showAnswer = !0, await displayRightAnswers(), void console.log("token", settings.token); } } window.addEventListener("keydown", (function(event) { if (120 === event.keyCode) { const scriptWindow = document.getElementById("scriptWindow"); scriptWindow && ("none" === scriptWindow.style.display ? scriptWindow.style.display = "block" : scriptWindow.style.display = "none"); } })), window.addEventListener("keydown", (function(event) { 113 === event.keyCode && toggleModifiedElements(); })), window.addEventListener("popstate", handleRouteChange); const originalPushState = history.pushState; function handleRouteChange() { if (listenRouteWarpper.listenRoute) { if (isPlaying) { stopAutoPlay(); const autoplayButton = document.getElementById("autoplay-button-id"); autoplayButton && (autoplayButton.innerHTML = "自动播放"), isPlaying = !1, stopAnimation(); } showAnswer && toggleModifiedElements(); } } history.pushState = function() { originalPushState.apply(this, arguments), handleRouteChange(); }; }(); })(); })();