// ==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
// ==/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) => `
<svg width="${w}" height="${h}" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" opacity="0.5">
<defs>
<linearGradient id="g-image-shimmer">
<stop stop-color="#ccc" offset="20%" />
<stop stop-color="#eee" offset="50%" />
<stop stop-color="#ccc" offset="70%" />
</linearGradient>
</defs>
<rect width="${w}" height="${h}" fill="#333" />
<rect id="r" width="${w}" height="${h}" fill="url(#g-image-shimmer)" />
<animate xlink:href="#r" attributeName="x" from="-${w}" to="${w}" dur="1s" repeatCount="indefinite" />
</svg>`;
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 + `
<div class="mio-pro-msg" style="display: flex;flex-direction: column;gap: 10px;">
<p>当前排行榜类型为:${params.rankType}</p>
<p>过滤一些非插画类型,实际抓取数据量为:${params.rankList.length}条</p>
<p>开始发送数据...</p>
<p style="color: #69f769;" class="mio-result-message"></p>
</div>
`;
let msg = document.querySelector(".mio-result-message");
request({
method: "POST",
url: input.value,
headers: { "Content-Type": "application/json" },
data: JSON.stringify(params)
}).then((res) => {
console.log("请求mio结果:", res);
if (res.success) {
msg.innerHTML = "🎉好耶!发送数据成功~";
if (mioDates) {
_GM.setValue("mio-dates", `${mioDates},${date}`);
mioDates = `${mioDates},${date}`;
} else {
_GM.setValue("mio-dates", date);
mioDates = data;
}
} else {
msg.style.color = "red";
msg.innerHTML = `💔发送失败惹。${(res == null ? void 0 : res.message) || ""}`;
}
_GM.notification(res.message);
}).catch((e) => {
msg.style.color = "red";
msg.innerHTML = `💔发送失败惹。${(e == null ? void 0 : e.statusText) || e}`;
}).finally(() => {
onLoading(false);
});
}).finally(() => {
onLoading(false);
});
};
const getArtworkAndToMio = (_e) => {
console.log("artwork", artwork, input.value);
if (+artwork.pid == +(pid || 0) && artwork.illustType == 0) {
if (!input.value && distExports.isValidUrl(input.value))
return topError("❗请求地址不正确,请检查~");
storage.set("ArtApi", input.value);
request({
method: "POST",
url: input.value,
headers: { "Content-Type": "application/json" },
data: JSON.stringify(artwork)
}).then((res) => {
console.log("请求新增mio结果:", res);
if (res.success) {
onTips(`🎉好耶!${res.message}~`);
} else {
onTips(`💔新增失败惹。${(res == null ? void 0 : res.message) || ""}~`, true);
}
}).catch((e) => onTips(`💔新增失败惹。${e == null ? void 0 : e.statusText}~`, true)).finally(() => {
onLoading(false);
});
} else {
topError(
artwork.pid != pid ? "❗pid不一致,请检查~" : "💤该作品类型不支持添加mio~"
);
}
};
const getArtwork = () => {
request({
method: "GET",
url: `/ajax/illust/${pid}`,
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"
}
}).then((res) => {
if (!res.error) {
artwork = formatIllust(res.body);
if (artwork.illustType != 0 || artwork.tag.includes("漫画") || artwork.tag.includes("manga")) {
topError("💤该作品类型不支持添加mio~");
addMio.disabled = true;
} else {
topError("");
addMio.disabled = false;
}
content.innerHTML = content.innerHTML + `
<p>Pid:${artwork.pid} 画师:${artwork.author}</P>
<p>标题:${artwork.title}</P>
<p>标签:${artwork.tags}</P>
`;
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 = `
<p style="color: #f5765c;" class="mio-error"></p>
<p>正在获取:<span style="color: #69f769;" class="mio-date">${pid}</span>数据</p>
`;
getArtwork();
input.value = ArtApi;
} else {
if (!DATE) {
DATE = getDate();
}
if (NOW == DATE) {
nextBtn.disabled = true;
}
content.innerHTML = `
<p style="color: #f5765c;" class="mio-error"></p>
<p>将要获取排行榜数据日期为:<span style="color: #69f769;" class="mio-date">${DATE}</span></p>
`;
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 = `
<svg width="24" height="24" viewBox="0 0 15 15" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M11.7816 4.03157C12.0062 3.80702 12.0062 3.44295 11.7816 3.2184C11.5571 2.99385 11.193 2.99385 10.9685 3.2184L7.50005 6.68682L4.03164 3.2184C3.80708 2.99385 3.44301 2.99385 3.21846 3.2184C2.99391 3.44295 2.99391 3.80702 3.21846 4.03157L6.68688 7.49999L3.21846 10.9684C2.99391 11.193 2.99391 11.557 3.21846 11.7816C3.44301 12.0061 3.80708 12.0061 4.03164 11.7816L7.50005 8.31316L10.9685 11.7816C11.193 12.0061 11.5571 12.0061 11.7816 11.7816C12.0062 11.557 12.0062 11.193 11.7816 10.9684L8.31322 7.49999L11.7816 4.03157Z" fill="currentColor" fill-rule="evenodd" clip-rule="evenodd"></path></svg>
`;
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);
})();