// ==UserScript== // @name Pixiv Mio Tools // @namespace remio/script-pixiv // @version 1.1.0 // @author kasuie // @license MIT // @icon https://www.google.com/s2/favicons?sz=64&domain=pixiv.net // @match https://www.pixiv.net/artworks/* // @match https://www.pixiv.net/ranking.php* // @grant GM.addStyle // @grant GM.deleteValue // @grant GM.getValue // @grant GM.listValues // @grant GM.notification // @grant GM.setValue // @grant GM.xmlHttpRequest // @description 获取pixiv的排行数据,并新增到mio // @downloadURL https://update.greasyfork.icu/scripts/491140/Pixiv%20Mio%20Tools.user.js // @updateURL https://update.greasyfork.icu/scripts/491140/Pixiv%20Mio%20Tools.meta.js // ==/UserScript== (function () { 'use strict'; var _a, _b; var _GM = /* @__PURE__ */ (() => typeof GM != "undefined" ? GM : void 0)(); const storage = { set(key, val) { return _GM.setValue(key, val); }, get(key, defaultValue) { return _GM.getValue(key, defaultValue); }, all() { return _GM.listValues(); }, del(key) { return _GM.deleteValue(key); }, async clear() { let keys = this.all(); for (let key of await keys) { _GM.deleteValue(key); } } }; const request = (data) => { return new Promise((resolve, reject) => { if (!data.method) { data.method = "get"; } if (!data.timeout) { data.timeout = 6e4; } data.onload = function(res) { try { resolve(JSON.parse(res.responseText)); } catch (error) { reject(error); } }; data.onerror = function(e) { reject(e); }; data.ontimeout = function() { reject("timeout"); }; _GM.xmlHttpRequest(data); }); }; var dayjs_min$1 = { exports: {} }; var dayjs_min = dayjs_min$1.exports; var hasRequiredDayjs_min; function requireDayjs_min() { if (hasRequiredDayjs_min) return dayjs_min$1.exports; hasRequiredDayjs_min = 1; (function(module, exports) { !function(t, e) { module.exports = e(); }(dayjs_min, function() { var t = 1e3, e = 6e4, n = 36e5, r = "millisecond", i = "second", s = "minute", u = "hour", a = "day", o = "week", c = "month", f = "quarter", h = "year", d = "date", l = "Invalid Date", $ = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/, y = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g, M = { name: "en", weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), ordinal: function(t2) { var e2 = ["th", "st", "nd", "rd"], n2 = t2 % 100; return "[" + t2 + (e2[(n2 - 20) % 10] || e2[n2] || e2[0]) + "]"; } }, m = function(t2, e2, n2) { var r2 = String(t2); return !r2 || r2.length >= e2 ? t2 : "" + Array(e2 + 1 - r2.length).join(n2) + t2; }, v = { s: m, z: function(t2) { var e2 = -t2.utcOffset(), n2 = Math.abs(e2), r2 = Math.floor(n2 / 60), i2 = n2 % 60; return (e2 <= 0 ? "+" : "-") + m(r2, 2, "0") + ":" + m(i2, 2, "0"); }, m: function t2(e2, n2) { if (e2.date() < n2.date()) return -t2(n2, e2); var r2 = 12 * (n2.year() - e2.year()) + (n2.month() - e2.month()), i2 = e2.clone().add(r2, c), s2 = n2 - i2 < 0, u2 = e2.clone().add(r2 + (s2 ? -1 : 1), c); return +(-(r2 + (n2 - i2) / (s2 ? i2 - u2 : u2 - i2)) || 0); }, a: function(t2) { return t2 < 0 ? Math.ceil(t2) || 0 : Math.floor(t2); }, p: function(t2) { return { M: c, y: h, w: o, d: a, D: d, h: u, m: s, s: i, ms: r, Q: f }[t2] || String(t2 || "").toLowerCase().replace(/s$/, ""); }, u: function(t2) { return void 0 === t2; } }, g = "en", D = {}; D[g] = M; var p = "$isDayjsObject", S = function(t2) { return t2 instanceof _ || !(!t2 || !t2[p]); }, w = function t2(e2, n2, r2) { var i2; if (!e2) return g; if ("string" == typeof e2) { var s2 = e2.toLowerCase(); D[s2] && (i2 = s2), n2 && (D[s2] = n2, i2 = s2); var u2 = e2.split("-"); if (!i2 && u2.length > 1) return t2(u2[0]); } else { var a2 = e2.name; D[a2] = e2, i2 = a2; } return !r2 && i2 && (g = i2), i2 || !r2 && g; }, O = function(t2, e2) { if (S(t2)) return t2.clone(); var n2 = "object" == typeof e2 ? e2 : {}; return n2.date = t2, n2.args = arguments, new _(n2); }, b = v; b.l = w, b.i = S, b.w = function(t2, e2) { return O(t2, { locale: e2.$L, utc: e2.$u, x: e2.$x, $offset: e2.$offset }); }; var _ = function() { function M2(t2) { this.$L = w(t2.locale, null, true), this.parse(t2), this.$x = this.$x || t2.x || {}, this[p] = true; } var m2 = M2.prototype; return m2.parse = function(t2) { this.$d = function(t3) { var e2 = t3.date, n2 = t3.utc; if (null === e2) return /* @__PURE__ */ new Date(NaN); if (b.u(e2)) return /* @__PURE__ */ new Date(); if (e2 instanceof Date) return new Date(e2); if ("string" == typeof e2 && !/Z$/i.test(e2)) { var r2 = e2.match($); if (r2) { var i2 = r2[2] - 1 || 0, s2 = (r2[7] || "0").substring(0, 3); return n2 ? new Date(Date.UTC(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2)) : new Date(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2); } } return new Date(e2); }(t2), this.init(); }, m2.init = function() { var t2 = this.$d; this.$y = t2.getFullYear(), this.$M = t2.getMonth(), this.$D = t2.getDate(), this.$W = t2.getDay(), this.$H = t2.getHours(), this.$m = t2.getMinutes(), this.$s = t2.getSeconds(), this.$ms = t2.getMilliseconds(); }, m2.$utils = function() { return b; }, m2.isValid = function() { return !(this.$d.toString() === l); }, m2.isSame = function(t2, e2) { var n2 = O(t2); return this.startOf(e2) <= n2 && n2 <= this.endOf(e2); }, m2.isAfter = function(t2, e2) { return O(t2) < this.startOf(e2); }, m2.isBefore = function(t2, e2) { return this.endOf(e2) < O(t2); }, m2.$g = function(t2, e2, n2) { return b.u(t2) ? this[e2] : this.set(n2, t2); }, m2.unix = function() { return Math.floor(this.valueOf() / 1e3); }, m2.valueOf = function() { return this.$d.getTime(); }, m2.startOf = function(t2, e2) { var n2 = this, r2 = !!b.u(e2) || e2, f2 = b.p(t2), l2 = function(t3, e3) { var i2 = b.w(n2.$u ? Date.UTC(n2.$y, e3, t3) : new Date(n2.$y, e3, t3), n2); return r2 ? i2 : i2.endOf(a); }, $2 = function(t3, e3) { return b.w(n2.toDate()[t3].apply(n2.toDate("s"), (r2 ? [0, 0, 0, 0] : [23, 59, 59, 999]).slice(e3)), n2); }, y2 = this.$W, M3 = this.$M, m3 = this.$D, v2 = "set" + (this.$u ? "UTC" : ""); switch (f2) { case h: return r2 ? l2(1, 0) : l2(31, 11); case c: return r2 ? l2(1, M3) : l2(0, M3 + 1); case o: var g2 = this.$locale().weekStart || 0, D2 = (y2 < g2 ? y2 + 7 : y2) - g2; return l2(r2 ? m3 - D2 : m3 + (6 - D2), M3); case a: case d: return $2(v2 + "Hours", 0); case u: return $2(v2 + "Minutes", 1); case s: return $2(v2 + "Seconds", 2); case i: return $2(v2 + "Milliseconds", 3); default: return this.clone(); } }, m2.endOf = function(t2) { return this.startOf(t2, false); }, m2.$set = function(t2, e2) { var n2, o2 = b.p(t2), f2 = "set" + (this.$u ? "UTC" : ""), l2 = (n2 = {}, n2[a] = f2 + "Date", n2[d] = f2 + "Date", n2[c] = f2 + "Month", n2[h] = f2 + "FullYear", n2[u] = f2 + "Hours", n2[s] = f2 + "Minutes", n2[i] = f2 + "Seconds", n2[r] = f2 + "Milliseconds", n2)[o2], $2 = o2 === a ? this.$D + (e2 - this.$W) : e2; if (o2 === c || o2 === h) { var y2 = this.clone().set(d, 1); y2.$d[l2]($2), y2.init(), this.$d = y2.set(d, Math.min(this.$D, y2.daysInMonth())).$d; } else l2 && this.$d[l2]($2); return this.init(), this; }, m2.set = function(t2, e2) { return this.clone().$set(t2, e2); }, m2.get = function(t2) { return this[b.p(t2)](); }, m2.add = function(r2, f2) { var d2, l2 = this; r2 = Number(r2); var $2 = b.p(f2), y2 = function(t2) { var e2 = O(l2); return b.w(e2.date(e2.date() + Math.round(t2 * r2)), l2); }; if ($2 === c) return this.set(c, this.$M + r2); if ($2 === h) return this.set(h, this.$y + r2); if ($2 === a) return y2(1); if ($2 === o) return y2(7); var M3 = (d2 = {}, d2[s] = e, d2[u] = n, d2[i] = t, d2)[$2] || 1, m3 = this.$d.getTime() + r2 * M3; return b.w(m3, this); }, m2.subtract = function(t2, e2) { return this.add(-1 * t2, e2); }, m2.format = function(t2) { var e2 = this, n2 = this.$locale(); if (!this.isValid()) return n2.invalidDate || l; var r2 = t2 || "YYYY-MM-DDTHH:mm:ssZ", i2 = b.z(this), s2 = this.$H, u2 = this.$m, a2 = this.$M, o2 = n2.weekdays, c2 = n2.months, f2 = n2.meridiem, h2 = function(t3, n3, i3, s3) { return t3 && (t3[n3] || t3(e2, r2)) || i3[n3].slice(0, s3); }, d2 = function(t3) { return b.s(s2 % 12 || 12, t3, "0"); }, $2 = f2 || function(t3, e3, n3) { var r3 = t3 < 12 ? "AM" : "PM"; return n3 ? r3.toLowerCase() : r3; }; return r2.replace(y, function(t3, r3) { return r3 || function(t4) { switch (t4) { case "YY": return String(e2.$y).slice(-2); case "YYYY": return b.s(e2.$y, 4, "0"); case "M": return a2 + 1; case "MM": return b.s(a2 + 1, 2, "0"); case "MMM": return h2(n2.monthsShort, a2, c2, 3); case "MMMM": return h2(c2, a2); case "D": return e2.$D; case "DD": return b.s(e2.$D, 2, "0"); case "d": return String(e2.$W); case "dd": return h2(n2.weekdaysMin, e2.$W, o2, 2); case "ddd": return h2(n2.weekdaysShort, e2.$W, o2, 3); case "dddd": return o2[e2.$W]; case "H": return String(s2); case "HH": return b.s(s2, 2, "0"); case "h": return d2(1); case "hh": return d2(2); case "a": return $2(s2, u2, true); case "A": return $2(s2, u2, false); case "m": return String(u2); case "mm": return b.s(u2, 2, "0"); case "s": return String(e2.$s); case "ss": return b.s(e2.$s, 2, "0"); case "SSS": return b.s(e2.$ms, 3, "0"); case "Z": return i2; } return null; }(t3) || i2.replace(":", ""); }); }, m2.utcOffset = function() { return 15 * -Math.round(this.$d.getTimezoneOffset() / 15); }, m2.diff = function(r2, d2, l2) { var $2, y2 = this, M3 = b.p(d2), m3 = O(r2), v2 = (m3.utcOffset() - this.utcOffset()) * e, g2 = this - m3, D2 = function() { return b.m(y2, m3); }; switch (M3) { case h: $2 = D2() / 12; break; case c: $2 = D2(); break; case f: $2 = D2() / 3; break; case o: $2 = (g2 - v2) / 6048e5; break; case a: $2 = (g2 - v2) / 864e5; break; case u: $2 = g2 / n; break; case s: $2 = g2 / e; break; case i: $2 = g2 / t; break; default: $2 = g2; } return l2 ? $2 : b.a($2); }, m2.daysInMonth = function() { return this.endOf(c).$D; }, m2.$locale = function() { return D[this.$L]; }, m2.locale = function(t2, e2) { if (!t2) return this.$L; var n2 = this.clone(), r2 = w(t2, e2, true); return r2 && (n2.$L = r2), n2; }, m2.clone = function() { return b.w(this.$d, this); }, m2.toDate = function() { return new Date(this.valueOf()); }, m2.toJSON = function() { return this.isValid() ? this.toISOString() : null; }, m2.toISOString = function() { return this.$d.toISOString(); }, m2.toString = function() { return this.$d.toUTCString(); }, M2; }(), k = _.prototype; return O.prototype = k, [["$ms", r], ["$s", i], ["$m", s], ["$H", u], ["$W", a], ["$M", c], ["$y", h], ["$D", d]].forEach(function(t2) { k[t2[1]] = function(e2) { return this.$g(e2, t2[0], t2[1]); }; }), O.extend = function(t2, e2) { return t2.$i || (t2(e2, _, O), t2.$i = true), O; }, O.locale = w, O.isDayjs = S, O.unix = function(t2) { return O(1e3 * t2); }, O.en = D[g], O.Ls = D, O.p = {}, O; }); })(dayjs_min$1); return dayjs_min$1.exports; } var customParseFormat$1 = { exports: {} }; var customParseFormat = customParseFormat$1.exports; var hasRequiredCustomParseFormat; function requireCustomParseFormat() { if (hasRequiredCustomParseFormat) return customParseFormat$1.exports; hasRequiredCustomParseFormat = 1; (function(module, exports) { !function(e, t) { module.exports = t(); }(customParseFormat, function() { var e = { LTS: "h:mm:ss A", LT: "h:mm A", L: "MM/DD/YYYY", LL: "MMMM D, YYYY", LLL: "MMMM D, YYYY h:mm A", LLLL: "dddd, MMMM D, YYYY h:mm A" }, t = /(\[[^[]*\])|([-_:/.,()\s]+)|(A|a|Q|YYYY|YY?|ww?|MM?M?M?|Do|DD?|hh?|HH?|mm?|ss?|S{1,3}|z|ZZ?)/g, n = /\d/, r = /\d\d/, i = /\d\d?/, o = /\d*[^-_:/,()\s\d]+/, s = {}, a = function(e2) { return (e2 = +e2) + (e2 > 68 ? 1900 : 2e3); }; var f = function(e2) { return function(t2) { this[e2] = +t2; }; }, h = [/[+-]\d\d:?(\d\d)?|Z/, function(e2) { (this.zone || (this.zone = {})).offset = function(e3) { if (!e3) return 0; if ("Z" === e3) return 0; var t2 = e3.match(/([+-]|\d\d)/g), n2 = 60 * t2[1] + (+t2[2] || 0); return 0 === n2 ? 0 : "+" === t2[0] ? -n2 : n2; }(e2); }], u = function(e2) { var t2 = s[e2]; return t2 && (t2.indexOf ? t2 : t2.s.concat(t2.f)); }, d = function(e2, t2) { var n2, r2 = s.meridiem; if (r2) { for (var i2 = 1; i2 <= 24; i2 += 1) if (e2.indexOf(r2(i2, 0, t2)) > -1) { n2 = i2 > 12; break; } } else n2 = e2 === (t2 ? "pm" : "PM"); return n2; }, c = { A: [o, function(e2) { this.afternoon = d(e2, false); }], a: [o, function(e2) { this.afternoon = d(e2, true); }], Q: [n, function(e2) { this.month = 3 * (e2 - 1) + 1; }], S: [n, function(e2) { this.milliseconds = 100 * +e2; }], SS: [r, function(e2) { this.milliseconds = 10 * +e2; }], SSS: [/\d{3}/, function(e2) { this.milliseconds = +e2; }], s: [i, f("seconds")], ss: [i, f("seconds")], m: [i, f("minutes")], mm: [i, f("minutes")], H: [i, f("hours")], h: [i, f("hours")], HH: [i, f("hours")], hh: [i, f("hours")], D: [i, f("day")], DD: [r, f("day")], Do: [o, function(e2) { var t2 = s.ordinal, n2 = e2.match(/\d+/); if (this.day = n2[0], t2) for (var r2 = 1; r2 <= 31; r2 += 1) t2(r2).replace(/\[|\]/g, "") === e2 && (this.day = r2); }], w: [i, f("week")], ww: [r, f("week")], M: [i, f("month")], MM: [r, f("month")], MMM: [o, function(e2) { var t2 = u("months"), n2 = (u("monthsShort") || t2.map(function(e3) { return e3.slice(0, 3); })).indexOf(e2) + 1; if (n2 < 1) throw new Error(); this.month = n2 % 12 || n2; }], MMMM: [o, function(e2) { var t2 = u("months").indexOf(e2) + 1; if (t2 < 1) throw new Error(); this.month = t2 % 12 || t2; }], Y: [/[+-]?\d+/, f("year")], YY: [r, function(e2) { this.year = a(e2); }], YYYY: [/\d{4}/, f("year")], Z: h, ZZ: h }; function l(n2) { var r2, i2; r2 = n2, i2 = s && s.formats; for (var o2 = (n2 = r2.replace(/(\[[^\]]+])|(LTS?|l{1,4}|L{1,4})/g, function(t2, n3, r3) { var o3 = r3 && r3.toUpperCase(); return n3 || i2[r3] || e[r3] || i2[o3].replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g, function(e2, t3, n4) { return t3 || n4.slice(1); }); })).match(t), a2 = o2.length, f2 = 0; f2 < a2; f2 += 1) { var h2 = o2[f2], u2 = c[h2], d2 = u2 && u2[0], l2 = u2 && u2[1]; o2[f2] = l2 ? { regex: d2, parser: l2 } : h2.replace(/^\[|\]$/g, ""); } return function(e2) { for (var t2 = {}, n3 = 0, r3 = 0; n3 < a2; n3 += 1) { var i3 = o2[n3]; if ("string" == typeof i3) r3 += i3.length; else { var s2 = i3.regex, f3 = i3.parser, h3 = e2.slice(r3), u3 = s2.exec(h3)[0]; f3.call(t2, u3), e2 = e2.replace(u3, ""); } } return function(e3) { var t3 = e3.afternoon; if (void 0 !== t3) { var n4 = e3.hours; t3 ? n4 < 12 && (e3.hours += 12) : 12 === n4 && (e3.hours = 0), delete e3.afternoon; } }(t2), t2; }; } return function(e2, t2, n2) { n2.p.customParseFormat = true, e2 && e2.parseTwoDigitYear && (a = e2.parseTwoDigitYear); var r2 = t2.prototype, i2 = r2.parse; r2.parse = function(e3) { var t3 = e3.date, r3 = e3.utc, o2 = e3.args; this.$u = r3; var a2 = o2[1]; if ("string" == typeof a2) { var f2 = true === o2[2], h2 = true === o2[3], u2 = f2 || h2, d2 = o2[2]; h2 && (d2 = o2[2]), s = this.$locale(), !f2 && d2 && (s = n2.Ls[d2]), this.$d = function(e4, t4, n3, r4) { try { if (["x", "X"].indexOf(t4) > -1) return new Date(("X" === t4 ? 1e3 : 1) * e4); var i3 = l(t4)(e4), o3 = i3.year, s2 = i3.month, a3 = i3.day, f3 = i3.hours, h3 = i3.minutes, u3 = i3.seconds, d3 = i3.milliseconds, c3 = i3.zone, m2 = i3.week, M2 = /* @__PURE__ */ new Date(), Y = a3 || (o3 || s2 ? 1 : M2.getDate()), p = o3 || M2.getFullYear(), v = 0; o3 && !s2 || (v = s2 > 0 ? s2 - 1 : M2.getMonth()); var D, w = f3 || 0, g = h3 || 0, y = u3 || 0, L = d3 || 0; return c3 ? new Date(Date.UTC(p, v, Y, w, g, y, L + 60 * c3.offset * 1e3)) : n3 ? new Date(Date.UTC(p, v, Y, w, g, y, L)) : (D = new Date(p, v, Y, w, g, y, L), m2 && (D = r4(D).week(m2).toDate()), D); } catch (e5) { return /* @__PURE__ */ new Date(""); } }(t3, a2, r3, n2), this.init(), d2 && true !== d2 && (this.$L = this.locale(d2).$L), u2 && t3 != this.format(a2) && (this.$d = /* @__PURE__ */ new Date("")), s = {}; } else if (a2 instanceof Array) for (var c2 = a2.length, m = 1; m <= c2; m += 1) { o2[1] = a2[m - 1]; var M = n2.apply(this, o2); if (M.isValid()) { this.$d = M.$d, this.$L = M.$L, this.init(); break; } m === c2 && (this.$d = /* @__PURE__ */ new Date("")); } else i2.call(this, e3); }; }; }); })(customParseFormat$1); return customParseFormat$1.exports; } var localizedFormat$1 = { exports: {} }; var localizedFormat = localizedFormat$1.exports; var hasRequiredLocalizedFormat; function requireLocalizedFormat() { if (hasRequiredLocalizedFormat) return localizedFormat$1.exports; hasRequiredLocalizedFormat = 1; (function(module, exports) { !function(e, t) { module.exports = t(); }(localizedFormat, function() { var e = { LTS: "h:mm:ss A", LT: "h:mm A", L: "MM/DD/YYYY", LL: "MMMM D, YYYY", LLL: "MMMM D, YYYY h:mm A", LLLL: "dddd, MMMM D, YYYY h:mm A" }; return function(t, o, n) { var r = o.prototype, i = r.format; n.en.formats = e, r.format = function(t2) { void 0 === t2 && (t2 = "YYYY-MM-DDTHH:mm:ssZ"); var o2 = this.$locale().formats, n2 = function(t3, o3) { return t3.replace(/(\[[^\]]+])|(LTS?|l{1,4}|L{1,4})/g, function(t4, n3, r2) { var i2 = r2 && r2.toUpperCase(); return n3 || o3[r2] || e[r2] || o3[i2].replace(/(\[[^\]]+])|(MMMM|MM|DD|dddd)/g, function(e2, t5, o4) { return t5 || o4.slice(1); }); }); }(t2, void 0 === o2 ? {} : o2); return i.call(this, n2); }; }; }); })(localizedFormat$1); return localizedFormat$1.exports; } var zhCn$1 = { exports: {} }; var zhCn = zhCn$1.exports; var hasRequiredZhCn; function requireZhCn() { if (hasRequiredZhCn) return zhCn$1.exports; hasRequiredZhCn = 1; (function(module, exports) { !function(e, _) { module.exports = _(requireDayjs_min()); }(zhCn, function(e) { function _(e2) { return e2 && "object" == typeof e2 && "default" in e2 ? e2 : { default: e2 }; } var t = _(e), d = { name: "zh-cn", weekdays: "星期日_星期一_星期二_星期三_星期四_星期五_星期六".split("_"), weekdaysShort: "周日_周一_周二_周三_周四_周五_周六".split("_"), weekdaysMin: "日_一_二_三_四_五_六".split("_"), months: "一月_二月_三月_四月_五月_六月_七月_八月_九月_十月_十一月_十二月".split("_"), monthsShort: "1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月".split("_"), ordinal: function(e2, _2) { return "W" === _2 ? e2 + "周" : e2 + "日"; }, weekStart: 1, yearStart: 4, formats: { LT: "HH:mm", LTS: "HH:mm:ss", L: "YYYY/MM/DD", LL: "YYYY年M月D日", LLL: "YYYY年M月D日Ah点mm分", LLLL: "YYYY年M月D日ddddAh点mm分", l: "YYYY/M/D", ll: "YYYY年M月D日", lll: "YYYY年M月D日 HH:mm", llll: "YYYY年M月D日dddd HH:mm" }, relativeTime: { future: "%s内", past: "%s前", s: "几秒", m: "1 分钟", mm: "%d 分钟", h: "1 小时", hh: "%d 小时", d: "1 天", dd: "%d 天", M: "1 个月", MM: "%d 个月", y: "1 年", yy: "%d 年" }, meridiem: function(e2, _2) { var t2 = 100 * e2 + _2; return t2 < 600 ? "凌晨" : t2 < 900 ? "早上" : t2 < 1100 ? "上午" : t2 < 1300 ? "中午" : t2 < 1800 ? "下午" : "晚上"; } }; return t.default.locale(d, null, true), d; }); })(zhCn$1); return zhCn$1.exports; } var dist; var hasRequiredDist; function requireDist() { if (hasRequiredDist) return dist; hasRequiredDist = 1; var __create = Object.create; var __defProp = Object.defineProperty; var __getOwnPropDesc = Object.getOwnPropertyDescriptor; var __getOwnPropNames = Object.getOwnPropertyNames; var __getProtoOf = Object.getPrototypeOf; var __hasOwnProp = Object.prototype.hasOwnProperty; var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; var __export = (target, all) => { for (var name in all) __defProp(target, name, { get: all[name], enumerable: true }); }; var __copyProps = (to, from, except, desc) => { if (from && typeof from === "object" || typeof from === "function") { for (let key of __getOwnPropNames(from)) if (!__hasOwnProp.call(to, key) && key !== except) __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable }); } return to; }; var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps( // If the importer is in node compatibility mode or this is not an ESM // file that has been converted to a CommonJS file using a Babel- // compatible transform (i.e. "__esModule" has not been set), then set // "default" to the CommonJS "module.exports" for node compatibility. !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target, mod )); var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod); var __publicField = (obj, key, value) => { __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value); return value; }; var src_exports = {}; __export(src_exports, { DateFormat: () => DateFormat, SakuraAnimation: () => SakuraAnimation, aDayjs: () => aDayjs, aSakura: () => aSakura, addAlphaToHSL: () => addAlphaToHSL, addAlphaToHex: () => addAlphaToHex, arrayToObject: () => arrayToObject, base64ToBuffer: () => base64ToBuffer, blboToBuffer: () => blboToBuffer, bufferToBase64: () => bufferToBase64, bufferToBlbo: () => bufferToBlbo, bufferToBlboUrl: () => bufferToBlboUrl, calcTimeDiff: () => calcTimeDiff, callAll: () => callAll, callAllHandlers: () => callAllHandlers, capitalize: () => capitalize, clampPercentage: () => clampPercentage, cleanObject: () => cleanObject, cleanObjectKeys: () => cleanObjectKeys, cloneDeep: () => cloneDeep, clsx: () => clsx, compact: () => compact, copyObject: () => copyObject, copyToClipboard: () => copyToClipboard, dataAttr: () => dataAttr, dateFormat: () => dateFormat, dayOfYear: () => dayOfYear, daysOfYear: () => daysOfYear, debounce: () => debounce, decreaseTransition: () => decreaseTransition, downTransition: () => downTransition, endOfDayTimestamp: () => endOfDayTimestamp, endOfWeekTimestamp: () => endOfWeekTimestamp, extractProperty: () => extractProperty, extractRGBA: () => extractRGBA, fadeInTransition: () => fadeInTransition, fadeOutTransition: () => fadeOutTransition, fileDownload: () => fileDownload, fileToBlbo: () => fileToBlbo, fileToBuffer: () => fileToBuffer, formatSeconds: () => formatSeconds, generateTransitionColors: () => generateTransitionColors, getBrowser: () => getBrowser, getColorScheme: () => getColorScheme, getFileSize: () => getFileSize, getImageExt: () => getImageExt, getImageMimeType: () => getImageMimeType, getKeyValue: () => getKeyValue, getOS: () => getOS, getProp: () => getProp, getRandomElements: () => getRandomElements, getUniqueID: () => getUniqueID, hexToHsl: () => hexToHsl, increaseTransition: () => increaseTransition, isArray: () => isArray, isClientSide: () => isClientSide, isDev: () => isDev, isEmpty: () => isEmpty, isEmptyArray: () => isEmptyArray, isEmptyObject: () => isEmptyObject, isFunction: () => isFunction, isLeapYear: () => isLeapYear, isMobile: () => isMobile, isNil: () => isNil, isNumeric: () => isNumeric, isObject: () => isObject, isServerSide: () => isServerSide, isValidDate: () => isValidDate, isValidUrl: () => isValidUrl, makeBlurDataURL: () => makeBlurDataURL, microDampingPreset: () => microDampingPreset, microReboundPreset: () => microReboundPreset, omitObject: () => omitObject, onDebug: () => onDebug, onDomain: () => onDomain, parseDate: () => parseDate, pick: () => pick, range: () => range, reboundPreset: () => reboundPreset, relativeTimeFromNow: () => relativeTimeFromNow, removeEvents: () => removeEvents, renameProp: () => renameProp, secondOfDay: () => secondOfDay, secondOfDays: () => secondOfDays, shuffleArray: () => shuffleArray, softBouncePreset: () => softBouncePreset, softSpringPreset: () => softSpringPreset, startOfDayTimestamp: () => startOfDayTimestamp, startOfWeekTimestamp: () => startOfWeekTimestamp, storage: () => storage2, stringToHue: () => stringToHue, throttle: () => throttle, toHsl: () => toHsl, toLeftTransition: () => toLeftTransition, toRightTransition: () => toRightTransition, transform: () => transform, transitions: () => transitions, upTransition: () => upTransition, url: () => url }); dist = __toCommonJS(src_exports); var import_dayjs = __toESM(requireDayjs_min()); var import_customParseFormat = __toESM(requireCustomParseFormat()); var import_localizedFormat = __toESM(requireLocalizedFormat()); requireZhCn(); import_dayjs.default.extend(import_customParseFormat.default); import_dayjs.default.extend(import_localizedFormat.default); import_dayjs.default.locale("zh-cn"); var aDayjs = import_dayjs.default; var DateFormat = /* @__PURE__ */ ((DateFormat2) => { DateFormat2[DateFormat2["YYYY-MM-DD HH:mm:ss"] = 0] = "YYYY-MM-DD HH:mm:ss"; DateFormat2[DateFormat2["MMM DD YYYY"] = 1] = "MMM DD YYYY"; DateFormat2[DateFormat2["HH:mm"] = 2] = "HH:mm"; DateFormat2[DateFormat2["LLLL"] = 3] = "LLLL"; DateFormat2[DateFormat2["H:mm:ss A"] = 4] = "H:mm:ss A"; DateFormat2[DateFormat2["YYYY-MM-DD"] = 5] = "YYYY-MM-DD"; DateFormat2[DateFormat2["YYYY-MM-DD dddd"] = 6] = "YYYY-MM-DD dddd"; DateFormat2[DateFormat2["YYYY-MM-DD ddd"] = 7] = "YYYY-MM-DD ddd"; DateFormat2[DateFormat2["MM-DD ddd"] = 8] = "MM-DD ddd"; DateFormat2[DateFormat2["YYYY 年 M 月 D 日 dddd"] = 9] = "YYYY 年 M 月 D 日 dddd"; return DateFormat2; })(DateFormat || {}); var dateFormat = (time = /* @__PURE__ */ new Date(), format2 = "YYYY-MM-DD HH:mm:ss") => (0, import_dayjs.default)(time).format(format2); var parseDate = (time = /* @__PURE__ */ new Date(), format2 = "YYYY-MM-DD HH:mm:ss") => (0, import_dayjs.default)(time).format(format2); var relativeTimeFromNow = (time, current = /* @__PURE__ */ new Date()) => { if (!time) { return ""; } time = new Date(time); const msPerMinute = 60 * 1e3; const msPerHour = msPerMinute * 60; const msPerDay = msPerHour * 24; const msPerMonth = msPerDay * 30; const msPerYear = msPerDay * 365; const elapsed = +current - +time; if (elapsed < msPerMinute) { const gap = Math.ceil(elapsed / 1e3); return gap <= 0 ? "刚刚" : `${gap} 秒前`; } else if (elapsed < msPerHour) { return `${Math.round(elapsed / msPerMinute)} 分钟前`; } else if (elapsed < msPerDay) { return `${Math.round(elapsed / msPerHour)} 小时前`; } else if (elapsed < msPerMonth) { return `${Math.round(elapsed / msPerDay)} 天前`; } else if (elapsed < msPerYear) { return `${Math.round(elapsed / msPerMonth)} 个月前`; } else { return `${Math.round(elapsed / msPerYear)} 年前`; } }; var dayOfYear = () => { const now = /* @__PURE__ */ new Date(); const start = new Date(now.getFullYear(), 0, 0); const diff = now.getTime() - start.getTime(); const oneDay = 1e3 * 60 * 60 * 24; const day = Math.floor(diff / oneDay); return day; }; function daysOfYear(year) { return isLeapYear(year ?? (/* @__PURE__ */ new Date()).getFullYear()) ? 366 : 365; } function isLeapYear(year) { return year % 400 === 0 || year % 100 !== 0 && year % 4 === 0; } var secondOfDay = () => { const dt = /* @__PURE__ */ new Date(); const secs = dt.getSeconds() + 60 * (dt.getMinutes() + 60 * dt.getHours()); return secs; }; var secondOfDays = 86400; function isValidDate(d) { return d instanceof Date && !Number.isNaN(+d); } function formatSeconds(seconds) { const days = Math.floor(seconds / (24 * 3600)); const hours = Math.floor(seconds % (24 * 3600) / 3600); const minutes = Math.floor(seconds % 3600 / 60); const remainingSeconds = Math.floor(seconds % 60); return { days, hours, minutes, seconds: remainingSeconds }; } function calcTimeDiff(date, returnStr = false, hideZero = false) { const inputDate = (0, import_dayjs.default)(date); const now = (0, import_dayjs.default)(); const days = now.diff(inputDate, "day"); const hours = now.diff(inputDate, "hour") % 24; const minutes = now.diff(inputDate, "minute") % 60; const seconds = now.diff(inputDate, "second") % 60; if (returnStr) { let result = ""; if (!hideZero || days > 0) { result += `${days}天`; } if (!hideZero || hours > 0) { result += `${hours}小时`; } if (!hideZero || minutes > 0) { result += `${minutes}分钟`; } if (!hideZero || seconds > 0) { result += `${seconds}秒`; } return result.trim(); } else { return { days, hours, minutes, seconds }; } } var endOfDayTimestamp = (0, import_dayjs.default)().endOf("day").valueOf(); var startOfDayTimestamp = (0, import_dayjs.default)().startOf("day").valueOf(); var startOfWeekTimestamp = (0, import_dayjs.default)().day(1).startOf("day").valueOf(); var endOfWeekTimestamp = (0, import_dayjs.default)().day(7).endOf("day").valueOf(); function copyToClipboard(text) { return new Promise((resolve, reject) => { if (!navigator.clipboard || !navigator.clipboard.writeText) { const textArea = document.createElement("textarea"); textArea.value = text; document.body.appendChild(textArea); textArea.focus(); textArea.select(); try { document.execCommand("copy"); document.body.removeChild(textArea); resolve(); } catch (error) { document.body.removeChild(textArea); reject(error); } } else { navigator.clipboard.writeText(text).then(() => resolve()).catch((error) => reject(error)); } }); } function fileDownload(url2, filename) { return new Promise((resolve, reject) => { const downloadElement = document.createElement("a"); downloadElement.target = "_blank"; downloadElement.style.display = "none"; downloadElement.href = url2; downloadElement.download = filename; downloadElement.addEventListener("load", () => { document.body.removeChild(downloadElement); resolve(); }); downloadElement.addEventListener("error", (error) => { document.body.removeChild(downloadElement); reject(error); }); document.body.appendChild(downloadElement); downloadElement.click(); }); } var onDebug = (redirectUrl = "https://www.baidu.com") => { if (window.location.hostname !== "localhost") { (() => { let callbacks = []; const timeLimit = 50; let open = false; setInterval(loop, 1); const devToolsChecker = { addListener: (fn) => { callbacks.push(fn); }, cancelListener: (fn) => { callbacks = callbacks.filter((v) => v !== fn); } }; function loop() { const startTime = (/* @__PURE__ */ new Date()).getTime(); debugger; if ((/* @__PURE__ */ new Date()).getTime() - startTime > timeLimit) { if (!open) { callbacks.forEach((fn) => fn()); } open = true; window.stop(); document.body.innerHTML = ""; window.location.href = redirectUrl; } else { open = false; } } devToolsChecker.addListener(() => { window.location.reload(); }); window.document.addEventListener("keydown", (event) => { if (event.key === "F12") { window.location.href = redirectUrl; } }); })(); } }; function isArray(value) { return Array.isArray(value); } function isEmptyArray(value) { return isArray(value) && value.length === 0; } function isObject(value) { const type = typeof value; return value != null && (type === "object" || type === "function") && !isArray(value); } function isEmptyObject(value) { return isObject(value) && Object.keys(value).length === 0; } function isEmpty(value) { if (isArray(value)) return isEmptyArray(value); if (isObject(value)) return isEmptyObject(value); if (value == null || value === "") return true; return false; } function isFunction(value) { return typeof value === "function"; } var dataAttr = (condition) => condition ? "true" : void 0; var isNumeric = (value) => value != null && parseInt(value.toString(), 10) > 0; function toVal(mix) { let k, y, str = ""; if (typeof mix === "string" || typeof mix === "number") { str += mix; } else if (typeof mix === "object") { if (Array.isArray(mix)) { for (k = 0; k < mix.length; k++) { if (mix[k]) { if (y = toVal(mix[k])) { str && (str += " "); str += y; } } } } else { for (k in mix) { if (mix[k]) { str && (str += " "); str += k; } } } } return str; } function clsx(...args) { let i = 0, tmp, x, str = ""; while (i < args.length) { if (tmp = args[i++]) { if (x = toVal(tmp)) { str && (str += " "); str += x; } } } return str; } var getRandomColor = (lightness, saturation, hue) => { const satAccent = Math.floor( Math.random() * (saturation[1] - saturation[0] + 1) + saturation[0] ); const lightAccent = Math.floor( Math.random() * (lightness[1] - lightness[0] + 1) + lightness[0] ); const satBackground = satAccent > 30 ? satAccent - 30 : 0; const lightBackground = lightAccent < 80 ? lightAccent + 20 : 100; return { accent: `hsl(${hue}, ${satAccent}%, ${lightAccent}%)`, // 强调颜色的HSL格式 background: `hsl(${hue}, ${satBackground}%, ${lightBackground}%)` // 背景颜色的HSL格式 }; }; function stringToHue(str) { let hash = 0; for (let i = 0; i < str.length; i++) { hash = str.charCodeAt(i) + ((hash << 5) - hash); } const hue = hash % 360; return hue < 0 ? hue + 360 : hue; } var getColorScheme = (hue) => { const baseHue = hue ?? Math.floor(Math.random() * 361); const complementaryHue = (baseHue + 180) % 360; const lightColors = getRandomColor([40, 70], [70, 90], baseHue); const darkColors = getRandomColor([20, 50], [70, 90], complementaryHue); return { light: { accent: lightColors.accent, background: lightColors.background }, dark: { accent: darkColors.accent, background: darkColors.background } }; }; function addAlphaToHex(hex, alpha) { if (!/^#([A-Fa-f0-9]{3}){1,2}$/.test(hex)) { throw new Error("Invalid hex color value"); } let color = ""; if (hex.length === 4) { color = `#${[1, 2, 3].map( (index) => parseInt(hex.charAt(index), 16).toString(16) + parseInt(hex.charAt(index), 16).toString(16) ).join("")}`; } else { color = hex; } const r = parseInt(color.substr(1, 2), 16); const g = parseInt(color.substr(3, 2), 16); const b = parseInt(color.substr(5, 2), 16); return `rgba(${r},${g},${b},${alpha})`; } function addAlphaToHSL(hsl, alpha) { if (!/^hsl\((\d{1,3}),\s*([\d.]+)%,\s*([\d.]+)%\)$/.test(hsl)) { throw new Error("Invalid HSL color value"); } const hsla = `${hsl.slice(0, -1)}, ${alpha})`; return hsla.replace("hsl", "hsla"); } function hexToHsl(hex) { hex = hex.replace("#", ""); const r = parseInt(hex.substring(0, 2), 16) / 255; const g = parseInt(hex.substring(2, 4), 16) / 255; const b = parseInt(hex.substring(4, 6), 16) / 255; const min = Math.min(r, g, b); const max = Math.max(r, g, b); let h = 0; if (max === min) { h = 0; } else if (max === r) { h = (g - b) / (max - min) % 6; } else if (max === g) { h = (2 + (b - r) / (max - min)) % 6; } else { h = (4 + (r - g) / (max - min)) % 6; } h = Math.round(h * 60); const l = (max + min) / 2; let s = 0; if (max !== min) { s = (max - min) / (1 - Math.abs(2 * l - 1)); } s = Math.round(s * 100); return [h, s, Math.round(l * 100)]; } function extractRGBA(color) { const rgbaRegex = /^rgba?\((\d{1,3}),\s*(\d{1,3}),\s*(\d{1,3})(?:,\s*(\d*(?:\.\d+)?))?\)$/; const match = color.match(rgbaRegex); if (!match) { throw new Error("Invalid color format"); } const r = parseInt(match[1], 10); const g = parseInt(match[2], 10); const b = parseInt(match[3], 10); const a = match[4] !== void 0 ? parseFloat(match[4]) : 1; return [r, g, b, a]; } function toHsl(color) { let r, g, b; if (color.includes("#")) { color = color.replace("#", ""); r = parseInt(color.substring(0, 2), 16) / 255; g = parseInt(color.substring(2, 4), 16) / 255; b = parseInt(color.substring(4, 6), 16) / 255; } else if (color.includes("rgb")) { const RGBA = extractRGBA(color); r = RGBA[0]; g = RGBA[1]; b = RGBA[2]; } else { return ""; } const min = Math.min(r, g, b); const max = Math.max(r, g, b); let h = 0; if (max === min) { h = 0; } else if (max === r) { h = (g - b) / (max - min) % 6; } else if (max === g) { h = (2 + (b - r) / (max - min)) % 6; } else { h = (4 + (r - g) / (max - min)) % 6; } h = Math.round(h * 60); const l = (max + min) / 2; let s = 0; if (max !== min) { s = (max - min) / (1 - Math.abs(2 * l - 1)); } s = Math.round(s * 100); return `${h} ${s}% ${Math.round(l * 100)}%`; } function generateTransitionColors(startColor, targetColor, step) { const startRed = parseInt(startColor.substring(1, 3), 16); const startGreen = parseInt(startColor.substring(3, 5), 16); const startBlue = parseInt(startColor.substring(5, 7), 16); const targetRed = parseInt(targetColor.substring(1, 3), 16); const targetGreen = parseInt(targetColor.substring(3, 5), 16); const targetBlue = parseInt(targetColor.substring(5, 7), 16); const redIncrement = (targetRed - startRed) / step; const greenIncrement = (targetGreen - startGreen) / step; const blueIncrement = (targetBlue - startBlue) / step; const transitionColors = []; for (let i = 0; i < step; i++) { const transitionRed = Math.round(startRed + redIncrement * i); const transitionGreen = Math.round(startGreen + greenIncrement * i); const transitionBlue = Math.round(startBlue + blueIncrement * i); const hexColor = `#${(1 << 24 | transitionRed << 16 | transitionGreen << 8 | transitionBlue).toString(16).slice(1)}`; transitionColors.push(hexColor); } return Array.from(new Set(transitionColors)); } var renameProp = (oldProp, newProp, { [oldProp]: old, ...others }) => ({ [newProp]: old, ...others }); var copyObject = (obj) => { if (!isObject(obj)) return obj; if (obj instanceof Array) return [...obj]; return { ...obj }; }; var omitObject = (obj, omitKeys) => { if (!isObject(obj)) return obj; if (obj instanceof Array) return [...obj]; const newObj = { ...obj }; omitKeys.forEach((key) => newObj[key] && delete newObj[key]); return newObj; }; var cleanObject = (obj) => { if (!isObject(obj)) return obj; if (obj instanceof Array) return [...obj]; const newObj = { ...obj }; Object.keys(newObj).forEach((key) => { if (newObj[key] === void 0 || newObj[key] === null) { delete newObj[key]; } }); return newObj; }; var cleanObjectKeys = (obj, keys = []) => { if (!isObject(obj)) return obj; if (obj instanceof Array) return [...obj]; const newObj = { ...obj }; keys.forEach((key) => { if (newObj[key]) { delete newObj[key]; } }); return newObj; }; var getKeyValue = (obj, key) => { if (!isObject(obj)) return obj; if (obj instanceof Array) return [...obj]; return obj[key]; }; var getProp = (obj, path, fallback, index) => { const key = typeof path === "string" ? path.split(".") : [path]; for (index = 0; index < key.length; index += 1) { if (!obj) break; obj = obj[key[index]]; } return obj === void 0 ? fallback : obj; }; var arrayToObject = (arr) => { if (!arr.length || !Array.isArray(arr)) return {}; return arr.reduce((acc, item) => { return { ...acc, ...item }; }, {}); }; function compact(object) { const clone = Object.assign({}, object); for (let key in clone) { if (clone[key] === void 0) delete clone[key]; } return clone; } function range(start, end) { const length = end - start + 1; return Array.from({ length }, (_, index) => index + start); } function clampPercentage(value, max = 100) { return Math.min(Math.max(value, 0), max); } var capitalize = (text) => { return text.charAt(0).toUpperCase() + text.slice(1); }; function callAllHandlers(...fns) { return function func(event) { fns.some((fn) => { fn == null ? void 0 : fn(event); return event == null ? void 0 : event.defaultPrevented; }); }; } function callAll(...fns) { return function mergedFn(arg) { fns.forEach((fn) => { fn == null ? void 0 : fn(arg); }); }; } function extractProperty(key, defaultValue, ...objs) { let result = defaultValue; for (const obj of objs) { if (obj && key in obj && !!obj[key]) { result = obj[key]; } } return result; } function getUniqueID(prefix) { return `${prefix}-${Math.floor(Math.random() * 1e6)}`; } function removeEvents(input2) { for (const key in input2) { if (key.startsWith("on")) { delete input2[key]; } } return input2; } var storage2 = { s: { set(key, val, isObject2 = false) { return isObject2 ? sessionStorage.setItem(key, JSON.stringify(val)) : sessionStorage.setItem(key, val); }, get(key, isReturnObject = false) { const val = sessionStorage.getItem(key); if (val) { try { return isReturnObject ? JSON.parse(sessionStorage.getItem(key) || "") : sessionStorage.getItem(key); } catch (e) { return null; } } else { return null; } }, remove(key) { if (!sessionStorage[key]) return false; sessionStorage.removeItem(key); return true; }, clear() { sessionStorage.clear(); } }, l: { set(key, val, isObject2 = false) { return isObject2 ? localStorage.setItem(key, JSON.stringify(val)) : localStorage.setItem(key, val); }, get(key, isReturnObject = false) { const val = localStorage.getItem(key); if (val) { try { return isReturnObject ? JSON.parse(localStorage.getItem(key) || "") : localStorage.getItem(key); } catch (e) { return null; } } else { return null; } }, remove(key) { if (!localStorage[key]) return false; localStorage.removeItem(key); return true; }, clear() { localStorage.clear(); } } }; var debounce = (func, wait, immediate = false) => { let timeoutId; return function(...args) { const context = this; const doLater = () => { timeoutId = void 0; if (!immediate) { func.apply(context, args); } }; const shouldCallNow = immediate && timeoutId === void 0; if (timeoutId !== void 0) { clearTimeout(timeoutId); } timeoutId = setTimeout(doLater, wait); if (shouldCallNow) { func.apply(context, args); } }; }; var throttle = (func, wait, options = {}) => { let timeoutId; let lastArgs; let lastCallTime; const doLater = () => { timeoutId = void 0; if (lastArgs !== void 0) { func.apply(void 0, lastArgs); lastArgs = void 0; lastCallTime = Date.now(); timeoutId = setTimeout(doLater, wait); } }; return function(...args) { const currentTime = Date.now(); if (lastCallTime === void 0 && options.leading === false) { lastCallTime = currentTime; } const remainingTime = wait - (currentTime - (lastCallTime ?? 0)); if (remainingTime <= 0 || remainingTime > wait) { if (timeoutId !== void 0) { clearTimeout(timeoutId); } func.apply(this, args); lastCallTime = currentTime; timeoutId = setTimeout(doLater, wait); } else if (options.trailing !== false) { lastArgs = args; if (timeoutId === void 0) { timeoutId = setTimeout(doLater, remainingTime); } } }; }; var cloneDeep = (val) => { if (Array.isArray(val)) { return val.map(cloneDeep); } else if (typeof val === "object" && val !== null) { const result = {}; for (const key in val) { result[key] = cloneDeep(val[key]); } return result; } else { return val; } }; var pick = (obj, keys) => { const result = {}; keys.forEach((key) => { if (key in obj) { result[key] = obj[key]; } }); return result; }; var isNil = (value) => { return value === null || value === void 0; }; var transform = (collection, iteratee, accumulator) => { const result = accumulator; if (Array.isArray(collection)) { for (let index = 0; index < collection.length; index++) { const value = collection[index]; const shouldContinue = iteratee( result, value, index, collection ); if (shouldContinue === false) break; } } else { for (const key in collection) { if (Object.prototype.hasOwnProperty.call(collection, key)) { const value = collection[key]; const shouldContinue = iteratee( result, value, key, collection ); if (shouldContinue === false) break; } } } return result; }; function getBrowser() { const userAgent = navigator.userAgent; const getVersion = (userAgent2, reg) => { const reBrowser = new RegExp(reg); reBrowser.test(userAgent2); return ` ${RegExp["$1"]}`; }; const _windows = window; let version; if (/opera/i.test(userAgent) || /OPR/i.test(userAgent)) { version = getVersion(userAgent, "OPR/(\\d+\\.\\d+)?"); return "Opera" + version; } else if (/compatible/i.test(userAgent) && /MSIE/i.test(userAgent)) { version = getVersion(userAgent, "MSIE (\\d+\\.+\\d+)?"); return "IE" + version; } else if (/Edg/i.test(userAgent)) { version = getVersion(userAgent, "Edg/(\\d+\\.*\\d+)?"); return "Edge" + version; } else if (/Firefox/i.test(userAgent)) { version = getVersion(userAgent, "Firefox/(\\d+\\.+\\d+)?"); return "Firefox" + version; } else if (/Safari/i.test(userAgent) && !/Chrome/i.test(userAgent)) { version = getVersion(userAgent, "Safari/(\\d+\\.+\\d+)?"); return "Safari" + version; } else if (/Chrome/i.test(userAgent) && /Safari/i.test(userAgent)) { version = getVersion(userAgent, "Chrome/(\\d+\\.+\\d+)?"); return "Chrome" + version; } else if (!!_windows.ActiveXObject || "ActiveXObject" in _windows) { version = 11; return "IE" + version; } else { return null; } } function getOS() { const userAgent = navigator.userAgent.toLowerCase(); let name = null; let version = null; if (userAgent.indexOf("win") > -1) { name = "Windows"; if (userAgent.indexOf("windows nt 10.0") > -1) { if (userAgent.indexOf("win11") > -1) { version = "11"; } else { version = "10"; } } else if (userAgent.indexOf("windows nt 6.3") > -1) { version = "8.1"; } else if (userAgent.indexOf("windows nt 6.2") > -1 || userAgent.indexOf("windows 8") > -1) { version = "8"; } else if (userAgent.indexOf("windows nt 6.1") > -1 || userAgent.indexOf("windows 7") > -1) { version = "7"; } else if (userAgent.indexOf("windows nt 6.0") > -1) { version = "Vista"; } else if (userAgent.indexOf("windows nt 5.1") > -1 || userAgent.indexOf("windows nt 5.2") > -1) { version = "XP"; } else if (userAgent.indexOf("windows nt 5.0") > -1) { version = "2000"; } } else if (userAgent.indexOf("iphone") > -1) { name = "iPhone"; } else if (userAgent.indexOf("mac") > -1) { name = "Mac"; } else if (userAgent.indexOf("android") > -1) { name = "Android"; } else if (userAgent.indexOf("x11") > -1 || userAgent.indexOf("unix") > -1 || userAgent.indexOf("sunname") > -1 || userAgent.indexOf("bsd") > -1) { name = "Unix"; } else if (userAgent.indexOf("linux") > -1) { name = "Linux"; } const os = version && name ? `${name} ${version}` : name ? name : null; return os; } function isMobile() { if (typeof navigator != "undefined" && navigator && (navigator.userAgent.indexOf("iPod") != -1 || navigator.userAgent.indexOf("iPad") != -1 || navigator.userAgent.indexOf("Android") != -1)) { return true; } else { return false; } } var isClientSide = typeof window !== "undefined"; var isServerSide = !isClientSide; var isDev = false; var shimmer = (w, h) => ` `; var toBase64 = (str) => typeof window === "undefined" ? Buffer.from(str).toString("base64") : window.btoa(str); function makeBlurDataURL(width, height) { return `data:image/svg+xml;base64,${toBase64(shimmer(width, height))}`; } var getImageExt = (file) => { if (!file || !file.type) { return null; } const mimeType = file.type; if (mimeType === "image/jpeg") { return "jpeg"; } else if (mimeType === "image/png") { return "png"; } else if (mimeType === "image/gif") { return "gif"; } else if (mimeType === "image/webp") { return "webp"; } else if (mimeType === "image/svg+xml") { return "svg"; } else if (mimeType === "image/bmp") { return "bmp"; } else if (mimeType === "image/tiff") { return "tiff"; } else { return null; } }; var getImageMimeType = (ext) => { switch (ext) { case "jpeg": return "image/jpeg"; case "jpg": return "image/jpg"; case "png": return "image/png"; case "gif": return "image/gif"; case "webp": return "image/webp"; case "svg": return "image/svg+xml"; case "bmp": return "image/bmp"; case "tiff": return "image/tiff"; default: return null; } }; var SNOW = ""; var SAKURA = ""; var Sakura = class { constructor(x, y, s, r, fn, idx) { __publicField(this, "x"); __publicField(this, "y"); __publicField(this, "s"); __publicField(this, "r"); __publicField(this, "fn"); __publicField(this, "idx"); this.x = x; this.y = y; this.s = s; this.r = r; this.fn = fn; this.idx = idx; } draw(cxt, img) { cxt.save(); 40 * this.s / 4; cxt.translate(this.x, this.y); cxt.rotate(this.r); cxt.drawImage(img, 0, 0, 40 * this.s, 40 * this.s); cxt.restore(); } update(limitArray, getRandom) { this.x = this.fn.x(this.x, this.y); this.y = this.fn.y(this.x, this.y); this.r = this.fn.r(this.r); if (this.x > window.innerWidth || this.x < 0 || this.y > window.innerHeight || this.y < 0) { if (limitArray[this.idx] === -1) { this.reset(getRandom); } else { if (limitArray[this.idx] > 0) { this.reset(getRandom); limitArray[this.idx]--; } } } } reset(getRandom) { this.r = getRandom("fnr"); if (Math.random() > 0.4) { this.x = getRandom("x"); this.y = 0; this.s = getRandom("s"); this.r = getRandom("r"); } else { this.x = window.innerWidth; this.y = getRandom("y"); this.s = getRandom("s"); this.r = getRandom("r"); } } }; var SakuraList = class { constructor() { __publicField(this, "list", []); } push(sakura) { this.list.push(sakura); } update(limitArray, getRandom) { for (const sakura of this.list) { sakura.update(limitArray, getRandom); } } draw(cxt, img) { for (const sakura of this.list) { sakura.draw(cxt, img); } } }; var SakuraAnimation = class { constructor() { __publicField(this, "stopId", null); __publicField(this, "staticx", false); __publicField(this, "img"); __publicField(this, "sakuraNum"); __publicField(this, "limitTimes"); __publicField(this, "limitArray"); __publicField(this, "sakuraList"); __publicField(this, "onResize", () => { const canvasSnow = document.getElementById( "canvas_snow" ); if (canvasSnow) { canvasSnow.width = window.innerWidth; canvasSnow.height = window.innerHeight; } }); this.img = new Image(); this.sakuraNum = this.isMobile() ? 3 : 10; this.limitTimes = -1; this.limitArray = new Array(this.sakuraNum).fill(this.limitTimes); this.sakuraList = new SakuraList(); window.addEventListener("resize", this.onResize); } isMobile() { return navigator.userAgent.indexOf("iPod") !== -1 || navigator.userAgent.indexOf("iPad") !== -1 || navigator.userAgent.indexOf("Android") !== -1; } getRandom(option) { let ret, random; switch (option) { case "x": ret = Math.random() * window.innerWidth; break; case "y": ret = Math.random() * window.innerHeight; break; case "s": ret = Math.random(); break; case "r": ret = Math.random() * 6; break; case "fnx": random = -0.3 + Math.random() * 1; ret = (x, y) => x + 0.5 * random - 1.7; break; case "fny": random = 1.1 + Math.random() * 0.7; ret = (x, y) => y + random; break; case "fnr": random = Math.random() * 0.03; ret = (r) => r + random; break; } return ret; } setImage(src) { this.img.src = src; this.img.onload = () => { this.startSakura(); }; } startSakura() { const canvas = document.createElement("canvas"); canvas.height = window.innerHeight; canvas.width = window.innerWidth; canvas.setAttribute( "style", "position: fixed; left: 0; top: 0; pointer-events: none; opacity: 0.4;" ); canvas.setAttribute("id", "remio_sakura"); document.body.appendChild(canvas); const cxt = canvas.getContext("2d"); for (let i = 0; i < this.sakuraNum; i++) { const sakura = new Sakura( this.getRandom("x"), this.getRandom("y"), this.getRandom("s"), this.getRandom("r"), { x: this.getRandom("fnx"), y: this.getRandom("fny"), r: this.getRandom("fnr") }, i ); sakura.draw(cxt, this.img); this.sakuraList.push(sakura); } this.staticx = true; this.stopId = requestAnimationFrame(this.update.bind(this, cxt)); } update(cxt) { cxt.clearRect(0, 0, cxt.canvas.width, cxt.canvas.height); this.sakuraList.update(this.limitArray, this.getRandom.bind(this)); this.sakuraList.draw(cxt, this.img); this.stopId = requestAnimationFrame(this.update.bind(this, cxt)); } stop() { var _a2; if (this.staticx) { const child = document.getElementById("remio_sakura"); if (child) { (_a2 = child.parentNode) == null ? void 0 : _a2.removeChild(child); if (this.stopId !== null) { cancelAnimationFrame(this.stopId); } } this.staticx = false; } else { this.startSakura(); } } }; var aSakura = (src = SAKURA) => { var _a2; const child = document.getElementById("remio_sakura"); if (child) (_a2 = child.parentNode) == null ? void 0 : _a2.removeChild(child); const sakuraAnimation = new SakuraAnimation(); switch (src) { case "sakura": sakuraAnimation.setImage(SAKURA); break; case "snow": sakuraAnimation.setImage(SNOW); break; default: sakuraAnimation.setImage(SAKURA); break; } }; var isValidUrl = (url2, validHttp = false, returnHost = false) => { if (!url2) return false; try { const newUrl = new URL(url2); if (validHttp) return newUrl.protocol === "http:" || newUrl.protocol === "https:"; if (returnHost) return newUrl.host; return true; } catch (err) { return false; } }; function url(path = "") { if ("https://example.com".includes("localhost")) { path = path.replace("/api", ""); } const baseUrl = "https://example.com"; return new URL(path, baseUrl); } function onDomain(url2, onlyRoot = true) { const hostname = new URL( url2.includes("http") ? url2 : `http://${url2}` ).hostname.replace("www.", ""); const parts = hostname.split("."); if (parts.length <= 2 || !onlyRoot) { return hostname; } return parts.slice(-2).join("."); } var reboundPreset = { type: "spring", bounce: 1, // 弹性效果的弹性程度 stiffness: 140, // 弹性表现硬度的数值 damping: 8 // 反方向的阻力 }; var microDampingPreset = { type: "spring", damping: 24 }; var microReboundPreset = { type: "spring", stiffness: 300, damping: 20 }; var softSpringPreset = { duration: 0.35, type: "spring", stiffness: 120, damping: 20 }; var softBouncePreset = { type: "spring", damping: 10, stiffness: 100 }; var upTransition = { from: { y: 50, opacity: 1e-3 }, to: { y: 0, opacity: 1 }, preset: softBouncePreset }; var downTransition = { from: { y: -50, opacity: 1e-3 }, to: { y: 0, opacity: 1 }, preset: softBouncePreset }; var toRightTransition = { from: { translateX: -70, opacity: 1e-3 }, to: { translateX: 0, opacity: 1 } }; var toLeftTransition = { from: { translateX: 70, opacity: 1e-3 }, to: { translateX: 0, opacity: 1 } }; var fadeInTransition = { from: { opacity: 1e-3 }, to: { opacity: 1 } }; var fadeOutTransition = { from: { opacity: 1 }, to: { opacity: 1e-3 } }; var increaseTransition = { from: { scale: 1e-3, opacity: 1e-3 }, to: { scale: 1, opacity: 1 } }; var decreaseTransition = { from: { scale: 1, opacity: 1 }, to: { scale: 1e-3, opacity: 1e-3 } }; var transitions = { up: upTransition, down: downTransition, toRight: toRightTransition, toLeft: toLeftTransition, fadeIn: fadeInTransition, fadeOut: fadeOutTransition, increase: increaseTransition, decrease: decreaseTransition }; var bufferToBase64 = (buffer) => { return buffer.toString("base64"); }; var base64ToBuffer = (base64Str) => { return Buffer.from(base64Str, "base64"); }; var bufferToBlbo = (buffer) => { return new Blob([buffer]); }; var bufferToBlboUrl = (buffer) => { return URL.createObjectURL(new Blob([buffer])); }; var blboToBuffer = async (blob) => { return Buffer.from(await blob.arrayBuffer()); }; var fileToBuffer = async (file) => { const arrayBuffer = await file.arrayBuffer(); return Buffer.from(arrayBuffer); }; var fileToBlbo = async (file) => { const reader = new FileReader(); reader.addEventListener("load", (e) => { var _a2; const base64 = ((_a2 = e.target) == null ? void 0 : _a2.result) || ""; return base64 ? new Blob([base64], { type: file.type }) : null; }); reader.readAsDataURL(file); }; function getFileSize(size, { decimalPlaces = 2, showByte = true, showSuffix = true } = {}) { if (!size) return 0; if (typeof decimalPlaces !== "number" || !Number.isInteger(decimalPlaces)) { throw new Error("decimalPlaces 必须是一个整数"); } const units = ["B", "K", "M", "G", "T"]; const powers = [0, 1, 2, 3, 4]; const num = 1024; const precalculated = powers.map((power) => Math.pow(num, power)); let unitIndex = 0; while (size >= precalculated[unitIndex + 1] && unitIndex < precalculated.length - 1) { unitIndex++; } const buildSizeString = (value, unit, _showSuffix = showSuffix) => { const suffix = ` ${unit}${_showSuffix ? "B" : ""}`; return value.toFixed(decimalPlaces) + suffix; }; if (showByte && size < num) { return buildSizeString(size, "B", false); } return buildSizeString(size / precalculated[unitIndex], units[unitIndex]); } var getRandomElements = (array, count) => { if (!(array == null ? void 0 : array.length)) return array; const shuffled = [...array].sort(() => 0.5 - Math.random()); return shuffled.slice(0, count); }; var shuffleArray = (array) => { return [...array].sort(() => Math.random() - 0.5); }; return dist; } var distExports = requireDist(); const BaseUrl = "https://example.com"; let DATE = ""; let mioDates = ""; let artwork = null; const isArtwork = () => { if (window.location.pathname && window.location.pathname.includes("artworks")) { const pathname = window.location.pathname.split("/"); if (pathname == null ? void 0 : pathname.length) { return +pathname[pathname.length - 1]; } else { return null; } } else { return null; } }; let pid = isArtwork(); const createRadio = (id, name, value, labelText, div2, field) => { const radioButton = document.createElement("input"); radioButton.type = "radio"; radioButton.id = id; radioButton.name = name; radioButton.value = value.toString(); radioButton.addEventListener("click", () => { artwork[field] = +radioButton.value; }); if (+artwork[field] == +value) { radioButton.checked = true; } const label = document.createElement("label"); label.htmlFor = id; label.textContent = labelText; div2.className = "mio-options-item"; div2.appendChild(radioButton); div2.appendChild(label); }; const renderOptions = (root) => { const tips = document.createElement("p"); tips.className = "mio-result-message"; const r18 = document.createElement("div"); createRadio("r18-option0", "r18options", 10, "默认", r18, "r18"); createRadio("r18-option1", "r18options", 0, "r12", r18, "r18"); createRadio("r18-option2", "r18options", 1, "r18", r18, "r18"); createRadio("r18-option3", "r18options", 2, "全年龄", r18, "r18"); const wall = document.createElement("div"); createRadio("wall-option0", "walloptions", 0, "默认", wall, "wallpaper"); createRadio("wall-option1", "walloptions", 1, "横屏壁纸", wall, "wallpaper"); createRadio("wall-option2", "walloptions", 2, "竖屏壁纸", wall, "wallpaper"); createRadio("wall-option3", "walloptions", 3, "头像", wall, "wallpaper"); root.appendChild(r18); root.appendChild(wall); root.appendChild(tips); }; const topError = (text) => { const error = document.querySelector(".mio-error"); if (error) { error.innerText = text; } }; const onTips = (text, error) => { let msg = document.querySelector(".mio-result-message"); if (msg) { msg.style.color = error ? "red" : "#69f769"; msg.innerHTML = text; } }; const format = (v, date, mode, uid, uploadName) => { var _a2, _b2, _c, _d, _e, _f, _g, _h; let tags = (v == null ? void 0 : v.tags) || []; let pageCount = +v.illust_page_count; let pathDate = null, pixAvatar = null, exts = []; if (v.attr == "original" && !tags.includes("original")) { tags.push("原创"); tags.push("original"); } if (tags == null ? void 0 : tags.length) { tags = tags.filter((vv) => { return vv && !vv.includes("收藏") && !vv.includes("users") && !vv.includes("bookmarks") && !vv.includes("Bookmarks") && !vv.includes("R-18"); }); } const matches = v.url.match(/\/(\d{4}\/\d{2}\/\d{2}\/\d{2}\/\d{2}\/\d{2})\//); if (matches && matches[1]) { pathDate = matches[1]; } const extArr = (_a2 = v.url) == null ? void 0 : _a2.split("."); if (extArr == null ? void 0 : extArr.length) { const ext = extArr[extArr.length - 1]; for (let index = 0; index < pageCount; index++) { exts.push(ext); } } if (v.profile_img && !v.profile_img.includes("no_profile")) { pixAvatar = (_c = (_b2 = v.profile_img) == null ? void 0 : _b2.replace("https://i.pximg.net/user-profile/img/", "")) == null ? void 0 : _c.replace("_50", ""); } return { pid: v.illust_id, uid: v.user_id, author: ((_h = (_g = (_f = (_e = (_d = v.user_name) == null ? void 0 : _d.replace(/@(.*)/, "")) == null ? void 0 : _e.replace(/@(.*)/, "")) == null ? void 0 : _f.replace(/❤(.*)/, "")) == null ? void 0 : _g.replace(/■(.*)/, "")) == null ? void 0 : _h.replace(/▶(.*)/, "")) || v.user_name, rankType: mode, tags: tags == null ? void 0 : tags.join(","), exts: exts[0], pageCount, title: v.title, datePath: pathDate, pixAvatar, width: v.width, height: v.height, aspectRatio: Math.round(v.width / v.height * 1e3) / 1e3, createDate: new Date( new Date(v.illust_upload_timestamp * 1e3).toLocaleString("chinese", { hour12: false }) ), viewCount: v.view_count, ratingCount: v.rating_count, illusType: +v.illust_type, uploadName, uploadUid: uid, status: (v == null ? void 0 : v.is_bookmarked) ? v.yes_rank - 101 : v.yes_rank, startDate: v.yes_rank == 0 ? `${date}_${v.yes_rank}:${v.rank}` : null, endDate: v.yes_rank > 0 ? `${date}_${v.yes_rank}:${v.rank}` : null }; }; const formatIllust = (image) => { var _a2, _b2, _c, _d, _e, _f, _g; let { id, height, width, aiType, pageCount, urls, createDate, bookmarkCount, illustType, title, tags: { tags: tagsObj }, userName: author, userId: uid, userAccount: account } = image; let datePath = null, pixAvatar = null, ext = null, tag = [], r18 = 10; const divAvatar = document.querySelector(`a[href="/users/${uid}"]`); if (divAvatar) { const src = ((_a2 = divAvatar.querySelector("img")) == null ? void 0 : _a2.src) || null; if (src && !src.includes("no_profile")) { pixAvatar = (_c = (_b2 = src.replace("https://i.pximg.net/user-profile/img/", "")) == null ? void 0 : _b2.replace("_170", "")) == null ? void 0 : _c.replace("_50", ""); } } if (urls && urls.original) { let matches = urls.original.match( /\/(\d{4}\/\d{2}\/\d{2}\/\d{2}\/\d{2}\/\d{2})\// ); if (matches && matches[1]) { datePath = matches[1]; } const arrs = urls.original.split("."); ext = arrs[arrs.length - 1]; } if (tagsObj == null ? void 0 : tagsObj.length) { tagsObj.forEach((v) => { if (r18 != 1 && v.tag.includes("R-18")) { return r18 = 1; } if (v.tag.includes("收藏") || v.tag.includes("users") || v.tag.includes("bookmarks") || v.tag.includes("Bookmarks")) { return; } if (aiType != 2 && (v.tag.includes("AIイラスト") || v.tag.includes("ai绘图"))) { aiType = 2; } if (v.tag) { tag.push(v.tag); } if (v.translation && v.translation.en) { tag.push(v.translation.en); } return v; }); } tag = [...new Set(tag)]; const userDom = document.querySelector("div.sc-1asno00-0"); const uploadUserName = userDom == null ? void 0 : userDom.getAttribute("title"); return { pid: +id, pixAccount: account, illustType, height, width, aiType, pageCount, createDate, status: bookmarkCount, pixAvatar, title, uid, ext: [ext], r18, wallpaper: 0, aspectRatio: Math.round(width / height * 1e3) / 1e3, author: ((_g = (_f = (_e = (_d = author == null ? void 0 : author.replace(/@(.*)/, "")) == null ? void 0 : _d.replace(/@(.*)/, "")) == null ? void 0 : _e.replace(/❤(.*)/, "")) == null ? void 0 : _f.replace(/■(.*)/, "")) == null ? void 0 : _g.replace(/▶(.*)/, "")) || author, datePath, tag, tags: tag.join(","), uploadUid: -1, uploadUserName }; }; const getDate = (prev, next, date) => { let currentDate = /* @__PURE__ */ new Date(); if (!prev && !next) { if (currentDate.getHours() > 12 || currentDate.getHours() === 12 && currentDate.getMinutes() > 0) { currentDate.setDate(currentDate.getDate() - 1); } else { currentDate.setDate(currentDate.getDate() - 2); } } else if (date) { const year2 = date.slice(0, 4); const month2 = date.slice(4, 6) - 1; const day2 = date.slice(6, 8); currentDate = new Date(year2, month2, day2); if (prev) { currentDate.setDate(currentDate.getDate() - 1); } else { currentDate.setDate(currentDate.getDate() + 1); } } const year = currentDate.getFullYear(); const month = String(currentDate.getMonth() + 1).padStart(2, "0"); const day = String(currentDate.getDate()).padStart(2, "0"); return `${year}${month}${day}`; }; const getRankAndToMio = (_e) => { if (!onCheckDate()) return; const urlParams = new URLSearchParams(window.location.search); let mode = urlParams.get("mode"), date = DATE; let data = [], url = `/ranking.php?format=json`, uid = null; if (mode) url = `${url}&mode=${mode}`; if (date) url = `${url}&date=${date}`; const userDom = document.querySelector("div.sc-1asno00-0"); const uploadName = userDom == null ? void 0 : userDom.getAttribute("title"); onLoading(true); const page_1 = request({ method: "GET", url: `${url}&p=1`, headers: { referer: "https://www.pixiv.net/", "Accept-Language:": "zh-CN,zh-CN;q=0.9,zh;q=0.8,en-US;q=0.7,en,en-CN;q=0.6" } }); const page_2 = request({ method: "GET", url: `${url}&p=2`, headers: { referer: "https://www.pixiv.net/", "Accept-Language:": "zh-CN,zh-CN;q=0.9,zh;q=0.8,en-US;q=0.7,en,en-CN;q=0.6" } }); Promise.all([page_1, page_2]).then(([res_1, res_2]) => { if (res_1 && res_2) { const { contents: page1, date: date1, mode: mode1 } = res_1; const { contents: page2, date: date2, mode: mode2, prev_date, next_date } = res_2; if (date1 == date2 && mode1 == mode2) { [...page1, ...page2].forEach((ele) => { data.push(format(ele, date1, mode1, uid, uploadName)); }); return { rankDate: date1, prevDate: prev_date, nextDate: next_date, rankType: mode1, uploadName, rankList: data }; } } return null; }).then((params) => { if (!params) return topError("❗未获取到数据~"); if (!input.value && distExports.isValidUrl(input.value)) return topError("❗请求地址不正确,请检查~"); storage.set("RankApi", input.value); const proMsg = document.querySelector(".mio-pro-msg"); if (proMsg) { content.removeChild(proMsg); } content.innerHTML = content.innerHTML + `
当前排行榜类型为:${params.rankType}
过滤一些非插画类型,实际抓取数据量为:${params.rankList.length}条
开始发送数据...
Pid:${artwork.pid} 画师:${artwork.author}
标题:${artwork.title}
标签:${artwork.tags}
`; renderOptions(content); } }); }; const NOW = getDate(); const actions = document.createElement("div"); const content = document.createElement("div"); const addMio = document.createElement("button"); const prevBtn = document.createElement("button"); const nextBtn = document.createElement("button"); const span = document.createElement("span"); const input = document.createElement("input"); const html = document.querySelector("html"); const div = document.createElement("div"); div.id = "mio-tools"; const main = document.createElement("div"); main.className = "mio-tools-main"; const onLoading = (loading) => { if (loading) { addMio.disabled = true; } else { addMio.disabled = false; } }; const onModalChange = async () => { if (div.classList.contains("mio-tools-open")) { html.style.overflow = "unset"; div.classList.remove("mio-tools-open"); content.innerHTML = ""; } else { const ArtApi = await storage.get("ArtApi", `${BaseUrl}/img/save`); const RankApi = await storage.get("RankApi", `${BaseUrl}/prank/newDate`); mioDates = await storage.get("mio-dates", ""); html.style.overflow = "hidden"; div.classList.add("mio-tools-open"); pid = isArtwork(); if (pid) { content.innerHTML = `正在获取:${pid}数据
`; getArtwork(); input.value = ArtApi; } else { if (!DATE) { DATE = getDate(); } if (NOW == DATE) { nextBtn.disabled = true; } content.innerHTML = `将要获取排行榜数据日期为:${DATE}
`; onCheckDate(); input.value = RankApi; } } }; const onCheckDate = () => { if (mioDates && mioDates.includes(DATE)) { topError("💤当前日期已抓取过~"); return false; } else { const error = document.querySelector(".mio-error"); error.innerText = ""; return true; } }; span.innerHTML = ` `; span.className = "mio-tools-main-close"; span.addEventListener("click", (_e) => onModalChange()); addMio.innerText = "抓取并提交Mio"; addMio.className = "mio-btn-add"; addMio.addEventListener("click", (_e) => { if (pid) { getArtworkAndToMio(); } else { getRankAndToMio(); } }); prevBtn.innerText = "前一天"; prevBtn.className = "mio-btn-prev"; prevBtn.addEventListener("click", (_e) => { const mioDate = document.querySelector(".mio-date"); const proMsg = content.querySelector(".mio-pro-msg"); DATE = getDate(true, null, DATE); if (NOW != DATE && nextBtn.disabled) { nextBtn.disabled = false; } if (proMsg) { content.removeChild(proMsg); } mioDate.innerText = DATE; onCheckDate(); }); nextBtn.innerText = "后一天"; nextBtn.className = "mio-btn-next"; nextBtn.addEventListener("click", (_e) => { const mioDate = document.querySelector(".mio-date"); if (NOW == DATE) { nextBtn.disabled = true; } else { DATE = getDate(null, true, DATE); const proMsg = content.querySelector(".mio-pro-msg"); if (proMsg) { content.removeChild(proMsg); } mioDate.innerText = DATE; onCheckDate(); } }); actions.className = "mio-tools-main-btns"; actions.appendChild(input); if (!pid) { actions.appendChild(prevBtn); actions.appendChild(nextBtn); } actions.appendChild(addMio); content.className = "mio-tools-main-content"; main.appendChild(span); main.appendChild(content); main.appendChild(actions); div.appendChild(main); const btn = document.createElement("button"); btn.id = "mio-tools-btn"; btn.addEventListener("click", (_e) => onModalChange()); btn.innerHTML = "Mio"; (_a = document.querySelector("body")) == null ? void 0 : _a.appendChild(btn); _GM.addStyle(` html { &::-webkit-scrollbar { width: 4px; transition: all .3s ease-in-out; } &::-webkit-scrollbar-thumb { cursor: pointer; border-radius: 10px; transition: all .15s ease-in-out; background: rgba(255, 255, 255, 0.15); box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.1); } &::-webkit-scrollbar-track { border-radius: 10px; box-shadow: inset 0 0 5px rgba(0, 0, 0, 0.1); background: rgba(255, 255, 255, 0.05); } &::-webkit-scrollbar-thumb:hover { @apply bg-[#64d1e2]; } } #mio-tools-btn { position: fixed; right: 0px; top: 85%; border-radius: 16px; width: 36px; height: 36px; outline: none; border: none; padding: 6px 10px; z-index: 10; background: #0097fac7; display: flex; align-items: center; justify-content: center; cursor: pointer; color: #fff; } #mio-tools { position: fixed; display: flex; align-items: center; justify-content: center; width: 0; height: 0; overflow: hidden; top: 0; right: 0; background: #00000080; backdrop-filter: blur(2px); z-index: 99; } .mio-tools-open { width: 100% !important; height: 100vh !important; > .mio-tools-main { position: relative; background: #010101; width: 600px; height: 300px; border-radius: 16px; padding: 32px; transition: all .1s ease-in-out; display: flex; flex-direction: column; justify-content: space-between; gap: 16px; .mio-tools-main-close { position: absolute; right: 10px; top: 10px; color: #ffffff; cursor: pointer; rotate: 0deg; transition: all .3s ease-in-out; &:hover { transform: scale(1.1); color: #0097fa; rotate: 180deg; } } .mio-tools-main-content { flex: 1; color: #ffffff; display: flex; flex-direction: column; gap: 10px; .mio-options-item { display: flex; align-items: center; gap: 5px; user-select: none; > input, label { cursor: pointer; } > label { margin-right: 20px; } } } .mio-tools-main-btns { display: flex; justify-content: flex-end; gap: 16px; .mio-btn-add, .mio-btn-prev, .mio-btn-next { outline: none; border: none; padding: 6px 10px; border-radius: 10px; cursor: pointer; background: #0097fa; color: #ebebeb; } button:disabled { opacity: 0.7; cursor: not-allowed; } > input { outline: none; border: none; color: #ffffff; background-color: rgba(255, 255, 255, .3); width: 250px; border-radius: 8px; padding: 6px 8px; } } } } `); (_b = document.querySelector("body")) == null ? void 0 : _b.appendChild(div); })();