Raw Source
birdplane / EasyUpload PT一键转种

// ==UserScript==
// @name         EasyUpload PT一键转种
// @name:en      EasyUpload - Trackers Transfer Tool
// @namespace    https://github.com/techmovie/easy-upload
// @version      5.2.2
// @description  easy uploading torrents to other trackers
// @description:en easy uploading torrents to other trackers
// @author       birdplane
// @require      https://s4.zstatic.net/ajax/libs/jquery/1.7.1/jquery.min.js
// @match        https://*/torrents.php?id=*
// @match        http://*/torrents.php?id=*
// @match        https://broadcasthe.net/torrents.php?torrentid=*
// @match        http://*/details.php?id=*
// @match        https://*/details.php?id=*
// @match        https://totheglory.im/t/*
// @match        https://beyond-hd.me/torrents/*
// @match        https://blutopia.cc/torrents/*
// @match        https://blutopia.cc/torrents?*
// @match        https://blutopia.cc/upload/*
// @match        https://fearnopeer.com/torrents/*
// @match        https://fearnopeer.com/torrents?*
// @match        https://pt.hdpost.top/torrents?*
// @match        https://pt.hdpost.top/torrents/*
// @match        https://asiancinema.me/torrents/*
// @match        https://asiancinema.me/torrents?*
// @match        https://aither.cc/torrents/*
// @match        https://aither.cc/torrents?*
// @match        https://ptpimg.me/*
// @match        https://*/upload*
// @match        http://*/upload*
// @match        https://*/offers.php*
// @match        https://broadcity.in/browse.php?imdb=*
// @match        https://privatehd.to/torrent/*
// @match        https://avistaz.to/torrent/*
// @exclude      https://privatehd.to/torrent/peers*
// @exclude      https://avistaz.to/torrent/peers*
// @exclude      https://privatehd.to/torrent/history*
// @exclude      https://avistaz.to/torrent/history*
// @match        https://cinemaz.to/torrent/*
// @exclude      https://cinemaz.to/torrent/peers*
// @exclude      https://cinemaz.to/torrent/history*
// @match        https://piratethenet.org/browse.php?*
// @match        https://teamhd.org/details/id*
// @match        https://hd-space.org/index.php?page=upload
// @match        https://hd-space.org/index.php?page=torrent-details&id=*
// @match        https://speedapp.io/browse/*
// @match        https://zhuque.in/torrent/upload
// @match        https://monikadesign.uk/torrents/*
// @match        https://monikadesign.uk/torrents?*
// @match        https://monikadesign.uk/upload/*
// @match        https://lst.gg/torrents/*
// @match        https://lst.gg/torrents?*
// @match        https://*.m-team.cc/detail/*
// @match        https://www.morethantv.me/upload.php

// @run-at       document-end
// @grant        GM_addStyle
// @grant        GM_getValue
// @grant        GM_setValue
// @grant        GM_openInTab
// @grant        GM_xmlhttpRequest
// @grant        GM_setClipboard
// @downloadURL  https://github.com/techmovie/easy-upload/raw/master/dist/easy-upload.user.js
// @updateURL    https://github.com/techmovie/easy-upload/raw/master/dist/easy-upload.user.js
// @license      MIT
// ==/UserScript==
(() => {
  var __create = Object.create;
  var __defProp = Object.defineProperty;
  var __defProps = Object.defineProperties;
  var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
  var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
  var __getOwnPropNames = Object.getOwnPropertyNames;
  var __getOwnPropSymbols = Object.getOwnPropertySymbols;
  var __getProtoOf = Object.getPrototypeOf;
  var __hasOwnProp = Object.prototype.hasOwnProperty;
  var __propIsEnum = Object.prototype.propertyIsEnumerable;
  var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
  var __spreadValues = (a3, b3) => {
    for (var prop in b3 || (b3 = {}))
      if (__hasOwnProp.call(b3, prop))
        __defNormalProp(a3, prop, b3[prop]);
    if (__getOwnPropSymbols)
      for (var prop of __getOwnPropSymbols(b3)) {
        if (__propIsEnum.call(b3, prop))
          __defNormalProp(a3, prop, b3[prop]);
      }
    return a3;
  };
  var __spreadProps = (a3, b3) => __defProps(a3, __getOwnPropDescs(b3));
  var __esm = (fn2, res) => function __init() {
    return fn2 && (res = (0, fn2[__getOwnPropNames(fn2)[0]])(fn2 = 0)), res;
  };
  var __commonJS = (cb, mod) => function __require() {
    return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
  };
  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.
    isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
    mod
  ));

  // node_modules/preact/dist/preact.module.js
  function a(n2, l3) {
    for (var u3 in l3) n2[u3] = l3[u3];
    return n2;
  }
  function h(n2) {
    var l3 = n2.parentNode;
    l3 && l3.removeChild(n2);
  }
  function v(l3, u3, i3) {
    var t3, o4, r3, f3 = {};
    for (r3 in u3) "key" == r3 ? t3 = u3[r3] : "ref" == r3 ? o4 = u3[r3] : f3[r3] = u3[r3];
    if (arguments.length > 2 && (f3.children = arguments.length > 3 ? n.call(arguments, 2) : i3), "function" == typeof l3 && null != l3.defaultProps) for (r3 in l3.defaultProps) void 0 === f3[r3] && (f3[r3] = l3.defaultProps[r3]);
    return y(l3, f3, t3, o4, null);
  }
  function y(n2, i3, t3, o4, r3) {
    var f3 = { type: n2, props: i3, key: t3, ref: o4, __k: null, __: null, __b: 0, __e: null, __d: void 0, __c: null, __h: null, constructor: void 0, __v: null == r3 ? ++u : r3 };
    return null == r3 && null != l.vnode && l.vnode(f3), f3;
  }
  function p() {
    return { current: null };
  }
  function d(n2) {
    return n2.children;
  }
  function _(n2, l3) {
    this.props = n2, this.context = l3;
  }
  function k(n2, l3) {
    if (null == l3) return n2.__ ? k(n2.__, n2.__.__k.indexOf(n2) + 1) : null;
    for (var u3; l3 < n2.__k.length; l3++) if (null != (u3 = n2.__k[l3]) && null != u3.__e) return u3.__e;
    return "function" == typeof n2.type ? k(n2) : null;
  }
  function b(n2) {
    var l3, u3;
    if (null != (n2 = n2.__) && null != n2.__c) {
      for (n2.__e = n2.__c.base = null, l3 = 0; l3 < n2.__k.length; l3++) if (null != (u3 = n2.__k[l3]) && null != u3.__e) {
        n2.__e = n2.__c.base = u3.__e;
        break;
      }
      return b(n2);
    }
  }
  function m(n2) {
    (!n2.__d && (n2.__d = true) && t.push(n2) && !g.__r++ || r !== l.debounceRendering) && ((r = l.debounceRendering) || o)(g);
  }
  function g() {
    for (var n2; g.__r = t.length; ) n2 = t.sort(function(n3, l3) {
      return n3.__v.__b - l3.__v.__b;
    }), t = [], n2.some(function(n3) {
      var l3, u3, i3, t3, o4, r3;
      n3.__d && (o4 = (t3 = (l3 = n3).__v).__e, (r3 = l3.__P) && (u3 = [], (i3 = a({}, t3)).__v = t3.__v + 1, j(r3, t3, i3, l3.__n, void 0 !== r3.ownerSVGElement, null != t3.__h ? [o4] : null, u3, null == o4 ? k(t3) : o4, t3.__h), z(u3, t3), t3.__e != o4 && b(t3)));
    });
  }
  function w(n2, l3, u3, i3, t3, o4, r3, f3, s3, a3) {
    var h3, v3, p3, _3, b3, m3, g4, w4 = i3 && i3.__k || c, A4 = w4.length;
    for (u3.__k = [], h3 = 0; h3 < l3.length; h3++) if (null != (_3 = u3.__k[h3] = null == (_3 = l3[h3]) || "boolean" == typeof _3 ? null : "string" == typeof _3 || "number" == typeof _3 || "bigint" == typeof _3 ? y(null, _3, null, null, _3) : Array.isArray(_3) ? y(d, { children: _3 }, null, null, null) : _3.__b > 0 ? y(_3.type, _3.props, _3.key, null, _3.__v) : _3)) {
      if (_3.__ = u3, _3.__b = u3.__b + 1, null === (p3 = w4[h3]) || p3 && _3.key == p3.key && _3.type === p3.type) w4[h3] = void 0;
      else for (v3 = 0; v3 < A4; v3++) {
        if ((p3 = w4[v3]) && _3.key == p3.key && _3.type === p3.type) {
          w4[v3] = void 0;
          break;
        }
        p3 = null;
      }
      j(n2, _3, p3 = p3 || e, t3, o4, r3, f3, s3, a3), b3 = _3.__e, (v3 = _3.ref) && p3.ref != v3 && (g4 || (g4 = []), p3.ref && g4.push(p3.ref, null, _3), g4.push(v3, _3.__c || b3, _3)), null != b3 ? (null == m3 && (m3 = b3), "function" == typeof _3.type && _3.__k === p3.__k ? _3.__d = s3 = x(_3, s3, n2) : s3 = P(n2, _3, p3, w4, b3, s3), "function" == typeof u3.type && (u3.__d = s3)) : s3 && p3.__e == s3 && s3.parentNode != n2 && (s3 = k(p3));
    }
    for (u3.__e = m3, h3 = A4; h3--; ) null != w4[h3] && ("function" == typeof u3.type && null != w4[h3].__e && w4[h3].__e == u3.__d && (u3.__d = k(i3, h3 + 1)), N(w4[h3], w4[h3]));
    if (g4) for (h3 = 0; h3 < g4.length; h3++) M(g4[h3], g4[++h3], g4[++h3]);
  }
  function x(n2, l3, u3) {
    for (var i3, t3 = n2.__k, o4 = 0; t3 && o4 < t3.length; o4++) (i3 = t3[o4]) && (i3.__ = n2, l3 = "function" == typeof i3.type ? x(i3, l3, u3) : P(u3, i3, i3, t3, i3.__e, l3));
    return l3;
  }
  function A(n2, l3) {
    return l3 = l3 || [], null == n2 || "boolean" == typeof n2 || (Array.isArray(n2) ? n2.some(function(n3) {
      A(n3, l3);
    }) : l3.push(n2)), l3;
  }
  function P(n2, l3, u3, i3, t3, o4) {
    var r3, f3, e4;
    if (void 0 !== l3.__d) r3 = l3.__d, l3.__d = void 0;
    else if (null == u3 || t3 != o4 || null == t3.parentNode) n: if (null == o4 || o4.parentNode !== n2) n2.appendChild(t3), r3 = null;
    else {
      for (f3 = o4, e4 = 0; (f3 = f3.nextSibling) && e4 < i3.length; e4 += 2) if (f3 == t3) break n;
      n2.insertBefore(t3, o4), r3 = o4;
    }
    return void 0 !== r3 ? r3 : t3.nextSibling;
  }
  function C(n2, l3, u3, i3, t3) {
    var o4;
    for (o4 in u3) "children" === o4 || "key" === o4 || o4 in l3 || H(n2, o4, null, u3[o4], i3);
    for (o4 in l3) t3 && "function" != typeof l3[o4] || "children" === o4 || "key" === o4 || "value" === o4 || "checked" === o4 || u3[o4] === l3[o4] || H(n2, o4, l3[o4], u3[o4], i3);
  }
  function $2(n2, l3, u3) {
    "-" === l3[0] ? n2.setProperty(l3, u3) : n2[l3] = null == u3 ? "" : "number" != typeof u3 || s.test(l3) ? u3 : u3 + "px";
  }
  function H(n2, l3, u3, i3, t3) {
    var o4;
    n: if ("style" === l3) if ("string" == typeof u3) n2.style.cssText = u3;
    else {
      if ("string" == typeof i3 && (n2.style.cssText = i3 = ""), i3) for (l3 in i3) u3 && l3 in u3 || $2(n2.style, l3, "");
      if (u3) for (l3 in u3) i3 && u3[l3] === i3[l3] || $2(n2.style, l3, u3[l3]);
    }
    else if ("o" === l3[0] && "n" === l3[1]) o4 = l3 !== (l3 = l3.replace(/Capture$/, "")), l3 = l3.toLowerCase() in n2 ? l3.toLowerCase().slice(2) : l3.slice(2), n2.l || (n2.l = {}), n2.l[l3 + o4] = u3, u3 ? i3 || n2.addEventListener(l3, o4 ? T : I, o4) : n2.removeEventListener(l3, o4 ? T : I, o4);
    else if ("dangerouslySetInnerHTML" !== l3) {
      if (t3) l3 = l3.replace(/xlink(H|:h)/, "h").replace(/sName$/, "s");
      else if ("href" !== l3 && "list" !== l3 && "form" !== l3 && "tabIndex" !== l3 && "download" !== l3 && l3 in n2) try {
        n2[l3] = null == u3 ? "" : u3;
        break n;
      } catch (n3) {
      }
      "function" == typeof u3 || (null != u3 && (false !== u3 || "a" === l3[0] && "r" === l3[1]) ? n2.setAttribute(l3, u3) : n2.removeAttribute(l3));
    }
  }
  function I(n2) {
    this.l[n2.type + false](l.event ? l.event(n2) : n2);
  }
  function T(n2) {
    this.l[n2.type + true](l.event ? l.event(n2) : n2);
  }
  function j(n2, u3, i3, t3, o4, r3, f3, e4, c3) {
    var s3, h3, v3, y3, p3, k4, b3, m3, g4, x3, A4, P3, C3, $4 = u3.type;
    if (void 0 !== u3.constructor) return null;
    null != i3.__h && (c3 = i3.__h, e4 = u3.__e = i3.__e, u3.__h = null, r3 = [e4]), (s3 = l.__b) && s3(u3);
    try {
      n: if ("function" == typeof $4) {
        if (m3 = u3.props, g4 = (s3 = $4.contextType) && t3[s3.__c], x3 = s3 ? g4 ? g4.props.value : s3.__ : t3, i3.__c ? b3 = (h3 = u3.__c = i3.__c).__ = h3.__E : ("prototype" in $4 && $4.prototype.render ? u3.__c = h3 = new $4(m3, x3) : (u3.__c = h3 = new _(m3, x3), h3.constructor = $4, h3.render = O), g4 && g4.sub(h3), h3.props = m3, h3.state || (h3.state = {}), h3.context = x3, h3.__n = t3, v3 = h3.__d = true, h3.__h = []), null == h3.__s && (h3.__s = h3.state), null != $4.getDerivedStateFromProps && (h3.__s == h3.state && (h3.__s = a({}, h3.__s)), a(h3.__s, $4.getDerivedStateFromProps(m3, h3.__s))), y3 = h3.props, p3 = h3.state, v3) null == $4.getDerivedStateFromProps && null != h3.componentWillMount && h3.componentWillMount(), null != h3.componentDidMount && h3.__h.push(h3.componentDidMount);
        else {
          if (null == $4.getDerivedStateFromProps && m3 !== y3 && null != h3.componentWillReceiveProps && h3.componentWillReceiveProps(m3, x3), !h3.__e && null != h3.shouldComponentUpdate && false === h3.shouldComponentUpdate(m3, h3.__s, x3) || u3.__v === i3.__v) {
            h3.props = m3, h3.state = h3.__s, u3.__v !== i3.__v && (h3.__d = false), h3.__v = u3, u3.__e = i3.__e, u3.__k = i3.__k, u3.__k.forEach(function(n3) {
              n3 && (n3.__ = u3);
            }), h3.__h.length && f3.push(h3);
            break n;
          }
          null != h3.componentWillUpdate && h3.componentWillUpdate(m3, h3.__s, x3), null != h3.componentDidUpdate && h3.__h.push(function() {
            h3.componentDidUpdate(y3, p3, k4);
          });
        }
        if (h3.context = x3, h3.props = m3, h3.__v = u3, h3.__P = n2, A4 = l.__r, P3 = 0, "prototype" in $4 && $4.prototype.render) h3.state = h3.__s, h3.__d = false, A4 && A4(u3), s3 = h3.render(h3.props, h3.state, h3.context);
        else do {
          h3.__d = false, A4 && A4(u3), s3 = h3.render(h3.props, h3.state, h3.context), h3.state = h3.__s;
        } while (h3.__d && ++P3 < 25);
        h3.state = h3.__s, null != h3.getChildContext && (t3 = a(a({}, t3), h3.getChildContext())), v3 || null == h3.getSnapshotBeforeUpdate || (k4 = h3.getSnapshotBeforeUpdate(y3, p3)), C3 = null != s3 && s3.type === d && null == s3.key ? s3.props.children : s3, w(n2, Array.isArray(C3) ? C3 : [C3], u3, i3, t3, o4, r3, f3, e4, c3), h3.base = u3.__e, u3.__h = null, h3.__h.length && f3.push(h3), b3 && (h3.__E = h3.__ = null), h3.__e = false;
      } else null == r3 && u3.__v === i3.__v ? (u3.__k = i3.__k, u3.__e = i3.__e) : u3.__e = L(i3.__e, u3, i3, t3, o4, r3, f3, c3);
      (s3 = l.diffed) && s3(u3);
    } catch (n3) {
      u3.__v = null, (c3 || null != r3) && (u3.__e = e4, u3.__h = !!c3, r3[r3.indexOf(e4)] = null), l.__e(n3, u3, i3);
    }
  }
  function z(n2, u3) {
    l.__c && l.__c(u3, n2), n2.some(function(u4) {
      try {
        n2 = u4.__h, u4.__h = [], n2.some(function(n3) {
          n3.call(u4);
        });
      } catch (n3) {
        l.__e(n3, u4.__v);
      }
    });
  }
  function L(l3, u3, i3, t3, o4, r3, f3, c3) {
    var s3, a3, v3, y3 = i3.props, p3 = u3.props, d3 = u3.type, _3 = 0;
    if ("svg" === d3 && (o4 = true), null != r3) {
      for (; _3 < r3.length; _3++) if ((s3 = r3[_3]) && "setAttribute" in s3 == !!d3 && (d3 ? s3.localName === d3 : 3 === s3.nodeType)) {
        l3 = s3, r3[_3] = null;
        break;
      }
    }
    if (null == l3) {
      if (null === d3) return document.createTextNode(p3);
      l3 = o4 ? document.createElementNS("http://www.w3.org/2000/svg", d3) : document.createElement(d3, p3.is && p3), r3 = null, c3 = false;
    }
    if (null === d3) y3 === p3 || c3 && l3.data === p3 || (l3.data = p3);
    else {
      if (r3 = r3 && n.call(l3.childNodes), a3 = (y3 = i3.props || e).dangerouslySetInnerHTML, v3 = p3.dangerouslySetInnerHTML, !c3) {
        if (null != r3) for (y3 = {}, _3 = 0; _3 < l3.attributes.length; _3++) y3[l3.attributes[_3].name] = l3.attributes[_3].value;
        (v3 || a3) && (v3 && (a3 && v3.__html == a3.__html || v3.__html === l3.innerHTML) || (l3.innerHTML = v3 && v3.__html || ""));
      }
      if (C(l3, p3, y3, o4, c3), v3) u3.__k = [];
      else if (_3 = u3.props.children, w(l3, Array.isArray(_3) ? _3 : [_3], u3, i3, t3, o4 && "foreignObject" !== d3, r3, f3, r3 ? r3[0] : i3.__k && k(i3, 0), c3), null != r3) for (_3 = r3.length; _3--; ) null != r3[_3] && h(r3[_3]);
      c3 || ("value" in p3 && void 0 !== (_3 = p3.value) && (_3 !== l3.value || "progress" === d3 && !_3 || "option" === d3 && _3 !== y3.value) && H(l3, "value", _3, y3.value, false), "checked" in p3 && void 0 !== (_3 = p3.checked) && _3 !== l3.checked && H(l3, "checked", _3, y3.checked, false));
    }
    return l3;
  }
  function M(n2, u3, i3) {
    try {
      "function" == typeof n2 ? n2(u3) : n2.current = u3;
    } catch (n3) {
      l.__e(n3, i3);
    }
  }
  function N(n2, u3, i3) {
    var t3, o4;
    if (l.unmount && l.unmount(n2), (t3 = n2.ref) && (t3.current && t3.current !== n2.__e || M(t3, null, u3)), null != (t3 = n2.__c)) {
      if (t3.componentWillUnmount) try {
        t3.componentWillUnmount();
      } catch (n3) {
        l.__e(n3, u3);
      }
      t3.base = t3.__P = null;
    }
    if (t3 = n2.__k) for (o4 = 0; o4 < t3.length; o4++) t3[o4] && N(t3[o4], u3, "function" != typeof n2.type);
    i3 || null == n2.__e || h(n2.__e), n2.__e = n2.__d = void 0;
  }
  function O(n2, l3, u3) {
    return this.constructor(n2, u3);
  }
  function S(u3, i3, t3) {
    var o4, r3, f3;
    l.__ && l.__(u3, i3), r3 = (o4 = "function" == typeof t3) ? null : t3 && t3.__k || i3.__k, f3 = [], j(i3, u3 = (!o4 && t3 || i3).__k = v(d, null, [u3]), r3 || e, e, void 0 !== i3.ownerSVGElement, !o4 && t3 ? [t3] : r3 ? null : i3.firstChild ? n.call(i3.childNodes) : null, f3, !o4 && t3 ? t3 : r3 ? r3.__e : i3.firstChild, o4), z(f3, u3);
  }
  function q(n2, l3) {
    S(n2, l3, q);
  }
  function B(l3, u3, i3) {
    var t3, o4, r3, f3 = a({}, l3.props);
    for (r3 in u3) "key" == r3 ? t3 = u3[r3] : "ref" == r3 ? o4 = u3[r3] : f3[r3] = u3[r3];
    return arguments.length > 2 && (f3.children = arguments.length > 3 ? n.call(arguments, 2) : i3), y(l3.type, f3, t3 || l3.key, o4 || l3.ref, null);
  }
  function D(n2, l3) {
    var u3 = { __c: l3 = "__cC" + f++, __: n2, Consumer: function(n3, l4) {
      return n3.children(l4);
    }, Provider: function(n3) {
      var u4, i3;
      return this.getChildContext || (u4 = [], (i3 = {})[l3] = this, this.getChildContext = function() {
        return i3;
      }, this.shouldComponentUpdate = function(n4) {
        this.props.value !== n4.value && u4.some(m);
      }, this.sub = function(n4) {
        u4.push(n4);
        var l4 = n4.componentWillUnmount;
        n4.componentWillUnmount = function() {
          u4.splice(u4.indexOf(n4), 1), l4 && l4.call(n4);
        };
      }), n3.children;
    } };
    return u3.Provider.__ = u3.Consumer.contextType = u3;
  }
  var n, l, u, i, t, o, r, f, e, c, s;
  var init_preact_module = __esm({
    "node_modules/preact/dist/preact.module.js"() {
      init_preact_shim();
      e = {};
      c = [];
      s = /acit|ex(?:s|g|n|p|$)|rph|grid|ows|mnc|ntw|ine[ch]|zoo|^ord|itera/i;
      n = c.slice, l = { __e: function(n2, l3, u3, i3) {
        for (var t3, o4, r3; l3 = l3.__; ) if ((t3 = l3.__c) && !t3.__) try {
          if ((o4 = t3.constructor) && null != o4.getDerivedStateFromError && (t3.setState(o4.getDerivedStateFromError(n2)), r3 = t3.__d), null != t3.componentDidCatch && (t3.componentDidCatch(n2, i3 || {}), r3 = t3.__d), r3) return t3.__E = t3;
        } catch (l4) {
          n2 = l4;
        }
        throw n2;
      } }, u = 0, i = function(n2) {
        return null != n2 && void 0 === n2.constructor;
      }, _.prototype.setState = function(n2, l3) {
        var u3;
        u3 = null != this.__s && this.__s !== this.state ? this.__s : this.__s = a({}, this.state), "function" == typeof n2 && (n2 = n2(a({}, u3), this.props)), n2 && a(u3, n2), null != n2 && this.__v && (l3 && this.__h.push(l3), m(this));
      }, _.prototype.forceUpdate = function(n2) {
        this.__v && (this.__e = true, n2 && this.__h.push(n2), m(this));
      }, _.prototype.render = d, t = [], o = "function" == typeof Promise ? Promise.prototype.then.bind(Promise.resolve()) : setTimeout, g.__r = 0, f = 0;
    }
  });

  // scripts/preact-shim.ts
  var init_preact_shim = __esm({
    "scripts/preact-shim.ts"() {
      init_preact_module();
    }
  });

  // node_modules/classnames/index.js
  var require_classnames = __commonJS({
    "node_modules/classnames/index.js"(exports, module) {
      init_preact_shim();
      (function() {
        "use strict";
        var hasOwn = {}.hasOwnProperty;
        function classNames2() {
          var classes = [];
          for (var i3 = 0; i3 < arguments.length; i3++) {
            var arg = arguments[i3];
            if (!arg) continue;
            var argType = typeof arg;
            if (argType === "string" || argType === "number") {
              classes.push(arg);
            } else if (Array.isArray(arg)) {
              if (arg.length) {
                var inner = classNames2.apply(null, arg);
                if (inner) {
                  classes.push(inner);
                }
              }
            } else if (argType === "object") {
              if (arg.toString === Object.prototype.toString) {
                for (var key in arg) {
                  if (hasOwn.call(arg, key) && arg[key]) {
                    classes.push(key);
                  }
                }
              } else {
                classes.push(arg.toString());
              }
            }
          }
          return classes.join(" ");
        }
        if (typeof module !== "undefined" && module.exports) {
          classNames2.default = classNames2;
          module.exports = classNames2;
        } else if (typeof define === "function" && typeof define.amd === "object" && define.amd) {
          define("classnames", [], function() {
            return classNames2;
          });
        } else {
          window.classNames = classNames2;
        }
      })();
    }
  });

  // node_modules/base64-js/index.js
  var require_base64_js = __commonJS({
    "node_modules/base64-js/index.js"(exports) {
      "use strict";
      init_preact_shim();
      exports.byteLength = byteLength;
      exports.toByteArray = toByteArray;
      exports.fromByteArray = fromByteArray;
      var lookup2 = [];
      var revLookup = [];
      var Arr = typeof Uint8Array !== "undefined" ? Uint8Array : Array;
      var code = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
      for (i3 = 0, len = code.length; i3 < len; ++i3) {
        lookup2[i3] = code[i3];
        revLookup[code.charCodeAt(i3)] = i3;
      }
      var i3;
      var len;
      revLookup["-".charCodeAt(0)] = 62;
      revLookup["_".charCodeAt(0)] = 63;
      function getLens(b64) {
        var len2 = b64.length;
        if (len2 % 4 > 0) {
          throw new Error("Invalid string. Length must be a multiple of 4");
        }
        var validLen = b64.indexOf("=");
        if (validLen === -1) validLen = len2;
        var placeHoldersLen = validLen === len2 ? 0 : 4 - validLen % 4;
        return [validLen, placeHoldersLen];
      }
      function byteLength(b64) {
        var lens = getLens(b64);
        var validLen = lens[0];
        var placeHoldersLen = lens[1];
        return (validLen + placeHoldersLen) * 3 / 4 - placeHoldersLen;
      }
      function _byteLength(b64, validLen, placeHoldersLen) {
        return (validLen + placeHoldersLen) * 3 / 4 - placeHoldersLen;
      }
      function toByteArray(b64) {
        var tmp;
        var lens = getLens(b64);
        var validLen = lens[0];
        var placeHoldersLen = lens[1];
        var arr = new Arr(_byteLength(b64, validLen, placeHoldersLen));
        var curByte = 0;
        var len2 = placeHoldersLen > 0 ? validLen - 4 : validLen;
        var i4;
        for (i4 = 0; i4 < len2; i4 += 4) {
          tmp = revLookup[b64.charCodeAt(i4)] << 18 | revLookup[b64.charCodeAt(i4 + 1)] << 12 | revLookup[b64.charCodeAt(i4 + 2)] << 6 | revLookup[b64.charCodeAt(i4 + 3)];
          arr[curByte++] = tmp >> 16 & 255;
          arr[curByte++] = tmp >> 8 & 255;
          arr[curByte++] = tmp & 255;
        }
        if (placeHoldersLen === 2) {
          tmp = revLookup[b64.charCodeAt(i4)] << 2 | revLookup[b64.charCodeAt(i4 + 1)] >> 4;
          arr[curByte++] = tmp & 255;
        }
        if (placeHoldersLen === 1) {
          tmp = revLookup[b64.charCodeAt(i4)] << 10 | revLookup[b64.charCodeAt(i4 + 1)] << 4 | revLookup[b64.charCodeAt(i4 + 2)] >> 2;
          arr[curByte++] = tmp >> 8 & 255;
          arr[curByte++] = tmp & 255;
        }
        return arr;
      }
      function tripletToBase64(num) {
        return lookup2[num >> 18 & 63] + lookup2[num >> 12 & 63] + lookup2[num >> 6 & 63] + lookup2[num & 63];
      }
      function encodeChunk(uint8, start, end) {
        var tmp;
        var output = [];
        for (var i4 = start; i4 < end; i4 += 3) {
          tmp = (uint8[i4] << 16 & 16711680) + (uint8[i4 + 1] << 8 & 65280) + (uint8[i4 + 2] & 255);
          output.push(tripletToBase64(tmp));
        }
        return output.join("");
      }
      function fromByteArray(uint8) {
        var tmp;
        var len2 = uint8.length;
        var extraBytes = len2 % 3;
        var parts = [];
        var maxChunkLength = 16383;
        for (var i4 = 0, len22 = len2 - extraBytes; i4 < len22; i4 += maxChunkLength) {
          parts.push(encodeChunk(uint8, i4, i4 + maxChunkLength > len22 ? len22 : i4 + maxChunkLength));
        }
        if (extraBytes === 1) {
          tmp = uint8[len2 - 1];
          parts.push(
            lookup2[tmp >> 2] + lookup2[tmp << 4 & 63] + "=="
          );
        } else if (extraBytes === 2) {
          tmp = (uint8[len2 - 2] << 8) + uint8[len2 - 1];
          parts.push(
            lookup2[tmp >> 10] + lookup2[tmp >> 4 & 63] + lookup2[tmp << 2 & 63] + "="
          );
        }
        return parts.join("");
      }
    }
  });

  // node_modules/ieee754/index.js
  var require_ieee754 = __commonJS({
    "node_modules/ieee754/index.js"(exports) {
      init_preact_shim();
      exports.read = function(buffer, offset, isLE, mLen, nBytes) {
        var e4, m3;
        var eLen = nBytes * 8 - mLen - 1;
        var eMax = (1 << eLen) - 1;
        var eBias = eMax >> 1;
        var nBits = -7;
        var i3 = isLE ? nBytes - 1 : 0;
        var d3 = isLE ? -1 : 1;
        var s3 = buffer[offset + i3];
        i3 += d3;
        e4 = s3 & (1 << -nBits) - 1;
        s3 >>= -nBits;
        nBits += eLen;
        for (; nBits > 0; e4 = e4 * 256 + buffer[offset + i3], i3 += d3, nBits -= 8) {
        }
        m3 = e4 & (1 << -nBits) - 1;
        e4 >>= -nBits;
        nBits += mLen;
        for (; nBits > 0; m3 = m3 * 256 + buffer[offset + i3], i3 += d3, nBits -= 8) {
        }
        if (e4 === 0) {
          e4 = 1 - eBias;
        } else if (e4 === eMax) {
          return m3 ? NaN : (s3 ? -1 : 1) * Infinity;
        } else {
          m3 = m3 + Math.pow(2, mLen);
          e4 = e4 - eBias;
        }
        return (s3 ? -1 : 1) * m3 * Math.pow(2, e4 - mLen);
      };
      exports.write = function(buffer, value, offset, isLE, mLen, nBytes) {
        var e4, m3, c3;
        var eLen = nBytes * 8 - mLen - 1;
        var eMax = (1 << eLen) - 1;
        var eBias = eMax >> 1;
        var rt = mLen === 23 ? Math.pow(2, -24) - Math.pow(2, -77) : 0;
        var i3 = isLE ? 0 : nBytes - 1;
        var d3 = isLE ? 1 : -1;
        var s3 = value < 0 || value === 0 && 1 / value < 0 ? 1 : 0;
        value = Math.abs(value);
        if (isNaN(value) || value === Infinity) {
          m3 = isNaN(value) ? 1 : 0;
          e4 = eMax;
        } else {
          e4 = Math.floor(Math.log(value) / Math.LN2);
          if (value * (c3 = Math.pow(2, -e4)) < 1) {
            e4--;
            c3 *= 2;
          }
          if (e4 + eBias >= 1) {
            value += rt / c3;
          } else {
            value += rt * Math.pow(2, 1 - eBias);
          }
          if (value * c3 >= 2) {
            e4++;
            c3 /= 2;
          }
          if (e4 + eBias >= eMax) {
            m3 = 0;
            e4 = eMax;
          } else if (e4 + eBias >= 1) {
            m3 = (value * c3 - 1) * Math.pow(2, mLen);
            e4 = e4 + eBias;
          } else {
            m3 = value * Math.pow(2, eBias - 1) * Math.pow(2, mLen);
            e4 = 0;
          }
        }
        for (; mLen >= 8; buffer[offset + i3] = m3 & 255, i3 += d3, m3 /= 256, mLen -= 8) {
        }
        e4 = e4 << mLen | m3;
        eLen += mLen;
        for (; eLen > 0; buffer[offset + i3] = e4 & 255, i3 += d3, e4 /= 256, eLen -= 8) {
        }
        buffer[offset + i3 - d3] |= s3 * 128;
      };
    }
  });

  // node_modules/buffer/index.js
  var require_buffer = __commonJS({
    "node_modules/buffer/index.js"(exports) {
      "use strict";
      init_preact_shim();
      var base64 = require_base64_js();
      var ieee754 = require_ieee754();
      var customInspectSymbol = typeof Symbol === "function" && typeof Symbol["for"] === "function" ? Symbol["for"]("nodejs.util.inspect.custom") : null;
      exports.Buffer = Buffer4;
      exports.SlowBuffer = SlowBuffer;
      exports.INSPECT_MAX_BYTES = 50;
      var K_MAX_LENGTH = 2147483647;
      exports.kMaxLength = K_MAX_LENGTH;
      Buffer4.TYPED_ARRAY_SUPPORT = typedArraySupport();
      if (!Buffer4.TYPED_ARRAY_SUPPORT && typeof console !== "undefined" && typeof console.error === "function") {
        console.error(
          "This browser lacks typed array (Uint8Array) support which is required by `buffer` v5.x. Use `buffer` v4.x if you require old browser support."
        );
      }
      function typedArraySupport() {
        try {
          var arr = new Uint8Array(1);
          var proto = { foo: function() {
            return 42;
          } };
          Object.setPrototypeOf(proto, Uint8Array.prototype);
          Object.setPrototypeOf(arr, proto);
          return arr.foo() === 42;
        } catch (e4) {
          return false;
        }
      }
      Object.defineProperty(Buffer4.prototype, "parent", {
        enumerable: true,
        get: function() {
          if (!Buffer4.isBuffer(this)) return void 0;
          return this.buffer;
        }
      });
      Object.defineProperty(Buffer4.prototype, "offset", {
        enumerable: true,
        get: function() {
          if (!Buffer4.isBuffer(this)) return void 0;
          return this.byteOffset;
        }
      });
      function createBuffer(length) {
        if (length > K_MAX_LENGTH) {
          throw new RangeError('The value "' + length + '" is invalid for option "size"');
        }
        var buf = new Uint8Array(length);
        Object.setPrototypeOf(buf, Buffer4.prototype);
        return buf;
      }
      function Buffer4(arg, encodingOrOffset, length) {
        if (typeof arg === "number") {
          if (typeof encodingOrOffset === "string") {
            throw new TypeError(
              'The "string" argument must be of type string. Received type number'
            );
          }
          return allocUnsafe(arg);
        }
        return from(arg, encodingOrOffset, length);
      }
      Buffer4.poolSize = 8192;
      function from(value, encodingOrOffset, length) {
        if (typeof value === "string") {
          return fromString(value, encodingOrOffset);
        }
        if (ArrayBuffer.isView(value)) {
          return fromArrayView(value);
        }
        if (value == null) {
          throw new TypeError(
            "The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value
          );
        }
        if (isInstance(value, ArrayBuffer) || value && isInstance(value.buffer, ArrayBuffer)) {
          return fromArrayBuffer(value, encodingOrOffset, length);
        }
        if (typeof SharedArrayBuffer !== "undefined" && (isInstance(value, SharedArrayBuffer) || value && isInstance(value.buffer, SharedArrayBuffer))) {
          return fromArrayBuffer(value, encodingOrOffset, length);
        }
        if (typeof value === "number") {
          throw new TypeError(
            'The "value" argument must not be of type number. Received type number'
          );
        }
        var valueOf = value.valueOf && value.valueOf();
        if (valueOf != null && valueOf !== value) {
          return Buffer4.from(valueOf, encodingOrOffset, length);
        }
        var b3 = fromObject(value);
        if (b3) return b3;
        if (typeof Symbol !== "undefined" && Symbol.toPrimitive != null && typeof value[Symbol.toPrimitive] === "function") {
          return Buffer4.from(
            value[Symbol.toPrimitive]("string"),
            encodingOrOffset,
            length
          );
        }
        throw new TypeError(
          "The first argument must be one of type string, Buffer, ArrayBuffer, Array, or Array-like Object. Received type " + typeof value
        );
      }
      Buffer4.from = function(value, encodingOrOffset, length) {
        return from(value, encodingOrOffset, length);
      };
      Object.setPrototypeOf(Buffer4.prototype, Uint8Array.prototype);
      Object.setPrototypeOf(Buffer4, Uint8Array);
      function assertSize(size) {
        if (typeof size !== "number") {
          throw new TypeError('"size" argument must be of type number');
        } else if (size < 0) {
          throw new RangeError('The value "' + size + '" is invalid for option "size"');
        }
      }
      function alloc(size, fill, encoding) {
        assertSize(size);
        if (size <= 0) {
          return createBuffer(size);
        }
        if (fill !== void 0) {
          return typeof encoding === "string" ? createBuffer(size).fill(fill, encoding) : createBuffer(size).fill(fill);
        }
        return createBuffer(size);
      }
      Buffer4.alloc = function(size, fill, encoding) {
        return alloc(size, fill, encoding);
      };
      function allocUnsafe(size) {
        assertSize(size);
        return createBuffer(size < 0 ? 0 : checked(size) | 0);
      }
      Buffer4.allocUnsafe = function(size) {
        return allocUnsafe(size);
      };
      Buffer4.allocUnsafeSlow = function(size) {
        return allocUnsafe(size);
      };
      function fromString(string, encoding) {
        if (typeof encoding !== "string" || encoding === "") {
          encoding = "utf8";
        }
        if (!Buffer4.isEncoding(encoding)) {
          throw new TypeError("Unknown encoding: " + encoding);
        }
        var length = byteLength(string, encoding) | 0;
        var buf = createBuffer(length);
        var actual = buf.write(string, encoding);
        if (actual !== length) {
          buf = buf.slice(0, actual);
        }
        return buf;
      }
      function fromArrayLike(array) {
        var length = array.length < 0 ? 0 : checked(array.length) | 0;
        var buf = createBuffer(length);
        for (var i3 = 0; i3 < length; i3 += 1) {
          buf[i3] = array[i3] & 255;
        }
        return buf;
      }
      function fromArrayView(arrayView) {
        if (isInstance(arrayView, Uint8Array)) {
          var copy = new Uint8Array(arrayView);
          return fromArrayBuffer(copy.buffer, copy.byteOffset, copy.byteLength);
        }
        return fromArrayLike(arrayView);
      }
      function fromArrayBuffer(array, byteOffset, length) {
        if (byteOffset < 0 || array.byteLength < byteOffset) {
          throw new RangeError('"offset" is outside of buffer bounds');
        }
        if (array.byteLength < byteOffset + (length || 0)) {
          throw new RangeError('"length" is outside of buffer bounds');
        }
        var buf;
        if (byteOffset === void 0 && length === void 0) {
          buf = new Uint8Array(array);
        } else if (length === void 0) {
          buf = new Uint8Array(array, byteOffset);
        } else {
          buf = new Uint8Array(array, byteOffset, length);
        }
        Object.setPrototypeOf(buf, Buffer4.prototype);
        return buf;
      }
      function fromObject(obj) {
        if (Buffer4.isBuffer(obj)) {
          var len = checked(obj.length) | 0;
          var buf = createBuffer(len);
          if (buf.length === 0) {
            return buf;
          }
          obj.copy(buf, 0, 0, len);
          return buf;
        }
        if (obj.length !== void 0) {
          if (typeof obj.length !== "number" || numberIsNaN(obj.length)) {
            return createBuffer(0);
          }
          return fromArrayLike(obj);
        }
        if (obj.type === "Buffer" && Array.isArray(obj.data)) {
          return fromArrayLike(obj.data);
        }
      }
      function checked(length) {
        if (length >= K_MAX_LENGTH) {
          throw new RangeError("Attempt to allocate Buffer larger than maximum size: 0x" + K_MAX_LENGTH.toString(16) + " bytes");
        }
        return length | 0;
      }
      function SlowBuffer(length) {
        if (+length != length) {
          length = 0;
        }
        return Buffer4.alloc(+length);
      }
      Buffer4.isBuffer = function isBuffer(b3) {
        return b3 != null && b3._isBuffer === true && b3 !== Buffer4.prototype;
      };
      Buffer4.compare = function compare(a3, b3) {
        if (isInstance(a3, Uint8Array)) a3 = Buffer4.from(a3, a3.offset, a3.byteLength);
        if (isInstance(b3, Uint8Array)) b3 = Buffer4.from(b3, b3.offset, b3.byteLength);
        if (!Buffer4.isBuffer(a3) || !Buffer4.isBuffer(b3)) {
          throw new TypeError(
            'The "buf1", "buf2" arguments must be one of type Buffer or Uint8Array'
          );
        }
        if (a3 === b3) return 0;
        var x3 = a3.length;
        var y3 = b3.length;
        for (var i3 = 0, len = Math.min(x3, y3); i3 < len; ++i3) {
          if (a3[i3] !== b3[i3]) {
            x3 = a3[i3];
            y3 = b3[i3];
            break;
          }
        }
        if (x3 < y3) return -1;
        if (y3 < x3) return 1;
        return 0;
      };
      Buffer4.isEncoding = function isEncoding(encoding) {
        switch (String(encoding).toLowerCase()) {
          case "hex":
          case "utf8":
          case "utf-8":
          case "ascii":
          case "latin1":
          case "binary":
          case "base64":
          case "ucs2":
          case "ucs-2":
          case "utf16le":
          case "utf-16le":
            return true;
          default:
            return false;
        }
      };
      Buffer4.concat = function concat2(list, length) {
        if (!Array.isArray(list)) {
          throw new TypeError('"list" argument must be an Array of Buffers');
        }
        if (list.length === 0) {
          return Buffer4.alloc(0);
        }
        var i3;
        if (length === void 0) {
          length = 0;
          for (i3 = 0; i3 < list.length; ++i3) {
            length += list[i3].length;
          }
        }
        var buffer = Buffer4.allocUnsafe(length);
        var pos = 0;
        for (i3 = 0; i3 < list.length; ++i3) {
          var buf = list[i3];
          if (isInstance(buf, Uint8Array)) {
            if (pos + buf.length > buffer.length) {
              Buffer4.from(buf).copy(buffer, pos);
            } else {
              Uint8Array.prototype.set.call(
                buffer,
                buf,
                pos
              );
            }
          } else if (!Buffer4.isBuffer(buf)) {
            throw new TypeError('"list" argument must be an Array of Buffers');
          } else {
            buf.copy(buffer, pos);
          }
          pos += buf.length;
        }
        return buffer;
      };
      function byteLength(string, encoding) {
        if (Buffer4.isBuffer(string)) {
          return string.length;
        }
        if (ArrayBuffer.isView(string) || isInstance(string, ArrayBuffer)) {
          return string.byteLength;
        }
        if (typeof string !== "string") {
          throw new TypeError(
            'The "string" argument must be one of type string, Buffer, or ArrayBuffer. Received type ' + typeof string
          );
        }
        var len = string.length;
        var mustMatch = arguments.length > 2 && arguments[2] === true;
        if (!mustMatch && len === 0) return 0;
        var loweredCase = false;
        for (; ; ) {
          switch (encoding) {
            case "ascii":
            case "latin1":
            case "binary":
              return len;
            case "utf8":
            case "utf-8":
              return utf8ToBytes(string).length;
            case "ucs2":
            case "ucs-2":
            case "utf16le":
            case "utf-16le":
              return len * 2;
            case "hex":
              return len >>> 1;
            case "base64":
              return base64ToBytes(string).length;
            default:
              if (loweredCase) {
                return mustMatch ? -1 : utf8ToBytes(string).length;
              }
              encoding = ("" + encoding).toLowerCase();
              loweredCase = true;
          }
        }
      }
      Buffer4.byteLength = byteLength;
      function slowToString(encoding, start, end) {
        var loweredCase = false;
        if (start === void 0 || start < 0) {
          start = 0;
        }
        if (start > this.length) {
          return "";
        }
        if (end === void 0 || end > this.length) {
          end = this.length;
        }
        if (end <= 0) {
          return "";
        }
        end >>>= 0;
        start >>>= 0;
        if (end <= start) {
          return "";
        }
        if (!encoding) encoding = "utf8";
        while (true) {
          switch (encoding) {
            case "hex":
              return hexSlice(this, start, end);
            case "utf8":
            case "utf-8":
              return utf8Slice(this, start, end);
            case "ascii":
              return asciiSlice(this, start, end);
            case "latin1":
            case "binary":
              return latin1Slice(this, start, end);
            case "base64":
              return base64Slice(this, start, end);
            case "ucs2":
            case "ucs-2":
            case "utf16le":
            case "utf-16le":
              return utf16leSlice(this, start, end);
            default:
              if (loweredCase) throw new TypeError("Unknown encoding: " + encoding);
              encoding = (encoding + "").toLowerCase();
              loweredCase = true;
          }
        }
      }
      Buffer4.prototype._isBuffer = true;
      function swap(b3, n2, m3) {
        var i3 = b3[n2];
        b3[n2] = b3[m3];
        b3[m3] = i3;
      }
      Buffer4.prototype.swap16 = function swap16() {
        var len = this.length;
        if (len % 2 !== 0) {
          throw new RangeError("Buffer size must be a multiple of 16-bits");
        }
        for (var i3 = 0; i3 < len; i3 += 2) {
          swap(this, i3, i3 + 1);
        }
        return this;
      };
      Buffer4.prototype.swap32 = function swap32() {
        var len = this.length;
        if (len % 4 !== 0) {
          throw new RangeError("Buffer size must be a multiple of 32-bits");
        }
        for (var i3 = 0; i3 < len; i3 += 4) {
          swap(this, i3, i3 + 3);
          swap(this, i3 + 1, i3 + 2);
        }
        return this;
      };
      Buffer4.prototype.swap64 = function swap64() {
        var len = this.length;
        if (len % 8 !== 0) {
          throw new RangeError("Buffer size must be a multiple of 64-bits");
        }
        for (var i3 = 0; i3 < len; i3 += 8) {
          swap(this, i3, i3 + 7);
          swap(this, i3 + 1, i3 + 6);
          swap(this, i3 + 2, i3 + 5);
          swap(this, i3 + 3, i3 + 4);
        }
        return this;
      };
      Buffer4.prototype.toString = function toString() {
        var length = this.length;
        if (length === 0) return "";
        if (arguments.length === 0) return utf8Slice(this, 0, length);
        return slowToString.apply(this, arguments);
      };
      Buffer4.prototype.toLocaleString = Buffer4.prototype.toString;
      Buffer4.prototype.equals = function equals(b3) {
        if (!Buffer4.isBuffer(b3)) throw new TypeError("Argument must be a Buffer");
        if (this === b3) return true;
        return Buffer4.compare(this, b3) === 0;
      };
      Buffer4.prototype.inspect = function inspect() {
        var str = "";
        var max = exports.INSPECT_MAX_BYTES;
        str = this.toString("hex", 0, max).replace(/(.{2})/g, "$1 ").trim();
        if (this.length > max) str += " ... ";
        return "<Buffer " + str + ">";
      };
      if (customInspectSymbol) {
        Buffer4.prototype[customInspectSymbol] = Buffer4.prototype.inspect;
      }
      Buffer4.prototype.compare = function compare(target, start, end, thisStart, thisEnd) {
        if (isInstance(target, Uint8Array)) {
          target = Buffer4.from(target, target.offset, target.byteLength);
        }
        if (!Buffer4.isBuffer(target)) {
          throw new TypeError(
            'The "target" argument must be one of type Buffer or Uint8Array. Received type ' + typeof target
          );
        }
        if (start === void 0) {
          start = 0;
        }
        if (end === void 0) {
          end = target ? target.length : 0;
        }
        if (thisStart === void 0) {
          thisStart = 0;
        }
        if (thisEnd === void 0) {
          thisEnd = this.length;
        }
        if (start < 0 || end > target.length || thisStart < 0 || thisEnd > this.length) {
          throw new RangeError("out of range index");
        }
        if (thisStart >= thisEnd && start >= end) {
          return 0;
        }
        if (thisStart >= thisEnd) {
          return -1;
        }
        if (start >= end) {
          return 1;
        }
        start >>>= 0;
        end >>>= 0;
        thisStart >>>= 0;
        thisEnd >>>= 0;
        if (this === target) return 0;
        var x3 = thisEnd - thisStart;
        var y3 = end - start;
        var len = Math.min(x3, y3);
        var thisCopy = this.slice(thisStart, thisEnd);
        var targetCopy = target.slice(start, end);
        for (var i3 = 0; i3 < len; ++i3) {
          if (thisCopy[i3] !== targetCopy[i3]) {
            x3 = thisCopy[i3];
            y3 = targetCopy[i3];
            break;
          }
        }
        if (x3 < y3) return -1;
        if (y3 < x3) return 1;
        return 0;
      };
      function bidirectionalIndexOf(buffer, val, byteOffset, encoding, dir) {
        if (buffer.length === 0) return -1;
        if (typeof byteOffset === "string") {
          encoding = byteOffset;
          byteOffset = 0;
        } else if (byteOffset > 2147483647) {
          byteOffset = 2147483647;
        } else if (byteOffset < -2147483648) {
          byteOffset = -2147483648;
        }
        byteOffset = +byteOffset;
        if (numberIsNaN(byteOffset)) {
          byteOffset = dir ? 0 : buffer.length - 1;
        }
        if (byteOffset < 0) byteOffset = buffer.length + byteOffset;
        if (byteOffset >= buffer.length) {
          if (dir) return -1;
          else byteOffset = buffer.length - 1;
        } else if (byteOffset < 0) {
          if (dir) byteOffset = 0;
          else return -1;
        }
        if (typeof val === "string") {
          val = Buffer4.from(val, encoding);
        }
        if (Buffer4.isBuffer(val)) {
          if (val.length === 0) {
            return -1;
          }
          return arrayIndexOf(buffer, val, byteOffset, encoding, dir);
        } else if (typeof val === "number") {
          val = val & 255;
          if (typeof Uint8Array.prototype.indexOf === "function") {
            if (dir) {
              return Uint8Array.prototype.indexOf.call(buffer, val, byteOffset);
            } else {
              return Uint8Array.prototype.lastIndexOf.call(buffer, val, byteOffset);
            }
          }
          return arrayIndexOf(buffer, [val], byteOffset, encoding, dir);
        }
        throw new TypeError("val must be string, number or Buffer");
      }
      function arrayIndexOf(arr, val, byteOffset, encoding, dir) {
        var indexSize = 1;
        var arrLength = arr.length;
        var valLength = val.length;
        if (encoding !== void 0) {
          encoding = String(encoding).toLowerCase();
          if (encoding === "ucs2" || encoding === "ucs-2" || encoding === "utf16le" || encoding === "utf-16le") {
            if (arr.length < 2 || val.length < 2) {
              return -1;
            }
            indexSize = 2;
            arrLength /= 2;
            valLength /= 2;
            byteOffset /= 2;
          }
        }
        function read(buf, i4) {
          if (indexSize === 1) {
            return buf[i4];
          } else {
            return buf.readUInt16BE(i4 * indexSize);
          }
        }
        var i3;
        if (dir) {
          var foundIndex = -1;
          for (i3 = byteOffset; i3 < arrLength; i3++) {
            if (read(arr, i3) === read(val, foundIndex === -1 ? 0 : i3 - foundIndex)) {
              if (foundIndex === -1) foundIndex = i3;
              if (i3 - foundIndex + 1 === valLength) return foundIndex * indexSize;
            } else {
              if (foundIndex !== -1) i3 -= i3 - foundIndex;
              foundIndex = -1;
            }
          }
        } else {
          if (byteOffset + valLength > arrLength) byteOffset = arrLength - valLength;
          for (i3 = byteOffset; i3 >= 0; i3--) {
            var found = true;
            for (var j4 = 0; j4 < valLength; j4++) {
              if (read(arr, i3 + j4) !== read(val, j4)) {
                found = false;
                break;
              }
            }
            if (found) return i3;
          }
        }
        return -1;
      }
      Buffer4.prototype.includes = function includes(val, byteOffset, encoding) {
        return this.indexOf(val, byteOffset, encoding) !== -1;
      };
      Buffer4.prototype.indexOf = function indexOf(val, byteOffset, encoding) {
        return bidirectionalIndexOf(this, val, byteOffset, encoding, true);
      };
      Buffer4.prototype.lastIndexOf = function lastIndexOf(val, byteOffset, encoding) {
        return bidirectionalIndexOf(this, val, byteOffset, encoding, false);
      };
      function hexWrite(buf, string, offset, length) {
        offset = Number(offset) || 0;
        var remaining = buf.length - offset;
        if (!length) {
          length = remaining;
        } else {
          length = Number(length);
          if (length > remaining) {
            length = remaining;
          }
        }
        var strLen = string.length;
        if (length > strLen / 2) {
          length = strLen / 2;
        }
        for (var i3 = 0; i3 < length; ++i3) {
          var parsed = parseInt(string.substr(i3 * 2, 2), 16);
          if (numberIsNaN(parsed)) return i3;
          buf[offset + i3] = parsed;
        }
        return i3;
      }
      function utf8Write(buf, string, offset, length) {
        return blitBuffer(utf8ToBytes(string, buf.length - offset), buf, offset, length);
      }
      function asciiWrite(buf, string, offset, length) {
        return blitBuffer(asciiToBytes(string), buf, offset, length);
      }
      function base64Write(buf, string, offset, length) {
        return blitBuffer(base64ToBytes(string), buf, offset, length);
      }
      function ucs2Write(buf, string, offset, length) {
        return blitBuffer(utf16leToBytes(string, buf.length - offset), buf, offset, length);
      }
      Buffer4.prototype.write = function write(string, offset, length, encoding) {
        if (offset === void 0) {
          encoding = "utf8";
          length = this.length;
          offset = 0;
        } else if (length === void 0 && typeof offset === "string") {
          encoding = offset;
          length = this.length;
          offset = 0;
        } else if (isFinite(offset)) {
          offset = offset >>> 0;
          if (isFinite(length)) {
            length = length >>> 0;
            if (encoding === void 0) encoding = "utf8";
          } else {
            encoding = length;
            length = void 0;
          }
        } else {
          throw new Error(
            "Buffer.write(string, encoding, offset[, length]) is no longer supported"
          );
        }
        var remaining = this.length - offset;
        if (length === void 0 || length > remaining) length = remaining;
        if (string.length > 0 && (length < 0 || offset < 0) || offset > this.length) {
          throw new RangeError("Attempt to write outside buffer bounds");
        }
        if (!encoding) encoding = "utf8";
        var loweredCase = false;
        for (; ; ) {
          switch (encoding) {
            case "hex":
              return hexWrite(this, string, offset, length);
            case "utf8":
            case "utf-8":
              return utf8Write(this, string, offset, length);
            case "ascii":
            case "latin1":
            case "binary":
              return asciiWrite(this, string, offset, length);
            case "base64":
              return base64Write(this, string, offset, length);
            case "ucs2":
            case "ucs-2":
            case "utf16le":
            case "utf-16le":
              return ucs2Write(this, string, offset, length);
            default:
              if (loweredCase) throw new TypeError("Unknown encoding: " + encoding);
              encoding = ("" + encoding).toLowerCase();
              loweredCase = true;
          }
        }
      };
      Buffer4.prototype.toJSON = function toJSON() {
        return {
          type: "Buffer",
          data: Array.prototype.slice.call(this._arr || this, 0)
        };
      };
      function base64Slice(buf, start, end) {
        if (start === 0 && end === buf.length) {
          return base64.fromByteArray(buf);
        } else {
          return base64.fromByteArray(buf.slice(start, end));
        }
      }
      function utf8Slice(buf, start, end) {
        end = Math.min(buf.length, end);
        var res = [];
        var i3 = start;
        while (i3 < end) {
          var firstByte = buf[i3];
          var codePoint = null;
          var bytesPerSequence = firstByte > 239 ? 4 : firstByte > 223 ? 3 : firstByte > 191 ? 2 : 1;
          if (i3 + bytesPerSequence <= end) {
            var secondByte, thirdByte, fourthByte, tempCodePoint;
            switch (bytesPerSequence) {
              case 1:
                if (firstByte < 128) {
                  codePoint = firstByte;
                }
                break;
              case 2:
                secondByte = buf[i3 + 1];
                if ((secondByte & 192) === 128) {
                  tempCodePoint = (firstByte & 31) << 6 | secondByte & 63;
                  if (tempCodePoint > 127) {
                    codePoint = tempCodePoint;
                  }
                }
                break;
              case 3:
                secondByte = buf[i3 + 1];
                thirdByte = buf[i3 + 2];
                if ((secondByte & 192) === 128 && (thirdByte & 192) === 128) {
                  tempCodePoint = (firstByte & 15) << 12 | (secondByte & 63) << 6 | thirdByte & 63;
                  if (tempCodePoint > 2047 && (tempCodePoint < 55296 || tempCodePoint > 57343)) {
                    codePoint = tempCodePoint;
                  }
                }
                break;
              case 4:
                secondByte = buf[i3 + 1];
                thirdByte = buf[i3 + 2];
                fourthByte = buf[i3 + 3];
                if ((secondByte & 192) === 128 && (thirdByte & 192) === 128 && (fourthByte & 192) === 128) {
                  tempCodePoint = (firstByte & 15) << 18 | (secondByte & 63) << 12 | (thirdByte & 63) << 6 | fourthByte & 63;
                  if (tempCodePoint > 65535 && tempCodePoint < 1114112) {
                    codePoint = tempCodePoint;
                  }
                }
            }
          }
          if (codePoint === null) {
            codePoint = 65533;
            bytesPerSequence = 1;
          } else if (codePoint > 65535) {
            codePoint -= 65536;
            res.push(codePoint >>> 10 & 1023 | 55296);
            codePoint = 56320 | codePoint & 1023;
          }
          res.push(codePoint);
          i3 += bytesPerSequence;
        }
        return decodeCodePointsArray(res);
      }
      var MAX_ARGUMENTS_LENGTH = 4096;
      function decodeCodePointsArray(codePoints) {
        var len = codePoints.length;
        if (len <= MAX_ARGUMENTS_LENGTH) {
          return String.fromCharCode.apply(String, codePoints);
        }
        var res = "";
        var i3 = 0;
        while (i3 < len) {
          res += String.fromCharCode.apply(
            String,
            codePoints.slice(i3, i3 += MAX_ARGUMENTS_LENGTH)
          );
        }
        return res;
      }
      function asciiSlice(buf, start, end) {
        var ret = "";
        end = Math.min(buf.length, end);
        for (var i3 = start; i3 < end; ++i3) {
          ret += String.fromCharCode(buf[i3] & 127);
        }
        return ret;
      }
      function latin1Slice(buf, start, end) {
        var ret = "";
        end = Math.min(buf.length, end);
        for (var i3 = start; i3 < end; ++i3) {
          ret += String.fromCharCode(buf[i3]);
        }
        return ret;
      }
      function hexSlice(buf, start, end) {
        var len = buf.length;
        if (!start || start < 0) start = 0;
        if (!end || end < 0 || end > len) end = len;
        var out = "";
        for (var i3 = start; i3 < end; ++i3) {
          out += hexSliceLookupTable[buf[i3]];
        }
        return out;
      }
      function utf16leSlice(buf, start, end) {
        var bytes = buf.slice(start, end);
        var res = "";
        for (var i3 = 0; i3 < bytes.length - 1; i3 += 2) {
          res += String.fromCharCode(bytes[i3] + bytes[i3 + 1] * 256);
        }
        return res;
      }
      Buffer4.prototype.slice = function slice(start, end) {
        var len = this.length;
        start = ~~start;
        end = end === void 0 ? len : ~~end;
        if (start < 0) {
          start += len;
          if (start < 0) start = 0;
        } else if (start > len) {
          start = len;
        }
        if (end < 0) {
          end += len;
          if (end < 0) end = 0;
        } else if (end > len) {
          end = len;
        }
        if (end < start) end = start;
        var newBuf = this.subarray(start, end);
        Object.setPrototypeOf(newBuf, Buffer4.prototype);
        return newBuf;
      };
      function checkOffset(offset, ext, length) {
        if (offset % 1 !== 0 || offset < 0) throw new RangeError("offset is not uint");
        if (offset + ext > length) throw new RangeError("Trying to access beyond buffer length");
      }
      Buffer4.prototype.readUintLE = Buffer4.prototype.readUIntLE = function readUIntLE(offset, byteLength2, noAssert) {
        offset = offset >>> 0;
        byteLength2 = byteLength2 >>> 0;
        if (!noAssert) checkOffset(offset, byteLength2, this.length);
        var val = this[offset];
        var mul = 1;
        var i3 = 0;
        while (++i3 < byteLength2 && (mul *= 256)) {
          val += this[offset + i3] * mul;
        }
        return val;
      };
      Buffer4.prototype.readUintBE = Buffer4.prototype.readUIntBE = function readUIntBE(offset, byteLength2, noAssert) {
        offset = offset >>> 0;
        byteLength2 = byteLength2 >>> 0;
        if (!noAssert) {
          checkOffset(offset, byteLength2, this.length);
        }
        var val = this[offset + --byteLength2];
        var mul = 1;
        while (byteLength2 > 0 && (mul *= 256)) {
          val += this[offset + --byteLength2] * mul;
        }
        return val;
      };
      Buffer4.prototype.readUint8 = Buffer4.prototype.readUInt8 = function readUInt8(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 1, this.length);
        return this[offset];
      };
      Buffer4.prototype.readUint16LE = Buffer4.prototype.readUInt16LE = function readUInt16LE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 2, this.length);
        return this[offset] | this[offset + 1] << 8;
      };
      Buffer4.prototype.readUint16BE = Buffer4.prototype.readUInt16BE = function readUInt16BE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 2, this.length);
        return this[offset] << 8 | this[offset + 1];
      };
      Buffer4.prototype.readUint32LE = Buffer4.prototype.readUInt32LE = function readUInt32LE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 4, this.length);
        return (this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16) + this[offset + 3] * 16777216;
      };
      Buffer4.prototype.readUint32BE = Buffer4.prototype.readUInt32BE = function readUInt32BE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 4, this.length);
        return this[offset] * 16777216 + (this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3]);
      };
      Buffer4.prototype.readIntLE = function readIntLE(offset, byteLength2, noAssert) {
        offset = offset >>> 0;
        byteLength2 = byteLength2 >>> 0;
        if (!noAssert) checkOffset(offset, byteLength2, this.length);
        var val = this[offset];
        var mul = 1;
        var i3 = 0;
        while (++i3 < byteLength2 && (mul *= 256)) {
          val += this[offset + i3] * mul;
        }
        mul *= 128;
        if (val >= mul) val -= Math.pow(2, 8 * byteLength2);
        return val;
      };
      Buffer4.prototype.readIntBE = function readIntBE(offset, byteLength2, noAssert) {
        offset = offset >>> 0;
        byteLength2 = byteLength2 >>> 0;
        if (!noAssert) checkOffset(offset, byteLength2, this.length);
        var i3 = byteLength2;
        var mul = 1;
        var val = this[offset + --i3];
        while (i3 > 0 && (mul *= 256)) {
          val += this[offset + --i3] * mul;
        }
        mul *= 128;
        if (val >= mul) val -= Math.pow(2, 8 * byteLength2);
        return val;
      };
      Buffer4.prototype.readInt8 = function readInt8(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 1, this.length);
        if (!(this[offset] & 128)) return this[offset];
        return (255 - this[offset] + 1) * -1;
      };
      Buffer4.prototype.readInt16LE = function readInt16LE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 2, this.length);
        var val = this[offset] | this[offset + 1] << 8;
        return val & 32768 ? val | 4294901760 : val;
      };
      Buffer4.prototype.readInt16BE = function readInt16BE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 2, this.length);
        var val = this[offset + 1] | this[offset] << 8;
        return val & 32768 ? val | 4294901760 : val;
      };
      Buffer4.prototype.readInt32LE = function readInt32LE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 4, this.length);
        return this[offset] | this[offset + 1] << 8 | this[offset + 2] << 16 | this[offset + 3] << 24;
      };
      Buffer4.prototype.readInt32BE = function readInt32BE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 4, this.length);
        return this[offset] << 24 | this[offset + 1] << 16 | this[offset + 2] << 8 | this[offset + 3];
      };
      Buffer4.prototype.readFloatLE = function readFloatLE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 4, this.length);
        return ieee754.read(this, offset, true, 23, 4);
      };
      Buffer4.prototype.readFloatBE = function readFloatBE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 4, this.length);
        return ieee754.read(this, offset, false, 23, 4);
      };
      Buffer4.prototype.readDoubleLE = function readDoubleLE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 8, this.length);
        return ieee754.read(this, offset, true, 52, 8);
      };
      Buffer4.prototype.readDoubleBE = function readDoubleBE(offset, noAssert) {
        offset = offset >>> 0;
        if (!noAssert) checkOffset(offset, 8, this.length);
        return ieee754.read(this, offset, false, 52, 8);
      };
      function checkInt(buf, value, offset, ext, max, min) {
        if (!Buffer4.isBuffer(buf)) throw new TypeError('"buffer" argument must be a Buffer instance');
        if (value > max || value < min) throw new RangeError('"value" argument is out of bounds');
        if (offset + ext > buf.length) throw new RangeError("Index out of range");
      }
      Buffer4.prototype.writeUintLE = Buffer4.prototype.writeUIntLE = function writeUIntLE(value, offset, byteLength2, noAssert) {
        value = +value;
        offset = offset >>> 0;
        byteLength2 = byteLength2 >>> 0;
        if (!noAssert) {
          var maxBytes = Math.pow(2, 8 * byteLength2) - 1;
          checkInt(this, value, offset, byteLength2, maxBytes, 0);
        }
        var mul = 1;
        var i3 = 0;
        this[offset] = value & 255;
        while (++i3 < byteLength2 && (mul *= 256)) {
          this[offset + i3] = value / mul & 255;
        }
        return offset + byteLength2;
      };
      Buffer4.prototype.writeUintBE = Buffer4.prototype.writeUIntBE = function writeUIntBE(value, offset, byteLength2, noAssert) {
        value = +value;
        offset = offset >>> 0;
        byteLength2 = byteLength2 >>> 0;
        if (!noAssert) {
          var maxBytes = Math.pow(2, 8 * byteLength2) - 1;
          checkInt(this, value, offset, byteLength2, maxBytes, 0);
        }
        var i3 = byteLength2 - 1;
        var mul = 1;
        this[offset + i3] = value & 255;
        while (--i3 >= 0 && (mul *= 256)) {
          this[offset + i3] = value / mul & 255;
        }
        return offset + byteLength2;
      };
      Buffer4.prototype.writeUint8 = Buffer4.prototype.writeUInt8 = function writeUInt8(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 1, 255, 0);
        this[offset] = value & 255;
        return offset + 1;
      };
      Buffer4.prototype.writeUint16LE = Buffer4.prototype.writeUInt16LE = function writeUInt16LE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 2, 65535, 0);
        this[offset] = value & 255;
        this[offset + 1] = value >>> 8;
        return offset + 2;
      };
      Buffer4.prototype.writeUint16BE = Buffer4.prototype.writeUInt16BE = function writeUInt16BE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 2, 65535, 0);
        this[offset] = value >>> 8;
        this[offset + 1] = value & 255;
        return offset + 2;
      };
      Buffer4.prototype.writeUint32LE = Buffer4.prototype.writeUInt32LE = function writeUInt32LE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 4, 4294967295, 0);
        this[offset + 3] = value >>> 24;
        this[offset + 2] = value >>> 16;
        this[offset + 1] = value >>> 8;
        this[offset] = value & 255;
        return offset + 4;
      };
      Buffer4.prototype.writeUint32BE = Buffer4.prototype.writeUInt32BE = function writeUInt32BE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 4, 4294967295, 0);
        this[offset] = value >>> 24;
        this[offset + 1] = value >>> 16;
        this[offset + 2] = value >>> 8;
        this[offset + 3] = value & 255;
        return offset + 4;
      };
      Buffer4.prototype.writeIntLE = function writeIntLE(value, offset, byteLength2, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) {
          var limit = Math.pow(2, 8 * byteLength2 - 1);
          checkInt(this, value, offset, byteLength2, limit - 1, -limit);
        }
        var i3 = 0;
        var mul = 1;
        var sub = 0;
        this[offset] = value & 255;
        while (++i3 < byteLength2 && (mul *= 256)) {
          if (value < 0 && sub === 0 && this[offset + i3 - 1] !== 0) {
            sub = 1;
          }
          this[offset + i3] = (value / mul >> 0) - sub & 255;
        }
        return offset + byteLength2;
      };
      Buffer4.prototype.writeIntBE = function writeIntBE(value, offset, byteLength2, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) {
          var limit = Math.pow(2, 8 * byteLength2 - 1);
          checkInt(this, value, offset, byteLength2, limit - 1, -limit);
        }
        var i3 = byteLength2 - 1;
        var mul = 1;
        var sub = 0;
        this[offset + i3] = value & 255;
        while (--i3 >= 0 && (mul *= 256)) {
          if (value < 0 && sub === 0 && this[offset + i3 + 1] !== 0) {
            sub = 1;
          }
          this[offset + i3] = (value / mul >> 0) - sub & 255;
        }
        return offset + byteLength2;
      };
      Buffer4.prototype.writeInt8 = function writeInt8(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 1, 127, -128);
        if (value < 0) value = 255 + value + 1;
        this[offset] = value & 255;
        return offset + 1;
      };
      Buffer4.prototype.writeInt16LE = function writeInt16LE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 2, 32767, -32768);
        this[offset] = value & 255;
        this[offset + 1] = value >>> 8;
        return offset + 2;
      };
      Buffer4.prototype.writeInt16BE = function writeInt16BE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 2, 32767, -32768);
        this[offset] = value >>> 8;
        this[offset + 1] = value & 255;
        return offset + 2;
      };
      Buffer4.prototype.writeInt32LE = function writeInt32LE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 4, 2147483647, -2147483648);
        this[offset] = value & 255;
        this[offset + 1] = value >>> 8;
        this[offset + 2] = value >>> 16;
        this[offset + 3] = value >>> 24;
        return offset + 4;
      };
      Buffer4.prototype.writeInt32BE = function writeInt32BE(value, offset, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) checkInt(this, value, offset, 4, 2147483647, -2147483648);
        if (value < 0) value = 4294967295 + value + 1;
        this[offset] = value >>> 24;
        this[offset + 1] = value >>> 16;
        this[offset + 2] = value >>> 8;
        this[offset + 3] = value & 255;
        return offset + 4;
      };
      function checkIEEE754(buf, value, offset, ext, max, min) {
        if (offset + ext > buf.length) throw new RangeError("Index out of range");
        if (offset < 0) throw new RangeError("Index out of range");
      }
      function writeFloat(buf, value, offset, littleEndian, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) {
          checkIEEE754(buf, value, offset, 4, 34028234663852886e22, -34028234663852886e22);
        }
        ieee754.write(buf, value, offset, littleEndian, 23, 4);
        return offset + 4;
      }
      Buffer4.prototype.writeFloatLE = function writeFloatLE(value, offset, noAssert) {
        return writeFloat(this, value, offset, true, noAssert);
      };
      Buffer4.prototype.writeFloatBE = function writeFloatBE(value, offset, noAssert) {
        return writeFloat(this, value, offset, false, noAssert);
      };
      function writeDouble(buf, value, offset, littleEndian, noAssert) {
        value = +value;
        offset = offset >>> 0;
        if (!noAssert) {
          checkIEEE754(buf, value, offset, 8, 17976931348623157e292, -17976931348623157e292);
        }
        ieee754.write(buf, value, offset, littleEndian, 52, 8);
        return offset + 8;
      }
      Buffer4.prototype.writeDoubleLE = function writeDoubleLE(value, offset, noAssert) {
        return writeDouble(this, value, offset, true, noAssert);
      };
      Buffer4.prototype.writeDoubleBE = function writeDoubleBE(value, offset, noAssert) {
        return writeDouble(this, value, offset, false, noAssert);
      };
      Buffer4.prototype.copy = function copy(target, targetStart, start, end) {
        if (!Buffer4.isBuffer(target)) throw new TypeError("argument should be a Buffer");
        if (!start) start = 0;
        if (!end && end !== 0) end = this.length;
        if (targetStart >= target.length) targetStart = target.length;
        if (!targetStart) targetStart = 0;
        if (end > 0 && end < start) end = start;
        if (end === start) return 0;
        if (target.length === 0 || this.length === 0) return 0;
        if (targetStart < 0) {
          throw new RangeError("targetStart out of bounds");
        }
        if (start < 0 || start >= this.length) throw new RangeError("Index out of range");
        if (end < 0) throw new RangeError("sourceEnd out of bounds");
        if (end > this.length) end = this.length;
        if (target.length - targetStart < end - start) {
          end = target.length - targetStart + start;
        }
        var len = end - start;
        if (this === target && typeof Uint8Array.prototype.copyWithin === "function") {
          this.copyWithin(targetStart, start, end);
        } else {
          Uint8Array.prototype.set.call(
            target,
            this.subarray(start, end),
            targetStart
          );
        }
        return len;
      };
      Buffer4.prototype.fill = function fill(val, start, end, encoding) {
        if (typeof val === "string") {
          if (typeof start === "string") {
            encoding = start;
            start = 0;
            end = this.length;
          } else if (typeof end === "string") {
            encoding = end;
            end = this.length;
          }
          if (encoding !== void 0 && typeof encoding !== "string") {
            throw new TypeError("encoding must be a string");
          }
          if (typeof encoding === "string" && !Buffer4.isEncoding(encoding)) {
            throw new TypeError("Unknown encoding: " + encoding);
          }
          if (val.length === 1) {
            var code = val.charCodeAt(0);
            if (encoding === "utf8" && code < 128 || encoding === "latin1") {
              val = code;
            }
          }
        } else if (typeof val === "number") {
          val = val & 255;
        } else if (typeof val === "boolean") {
          val = Number(val);
        }
        if (start < 0 || this.length < start || this.length < end) {
          throw new RangeError("Out of range index");
        }
        if (end <= start) {
          return this;
        }
        start = start >>> 0;
        end = end === void 0 ? this.length : end >>> 0;
        if (!val) val = 0;
        var i3;
        if (typeof val === "number") {
          for (i3 = start; i3 < end; ++i3) {
            this[i3] = val;
          }
        } else {
          var bytes = Buffer4.isBuffer(val) ? val : Buffer4.from(val, encoding);
          var len = bytes.length;
          if (len === 0) {
            throw new TypeError('The value "' + val + '" is invalid for argument "value"');
          }
          for (i3 = 0; i3 < end - start; ++i3) {
            this[i3 + start] = bytes[i3 % len];
          }
        }
        return this;
      };
      var INVALID_BASE64_RE = /[^+/0-9A-Za-z-_]/g;
      function base64clean(str) {
        str = str.split("=")[0];
        str = str.trim().replace(INVALID_BASE64_RE, "");
        if (str.length < 2) return "";
        while (str.length % 4 !== 0) {
          str = str + "=";
        }
        return str;
      }
      function utf8ToBytes(string, units) {
        units = units || Infinity;
        var codePoint;
        var length = string.length;
        var leadSurrogate = null;
        var bytes = [];
        for (var i3 = 0; i3 < length; ++i3) {
          codePoint = string.charCodeAt(i3);
          if (codePoint > 55295 && codePoint < 57344) {
            if (!leadSurrogate) {
              if (codePoint > 56319) {
                if ((units -= 3) > -1) bytes.push(239, 191, 189);
                continue;
              } else if (i3 + 1 === length) {
                if ((units -= 3) > -1) bytes.push(239, 191, 189);
                continue;
              }
              leadSurrogate = codePoint;
              continue;
            }
            if (codePoint < 56320) {
              if ((units -= 3) > -1) bytes.push(239, 191, 189);
              leadSurrogate = codePoint;
              continue;
            }
            codePoint = (leadSurrogate - 55296 << 10 | codePoint - 56320) + 65536;
          } else if (leadSurrogate) {
            if ((units -= 3) > -1) bytes.push(239, 191, 189);
          }
          leadSurrogate = null;
          if (codePoint < 128) {
            if ((units -= 1) < 0) break;
            bytes.push(codePoint);
          } else if (codePoint < 2048) {
            if ((units -= 2) < 0) break;
            bytes.push(
              codePoint >> 6 | 192,
              codePoint & 63 | 128
            );
          } else if (codePoint < 65536) {
            if ((units -= 3) < 0) break;
            bytes.push(
              codePoint >> 12 | 224,
              codePoint >> 6 & 63 | 128,
              codePoint & 63 | 128
            );
          } else if (codePoint < 1114112) {
            if ((units -= 4) < 0) break;
            bytes.push(
              codePoint >> 18 | 240,
              codePoint >> 12 & 63 | 128,
              codePoint >> 6 & 63 | 128,
              codePoint & 63 | 128
            );
          } else {
            throw new Error("Invalid code point");
          }
        }
        return bytes;
      }
      function asciiToBytes(str) {
        var byteArray = [];
        for (var i3 = 0; i3 < str.length; ++i3) {
          byteArray.push(str.charCodeAt(i3) & 255);
        }
        return byteArray;
      }
      function utf16leToBytes(str, units) {
        var c3, hi, lo;
        var byteArray = [];
        for (var i3 = 0; i3 < str.length; ++i3) {
          if ((units -= 2) < 0) break;
          c3 = str.charCodeAt(i3);
          hi = c3 >> 8;
          lo = c3 % 256;
          byteArray.push(lo);
          byteArray.push(hi);
        }
        return byteArray;
      }
      function base64ToBytes(str) {
        return base64.toByteArray(base64clean(str));
      }
      function blitBuffer(src, dst, offset, length) {
        for (var i3 = 0; i3 < length; ++i3) {
          if (i3 + offset >= dst.length || i3 >= src.length) break;
          dst[i3 + offset] = src[i3];
        }
        return i3;
      }
      function isInstance(obj, type) {
        return obj instanceof type || obj != null && obj.constructor != null && obj.constructor.name != null && obj.constructor.name === type.name;
      }
      function numberIsNaN(obj) {
        return obj !== obj;
      }
      var hexSliceLookupTable = function() {
        var alphabet2 = "0123456789abcdef";
        var table = new Array(256);
        for (var i3 = 0; i3 < 16; ++i3) {
          var i16 = i3 * 16;
          for (var j4 = 0; j4 < 16; ++j4) {
            table[i16 + j4] = alphabet2[i3] + alphabet2[j4];
          }
        }
        return table;
      }();
    }
  });

  // (disabled):fs
  var require_fs = __commonJS({
    "(disabled):fs"() {
      init_preact_shim();
    }
  });

  // node_modules/path-browserify/index.js
  var require_path_browserify = __commonJS({
    "node_modules/path-browserify/index.js"(exports, module) {
      "use strict";
      init_preact_shim();
      function assertPath(path2) {
        if (typeof path2 !== "string") {
          throw new TypeError("Path must be a string. Received " + JSON.stringify(path2));
        }
      }
      function normalizeStringPosix(path2, allowAboveRoot) {
        var res = "";
        var lastSegmentLength = 0;
        var lastSlash = -1;
        var dots = 0;
        var code;
        for (var i3 = 0; i3 <= path2.length; ++i3) {
          if (i3 < path2.length)
            code = path2.charCodeAt(i3);
          else if (code === 47)
            break;
          else
            code = 47;
          if (code === 47) {
            if (lastSlash === i3 - 1 || dots === 1) {
            } else if (lastSlash !== i3 - 1 && dots === 2) {
              if (res.length < 2 || lastSegmentLength !== 2 || res.charCodeAt(res.length - 1) !== 46 || res.charCodeAt(res.length - 2) !== 46) {
                if (res.length > 2) {
                  var lastSlashIndex = res.lastIndexOf("/");
                  if (lastSlashIndex !== res.length - 1) {
                    if (lastSlashIndex === -1) {
                      res = "";
                      lastSegmentLength = 0;
                    } else {
                      res = res.slice(0, lastSlashIndex);
                      lastSegmentLength = res.length - 1 - res.lastIndexOf("/");
                    }
                    lastSlash = i3;
                    dots = 0;
                    continue;
                  }
                } else if (res.length === 2 || res.length === 1) {
                  res = "";
                  lastSegmentLength = 0;
                  lastSlash = i3;
                  dots = 0;
                  continue;
                }
              }
              if (allowAboveRoot) {
                if (res.length > 0)
                  res += "/..";
                else
                  res = "..";
                lastSegmentLength = 2;
              }
            } else {
              if (res.length > 0)
                res += "/" + path2.slice(lastSlash + 1, i3);
              else
                res = path2.slice(lastSlash + 1, i3);
              lastSegmentLength = i3 - lastSlash - 1;
            }
            lastSlash = i3;
            dots = 0;
          } else if (code === 46 && dots !== -1) {
            ++dots;
          } else {
            dots = -1;
          }
        }
        return res;
      }
      function _format(sep, pathObject) {
        var dir = pathObject.dir || pathObject.root;
        var base = pathObject.base || (pathObject.name || "") + (pathObject.ext || "");
        if (!dir) {
          return base;
        }
        if (dir === pathObject.root) {
          return dir + base;
        }
        return dir + sep + base;
      }
      var posix = {
        // path.resolve([from ...], to)
        resolve: function resolve() {
          var resolvedPath = "";
          var resolvedAbsolute = false;
          var cwd;
          for (var i3 = arguments.length - 1; i3 >= -1 && !resolvedAbsolute; i3--) {
            var path2;
            if (i3 >= 0)
              path2 = arguments[i3];
            else {
              if (cwd === void 0)
                cwd = process.cwd();
              path2 = cwd;
            }
            assertPath(path2);
            if (path2.length === 0) {
              continue;
            }
            resolvedPath = path2 + "/" + resolvedPath;
            resolvedAbsolute = path2.charCodeAt(0) === 47;
          }
          resolvedPath = normalizeStringPosix(resolvedPath, !resolvedAbsolute);
          if (resolvedAbsolute) {
            if (resolvedPath.length > 0)
              return "/" + resolvedPath;
            else
              return "/";
          } else if (resolvedPath.length > 0) {
            return resolvedPath;
          } else {
            return ".";
          }
        },
        normalize: function normalize(path2) {
          assertPath(path2);
          if (path2.length === 0) return ".";
          var isAbsolute = path2.charCodeAt(0) === 47;
          var trailingSeparator = path2.charCodeAt(path2.length - 1) === 47;
          path2 = normalizeStringPosix(path2, !isAbsolute);
          if (path2.length === 0 && !isAbsolute) path2 = ".";
          if (path2.length > 0 && trailingSeparator) path2 += "/";
          if (isAbsolute) return "/" + path2;
          return path2;
        },
        isAbsolute: function isAbsolute(path2) {
          assertPath(path2);
          return path2.length > 0 && path2.charCodeAt(0) === 47;
        },
        join: function join() {
          if (arguments.length === 0)
            return ".";
          var joined;
          for (var i3 = 0; i3 < arguments.length; ++i3) {
            var arg = arguments[i3];
            assertPath(arg);
            if (arg.length > 0) {
              if (joined === void 0)
                joined = arg;
              else
                joined += "/" + arg;
            }
          }
          if (joined === void 0)
            return ".";
          return posix.normalize(joined);
        },
        relative: function relative(from, to) {
          assertPath(from);
          assertPath(to);
          if (from === to) return "";
          from = posix.resolve(from);
          to = posix.resolve(to);
          if (from === to) return "";
          var fromStart = 1;
          for (; fromStart < from.length; ++fromStart) {
            if (from.charCodeAt(fromStart) !== 47)
              break;
          }
          var fromEnd = from.length;
          var fromLen = fromEnd - fromStart;
          var toStart = 1;
          for (; toStart < to.length; ++toStart) {
            if (to.charCodeAt(toStart) !== 47)
              break;
          }
          var toEnd = to.length;
          var toLen = toEnd - toStart;
          var length = fromLen < toLen ? fromLen : toLen;
          var lastCommonSep = -1;
          var i3 = 0;
          for (; i3 <= length; ++i3) {
            if (i3 === length) {
              if (toLen > length) {
                if (to.charCodeAt(toStart + i3) === 47) {
                  return to.slice(toStart + i3 + 1);
                } else if (i3 === 0) {
                  return to.slice(toStart + i3);
                }
              } else if (fromLen > length) {
                if (from.charCodeAt(fromStart + i3) === 47) {
                  lastCommonSep = i3;
                } else if (i3 === 0) {
                  lastCommonSep = 0;
                }
              }
              break;
            }
            var fromCode = from.charCodeAt(fromStart + i3);
            var toCode = to.charCodeAt(toStart + i3);
            if (fromCode !== toCode)
              break;
            else if (fromCode === 47)
              lastCommonSep = i3;
          }
          var out = "";
          for (i3 = fromStart + lastCommonSep + 1; i3 <= fromEnd; ++i3) {
            if (i3 === fromEnd || from.charCodeAt(i3) === 47) {
              if (out.length === 0)
                out += "..";
              else
                out += "/..";
            }
          }
          if (out.length > 0)
            return out + to.slice(toStart + lastCommonSep);
          else {
            toStart += lastCommonSep;
            if (to.charCodeAt(toStart) === 47)
              ++toStart;
            return to.slice(toStart);
          }
        },
        _makeLong: function _makeLong(path2) {
          return path2;
        },
        dirname: function dirname(path2) {
          assertPath(path2);
          if (path2.length === 0) return ".";
          var code = path2.charCodeAt(0);
          var hasRoot = code === 47;
          var end = -1;
          var matchedSlash = true;
          for (var i3 = path2.length - 1; i3 >= 1; --i3) {
            code = path2.charCodeAt(i3);
            if (code === 47) {
              if (!matchedSlash) {
                end = i3;
                break;
              }
            } else {
              matchedSlash = false;
            }
          }
          if (end === -1) return hasRoot ? "/" : ".";
          if (hasRoot && end === 1) return "//";
          return path2.slice(0, end);
        },
        basename: function basename(path2, ext) {
          if (ext !== void 0 && typeof ext !== "string") throw new TypeError('"ext" argument must be a string');
          assertPath(path2);
          var start = 0;
          var end = -1;
          var matchedSlash = true;
          var i3;
          if (ext !== void 0 && ext.length > 0 && ext.length <= path2.length) {
            if (ext.length === path2.length && ext === path2) return "";
            var extIdx = ext.length - 1;
            var firstNonSlashEnd = -1;
            for (i3 = path2.length - 1; i3 >= 0; --i3) {
              var code = path2.charCodeAt(i3);
              if (code === 47) {
                if (!matchedSlash) {
                  start = i3 + 1;
                  break;
                }
              } else {
                if (firstNonSlashEnd === -1) {
                  matchedSlash = false;
                  firstNonSlashEnd = i3 + 1;
                }
                if (extIdx >= 0) {
                  if (code === ext.charCodeAt(extIdx)) {
                    if (--extIdx === -1) {
                      end = i3;
                    }
                  } else {
                    extIdx = -1;
                    end = firstNonSlashEnd;
                  }
                }
              }
            }
            if (start === end) end = firstNonSlashEnd;
            else if (end === -1) end = path2.length;
            return path2.slice(start, end);
          } else {
            for (i3 = path2.length - 1; i3 >= 0; --i3) {
              if (path2.charCodeAt(i3) === 47) {
                if (!matchedSlash) {
                  start = i3 + 1;
                  break;
                }
              } else if (end === -1) {
                matchedSlash = false;
                end = i3 + 1;
              }
            }
            if (end === -1) return "";
            return path2.slice(start, end);
          }
        },
        extname: function extname(path2) {
          assertPath(path2);
          var startDot = -1;
          var startPart = 0;
          var end = -1;
          var matchedSlash = true;
          var preDotState = 0;
          for (var i3 = path2.length - 1; i3 >= 0; --i3) {
            var code = path2.charCodeAt(i3);
            if (code === 47) {
              if (!matchedSlash) {
                startPart = i3 + 1;
                break;
              }
              continue;
            }
            if (end === -1) {
              matchedSlash = false;
              end = i3 + 1;
            }
            if (code === 46) {
              if (startDot === -1)
                startDot = i3;
              else if (preDotState !== 1)
                preDotState = 1;
            } else if (startDot !== -1) {
              preDotState = -1;
            }
          }
          if (startDot === -1 || end === -1 || // We saw a non-dot character immediately before the dot
          preDotState === 0 || // The (right-most) trimmed path component is exactly '..'
          preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {
            return "";
          }
          return path2.slice(startDot, end);
        },
        format: function format(pathObject) {
          if (pathObject === null || typeof pathObject !== "object") {
            throw new TypeError('The "pathObject" argument must be of type Object. Received type ' + typeof pathObject);
          }
          return _format("/", pathObject);
        },
        parse: function parse(path2) {
          assertPath(path2);
          var ret = { root: "", dir: "", base: "", ext: "", name: "" };
          if (path2.length === 0) return ret;
          var code = path2.charCodeAt(0);
          var isAbsolute = code === 47;
          var start;
          if (isAbsolute) {
            ret.root = "/";
            start = 1;
          } else {
            start = 0;
          }
          var startDot = -1;
          var startPart = 0;
          var end = -1;
          var matchedSlash = true;
          var i3 = path2.length - 1;
          var preDotState = 0;
          for (; i3 >= start; --i3) {
            code = path2.charCodeAt(i3);
            if (code === 47) {
              if (!matchedSlash) {
                startPart = i3 + 1;
                break;
              }
              continue;
            }
            if (end === -1) {
              matchedSlash = false;
              end = i3 + 1;
            }
            if (code === 46) {
              if (startDot === -1) startDot = i3;
              else if (preDotState !== 1) preDotState = 1;
            } else if (startDot !== -1) {
              preDotState = -1;
            }
          }
          if (startDot === -1 || end === -1 || // We saw a non-dot character immediately before the dot
          preDotState === 0 || // The (right-most) trimmed path component is exactly '..'
          preDotState === 1 && startDot === end - 1 && startDot === startPart + 1) {
            if (end !== -1) {
              if (startPart === 0 && isAbsolute) ret.base = ret.name = path2.slice(1, end);
              else ret.base = ret.name = path2.slice(startPart, end);
            }
          } else {
            if (startPart === 0 && isAbsolute) {
              ret.name = path2.slice(1, startDot);
              ret.base = path2.slice(1, end);
            } else {
              ret.name = path2.slice(startPart, startDot);
              ret.base = path2.slice(startPart, end);
            }
            ret.ext = path2.slice(startDot, end);
          }
          if (startPart > 0) ret.dir = path2.slice(0, startPart - 1);
          else if (isAbsolute) ret.dir = "/";
          return ret;
        },
        sep: "/",
        delimiter: ":",
        win32: null,
        posix: null
      };
      posix.posix = posix;
      module.exports = posix;
    }
  });

  // node_modules/queue-microtask/index.js
  var require_queue_microtask = __commonJS({
    "node_modules/queue-microtask/index.js"(exports, module) {
      init_preact_shim();
      var promise;
      module.exports = typeof queueMicrotask === "function" ? queueMicrotask.bind(typeof window !== "undefined" ? window : global) : (cb) => (promise || (promise = Promise.resolve())).then(cb).catch((err) => setTimeout(() => {
        throw err;
      }, 0));
    }
  });

  // src/index.tsx
  init_preact_shim();
  init_preact_module();

  // src/const.ts
  init_preact_shim();

  // src/config.json
  var PT_SITE = {
    "1PTBA": {
      url: "https://1ptba.com",
      host: "1ptba.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: "#torrenttable>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          x264: "1",
          hevc: "10",
          x265: "10",
          h265: "10",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "18",
          dd: "18",
          "dd+": "18",
          flac: "1",
          dts: "3",
          truehd: "20",
          lpcm: "21",
          dtshdma: "19",
          atmos: "19",
          dtsx: "3",
          ape: "2",
          wav: "22",
          mp3: "4",
          m4a: "5",
          other: "7"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "10",
          bluray: "13",
          remux: "3",
          encode: "7",
          web: "11",
          hdtv: "5",
          dvd: "2",
          dvdrip: "7",
          other: "12",
          cd: "8"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "11",
          "2160p": "10",
          "1080p": "2",
          "1080i": "2",
          "720p": "4",
          "576p": "5",
          "480p": "5"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          "1ptba": "1",
          chd: "2",
          mysilu: "3",
          wiki: "4",
          other: "5"
        }
      }
    },
    "3Wmg": {
      url: "https://www.3wmg.com",
      host: "3wmg.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="pt_gen[douban][link]"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: 'input[name="tags[]"][value="16"]',
        diy: 'input[name="tags[]"][value="8"]',
        hdr: 'input[name="tags[]"][value="64"]',
        chinese_subtitle: 'input[name="tags[]"][value="32"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "403",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "410",
          cartoon: "405",
          variety: "403"
        }
      },
      source: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "1",
          hdtv: "4",
          dvd: "3",
          web: "6",
          vhs: "6",
          hddvd: "2"
        }
      }
    },
    "52pt": {
      url: "https://52pt.site",
      host: "52pt.site",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "13",
          x264: "11",
          hevc: "1",
          x265: "12",
          h265: "1",
          mpeg2: "4",
          mpeg4: "13",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "13",
          ac3: "6",
          dd: "6",
          "dd+": "6",
          flac: "1",
          dts: "15",
          truehd: "12",
          lpcm: "14",
          dtshdma: "4",
          atmos: "10",
          dtsx: "3",
          ape: "2",
          wav: "11",
          other: "7"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "11",
          remux: "4",
          encode: "7",
          web: "10",
          hdtv: "3",
          dvd: "6",
          dvdrip: "7",
          other: "9",
          cd: "8"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "7",
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "6",
          "480p": "6"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          beyondhd: "1",
          hdsky: "2",
          ttg: "3",
          mteam: "8",
          coaster: "4",
          chdbits: "9",
          ourbits: "10",
          hdhome: "11",
          cmct: "12",
          hdchina: "14",
          pthome: "15",
          other: "5"
        }
      }
    },
    ACM: {
      url: "https://asiancinema.me",
      host: "asiancinema.me",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload/1",
      needDoubanInfo: true,
      seedDomSelector: '#meta-info+.meta-general>.panel:has(".table-responsive"):first table tr:last',
      torrentDownloadLinkSelector: 'a[href*="/torrents/download/"]',
      search: {
        path: "/torrents",
        params: {
          name: "{name}",
          imdb: "{imdb}"
        }
      },
      name: {
        selector: "#title"
      },
      description: {
        selector: "#upload-form-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      anonymous: {
        selector: '.radio-inline:first input[name="anonymous"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      videoType: {
        selector: "#autocat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      category: {
        selector: "#autotype",
        map: {
          BD100: "1",
          BD66: "2",
          UHD50: "3",
          BD50: "4",
          BD25: "5",
          remux: [
            "12",
            "7"
          ],
          encode: [
            "8",
            "10",
            "11",
            "13"
          ],
          web: "9",
          hdtv: "17",
          dvd: [
            "14",
            "16"
          ],
          dvdrip: "13",
          other: ""
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "2160p": [
            "1",
            "1",
            "2",
            "3",
            "12",
            "8"
          ],
          "1080p": [
            "2",
            "4",
            "5",
            "7",
            "10"
          ],
          "1080i": [
            "2",
            "4",
            "5",
            "7",
            "10"
          ],
          "720p": [
            "3",
            "11"
          ],
          "576p": [
            "4",
            "13"
          ],
          "480p": [
            "5",
            "14",
            "16",
            "13"
          ],
          other: ""
        }
      }
    },
    Aither: {
      url: "https://aither.cc",
      host: "aither.cc",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/torrents/create?category_id=1",
      needDoubanInfo: true,
      seedDomSelector: ".torrent__buttons+.panelV2",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          name: "{name}",
          imdbId: "{imdb}",
          sortField: "size"
        }
      },
      name: {
        selector: 'input[name="name"][class="form__text"]'
      },
      description: {
        selector: "#bbcode-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      anonymous: {
        selector: '.form__group input[type="checkbox"][name="anonymous"]'
      },
      torrent: {
        selector: 'input[type="file"][accept=".torrent"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2",
          documentary: "1",
          concert: "1",
          sport: "9",
          cartoon: "405",
          app: "10",
          ebook: "11",
          magazine: "11",
          audioBook: "14"
        }
      },
      videoType: {
        selector: "#autotype",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "2",
          encode: "3",
          web: "4",
          hdtv: "6",
          dvd: "1",
          dvdrip: "3",
          other: "7"
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "4320p": "1",
          "2160p": "2",
          "1080p": "3",
          "1080i": "4",
          "720p": "5",
          "576p": "6",
          "480p": "8"
        }
      }
    },
    Audiences: {
      url: "https://audiences.me",
      host: "audiences.me",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_id"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: "#tag_gy",
        diy: "#tag_diy",
        cantonese_audio: "#tag_yy",
        chinese_subtitle: "#tag_zz",
        hdr: "#tag_hdr10",
        hdr10_plus: "#tag_hdrm",
        dolby_vision: "#tag_db"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "401",
          concert: "408",
          sport: "407",
          cartoon: "401",
          variety: "403",
          app: "411",
          ebook: "405",
          magazine: "412",
          audioBook: "404"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          x264: "1",
          hevc: "6",
          x265: "6",
          h265: "6",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "5",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "18",
          dd: "18",
          "dd+": "18",
          flac: "1",
          dts: "3",
          truehd: "20",
          lpcm: "21",
          dtshdma: "19",
          atmos: "26",
          dtsx: "25",
          ape: "2",
          wav: "22",
          mp3: "23",
          m4a: "24"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "12",
          bluray: "1",
          remux: "3",
          encode: "15",
          web: "10",
          hdtv: "5",
          dvd: "2",
          dvdrip: "15",
          other: "11"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "10",
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          other: "5"
        }
      }
    },
    AvistaZ: {
      url: "https://avistaz.to",
      host: "avistaz.to",
      siteType: "AvistaZ",
      icon: "",
      asSource: true,
      asTarget: false,
      uploadPath: "/upload.php",
      seedDomSelector: "#content-area .block:last table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="/download/torrent/"]',
      needDoubanInfo: true,
      search: {
        path: "/torrents",
        params: {
          search: "{imdb}",
          in: "1",
          order: "size",
          sort: "desc"
        }
      }
    },
    BLUEBIRD: {
      url: "https://bluebird-hd.org",
      host: "bluebird-hd.org",
      siteType: "bluebird",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/browse.php",
        params: {
          search: "{name}",
          incldead: 0,
          cat: 0,
          dsearch: "{imdb}",
          stype: "or"
        }
      }
    },
    BTN: {
      url: "https://broadcasthe.net",
      host: "broadcasthe.net",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: false,
      needDoubanInfo: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          action: "advanced",
          imdb: "{imdb}",
          artistname: "{name}"
        }
      }
    },
    BTSCHOOL: {
      url: "https://pt.btschool.club",
      host: "btschool.club",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      poster: 'input[name="picture"]',
      imdb: {
        selector: 'input[name="imdbid"]'
      },
      douban: {
        selector: 'input[name="doubanid"]'
      },
      tags: {
        chinese_audio: 'input[type="checkbox"][name="span[]"][value="5"]',
        chinese_subtitle: 'input[type="checkbox"][name="span[]"][value="6"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "405",
          tv: "406",
          tvPack: "406",
          documentary: "408",
          concert: "409",
          sport: "410",
          cartoon: "407",
          variety: "412",
          music: "411"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          x264: "1",
          hevc: "10",
          x265: "10",
          h265: "10",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "10",
          dd: "10",
          "dd+": "10",
          flac: "1",
          dts: "3",
          truehd: "11",
          lpcm: "5",
          dtshdma: "3",
          atmos: "3",
          dtsx: "3"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "12",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "10",
          hdtv: "5",
          dvd: "6",
          dvdrip: "6",
          other: "11",
          cd: "8"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "5",
          "1080p": "1",
          "1080i": "1",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          btschool: "1",
          zone: "13",
          btshd: "2",
          btstv: "3",
          btspad: "4",
          wiki: "5",
          hdchina: "6",
          hdbint: "7",
          mteam: "9",
          cmct: "10",
          ourbits: "11",
          other: "12"
        }
      }
    },
    BYR: {
      url: "https://byr.pt",
      host: "byr.pt",
      siteType: "NexusPHP",
      icon: "",
      asSource: false,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="dburl"]'
      },
      torrent: {
        selector: "#torrent"
      }
    },
    Bdc: {
      url: "https://broadcity.in",
      host: "broadcity.in",
      siteType: "Bdc",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      needDoubanInfo: true,
      search: {
        path: "/browse.php",
        imdbOptionKey: "t_genre",
        nameOptionKey: "t_name",
        params: {
          imdb: "{imdb}",
          search_area: "{optionKey}"
        }
      },
      seedDomSelector: "#details>table>tbody>tr:nth-child(11)",
      name: {
        selector: "#subject"
      },
      description: {
        selector: 'textarea[name="message"]'
      },
      imdb: {
        selector: 'input[name="t_link"]'
      },
      anonymous: {
        selector: 'input[name="anonymous"]'
      },
      videoType: {
        map: {
          uhdbluray: "1",
          bluray: "2",
          remux: "3",
          encode: "6",
          web: "5",
          hdtv: "4",
          dvd: "7",
          dvdrip: "7",
          other: "15"
        }
      },
      resolution: {
        map: {
          "2160p": {
            remux: "2",
            encode: "2",
            web: "6"
          },
          "1080p": {
            remux: "4",
            hdtv: "4",
            encode: "4",
            web: "5"
          },
          "720p": {
            hdtv: "4",
            encode: "4",
            web: "5"
          },
          "576p": {
            encode: "23",
            web: "5",
            dvdrip: "36",
            dvd: "10"
          },
          "480p": {
            encode: "23",
            web: "5",
            dvdrip: "36",
            dvd: "10"
          }
        }
      }
    },
    BeyondHD: {
      url: "https://beyond-hd.me",
      host: "beyond-hd.me",
      siteType: "F3NIX",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: ".table-details tr:last",
      torrentDownloadLinkSelector: 'a[href*="/download/"].bhd-fl-button',
      needDoubanInfo: true,
      uploadPath: "/upload",
      search: {
        path: "/torrents/all",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          imdb: "{imdb}",
          search: "{name}",
          sorting: "size",
          direction: "desc",
          doSearch: "Search"
        }
      },
      sourceInfo: {
        editionTags: {
          "10-bit": "10_bit",
          "2-Disc Set": "2_disc_set",
          "2D/3D Edition": "2d_3d_edition",
          "2in1": "2_in_1",
          "3D": "3d",
          "3D Anaglyph": "3d_anaglyph",
          "3D Full SBS": "3d_full_sbs",
          "3D Half OU": "3d_half_ou",
          "3D Half SBS": "3d_half_sbs",
          "4K Remaster": "4k_remaster",
          "4K Restoration": "4k_restoration",
          "Digital Extras": "extras",
          "Director's Cut": "director_s_cut",
          "Dolby Atmos": "dolby_atmos",
          "Dolby Vision": "dolby_vision",
          "Dual Audio": "dual_audio",
          "English Dub": "english_dub",
          "Extended Cut": "extended_edition",
          "Extended Edition": "extended_edition",
          Extras: "extras",
          HDR10: "hdr",
          "HDR10+": "hdr10_plus",
          "Masters of Cinema": "masters_of_cinema",
          Scene: "scene",
          "The Criterion Collection": "the_criterion_collection",
          "Theatrical Cut": "theatrical_cut",
          "Two-Disc Set": "two_disc_set",
          Remux: "remux",
          Rifftrax: "rifftrax",
          Uncut: "uncut",
          Unrated: "unrated",
          "Warner Archive Collection": "warner_archive_collection",
          Commentary: "with_commentary"
        }
      },
      targetInfo: {
        editionTags: {
          "2d_3d_edition": "2D3D",
          "2_in_1": "2in1",
          "3d": "3D",
          "3d_anaglyph": "3D",
          "3d_full_sbs": "3D",
          "3d_half_ou": "3D",
          "3d_half_sbs": "3D",
          "4k_remaster": "4kRemaster",
          director_s_cut: "Director",
          dual_audio: "DualAudio",
          english_dub: "EnglishDub",
          extended_edition: "Extended",
          extras: "Extras",
          hybrid: "Hybrid",
          scene: "Scene",
          theatrical_cut: "Theatrical",
          uncut: "Uncut",
          unrated: "Unrated",
          webdl: "WEBDL",
          webrip: "WEBRip",
          with_commentary: "Commentary"
        }
      },
      name: {
        selector: "#title"
      },
      description: {
        selector: "#upload-form-description"
      },
      imdb: {
        selector: "#imdbauto"
      },
      tmdb: {
        selector: "#tmdbauto"
      },
      mediaInfo: {
        selector: "#mediainfo"
      },
      anonymous: {
        selector: 'input[name="anonymous"]'
      },
      videoType: {
        selector: "#category_id",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      torrent: {
        selector: 'input[type="file"][accept=".torrent"]'
      },
      category: {
        selector: "#autotype",
        map: {
          BD100: "UHD 100",
          BD66: "UHD 66",
          UHD50: "UHD 50",
          BD50: "BD 50",
          BD25: "BD 25",
          DVD5: "DVD 5",
          DVD9: "DVD 9",
          remux: [
            "UHD Remux",
            "BD Remux",
            "DVD Remux"
          ],
          encode: [
            "2160p",
            "1080p",
            "720p",
            "576p",
            "540p",
            "480p"
          ],
          web: [
            "2160p",
            "1080p",
            "720p",
            "576p",
            "540p",
            "480p"
          ],
          hdtv: [
            "2160p",
            "1080p",
            "1080i",
            "720p"
          ],
          dvd: [
            "DVD 9",
            "DVD 5",
            "DVD Remux"
          ],
          dvdrip: [
            "480p"
          ],
          other: ""
        }
      },
      source: {
        selector: "#autosource",
        map: {
          uhdbluray: [
            "Blu-ray"
          ],
          bluray: [
            "Blu-ray",
            "BD 50",
            "BD 25",
            "BD Remux",
            "UHD 100",
            "UHD 66",
            "UHD 50",
            "UHD Remux",
            "2160p",
            "1080p",
            "720p",
            "576p",
            "540p",
            "480p"
          ],
          hdtv: [
            "HDTV",
            "2160p",
            "1080p",
            "1080i",
            "720p"
          ],
          dvd: [
            "DVD",
            "DVD 9",
            "DVD 5",
            "DVD Remux",
            "480p"
          ],
          web: [
            "WEB",
            "2160p",
            "1080p",
            "720p",
            "576p",
            "540p",
            "480p"
          ],
          hddvd: "HD-DVD"
        }
      },
      resolution: {
        map: {
          "2160p": [
            "UHD 100",
            "UHD 66",
            "UHD 50",
            "UHD Remux",
            "2160p"
          ],
          "1080p": [
            "BD 50",
            "BD 25",
            "BD Remux",
            "1080p"
          ],
          "1080i": [
            "BD 50",
            "BD 25",
            "BD Remux",
            "1080i"
          ],
          "720p": [
            "720p"
          ],
          "576p": [
            "576p"
          ],
          "540p": [
            "540p"
          ],
          "480p": [
            "DVD 9",
            "DVD 5",
            "DVD Remux",
            "480p"
          ],
          other: [
            "Other"
          ]
        }
      }
    },
    Bib: {
      url: " https://bibliotik.me",
      host: "bibliotik.me",
      siteType: "Bib",
      icon: "",
      asSource: false,
      asTarget: true,
      uploadPath: "/upload",
      name: {
        selector: "#TitleField"
      },
      description: {
        selector: "#DescriptionField"
      },
      anonymous: {
        selector: "#AnonymousField"
      },
      image: {
        selector: "#ImageField"
      },
      format: {
        selector: "#FormatField",
        map: {
          epub: "15",
          mobi: "16",
          pdf: "2",
          azw3: "21"
        }
      }
    },
    Blutopia: {
      url: "https://blutopia.cc",
      host: "blutopia.cc",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/torrents/create?category_id=1",
      torrentDownloadLinkSelector: 'a[href*="/torrents/download/"]',
      needDoubanInfo: true,
      seedDomSelector: ".torrent__buttons+.panelV2",
      search: {
        path: "/torrents",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          name: "{name}",
          imdbId: "{imdb}",
          sortField: "size"
        }
      },
      name: {
        selector: 'input[name="name"][class="form__text"]'
      },
      description: {
        selector: "#bbcode-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      anonymous: {
        selector: '.form__group input[type="checkbox"][name="anon"]'
      },
      torrent: {
        selector: 'input[type="file"][accept=".torrent"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      videoType: {
        selector: "#autotype",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "3",
          encode: "12",
          web: "4",
          hdtv: "6",
          dvd: "1",
          dvdrip: "12",
          other: ""
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "4320p": "11",
          "2160p": "1",
          "1080p": "2",
          "1080i": "3",
          "720p": "5",
          "576p": "6",
          "480p": "8"
        }
      }
    },
    CHDBits: {
      url: "https://ptchdbits.co",
      host: "ptchdbits.co",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(6)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: 'textarea[name="descr"]'
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: "#torrent"
      },
      tags: {
        chinese_audio: 'input[name="cnlang"]',
        chinese_subtitle: 'input[name="cnsub"]',
        diy: 'input[name="diy"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "403",
          tvPack: "402",
          documentary: "404",
          cartoon: "405",
          sport: "407",
          concert: "406",
          music: "406"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "5",
          h265: "5",
          x264: "1",
          x265: "5",
          mpeg2: "4",
          mpeg4: "6",
          vc1: "2",
          xvid: "6"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "7",
          dd: "4",
          "dd+": "7",
          flac: "1",
          dts: "3",
          truehd: "11",
          lpcm: "13",
          dtshdma: "10",
          atmos: "10",
          dtsx: "3"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: [
            "19"
          ],
          bluray: [
            "1"
          ],
          remux: [
            "3"
          ],
          encode: [
            "4"
          ],
          web: [
            "18"
          ],
          hdtv: [
            "6"
          ]
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": [
            "6"
          ],
          "1080p": [
            "1"
          ],
          "1080i": [
            "2"
          ],
          "720p": [
            "3"
          ],
          "480p": [
            "5"
          ]
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "8",
          US: "3",
          EU: "7",
          HK: "5",
          TW: "9",
          JP: "4",
          KR: "6",
          OT: "0"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          chdbits: "14",
          sgnb: "13",
          remux: "1",
          chdtv: "2",
          chdpad: "15",
          chdweb: "12",
          chdhktv: "11",
          stbox: "10",
          onehd: "8",
          blucook: "16",
          hqc: "17",
          gbt: "18",
          kan: "19"
        }
      }
    },
    CinemaZ: {
      url: "https://cinemaz.to",
      host: "cinemaz.to",
      siteType: "AvistaZ",
      icon: "",
      asSource: true,
      asTarget: false,
      uploadPath: "/upload.php",
      seedDomSelector: "#content-area .block:last table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="/download/torrent/"]',
      needDoubanInfo: true,
      search: {
        path: "/torrents",
        params: {
          search: "{imdb}",
          in: "1",
          order: "size",
          sort: "desc"
        }
      }
    },
    Cinematik: {
      url: "https://cinematik.net",
      host: "cinematik.net",
      siteType: "Cinematik",
      icon: "",
      asSource: true,
      asTarget: false,
      uploadPath: "/upload.php",
      seedDomSelector: "div.odiv_1 + table >tbody tr:nth-child(3n)",
      needDoubanInfo: true,
      search: {
        path: "/browse.php",
        params: {
          search: "{imdb}",
          cat: 0,
          incldead: 1,
          srchdtls: 1
        }
      }
    },
    Concertos: {
      url: "https://concertos.live",
      host: "concertos.live",
      siteType: "UNIT3D",
      icon: "",
      asSource: false,
      asTarget: true,
      seedDomSelector: "div.torrent > div.buttons.mbox.mbox--small-bottom",
      uploadPath: "/upload",
      needDoubanInfo: false,
      search: {
        path: "/torrents",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          name: "{name}",
          imdb: "{imdb}",
          order_by: "size"
        }
      },
      name: {
        selector: "#title"
      },
      description: {
        selector: "div.sceditor-container textarea"
      },
      imdb: {
        selector: 'input[name="imdb"]'
      },
      tmdb: {
        selector: 'input[name="tmdb"]'
      },
      mediaInfo: {
        selector: "#mediainfo"
      },
      anonymous: {
        selector: 'input[name="anonymous"]'
      },
      category: {
        selector: 'select[name="type_id"]',
        map: {
          BD100: "1",
          BD66: "2",
          UHD50: "3",
          BD50: "4",
          BD25: "5",
          remux: [
            "12",
            "7"
          ],
          encode: [
            "8",
            "10",
            "11",
            "13"
          ],
          web: "9",
          hdtv: "17",
          dvd: [
            "14",
            "16"
          ],
          dvdrip: "13",
          other: ""
        }
      }
    },
    DicMusic: {
      url: "https://dicmusic.com",
      host: "dicmusic.com",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          searchstr: "{name}"
        }
      },
      torrent: {
        selector: "#file"
      }
    },
    DiscFan: {
      url: "https://discfan.net",
      host: "discfan.net",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: 'textarea[name="descr"]'
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_url"]'
      },
      torrent: {
        selector: 'input[type="file"]'
      },
      category: {
        selector: "#browsecat1",
        map: {
          tv: "411",
          tvPack: "411",
          documentary: "413",
          cartoon: "419",
          sport: "417",
          concert: "414",
          variety: "416"
        }
      },
      videoType: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "2",
          bluray: "3",
          remux: "0",
          encode: "10",
          web: "9",
          hdtv: "1",
          dvd: "4",
          hddvd: "4",
          dvdrip: "10",
          other: "0"
        }
      },
      area: {
        selector: "#browsecat",
        map: {
          CN: "401",
          US: "410",
          EU: "410",
          HK: "404",
          TW: "405",
          JP: "403",
          KR: "406"
        }
      }
    },
    EMP: {
      url: "https://www.empornium.is",
      host: "empornium.(is|me|sx)",
      siteType: "gazelle",
      asSource: true,
      asTarget: false,
      uploadPath: "/upload.php"
    },
    FL: {
      url: "https://filelist.io",
      host: "filelist.io",
      siteType: "FL",
      icon: "",
      asSource: false,
      asTarget: false,
      uploadPath: "/upload.php",
      search: {
        path: "/browse.php",
        imdbOptionKey: "3",
        nameOptionKey: "0",
        params: {
          search: "{imdb}",
          searchin: "{optionKey}",
          sort: "3"
        }
      }
    },
    GPW: {
      url: "https://greatposterwall.com",
      host: "greatposterwall.com",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          searchstr: "{imdb}",
          order_by: "size",
          order_way: "desc",
          group_results: 1,
          action: "basic",
          searchsubmit: 1
        }
      },
      needDoubanInfo: true,
      torrent: {
        selector: "#file"
      },
      sourceInfo: {
        editionTags: {
          "10-bit": "10_bit",
          "2D/3D\u7248": "2d_3d_edition",
          "4K\u4FEE\u590D\u7248": "4k_restoration",
          "4K\u91CD\u5236\u7248": "4k_remaster",
          DIY: "diy",
          "DTS:X": "dts_x",
          "HDR10+": "hdr10plus",
          HDR10: "hdr10",
          Remux: "remux",
          Rifftrax: "rifftrax",
          \u534A\u9AD83D: "3d_half_ou",
          \u534A\u5BBD3D: "3d_half_sbs",
          \u6807\u51C6\u6536\u85CF: "the_criterion_collection",
          \u91CD\u5236\u7248: "remaster",
          \u5BFC\u6F14\u526A\u8F91\u7248: "director_s_cut",
          \u7535\u5F71\u5927\u5E08: "masters_of_cinema",
          \u675C\u6BD4\u5168\u666F\u58F0: "dolby_atmos",
          \u675C\u6BD4\u89C6\u754C: "dolby_vision",
          \u989D\u5916\u5185\u5BB9: "extras",
          \u4E8C\u5408\u4E00: "2_in_1",
          \u7EA2\u84DD3D: "3d_anaglyph",
          \u534E\u7EB3\u6863\u6848\u9986: "warner_archive_collection",
          \u52A0\u957F\u7248: "extended_edition",
          \u8BC4\u8BBA\u97F3\u8F68: "with_commentary",
          \u5168\u5BBD3D: "3d_full_sbs",
          \u53CC\u789F\u5957\u88C5: "2_disc_set",
          \u53CC\u97F3\u8F68: "dual_audio",
          \u672A\u5206\u7EA7\u7248: "unrated",
          \u672A\u5220\u51CF\u7248: "uncut",
          \u82F1\u8BED\u914D\u97F3: "english_dub",
          \u5F71\u9662\u7248: "theatrical_cut",
          \u4E2D\u5B57: "chinese_subtitle"
        }
      },
      targetInfo: {
        editionTags: {
          "2_disc_set": "2_disc_set",
          "2d_3d_edition": "2d_3d_edition",
          "2_in_1": "2_in_1",
          "3d": "3d",
          "3d_anaglyph": "3d_anaglyph",
          "3d_full_sbs": "3d_full_sbs",
          "3d_half_ou": "3d_half_ou",
          "3d_half_sbs": "3d_half_sbs",
          "4k_remaster": "4k_remaster",
          "4k_restoration": "4k_restoration",
          director_s_cut: "director_s_cut",
          dual_audio: "dual_audio",
          english_dub: "english_dub",
          extended_edition: "extended_edition",
          extras: "extras",
          masters_of_cinema: "masters_of_cinema",
          scene: null,
          the_criterion_collection: "the_criterion_collection",
          theatrical_cut: "theatrical_cut",
          two_disc_set: "2_disc_set",
          remux: null,
          rifftrax: "rifftrax",
          uncut: "uncut",
          unrated: "unrated",
          warner_archive_collection: "warner_archive_collection",
          with_commentary: "with_commentary"
        }
      },
      description: {
        selector: "#release_desc"
      },
      imdb: {
        selector: "#imdb"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo[]"]'
      },
      category: {
        selector: "#releasetype",
        map: {
          movie: "1",
          tv: "3",
          tvPack: "3",
          concert: "5"
        }
      },
      source: {
        selector: "#source",
        map: {
          uhdbluray: "Blu-ray",
          bluray: "Blu-ray",
          web: "WEB",
          hdtv: "HDTV",
          hddvd: "HD-DVD",
          dvd: "DVD",
          other: "Other"
        }
      },
      videoCodec: {
        selector: "#codec",
        map: {
          h264: "H.264",
          hevc: "H.265",
          x264: "x264",
          x265: "x265",
          h265: "H.265",
          mpeg2: "Other",
          mpeg4: "H.264",
          vc1: "Other",
          xvid: "xvid"
        }
      },
      resolution: {
        selector: "#resolution",
        map: {
          NTSC: "NTSC",
          PAL: "PAL",
          "2160p": "2160p",
          "1080p": "1080p",
          "1080i": "1080i",
          "720p": "720p",
          "576p": "576p",
          "480p": "480p"
        }
      },
      format: {
        selector: "#container",
        map: {
          mkv: "MKV",
          mp4: "MP4",
          avi: "AVI",
          ts: "TS",
          wmv: "WMV",
          vob: "VOB IFO",
          iso: "ISO",
          mpg: "MPG",
          m2ts: "m2ts"
        }
      },
      videoType: {
        selector: "#processing",
        map: {
          encode: "Encode",
          remux: "Remux",
          DIY: "DIY",
          bluray: "Untouched",
          uhdbluray: "Untouched",
          dvd: "Untouched",
          dvdrip: "Encode"
        }
      }
    },
    HD4FANS: {
      url: "https://pt.hd4fans.org",
      host: "hd4fans.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "403",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "405"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "1",
          hddvd: "2",
          remux: "3",
          encode: "7",
          web: "7",
          hdtv: "5",
          dvd: "6",
          dvdrip: "6",
          other: ""
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "10",
          x264: "1",
          x265: "10",
          h265: "10",
          mpeg2: "4",
          mpeg4: "5",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          chd: "2",
          mysilu: "3",
          wiki: "4",
          other: "5",
          cmct: "6",
          r2ts: "7",
          kbits: "8"
        }
      }
    },
    HDArea: {
      url: "https://hdarea.club",
      host: "hdarea.club",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="dburl"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: [
            "300",
            "401",
            "415",
            "416",
            "410",
            "411",
            "414",
            "412",
            "413",
            "417"
          ],
          tv: [
            "402",
            "403"
          ],
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "7",
          x264: "7",
          hevc: "6",
          x265: "6",
          h265: "6",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "0",
          dvd: "0"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "11",
          dd: "5",
          "dd+": "4",
          flac: "1",
          dts: "3",
          truehd: "7",
          lpcm: "8",
          dtshdma: "4",
          atmos: "10",
          dtsx: "0"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: [
            "1",
            "300"
          ],
          bluray: [
            "1",
            "401"
          ],
          remux: [
            "3",
            "415"
          ],
          encode: "7",
          web: [
            "9",
            "412"
          ],
          hdtv: [
            "5",
            "413"
          ],
          dvd: [
            "2",
            "414"
          ],
          dvdrip: "6",
          other: "0"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "5",
          "1080p": [
            "1",
            "410"
          ],
          "1080i": "2",
          "720p": [
            "3",
            "411"
          ],
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          epic: "1",
          hdarea: "2",
          hdwing: "3",
          wiki: "4",
          ttg: "5",
          other: "6",
          mteam: "7",
          hdapad: "8",
          chd: "9",
          hdaccess: "10",
          hdatv: "11",
          cxcy: "12",
          cmct: "13"
        }
      }
    },
    HDAtmos: {
      url: "https://hdatmos.club",
      host: "hdatmos.club",
      siteType: "NexusPHP",
      icon: "",
      asSource: false,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: 'textarea[name="descr"]'
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          cartoon: "405",
          sport: "407",
          concert: "406"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "10",
          h265: "10",
          x264: "1",
          x265: "10",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "3"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "20",
          ac3: "22",
          dd: "23",
          "dd+": "23",
          flac: "17",
          dts: "14",
          truehd: "13",
          lpcm: "15",
          dtshdma: "10",
          atmos: "11",
          dtsx: "12"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "10",
          hdtv: "5",
          dvd: "6",
          hddvd: "2",
          dvdrip: "13",
          other: "13"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "15",
          "2160p": "10",
          "1080p": "11",
          "1080i": "12",
          "720p": "13",
          "576p": "14",
          "480p": "14"
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "3",
          US: "4",
          EU: "8",
          HK: "5",
          TW: "3",
          JP: "5",
          KR: "6",
          OT: "9"
        }
      },
      source: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "6",
          bluray: "6",
          hdtv: "3",
          dvd: "8",
          web: "2",
          vhs: "12",
          hddvd: "7"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          other: "22"
        }
      }
    },
    HDBits: {
      url: "https://hdbits.org",
      host: "hdbits.org",
      siteType: "HDB",
      icon: "",
      asSource: true,
      asTarget: true,
      needDoubanInfo: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#details >tbody >tr:contains(Last seeded)",
      torrentDownloadLinkSelector: 'a[href*="download.php/"]',
      search: {
        path: "/browse.php",
        params: {
          sort: "size",
          d: "DESC",
          search: "{imdb}"
        }
      },
      name: {
        selector: "#name"
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: "#imdb"
      },
      mediaInfo: {
        selector: 'textarea[name="techinfo"]'
      },
      torrent: {
        selector: "#file"
      },
      category: {
        selector: "#type_category",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2",
          documentary: "3",
          concert: "4",
          sport: "5",
          cartoon: "1"
        }
      },
      videoCodec: {
        selector: "#type_codec",
        map: {
          h264: "1",
          h265: "5",
          hevc: "5",
          x264: "1",
          x265: "5",
          mpeg2: "2",
          vc1: "3",
          xvid: "4",
          bluray: "1",
          uhdbluray: "5",
          vp9: "6"
        }
      },
      videoType: {
        selector: "#type_medium",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "5",
          encode: "3",
          web: "6",
          hdtv: "4"
        }
      }
    },
    HDChina: {
      url: "https://hdchina.org",
      host: "hdchina.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: ".table_details>tbody>tr:nth-child(1)",
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrent_list>tbody>tr",
          url: '.tbname td a[href*="details.php?id="]',
          name: '.tbname td a[href*="details.php?id="]',
          size: ".t_size"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      poster: "#cover",
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_id"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: [
            "20",
            "17",
            "16",
            "9",
            "410",
            "27"
          ],
          tv: [
            "13",
            "25",
            "26",
            "24",
            "27"
          ],
          tvPack: [
            "20",
            "21",
            "22",
            "23",
            "27"
          ],
          documentary: [
            "20",
            "5",
            "27"
          ],
          concert: "402",
          sport: "15",
          cartoon: "14",
          variety: "401",
          music: "408",
          ebook: "404",
          other: "409"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "10",
          x264: "6",
          x265: "10",
          h265: "10",
          mpeg2: "4",
          mpeg4: [
            "1",
            "27"
          ],
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "8",
          dd: "8",
          "dd+": "8",
          dts: "3",
          truehd: "13",
          lpcm: "11",
          dtshdma: "12",
          atmos: "15",
          dtsx: "14",
          flac: "1"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: [
            "11",
            "20",
            "410"
          ],
          bluray: [
            "11",
            "20"
          ],
          remux: "6",
          encode: "5",
          web: "21",
          hdtv: "13",
          dvd: "14",
          dvdrip: "4",
          other: "15"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": [
            "17",
            "13",
            "25",
            "26",
            "24",
            "21",
            "22",
            "23",
            "410"
          ],
          "1080p": [
            "11",
            "17",
            "13",
            "25",
            "26",
            "24",
            "21",
            "22",
            "23"
          ],
          "1080i": [
            "12",
            "16",
            "13",
            "25",
            "26",
            "24",
            "21",
            "22",
            "23"
          ],
          "720p": [
            "13",
            "9",
            "13",
            "25",
            "26",
            "24",
            "21",
            "22",
            "23"
          ],
          "576p": "15",
          "480p": "15"
        }
      },
      area: {
        map: {
          CN: [
            "25",
            "22"
          ],
          US: [
            "13",
            "21"
          ],
          EU: [
            "13",
            "21"
          ],
          HK: [
            "25",
            "22"
          ],
          TW: [
            "25",
            "22"
          ],
          JP: [
            "24",
            "23"
          ],
          KR: [
            "26",
            "23"
          ]
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          hdchina: "15",
          hdctv: "16",
          ihd: "12",
          hdwing: "10",
          hdwtv: "11",
          kishd: "17",
          openmv: "7",
          hdc: "22",
          diy: "23",
          khq: "6",
          exren: "30",
          joma: "26",
          anonymous: "25",
          crss: "24",
          ebp: "18",
          don: "19",
          esir: "20",
          trollhd: "29",
          wiki: "9",
          beast: "4",
          cmct: "2",
          ngb: "8",
          lu9998: "21",
          taichi: "28",
          u2: "27",
          enichi: "31",
          arey: "32",
          other: "5"
        }
      }
    },
    HDDolby: {
      url: "https://www.hddolby.com",
      host: "hddolby.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_id"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: "#tag_gy",
        diy: "#tag_diy",
        chinese_subtitle: "#tag_zz",
        cantonese_audio: "#tag_yy",
        hdr: "#tag_hdr10",
        hdr10_plus: "#tag_hdrm",
        dolby_vision: "#tag_db"
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          x264: "3",
          hevc: "2",
          x265: "4",
          h265: "2",
          mpeg2: "6",
          mpeg4: "0",
          vc1: "5",
          xvid: "0",
          dvd: "0"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "2",
          remux: "3",
          encode: "10",
          web: "6",
          hdtv: "5",
          dvd: "8",
          dvdrip: "8",
          other: "0"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "5",
          dd: "5",
          "dd+": "14",
          flac: "7",
          dts: "4",
          truehd: "2",
          lpcm: "3",
          dtshdma: "1",
          atmos: "2",
          dtsx: "1"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "1",
          "1080p": "2",
          "1080i": "3",
          "720p": "4",
          "576p": "5",
          "480p": "5"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          dream: "1",
          hdo: "9",
          dbtv: "10",
          nazorip: "12",
          mteam: "2",
          frds: "7",
          wiki: "4",
          beast: "11",
          chd: "5",
          cmct: "6",
          pthome: "3",
          other: "8"
        }
      }
    },
    HDF: {
      url: "https://hdf.world",
      host: "hdf.world",
      siteType: "gazelle",
      icon: "",
      asSource: false,
      asTarget: false,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          order_way: "desc",
          order_by: "time",
          searchstr: "{name}",
          group_results: "1",
          action: "basic"
        }
      }
    },
    HDFans: {
      url: "https://hdfans.org",
      host: "hdfans.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~font table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "403",
          concert: "441",
          sport: "418",
          cartoon: "417",
          variety: "416",
          app: "419",
          ebook: "423",
          audioBook: "405"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "3",
          x264: "2",
          x265: "4",
          h265: "3",
          mpeg2: "10",
          mpeg4: "11",
          vc1: "5",
          xvid: "12"
        }
      },
      source: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "2",
          hdtv: "6",
          dvd: "7",
          web: "5",
          vhs: "10",
          hddvd: "17",
          cd: "9",
          sacd: "16"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "11",
          ac3: "10",
          dd: "21",
          "dd+": "21",
          flac: "12",
          dts: "2",
          truehd: "6",
          lpcm: "7",
          dtshdma: "4",
          atmos: "1",
          dtsx: "3",
          ape: "13",
          wav: "14",
          mp3: "17",
          m4a: "5",
          other: "7"
        }
      },
      videoType: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "3",
          remux: "10",
          encode: "9",
          web: "7",
          hdtv: "6",
          dvd: "17",
          dvdrip: "17",
          other: "10"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "1",
          "2160p": [
            "2",
            "10",
            "9"
          ],
          "1080p": [
            "3",
            "5",
            "8"
          ],
          "1080i": [
            "4",
            "5",
            "8"
          ],
          "720p": [
            "5",
            "11"
          ],
          "576p": "6",
          "480p": "6"
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "1",
          US: "2",
          EU: "8",
          HK: "4",
          TW: "5",
          JP: "6",
          KR: "7",
          OT: "9"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          hdfans: "9",
          hdf: "10",
          chd: "1",
          hdc: "2",
          ttg: "19",
          wiki: "3",
          beast: "4",
          cmct: "5",
          frds: "6",
          hdsky: "7",
          ourbits: "17",
          hdhome: "18",
          pthome: "16",
          tlf: "8",
          pter: "20",
          pbk: "21"
        }
      }
    },
    HDHome: {
      url: "https://hdhome.org",
      host: "hdhome.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_id"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: "#torrent"
      },
      tags: {
        chinese_audio: "#tag_gy",
        diy: "#tag_diy",
        cantonese_audio: "#tag_yy",
        chinese_subtitle: "#tag_zz",
        hdr: "#tag_hdr10",
        hdr10_plus: "#tag_hdrm",
        dolby_vision: "#tag_db"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: [
            "411",
            "412",
            "413",
            "414",
            "415",
            "450",
            "499",
            "416"
          ],
          tv: [
            "425",
            "426",
            "471",
            "427",
            "428",
            "429",
            "430",
            "452",
            "431"
          ],
          tvPack: [
            "432",
            "433",
            "434",
            "435",
            "436",
            "437",
            "438",
            "502"
          ],
          documentary: [
            "417",
            "418",
            "419",
            "420",
            "421",
            "451",
            "500",
            "422"
          ],
          concert: "441",
          sport: [
            "442",
            "443"
          ],
          cartoon: [
            "444",
            "445",
            "446",
            "447",
            "448",
            "454",
            "449",
            "501"
          ],
          variety: ""
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "12",
          x264: "1",
          x265: "2",
          h265: "2",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "3",
          xvid: "5",
          dvd: "5"
        }
      },
      source: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "9",
          bluray: "1",
          hdtv: "4",
          dvd: "3",
          web: "7",
          vhs: "8",
          hddvd: "8"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "15",
          dd: "15",
          "dd+": "15",
          dts: "3",
          truehd: "13",
          lpcm: "14",
          dtshdma: "11",
          atmos: "12",
          dtsx: "17"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: [
            "10",
            "499",
            "500",
            "502",
            "501"
          ],
          bluray: [
            "1",
            "450",
            "451",
            "452",
            "453",
            "454"
          ],
          remux: [
            "3",
            "415",
            "421",
            "430",
            "437",
            "448"
          ],
          encode: [
            "7",
            "411",
            "412",
            "413",
            "414",
            "416",
            "417",
            "418",
            "419",
            "420",
            "422",
            "425",
            "426",
            "471",
            "427",
            "428",
            "429",
            "431",
            "432",
            "433",
            "434",
            "435",
            "436",
            "438",
            "444",
            "445",
            "446",
            "447",
            "449"
          ],
          web: [
            "11",
            "411",
            "412",
            "413",
            "414",
            "416",
            "417",
            "418",
            "419",
            "420",
            "422",
            "425",
            "426",
            "471",
            "427",
            "429",
            "431",
            "432",
            "433",
            "434",
            "436",
            "438",
            "444",
            "445",
            "446",
            "447",
            "449"
          ],
          hdtv: [
            "5",
            "412",
            "413",
            "416",
            "418",
            "419",
            "422",
            "424",
            "426",
            "471",
            "427",
            "428",
            "431",
            "433",
            "434",
            "435",
            "438",
            "442",
            "443",
            "445",
            "446",
            "449"
          ],
          dvd: [
            "",
            "411",
            "417",
            "425",
            "432",
            "444"
          ],
          dvdrip: [
            "7",
            "411",
            "417",
            "425",
            "432",
            "444"
          ],
          other: ""
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": [
            "1",
            "499",
            "416",
            "500",
            "422",
            "431",
            "438",
            "502",
            "449",
            "501"
          ],
          "1080p": [
            "2",
            "414",
            "420",
            "429",
            "436",
            "447"
          ],
          "1080i": [
            "3",
            "424",
            "428",
            "435",
            "443"
          ],
          "720p": [
            "4",
            "413",
            "419",
            "423",
            "427",
            "434",
            "442",
            "446"
          ],
          "576p": [
            "5",
            "411",
            "417",
            "425",
            "432",
            "444"
          ],
          "480p": [
            "5",
            "411",
            "417",
            "425",
            "432",
            "444"
          ]
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          "3201": "20",
          "969154968": "22",
          hdhome: "1",
          hdh: "2",
          hdhtv: "3",
          hdhpad: "4",
          hdhweb: "12",
          shma: "17",
          tvman: "21",
          arin: "19",
          ttg: "6",
          mteam: "7",
          other: "11"
        }
      }
    },
    HDPOST: {
      url: "https://pt.hdpost.top",
      host: "hdpost.top",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload/1",
      needDoubanInfo: true,
      seedDomSelector: '#meta-info+.meta-general>.panel:has(".table-responsive"):first table tr:last',
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents",
        params: {
          name: "{name}",
          imdb: "{imdb}"
        }
      },
      name: {
        selector: "#title"
      },
      description: {
        selector: "#bbcode-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      anonymous: {
        selector: '.form__group input[type="checkbox"][name="anonymous"]'
      },
      torrent: {
        selector: "#torrent"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      videoType: {
        selector: "#autotype",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "2",
          encode: "3",
          web: "4",
          hdtv: "6",
          dvd: "1",
          dvdrip: "12",
          other: ""
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "4320p": "1",
          "2160p": "2",
          "1080p": "3",
          "1080i": "4",
          "720p": "5",
          "576p": "6",
          "480p": "8"
        }
      }
    },
    HDRoute: {
      url: "http://hdroute.org",
      host: "hdroute.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: false,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/browse.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          s: "{name}",
          dp: "0",
          add: "0",
          action: "s",
          or: "4",
          imdb: "{imdb}"
        }
      },
      name: {
        selector: "#title_eng"
      },
      subtitle: {
        selector: 'input[name="title_sub"]'
      },
      description: {
        selector: 'textarea[name="description"]'
      },
      poster: 'input[name="poster_big"]',
      imdb: {
        selector: "#upload-imdb_url"
      },
      anonymous: {
        selector: 'input[name="is_anonymous"]'
      },
      torrent: {
        selector: "#file_torrent"
      },
      tags: {
        chinese_audio: 'input[name="is_mandrain"]',
        cantonese_audio: 'input[name="is_cantonese"]',
        diy: 'input[name="is_diyed"]',
        chinese_subtitle: 'input[name="is_chs_sub_incl"]'
      },
      category: {
        selector: "#type_category",
        map: {
          movie: "1",
          tv: "3",
          tvPack: "3",
          documentary: "2",
          concert: "5",
          sport: "6",
          cartoon: "4",
          variety: "9"
        }
      },
      videoCodec: {
        selector: "#type_codec",
        map: {
          h264: "1",
          hevc: "7",
          x264: "1",
          x265: "7",
          h265: "7",
          mpeg2: "3",
          mpeg4: "1",
          vc1: "2",
          xvid: "4",
          dvd: "3"
        }
      },
      audioCodec: {
        selector: "#type_audio",
        map: {
          aac: "9",
          ac3: "5",
          dd: "5",
          "dd+": "5",
          flac: "7",
          dts: "4",
          truehd: "3",
          lpcm: "1",
          dtshdma: "2",
          atmos: "2",
          dtsx: "4"
        }
      },
      videoType: {
        selector: "#type_medium",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "2",
          encode: "4",
          web: "6",
          hddvd: "6",
          hdtv: "3",
          dvd: "6",
          dvdrip: "6",
          other: "6"
        }
      },
      resolution: {
        selector: "#type_resolution",
        map: {
          "2160p": "7",
          "1080p": "1",
          "1080i": "2",
          "720p": "4",
          "576p": "6",
          "480p": "6"
        }
      }
    },
    HDSpace: {
      url: "https://hd-space.org",
      host: "hd-space.org",
      siteType: "HDSpace",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#mcol>table>tbody>tr:last table:first>tbody>tr:nth-child(2)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      needDoubanInfo: true,
      uploadPath: "/index.php?page=upload",
      search: {
        path: "/index.php",
        imdbOptionKey: "2",
        nameOptionKey: "0",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          search: "{imdb}",
          page: "torrents",
          options: "{optionKey}",
          order: 4,
          by: 2
        }
      },
      name: {
        selector: "#filename"
      },
      imdb: {
        selector: 'input[name="imdb"]'
      },
      description: {
        selector: 'textarea[name="info"]'
      },
      anonymous: {
        selector: 'input[name="anonymous"][value="true"]'
      },
      torrent: {
        selector: 'input[type="file"][name="torrent"]'
      },
      category: {
        selector: 'select[name="category"]',
        map: {
          movie: [
            "15",
            "40",
            "16",
            "18",
            "19",
            "41"
          ],
          tv: [
            "15",
            "40",
            "16",
            "21",
            "22"
          ],
          tvPack: [
            "15",
            "40",
            "16",
            "21",
            "22"
          ],
          documentary: [
            "15",
            "40",
            "16",
            "24",
            "25"
          ],
          cartoon: [
            "15",
            "40",
            "16",
            "27",
            "28"
          ],
          concert: [
            "15",
            "40",
            "16",
            "31"
          ]
        }
      },
      videoType: {
        map: {
          uhdbluray: [
            "15"
          ],
          bluray: [
            "15"
          ],
          remux: [
            "40"
          ],
          encode: [
            "18",
            "19",
            "41",
            "21",
            "22",
            "24",
            "25",
            "27",
            "28",
            "31"
          ],
          web: [
            "18",
            "19",
            "41",
            "21",
            "22",
            "24",
            "25",
            "27",
            "28",
            "31"
          ],
          hdtv: [
            "18",
            "19",
            "41",
            "21",
            "22",
            "24",
            "25",
            "27",
            "28",
            "31"
          ]
        }
      },
      resolution: {
        map: {
          "2160p": [
            "15",
            "40",
            "16",
            "41"
          ],
          "1080p": [
            "19",
            "22",
            "25",
            "28",
            "31"
          ],
          "1080i": [
            "19",
            "22",
            "25",
            "28",
            "31"
          ],
          "720p": [
            "18",
            "21",
            "24",
            "24",
            "31"
          ]
        }
      }
    },
    HDT: {
      url: "https://hd-torrents.org",
      host: "hd-torrents.org",
      siteType: "HDT",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: ".listadetails>tbody>tr:nth-child(2)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      needDoubanInfo: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "2",
        nameOptionKey: "3",
        params: {
          search: "{imdb}",
          options: "{optionKey}",
          order: "size",
          by: "DESC"
        }
      },
      name: {
        selector: 'input[name="filename"]'
      },
      imdb: {
        selector: 'input[name="infosite"]'
      },
      description: {
        selector: 'textarea[name="info"]'
      },
      tags: {
        hdr: 'input[name="HDR10"]',
        hdr10_plus: 'input[name="HDR10Plus"]',
        dolby_vision: 'input[name="DolbyVision"]'
      },
      anonymous: {
        selector: 'input[name="anonymous"][value="true"]'
      },
      torrent: {
        selector: 'input[name="torrent"]'
      },
      category: {
        selector: 'select[name="category"]',
        map: {
          movie: [
            "70",
            "1",
            "71",
            "2",
            "64",
            "5",
            "3",
            "63"
          ],
          tv: [
            "72",
            "59",
            "73",
            "60",
            "65",
            "30",
            "38"
          ],
          tvPack: [
            "72",
            "59",
            "73",
            "60",
            "65",
            "30",
            "38"
          ],
          documentary: [
            "70",
            "1",
            "71",
            "2",
            "64",
            "5",
            "3",
            "63"
          ],
          cartoon: [
            "70",
            "1",
            "71",
            "2",
            "64",
            "5",
            "3",
            "63"
          ],
          concert: [
            "61",
            "62",
            "66",
            "57",
            "45",
            "44"
          ],
          variety: [
            "72",
            "59",
            "73",
            "60",
            "65",
            "30",
            "38"
          ]
        }
      },
      videoType: {
        map: {
          uhdbluray: [
            "70",
            "72"
          ],
          bluray: [
            "1",
            "59",
            "61"
          ],
          remux: [
            "71",
            "2",
            "62",
            "73",
            "60"
          ],
          encode: [
            "64",
            "5",
            "3",
            "65",
            "30",
            "38",
            "66",
            "57",
            "45"
          ],
          web: [
            "64",
            "5",
            "3",
            "65",
            "30",
            "38",
            "66",
            "57",
            "45"
          ],
          hdtv: [
            "64",
            "5",
            "3",
            "65",
            "30",
            "38",
            "66",
            "57",
            "45"
          ]
        }
      },
      resolution: {
        map: {
          "2160p": [
            "70",
            "72",
            "71",
            "73",
            "64",
            "65",
            "66"
          ],
          "1080p": [
            "1",
            "59",
            "61",
            "2",
            "60",
            "62",
            "5",
            "30",
            "57"
          ],
          "1080i": [
            "1",
            "59",
            "61",
            "2",
            "60",
            "62",
            "5",
            "30",
            "57"
          ],
          "720p": [
            "3",
            "38",
            "45"
          ]
        }
      }
    },
    HDTime: {
      url: "https://hdtime.org",
      host: "hdtime.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      mediaInfo: {
        selector: 'textarea[name="technical_info"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        diy: 'input[type="checkbox"][name="tags[]"][value="8"]',
        chinese_audio: 'input[type="checkbox"][name="tags[]"][value="16"]',
        chinese_subtitle: 'input[type="checkbox"][name="tags[]"][value="32"]',
        hdr: 'input[type="checkbox"][name="tags[]"][value="64"]',
        hdr10_plus: 'input[type="checkbox"][name="tags[]"][value="64"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "12",
          x264: "10",
          x265: "12",
          h265: "12",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1 ",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "7",
          hddvd: "2",
          hdtv: "5",
          dvd: "6",
          dvdrip: "6",
          other: "0"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          hdtime: "6",
          hdt: "12",
          vtime: "15",
          padtime: "7",
          cmct: "8",
          wiki: "4",
          beast: "3",
          chd: "2",
          other: "5"
        }
      }
    },
    HDU: {
      url: "https://pt.hdupt.com",
      host: "hdupt.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "14",
          x264: "16",
          x265: "14",
          h265: "14",
          mpeg2: "18",
          mpeg4: "18",
          vc1: "2",
          xvid: "3",
          dvd: "18"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "2",
          dd: "2",
          "dd+": "2",
          flac: "7",
          dts: "4",
          truehd: "3",
          lpcm: "11",
          dtshdma: "1",
          atmos: "17",
          dtsx: "16"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "11",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "10",
          hddvd: "2",
          hdtv: "5",
          dvd: "6",
          dvdrip: "6",
          other: "0"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "1",
          US: "2",
          EU: "2",
          HK: "3",
          TW: "3",
          JP: "4",
          KR: "5",
          IND: "6",
          SEA: "8",
          OT: "7"
        }
      }
    },
    HH: {
      url: "https://hhanclub.top",
      host: "hhanclub.top",
      siteType: "HanHan",
      icon: "",
      asSource: true,
      asTarget: false,
      uploadPath: "/upload.php",
      needDoubanInfo: true,
      seedDomSelector: ".bg-content_bg div.leading-6:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrenttable>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      }
    },
    HaresClub: {
      url: "https://club.hares.top",
      host: "hares.top",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~.layui-row:first table:first>tbody>tr:nth-child(6)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          search_mode: "0"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="pt_gen[imdb][link]"]'
      },
      douban: {
        selector: 'input[name="pt_gen[douban][link]"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: "#torrent"
      },
      mediaInfo: {
        selector: 'textarea[name="technical_info"]'
      },
      screenshots: {
        selector: 'textarea[name="screenshots"]'
      },
      tags: {
        chinese_audio: 'input[name="tags[]"][value="32"]',
        cantonese_audio: 'input[name="tags[]"][value="64"]',
        diy: 'input[name="tags[]"][value="1024"]',
        hdr: 'input[name="tags[]"][value="4096"]',
        hdr10_plus: 'input[name="tags[]"][value="8192"]',
        dolby_vision: 'input[name="tags[]"][value="16384"]',
        chinese_subtitle: 'input[name="tags[]"][value="256"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "409",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "6",
          x264: "8",
          x265: "7",
          h265: "6",
          mpeg2: "4",
          mpeg4: "9",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "13",
          dd: "13",
          mp3: "4",
          "dd+": "13",
          flac: "1",
          dts: "3",
          truehd: "9",
          lpcm: "14",
          dtshdma: "11",
          atmos: "8",
          dtsx: "10",
          ape: "2",
          ogg: "5",
          wav: "15"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "2",
          bluray: "2",
          remux: "3",
          encode: "4",
          web: "5",
          hdtv: "8",
          dvd: "0",
          dvdrip: "0",
          other: "0"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "5",
          "2160p": "6",
          "1080p": "1",
          "1080i": "2",
          "720p": "3"
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "1",
          US: "4",
          EU: "4",
          HK: "2",
          TW: "3",
          JP: "7",
          KR: "7",
          OT: "10"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          chd: "4",
          hds: "5",
          wiki: "6",
          cmct: "8",
          beast: "9",
          hdc: "10",
          frds: "11",
          pter: "12",
          bhd: "13",
          pth: "14",
          other: "15"
        }
      }
    },
    KEEPFRDS: {
      url: "https://pt.keepfrds.com",
      host: "keepfrds.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      needDoubanInfo: true,
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      name: {
        selector: 'input[name="small_descr"]'
      },
      subtitle: {
        selector: "#name"
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_url"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "408",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      source: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "10",
          bluray: "1",
          hdtv: "4",
          dvd: "3",
          web: "7",
          vhs: "8",
          hddvd: "8"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "3",
          hevc: "0",
          x264: "3",
          x265: "0",
          h265: "0",
          mpeg2: "17",
          mpeg4: "1",
          vc1: "16",
          xvid: "5"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "0",
          "2160p": "7",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "5",
          "480p": "5"
        }
      }
    },
    KG: {
      url: "https://karagarga.in",
      host: "karagarga.in",
      siteType: "KG",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: ".outer h1~table:first>tbody>tr:nth-child(6)",
      torrentDownloadLinkSelector: 'a[href*="/down.php/"]',
      needDoubanInfo: true,
      search: {
        path: "/browse.php",
        imdbOptionKey: "imdb",
        nameOptionKey: "title",
        params: {
          search: "{imdb}",
          search_type: "{optionKey}",
          sort: "size",
          d: "DESC"
        }
      },
      source: {
        selector: "select[name='source']",
        map: {
          uhdbluray: "Blu-ray",
          bluray: "Blu-ray",
          hdtv: "TV",
          dvd: "DVD",
          web: "WEB",
          vhs: "VHS",
          hddvd: "HD-DVD",
          other: "Other"
        }
      },
      resolution: {
        selector: "select[name='hdrip']",
        map: {
          "720p": "1",
          "1080p": "2",
          bluray: "3"
        }
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      genres: {
        map: {
          Action: "4",
          Adventure: "55",
          Animation: "5",
          Arthouse: "6",
          Camp: "43",
          Classics: "8",
          Comedy: "9",
          Crime: "10",
          Cult: "11",
          Documentary: "20",
          Drama: "12",
          Epic: "44",
          Erotica: "13",
          Experimental: "51",
          Exploitation: "47",
          Fantasy: "14",
          "Film Noir": "15",
          Giallo: "53",
          Horror: "17",
          "Martial Arts": "18",
          Musical: "19",
          Mystery: "54",
          Performance: "60",
          Philosophy: "48",
          Politics: "49",
          Romance: "50",
          "Sci-Fi": "21",
          Short: "22",
          Silent: "23",
          Thriller: "24",
          TV: "25",
          "Video Art": "56",
          War: "26",
          Western: "27"
        }
      },
      country: {
        map: {
          USA: "2",
          UK: "12",
          Germany: "7",
          Italy: "9",
          "---": "255",
          Abkhazia: "119",
          Afghanistan: "54",
          "Akrotiri and Dhekelia": "120",
          "Aland Islands": "121",
          Albania: "65",
          Algeria: "35",
          "American Samoa": "122",
          Andorra: "68",
          Angola: "36",
          Anguilla: "123",
          "Antigua Barbuda": "89",
          Argentina: "19",
          Armenia: "124",
          Aruba: "125",
          "Ascension Island": "126",
          Australia: "20",
          Austria: "37",
          Azerbaijan: "118",
          Bahamas: "82",
          Bahrain: "127",
          Bangladesh: "86",
          Barbados: "85",
          Belarus: "129",
          Belgium: "16",
          Belize: "34",
          Benin: "116",
          Bermuda: "130",
          Bhutan: "131",
          Bolivia: "132",
          "Bosnia Herzegovina": "67",
          Botswana: "133",
          Brazil: "18",
          "British Virgin Islands": "134",
          Brunei: "135",
          Bulgaria: "104",
          "Burkina Faso": "60",
          Burundi: "136",
          Cambodia: "84",
          Cameroon: "137",
          Canada: "5",
          "Cape Verde": "138",
          "Cayman Islands": "139",
          "Central African Republic": "140",
          Chad: "114",
          Chile: "51",
          China: "8",
          "Christmas Island": "141",
          "Cocos (Keeling) Islands": "142",
          Colombia: "99",
          Comoros: "143",
          "Congo (Brazzaville)": "53",
          "Congo-Kinshasa (Zaire)": "252",
          "Cook Islands": "144",
          "Costa Rica": "102",
          "Cote d'Ivoire": "145",
          Croatia: "97",
          Cuba: "52",
          Cyprus: "146",
          "Czech Republic": "46",
          Denmark: "10",
          Djibouti: "147",
          Dominica: "148",
          "Dominican Republic": "41",
          Ecuador: "81",
          Egypt: "103",
          "El Salvador": "149",
          "Equatorial Guinea": "150",
          Eritrea: "151",
          Estonia: "98",
          Ethiopia: "112",
          "European Union": "253",
          "Falkland Islands": "153",
          "Faroe Islands": "111",
          Fiji: "152",
          Finland: "4",
          France: "6",
          "French Polynesia": "154",
          Gabon: "155",
          Gambia: "156",
          Georgia: "108",
          Ghana: "157",
          Gibraltar: "158",
          Greece: "42",
          Greenland: "159",
          Grenada: "160",
          Guam: "161",
          Guatemala: "43",
          Guernsey: "162",
          Guinea: "113",
          "Guinea-Bissau": "163",
          Guyana: "164",
          Haiti: "165",
          Honduras: "79",
          "Hong Kong": "33",
          Hungary: "74",
          Iceland: "62",
          India: "70",
          Indonesia: "166",
          Iran: "107",
          Iraq: "167",
          Ireland: "13",
          "Isla de Muerte": "105",
          "Isle of Man": "168",
          Israel: "44",
          Jamaica: "31",
          Japan: "17",
          Jersey: "170",
          Jordan: "169",
          Kazakhstan: "110",
          Kenya: "172",
          Kiribati: "58",
          Kosovo: "173",
          Kuwait: "171",
          Kyrgyzstan: "80",
          Laos: "87",
          Latvia: "101",
          Lebanon: "100",
          Lesotho: "174",
          Liberia: "175",
          Libya: "176",
          Liechtenstein: "177",
          Lithuania: "69",
          Luxembourg: "32",
          Macau: "178",
          Macedonia: "179",
          Madagascar: "180",
          Malawi: "181",
          Malaysia: "40",
          Maldives: "182",
          Mali: "115",
          Malta: "183",
          "Marshall Islands": "184",
          Mauritania: "185",
          Mauritius: "186",
          Mayotte: "187",
          Mexico: "25",
          Micronesia: "188",
          Moldova: "189",
          Monaco: "190",
          Mongolia: "109",
          Montenegro: "257",
          Montserrat: "191",
          Morocco: "192",
          Mozambique: "193",
          Myanmar: "194",
          "Nagorno-Karabakh": "195",
          Namibia: "196",
          Nauru: "63",
          Nepal: "197",
          Netherlands: "15",
          "Netherlands Antilles": "71",
          "New Caledonia": "198",
          "New Zealand": "21",
          Nicaragua: "199",
          Niger: "200",
          Nigeria: "61",
          Niue: "201",
          "Norfolk Island": "202",
          "North Korea": "96",
          "Northern Cyprus": "203",
          "Northern Mariana Islands": "204",
          Norway: "11",
          Oman: "205",
          Pakistan: "45",
          Palau: "207",
          Palestine: "208",
          Panama: "206",
          "Papua New Guinea": "209",
          Paraguay: "90",
          Peru: "83",
          Philippines: "59",
          "Pitcairn Islands": "210",
          Poland: "14",
          Portugal: "24",
          "Puerto Rico": "50",
          Qatar: "211",
          Romania: "75",
          Russia: "3",
          Rwanda: "212",
          "Saint Helena": "213",
          "Saint Kitts and Nevis": "214",
          "Saint Lucia": "215",
          "Saint Vincent and the Grenadines": "217",
          "Saint-Pierre and Miquelon": "216",
          Samoa: "39",
          "San Marino": "219",
          "S\xE3o Tom\xE9 and Pr\xEDncipe": "220",
          "Saudi Arabia": "221",
          Sealand: "258",
          Senegal: "94",
          Serbia: "256",
          "Serbia and Montenegro": "47",
          Seychelles: "48",
          "Sierra Leone": "222",
          Singapore: "26",
          Slovakia: "223",
          Slovenia: "64",
          "Solomon Islands": "224",
          Somalia: "225",
          Somaliland: "226",
          "South Africa": "29",
          "South Korea": "30",
          "South Ossetia": "227",
          Spain: "23",
          "Sri Lanka": "228",
          Sudan: "229",
          Suriname: "230",
          Svalbard: "231",
          Swaziland: "232",
          Sweden: "1",
          Switzerland: "57",
          Syria: "233",
          Taiwan: "49",
          Tajikistan: "234",
          Tanzania: "235",
          Thailand: "93",
          "Timor-Leste": "236",
          Togo: "95",
          Tokelau: "237",
          Tonga: "238",
          Transnistria: "239",
          "Trinidad & Tobago": "78",
          "Tristan da Cunha": "240",
          Tunisia: "106",
          Turkey: "55",
          Turkmenistan: "66",
          "Turks and Caicos Islands": "241",
          Tuvalu: "242",
          Uganda: "243",
          Ukraine: "72",
          "United Arab Emirates": "244",
          "United Kingdom": "12",
          Uruguay: "88",
          USSR: "92",
          Uzbekistan: "56",
          Vanuatu: "76",
          "Various/International": "117",
          "Vatican City": "245",
          Venezuela: "73",
          Vietnam: "77",
          "Virgin Islands": "246",
          "Wallis and Futuna": "247",
          "Western Sahara": "248",
          World: "254",
          Yemen: "249",
          Yugoslavia: "38",
          Zambia: "250",
          Zimbabwe: "251"
        }
      }
    },
    KamePT: {
      url: "https://kamept.com",
      host: "kamept.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table>tbody>tr:nth-child(4)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      }
    },
    LST: {
      url: "https://lst.gg",
      host: "lst.gg",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload/1",
      needDoubanInfo: true,
      seedDomSelector: "#meta-info+.meta-general>.panel:first",
      torrentDownloadLinkSelector: 'a[href*="/download/torrent/"]',
      search: {
        path: "/torrents",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          name: "{name}",
          imdbId: "{imdb}",
          sortField: "size"
        }
      },
      name: {
        selector: "#title"
      },
      description: {
        selector: "#bbcode-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mal: {
        selector: "#automal"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      anonymous: {
        selector: '.form__group input[type="checkbox"][name="anonymous"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      videoType: {
        selector: "#autotype",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "2",
          encode: "3",
          web: "4",
          hdtv: "6",
          dvd: "1",
          dvdrip: "3",
          other: "7"
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "4320p": "1",
          "2160p": "2",
          "1080p": "3",
          "1080i": "4",
          "720p": "5",
          "576p": "6",
          "480p": "8"
        }
      }
    },
    MDU: {
      url: "https://monikadesign.uk",
      host: "monikadesign.uk",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload/1",
      needDoubanInfo: true,
      seedDomSelector: "#meta-info+.meta-general>.panel:first",
      torrentDownloadLinkSelector: 'a[href*="/download/torrent/"]',
      search: {
        path: "/torrents",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          name: "{name}",
          imdbId: "{imdb}",
          sortField: "size"
        }
      },
      name: {
        selector: "#title"
      },
      subtitle: {
        selector: 'input[name="subhead"]'
      },
      description: {
        selector: "#bbcode-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mal: {
        selector: "#automal"
      },
      bgm: {
        selector: "#bgm"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      bdinfo: {
        selector: 'textarea[name="bdinfo"]'
      },
      anonymous: {
        selector: '.form__group input[type="checkbox"][name="anonymous"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#autocat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      videoType: {
        selector: "#autotype",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "2",
          encode: "3",
          web: "4",
          hdtv: "",
          dvd: "",
          dvdrip: "",
          other: ""
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "4320p": "1",
          "2160p": "2",
          "1080p": "3",
          "1080i": "4",
          "720p": "5",
          "576p": "6",
          "480p": "8"
        }
      }
    },
    MTV: {
      url: "https://www.morethantv.me",
      host: "morethantv.me",
      siteType: "gazelle",
      asSource: true,
      asTarget: true,
      needDoubanInfo: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents/browse",
        params: {
          searchtext: "{imdb}",
          title: "{name}"
        }
      },
      icon: "",
      seedDomSelector: "#descbox",
      torrentDownloadLinkSelector: 'a[href*="/torrents.php"][title="Download Torrent"]',
      name: {
        selector: 'input[name="title"][class="long"]'
      },
      description: {
        selector: "#desc"
      },
      anonymous: {
        selector: 'input[name="anonymous"][value="1"]'
      },
      torrent: {
        selector: "#file"
      },
      category: {
        selector: "#category",
        map: {
          movie: "1",
          tv: "5",
          tvPack: "5",
          documentary: "1",
          concert: "1"
        }
      }
    },
    MTeam: {
      url: "https://kp.m-team.cc",
      host: "m-team.cc",
      siteType: "MTeam",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload",
      seedDomSelector: ".detail-view .ant-descriptions-view>table>tbody .ant-descriptions-row:nth-child(3)",
      search: {
        path: "/browse/movie",
        replaceKey: [
          "tt",
          "https://www.imdb.com/title/tt"
        ],
        params: {
          keyword: "{imdb}"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: "#smallDescr"
      },
      description: {
        selector: "#descr"
      },
      mediainfo: {
        selector: "#mediainfo"
      },
      imdb: {
        selector: "#imdb"
      },
      douban: {
        selector: "#douban"
      },
      tags: {
        diy: 'input[value="diy"]',
        chinese_subtitle: 'input[value="sub"]',
        chinese_audio: 'input[value="dub"]'
      },
      torrent: {
        selector: "#torrent-input"
      },
      category: {
        selector: "#category",
        map: {
          movie: [
            "401",
            "419",
            "420",
            "421",
            "439"
          ],
          tv: [
            "403",
            "402",
            "435",
            "438"
          ],
          tvPack: [
            "403",
            "402",
            "435",
            "438"
          ],
          documentary: "404",
          concert: "406",
          sport: "407",
          music: "434",
          cartoon: "405",
          app: "422",
          ebook: "427",
          magazine: "427",
          audioBook: "427"
        }
      },
      videoCodec: {
        selector: "#videoCodec",
        map: {
          h264: "1",
          hevc: "16",
          h265: "16",
          x264: "1",
          x265: "16",
          mpeg2: "4",
          mpeg4: "15",
          vc1: "2",
          xvid: "3",
          av1: "19"
        }
      },
      audioCodec: {
        selector: "#audioCodec",
        map: {
          aac: "6",
          ac3: "8",
          dd: "8",
          "dd+": "8",
          flac: "1",
          dts: "3",
          truehd: "9",
          lpcm: "7",
          dtshdma: "11",
          atmos: "10",
          dtsx: "3",
          ape: "2",
          wav: "7",
          other: "7",
          mp3: "4"
        }
      },
      source: {
        selector: "#source",
        map: {
          uhdbluray: "1",
          bluray: "1",
          hdtv: "4",
          dvd: "3",
          web: "8",
          vhs: "6",
          hddvd: "6"
        }
      },
      videoType: {
        selector: "#medium",
        map: {
          uhdbluray: [
            "1",
            "421",
            "438"
          ],
          bluray: [
            "1",
            "421",
            "438"
          ],
          remux: [
            "3",
            "439"
          ],
          encode: [
            "7",
            "401",
            "419",
            "403",
            "402"
          ],
          web: [
            "10",
            "419",
            "402"
          ],
          hdtv: [
            "5",
            "419",
            "402"
          ],
          dvd: [
            "6",
            "420",
            "435"
          ],
          dvdrip: [
            "7",
            "401",
            "403"
          ],
          other: ""
        }
      },
      resolution: {
        selector: "#standard",
        map: {
          "2160p": [
            "6",
            "419",
            "402"
          ],
          "1080p": [
            "1",
            "419",
            "402"
          ],
          "1080i": [
            "2",
            "419",
            "402"
          ],
          "720p": [
            "3",
            "419",
            "402"
          ],
          "576p": [
            "5",
            "401",
            "403"
          ],
          "480p": [
            "5",
            "401",
            "403"
          ]
        }
      },
      area: {
        selector: "#processing",
        map: {
          CN: "1",
          US: "2",
          EU: "2",
          HK: "3",
          TW: "3",
          JP: "4",
          KR: "5",
          OT: "6"
        }
      },
      team: {
        selector: "#team",
        map: {
          mteam: "9",
          tnp: "23",
          kishd: "7",
          bmdru: "6",
          onehd: "18",
          cnhk: "19",
          stbox: "20",
          r2hd: "21",
          pack: "8",
          geek: "24",
          qhstudio: "34"
        }
      }
    },
    NPUBits: {
      url: "https://npupt.com",
      host: "npupt.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: false,
      asTarget: true,
      uploadPath: "/upload.php",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        params: {
          incldead: "0",
          search: "{name}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: "#torrents_table>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(3)>center:first"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: "#small_descr"
      },
      description: {
        selector: "#descr"
      },
      anonymous: {
        selector: 'input[name="uplver"]',
        value: "yes"
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403",
          music: "414",
          app: "408",
          ebook: "411",
          magazine: "411",
          audioBook: "411"
        }
      },
      area: {
        selector: "#source_sel",
        map: {
          CN: "6",
          US: "5",
          EU: "5",
          HK: "6",
          TW: "6",
          JP: "5",
          KR: "5",
          OT: "7"
        }
      },
      videoCodec: {
        selector: 4,
        map: {
          h264: "H264",
          hevc: "x265",
          x264: "x264",
          x265: "x265",
          h265: "x265",
          mpeg2: "MPEG2",
          mpeg4: "H264",
          xvid: "Xvid",
          dvd: "MPEG2"
        }
      },
      videoType: {
        selector: 2,
        map: {
          uhdbluray: "BluRay",
          bluray: "BluRay",
          remux: "Remux",
          encode: "BluRay",
          web: "WEB-DL",
          hdtv: "HDTV",
          dvd: "DVD",
          dvdrip: "DVDRip",
          other: ""
        }
      },
      resolution: {
        selector: 3,
        map: {
          "2160p": "2160p",
          "1080p": "1080p",
          "1080i": "1080i",
          "720p": "720p",
          "576p": "576p",
          "480p": "480p"
        }
      },
      team: {
        selector: 5,
        map: {
          wiki: "WiKi",
          cmct: "CMCT",
          mteam: "MTeam",
          epic: "EPiC",
          hdchina: "HDChina",
          hds: "HDS",
          beast: "beAst",
          ctrlhd: "CtrlHD",
          chd: "CHD"
        }
      }
    },
    NYPT: {
      url: "https://nanyangpt.com",
      host: "nanyangpt.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="dburl"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "406",
          concert: "407",
          sport: "405",
          cartoon: "403",
          variety: "404"
        }
      }
    },
    OpenSub: {
      url: "https://www.opensubtitles.org",
      host: "opensubtitles.org",
      siteType: "subtitles",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/en/search/sublanguageid-all/imdbid-{name}"
      }
    },
    Orpheus: {
      url: "https://orpheus.network",
      host: "orpheus.network",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          searchstr: "{name}"
        }
      },
      torrent: {
        selector: "#file"
      }
    },
    OurBits: {
      url: "https://ourbits.club",
      host: "ourbits.club",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: "#torrenttable>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      poster: 'input[name="picture"]',
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: "#tagGY",
        diy: "#tagDIY",
        cantonese_audio: "#tag_yy",
        chinese_subtitle: "#tagZZ",
        hdr: "#tagHDR10",
        hdr10_plus: "#tagHDR10P",
        dolby_vision: "#tagDB"
      },
      category: {
        selector: 'select[name="type"]',
        map: {
          movie: "401",
          "3d": "402",
          tv: "412",
          tvPack: "405",
          documentary: "410",
          concert: "419",
          sport: "415",
          cartoon: "411",
          variety: "413",
          music: "416"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "12",
          hevc: "14",
          x264: "12",
          x265: "14",
          h265: "14",
          mpeg2: "15",
          mpeg4: "12",
          vc1: "16",
          xvid: "17",
          dvd: "18"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "7",
          ac3: "6",
          dd: "6",
          "dd+": "6",
          flac: "13",
          dts: "4",
          truehd: "2",
          lpcm: "5",
          dtshdma: "1",
          atmos: "14",
          dtsx: "21"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "12",
          bluray: "1",
          remux: "4",
          encode: "7",
          web: "9",
          hdtv: "5",
          dvd: "2",
          dvdrip: "2",
          other: "0"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "1",
          US: "2",
          EU: "2",
          HK: "3",
          TW: "3",
          JP: "4",
          KR: "5",
          OT: "6"
        }
      }
    },
    PTHome: {
      url: "https://www.pthome.net",
      host: "pthome.net",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_id"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: "#torrent"
      },
      tags: {
        chinese_audio: "#tag_gy",
        diy: "#tag_diy",
        cantonese_audio: "#tag_yy",
        chinese_subtitle: "#tag_zz",
        hdr: "#tag_hdr10",
        hdr10_plus: "#tag_hdrm",
        dolby_vision: "#tag_db"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          concert: "408",
          sport: "407",
          cartoon: "405",
          variety: "403"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          x264: "1",
          hevc: "6",
          x265: "6",
          h265: "6",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "5",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "18",
          dd: "18",
          "dd+": "18",
          flac: "1",
          dts: "3",
          truehd: "20",
          lpcm: "21",
          dtshdma: "19",
          atmos: "19",
          dtsx: "3"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "12",
          bluray: "1",
          remux: "3",
          encode: "15",
          web: "10",
          hdtv: "5",
          dvd: "2",
          dvdrip: "15",
          other: "11"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "4320p": "10",
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          pthome: "19",
          pth: "21",
          pthweb: "20",
          pthtv: "22",
          pthaudio: "23",
          pthebook: "24",
          pthmusic: "25",
          other: "5"
        }
      }
    },
    PTN: {
      url: "https://piratethenet.org",
      host: "piratethenet.org",
      siteType: "PTN",
      icon: "",
      asSource: false,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/browse.php",
        params: {
          name: "{name}",
          imdb: "{imdb}"
        }
      },
      name: {
        selector: "#name"
      },
      description: {
        selector: "#descr"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      }
    },
    PTP: {
      url: "https://passthepopcorn.me",
      host: "passthepopcorn.me",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: true,
      needDoubanInfo: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          action: "advanced",
          searchstr: "{imdb}"
        }
      },
      sourceInfo: {
        editionTags: {
          "10-bit": "10_bit",
          "2-Disc Set": "2_disc_set",
          "2D/3D Edition": "2d_3d_edition",
          "2in1": "2_in_1",
          "3D": "3d",
          "3D Anaglyph": "3d_anaglyph",
          "3D Full SBS": "3d_full_sbs",
          "3D Half OU": "3d_half_ou",
          "3D Half SBS": "3d_half_sbs",
          "4K Remaster": "4k_remaster",
          "4K Restoration": "4k_restoration",
          "Director's Cut": "director_s_cut",
          "Dolby Atmos": "dolby_atmos",
          "Dolby Vision": "dolby_vision",
          "Dual Audio": "dual_audio",
          "English Dub": "english_dub",
          "Extended Cut": "extended_edition",
          "Extended Edition": "extended_edition",
          Extras: "extras",
          HDR10: "hdr10",
          "HDR10+": "hdr10_plus",
          "Masters of Cinema": "masters_of_cinema",
          Scene: "scene",
          "The Criterion Collection": "the_criterion_collection",
          "Theatrical Cut": "theatrical_cut",
          Trumpable: null,
          "Two-Disc Set": "two_disc_set",
          Remux: "remux",
          Rifftrax: "rifftrax",
          Uncut: "uncut",
          Unrated: "unrated",
          "Warner Archive Collection": "warner_archive_collection",
          "With Commentary": "with_commentary"
        }
      },
      description: {
        selector: "#release_desc"
      },
      poster: "#image",
      imdb: {
        selector: "#imdb"
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      mediaInfo: {
        selector: "#Media_BDInfo"
      },
      screenshots: {
        selector: "#url_vimages"
      },
      torrent: {
        selector: "#file"
      },
      category: {
        selector: "#categories",
        map: {
          movie: "Feature Film",
          tv: "Miniseries",
          tvPack: "Miniseries",
          documentary: "Feature Film",
          concert: "Live Performance"
        }
      },
      videoCodec: {
        selector: "#codec",
        map: {
          h264: "H.264",
          hevc: "H.265",
          x264: "x264",
          x265: "x265",
          h265: "H.265",
          mpeg2: "Other",
          mpeg4: "H.264",
          vc1: "Other",
          xvid: "XviD",
          DVD5: "DVD5",
          DVD9: "DVD9",
          BD100: "BD100",
          BD66: "BD66",
          BD50: "BD50",
          BD25: "BD25"
        }
      },
      source: {
        selector: "#source",
        map: {
          uhdbluray: "Blu-ray",
          bluray: "Blu-ray",
          hdtv: "HDTV",
          dvd: "DVD",
          web: "WEB",
          vhs: "VHS",
          hddvd: "HD-DVD"
        }
      },
      resolution: {
        selector: "#resolution",
        map: {
          "2160p": "2160p",
          "1080p": "1080p",
          "1080i": "1080i",
          "720p": "720p",
          "576p": "576p",
          "480p": "480p",
          NTSC: "NTSC",
          PAL: "PAL",
          other: "Other"
        }
      }
    },
    PTSBAO: {
      url: "https://ptsbao.club",
      host: "ptsbao.club",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(7)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: "#small_descr"
      },
      description: {
        selector: "textarea[tabindex]"
      },
      imdb: {
        selector: 'input[name="imdburl"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_subtitle: 'input[type="checkbox"][name="zz"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "0"
        }
      },
      source: {
        selector: "#medium_sel",
        map: {
          uhdbluray: "10",
          bluray: "1",
          hdtv: "5",
          dvd: "3",
          web: "2",
          vhs: "9",
          hddvd: "9"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "6",
          x264: "1",
          x265: "6",
          h265: "6",
          mpeg2: "4",
          mpeg4: "5",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: "#audiocodec_sel",
        map: {
          aac: "6",
          ac3: "11",
          dd: "10",
          "dd+": "10",
          dts: "3",
          truehd: "9",
          lpcm: "12",
          dtshdma: "8",
          atmos: "8",
          dtsx: "13",
          flac: "1"
        }
      },
      videoType: {
        selector: "#processing_sel",
        map: {
          uhdbluray: "5",
          bluray: "5",
          remux: "1",
          encode: "2",
          web: "2",
          hdtv: "3",
          dvd: "3",
          dvdrip: "3",
          other: "3"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": [
            "5",
            "92"
          ],
          "1080p": [
            "1",
            "3"
          ],
          "1080i": "1",
          "720p": [
            "2",
            "91"
          ],
          "576p": "3",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          ffansbd: "8",
          ops: "11",
          ffansweb: "12",
          ffanstv: "13",
          hqc: "10",
          ttg: "3",
          hdc: "6",
          chd: "2",
          hdsky: "9",
          cmct: "4",
          frds: "5",
          other: "7",
          ffansdvd: "14",
          fhdmv: "15",
          enichi: "16"
        }
      }
    },
    "PTer-offer": {
      url: "https://pterclub.com",
      host: "pterclub.com",
      siteType: "NexusPHP",
      icon: "",
      asTarget: true,
      uploadPath: "/offers.php?add_offer=1"
    },
    PTer: {
      url: "https://pterclub.com",
      host: "pterclub.com",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: "#torrenttable>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr,#body"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: "#guoyu",
        diy: "#diy",
        cantonese_audio: "#yueyu",
        chinese_subtitle: "#zhongzi"
      },
      category: {
        selector: "#browsecat,select[name='type']",
        map: {
          movie: "401",
          tv: "404",
          tvPack: "404",
          documentary: "402",
          concert: "406",
          sport: "407",
          cartoon: "403",
          variety: "405",
          music: "406"
        }
      },
      videoType: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "2",
          remux: "3",
          encode: "6",
          web: "5",
          hdtv: "4",
          dvd: "7",
          dvdrip: "7",
          other: "15"
        }
      },
      area: {
        selector: 'select[name="team_sel"]',
        map: {
          CN: "1",
          US: "4",
          EU: "4",
          HK: "2",
          TW: "3",
          JP: "6",
          KR: "5",
          IND: "7",
          OT: "8"
        }
      }
    },
    "Piggo-offer": {
      url: "https://piggo.me",
      host: "piggo.me",
      siteType: "NexusPHP",
      icon: "",
      asTarget: true,
      uploadPath: "/offers.php?add_offer=1"
    },
    Piggo: {
      url: "https://piggo.me",
      host: "piggo.me",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: "#torrenttable>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr,#body"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="pt_gen"]'
      },
      mediaInfo: {
        selector: 'textarea[name="technical_info"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: "#guoyu",
        diy: "#diy",
        cantonese_audio: "#yueyu",
        chinese_subtitle: "#zhongzi"
      },
      category: {
        selector: '#specialcat,select[name="type"]',
        map: {
          movie: "401",
          tv: "404",
          tvPack: "404",
          documentary: "402",
          concert: "406",
          sport: "407",
          cartoon: "403",
          variety: "405",
          music: "406"
        }
      },
      videoType: {
        selector: 'select[name="source_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "2",
          remux: "3",
          encode: "6",
          web: "5",
          hdtv: "4",
          dvd: "7",
          dvdrip: "7",
          other: "15"
        }
      },
      area: {
        selector: 'select[name="team_sel"]',
        map: {
          CN: "1",
          US: "4",
          EU: "4",
          HK: "2",
          TW: "3",
          JP: "6",
          KR: "5",
          IND: "7",
          OT: "8"
        }
      }
    },
    PrivateHD: {
      url: "https://privatehd.to",
      host: "privatehd.to",
      siteType: "AvistaZ",
      icon: "",
      asSource: true,
      asTarget: false,
      uploadPath: "/upload.php",
      seedDomSelector: "#content-area .block:last table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="/download/torrent"]',
      needDoubanInfo: true,
      search: {
        path: "/browse.php",
        params: {
          search: "{name}",
          in: "1",
          order: "size",
          sort: "desc"
        }
      }
    },
    PuTao: {
      url: "https://pt.sjtu.edu.cn",
      host: "sjtu.edu.cn",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "h1~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_url"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: "#torrent"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: [
            "401",
            "402",
            "403"
          ],
          tv: [
            "407",
            "408",
            "409",
            "410"
          ],
          tvPack: [
            "407",
            "408",
            "409",
            "410"
          ],
          documentary: "406",
          concert: "427",
          cartoon: "431",
          app: "434",
          sport: "432",
          music: [
            "420",
            "421",
            "422"
          ],
          variety: [
            "411",
            "412",
            "413",
            "414"
          ]
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "10",
          x264: "1",
          x265: "10",
          h265: "10",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "9",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "11",
          hdtv: "5",
          dvd: "6",
          dvdrip: "7",
          hddvd: "2",
          other: "4"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "6",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      area: {
        map: {
          CN: [
            "401",
            "409",
            "411",
            "420"
          ],
          US: [
            "402",
            "410",
            "413",
            "422"
          ],
          EU: [
            "402",
            "410",
            "413",
            "422"
          ],
          HK: [
            "403",
            "407",
            "412",
            "420"
          ],
          TW: [
            "403",
            "407",
            "412",
            "420"
          ],
          JP: [
            "403",
            "408",
            "414",
            "421"
          ],
          KR: [
            "403",
            "408",
            "414",
            "421"
          ]
        }
      }
    },
    R3SUB: {
      url: "https://r3sub.com",
      host: "r3sub.com",
      siteType: "subtitles",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/movie.php",
        params: {
          id: "{imdb}"
        }
      }
    },
    RED: {
      url: "https://redacted.ch",
      host: "redacted.ch",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          searchstr: "{name}"
        }
      },
      torrent: {
        selector: "#file"
      }
    },
    RedLeaves: {
      url: "https://leaves.red",
      host: "leaves.red",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: "#torrenttable>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="pt_gen"]'
      },
      mediaInfo: {
        selector: 'textarea[name="technical_info"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      tags: {
        chinese_audio: "#leaves-tag5",
        diy: "#leaves-tag4",
        cantonese_audio: "#leaves-tag18",
        chinese_subtitle: "#leaves-tag6",
        HDR: "#leaves-tag7",
        DolbyVision: "#leaves-tag17"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: [
            "402",
            "403"
          ],
          documentary: "404",
          concert: "406",
          sport: "407",
          cartoon: "405",
          music: [
            "406",
            "408",
            "409"
          ]
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "10",
          x264: "1",
          x265: "10",
          h265: "10",
          mpeg2: "5",
          mpeg4: "4",
          vc1: "2",
          xvid: "3",
          dvd: "5"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel[5]"]',
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "8",
          hdtv: "5",
          dvd: "6",
          dvdrip: "6",
          other: "6"
        }
      },
      area: {
        selector: 'select[name="processing_sel[5]"]',
        map: {
          CN: "2",
          US: "3",
          EU: "3",
          HK: "1",
          TW: "1",
          JP: "4",
          KR: "5",
          IND: "6",
          OT: "6"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel[5]"]',
        map: {
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      }
    },
    SC: {
      url: "https://secret-cinema.pw",
      host: "secret-cinema.pw",
      siteType: "gazelle",
      icon: "",
      asSource: false,
      asTarget: true,
      uploadPath: "/upload.php",
      torrent: {
        selector: 'input[name="file_input"]'
      },
      search: {
        path: "/torrents.php",
        params: {
          action: "advanced",
          searchsubmit: 1,
          filter_cat: 1,
          groupname: "{name}",
          cataloguenumber: "{imdb}",
          order_by: "size",
          order_way: "desc",
          tags_type: 0
        }
      }
    },
    SSD: {
      url: "https://springsunday.net",
      host: "springsunday.net",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(6)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: "#small_descr"
      },
      description: {
        selector: "#descr"
      },
      poster: "#url_poster",
      imdb: {
        selector: "#url"
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      mediaInfo: {
        selector: "#Media_BDInfo"
      },
      screenshots: {
        selector: "#url_vimages"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "501",
          tv: "502",
          tvPack: "502",
          documentary: "503",
          concert: "507",
          sport: "506",
          cartoon: "504",
          variety: "505",
          music: "508"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "2",
          hevc: "1",
          x264: "2",
          x265: "1",
          h265: "1",
          mpeg2: "4",
          mpeg4: "2",
          vc1: "3",
          xvid: "",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "5",
          ac3: "4",
          dd: "4",
          "dd+": "4",
          flac: "7",
          dts: "3",
          truehd: "2",
          lpcm: "6",
          dtshdma: "1",
          atmos: "3",
          dtsx: "3"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "4",
          encode: "6",
          web: "7",
          hdtv: "5",
          dvd: "3",
          dvdrip: "10",
          other: ""
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "1",
          "1080p": "2",
          "1080i": "3",
          "720p": "4",
          "576p": "5",
          "480p": "5"
        }
      },
      area: {
        selector: 'select[name="source_sel"]',
        map: {
          CN: "1",
          US: "9",
          EU: "9",
          HK: "2",
          TW: "2",
          JP: "10",
          KR: "10",
          OT: "3"
        }
      }
    },
    SoulVoice: {
      url: "https://pt.soulvoice.club",
      host: "soulvoice.club",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      needDoubanBookInfo: true,
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "404",
          cartoon: "405",
          sport: "407",
          concert: "406",
          variety: "403",
          music: "408"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "2",
          h265: "2",
          x264: "1",
          x265: "2",
          mpeg2: "5",
          mpeg4: "1",
          vc1: "5",
          xvid: "5"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "3",
          "1080p": "1",
          "1080i": "2",
          "720p": "4",
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          hds: "1",
          chd: "2",
          frds: "3",
          cmct: "4",
          other: "5"
        }
      }
    },
    SpeedApp: {
      url: "https://speedapp.io",
      host: "speedapp.io",
      siteType: "SpeedApp",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "div.row.d-sm-none + div + div",
      uploadPath: "/upload",
      needDoubanInfo: false,
      search: {
        path: "/browse",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          search_area: "{optionKey}",
          search: "{imdb}"
        }
      },
      name: {
        selector: "#name"
      },
      description: {
        selector: "#torrentDescription_releaseInfo"
      },
      imdb: {
        selector: "#url"
      },
      mediaInfo: {
        selector: "#torrentDescription_mediaInfo"
      },
      bdinfo: {
        selector: "#torrentDescription_bdInfo"
      },
      screenshots: {
        selector: "#torrentDescription_screenshots"
      }
    },
    SubHD: {
      url: "https://subhd.tv",
      host: "subhd.tv",
      siteType: "subtitles",
      category: [
        "subtitles"
      ],
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/search/{name}"
      }
    },
    TCCF: {
      url: "https://et8.org",
      host: "et8.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      anonymous: {
        selector: 'input[name="uplver"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "622",
          tv: "623",
          tvPack: "623",
          documentary: "404",
          concert: "626",
          sport: "627",
          cartoon: "627",
          variety: "627",
          app: "625",
          ebook: "629",
          magazine: "631",
          comics: "632",
          audioBook: "633",
          onlineCourse: "634"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          x264: "7",
          hevc: "8",
          x265: "6",
          h265: "8",
          mpeg2: "4",
          mpeg4: "1",
          vc1: "2",
          xvid: "3",
          dvd: "4"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "4",
          dd: "4",
          "dd+": "4",
          flac: "1",
          dts: "3",
          truehd: "9",
          lpcm: "10",
          dtshdma: "8",
          atmos: "8",
          dtsx: "3"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "10",
          bluray: "1",
          remux: "5",
          encode: "11",
          web: "9",
          hdtv: "6",
          dvd: "7",
          dvdrip: "4",
          other: "0"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "5",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      team: {
        selector: 'select[name="team_sel"]',
        map: {
          torrentccf: "1",
          tccf: "1",
          tlf: "2",
          bmdru: "3",
          catedu: "4",
          madfox: "5",
          other: "7"
        }
      }
    },
    TJUPT: {
      url: "https://www.tjupt.org",
      host: "tjupt.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(5)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: "#descr"
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: "#external_url"
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "401",
          tv: "402",
          tvPack: "402",
          documentary: "411",
          concert: "406",
          sport: "407",
          cartoon: "405",
          variety: "403",
          music: "406"
        }
      }
    },
    TLF: {
      url: "https://pt.eastgame.org",
      host: "eastgame.org",
      siteType: "NexusPHP",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#top~table:first>tbody>tr:nth-child(3)",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          incldead: "0",
          search_area: "{optionKey}",
          search: "{imdb}",
          sort: "5",
          type: "desc"
        },
        result: {
          list: ".torrents>tbody>tr",
          url: '.torrentname td a[href*="details.php?id="]',
          name: '.torrentname td a[href*="details.php?id="]',
          size: "td:nth-child(5)"
        }
      },
      name: {
        selector: "#name"
      },
      subtitle: {
        selector: 'input[name="small_descr"]'
      },
      description: {
        selector: 'textarea[name="descr"]'
      },
      imdb: {
        selector: 'input[name="url"][type="text"]'
      },
      douban: {
        selector: 'input[name="douban_url"]'
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "438",
          tv: "440",
          tvPack: "440",
          documentary: "443",
          cartoon: "442",
          sport: "444",
          concert: "445",
          variety: "441",
          music: "446"
        }
      },
      videoCodec: {
        selector: 'select[name="codec_sel"]',
        map: {
          h264: "1",
          hevc: "6",
          h265: "6",
          x264: "1",
          x265: "6",
          mpeg2: "4",
          mpeg4: "0",
          vc1: "2",
          xvid: "3"
        }
      },
      audioCodec: {
        selector: 'select[name="audiocodec_sel"]',
        map: {
          aac: "6",
          ac3: "9",
          dd: "9",
          "dd+": "9",
          flac: "1",
          dts: "10",
          truehd: "14",
          lpcm: "12",
          dtshdma: "11",
          atmos: "13",
          dtsx: "10"
        }
      },
      videoType: {
        selector: 'select[name="medium_sel"]',
        map: {
          uhdbluray: "10",
          bluray: "1",
          remux: "3",
          encode: "7",
          web: "4",
          hdtv: "5",
          dvd: "6",
          hddvd: "1",
          dvdrip: "6",
          other: "9"
        }
      },
      resolution: {
        selector: 'select[name="standard_sel"]',
        map: {
          "2160p": "6",
          "1080p": "1",
          "1080i": "2",
          "720p": "3",
          "576p": "4",
          "480p": "4"
        }
      },
      area: {
        selector: 'select[name="processing_sel"]',
        map: {
          CN: "1",
          US: "2",
          EU: "2",
          HK: "3",
          TW: "3",
          JP: "4",
          KR: "5",
          OT: "6"
        }
      }
    },
    TMDB: {
      url: "https://www.themoviedb.org",
      host: "www.themoviedb.org",
      siteType: "tmdb",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/search?query={name}"
      }
    },
    TTG: {
      url: "https://totheglory.im",
      host: "totheglory.im",
      siteType: "TTG",
      icon: "",
      asSource: true,
      asTarget: true,
      seedDomSelector: "#main_table h1~table:first>tbody>tr:nth-child(2)",
      torrentDownloadLinkSelector: 'a[href*="im/dl/"]',
      uploadPath: "/upload.php",
      search: {
        path: "/browse.php",
        replaceKey: [
          "tt",
          "imdb"
        ],
        params: {
          search_field: "{imdb}",
          sort: "5",
          type: "desc",
          c: "M"
        },
        result: {
          list: "#torrent_table>tbody>tr",
          url: '.name_left a[href*="/t/"]',
          name: '.name_left a[href*="/t/"] b',
          size: "td:nth-child(7)"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      subtitle: {
        selector: 'input[name="subtitle"]'
      },
      description: {
        selector: 'textarea[name="descr"]'
      },
      imdb: {
        selector: 'input[name="imdb_c"]'
      },
      douban: {
        selector: 'input[name="douban_id"]'
      },
      anonymous: {
        selector: 'select[name="anonymity"]',
        value: "yes"
      },
      torrent: {
        selector: 'input[name="file"]'
      },
      category: {
        selector: 'select[name="type"]',
        map: {
          movie: [
            "51",
            "52",
            "53",
            "54",
            "108",
            "109"
          ],
          tv: [
            "69",
            "70",
            "73",
            "74",
            "75",
            "76"
          ],
          tvPack: [
            "87",
            "88",
            "99",
            "90"
          ],
          documentary: [
            "62",
            "63",
            "67"
          ],
          concert: "59",
          sport: "57",
          cartoon: "58",
          music: "83",
          variety: [
            "103",
            "60",
            "101"
          ]
        }
      },
      videoType: {
        map: {
          uhdbluray: [
            "109"
          ],
          bluray: [
            "54",
            "109",
            "67"
          ],
          remux: [
            "53",
            "108",
            "63",
            "70",
            "75"
          ],
          encode: [
            "53",
            "63",
            "70",
            "75",
            "52",
            "62",
            "69",
            "76",
            "108"
          ],
          web: [
            "53",
            "62",
            "63",
            "70",
            "75",
            "52",
            "69",
            "76",
            "108",
            "87",
            "88",
            "99",
            "90"
          ],
          hdtv: [
            "53",
            "63",
            "70",
            "75",
            "52",
            "62",
            "69",
            "76",
            "108",
            "87",
            "88",
            "99",
            "90"
          ],
          dvd: [
            "51"
          ],
          dvdrip: [
            "51"
          ],
          other: ""
        }
      },
      resolution: {
        map: {
          "2160p": [
            "108",
            "109",
            "67"
          ],
          "1080p": [
            "53",
            "63",
            "70",
            "75",
            "54",
            "67",
            "87",
            "88",
            "99",
            "90"
          ],
          "1080i": [
            "53",
            "63",
            "70",
            "75",
            "87",
            "88",
            "99",
            "90"
          ],
          "720p": [
            "52",
            "62",
            "69",
            "76",
            "87",
            "88",
            "99",
            "90"
          ],
          "576p": "51",
          "480p": "51"
        }
      },
      area: {
        map: {
          CN: [
            "76",
            "75",
            "90"
          ],
          US: [
            "69",
            "70",
            "87"
          ],
          EU: [
            "69",
            "70",
            "87"
          ],
          HK: [
            "76",
            "75",
            "90"
          ],
          TW: [
            "76",
            "75",
            "90"
          ],
          JP: [
            "73",
            "88",
            "101"
          ],
          KR: [
            "74",
            "99",
            "103"
          ],
          OT: ""
        }
      }
    },
    TeamHD: {
      url: "https://teamhd.org",
      host: "teamhd.org",
      siteType: "TeamHD",
      icon: "",
      asSource: true,
      asTarget: false,
      seedDomSelector: "#details_hop",
      torrentDownloadLinkSelector: 'a[href*="download.php?id="]',
      needDoubanInfo: true,
      search: {
        path: "/browse",
        params: {
          incldead: "0",
          search: "{name}"
        }
      }
    },
    UHDBits: {
      url: "https://uhdbits.org",
      host: "uhdbits.org",
      siteType: "gazelle",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/upload.php",
      search: {
        path: "/torrents.php",
        params: {
          order_way: "desc",
          order_by: "size",
          searchstr: "{imdb}"
        }
      },
      needDoubanInfo: true,
      description: {
        selector: "#release_desc"
      },
      imdb: {
        selector: "#imdbid"
      },
      anonymous: {
        selector: "#anonymous"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      torrent: {
        selector: "#file"
      },
      category: {
        selector: "#categories",
        map: {
          movie: "0",
          tv: "2",
          tvPack: "2",
          music: "1"
        }
      },
      videoType: {
        selector: "#media",
        map: {
          uhdbluray: "Blu-ray",
          bluray: "Blu-ray",
          remux: "Remux",
          encode: "Encode",
          web: "WEB-DL",
          hdtv: "HDTV",
          dvdrip: "Encode",
          other: "Others"
        }
      },
      videoCodec: {
        selector: "#codec",
        map: {
          h264: "AVC/H.264",
          hevc: "HEVC",
          x264: "x264",
          x265: "x265",
          h265: "HEVC",
          mpeg2: "MPEG-2",
          mpeg4: "AVC/H.264",
          vc1: "VC-1",
          dvd: "MPEG"
        }
      },
      resolution: {
        selector: "#format",
        map: {
          "2160p": "2160p",
          "1080p": "1080p",
          "1080i": "1080i",
          "720p": "720p",
          "576p": "Others",
          "480p": "Others"
        }
      }
    },
    ZHUQUE: {
      url: "https://zhuque.in",
      host: "zhuque.in",
      siteType: "TNode",
      icon: "",
      asSource: false,
      asTarget: true,
      seedDomSelector: "div.layout-container > div > form",
      uploadPath: "/torrent/upload",
      needDoubanInfo: false,
      search: {
        path: "/torrent/search",
        imdbOptionKey: "4",
        nameOptionKey: "0",
        params: {
          search_area: "{optionKey}",
          search: "{imdb}"
        }
      },
      name: {
        selector: "#form_item_title"
      },
      subtitle: {
        selector: "#form_item_subtitle"
      },
      description: {
        selector: "#form_item_note"
      },
      anonymous: {
        selector: "#form_item_anonymous"
      },
      torrent: {
        selector: "#form_item_torrent"
      },
      imdb: {
        selector: 'input[placeholder="tt123456"]'
      },
      douban: {
        selector: "#form_item_doubanid"
      },
      tmdb: {
        selector: ".ant-space.ant-space-horizontal.ant-space-align-center >.ant-space-item:last-child > input"
      },
      screenshots: {
        selector: "#form_item_screenshot"
      },
      mediaInfo: {
        selector: "#form_item_mediainfo"
      },
      tags: {
        chinese_audio: 'input.ant-checkbox-input[value="603"]',
        chinese_subtitle: 'input.ant-checkbox-input[value="604"]',
        hdr: 'input.ant-checkbox-input[value="613"]',
        dolby_vision: 'input.ant-checkbox-input[value="611"]'
      },
      category: {
        selector: "#form_item_category",
        map: {
          movie: "\u7535\u5F71",
          tv: "\u7535\u89C6\u5267",
          tvPack: "\u7535\u89C6\u5267",
          cartoon: "\u52A8\u753B",
          concert: "\u5176\u5B83",
          documentary: "\u5176\u5B83",
          variety: "\u5176\u5B83"
        }
      },
      videoType: {
        selector: "#rc_select_9",
        map: {
          uhdbluray: "UHD Blu-ray",
          bluray: "Blu-ray",
          remux: "Remux",
          hdtv: "HDTV",
          web: "WEB-DL",
          webrip: "Encode",
          encode: "Encode"
        }
      },
      videoCodec: {
        selector: "#rc_select_10",
        map: {
          h264: "H264",
          hevc: "H265",
          x264: "x264",
          x265: "x265",
          h265: "H265",
          mpeg2: "Other",
          mpeg4: "H265",
          vc1: "Other",
          xvid: "Other",
          dvd: "Other"
        }
      },
      audioCodec: {
        selector: "#rc_select_3",
        map: {
          aac: "AAC",
          ac3: "AC3",
          dd: "AC3",
          "dd+": "DDP",
          dts: "DTS",
          truehd: "TrueHD",
          lpcm: "LPCM",
          flac: "FLAC",
          dtshdma: "DTS-HD MA",
          atmos: "TrueHD Atmos",
          dtsx: "DTS-X",
          mp3: "Other"
        }
      },
      resolution: {
        selector: "#rc_select_12"
      }
    },
    fearnopeer: {
      url: "https://fearnopeer.com",
      host: "fearnopeer.com",
      siteType: "UNIT3D",
      icon: "",
      asSource: true,
      asTarget: true,
      uploadPath: "/torrents/create?category_id=1",
      needDoubanInfo: true,
      seedDomSelector: ".torrent__buttons+.panelV2",
      torrentDownloadLinkSelector: 'a[href*="/torrents/download/"]',
      search: {
        path: "/torrents",
        replaceKey: [
          "tt",
          ""
        ],
        params: {
          name: "{name}",
          imdbId: "{imdb}",
          sortField: "size"
        }
      },
      name: {
        selector: "#title"
      },
      description: {
        selector: "#bbcode-description"
      },
      imdb: {
        selector: "#autoimdb"
      },
      tmdb: {
        selector: "#autotmdb"
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      anonymous: {
        selector: '.form__group input[type="checkbox"][name="anon"]'
      },
      torrent: {
        selector: 'input[type="file"][accept=".torrent"]'
      },
      category: {
        selector: "#browsecat",
        map: {
          movie: "1",
          tv: "2",
          tvPack: "2"
        }
      },
      videoType: {
        selector: "#autotype",
        map: {
          uhdbluray: "1",
          bluray: "1",
          remux: "3",
          encode: "12",
          web: "4",
          hdtv: "6",
          dvd: "1",
          dvdrip: "12",
          other: ""
        }
      },
      resolution: {
        selector: "#autores",
        map: {
          "4320p": "11",
          "2160p": "1",
          "1080p": "2",
          "1080i": "3",
          "720p": "5",
          "576p": "6",
          "480p": "8"
        }
      }
    },
    iTS: {
      url: "http://shadowthein.net",
      host: "shadowthein.net",
      siteType: "its",
      asSource: false,
      asTarget: true,
      icon: "",
      seedDomSelector: "h1~.line>tbody>tr:nth-child(2)",
      needDoubanInfo: true,
      uploadPath: "/upload.php",
      search: {
        path: "/browse.php",
        params: {
          incldead: 1,
          search: "{imdb}",
          search_in: "names",
          sort: 5,
          type: "desc"
        }
      },
      name: {
        selector: 'input[name="name"]'
      },
      imdb: {
        selector: 'input[name="imdblink"]'
      },
      description: {
        selector: 'textarea[name="descr"]'
      },
      mediaInfo: {
        selector: 'textarea[name="mediainfo"]'
      },
      tags: {
        hdr: 'input[name="HDR10"]',
        hdr10_plus: 'input[name="HDR10Plus"]',
        dolby_vision: 'input[name="DolbyVision"]'
      },
      anonymous: {
        selector: 'input[name="anonymous"][value="true"]'
      },
      category: {
        selector: 'select[name="type"]',
        map: {
          movie: "68",
          tv: "65",
          concert: "61",
          music: "6",
          ebook: "26"
        }
      }
    },
    "nzbs.in": {
      url: "https://nzbs.in",
      host: "nzbs.in",
      siteType: "nzb",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/search/{name}",
        params: {
          t: -1,
          ob: "size_desc"
        }
      }
    },
    zimuku: {
      url: "http://zimuku.org",
      host: "zimuku.org",
      siteType: "subtitles",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/search",
        params: {
          q: "{imdb}"
        }
      }
    },
    \u8C46\u74E3\u7535\u5F71: {
      url: "https://search.douban.com",
      host: "search.douban.com",
      siteType: "douban",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/movie/subject_search",
        params: {
          search_text: "{imdb}"
        }
      }
    },
    \u8C46\u74E3\u8BFB\u4E66: {
      url: "https://search.douban.com",
      host: "search.douban.com",
      siteType: "doubanBook",
      icon: "",
      asSource: false,
      asTarget: false,
      search: {
        path: "/book/subject_search?search_text={name}"
      }
    }
  };

  // src/const.ts
  var TORRENT_INFO = {
    title: "",
    subtitle: "",
    description: "",
    originalDescription: "",
    year: "",
    category: "",
    videoType: "",
    format: "",
    source: "",
    videoCodec: "",
    audioCodec: "",
    resolution: "",
    area: "",
    doubanUrl: "",
    doubanInfo: "",
    imdbUrl: "",
    tags: {
      diy: false,
      chinese_audio: false,
      cantonese_audio: false,
      chinese_subtitle: false,
      dolby_atoms: false,
      dts_x: false,
      hdr: false,
      dolby_vision: false
    },
    otherTags: {},
    mediaInfos: [],
    screenshots: [],
    comparisons: [],
    movieAkaName: "",
    movieName: "",
    sourceSite: "",
    sourceSiteType: "",
    size: 0,
    isForbidden: false,
    poster: ""
  };
  var DOUBAN_SUGGEST_API = "https://www.douban.com/search?cat=1002&q={query}";
  var DOUBAN_MOBILE_API = "https://m.douban.com/rexxar/api/v2";
  var PT_GEN_API = "https://media.pttool.workers.dev";
  var TMDB_API_URL = "https://api.tmdb.org";
  var TMDB_API_KEY = "3d62cb1443c6b34b61262ab332aaf78c";
  var BROWSER_LANGUAGE = navigator.language.toLowerCase().split("-")[0];
  var getSiteName = (host) => {
    let siteName = "";
    try {
      Object.keys(PT_SITE).forEach((key) => {
        const siteKey = key;
        const hostName = PT_SITE[siteKey].host;
        const matchReg = new RegExp(hostName, "i");
        if (hostName && host.match(matchReg)) {
          siteName = siteKey;
        }
      });
      return siteName;
    } catch (error) {
      if (error.message !== "end loop") {
        console.log(error);
      }
      return "";
    }
  };
  var getSortedSiteKeys = () => {
    return Object.keys(PT_SITE).sort((a3, b3) => {
      const isChineseReg = /[\u4e00-\u9fa5]+/;
      if (isChineseReg.test(a3) && !isChineseReg.test(b3)) {
        return 1;
      }
      if (!isChineseReg.test(a3) && isChineseReg.test(b3)) {
        return -1;
      }
      return a3.toLowerCase().localeCompare(b3.toLowerCase());
    });
  };
  var SORTED_SITE_KEYS = getSortedSiteKeys();
  var EUROPE_LIST = ["Albania", "Andorra", "Armenia", "Austria", "Azerbaijan", "Belarus", "Belgium", "Bosnia and Herzegovina", "Bulgaria", "Croatia", "Cyprus", "Czech Republic", "Denmark", "Estonia", "Finland", "France", "Georgia", "Germany", "Greece", "Hungary", "Iceland", "Ireland", "Italy", "Kazakhstan", "Latvia", "Liechtenstein", "Lithuania", "Luxembourg", "Malta", "Moldova", "Monaco", "Montenegro", "Netherlands", "North Macedonia", "Norway", "Poland", "Portugal", "Romania", "Russia", "San Marino", "Serbia", "Slovakia", "Slovenia", "Spain", "Sweden", "Switzerland", "Turkey", "Ukraine", "United Kingdom", "UK", "Vatican City"];
  var CURRENT_SITE_NAME = getSiteName(location.host);
  var CURRENT_SITE_INFO = PT_SITE[CURRENT_SITE_NAME];
  var HDB_TEAM = ["Chotab", "CRiSC", "CtrlHD", "DON", "EA", "EbP", "Geek", "LolHD", "NTb", "RightSiZE", "SA89", "SbR", "TayTo", "VietHD"];

  // src/common.ts
  init_preact_shim();

  // src/i18n.json
  var i18n_default = {
    en: {
      \u8C46\u74E3\u94FE\u63A5\u83B7\u53D6\u5931\u8D25: "Failed to get Douban link",
      \u8C46\u74E3ID\u83B7\u53D6\u5931\u8D25: "Failed to get Douban ID",
      \u83B7\u53D6\u8C46\u74E3\u4FE1\u606F\u5931\u8D25: "Failed to get Douban data",
      \u7F3A\u5C11IMDB\u4FE1\u606F: "Missing IMDB information",
      \u83B7\u53D6\u5931\u8D25: "Request failed",
      \u83B7\u53D6\u6210\u529F: "Data request successful",
      \u8BF7\u6C42\u5931\u8D25: "Request failed",
      "\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5": "Upload failed, please try again",
      ptpimg\u4E0A\u4F20\u5931\u8D25: "PtpImg upload failed",
      \u8BF7\u5230\u914D\u7F6E\u9762\u677F\u4E2D\u586B\u5165ptpimg\u7684api_key: "Please enter the API_KEY of ptpimg in the setting panel",
      \u5C01\u9762\u4E0A\u4F20\u5931\u8D25: "Failed to upload poster",
      "\u6570\u636E\u52A0\u8F7D\u4E2D...": "Loading data...",
      \u83B7\u53D6\u56FE\u7247\u5217\u8868\u5931\u8D25: "Failed to get list of images",
      "\u8F6C\u6362\u4E2D...": "Converting...",
      "\u8F6C\u6362\u6210\u529F\uFF01": "Converted!",
      "\u83B7\u53D6\u4E2D...": "Requesting...",
      \u7F3A\u5C11\u8C46\u74E3\u94FE\u63A5: "Missing Douban link",
      "\u672C\u79CD\u5B50\u53EF\u80FD\u7981\u6B62\u8F6C\u8F7D\uFF0C\u786E\u5B9A\u8981\u7EE7\u7EED\u8F6C\u8F7D\u4E48\uFF1F": "Transfer of this torrent may be prohibited, are you sure to continue?",
      \u8BF7\u7B49\u5F85\u9875\u9762\u52A0\u8F7D\u5B8C\u6210: "Please wait for the page to load",
      \u624B\u52A8\u8F93\u5165\u8C46\u74E3\u94FE\u63A5: "Enter the Douban link",
      \u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB: "Get data of Douban",
      \u83B7\u53D6\u8C46\u74E3\u8BFB\u4E66\u7B80\u4ECB: "Get data of Douban Book",
      \u8F6C\u7F29\u7565\u56FE: "Convert to thumbnails",
      \u5FEB\u901F\u68C0\u7D22: "Quick search",
      \u4E00\u952E\u7FA4\u8F6C: "Batch transfer",
      \u5FEB\u6377\u64CD\u4F5C: "Quick operation",
      \u4E00\u952E\u8F6C\u79CD: "Transfer to",
      \u8F6C\u79CD\u7AD9\u70B9\u542F\u7528: "Select sites for the 'Transfer to' section",
      \u6279\u91CF\u8F6C\u79CD\u542F\u7528: "Select sites for the 'Batch transfer' button",
      \u4E00\u952E\u6279\u91CF\u8F6C\u53D1\u5230\u4EE5\u4E0B\u9009\u4E2D\u7684\u7AD9\u70B9: "One-click batch transfer to the selected sites below",
      \u7AD9\u70B9\u641C\u7D22\u542F\u7528: "Select sites for the 'Quick search' section",
      \u56FE\u5E8A\u914D\u7F6E: "Image Host Settings",
      "\u5982\u4F55\u83B7\u53D6\uFF1F": "How to get it?",
      \u989D\u5916\u529F\u80FD\u5173\u95ED: "Turn off extra features",
      \u5173\u95ED\u8F6C\u7F29\u7565\u56FE\u529F\u80FD: "Remove the 'Convert to thumbnails' button",
      \u5173\u95ED\u7AD9\u70B9\u56FE\u6807\u663E\u793A: "Remove the icons",
      \u5173\u95ED\u8F6C\u5B58ptpimg\u529F\u80FD: "Remove the 'Upload screenshots to ptpimg' button",
      \u4FDD\u5B58: "Save",
      \u53D6\u6D88: "Cancel",
      \u9519\u8BEF: "Error",
      \u6210\u529F: "Success",
      \u4FDD\u5B58\u672C\u5730\u7AD9\u70B9\u8BBE\u7F6E\u5931\u8D25: "Failed to save local site settings",
      \u8BF7\u5148\u8BBE\u7F6E\u7FA4\u8F6C\u5217\u8868: "Please set up the batch transfer list first",
      "\u8F6C\u79CD\u9875\u9762\u5DF2\u6253\u5F00\uFF0C\u8BF7\u524D\u5F80\u5BF9\u5E94\u9875\u9762\u64CD\u4F5C": "The transfer pages have been opened, please go to the corresponding page to operate",
      \u63D0\u793A: "Hint",
      \u8F6C\u5B58\u622A\u56FE: "Upload screenshots to another host",
      \u65E0\u9700\u8F6C\u5B58: "No need to upload",
      "\u4E0A\u4F20\u4E2D\uFF0C\u8BF7\u7A0D\u5019...": "Uploading, be patient",
      \u4E0D\u663E\u793A\u81F4\u8C22\u5185\u5BB9: "Do not include thanks",
      \u62F7\u8D1D: "Copy",
      \u5DF2\u62F7\u8D1D: "Copied",
      \u4E0D\u663E\u793A\u8C46\u74E3\u6309\u94AE\u548C\u8C46\u74E3\u94FE\u63A5: "Hide Douban button & link field",
      \u8BF7\u586B\u5199\u6B63\u786E\u94FE\u63A5: "Please fill the correct link",
      \u6279\u91CF\u68C0\u7D22: "Batch search",
      \u540C\u65F6\u6253\u5F00\u591A\u4E2A\u641C\u7D22\u6807\u7B7E\u9875: "Open multiple search tabs at the same time",
      \u8C46\u74E3\u914D\u7F6E: "Douban Config",
      \u8C46\u74E3Cookie: "Douban Cookie",
      \u8BF7\u914D\u7F6E\u8C46\u74E3Cookie: "Please configure douban cookie",
      \u5173\u95ED\u5FEB\u901F\u68C0\u7D22: "Disable QuickSearch",
      \u79CD\u5B50\u6587\u4EF6\u4E0B\u8F7D\u5931\u8D25: "Failed to download torrent file",
      \u8BF7\u624B\u52A8\u4E0B\u8F7D: "Please download it manually"
    },
    ko: {
      \u8C46\u74E3\u94FE\u63A5\u83B7\u53D6\u5931\u8D25: "\uB354\uC6B0\uBC18 \uB9C1\uD06C \uC5BB\uAE30 \uC2E4\uD328",
      \u8C46\u74E3ID\u83B7\u53D6\u5931\u8D25: "\uB354\uC6B0\uBC18 ID \uC544\uC774\uB514 \uC5BB\uAE30 \uC2E4\uD328",
      \u83B7\u53D6\u8C46\u74E3\u4FE1\u606F\u5931\u8D25: "\uB354\uC6B0\uBC18 \uB370\uC774\uD130 \uC5BB\uAE30 \uC2E4\uD328",
      \u7F3A\u5C11IMDB\u4FE1\u606F: "\uB204\uB77D\uB41C IMDB \uC815\uBCF4",
      \u83B7\u53D6\u5931\u8D25: "\uC694\uCCAD \uC2E4\uD328",
      \u83B7\u53D6\u6210\u529F: "\uB370\uC774\uD130 \uC694\uCCAD \uC131\uACF5",
      \u8BF7\u6C42\u5931\u8D25: "\uC694\uCCAD \uC2E4\uD328",
      "\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5": "\uC5C5\uB85C\uB4DC \uC2E4\uD328, \uB2E4\uC2DC \uC2DC\uB3C4\uD558\uC138\uC694.",
      ptpimg\u4E0A\u4F20\u5931\u8D25: "PtpImg \uC5C5\uB85C\uB4DC \uC2E4\uD328",
      \u8BF7\u5230\u914D\u7F6E\u9762\u677F\u4E2D\u586B\u5165ptpimg\u7684api_key: "\uC124\uC815 \uD328\uB110\uC5D0 ptpimg\uC758 API_KEY\uB97C \uC785\uB825\uD558\uC138\uC694.",
      \u5C01\u9762\u4E0A\u4F20\u5931\u8D25: "\uD3EC\uC2A4\uD130 \uC5C5\uB85C\uB4DC \uC2E4\uD328",
      "\u6570\u636E\u52A0\u8F7D\u4E2D...": "\uB370\uC774\uD130 \uBD88\uB7EC\uC624\uAE30 \uC911...",
      \u83B7\u53D6\u56FE\u7247\u5217\u8868\u5931\u8D25: "\uC774\uBBF8\uC9C0 \uBAA9\uB85D \uC5BB\uAE30 \uC2E4\uD328",
      "\u8F6C\u6362\u4E2D...": "\uBCC0\uD658 \uC911...",
      "\u8F6C\u6362\u6210\u529F\uFF01": "\uBCC0\uD658\uB428!",
      "\u83B7\u53D6\u4E2D...": "\uC694\uCCAD \uC911...",
      \u7F3A\u5C11\u8C46\u74E3\u94FE\u63A5: "\uB354\uC6B0\uBC18 \uB9C1\uD06C \uB204\uB77D",
      "\u672C\u79CD\u5B50\u53EF\u80FD\u7981\u6B62\u8F6C\u8F7D\uFF0C\u786E\u5B9A\u8981\u7EE7\u7EED\u8F6C\u8F7D\u4E48\uFF1F": "\uC774 \uD1A0\uB80C\uD2B8\uC758 \uC804\uC1A1\uC774 \uAE08\uC9C0\uB420 \uC218 \uC788\uC2B5\uB2C8\uB2E4, \uACC4\uC18D\uD558\uACA0\uC2B5\uB2C8\uAE4C?",
      \u8BF7\u7B49\u5F85\u9875\u9762\u52A0\u8F7D\u5B8C\u6210: "\uD398\uC774\uC9C0\uAC00 \uBD88\uB7EC\uC62C \uB54C\uAE4C\uC9C0 \uAE30\uB2E4\uB824\uC8FC\uC138\uC694.",
      \u624B\u52A8\u8F93\u5165\u8C46\u74E3\u94FE\u63A5: "\uB354\uC6B0\uBC18 \uB9C1\uD06C \uC785\uB825",
      \u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB: "\uB354\uC6B0\uBC18\uC758 \uB370\uC774\uD130 \uC5BB\uAE30",
      \u83B7\u53D6\u8C46\u74E3\u8BFB\u4E66\u7B80\u4ECB: "\uB354\uC6B0\uBC18 \uB3C4\uC11C \uB370\uC774\uD130 \uC5BB\uAE30",
      \u8F6C\u7F29\u7565\u56FE: "\uC378\uB124\uC77C\uB85C \uBCC0\uD658",
      \u5FEB\u901F\u68C0\u7D22: "\uBE60\uB978 \uAC80\uC0C9",
      \u4E00\u952E\u7FA4\u8F6C: "\uC77C\uAD04 \uC804\uC1A1",
      \u5FEB\u6377\u64CD\u4F5C: "\uBE60\uB978 \uC791\uC5C5",
      \u4E00\u952E\u8F6C\u79CD: "\uC804\uC1A1 \uB300\uC0C1",
      \u8F6C\u79CD\u7AD9\u70B9\u542F\u7528: "\uC804\uC1A1 \uB300\uC0C1 \uC139\uC158\uC758 \uC0AC\uC774\uD2B8 \uC120\uD0DD",
      \u6279\u91CF\u8F6C\u79CD\u542F\u7528: "\uC77C\uAD04 \uC804\uC1A1 \uBC84\uD2BC\uC744 \uC0AC\uC6A9\uD560 \uC0AC\uC774\uD2B8 \uC120\uD0DD",
      \u4E00\u952E\u6279\u91CF\u8F6C\u53D1\u5230\u4EE5\u4E0B\u9009\u4E2D\u7684\u7AD9\u70B9: "\uC544\uB798\uC5D0\uC11C \uC120\uD0DD\uD55C \uC0AC\uC774\uD2B8\uB85C \uC6D0\uD074\uB9AD \uC77C\uAD04 \uC804\uC1A1\uD558\uAE30",
      \u7AD9\u70B9\u641C\u7D22\u542F\u7528: "\uBE60\uB978 \uAC80\uC0C9 \uC139\uC158\uC5D0\uC11C \uC0AC\uC774\uD2B8 \uC120\uD0DD",
      \u56FE\u5E8A\u914D\u7F6E: "\uC774\uBBF8\uC9C0 \uD638\uC2A4\uD2B8 \uC124\uC815",
      "\u5982\u4F55\u83B7\u53D6\uFF1F": "\uC5B4\uB5BB\uAC8C \uC5BB\uB098\uC694?",
      \u989D\u5916\u529F\u80FD\u5173\u95ED: "\uCD94\uAC00 \uAE30\uB2A5 \uB044\uAE30",
      \u5173\u95ED\u8F6C\u7F29\u7565\u56FE\u529F\u80FD: "\uC378\uB124\uC77C\uB85C \uBCC0\uD658 \uBC84\uD2BC \uC81C\uAC70\uD558\uAE30",
      \u5173\u95ED\u7AD9\u70B9\u56FE\u6807\u663E\u793A: "\uC544\uC774\uCF58 \uC81C\uAC70\uD558\uAE30",
      \u5173\u95ED\u8F6C\u5B58ptpimg\u529F\u80FD: "\uC2A4\uD06C\uB9B0\uC0F7\uC744 ptpimg\uC5D0 \uC5C5\uB85C\uB4DC \uBC84\uD2BC \uC81C\uAC70\uD558\uAE30",
      \u4FDD\u5B58: "\uC800\uC7A5",
      \u53D6\u6D88: "\uCDE8\uC18C",
      \u9519\u8BEF: "\uC624\uB958",
      \u6210\u529F: "\uC131\uACF5",
      \u4FDD\u5B58\u672C\u5730\u7AD9\u70B9\u8BBE\u7F6E\u5931\u8D25: "\uB85C\uCEEC \uC0AC\uC774\uD2B8 \uC124\uC815 \uC800\uC7A5 \uC2E4\uD328",
      \u8BF7\u5148\u8BBE\u7F6E\u7FA4\u8F6C\u5217\u8868: "\uBA3C\uC800 \uC77C\uAD04 \uC804\uC1A1 \uBAA9\uB85D \uC124\uC815",
      "\u8F6C\u79CD\u9875\u9762\u5DF2\u6253\u5F00\uFF0C\u8BF7\u524D\u5F80\u5BF9\u5E94\u9875\u9762\u64CD\u4F5C": "\uC804\uC1A1 \uD398\uC774\uC9C0\uAC00 \uC5F4\uB838\uACE0, \uD574\uB2F9 \uD398\uC774\uC9C0\uB85C \uC774\uB3D9\uD558\uC5EC \uC791\uC5C5",
      \u63D0\u793A: "\uD78C\uD2B8",
      \u8F6C\u5B58\u622A\u56FE: "\uB2E4\uB978 \uD638\uC2A4\uD2B8\uC5D0 \uC2A4\uD06C\uB9B0\uC0F7 \uC5C5\uB85C\uB4DC",
      \u65E0\u9700\u8F6C\u5B58: "\uC5C5\uB85C\uB4DC\uD560 \uD544\uC694 \uC5C6\uC74C",
      "\u4E0A\u4F20\u4E2D\uFF0C\u8BF7\u7A0D\u5019...": "\uC5C5\uB85C\uB4DC \uC911, \uC7A0\uC2DC\uB9CC \uAE30\uB2E4\uB824\uC8FC\uC138\uC694.",
      \u4E0D\u663E\u793A\u81F4\u8C22\u5185\u5BB9: "\uAC10\uC0AC \uB0B4\uC6A9\uC744 \uD3EC\uD568\uD558\uC9C0 \uC54A\uC74C",
      \u62F7\u8D1D: "\uBCF5\uC0AC",
      \u5DF2\u62F7\u8D1D: "\uBCF5\uC0AC\uB428",
      \u4E0D\u663E\u793A\u8C46\u74E3\u6309\u94AE\u548C\u8C46\u74E3\u94FE\u63A5: "\uB354\uC6B0\uBC18 \uBC84\uD2BC \uBC0F \uB9C1\uD06C \uD544\uB4DC \uC228\uAE30\uAE30",
      \u8BF7\u586B\u5199\u6B63\u786E\u94FE\u63A5: "\uC62C\uBC14\uB978 \uB9C1\uD06C\uB97C \uC785\uB825\uD558\uC138\uC694.",
      \u6279\u91CF\u68C0\u7D22: "\uC77C\uAD04 \uAC80\uC0C9",
      \u540C\u65F6\u6253\u5F00\u591A\u4E2A\u641C\u7D22\u6807\u7B7E\u9875: "\uC5EC\uB7EC \uAC80\uC0C9 \uD0ED \uB3D9\uC2DC\uC5D0 \uC5F4\uAE30",
      \u8C46\u74E3\u914D\u7F6E: "\uB354\uC6B0\uBC18 \uAD6C\uC131",
      \u8C46\u74E3Cookie: "\uB354\uC6B0\uBC18 \uCFE0\uD0A4",
      \u8BF7\u914D\u7F6E\u8C46\u74E3Cookie: "\uB354\uC6B0\uBC18 \uCFE0\uD0A4\uB97C \uAD6C\uC131\uD558\uC138\uC694.",
      \u5173\u95ED\u5FEB\u901F\u68C0\u7D22: "\uBE60\uB978\uAC80\uC0C9 \uBE44\uD65C\uC131\uD654",
      \u79CD\u5B50\u6587\u4EF6\u4E0B\u8F7D\u5931\u8D25: "\uD1A0\uB80C\uD2B8 \uD30C\uC77C \uB2E4\uC6B4\uB85C\uB4DC \uC2E4\uD328",
      \u8BF7\u624B\u52A8\u4E0B\u8F7D: "\uC218\uB3D9\uC73C\uB85C \uB2E4\uC6B4\uB85C\uB4DC\uD574\uC8FC\uC138\uC694"
    },
    zh: {
      \u8C46\u74E3\u94FE\u63A5\u83B7\u53D6\u5931\u8D25: "\u8C46\u74E3\u94FE\u63A5\u83B7\u53D6\u5931\u8D25",
      \u8C46\u74E3ID\u83B7\u53D6\u5931\u8D25: "\u8C46\u74E3ID\u83B7\u53D6\u5931\u8D25",
      \u83B7\u53D6\u8C46\u74E3\u4FE1\u606F\u5931\u8D25: "\u83B7\u53D6\u8C46\u74E3\u4FE1\u606F\u5931\u8D25",
      \u7F3A\u5C11IMDB\u4FE1\u606F: "\u7F3A\u5C11IMDB\u4FE1\u606F",
      \u83B7\u53D6\u5931\u8D25: "\u83B7\u53D6\u5931\u8D25",
      \u83B7\u53D6\u6210\u529F: "\u83B7\u53D6\u6210\u529F",
      \u8BF7\u6C42\u5931\u8D25: "\u8BF7\u6C42\u5931\u8D25",
      "\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5": "\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5",
      ptpimg\u4E0A\u4F20\u5931\u8D25: "ptpimg\u4E0A\u4F20\u5931\u8D25",
      \u8BF7\u5230\u914D\u7F6E\u9762\u677F\u4E2D\u586B\u5165ptpimg\u7684api_key: "\u8BF7\u5230\u914D\u7F6E\u9762\u677F\u4E2D\u586B\u5165ptpimg\u7684api_key",
      \u5C01\u9762\u4E0A\u4F20\u5931\u8D25: "\u5C01\u9762\u4E0A\u4F20\u5931\u8D25",
      "\u6570\u636E\u52A0\u8F7D\u4E2D...": "\u6570\u636E\u52A0\u8F7D\u4E2D...",
      \u83B7\u53D6\u56FE\u7247\u5217\u8868\u5931\u8D25: "\u83B7\u53D6\u56FE\u7247\u5217\u8868\u5931\u8D25",
      "\u8F6C\u6362\u4E2D...": "\u8F6C\u6362\u4E2D...",
      "\u8F6C\u6362\u6210\u529F\uFF01": "\u8F6C\u6362\u6210\u529F\uFF01",
      "\u83B7\u53D6\u4E2D...": "\u83B7\u53D6\u4E2D...",
      \u7F3A\u5C11\u8C46\u74E3\u94FE\u63A5: "\u7F3A\u5C11\u8C46\u74E3\u94FE\u63A5",
      "\u672C\u79CD\u5B50\u53EF\u80FD\u7981\u6B62\u8F6C\u8F7D\uFF0C\u786E\u5B9A\u8981\u7EE7\u7EED\u8F6C\u8F7D\u4E48\uFF1F": "\u672C\u79CD\u5B50\u53EF\u80FD\u7981\u6B62\u8F6C\u8F7D\uFF0C\u786E\u5B9A\u8981\u7EE7\u7EED\u8F6C\u8F7D\u4E48\uFF1F",
      \u8BF7\u7B49\u5F85\u9875\u9762\u52A0\u8F7D\u5B8C\u6210: "\u8BF7\u7B49\u5F85\u9875\u9762\u52A0\u8F7D\u5B8C\u6210",
      \u624B\u52A8\u8F93\u5165\u8C46\u74E3\u94FE\u63A5: "\u624B\u52A8\u8F93\u5165\u8C46\u74E3\u94FE\u63A5",
      \u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB: "\u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB",
      \u83B7\u53D6\u8C46\u74E3\u8BFB\u4E66\u7B80\u4ECB: "\u83B7\u53D6\u8C46\u74E3\u8BFB\u4E66\u7B80\u4ECB",
      \u8F6C\u7F29\u7565\u56FE: "\u8F6C\u7F29\u7565\u56FE",
      \u5FEB\u901F\u68C0\u7D22: "\u5FEB\u901F\u68C0\u7D22",
      \u4E00\u952E\u7FA4\u8F6C: "\u4E00\u952E\u7FA4\u8F6C",
      \u5FEB\u6377\u64CD\u4F5C: "\u5FEB\u6377\u64CD\u4F5C",
      \u4E00\u952E\u8F6C\u79CD: "\u4E00\u952E\u8F6C\u79CD",
      \u8F6C\u79CD\u7AD9\u70B9\u542F\u7528: "\u8F6C\u79CD\u7AD9\u70B9\u542F\u7528",
      \u6279\u91CF\u8F6C\u79CD\u542F\u7528: "\u6279\u91CF\u8F6C\u79CD\u542F\u7528",
      \u4E00\u952E\u6279\u91CF\u8F6C\u53D1\u5230\u4EE5\u4E0B\u9009\u4E2D\u7684\u7AD9\u70B9: "\u4E00\u952E\u6279\u91CF\u8F6C\u53D1\u5230\u4EE5\u4E0B\u9009\u4E2D\u7684\u7AD9\u70B9",
      \u7AD9\u70B9\u641C\u7D22\u542F\u7528: "\u7AD9\u70B9\u641C\u7D22\u542F\u7528",
      \u56FE\u5E8A\u914D\u7F6E: "\u56FE\u5E8A\u914D\u7F6E",
      "\u5982\u4F55\u83B7\u53D6\uFF1F": "\u5982\u4F55\u83B7\u53D6\uFF1F",
      \u989D\u5916\u529F\u80FD\u5173\u95ED: "\u989D\u5916\u529F\u80FD\u5173\u95ED",
      \u5173\u95ED\u8F6C\u7F29\u7565\u56FE\u529F\u80FD: "\u5173\u95ED\u8F6C\u7F29\u7565\u56FE\u529F\u80FD",
      \u5173\u95ED\u7AD9\u70B9\u56FE\u6807\u663E\u793A: "\u5173\u95ED\u7AD9\u70B9\u56FE\u6807\u663E\u793A",
      \u5173\u95ED\u8F6C\u5B58ptpimg\u529F\u80FD: "\u5173\u95ED\u8F6C\u5B58ptpimg\u529F\u80FD",
      \u4FDD\u5B58: "\u4FDD\u5B58",
      \u53D6\u6D88: "\u53D6\u6D88",
      \u9519\u8BEF: "\u9519\u8BEF",
      \u6210\u529F: "\u6210\u529F",
      \u4FDD\u5B58\u672C\u5730\u7AD9\u70B9\u8BBE\u7F6E\u5931\u8D25: "\u4FDD\u5B58\u672C\u5730\u7AD9\u70B9\u8BBE\u7F6E\u5931\u8D25",
      \u8BF7\u5148\u8BBE\u7F6E\u7FA4\u8F6C\u5217\u8868: "\u8BF7\u5148\u8BBE\u7F6E\u7FA4\u8F6C\u5217\u8868",
      "\u8F6C\u79CD\u9875\u9762\u5DF2\u6253\u5F00\uFF0C\u8BF7\u524D\u5F80\u5BF9\u5E94\u9875\u9762\u64CD\u4F5C": "\u8F6C\u79CD\u9875\u9762\u5DF2\u6253\u5F00\uFF0C\u8BF7\u524D\u5F80\u5BF9\u5E94\u9875\u9762\u64CD\u4F5C",
      \u63D0\u793A: "\u63D0\u793A",
      \u8F6C\u5B58\u622A\u56FE: "\u8F6C\u5B58\u622A\u56FE",
      \u65E0\u9700\u8F6C\u5B58: "\u65E0\u9700\u8F6C\u5B58",
      "\u4E0A\u4F20\u4E2D\uFF0C\u8BF7\u7A0D\u5019...": "\u4E0A\u4F20\u4E2D\uFF0C\u8BF7\u7A0D\u5019...",
      \u4E0D\u663E\u793A\u81F4\u8C22\u5185\u5BB9: "\u4E0D\u663E\u793A\u81F4\u8C22\u5185\u5BB9",
      \u62F7\u8D1D: "\u62F7\u8D1D",
      \u5DF2\u62F7\u8D1D: "\u5DF2\u62F7\u8D1D",
      \u4E0D\u663E\u793A\u8C46\u74E3\u6309\u94AE\u548C\u8C46\u74E3\u94FE\u63A5: "\u4E0D\u663E\u793A\u8C46\u74E3\u6309\u94AE\u548C\u8C46\u74E3\u94FE\u63A5",
      \u8BF7\u586B\u5199\u6B63\u786E\u94FE\u63A5: "\u8BF7\u586B\u5199\u6B63\u786E\u94FE\u63A5",
      \u6279\u91CF\u68C0\u7D22: "\u6279\u91CF\u68C0\u7D22",
      \u540C\u65F6\u6253\u5F00\u591A\u4E2A\u641C\u7D22\u6807\u7B7E\u9875: "\u540C\u65F6\u6253\u5F00\u591A\u4E2A\u641C\u7D22\u6807\u7B7E\u9875",
      \u8C46\u74E3\u914D\u7F6E: "\u8C46\u74E3\u914D\u7F6E",
      \u8C46\u74E3Cookie: "\u8C46\u74E3Cookie",
      \u8BF7\u914D\u7F6E\u8C46\u74E3Cookie: "\u8BF7\u914D\u7F6E\u8C46\u74E3Cookie",
      \u5173\u95ED\u5FEB\u901F\u68C0\u7D22: "\u5173\u95ED\u5FEB\u901F\u68C0\u7D22",
      \u79CD\u5B50\u6587\u4EF6\u4E0B\u8F7D\u5931\u8D25: "\u79CD\u5B50\u6587\u4EF6\u4E0B\u8F7D\u5931\u8D25",
      \u8BF7\u624B\u52A8\u4E0B\u8F7D: "\u8BF7\u624B\u52A8\u4E0B\u8F7D"
    }
  };

  // src/components/Notification.tsx
  init_preact_shim();

  // node_modules/rc-notification/es/index.js
  init_preact_shim();

  // node_modules/rc-notification/es/Notification.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/objectWithoutPropertiesLoose.js
  init_preact_shim();
  function _objectWithoutPropertiesLoose(source, excluded) {
    if (source == null) return {};
    var target = {};
    var sourceKeys = Object.keys(source);
    var key, i3;
    for (i3 = 0; i3 < sourceKeys.length; i3++) {
      key = sourceKeys[i3];
      if (excluded.indexOf(key) >= 0) continue;
      target[key] = source[key];
    }
    return target;
  }

  // node_modules/@babel/runtime/helpers/esm/objectWithoutProperties.js
  function _objectWithoutProperties(source, excluded) {
    if (source == null) return {};
    var target = _objectWithoutPropertiesLoose(source, excluded);
    var key, i3;
    if (Object.getOwnPropertySymbols) {
      var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
      for (i3 = 0; i3 < sourceSymbolKeys.length; i3++) {
        key = sourceSymbolKeys[i3];
        if (excluded.indexOf(key) >= 0) continue;
        if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
        target[key] = source[key];
      }
    }
    return target;
  }

  // node_modules/@babel/runtime/helpers/esm/defineProperty.js
  init_preact_shim();
  function _defineProperty(obj, key, value) {
    if (key in obj) {
      Object.defineProperty(obj, key, {
        value,
        enumerable: true,
        configurable: true,
        writable: true
      });
    } else {
      obj[key] = value;
    }
    return obj;
  }

  // node_modules/@babel/runtime/helpers/esm/classCallCheck.js
  init_preact_shim();
  function _classCallCheck(instance, Constructor) {
    if (!(instance instanceof Constructor)) {
      throw new TypeError("Cannot call a class as a function");
    }
  }

  // node_modules/@babel/runtime/helpers/esm/createClass.js
  init_preact_shim();
  function _defineProperties(target, props) {
    for (var i3 = 0; i3 < props.length; i3++) {
      var descriptor = props[i3];
      descriptor.enumerable = descriptor.enumerable || false;
      descriptor.configurable = true;
      if ("value" in descriptor) descriptor.writable = true;
      Object.defineProperty(target, descriptor.key, descriptor);
    }
  }
  function _createClass(Constructor, protoProps, staticProps) {
    if (protoProps) _defineProperties(Constructor.prototype, protoProps);
    if (staticProps) _defineProperties(Constructor, staticProps);
    Object.defineProperty(Constructor, "prototype", {
      writable: false
    });
    return Constructor;
  }

  // node_modules/@babel/runtime/helpers/esm/inherits.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/setPrototypeOf.js
  init_preact_shim();
  function _setPrototypeOf(o4, p3) {
    _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function _setPrototypeOf2(o5, p4) {
      o5.__proto__ = p4;
      return o5;
    };
    return _setPrototypeOf(o4, p3);
  }

  // node_modules/@babel/runtime/helpers/esm/inherits.js
  function _inherits(subClass, superClass) {
    if (typeof superClass !== "function" && superClass !== null) {
      throw new TypeError("Super expression must either be null or a function");
    }
    subClass.prototype = Object.create(superClass && superClass.prototype, {
      constructor: {
        value: subClass,
        writable: true,
        configurable: true
      }
    });
    Object.defineProperty(subClass, "prototype", {
      writable: false
    });
    if (superClass) _setPrototypeOf(subClass, superClass);
  }

  // node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/typeof.js
  init_preact_shim();
  function _typeof(obj) {
    "@babel/helpers - typeof";
    return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function(obj2) {
      return typeof obj2;
    } : function(obj2) {
      return obj2 && "function" == typeof Symbol && obj2.constructor === Symbol && obj2 !== Symbol.prototype ? "symbol" : typeof obj2;
    }, _typeof(obj);
  }

  // node_modules/@babel/runtime/helpers/esm/assertThisInitialized.js
  init_preact_shim();
  function _assertThisInitialized(self2) {
    if (self2 === void 0) {
      throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
    }
    return self2;
  }

  // node_modules/@babel/runtime/helpers/esm/possibleConstructorReturn.js
  function _possibleConstructorReturn(self2, call) {
    if (call && (_typeof(call) === "object" || typeof call === "function")) {
      return call;
    } else if (call !== void 0) {
      throw new TypeError("Derived constructors may only return object or undefined");
    }
    return _assertThisInitialized(self2);
  }

  // node_modules/@babel/runtime/helpers/esm/getPrototypeOf.js
  init_preact_shim();
  function _getPrototypeOf(o4) {
    _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function _getPrototypeOf2(o5) {
      return o5.__proto__ || Object.getPrototypeOf(o5);
    };
    return _getPrototypeOf(o4);
  }

  // node_modules/react/index.mjs
  init_preact_shim();

  // node_modules/preact/compat/dist/compat.module.js
  init_preact_shim();

  // node_modules/preact/hooks/dist/hooks.module.js
  init_preact_shim();
  init_preact_module();
  var t2;
  var u2;
  var r2;
  var o2;
  var i2 = 0;
  var c2 = [];
  var f2 = l.__b;
  var e2 = l.__r;
  var a2 = l.diffed;
  var v2 = l.__c;
  var l2 = l.unmount;
  function m2(t3, r3) {
    l.__h && l.__h(u2, t3, i2 || r3), i2 = 0;
    var o4 = u2.__H || (u2.__H = { __: [], __h: [] });
    return t3 >= o4.__.length && o4.__.push({}), o4.__[t3];
  }
  function d2(n2) {
    return i2 = 1, p2(z2, n2);
  }
  function p2(n2, r3, o4) {
    var i3 = m2(t2++, 2);
    return i3.t = n2, i3.__c || (i3.__ = [o4 ? o4(r3) : z2(void 0, r3), function(n3) {
      var t3 = i3.t(i3.__[0], n3);
      i3.__[0] !== t3 && (i3.__ = [t3, i3.__[1]], i3.__c.setState({}));
    }], i3.__c = u2), i3.__;
  }
  function y2(r3, o4) {
    var i3 = m2(t2++, 3);
    !l.__s && w2(i3.__H, o4) && (i3.__ = r3, i3.u = o4, u2.__H.__h.push(i3));
  }
  function h2(r3, o4) {
    var i3 = m2(t2++, 4);
    !l.__s && w2(i3.__H, o4) && (i3.__ = r3, i3.u = o4, u2.__h.push(i3));
  }
  function s2(n2) {
    return i2 = 5, A2(function() {
      return { current: n2 };
    }, []);
  }
  function _2(n2, t3, u3) {
    i2 = 6, h2(function() {
      return "function" == typeof n2 ? (n2(t3()), function() {
        return n2(null);
      }) : n2 ? (n2.current = t3(), function() {
        return n2.current = null;
      }) : void 0;
    }, null == u3 ? u3 : u3.concat(n2));
  }
  function A2(n2, u3) {
    var r3 = m2(t2++, 7);
    return w2(r3.__H, u3) ? (r3.o = n2(), r3.u = u3, r3.__h = n2, r3.o) : r3.__;
  }
  function F(n2, t3) {
    return i2 = 8, A2(function() {
      return n2;
    }, t3);
  }
  function T2(n2) {
    var r3 = u2.context[n2.__c], o4 = m2(t2++, 9);
    return o4.c = n2, r3 ? (null == o4.__ && (o4.__ = true, r3.sub(u2)), r3.props.value) : n2.__;
  }
  function q2(t3, u3) {
    l.useDebugValue && l.useDebugValue(u3 ? u3(t3) : t3);
  }
  function b2() {
    for (var t3; t3 = c2.shift(); ) if (t3.__P) try {
      t3.__H.__h.forEach(j2), t3.__H.__h.forEach(k2), t3.__H.__h = [];
    } catch (u3) {
      t3.__H.__h = [], l.__e(u3, t3.__v);
    }
  }
  l.__b = function(n2) {
    u2 = null, f2 && f2(n2);
  }, l.__r = function(n2) {
    e2 && e2(n2), t2 = 0;
    var o4 = (u2 = n2.__c).__H;
    o4 && (r2 === u2 ? (o4.__h = [], u2.__h = [], o4.__.forEach(function(n3) {
      n3.o = n3.u = void 0;
    })) : (o4.__.forEach(function(n3) {
      n3.u && (n3.__H = n3.u), n3.o && (n3.__ = n3.o), n3.o = n3.u = void 0;
    }), o4.__h.forEach(j2), o4.__h.forEach(k2), o4.__h = [])), r2 = u2;
  }, l.diffed = function(t3) {
    a2 && a2(t3);
    var i3 = t3.__c;
    i3 && i3.__H && i3.__H.__h.length && (1 !== c2.push(i3) && o2 === l.requestAnimationFrame || ((o2 = l.requestAnimationFrame) || function(n2) {
      var t4, u3 = function() {
        clearTimeout(r3), g2 && cancelAnimationFrame(t4), setTimeout(n2);
      }, r3 = setTimeout(u3, 100);
      g2 && (t4 = requestAnimationFrame(u3));
    })(b2)), u2 = null, r2 = null;
  }, l.__c = function(t3, u3) {
    u3.some(function(t4) {
      try {
        t4.__H && t4.__H.__.forEach(function(n2) {
          n2.u && (n2.__H = n2.u), n2.o && (n2.__ = n2.o), n2.o = n2.u = void 0;
        }), t4.__h.forEach(j2), t4.__h = t4.__h.filter(function(n2) {
          return !n2.__ || k2(n2);
        });
      } catch (r3) {
        u3.some(function(n2) {
          n2.__h && (n2.__h = []);
        }), u3 = [], l.__e(r3, t4.__v);
      }
    }), v2 && v2(t3, u3);
  }, l.unmount = function(t3) {
    l2 && l2(t3);
    var u3, r3 = t3.__c;
    r3 && r3.__H && (r3.__H.__.forEach(function(n2) {
      try {
        j2(n2);
      } catch (n3) {
        u3 = n3;
      }
    }), u3 && l.__e(u3, r3.__v));
  };
  var g2 = "function" == typeof requestAnimationFrame;
  function j2(n2) {
    var t3 = u2, r3 = n2.__c;
    "function" == typeof r3 && (n2.__c = void 0, r3()), u2 = t3;
  }
  function k2(n2) {
    var t3 = u2;
    n2.__c = n2.__(), u2 = t3;
  }
  function w2(n2, t3) {
    return !n2 || n2.length !== t3.length || t3.some(function(t4, u3) {
      return t4 !== n2[u3];
    });
  }
  function z2(n2, t3) {
    return "function" == typeof t3 ? t3(n2) : t3;
  }

  // node_modules/preact/compat/dist/compat.module.js
  init_preact_module();
  init_preact_module();
  function C2(n2, t3) {
    for (var e4 in t3) n2[e4] = t3[e4];
    return n2;
  }
  function S2(n2, t3) {
    for (var e4 in n2) if ("__source" !== e4 && !(e4 in t3)) return true;
    for (var r3 in t3) if ("__source" !== r3 && n2[r3] !== t3[r3]) return true;
    return false;
  }
  function E(n2) {
    this.props = n2;
  }
  function g3(n2, t3) {
    function e4(n3) {
      var e5 = this.props.ref, r4 = e5 == n3.ref;
      return !r4 && e5 && (e5.call ? e5(null) : e5.current = null), t3 ? !t3(this.props, n3) || !r4 : S2(this.props, n3);
    }
    function r3(t4) {
      return this.shouldComponentUpdate = e4, v(n2, t4);
    }
    return r3.displayName = "Memo(" + (n2.displayName || n2.name) + ")", r3.prototype.isReactComponent = true, r3.__f = true, r3;
  }
  (E.prototype = new _()).isPureReactComponent = true, E.prototype.shouldComponentUpdate = function(n2, t3) {
    return S2(this.props, n2) || S2(this.state, t3);
  };
  var w3 = l.__b;
  l.__b = function(n2) {
    n2.type && n2.type.__f && n2.ref && (n2.props.ref = n2.ref, n2.ref = null), w3 && w3(n2);
  };
  var R = "undefined" != typeof Symbol && Symbol.for && Symbol.for("react.forward_ref") || 3911;
  function x2(n2) {
    function t3(t4) {
      var e4 = C2({}, t4);
      return delete e4.ref, n2(e4, t4.ref || null);
    }
    return t3.$$typeof = R, t3.render = t3, t3.prototype.isReactComponent = t3.__f = true, t3.displayName = "ForwardRef(" + (n2.displayName || n2.name) + ")", t3;
  }
  var N2 = function(n2, t3) {
    return null == n2 ? null : A(A(n2).map(t3));
  };
  var k3 = { map: N2, forEach: N2, count: function(n2) {
    return n2 ? A(n2).length : 0;
  }, only: function(n2) {
    var t3 = A(n2);
    if (1 !== t3.length) throw "Children.only";
    return t3[0];
  }, toArray: A };
  var A3 = l.__e;
  l.__e = function(n2, t3, e4, r3) {
    if (n2.then) {
      for (var u3, o4 = t3; o4 = o4.__; ) if ((u3 = o4.__c) && u3.__c) return null == t3.__e && (t3.__e = e4.__e, t3.__k = e4.__k), u3.__c(n2, t3);
    }
    A3(n2, t3, e4, r3);
  };
  var O2 = l.unmount;
  function L2() {
    this.__u = 0, this.t = null, this.__b = null;
  }
  function U(n2) {
    var t3 = n2.__.__c;
    return t3 && t3.__e && t3.__e(n2);
  }
  function F2(n2) {
    var t3, e4, r3;
    function u3(u4) {
      if (t3 || (t3 = n2()).then(function(n3) {
        e4 = n3.default || n3;
      }, function(n3) {
        r3 = n3;
      }), r3) throw r3;
      if (!e4) throw t3;
      return v(e4, u4);
    }
    return u3.displayName = "Lazy", u3.__f = true, u3;
  }
  function M2() {
    this.u = null, this.o = null;
  }
  l.unmount = function(n2) {
    var t3 = n2.__c;
    t3 && t3.__R && t3.__R(), t3 && true === n2.__h && (n2.type = null), O2 && O2(n2);
  }, (L2.prototype = new _()).__c = function(n2, t3) {
    var e4 = t3.__c, r3 = this;
    null == r3.t && (r3.t = []), r3.t.push(e4);
    var u3 = U(r3.__v), o4 = false, i3 = function() {
      o4 || (o4 = true, e4.__R = null, u3 ? u3(l3) : l3());
    };
    e4.__R = i3;
    var l3 = function() {
      if (!--r3.__u) {
        if (r3.state.__e) {
          var n3 = r3.state.__e;
          r3.__v.__k[0] = function n4(t5, e5, r4) {
            return t5 && (t5.__v = null, t5.__k = t5.__k && t5.__k.map(function(t6) {
              return n4(t6, e5, r4);
            }), t5.__c && t5.__c.__P === e5 && (t5.__e && r4.insertBefore(t5.__e, t5.__d), t5.__c.__e = true, t5.__c.__P = r4)), t5;
          }(n3, n3.__c.__P, n3.__c.__O);
        }
        var t4;
        for (r3.setState({ __e: r3.__b = null }); t4 = r3.t.pop(); ) t4.forceUpdate();
      }
    }, f3 = true === t3.__h;
    r3.__u++ || f3 || r3.setState({ __e: r3.__b = r3.__v.__k[0] }), n2.then(i3, i3);
  }, L2.prototype.componentWillUnmount = function() {
    this.t = [];
  }, L2.prototype.render = function(n2, t3) {
    if (this.__b) {
      if (this.__v.__k) {
        var e4 = document.createElement("div"), r3 = this.__v.__k[0].__c;
        this.__v.__k[0] = function n3(t4, e5, r4) {
          return t4 && (t4.__c && t4.__c.__H && (t4.__c.__H.__.forEach(function(n4) {
            "function" == typeof n4.__c && n4.__c();
          }), t4.__c.__H = null), null != (t4 = C2({}, t4)).__c && (t4.__c.__P === r4 && (t4.__c.__P = e5), t4.__c = null), t4.__k = t4.__k && t4.__k.map(function(t5) {
            return n3(t5, e5, r4);
          })), t4;
        }(this.__b, e4, r3.__O = r3.__P);
      }
      this.__b = null;
    }
    var u3 = t3.__e && v(d, null, n2.fallback);
    return u3 && (u3.__h = null), [v(d, null, t3.__e ? null : n2.children), u3];
  };
  var T3 = function(n2, t3, e4) {
    if (++e4[1] === e4[0] && n2.o.delete(t3), n2.props.revealOrder && ("t" !== n2.props.revealOrder[0] || !n2.o.size)) for (e4 = n2.u; e4; ) {
      for (; e4.length > 3; ) e4.pop()();
      if (e4[1] < e4[0]) break;
      n2.u = e4 = e4[2];
    }
  };
  function D2(n2) {
    return this.getChildContext = function() {
      return n2.context;
    }, n2.children;
  }
  function I2(n2) {
    var t3 = this, e4 = n2.i;
    t3.componentWillUnmount = function() {
      S(null, t3.l), t3.l = null, t3.i = null;
    }, t3.i && t3.i !== e4 && t3.componentWillUnmount(), n2.__v ? (t3.l || (t3.i = e4, t3.l = { nodeType: 1, parentNode: e4, childNodes: [], appendChild: function(n3) {
      this.childNodes.push(n3), t3.i.appendChild(n3);
    }, insertBefore: function(n3, e5) {
      this.childNodes.push(n3), t3.i.appendChild(n3);
    }, removeChild: function(n3) {
      this.childNodes.splice(this.childNodes.indexOf(n3) >>> 1, 1), t3.i.removeChild(n3);
    } }), S(v(D2, { context: t3.context }, n2.__v), t3.l)) : t3.l && t3.componentWillUnmount();
  }
  function W(n2, t3) {
    var e4 = v(I2, { __v: n2, i: t3 });
    return e4.containerInfo = t3, e4;
  }
  (M2.prototype = new _()).__e = function(n2) {
    var t3 = this, e4 = U(t3.__v), r3 = t3.o.get(n2);
    return r3[0]++, function(u3) {
      var o4 = function() {
        t3.props.revealOrder ? (r3.push(u3), T3(t3, n2, r3)) : u3();
      };
      e4 ? e4(o4) : o4();
    };
  }, M2.prototype.render = function(n2) {
    this.u = null, this.o = /* @__PURE__ */ new Map();
    var t3 = A(n2.children);
    n2.revealOrder && "b" === n2.revealOrder[0] && t3.reverse();
    for (var e4 = t3.length; e4--; ) this.o.set(t3[e4], this.u = [1, 0, this.u]);
    return n2.children;
  }, M2.prototype.componentDidUpdate = M2.prototype.componentDidMount = function() {
    var n2 = this;
    this.o.forEach(function(t3, e4) {
      T3(n2, e4, t3);
    });
  };
  var P2 = "undefined" != typeof Symbol && Symbol.for && Symbol.for("react.element") || 60103;
  var V = /^(?:accent|alignment|arabic|baseline|cap|clip(?!PathU)|color|dominant|fill|flood|font|glyph(?!R)|horiz|marker(?!H|W|U)|overline|paint|stop|strikethrough|stroke|text(?!L)|underline|unicode|units|v|vector|vert|word|writing|x(?!C))[A-Z]/;
  var j3 = "undefined" != typeof document;
  var z3 = function(n2) {
    return ("undefined" != typeof Symbol && "symbol" == typeof Symbol() ? /fil|che|rad/i : /fil|che|ra/i).test(n2);
  };
  function B2(n2, t3, e4) {
    return null == t3.__k && (t3.textContent = ""), S(n2, t3), "function" == typeof e4 && e4(), n2 ? n2.__c : null;
  }
  function $3(n2, t3, e4) {
    return q(n2, t3), "function" == typeof e4 && e4(), n2 ? n2.__c : null;
  }
  _.prototype.isReactComponent = {}, ["componentWillMount", "componentWillReceiveProps", "componentWillUpdate"].forEach(function(n2) {
    Object.defineProperty(_.prototype, n2, { configurable: true, get: function() {
      return this["UNSAFE_" + n2];
    }, set: function(t3) {
      Object.defineProperty(this, n2, { configurable: true, writable: true, value: t3 });
    } });
  });
  var H2 = l.event;
  function Z() {
  }
  function Y() {
    return this.cancelBubble;
  }
  function q3() {
    return this.defaultPrevented;
  }
  l.event = function(n2) {
    return H2 && (n2 = H2(n2)), n2.persist = Z, n2.isPropagationStopped = Y, n2.isDefaultPrevented = q3, n2.nativeEvent = n2;
  };
  var G;
  var J = { configurable: true, get: function() {
    return this.class;
  } };
  var K = l.vnode;
  l.vnode = function(n2) {
    var t3 = n2.type, e4 = n2.props, r3 = e4;
    if ("string" == typeof t3) {
      var u3 = -1 === t3.indexOf("-");
      for (var o4 in r3 = {}, e4) {
        var i3 = e4[o4];
        j3 && "children" === o4 && "noscript" === t3 || "value" === o4 && "defaultValue" in e4 && null == i3 || ("defaultValue" === o4 && "value" in e4 && null == e4.value ? o4 = "value" : "download" === o4 && true === i3 ? i3 = "" : /ondoubleclick/i.test(o4) ? o4 = "ondblclick" : /^onchange(textarea|input)/i.test(o4 + t3) && !z3(e4.type) ? o4 = "oninput" : /^onfocus$/i.test(o4) ? o4 = "onfocusin" : /^onblur$/i.test(o4) ? o4 = "onfocusout" : /^on(Ani|Tra|Tou|BeforeInp|Compo)/.test(o4) ? o4 = o4.toLowerCase() : u3 && V.test(o4) ? o4 = o4.replace(/[A-Z0-9]/, "-$&").toLowerCase() : null === i3 && (i3 = void 0), /^oninput/i.test(o4) && (o4 = o4.toLowerCase(), r3[o4] && (o4 = "oninputCapture")), r3[o4] = i3);
      }
      "select" == t3 && r3.multiple && Array.isArray(r3.value) && (r3.value = A(e4.children).forEach(function(n3) {
        n3.props.selected = -1 != r3.value.indexOf(n3.props.value);
      })), "select" == t3 && null != r3.defaultValue && (r3.value = A(e4.children).forEach(function(n3) {
        n3.props.selected = r3.multiple ? -1 != r3.defaultValue.indexOf(n3.props.value) : r3.defaultValue == n3.props.value;
      })), n2.props = r3, e4.class != e4.className && (J.enumerable = "className" in e4, null != e4.className && (r3.class = e4.className), Object.defineProperty(r3, "className", J));
    }
    n2.$$typeof = P2, K && K(n2);
  };
  var Q = l.__r;
  l.__r = function(n2) {
    Q && Q(n2), G = n2.__c;
  };
  var X = { ReactCurrentDispatcher: { current: { readContext: function(n2) {
    return G.__n[n2.__c].props.value;
  } } } };
  function tn(n2) {
    return v.bind(null, n2);
  }
  function en(n2) {
    return !!n2 && n2.$$typeof === P2;
  }
  function rn(n2) {
    return en(n2) ? B.apply(null, arguments) : n2;
  }
  function un(n2) {
    return !!n2.__k && (S(null, n2), true);
  }
  function on(n2) {
    return n2 && (n2.base || 1 === n2.nodeType && n2) || null;
  }
  var ln = function(n2, t3) {
    return n2(t3);
  };
  var fn = function(n2, t3) {
    return n2(t3);
  };
  var compat_module_default = { useState: d2, useReducer: p2, useEffect: y2, useLayoutEffect: h2, useRef: s2, useImperativeHandle: _2, useMemo: A2, useCallback: F, useContext: T2, useDebugValue: q2, version: "17.0.2", Children: k3, render: B2, hydrate: $3, unmountComponentAtNode: un, createPortal: W, createElement: v, createContext: D, createFactory: tn, cloneElement: rn, createRef: p, Fragment: d, isValidElement: en, findDOMNode: on, Component: _, PureComponent: E, memo: g3, forwardRef: x2, flushSync: fn, unstable_batchedUpdates: ln, StrictMode: d, Suspense: L2, SuspenseList: M2, lazy: F2, __SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED: X };

  // node_modules/react-dom/index.mjs
  init_preact_shim();

  // node_modules/rc-animate/es/Animate.js
  init_preact_shim();

  // node_modules/rc-animate/node_modules/rc-util/es/unsafeLifecyclesPolyfill.js
  init_preact_shim();
  var unsafeLifecyclesPolyfill = function unsafeLifecyclesPolyfill2(Component) {
    var prototype = Component.prototype;
    if (!prototype || !prototype.isReactComponent) {
      throw new Error("Can only polyfill class components");
    }
    if (typeof prototype.componentWillReceiveProps !== "function") {
      return Component;
    }
    if (!compat_module_default.Profiler) {
      return Component;
    }
    prototype.UNSAFE_componentWillReceiveProps = prototype.componentWillReceiveProps;
    delete prototype.componentWillReceiveProps;
    return Component;
  };
  var unsafeLifecyclesPolyfill_default = unsafeLifecyclesPolyfill;

  // node_modules/rc-animate/es/ChildrenUtils.js
  init_preact_shim();
  function toArrayChildren(children) {
    var ret = [];
    compat_module_default.Children.forEach(children, function(child) {
      ret.push(child);
    });
    return ret;
  }
  function findChildInChildrenByKey(children, key) {
    var ret = null;
    if (children) {
      children.forEach(function(child) {
        if (ret) {
          return;
        }
        if (child && child.key === key) {
          ret = child;
        }
      });
    }
    return ret;
  }
  function findShownChildInChildrenByKey(children, key, showProp) {
    var ret = null;
    if (children) {
      children.forEach(function(child) {
        if (child && child.key === key && child.props[showProp]) {
          if (ret) {
            throw new Error("two child with same key for <rc-animate> children");
          }
          ret = child;
        }
      });
    }
    return ret;
  }
  function isSameChildren(c1, c22, showProp) {
    var same = c1.length === c22.length;
    if (same) {
      c1.forEach(function(child, index) {
        var child2 = c22[index];
        if (child && child2) {
          if (child && !child2 || !child && child2) {
            same = false;
          } else if (child.key !== child2.key) {
            same = false;
          } else if (showProp && child.props[showProp] !== child2.props[showProp]) {
            same = false;
          }
        }
      });
    }
    return same;
  }
  function mergeChildren(prev, next) {
    var ret = [];
    var nextChildrenPending = {};
    var pendingChildren = [];
    prev.forEach(function(child) {
      if (child && findChildInChildrenByKey(next, child.key)) {
        if (pendingChildren.length) {
          nextChildrenPending[child.key] = pendingChildren;
          pendingChildren = [];
        }
      } else {
        pendingChildren.push(child);
      }
    });
    next.forEach(function(child) {
      if (child && Object.prototype.hasOwnProperty.call(nextChildrenPending, child.key)) {
        ret = ret.concat(nextChildrenPending[child.key]);
      }
      ret.push(child);
    });
    ret = ret.concat(pendingChildren);
    return ret;
  }

  // node_modules/rc-animate/es/AnimateChild.js
  init_preact_shim();

  // node_modules/@ant-design/css-animation/es/index.js
  init_preact_shim();

  // node_modules/@ant-design/css-animation/es/Event.js
  init_preact_shim();
  var START_EVENT_NAME_MAP = {
    transitionstart: {
      transition: "transitionstart",
      WebkitTransition: "webkitTransitionStart",
      MozTransition: "mozTransitionStart",
      OTransition: "oTransitionStart",
      msTransition: "MSTransitionStart"
    },
    animationstart: {
      animation: "animationstart",
      WebkitAnimation: "webkitAnimationStart",
      MozAnimation: "mozAnimationStart",
      OAnimation: "oAnimationStart",
      msAnimation: "MSAnimationStart"
    }
  };
  var END_EVENT_NAME_MAP = {
    transitionend: {
      transition: "transitionend",
      WebkitTransition: "webkitTransitionEnd",
      MozTransition: "mozTransitionEnd",
      OTransition: "oTransitionEnd",
      msTransition: "MSTransitionEnd"
    },
    animationend: {
      animation: "animationend",
      WebkitAnimation: "webkitAnimationEnd",
      MozAnimation: "mozAnimationEnd",
      OAnimation: "oAnimationEnd",
      msAnimation: "MSAnimationEnd"
    }
  };
  var startEvents = [];
  var endEvents = [];
  function detectEvents() {
    var testEl = document.createElement("div");
    var style = testEl.style;
    if (!("AnimationEvent" in window)) {
      delete START_EVENT_NAME_MAP.animationstart.animation;
      delete END_EVENT_NAME_MAP.animationend.animation;
    }
    if (!("TransitionEvent" in window)) {
      delete START_EVENT_NAME_MAP.transitionstart.transition;
      delete END_EVENT_NAME_MAP.transitionend.transition;
    }
    function process2(EVENT_NAME_MAP, events) {
      for (var baseEventName in EVENT_NAME_MAP) {
        if (EVENT_NAME_MAP.hasOwnProperty(baseEventName)) {
          var baseEvents = EVENT_NAME_MAP[baseEventName];
          for (var styleName in baseEvents) {
            if (styleName in style) {
              events.push(baseEvents[styleName]);
              break;
            }
          }
        }
      }
    }
    process2(START_EVENT_NAME_MAP, startEvents);
    process2(END_EVENT_NAME_MAP, endEvents);
  }
  if (typeof window !== "undefined" && typeof document !== "undefined") {
    detectEvents();
  }
  function addEventListener(node, eventName, eventListener) {
    node.addEventListener(eventName, eventListener, false);
  }
  function removeEventListener(node, eventName, eventListener) {
    node.removeEventListener(eventName, eventListener, false);
  }
  var TransitionEvents = {
    // Start events
    startEvents,
    addStartEventListener: function addStartEventListener(node, eventListener) {
      if (startEvents.length === 0) {
        window.setTimeout(eventListener, 0);
        return;
      }
      startEvents.forEach(function(startEvent) {
        addEventListener(node, startEvent, eventListener);
      });
    },
    removeStartEventListener: function removeStartEventListener(node, eventListener) {
      if (startEvents.length === 0) {
        return;
      }
      startEvents.forEach(function(startEvent) {
        removeEventListener(node, startEvent, eventListener);
      });
    },
    // End events
    endEvents,
    addEndEventListener: function addEndEventListener(node, eventListener) {
      if (endEvents.length === 0) {
        window.setTimeout(eventListener, 0);
        return;
      }
      endEvents.forEach(function(endEvent) {
        addEventListener(node, endEvent, eventListener);
      });
    },
    removeEndEventListener: function removeEndEventListener(node, eventListener) {
      if (endEvents.length === 0) {
        return;
      }
      endEvents.forEach(function(endEvent) {
        removeEventListener(node, endEvent, eventListener);
      });
    }
  };
  var Event_default = TransitionEvents;

  // node_modules/@ant-design/css-animation/es/index.js
  var _typeof2 = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function(obj) {
    return typeof obj;
  } : function(obj) {
    return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
  };
  var isCssAnimationSupported = Event_default.endEvents.length !== 0;
  var capitalPrefixes = [
    "Webkit",
    "Moz",
    "O",
    // ms is special .... !
    "ms"
  ];
  var prefixes = ["-webkit-", "-moz-", "-o-", "ms-", ""];
  function getStyleProperty(node, name) {
    var style = window.getComputedStyle(node, null);
    var ret = "";
    for (var i3 = 0; i3 < prefixes.length; i3++) {
      ret = style.getPropertyValue(prefixes[i3] + name);
      if (ret) {
        break;
      }
    }
    return ret;
  }
  function fixBrowserByTimeout(node) {
    if (isCssAnimationSupported) {
      var transitionDelay = parseFloat(getStyleProperty(node, "transition-delay")) || 0;
      var transitionDuration = parseFloat(getStyleProperty(node, "transition-duration")) || 0;
      var animationDelay = parseFloat(getStyleProperty(node, "animation-delay")) || 0;
      var animationDuration = parseFloat(getStyleProperty(node, "animation-duration")) || 0;
      var time = Math.max(transitionDuration + transitionDelay, animationDuration + animationDelay);
      node.rcEndAnimTimeout = setTimeout(function() {
        node.rcEndAnimTimeout = null;
        if (node.rcEndListener) {
          node.rcEndListener();
        }
      }, time * 1e3 + 200);
    }
  }
  function clearBrowserBugTimeout(node) {
    if (node.rcEndAnimTimeout) {
      clearTimeout(node.rcEndAnimTimeout);
      node.rcEndAnimTimeout = null;
    }
  }
  var cssAnimation = function cssAnimation2(node, transitionName, endCallback) {
    var nameIsObj = (typeof transitionName === "undefined" ? "undefined" : _typeof2(transitionName)) === "object";
    var className = nameIsObj ? transitionName.name : transitionName;
    var activeClassName = nameIsObj ? transitionName.active : transitionName + "-active";
    var end = endCallback;
    var start = void 0;
    var active = void 0;
    if (endCallback && Object.prototype.toString.call(endCallback) === "[object Object]") {
      end = endCallback.end;
      start = endCallback.start;
      active = endCallback.active;
    }
    if (node.rcEndListener) {
      node.rcEndListener();
    }
    node.rcEndListener = function(e4) {
      if (e4 && e4.target !== node) {
        return;
      }
      if (node.rcAnimTimeout) {
        clearTimeout(node.rcAnimTimeout);
        node.rcAnimTimeout = null;
      }
      clearBrowserBugTimeout(node);
      node.classList.remove(className);
      node.classList.remove(activeClassName);
      Event_default.removeEndEventListener(node, node.rcEndListener);
      node.rcEndListener = null;
      if (end) {
        end();
      }
    };
    Event_default.addEndEventListener(node, node.rcEndListener);
    if (start) {
      start();
    }
    node.classList.add(className);
    node.rcAnimTimeout = setTimeout(function() {
      node.rcAnimTimeout = null;
      node.classList.add(activeClassName);
      if (active) {
        active();
      }
      fixBrowserByTimeout(node);
    }, 0);
    return {
      stop: function stop() {
        if (node.rcEndListener) {
          node.rcEndListener();
        }
      }
    };
  };
  cssAnimation.style = function(node, style, callback) {
    if (node.rcEndListener) {
      node.rcEndListener();
    }
    node.rcEndListener = function(e4) {
      if (e4 && e4.target !== node) {
        return;
      }
      if (node.rcAnimTimeout) {
        clearTimeout(node.rcAnimTimeout);
        node.rcAnimTimeout = null;
      }
      clearBrowserBugTimeout(node);
      Event_default.removeEndEventListener(node, node.rcEndListener);
      node.rcEndListener = null;
      if (callback) {
        callback();
      }
    };
    Event_default.addEndEventListener(node, node.rcEndListener);
    node.rcAnimTimeout = setTimeout(function() {
      for (var s3 in style) {
        if (style.hasOwnProperty(s3)) {
          node.style[s3] = style[s3];
        }
      }
      node.rcAnimTimeout = null;
      fixBrowserByTimeout(node);
    }, 0);
  };
  cssAnimation.setTransition = function(node, p3, value) {
    var property = p3;
    var v3 = value;
    if (value === void 0) {
      v3 = property;
      property = "";
    }
    property = property || "";
    capitalPrefixes.forEach(function(prefix) {
      node.style[prefix + "Transition" + property] = v3;
    });
  };
  cssAnimation.isCssAnimationSupported = isCssAnimationSupported;
  var es_default = cssAnimation;

  // node_modules/rc-animate/es/util/animate.js
  init_preact_shim();
  var util = {
    isAppearSupported: function isAppearSupported(props) {
      return props.transitionName && props.transitionAppear || props.animation.appear;
    },
    isEnterSupported: function isEnterSupported(props) {
      return props.transitionName && props.transitionEnter || props.animation.enter;
    },
    isLeaveSupported: function isLeaveSupported(props) {
      return props.transitionName && props.transitionLeave || props.animation.leave;
    },
    allowAppearCallback: function allowAppearCallback(props) {
      return props.transitionAppear || props.animation.appear;
    },
    allowEnterCallback: function allowEnterCallback(props) {
      return props.transitionEnter || props.animation.enter;
    },
    allowLeaveCallback: function allowLeaveCallback(props) {
      return props.transitionLeave || props.animation.leave;
    }
  };
  var animate_default = util;

  // node_modules/rc-animate/es/AnimateChild.js
  var _createClass2 = /* @__PURE__ */ function() {
    function defineProperties(target, props) {
      for (var i3 = 0; i3 < props.length; i3++) {
        var descriptor = props[i3];
        descriptor.enumerable = descriptor.enumerable || false;
        descriptor.configurable = true;
        if ("value" in descriptor) descriptor.writable = true;
        Object.defineProperty(target, descriptor.key, descriptor);
      }
    }
    return function(Constructor, protoProps, staticProps) {
      if (protoProps) defineProperties(Constructor.prototype, protoProps);
      if (staticProps) defineProperties(Constructor, staticProps);
      return Constructor;
    };
  }();
  function _classCallCheck2(instance, Constructor) {
    if (!(instance instanceof Constructor)) {
      throw new TypeError("Cannot call a class as a function");
    }
  }
  function _possibleConstructorReturn2(self2, call) {
    if (!self2) {
      throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
    }
    return call && (typeof call === "object" || typeof call === "function") ? call : self2;
  }
  function _inherits2(subClass, superClass) {
    if (typeof superClass !== "function" && superClass !== null) {
      throw new TypeError("Super expression must either be null or a function, not " + typeof superClass);
    }
    subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } });
    if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;
  }
  var transitionMap = {
    enter: "transitionEnter",
    appear: "transitionAppear",
    leave: "transitionLeave"
  };
  var AnimateChild = function(_React$Component) {
    _inherits2(AnimateChild2, _React$Component);
    function AnimateChild2() {
      _classCallCheck2(this, AnimateChild2);
      return _possibleConstructorReturn2(this, (AnimateChild2.__proto__ || Object.getPrototypeOf(AnimateChild2)).apply(this, arguments));
    }
    _createClass2(AnimateChild2, [{
      key: "componentWillUnmount",
      value: function componentWillUnmount() {
        this.stop();
      }
    }, {
      key: "componentWillEnter",
      value: function componentWillEnter(done) {
        if (animate_default.isEnterSupported(this.props)) {
          this.transition("enter", done);
        } else {
          done();
        }
      }
    }, {
      key: "componentWillAppear",
      value: function componentWillAppear(done) {
        if (animate_default.isAppearSupported(this.props)) {
          this.transition("appear", done);
        } else {
          done();
        }
      }
    }, {
      key: "componentWillLeave",
      value: function componentWillLeave(done) {
        if (animate_default.isLeaveSupported(this.props)) {
          this.transition("leave", done);
        } else {
          done();
        }
      }
    }, {
      key: "transition",
      value: function transition(animationType, finishCallback) {
        var _this2 = this;
        var node = compat_module_default.findDOMNode(this);
        var props = this.props;
        var transitionName = props.transitionName;
        var nameIsObj = typeof transitionName === "object";
        this.stop();
        var end = function end2() {
          _this2.stopper = null;
          finishCallback();
        };
        if ((isCssAnimationSupported || !props.animation[animationType]) && transitionName && props[transitionMap[animationType]]) {
          var name = nameIsObj ? transitionName[animationType] : transitionName + "-" + animationType;
          var activeName = name + "-active";
          if (nameIsObj && transitionName[animationType + "Active"]) {
            activeName = transitionName[animationType + "Active"];
          }
          this.stopper = es_default(node, {
            name,
            active: activeName
          }, end);
        } else {
          this.stopper = props.animation[animationType](node, end);
        }
      }
    }, {
      key: "stop",
      value: function stop() {
        var stopper = this.stopper;
        if (stopper) {
          this.stopper = null;
          stopper.stop();
        }
      }
    }, {
      key: "render",
      value: function render() {
        return this.props.children;
      }
    }]);
    return AnimateChild2;
  }(compat_module_default.Component);
  var AnimateChild_default = AnimateChild;

  // node_modules/rc-animate/es/Animate.js
  var _extends = Object.assign || function(target) {
    for (var i3 = 1; i3 < arguments.length; i3++) {
      var source = arguments[i3];
      for (var key in source) {
        if (Object.prototype.hasOwnProperty.call(source, key)) {
          target[key] = source[key];
        }
      }
    }
    return target;
  };
  var _createClass3 = /* @__PURE__ */ function() {
    function defineProperties(target, props) {
      for (var i3 = 0; i3 < props.length; i3++) {
        var descriptor = props[i3];
        descriptor.enumerable = descriptor.enumerable || false;
        descriptor.configurable = true;
        if ("value" in descriptor) descriptor.writable = true;
        Object.defineProperty(target, descriptor.key, descriptor);
      }
    }
    return function(Constructor, protoProps, staticProps) {
      if (protoProps) defineProperties(Constructor.prototype, protoProps);
      if (staticProps) defineProperties(Constructor, staticProps);
      return Constructor;
    };
  }();
  function _defineProperty2(obj, key, value) {
    if (key in obj) {
      Object.defineProperty(obj, key, { value, enumerable: true, configurable: true, writable: true });
    } else {
      obj[key] = value;
    }
    return obj;
  }
  function _classCallCheck3(instance, Constructor) {
    if (!(instance instanceof Constructor)) {
      throw new TypeError("Cannot call a class as a function");
    }
  }
  function _possibleConstructorReturn3(self2, call) {
    if (!self2) {
      throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
    }
    return call && (typeof call === "object" || typeof call === "function") ? call : self2;
  }
  function _inherits3(subClass, superClass) {
    if (typeof superClass !== "function" && superClass !== null) {
      throw new TypeError("Super expression must either be null or a function, not " + typeof superClass);
    }
    subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } });
    if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass;
  }
  var defaultKey = "rc_animate_" + Date.now();
  function getChildrenFromProps(props) {
    var children = props.children;
    if (compat_module_default.isValidElement(children)) {
      if (!children.key) {
        return compat_module_default.cloneElement(children, {
          key: defaultKey
        });
      }
    }
    return children;
  }
  function noop() {
  }
  var Animate = function(_React$Component) {
    _inherits3(Animate2, _React$Component);
    function Animate2(props) {
      _classCallCheck3(this, Animate2);
      var _this = _possibleConstructorReturn3(this, (Animate2.__proto__ || Object.getPrototypeOf(Animate2)).call(this, props));
      _initialiseProps.call(_this);
      _this.currentlyAnimatingKeys = {};
      _this.keysToEnter = [];
      _this.keysToLeave = [];
      _this.state = {
        children: toArrayChildren(getChildrenFromProps(props))
      };
      _this.childrenRefs = {};
      return _this;
    }
    _createClass3(Animate2, [{
      key: "componentDidMount",
      value: function componentDidMount() {
        var _this2 = this;
        var showProp = this.props.showProp;
        var children = this.state.children;
        if (showProp) {
          children = children.filter(function(child) {
            return !!child.props[showProp];
          });
        }
        children.forEach(function(child) {
          if (child) {
            _this2.performAppear(child.key);
          }
        });
      }
    }, {
      key: "componentWillReceiveProps",
      value: function componentWillReceiveProps(nextProps) {
        var _this3 = this;
        this.nextProps = nextProps;
        var nextChildren = toArrayChildren(getChildrenFromProps(nextProps));
        var props = this.props;
        if (props.exclusive) {
          Object.keys(this.currentlyAnimatingKeys).forEach(function(key) {
            _this3.stop(key);
          });
        }
        var showProp = props.showProp;
        var currentlyAnimatingKeys = this.currentlyAnimatingKeys;
        var currentChildren = props.exclusive ? toArrayChildren(getChildrenFromProps(props)) : this.state.children;
        var newChildren = [];
        if (showProp) {
          currentChildren.forEach(function(currentChild) {
            var nextChild = currentChild && findChildInChildrenByKey(nextChildren, currentChild.key);
            var newChild = void 0;
            if ((!nextChild || !nextChild.props[showProp]) && currentChild.props[showProp]) {
              newChild = compat_module_default.cloneElement(nextChild || currentChild, _defineProperty2({}, showProp, true));
            } else {
              newChild = nextChild;
            }
            if (newChild) {
              newChildren.push(newChild);
            }
          });
          nextChildren.forEach(function(nextChild) {
            if (!nextChild || !findChildInChildrenByKey(currentChildren, nextChild.key)) {
              newChildren.push(nextChild);
            }
          });
        } else {
          newChildren = mergeChildren(currentChildren, nextChildren);
        }
        this.setState({
          children: newChildren
        });
        nextChildren.forEach(function(child) {
          var key = child && child.key;
          if (child && currentlyAnimatingKeys[key]) {
            return;
          }
          var hasPrev = child && findChildInChildrenByKey(currentChildren, key);
          if (showProp) {
            var showInNext = child.props[showProp];
            if (hasPrev) {
              var showInNow = findShownChildInChildrenByKey(currentChildren, key, showProp);
              if (!showInNow && showInNext) {
                _this3.keysToEnter.push(key);
              }
            } else if (showInNext) {
              _this3.keysToEnter.push(key);
            }
          } else if (!hasPrev) {
            _this3.keysToEnter.push(key);
          }
        });
        currentChildren.forEach(function(child) {
          var key = child && child.key;
          if (child && currentlyAnimatingKeys[key]) {
            return;
          }
          var hasNext = child && findChildInChildrenByKey(nextChildren, key);
          if (showProp) {
            var showInNow = child.props[showProp];
            if (hasNext) {
              var showInNext = findShownChildInChildrenByKey(nextChildren, key, showProp);
              if (!showInNext && showInNow) {
                _this3.keysToLeave.push(key);
              }
            } else if (showInNow) {
              _this3.keysToLeave.push(key);
            }
          } else if (!hasNext) {
            _this3.keysToLeave.push(key);
          }
        });
      }
    }, {
      key: "componentDidUpdate",
      value: function componentDidUpdate() {
        var keysToEnter = this.keysToEnter;
        this.keysToEnter = [];
        keysToEnter.forEach(this.performEnter);
        var keysToLeave = this.keysToLeave;
        this.keysToLeave = [];
        keysToLeave.forEach(this.performLeave);
      }
    }, {
      key: "isValidChildByKey",
      value: function isValidChildByKey(currentChildren, key) {
        var showProp = this.props.showProp;
        if (showProp) {
          return findShownChildInChildrenByKey(currentChildren, key, showProp);
        }
        return findChildInChildrenByKey(currentChildren, key);
      }
    }, {
      key: "stop",
      value: function stop(key) {
        delete this.currentlyAnimatingKeys[key];
        var component = this.childrenRefs[key];
        if (component) {
          component.stop();
        }
      }
    }, {
      key: "render",
      value: function render() {
        var _this4 = this;
        var props = this.props;
        this.nextProps = props;
        var stateChildren = this.state.children;
        var children = null;
        if (stateChildren) {
          children = stateChildren.map(function(child) {
            if (child === null || child === void 0) {
              return child;
            }
            if (!child.key) {
              throw new Error("must set key for <rc-animate> children");
            }
            return compat_module_default.createElement(
              AnimateChild_default,
              {
                key: child.key,
                ref: function ref(node) {
                  _this4.childrenRefs[child.key] = node;
                },
                animation: props.animation,
                transitionName: props.transitionName,
                transitionEnter: props.transitionEnter,
                transitionAppear: props.transitionAppear,
                transitionLeave: props.transitionLeave
              },
              child
            );
          });
        }
        var Component = props.component;
        if (Component) {
          var passedProps = props;
          if (typeof Component === "string") {
            passedProps = _extends({
              className: props.className,
              style: props.style
            }, props.componentProps);
          }
          return compat_module_default.createElement(
            Component,
            passedProps,
            children
          );
        }
        return children[0] || null;
      }
    }]);
    return Animate2;
  }(compat_module_default.Component);
  Animate.isAnimate = true;
  Animate.defaultProps = {
    animation: {},
    component: "span",
    componentProps: {},
    transitionEnter: true,
    transitionLeave: true,
    transitionAppear: false,
    onEnd: noop,
    onEnter: noop,
    onLeave: noop,
    onAppear: noop
  };
  var _initialiseProps = function _initialiseProps2() {
    var _this5 = this;
    this.performEnter = function(key) {
      if (_this5.childrenRefs[key]) {
        _this5.currentlyAnimatingKeys[key] = true;
        _this5.childrenRefs[key].componentWillEnter(_this5.handleDoneAdding.bind(_this5, key, "enter"));
      }
    };
    this.performAppear = function(key) {
      if (_this5.childrenRefs[key]) {
        _this5.currentlyAnimatingKeys[key] = true;
        _this5.childrenRefs[key].componentWillAppear(_this5.handleDoneAdding.bind(_this5, key, "appear"));
      }
    };
    this.handleDoneAdding = function(key, type) {
      var props = _this5.props;
      delete _this5.currentlyAnimatingKeys[key];
      if (props.exclusive && props !== _this5.nextProps) {
        return;
      }
      var currentChildren = toArrayChildren(getChildrenFromProps(props));
      if (!_this5.isValidChildByKey(currentChildren, key)) {
        _this5.performLeave(key);
      } else if (type === "appear") {
        if (animate_default.allowAppearCallback(props)) {
          props.onAppear(key);
          props.onEnd(key, true);
        }
      } else if (animate_default.allowEnterCallback(props)) {
        props.onEnter(key);
        props.onEnd(key, true);
      }
    };
    this.performLeave = function(key) {
      if (_this5.childrenRefs[key]) {
        _this5.currentlyAnimatingKeys[key] = true;
        _this5.childrenRefs[key].componentWillLeave(_this5.handleDoneLeaving.bind(_this5, key));
      }
    };
    this.handleDoneLeaving = function(key) {
      var props = _this5.props;
      delete _this5.currentlyAnimatingKeys[key];
      if (props.exclusive && props !== _this5.nextProps) {
        return;
      }
      var currentChildren = toArrayChildren(getChildrenFromProps(props));
      if (_this5.isValidChildByKey(currentChildren, key)) {
        _this5.performEnter(key);
      } else {
        var end = function end2() {
          if (animate_default.allowLeaveCallback(props)) {
            props.onLeave(key);
            props.onEnd(key, false);
          }
        };
        if (!isSameChildren(_this5.state.children, currentChildren, props.showProp)) {
          _this5.setState({
            children: currentChildren
          }, end);
        } else {
          end();
        }
      }
    };
  };
  var Animate_default = unsafeLifecyclesPolyfill_default(Animate);

  // node_modules/rc-util/es/createChainedFunction.js
  init_preact_shim();
  function createChainedFunction() {
    var args = [].slice.call(arguments, 0);
    if (args.length === 1) {
      return args[0];
    }
    return function chainedFunction() {
      for (var i3 = 0; i3 < args.length; i3++) {
        if (args[i3] && args[i3].apply) {
          args[i3].apply(this, arguments);
        }
      }
    };
  }

  // node_modules/rc-notification/es/Notification.js
  var import_classnames2 = __toESM(require_classnames());

  // node_modules/rc-notification/es/Notice.js
  init_preact_shim();
  var import_classnames = __toESM(require_classnames());
  function _createSuper(Derived) {
    var hasNativeReflectConstruct = _isNativeReflectConstruct();
    return function() {
      var Super = _getPrototypeOf(Derived), result;
      if (hasNativeReflectConstruct) {
        var NewTarget = _getPrototypeOf(this).constructor;
        result = Reflect.construct(Super, arguments, NewTarget);
      } else {
        result = Super.apply(this, arguments);
      }
      return _possibleConstructorReturn(this, result);
    };
  }
  function _isNativeReflectConstruct() {
    if (typeof Reflect === "undefined" || !Reflect.construct) return false;
    if (Reflect.construct.sham) return false;
    if (typeof Proxy === "function") return true;
    try {
      Date.prototype.toString.call(Reflect.construct(Date, [], function() {
      }));
      return true;
    } catch (e4) {
      return false;
    }
  }
  var Notice = /* @__PURE__ */ function(_Component) {
    _inherits(Notice2, _Component);
    var _super = _createSuper(Notice2);
    function Notice2() {
      var _this;
      _classCallCheck(this, Notice2);
      _this = _super.apply(this, arguments);
      _this.closeTimer = null;
      _this.close = function(e4) {
        if (e4) {
          e4.stopPropagation();
        }
        _this.clearCloseTimer();
        var onClose2 = _this.props.onClose;
        if (onClose2) {
          onClose2();
        }
      };
      _this.startCloseTimer = function() {
        if (_this.props.duration) {
          _this.closeTimer = window.setTimeout(function() {
            _this.close();
          }, _this.props.duration * 1e3);
        }
      };
      _this.clearCloseTimer = function() {
        if (_this.closeTimer) {
          clearTimeout(_this.closeTimer);
          _this.closeTimer = null;
        }
      };
      return _this;
    }
    _createClass(Notice2, [{
      key: "componentDidMount",
      value: function componentDidMount() {
        this.startCloseTimer();
      }
    }, {
      key: "componentDidUpdate",
      value: function componentDidUpdate(prevProps) {
        if (this.props.duration !== prevProps.duration || this.props.update) {
          this.restartCloseTimer();
        }
      }
    }, {
      key: "componentWillUnmount",
      value: function componentWillUnmount() {
        this.clearCloseTimer();
      }
    }, {
      key: "restartCloseTimer",
      value: function restartCloseTimer() {
        this.clearCloseTimer();
        this.startCloseTimer();
      }
    }, {
      key: "render",
      value: function render() {
        var _this2 = this;
        var _this$props = this.props, prefixCls = _this$props.prefixCls, className = _this$props.className, closable = _this$props.closable, closeIcon = _this$props.closeIcon, style = _this$props.style, onClick = _this$props.onClick, children = _this$props.children, holder = _this$props.holder;
        var componentClass = "".concat(prefixCls, "-notice");
        var dataOrAriaAttributeProps = Object.keys(this.props).reduce(function(acc, key) {
          if (key.substr(0, 5) === "data-" || key.substr(0, 5) === "aria-" || key === "role") {
            acc[key] = _this2.props[key];
          }
          return acc;
        }, {});
        var node = compat_module_default.createElement("div", Object.assign({
          className: (0, import_classnames.default)(componentClass, className, _defineProperty({}, "".concat(componentClass, "-closable"), closable)),
          style,
          onMouseEnter: this.clearCloseTimer,
          onMouseLeave: this.startCloseTimer,
          onClick
        }, dataOrAriaAttributeProps), compat_module_default.createElement("div", {
          className: "".concat(componentClass, "-content")
        }, children), closable ? compat_module_default.createElement("a", {
          tabIndex: 0,
          onClick: this.close,
          className: "".concat(componentClass, "-close")
        }, closeIcon || compat_module_default.createElement("span", {
          className: "".concat(componentClass, "-close-x")
        })) : null);
        if (holder) {
          return compat_module_default.createPortal(node, holder);
        }
        return node;
      }
    }]);
    return Notice2;
  }(_);
  Notice.defaultProps = {
    onClose: function onClose() {
    },
    duration: 1.5,
    style: {
      right: "50%"
    }
  };

  // node_modules/rc-notification/es/useNotification.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/toConsumableArray.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/arrayLikeToArray.js
  init_preact_shim();
  function _arrayLikeToArray(arr, len) {
    if (len == null || len > arr.length) len = arr.length;
    for (var i3 = 0, arr2 = new Array(len); i3 < len; i3++) {
      arr2[i3] = arr[i3];
    }
    return arr2;
  }

  // node_modules/@babel/runtime/helpers/esm/arrayWithoutHoles.js
  function _arrayWithoutHoles(arr) {
    if (Array.isArray(arr)) return _arrayLikeToArray(arr);
  }

  // node_modules/@babel/runtime/helpers/esm/iterableToArray.js
  init_preact_shim();
  function _iterableToArray(iter) {
    if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
  }

  // node_modules/@babel/runtime/helpers/esm/unsupportedIterableToArray.js
  init_preact_shim();
  function _unsupportedIterableToArray(o4, minLen) {
    if (!o4) return;
    if (typeof o4 === "string") return _arrayLikeToArray(o4, minLen);
    var n2 = Object.prototype.toString.call(o4).slice(8, -1);
    if (n2 === "Object" && o4.constructor) n2 = o4.constructor.name;
    if (n2 === "Map" || n2 === "Set") return Array.from(o4);
    if (n2 === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n2)) return _arrayLikeToArray(o4, minLen);
  }

  // node_modules/@babel/runtime/helpers/esm/nonIterableSpread.js
  init_preact_shim();
  function _nonIterableSpread() {
    throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
  }

  // node_modules/@babel/runtime/helpers/esm/toConsumableArray.js
  function _toConsumableArray(arr) {
    return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
  }

  // node_modules/@babel/runtime/helpers/esm/slicedToArray.js
  init_preact_shim();

  // node_modules/@babel/runtime/helpers/esm/arrayWithHoles.js
  init_preact_shim();
  function _arrayWithHoles(arr) {
    if (Array.isArray(arr)) return arr;
  }

  // node_modules/@babel/runtime/helpers/esm/iterableToArrayLimit.js
  init_preact_shim();
  function _iterableToArrayLimit(arr, i3) {
    var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
    if (_i == null) return;
    var _arr = [];
    var _n = true;
    var _d = false;
    var _s, _e;
    try {
      for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) {
        _arr.push(_s.value);
        if (i3 && _arr.length === i3) break;
      }
    } catch (err) {
      _d = true;
      _e = err;
    } finally {
      try {
        if (!_n && _i["return"] != null) _i["return"]();
      } finally {
        if (_d) throw _e;
      }
    }
    return _arr;
  }

  // node_modules/@babel/runtime/helpers/esm/nonIterableRest.js
  init_preact_shim();
  function _nonIterableRest() {
    throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
  }

  // node_modules/@babel/runtime/helpers/esm/slicedToArray.js
  function _slicedToArray(arr, i3) {
    return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i3) || _unsupportedIterableToArray(arr, i3) || _nonIterableRest();
  }

  // node_modules/rc-notification/es/useNotification.js
  function useNotification(notificationInstance) {
    var createdRef = s2({});
    var _React$useState = d2([]), _React$useState2 = _slicedToArray(_React$useState, 2), elements = _React$useState2[0], setElements = _React$useState2[1];
    function notify(noticeProps) {
      notificationInstance.add(noticeProps, function(div, props) {
        var key = props.key;
        if (div && !createdRef.current[key]) {
          var noticeEle = v(Notice, Object.assign({}, props, {
            holder: div
          }));
          createdRef.current[key] = noticeEle;
          setElements(function(originElements) {
            return [].concat(_toConsumableArray(originElements), [noticeEle]);
          });
        }
      });
    }
    return [notify, v(d, null, elements)];
  }

  // node_modules/rc-notification/es/Notification.js
  function ownKeys(object, enumerableOnly) {
    var keys = Object.keys(object);
    if (Object.getOwnPropertySymbols) {
      var symbols = Object.getOwnPropertySymbols(object);
      if (enumerableOnly) symbols = symbols.filter(function(sym) {
        return Object.getOwnPropertyDescriptor(object, sym).enumerable;
      });
      keys.push.apply(keys, symbols);
    }
    return keys;
  }
  function _objectSpread(target) {
    for (var i3 = 1; i3 < arguments.length; i3++) {
      var source = arguments[i3] != null ? arguments[i3] : {};
      if (i3 % 2) {
        ownKeys(Object(source), true).forEach(function(key) {
          _defineProperty(target, key, source[key]);
        });
      } else if (Object.getOwnPropertyDescriptors) {
        Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
      } else {
        ownKeys(Object(source)).forEach(function(key) {
          Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
        });
      }
    }
    return target;
  }
  function _createSuper2(Derived) {
    var hasNativeReflectConstruct = _isNativeReflectConstruct2();
    return function() {
      var Super = _getPrototypeOf(Derived), result;
      if (hasNativeReflectConstruct) {
        var NewTarget = _getPrototypeOf(this).constructor;
        result = Reflect.construct(Super, arguments, NewTarget);
      } else {
        result = Super.apply(this, arguments);
      }
      return _possibleConstructorReturn(this, result);
    };
  }
  function _isNativeReflectConstruct2() {
    if (typeof Reflect === "undefined" || !Reflect.construct) return false;
    if (Reflect.construct.sham) return false;
    if (typeof Proxy === "function") return true;
    try {
      Date.prototype.toString.call(Reflect.construct(Date, [], function() {
      }));
      return true;
    } catch (e4) {
      return false;
    }
  }
  var seed = 0;
  var now = Date.now();
  function getUuid() {
    var id = seed;
    seed += 1;
    return "rcNotification_".concat(now, "_").concat(id);
  }
  var Notification = /* @__PURE__ */ function(_Component) {
    _inherits(Notification2, _Component);
    var _super = _createSuper2(Notification2);
    function Notification2() {
      var _this;
      _classCallCheck(this, Notification2);
      _this = _super.apply(this, arguments);
      _this.state = {
        notices: []
      };
      _this.hookRefs = /* @__PURE__ */ new Map();
      _this.add = function(notice2, holderCallback) {
        notice2.key = notice2.key || getUuid();
        var key = notice2.key;
        var maxCount = _this.props.maxCount;
        _this.setState(function(previousState) {
          var notices = previousState.notices;
          var noticeIndex = notices.map(function(v3) {
            return v3.notice.key;
          }).indexOf(key);
          var updatedNotices = notices.concat();
          if (noticeIndex !== -1) {
            updatedNotices.splice(noticeIndex, 1, {
              notice: notice2,
              holderCallback
            });
          } else {
            if (maxCount && notices.length >= maxCount) {
              notice2.updateKey = updatedNotices[0].notice.updateKey || updatedNotices[0].notice.key;
              updatedNotices.shift();
            }
            updatedNotices.push({
              notice: notice2,
              holderCallback
            });
          }
          return {
            notices: updatedNotices
          };
        });
      };
      _this.remove = function(key) {
        _this.setState(function(previousState) {
          return {
            notices: previousState.notices.filter(function(_ref) {
              var notice2 = _ref.notice;
              return notice2.key !== key;
            })
          };
        });
      };
      return _this;
    }
    _createClass(Notification2, [{
      key: "getTransitionName",
      value: function getTransitionName() {
        var _this$props = this.props, prefixCls = _this$props.prefixCls, animation = _this$props.animation;
        var transitionName = this.props.transitionName;
        if (!transitionName && animation) {
          transitionName = "".concat(prefixCls, "-").concat(animation);
        }
        return transitionName;
      }
    }, {
      key: "render",
      value: function render() {
        var _this2 = this;
        var notices = this.state.notices;
        var _this$props2 = this.props, prefixCls = _this$props2.prefixCls, className = _this$props2.className, closeIcon = _this$props2.closeIcon, style = _this$props2.style;
        var noticeNodes = notices.map(function(_ref2, index) {
          var notice2 = _ref2.notice, holderCallback = _ref2.holderCallback;
          var update = Boolean(index === notices.length - 1 && notice2.updateKey);
          var key = notice2.updateKey ? notice2.updateKey : notice2.key;
          var onClose2 = createChainedFunction(_this2.remove.bind(_this2, notice2.key), notice2.onClose);
          var noticeProps = _objectSpread(_objectSpread(_objectSpread({
            prefixCls,
            closeIcon
          }, notice2), notice2.props), {}, {
            key,
            update,
            onClose: onClose2,
            onClick: notice2.onClick,
            children: notice2.content
          });
          if (holderCallback) {
            return compat_module_default.createElement("div", {
              key,
              className: "".concat(prefixCls, "-hook-holder"),
              ref: function ref(div) {
                if (typeof key === "undefined") {
                  return;
                }
                if (div) {
                  _this2.hookRefs.set(key, div);
                  holderCallback(div, noticeProps);
                } else {
                  _this2.hookRefs.delete(key);
                }
              }
            });
          }
          return compat_module_default.createElement(Notice, Object.assign({}, noticeProps));
        });
        return compat_module_default.createElement("div", {
          className: (0, import_classnames2.default)(prefixCls, className),
          style
        }, compat_module_default.createElement(Animate_default, {
          transitionName: this.getTransitionName()
        }, noticeNodes));
      }
    }]);
    return Notification2;
  }(_);
  Notification.defaultProps = {
    prefixCls: "rc-notification",
    animation: "fade",
    style: {
      top: 65,
      left: "50%"
    }
  };
  Notification.newInstance = function newNotificationInstance(properties, callback) {
    var _ref3 = properties || {}, getContainer = _ref3.getContainer, props = _objectWithoutProperties(_ref3, ["getContainer"]);
    var div = document.createElement("div");
    if (getContainer) {
      var root = getContainer();
      root.appendChild(div);
    } else {
      document.body.appendChild(div);
    }
    var called = false;
    function ref(notification2) {
      if (called) {
        return;
      }
      called = true;
      callback({
        notice: function notice2(noticeProps) {
          notification2.add(noticeProps);
        },
        removeNotice: function removeNotice(key) {
          notification2.remove(key);
        },
        component: notification2,
        destroy: function destroy() {
          compat_module_default.unmountComponentAtNode(div);
          if (div.parentNode) {
            div.parentNode.removeChild(div);
          }
        },
        // Hooks
        useNotification: function useNotification2() {
          return useNotification(notification2);
        }
      });
    }
    if (false) {
      properties.TEST_RENDER(compat_module_default.createElement(Notification, Object.assign({}, props, {
        ref
      })));
      return;
    }
    compat_module_default.render(compat_module_default.createElement(Notification, Object.assign({}, props, {
      ref
    })), div);
  };
  var Notification_default = Notification;

  // node_modules/rc-notification/es/index.js
  var es_default2 = Notification_default;

  // src/assets/close.svg
  init_preact_shim();

  // node_modules/preact/jsx-runtime/dist/jsxRuntime.module.js
  init_preact_shim();
  init_preact_module();
  init_preact_module();
  var o3 = 0;
  function e3(_3, e4, n2, t3, f3) {
    var l3, s3, u3 = {};
    for (s3 in e4) "ref" == s3 ? l3 = e4[s3] : u3[s3] = e4[s3];
    var a3 = { type: _3, props: u3, key: n2, ref: l3, __k: null, __: null, __b: 0, __e: null, __d: void 0, __c: null, __h: null, constructor: void 0, __v: --o3, __source: f3, __self: t3 };
    if ("function" == typeof _3 && (l3 = _3.defaultProps)) for (s3 in l3) void 0 === u3[s3] && (u3[s3] = l3[s3]);
    return l.vnode && l.vnode(a3), a3;
  }

  // src/assets/close.svg
  var SvgClose = (props) => /* @__PURE__ */ e3("svg", __spreadProps(__spreadValues({ className: "icon", viewBox: "0 0 1024 1024", xmlns: "http://www.w3.org/2000/svg", width: 200, height: 200 }, props), { children: [
    /* @__PURE__ */ e3("path", { d: "M806.4 172.8 172.8 806.4c-12.8 12.8-12.8 32 0 44.8 12.8 12.8 32 12.8 44.8 0l633.6-633.6c12.8-12.8 12.8-32 0-44.8-12.8-12.8-32-12.8-44.8 0z", fill: "#333" }),
    /* @__PURE__ */ e3("path", { d: "M172.8 172.8c-12.8 12.8-12.8 32 0 44.8l633.6 633.6c12.8 12.8 32 12.8 44.8 0 12.8-12.8 12.8-32 0-44.8L217.6 172.8c-12.8-12.8-32-12.8-44.8 0z", fill: "#333" })
  ] }));
  var close_default = SvgClose;

  // src/components/Notification.tsx
  var defaultDuration = 3;
  var notification = null;
  var getNoticeProps = (args) => {
    const {
      duration: durationArg,
      description,
      message
    } = args;
    const key = `key${Date.now()}`;
    const duration = durationArg === void 0 ? defaultDuration : durationArg;
    return {
      content: /* @__PURE__ */ e3("div", { children: [
        /* @__PURE__ */ e3("div", { className: "notification-message", children: message }),
        /* @__PURE__ */ e3("div", { className: "notification-description", children: description })
      ] }),
      key,
      duration,
      closable: true,
      closeIcon: /* @__PURE__ */ e3(close_default, {}),
      style: {
        right: 0
      },
      onClose: () => {
        notification.removeNotice(key);
      }
    };
  };
  es_default2.newInstance({
    prefixCls: "easy-notification",
    style: {
      right: "0px",
      top: "24px"
    }
  }, (n2) => {
    notification = n2;
  });
  var notice = (options) => {
    notification.notice(getNoticeProps(options));
  };
  var NotificationApi = {
    open: notice
  };
  var Notification_default2 = NotificationApi;

  // src/common.ts
  var formatTorrentTitle = (title) => {
    return title.replace(/\.(?!(\d+))/ig, " ").replace(/\.(?=\d{4}|48|57|72|2k|4k|7.1|6.1|5.1|4.1|2.0|1.0)/ig, " ").trim();
  };
  var handleError = (error) => {
    Notification_default2.open({
      description: error.message || error
    });
  };
  var getDoubanInfo = async (doubanUrl, isTV) => {
    try {
      if (doubanUrl) {
        const doubanInfo = await getMobileDoubanInfo(doubanUrl, isTV);
        return doubanInfo;
      }
      throw $t("\u8C46\u74E3\u94FE\u63A5\u83B7\u53D6\u5931\u8D25");
    } catch (error) {
      handleError(error);
    }
  };
  var getDoubanBookInfo = async (doubanUrl) => {
    const reqUrl = `${PT_GEN_API}?url=${doubanUrl}`;
    const data = await fetch(reqUrl, {
      responseType: "json"
    });
    const { chinese_title, origin_title } = data;
    let foreignTitle = "";
    if (chinese_title !== origin_title) {
      foreignTitle = origin_title;
    }
    if (data) {
      return __spreadProps(__spreadValues({}, data), {
        chineseTitle: chinese_title,
        foreignTitle
      });
    }
  };
  var getDoubanAwards = async (doubanId) => {
    const data = await fetch(`https://movie.douban.com/subject/${doubanId}/awards/`, {
      responseType: void 0
    });
    const doc = new DOMParser().parseFromString(data, "text/html");
    const linkDom = doc.querySelector("#content > div > div.article");
    return linkDom == null ? void 0 : linkDom.innerHTML.replace(/[ \n]/g, "").replace(/<\/li><li>/g, "</li> <li>").replace(/<\/a><span/g, "</a> <span").replace(/<(div|ul)[^>]*>/g, "\n").replace(/<[^>]+>/g, "").replace(/&nbsp;/g, " ").replace(/ +\n/g, "\n").trim();
  };
  var getIMDBFromDouban = async (doubanLink) => {
    var _a3, _b2, _c, _d;
    const doubanPage = await fetch(doubanLink, {
      responseType: void 0
    });
    const dom = new DOMParser().parseFromString(doubanPage, "text/html");
    const imdbId = (_d = (_c = (_b2 = (_a3 = jQuery('#info span.pl:contains("IMDb")', dom)[0]) == null ? void 0 : _a3.nextSibling) == null ? void 0 : _b2.nodeValue) == null ? void 0 : _c.trim()) != null ? _d : "";
    return imdbId;
  };
  var getMobileDoubanInfo = async (doubanUrl, isTV) => {
    var _a3, _b2, _c, _d;
    try {
      if (doubanUrl) {
        const doubanId = (_b2 = (_a3 = doubanUrl.match(/subject\/(\d+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
        if (!doubanId) {
          throw $t("\u8C46\u74E3ID\u83B7\u53D6\u5931\u8D25");
        }
        const catPath = isTV ? "tv" : "movie";
        const url = `${DOUBAN_MOBILE_API}/${catPath}/${doubanId}`;
        const options = {
          headers: {
            Referer: `https://m.douban.com/${catPath}/subject/${doubanId}`
          },
          cookie: "",
          anonymous: false
        };
        const cookie = getValue("easy-seed.douban-cookie", false);
        const ckValue = (_d = (_c = cookie == null ? void 0 : cookie.match(/ck=([^;]+)?/)) == null ? void 0 : _c[1]) != null ? _d : "";
        if (cookie) {
          options.cookie = cookie;
          options.anonymous = true;
        }
        const data = await fetch(`${url}?for_mobile=1&ck=${ckValue}`, options);
        if (data && data.title === "\u672A\u77E5\u7535\u5F71") {
          throw $t("\u8BF7\u914D\u7F6E\u8C46\u74E3Cookie");
        }
        if (data && data.id) {
          const creditsData = await fetch(`${url}/credits`, options);
          data.credits = creditsData.credits;
          const awards = await getDoubanAwards(doubanId);
          data.awards = awards;
          return await formatDoubanInfo(data);
        }
        throw $t("\u83B7\u53D6\u8C46\u74E3\u4FE1\u606F\u5931\u8D25");
      } else {
        throw $t("\u8C46\u74E3\u94FE\u63A5\u83B7\u53D6\u5931\u8D25");
      }
    } catch (error) {
      handleError(error);
    }
  };
  var getIMDBRating = async (imdbId) => {
    var _a3, _b2, _c, _d;
    const url = `https://p.media-imdb.com/static-content/documents/v1/title/${imdbId}/ratings%3Fjsonp=imdb.rating.run:imdb.api.title.ratings/data.json`;
    const data = await fetch(url, {
      responseType: void 0
    });
    const { resource } = (_b2 = JSON.parse((_a3 = data.match(/[^(]+\((.+)\)/)) == null ? void 0 : _a3[1])) != null ? _b2 : {};
    return {
      count: resource.ratingCount,
      value: resource.rating,
      id: (_d = (_c = resource.id.match(/tt\d+/)) == null ? void 0 : _c[0]) != null ? _d : ""
    };
  };
  var formatDoubanInfo = async (data) => {
    var _a3, _b2;
    const {
      rating,
      pubdate,
      year,
      languages,
      genres,
      title,
      intro,
      actors,
      durations,
      cover_url,
      countries,
      url,
      original_title,
      directors,
      aka,
      episodes_count,
      credits,
      awards
    } = data;
    const { imdbUrl } = TORRENT_INFO;
    let imdbId = "";
    if (!imdbUrl) {
      imdbId = await getIMDBFromDouban(url);
    } else {
      imdbId = getIMDBIdByUrl(imdbUrl);
    }
    const imdbRate = await getIMDBRating(imdbId);
    let foreignTitle = "";
    if (original_title && title !== original_title) {
      foreignTitle = original_title;
    }
    let poster = cover_url;
    if (poster.includes("img3")) {
      poster = poster.replace("img3", "img1").replace(/m(_ratio_poster)/, "l$1");
    }
    const formatData = {
      imdbId: imdbRate.id,
      imdbLink: `https://www.imdb.com/title/${imdbRate.id}/`,
      imdbAverageRating: imdbRate.value,
      imdbVotes: imdbRate.count,
      imdbRating: `${(_a3 = imdbRate == null ? void 0 : imdbRate.value) != null ? _a3 : 0}/10 from ${(_b2 = imdbRate == null ? void 0 : imdbRate.count) != null ? _b2 : 0} users`,
      chineseTitle: title,
      foreignTitle,
      aka,
      transTitle: Array.from(/* @__PURE__ */ new Set([original_title ? title : "", ...aka])).filter(Boolean),
      thisTitle: [original_title || title],
      // original_title
      year,
      playDate: pubdate,
      region: countries.join(" / "),
      genre: genres,
      language: languages,
      episodes: episodes_count > 0 ? `${episodes_count}` : "",
      duration: durations.join(" / "),
      introduction: intro,
      doubanLink: url,
      doubanRatingAverage: rating.value,
      doubanVotes: `${rating.count}`,
      doubanRating: `${rating.value}/10 from ${rating.count} users`,
      poster,
      director: directors,
      cast: actors,
      writer: [],
      credits,
      awards
    };
    formatData.format = getDoubanFormat(formatData);
    return formatData;
  };
  var getDoubanFormat = (data) => {
    const {
      poster,
      thisTitle,
      transTitle,
      genre,
      year: movieYear,
      region,
      language,
      playDate,
      imdbRating,
      imdbLink,
      doubanRating,
      doubanLink,
      episodes: showEpisodes,
      duration: movieDuration,
      introduction,
      awards,
      tags,
      credits = []
    } = data;
    const spaceStr = "\xA0".repeat(7);
    const creditsData = credits.map((credit) => {
      const celebrity = credit.celebrities.map((item) => {
        return `${item.name} ${item.latin_name}`;
      });
      const repeatMap = {
        2: 7,
        3: 2,
        4: 0,
        5: 0
      };
      const celebrityKey = credit.title.split("").join("\xA0".repeat((repeatMap == null ? void 0 : repeatMap[credit.title.length]) || 0));
      const celebrityValue = celebrity.join(`
${"\xA0".repeat(24)}`).trim();
      return `\u25CE${celebrityKey}${spaceStr}${celebrityValue}`;
    });
    let descr = poster ? `[img]${poster}[/img]

` : "";
    descr += transTitle ? `\u25CE\u8BD1${spaceStr}\u540D${spaceStr}${transTitle.join(" / ")}
` : "";
    descr += thisTitle ? `\u25CE\u7247${spaceStr}\u540D${spaceStr}${thisTitle.join(" / ")}
` : "";
    descr += movieYear ? `\u25CE\u5E74${spaceStr}\u4EE3${spaceStr}${movieYear.trim()}
` : "";
    descr += region ? `\u25CE\u4EA7${spaceStr}\u5730${spaceStr}${region}
` : "";
    descr += genre ? `\u25CE\u7C7B${spaceStr}\u522B${spaceStr}${genre.join(" / ")}
` : "";
    descr += language ? `\u25CE\u8BED${spaceStr}\u8A00${spaceStr}${language.join(" / ")}
` : "";
    descr += playDate ? `\u25CE\u4E0A\u6620\u65E5\u671F${spaceStr} ${playDate.join(" / ")}
` : "";
    descr += imdbRating ? `\u25CEIMDb\u8BC4\u5206${spaceStr}${imdbRating}
` : "";
    descr += imdbLink ? `\u25CEIMDb\u94FE\u63A5${spaceStr}${imdbLink}
` : "";
    descr += doubanRating ? `\u25CE\u8C46\u74E3\u8BC4\u5206${spaceStr} ${doubanRating}
` : "";
    descr += doubanLink ? `\u25CE\u8C46\u74E3\u94FE\u63A5${spaceStr} ${doubanLink}
` : "";
    descr += showEpisodes ? `\u25CE\u96C6${spaceStr}\u6570${spaceStr}${showEpisodes}
` : "";
    descr += movieDuration ? `\u25CE\u7247${spaceStr}\u957F${spaceStr}${movieDuration}
` : "";
    descr += creditsData.length > 0 ? creditsData.join("\n") : "";
    descr += tags && tags.length > 0 ? `
\u25CE\u6807${spaceStr}\u7B7E${spaceStr}${tags.join(" | ")} 
` : "";
    descr += introduction ? `
\u25CE\u7B80${spaceStr}\u4ECB

  ${introduction.replace(/\n/g, `
${"\xA0".repeat(2)}`)} 
` : "";
    descr += awards ? `
\u25CE\u83B7\u5956\u60C5\u51B5

\u3000\u3000${awards.replace(/\n/g, `
${"\xA0".repeat(6)}`)} 
` : "";
    return descr.trim();
  };
  var getDoubanIdByIMDB = async (query) => {
    var _a3, _b2, _c, _d;
    try {
      const imdbId = getIMDBIdByUrl(query);
      const params = imdbId || query;
      const url = DOUBAN_SUGGEST_API.replace("{query}", params);
      const options = {
        cookie: "",
        anonymous: false,
        responseType: void 0
      };
      const cookie = getValue("easy-seed.douban-cookie", false);
      if (cookie) {
        options.cookie = cookie;
        options.anonymous = true;
      }
      const data = await fetch(url, options);
      const doc = new DOMParser().parseFromString(data, "text/html");
      const linkDom = doc.querySelector(".result-list .result h3 a");
      if (!linkDom) {
        throw $t("\u8C46\u74E3ID\u83B7\u53D6\u5931\u8D25");
      } else {
        const { href, textContent } = linkDom;
        const season = (_b2 = (_a3 = textContent == null ? void 0 : textContent.match(/第(.+?)季/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
        const doubanId = (_d = (_c = decodeURIComponent(href).match(/subject\/(\d+)/)) == null ? void 0 : _c[1]) != null ? _d : "";
        return {
          id: doubanId,
          season,
          title: textContent || ""
        };
      }
    } catch (error) {
      handleError(error);
    }
  };
  var getIMDBData = async (imdbUrl) => {
    try {
      if (!imdbUrl) {
        throw new Error("$t(\u7F3A\u5C11IMDB\u4FE1\u606F)");
      }
      const data = await fetch(`${PT_GEN_API}?url=${imdbUrl}`);
      if (data && data.success) {
        return data;
      }
      throw data.error || $t("\u8BF7\u6C42\u5931\u8D25");
    } catch (error) {
      handleError(error);
    }
  };
  var transferImgs = async (screenshot, authToken, imgHost = "https://imgbb.com/json") => {
    try {
      const isHdbHost = !!screenshot.match(/i\.hdbits\.org/);
      const formData = new FormData();
      if (isHdbHost || imgHost.includes("gifyu")) {
        const promiseArray = [urlToFile(screenshot)];
        const [fileData] = await Promise.all(promiseArray);
        formData.append("type", "file");
        formData.append("source", fileData);
      } else {
        formData.append("type", "url");
        formData.append("source", screenshot);
      }
      formData.append("action", "upload");
      formData.append("timestamp", `${Date.now()}`);
      formData.append("auth_token", authToken);
      const res = await fetch(imgHost, {
        method: "POST",
        data: formData,
        timeout: 3e5
      });
      if (res.status_txt !== "OK") {
        throw $t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5");
      }
      if (res.image) {
        return res.image;
      }
      throw $t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5");
    } catch (error) {
      console.log("err:", error);
      handleError(error);
    }
  };
  var uploadToPixhost = async (screenshots) => {
    try {
      const params = encodeURI(`imgs=${screenshots.join("\n")}&content_type=1&max_th_size=300`);
      const res = await fetch("https://pixhost.to/remote/", {
        method: "POST",
        data: params,
        timeout: 3e5,
        headers: {
          Accept: "application/json",
          "Content-Type": "application/x-www-form-urlencoded;charset=utf-8"
        },
        responseType: void 0
      });
      const data = res.match(/(upload_results = )({.*})(;)/);
      if (!data) {
        throw $t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5");
      }
      let imgResultList = [];
      if (data && data.length) {
        imgResultList = JSON.parse(data[2]).images;
        if (imgResultList.length < 1) {
          throw new Error($t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5"));
        }
        return imgResultList;
      }
      throw new Error($t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5"));
    } catch (error) {
      handleError(error);
    }
  };
  var uploadToImgbox = async (screenshot, authToken, tokenSecret) => {
    const file = await urlToFile(screenshot);
    const { token_id, token_secret } = tokenSecret;
    const options = {
      method: "POST",
      headers: {
        "X-CSRF-Token": authToken
      }
    };
    const formData = new FormData();
    formData.append("token_id", token_id);
    formData.append("token_secret", token_secret);
    formData.append("content_type", "1");
    formData.append("thumbnail_size", "350r");
    formData.append("gallery_id", "null");
    formData.append("gallery_secret", "null");
    formData.append("comments_enabled", "0");
    formData.append("files[]", file);
    options.data = formData;
    const data = await fetch("https://imgbox.com/upload/process", options);
    if (data && data.files && data.files.length) {
      return data.files[0];
    }
  };
  var uploadToHDB = async (screenshots, galleryName) => {
    const apiUrl = "https://img.hdbits.org/upload_api.php";
    try {
      const promiseArray = screenshots.map((item) => {
        return urlToFile(item);
      });
      const files = await Promise.all(promiseArray);
      const firstFile = files.shift();
      const formData = new FormData();
      formData.append("galleryoption", "1");
      formData.append("galleryname", galleryName);
      formData.append("images_files[]", firstFile);
      const firstResp = await fetch(apiUrl, {
        data: formData,
        method: "POST",
        responseType: void 0
      });
      if (firstResp.includes("error")) {
        throw firstResp;
      }
      const reqs = files.map((file) => {
        const formData2 = new FormData();
        formData2.append("galleryoption", "2");
        formData2.append("galleryname", galleryName);
        formData2.append("images_files[]", file);
        return fetch(apiUrl, {
          data: formData2,
          method: "POST",
          responseType: void 0
        });
      });
      const resp = await Promise.all(reqs);
      const respStr = resp.join("");
      if (respStr.includes("error")) {
        throw respStr;
      }
      return firstResp + respStr;
    } catch (error) {
      handleError(error);
    }
  };
  var getPreciseCategory = (torrentInfo2, category) => {
    var _a3, _b2;
    const { description, title, subtitle, doubanInfo } = torrentInfo2;
    const movieGenre = (_b2 = (_a3 = (description + doubanInfo).match(/(类\s+别)\s+(.+)?/)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
    if (movieGenre.match(/动画/)) {
      return "cartoon";
    } else if (movieGenre.match(/纪录/)) {
      return "documentary";
    } else if ((subtitle == null ? void 0 : subtitle.match(/全.+?集/)) || title.match(/s0?\d{1,2}[^(e|.e)]/i)) {
      return "tvPack";
    }
    if (category == null ? void 0 : category.match(/tv/)) {
      if (title.match(/(s0?\d{1,2})?e(p)?\d{1,2}/i) || (subtitle == null ? void 0 : subtitle.match(/第[^\s]集/))) {
        return "tv";
      }
      return "tvPack";
    }
    return category;
  };
  var getUrlParam = (key) => {
    const reg = new RegExp(`(^|&)${key}=([^&]*)(&|$)`);
    const regArray = location.search.substring(1).match(reg);
    if (regArray) {
      return decodeURIComponent(regArray[2]);
    }
    return "";
  };
  var getAudioCodecFromTitle = (title) => {
    if (!title) {
      return "";
    }
    title = title.replace(/:|-|\s/g, "");
    if (title.match(/atmos/i)) {
      return "atmos";
    } else if (title.match(/dtshdma/i)) {
      return "dtshdma";
    } else if (title.match(/dtsx/i)) {
      return "dtsx";
    } else if (title.match(/dts/i)) {
      return "dts";
    } else if (title.match(/truehd/i)) {
      return "truehd";
    } else if (title.match(/lpcm/i)) {
      return "lpcm";
    } else if (title.match(/flac/i)) {
      return "flac";
    } else if (title.match(/aac/i)) {
      return "aac";
    } else if (title.match(/DD\+|DDP|DolbyDigitalPlus/i)) {
      return "dd+";
    } else if (title.match(/DD|DolbyDigital/i)) {
      return "dd";
    } else if (title.match(/ac3/i)) {
      return "ac3";
    }
    return "";
  };
  var getVideoCodecFromTitle = (title, videoType = "") => {
    title = title.replace(/\.|-/g, "");
    if (title.match(/x264/i) || title.match(/h264|avc/i) && videoType === "encode") {
      return "x264";
    } else if (title.match(/h264|AVC/i)) {
      return "h264";
    } else if (title.match(/x265/i) || title.match(/h265|hevc/i) && videoType === "encode") {
      return "x265";
    } else if (title.match(/hevc|h265/i)) {
      return "hevc";
    } else if (title.match(/vc-?1/i)) {
      return "vc1";
    } else if (title.match(/mpeg-?2/i)) {
      return "mpeg2";
    } else if (title.match(/mpeg-?4/i)) {
      return "mpeg4";
    } else if (title.match(/vvc/i)) {
      return "vvc";
    }
    return "";
  };
  var getFilterImages = (bbcode) => {
    var _a3;
    if (!bbcode) {
      return [];
    }
    let allImages = Array.from((_a3 = bbcode.match(/(\[url=(http(s)*:\/{2}.+?)\])?\[img\](.+?)\[\/img](\[url\])?/ig)) != null ? _a3 : []);
    if (allImages && allImages.length > 0) {
      allImages = allImages.map((img) => {
        if (img.match(/\[url=.+?\]/)) {
          return `${img}[/url]`;
        }
        return img;
      });
      return allImages.filter((item) => {
        return !item.match(/poster\.jpg|2019\/01\/04\/info\.png|MoreScreens|PTer\.png|ms\.png|trans\.gif|PTerREMUX\.png|PTerWEB\.png|CS\.png|Ourbits_info|GDJT|douban|logo|(2019\/03\/28\/5c9cb8f8216d7\.png)|_front|(info_01\.png)|(screens\.png)|(04\/6b\/Ggp5ReQb_o)|(ce\/e7\/KCmGFMOB_o)/);
      });
    }
    return [];
  };
  var getScreenshotsFromBBCode = async (bbcode) => {
    const allImages = getFilterImages(bbcode);
    if (allImages && allImages.length > 0) {
      const result = [];
      for (const img of allImages) {
        const originalUrl = await getOriginalImgUrl(img);
        if (originalUrl !== void 0) {
          result.push(originalUrl);
        }
      }
      return result;
    }
    return [];
  };
  var getOriginalImgUrl = async (urlBBcode) => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o;
    let imgUrl = urlBBcode;
    if (urlBBcode.match(/\[url=http(s)*:.+/)) {
      imgUrl = (_b2 = (_a3 = urlBBcode.match(/=(([^\]])+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
      if (imgUrl.match(/img\.hdbits\.org/)) {
        const imgId = (_d = (_c = urlBBcode.match(/\[url=https:\/\/img\.hdbits\.org\/(\w+)?\]/)) == null ? void 0 : _c[1]) != null ? _d : "";
        imgUrl = `https://i.hdbits.org/${imgId}.png`;
      } else if (urlBBcode.match(/img\.pterclub\.com/)) {
        imgUrl = (_f = (_e = urlBBcode.match(/img\](([^[])+)/)) == null ? void 0 : _e[1]) != null ? _f : "";
        imgUrl = imgUrl.replace(/\.th/g, "");
      } else if (urlBBcode.match(/https?:\/\/imgbox\.com/)) {
        imgUrl = (_h = (_g = urlBBcode.match(/img\](([^[])+)/)) == null ? void 0 : _g[1]) != null ? _h : "";
        imgUrl = imgUrl.replace(/thumbs(\d)/, "images$1").replace(/_t(\.png)/, "_o.png");
      } else if (imgUrl.match(/imagebam\.com/)) {
        const originalPage = await fetch(imgUrl, {
          responseType: void 0
        });
        const doc = new DOMParser().parseFromString(originalPage, "text/html");
        imgUrl = jQuery(".main-image", doc).attr("src");
      } else if (imgUrl.match(/beyondhd\.co/)) {
        imgUrl = (_j = (_i = urlBBcode.match(/img\](([^[])+)/)) == null ? void 0 : _i[1]) != null ? _j : "";
        imgUrl = imgUrl.replace(/\.(th|md)\.(png|jpg|gif)/, ".$2");
      } else if (!imgUrl.match(/\.(jpg|png|gif|bmp|webp)$/)) {
        imgUrl = (_l = (_k = urlBBcode.match(/img\](([^[])+)/)) == null ? void 0 : _k[1]) != null ? _l : "";
      } else if (urlBBcode.match(/https:\/\/pixhost\.to/)) {
        const hostNumber = (_m = urlBBcode.match(/img\]https:\/\/t(\d+)\./)) == null ? void 0 : _m[1];
        imgUrl = imgUrl.replace(/(pixhost\.to)\/show/, `img${hostNumber}.$1/images`);
      }
    } else if (urlBBcode.match(/\[img\]/)) {
      imgUrl = (_o = (_n = urlBBcode.match(/img\](([^[])+)/)) == null ? void 0 : _n[1]) != null ? _o : "";
    }
    return imgUrl;
  };
  var getSourceFromTitle = (title) => {
    if (title.match(/(uhd|2160|4k).*(blu(-)?ray|remux)/i)) {
      return "uhdbluray";
    } else if (title.match(/blu(-)?ray|remux/i)) {
      return "bluray";
    } else if (title.match(/hdtv/i)) {
      return "hdtv";
    } else if (title.match(/web(-?(rip|dl))+/i)) {
      return "web";
    } else if (title.match(/hddvd/i)) {
      return "hddvd";
    } else if (title.match(/dvd/i)) {
      return "dvd";
    } else if (title.match(/vhs/i)) {
      return "vhs";
    }
    return "other";
  };
  var getSubTitle = (data) => {
    var _a3, _b2;
    const { chineseTitle, thisTitle: originalTitle, transTitle } = data;
    let title = "";
    if (chineseTitle.match(/[\u4e00-\u9fa5]+/)) {
      title += chineseTitle;
    }
    const moreTitle = originalTitle.concat(transTitle).filter((item) => title !== item);
    let seasonEpisode = (_b2 = (_a3 = TORRENT_INFO.title.match(/S\d+EP?(\d+)?/i)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    seasonEpisode = seasonEpisode.replace(/^0/i, "");
    const episode = seasonEpisode ? ` \u7B2C${seasonEpisode}\u96C6` : "";
    const hardcodedSub = TORRENT_INFO.hardcodedSub ? "| \u786C\u5B57\u5E55" : "";
    return `${title}${moreTitle.length > 0 ? "/" : ""}${moreTitle.join("/")}${episode} ${hardcodedSub}`;
  };
  var getAreaCode = (area) => {
    const europeList = EUROPE_LIST;
    if (area) {
      if (area.match(/USA|US|Canada|CA|美国|加拿大|United States/i)) {
        return "US";
      } else if (europeList.includes(area) || area.match(/欧|英|法|德|俄|意|苏联|EU/i)) {
        return "EU";
      } else if (area.match(/Japan|日本|JP/i)) {
        return "JP";
      } else if (area.match(/Korea|韩国|KR/i)) {
        return "KR";
      } else if (area.match(/Taiwan|台湾|TW/i)) {
        return "TW";
      } else if (area.match(/Hong\s?Kong|香港|HK/i)) {
        return "HK";
      } else if (area.match(/CN|China|大陆|中|内地|Mainland/i)) {
        return "CN";
      }
    }
    return "OT";
  };
  var getBDType = (size) => {
    const GBSize = size / 1e9;
    if (GBSize < 5) {
      return "DVD5";
    } else if (GBSize < 9) {
      return "DVD9";
    } else if (GBSize < 25) {
      return "BD25";
    } else if (GBSize < 50) {
      return "BD50";
    } else if (GBSize < 66) {
      return "BD66";
    } else if (GBSize < 100) {
      return "BD100";
    }
  };
  var getTMDBIdByIMDBId = async (imdbid) => {
    try {
      const url = `${TMDB_API_URL}/3/find/${imdbid}?api_key=${TMDB_API_KEY}&language=en&external_source=imdb_id`;
      const data = await fetch(url);
      const isMovie = data.movie_results && data.movie_results.length > 0;
      const isTV = data.tv_results && data.tv_results.length > 0;
      if (!isMovie && !isTV) {
        throw $t("\u8BF7\u6C42\u5931\u8D25");
      }
      const tmdbData = isMovie ? data.movie_results[0] : data.tv_results[0];
      return tmdbData;
    } catch (error) {
      return {};
    }
  };
  var getTMDBVideos = async (tmdbId) => {
    const url = `${TMDB_API_URL}/3/movie/${tmdbId}/videos?api_key=${TMDB_API_KEY}&language=en`;
    const data = await fetch(url);
    return data.results || [];
  };
  var getIMDBIdByUrl = (imdbLink) => {
    const imdbIdArray = /tt\d+/.exec(imdbLink);
    if (imdbIdArray && imdbIdArray[0]) {
      return imdbIdArray[0];
    }
    return "";
  };
  var getSize = (size) => {
    if (!size) {
      return 0;
    }
    if (size.match(/T/i)) {
      return parseFloat(size) * 1024 * 1024 * 1024 * 1024 || 0;
    } else if (size.match(/G/i)) {
      return parseFloat(size) * 1024 * 1024 * 1024 || 0;
    } else if (size.match(/M/i)) {
      return parseFloat(size) * 1024 * 1024 || 0;
    } else if (size.match(/K/i)) {
      return parseFloat(size) * 1024 || 0;
    }
    return 0;
  };
  var getInfoFromMediaInfo = (mediaInfo) => {
    var _a3, _b2, _c;
    if (!mediaInfo) {
      return {};
    }
    const mediaArray = mediaInfo.split(/\n\s*\n/).filter((item) => !!item.trim());
    const [generalPart, videoPart] = mediaArray;
    const secondVideoPart = mediaArray.filter((item) => item.startsWith("Video #2"));
    const [audioPart, ...otherAudioPart] = mediaArray.filter((item) => item.startsWith("Audio"));
    const textPart = mediaArray.filter((item) => item.startsWith("Text"));
    const completeName = getMediaValueByKey("Complete name", generalPart);
    const format = (_c = (_b2 = (_a3 = completeName == null ? void 0 : completeName.match(/\.(\w+)$/i)) == null ? void 0 : _a3[1]) == null ? void 0 : _b2.toLowerCase()) != null ? _c : "";
    const fileName = completeName.replace(/\.\w+$/i, "");
    const fileSize = getSize(getMediaValueByKey("File size", generalPart));
    const { videoCodec, hdrFormat, isDV } = getVideoCodecByMediaInfo(videoPart, generalPart, secondVideoPart);
    const { audioCodec, channelName, languageArray } = getAudioCodecByMediaInfo(audioPart, otherAudioPart);
    const subtitleLanguageArray = textPart.map((item) => {
      return getMediaValueByKey("Language", item);
    }).filter((sub) => !!sub);
    const mediaTags = getMediaTags(audioCodec, channelName, languageArray, subtitleLanguageArray, hdrFormat, isDV);
    const resolution = getResolution(videoPart);
    return {
      fileName,
      fileSize,
      format,
      subtitles: subtitleLanguageArray,
      videoCodec,
      audioCodec,
      resolution,
      mediaTags
    };
  };
  var getMediaValueByKey = (key, mediaInfo) => {
    var _a3, _b2;
    if (!mediaInfo) {
      return "";
    }
    const keyRegStr = key.replace(/\s/, "\\s*").replace(/(\(|\))/g, "\\$1");
    const reg = new RegExp(`${keyRegStr}\\s*:\\s([^\\n]+)`, "i");
    return (_b2 = (_a3 = mediaInfo.match(reg)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
  };
  var getResolution = (mediaInfo) => {
    const height = parseInt(getMediaValueByKey("Height", mediaInfo).replace(/\s/g, ""), 10);
    const width = parseInt(getMediaValueByKey("Width", mediaInfo).replace(/\s/g, ""), 10);
    const ScanType = getMediaValueByKey("Scan type", mediaInfo);
    if (height > 1080) {
      return "2160p";
    } else if (height > 720 && (ScanType === "Progressive" || !ScanType)) {
      return "1080p";
    } else if (height > 720 && ScanType !== "Progressive") {
      return "1080i";
    } else if (height > 576 || width > 1024) {
      return "720p";
    } else if (height > 480 || width === 1024) {
      return "576p";
    } else if (width >= 840 || height === 480) {
      return "480p";
    } else if (width && height) {
      return `${width}x${height}`;
    }
    return "";
  };
  var getMediaTags = (audioCodec, channelName, languageArray, subtitleLanguageArray, hdrFormat, isDV) => {
    const hasChineseAudio = languageArray.includes("Chinese");
    const hasChineseSubtitle = subtitleLanguageArray.includes("Chinese");
    const mediaTags = {};
    if (hasChineseAudio) {
      mediaTags.chinese_audio = true;
    }
    if (languageArray.includes("Cantonese")) {
      mediaTags.cantonese_audio = true;
    }
    if (hasChineseSubtitle) {
      mediaTags.chinese_subtitle = true;
    }
    if (hdrFormat) {
      if (hdrFormat.match(/HDR10\+/i)) {
        mediaTags.hdr10_plus = true;
      } else if (hdrFormat.match(/HDR/i)) {
        mediaTags.hdr = true;
      }
    }
    if (isDV) {
      mediaTags.dolby_vision = true;
    }
    if (audioCodec.match(/dtsx|atmos/ig)) {
      mediaTags.dts_x = true;
    } else if (audioCodec.match(/atmos/ig)) {
      mediaTags.dolby_atmos = true;
    }
    return mediaTags;
  };
  var getVideoCodecByMediaInfo = (mainVideo, generalPart, secondVideo) => {
    const generalFormat = getMediaValueByKey("Format", generalPart);
    const videoFormat = getMediaValueByKey("Format", mainVideo);
    const videoFormatVersion = getMediaValueByKey("Format version", mainVideo);
    const videoCodeId = getMediaValueByKey("Codec ID", mainVideo);
    const hdrFormat = getMediaValueByKey("HDR format", mainVideo);
    const isDV = hdrFormat.match(/Dolby\s*Vision/i) || secondVideo.length > 0 && getMediaValueByKey("HDR format", secondVideo[0]).match(/Dolby\s*Vision/i);
    const isEncoded = !!getMediaValueByKey("Encoding settings", mainVideo);
    let videoCodec = "";
    if (generalFormat === "DVD Video") {
      videoCodec = "mpeg2";
    } else if (generalFormat === "MPEG-4") {
      videoCodec = "mpeg4";
    } else if (videoFormat === "MPEG Video" && videoFormatVersion === "Version 2") {
      videoCodec = "mpeg2";
    } else if (videoCodeId.match(/xvid/i)) {
      videoCodec = "xvid";
    } else if (videoFormat.match(/HEVC/i) && !isEncoded) {
      videoCodec = "hevc";
    } else if (videoFormat.match(/HEVC/i) && isEncoded) {
      videoCodec = "x265";
    } else if (videoFormat.match(/AVC/i) && isEncoded) {
      videoCodec = "x264";
    } else if (videoFormat.match(/AVC/i) && !isEncoded) {
      videoCodec = "h264";
    } else if (videoFormat.match(/VC-1/i)) {
      videoCodec = "vc1";
    } else if (videoFormat.match(/vvc/i)) {
      videoCodec = "vvc";
    }
    return {
      videoCodec,
      hdrFormat,
      isDV: !!isDV
    };
  };
  var getAudioCodecByMediaInfo = (mainAudio, otherAudio) => {
    const audioFormat = getMediaValueByKey("Format", mainAudio);
    const audioChannels = getMediaValueByKey("Channel(s)", mainAudio);
    const commercialName = getMediaValueByKey("Commercial name", mainAudio);
    const formateProfile = getMediaValueByKey("Format profile", mainAudio);
    const languageArray = [mainAudio, ...otherAudio].map((item) => {
      return getMediaValueByKey("Language", item);
    });
    let channelName = "";
    let audioCodec = "";
    const channelNumber = parseInt(audioChannels, 10);
    if (channelNumber && channelNumber >= 6) {
      channelName = `${channelNumber - 1}.1`;
    } else {
      channelName = `${channelNumber}.0`;
    }
    if (audioFormat.match(/MLP FBA/i) && commercialName.match(/Dolby Atmos/i)) {
      audioCodec = "atmos";
    } else if (audioFormat.match(/MLP FBA/i) && !commercialName.match(/Dolby Atmos/i)) {
      audioCodec = "truehd";
    } else if (audioFormat.match(/AC-3/i) && commercialName.match(/Dolby Digital Plus/i)) {
      audioCodec = "dd+";
    } else if (audioFormat.match(/AC-3/i) && commercialName.match(/Dolby Digital/i)) {
      audioCodec = "dd";
    } else if (audioFormat.match(/AC-3/i)) {
      audioCodec = "ac3";
    } else if (audioFormat.match(/DTS XLL X/i)) {
      audioCodec = "dtsx";
    } else if (audioFormat.match(/DTS/i) && commercialName.match(/DTS-HD Master Audio/i)) {
      audioCodec = "dtshdma";
    } else if (audioFormat.match(/DTS/i) && formateProfile.match(/MA \/ Core/i)) {
      audioCodec = "dtshdma";
    } else if (audioFormat.match(/DTS/i)) {
      audioCodec = "dts";
    } else if (audioFormat.match(/FLAC/i)) {
      audioCodec = "flac";
    } else if (audioFormat.match(/AAC/i)) {
      audioCodec = "aac";
    } else if (audioFormat.match(/LPCM/i)) {
      audioCodec = "lpcm";
    }
    return {
      audioCodec,
      channelName,
      languageArray
    };
  };
  var getInfoFromBDInfo = (bdInfo) => {
    var _a3, _b2, _c, _d, _e;
    if (!bdInfo) {
      return {};
    }
    const splitArray = bdInfo.split("Disc Title");
    if (splitArray.length > 2) {
      bdInfo = splitArray[1];
    }
    const videoMatch = bdInfo.match(/VIDEO:(\s|Codec|Bitrate|Description|Language|-)*((.|\n)*)AUDIO:/i);
    const hasFileInfo = bdInfo.match(/FILES:/i);
    const subtitleReg = new RegExp(`SUBTITLE(S)*:(\\s|Codec|Bitrate|Description|Language|-)*((.|\\n)*)${hasFileInfo ? "FILES:" : ""}`, "i");
    const subtitleMatch = bdInfo.match(subtitleReg);
    const audioReg = new RegExp(`AUDIO:(\\s|Codec|Bitrate|Description|Language|-)*((.|\\n)*)${subtitleMatch ? "(SUBTITLE(S)?)" : hasFileInfo ? "FILES:" : ""}`, "i");
    const audioMatch = bdInfo.match(audioReg);
    const fileSize = (_b2 = (_a3 = bdInfo.match(/Disc\s*Size:\s*((\d|,| )+)bytes/)) == null ? void 0 : _a3[1]) == null ? void 0 : _b2.replace(/,/g, "");
    const quickSummaryStyle = !bdInfo.match(/PLAYLIST REPORT/i);
    const videoPart = splitBDMediaInfo(videoMatch, 2);
    const [mainVideo = "", otherVideo = ""] = videoPart;
    const videoCodec = mainVideo.match(/2160/) ? "hevc" : "h264";
    const hdrFormat = (_d = (_c = mainVideo.match(/\/\s*HDR(\d)*(\+)*\s*\//i)) == null ? void 0 : _c[0]) != null ? _d : "";
    const isDV = !!otherVideo.match(/\/\s*Dolby\s*Vision\s*/i);
    const audioPart = splitBDMediaInfo(audioMatch, 2);
    const subtitlePart = splitBDMediaInfo(subtitleMatch, 3);
    const resolution = (_e = mainVideo.match(/\d{3,4}(p|i)/)) == null ? void 0 : _e[0];
    const { audioCodec = "", channelName = "", languageArray = [] } = getBDAudioInfo(audioPart, quickSummaryStyle);
    const subtitleLanguageArray = subtitlePart.map((item) => {
      var _a4, _b3, _c2, _d2;
      const quickStyleMatch = (_b3 = (_a4 = item.match(/(\w+)\s*\//)) == null ? void 0 : _a4[1]) != null ? _b3 : "";
      const normalMatch = (_d2 = (_c2 = item.match(/Graphics\s*(\w+)\s*(\d|\.)+\s*kbps/i)) == null ? void 0 : _c2[1]) != null ? _d2 : "";
      const language = quickSummaryStyle ? quickStyleMatch : normalMatch;
      return language;
    }).filter((sub) => !!sub);
    const mediaTags = getMediaTags(audioCodec, channelName, languageArray, subtitleLanguageArray, hdrFormat, isDV);
    return {
      fileSize,
      videoCodec,
      subtitles: subtitleLanguageArray,
      audioCodec,
      resolution,
      mediaTags,
      format: "m2ts"
    };
  };
  var splitBDMediaInfo = (matchArray, matchIndex) => {
    var _a3, _b2;
    return (_b2 = (_a3 = matchArray == null ? void 0 : matchArray[matchIndex]) == null ? void 0 : _a3.split("\n").filter((item) => !!item)) != null ? _b2 : [];
  };
  var getBDAudioInfo = (audioPart, quickSummaryStyle) => {
    var _a3, _b2;
    if (audioPart.length < 1) {
      return {};
    }
    const sortArray = audioPart.sort((a3, b3) => {
      var _a4, _b3, _c, _d;
      const firstBitrate = parseInt((_b3 = (_a4 = a3.match(/\/\s*(\d+)\s*kbps/i)) == null ? void 0 : _a4[1]) != null ? _b3 : "", 10);
      const lastBitrate = parseInt((_d = (_c = b3.match(/\/\s*(\d+)\s*kbps/i)) == null ? void 0 : _c[1]) != null ? _d : "", 10);
      return lastBitrate - firstBitrate;
    });
    const [mainAudio, secondAudio] = sortArray;
    const mainAudioCodec = getAudioCodecFromTitle(mainAudio);
    const secondAudioCodec = getAudioCodecFromTitle(secondAudio);
    let audioCodec = mainAudioCodec;
    let channelName = (_a3 = mainAudio.match(/\d\.\d/)) == null ? void 0 : _a3[0];
    if (mainAudioCodec === "lpcm" && secondAudioCodec === "dtshdma") {
      audioCodec = secondAudioCodec;
      channelName = (_b2 = mainAudio.match(/\d\.\d/)) == null ? void 0 : _b2[0];
    }
    const languageArray = sortArray.map((item) => {
      var _a4, _b3, _c, _d;
      const quickStyleMatch = (_b3 = (_a4 = item.match(/(\w+)\s*\//)) == null ? void 0 : _a4[1]) != null ? _b3 : "";
      const normalMatch = (_d = (_c = item.match(/Audio\s*(\w+)\s*\d+\s*kbps/)) == null ? void 0 : _c[1]) != null ? _d : "";
      const language = quickSummaryStyle ? quickStyleMatch : normalMatch;
      return language;
    });
    return {
      audioCodec,
      channelName,
      languageArray
    };
  };
  var wrappingBBCodeTag = ({ pre, post }, preTag, poTag) => {
    const isPre = typeof pre !== "undefined" && pre !== null;
    const isPost = typeof post !== "undefined" && post !== null;
    if (isPre) {
      pre.unshift(preTag);
    }
    if (isPost) {
      post.push(poTag);
    }
  };
  var getFilterBBCode = (content) => {
    var _a3;
    if (content) {
      const bbCodes = htmlToBBCode(content);
      return (_a3 = bbCodes == null ? void 0 : bbCodes.replace(/\[quote\]((.|\n)*?)\[\/quote\]/g, (match, p1) => {
        if (p1 && p1.match(/温馨提示|郑重|PT站|网上搜集|本种子|商业盈利|商业用途|带宽|寬帶|法律责任|Quote:|正版|商用|注明|后果|负责/)) {
          return "";
        }
        return match;
      })) != null ? _a3 : "";
    }
    return "";
  };
  var rgb2hex = (rgb) => {
    var _a3;
    const result = (_a3 = rgb == null ? void 0 : rgb.match(/^rgba?[\s+]?\([\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?/i)) != null ? _a3 : [];
    return result.length === 4 ? `#${`0${parseInt(result[1], 10).toString(16)}`.slice(-2)}${`0${parseInt(result[2], 10).toString(16)}`.slice(-2)}${`0${parseInt(result[3], 10).toString(16)}`.slice(-2)}` : "";
  };
  var ensureProperColor = (color) => {
    if (/rgba?/.test(color)) return rgb2hex(color);
    return color;
  };
  var htmlToBBCode = (node) => {
    var _a3, _b2, _c, _d, _e, _f, _g;
    const bbCodes = [];
    const pre = [];
    const post = [];
    const pp = wrappingBBCodeTag.bind(null, { pre, post });
    switch (node.nodeType) {
      case 1: {
        switch (node.tagName.toUpperCase()) {
          case "SCRIPT": {
            return "";
          }
          case "UL": {
            pp(null, null);
            break;
          }
          case "OL": {
            pp("[list=1]", "[/list]");
            break;
          }
          case "LI": {
            const { className } = node;
            if (CURRENT_SITE_INFO.siteType === "UNIT3D" && className) {
              return `[quote]${(_a3 = node == null ? void 0 : node.textContent) == null ? void 0 : _a3.trim()}[/quote]`;
            }
            pp("[*]", "\n");
            break;
          }
          case "B": {
            pp("[b]", "[/b]");
            break;
          }
          case "U": {
            pp("[u]", "[/u]");
            break;
          }
          case "I": {
            pp("[i]", "[/i]");
            break;
          }
          case "DIV": {
            const { className, id } = node;
            if (className === "codemain") {
              if (node.children[0] && node.children[0].tagName === "PRE") {
                pp("");
                break;
              } else {
                return "";
              }
            } else if (className === "hidden" && CURRENT_SITE_NAME === "HDT") {
              pp("\n[quote]", "[/quote]");
              break;
            } else if (className.match("spoiler") && CURRENT_SITE_NAME === "KG") {
              if (className === "spoiler-content") {
                pp("\n[quote]", "[/quote]");
              } else if (className === "spoiler-header") {
                return "";
              }
              break;
            } else if (CURRENT_SITE_NAME === "BeyondHD") {
              if (className === "spoilerChild") {
                if (node.children[0].tagName.toUpperCase() === "BLOCKQUOTE" || node.children[0].tagName.toUpperCase() === "PRE") pp("\n", "");
                else pp("\n[quote]", "[/quote]");
              } else if (id === "screenMain") {
                return "\n";
              } else if (className === "spoilerHide") {
                return "";
              }
              break;
            } else if (className === "spoiler-text" && CURRENT_SITE_INFO.siteType === "AvistaZ") {
              pp("\n[quote]", "[/quote]");
              break;
            } else if (className === "spoiler-toggle" && CURRENT_SITE_INFO.siteType === "AvistaZ") {
              return "";
            } else if (className.match(/codetop|highlight/) && CURRENT_SITE_INFO.siteType === "Bdc") {
              return "";
            } else {
              pp("\n", "\n");
              break;
            }
          }
          case "P": {
            pp("\n");
            break;
          }
          case "BR": {
            if (CURRENT_SITE_INFO.siteType === "NexusPHP" && CURRENT_SITE_NAME !== "OurBits" || ((_b2 = CURRENT_SITE_NAME) == null ? void 0 : _b2.match(/^(UHDBits|HDBits|BTN)/))) {
              pp("");
            } else {
              pp("\n");
            }
            break;
          }
          case "SPAN": {
            const { className } = node;
            if (className.match(/size/)) {
              const matchSize = (_d = (_c = className.match(/size(\d)/)) == null ? void 0 : _c[1]) != null ? _d : "";
              if (matchSize) {
                pp(`[size=${matchSize}]`, "[/size]");
              }
            } else {
              pp(null, null);
            }
            break;
          }
          case "BLOCKQUOTE":
          case "PRE":
          case "FIELDSET": {
            pp("[quote]", "[/quote]");
            break;
          }
          case "CENTER": {
            pp("[center]", "[/center]");
            break;
          }
          case "TD": {
            if (((_e = CURRENT_SITE_NAME) == null ? void 0 : _e.match(/^(TTG|HDBits|KG|HDSpace)/)) || CURRENT_SITE_NAME === "HDT" || CURRENT_SITE_INFO.siteType === "UNIT3D") {
              pp("[quote]", "[/quote]");
              break;
            } else if (CURRENT_SITE_NAME.match(/EMP|Bdc/)) {
              pp("");
              break;
            } else {
              return "";
            }
          }
          case "IMG": {
            let imgUrl = "";
            const { src, title } = node;
            const dataSrc = node.getAttribute("data-src") || node.getAttribute("data-echo");
            const layerSrc = node.getAttribute("layer-src");
            if (title === ":m:") {
              return ":m:";
            }
            if (layerSrc) {
              imgUrl = layerSrc;
            } else if (dataSrc) {
              imgUrl = dataSrc.match(/(http(s)?:)?\/\//) ? dataSrc : `${location.origin}/${dataSrc}`;
            } else if (src && src.match(/broadcity\.eu\/images\/44846549843542759058\.png/)) {
              return "";
            } else if (src && !src.match(/ico_\w+.gif|jinzhuan|thumbsup|kralimarko/)) {
              imgUrl = src;
            } else {
              return "";
            }
            return `[img]${imgUrl}[/img]`;
          }
          case "FONT": {
            const { color: color2, size } = node;
            if (color2) {
              pp(`[color=${ensureProperColor(color2)}]`, "[/color]");
            }
            if (size) {
              pp(`[size=${size}]`, "[/size]");
            }
            break;
          }
          case "A": {
            const { href, textContent } = node;
            if (href && href.length > 0) {
              if (CURRENT_SITE_NAME === "HDSpace") {
                const div = jQuery(node).find("div");
                if (div[0] && div.attr("id")) {
                  const imgUrl = div.find("img").attr("src");
                  return `[url=${href}][img]${imgUrl}[/img][/url]`;
                }
              } else if (href.match(/javascript:void/) || textContent === "show" && CURRENT_SITE_NAME === "HDT") {
                return "";
              } else {
                pp(`[url=${href}]`, "[/url]");
              }
            }
            break;
          }
          case "H1": {
            pp('[b][size="7"]', "[/size][/b]\n");
            break;
          }
          case "H2": {
            pp('[b][size="6"]', "[/size][/b]\n");
            break;
          }
          case "H3": {
            pp('[b][size="5"]', "[/size][/b]\n");
            break;
          }
          case "H4": {
            pp('[b][size="4"]', "[/size][/b]\n");
            break;
          }
          case "STRONG": {
            pp("[b]", "[/b]");
            break;
          }
        }
        const { textAlign, fontWeight, fontStyle, textDecoration, color } = node.style;
        if (textAlign) {
          switch (textAlign.toUpperCase()) {
            case "LEFT": {
              pp("[left]", "[/left]");
              break;
            }
            case "RIGHT": {
              pp("[right]", "[/right]");
              break;
            }
            case "CENTER": {
              pp("[center]", "[/center]");
              break;
            }
          }
        }
        if (fontWeight === "bold" || ~~fontWeight >= 600) {
          pp("[b]", "[/b]");
        }
        if (fontStyle === "italic") pp("[i]", "[/i]");
        if (textDecoration === "underline") pp("[u]", "[/u]");
        if (color && color.trim() !== "") pp(`[color=${ensureProperColor(color)}]`, "[/color]");
        break;
      }
      case 3: {
        if ((_g = (_f = node == null ? void 0 : node.textContent) == null ? void 0 : _f.trim()) == null ? void 0 : _g.match(/^(引用|Quote|代码|代碼|Show|Hide|Hidden text|Hidden content|\[show\]|\[Show\])/)) {
          return "";
        }
        return node.textContent;
      }
      default:
        return null;
    }
    node.childNodes.forEach((node2) => {
      const code = htmlToBBCode(node2);
      if (code) {
        bbCodes.push(code);
      }
    });
    return pre.concat(bbCodes).concat(post).join("");
  };
  var getTagsFromSubtitle = (title) => {
    const tags = {};
    if (title.match(/diy/i)) {
      tags.diy = true;
    }
    if (title.match(/国配|国语|普通话|国粤/i) && !title.match(/多国语(言|字幕)/)) {
      tags.chinese_audio = true;
    }
    if (title.match(/Atmos|杜比全景声/i)) {
      tags.dolby_atoms = true;
    }
    if (title.match(/HDR/i)) {
      if (title.match(/HDR10\+/i)) {
        tags.hdr10_plus = true;
      } else {
        tags.hdr = true;
      }
    }
    if (title.match(/DoVi|(Dolby\s*Vision)|杜比视界/i)) {
      tags.dolby_vision = true;
    }
    if (title.match(/粤/i)) {
      tags.cantonese_audio = true;
    }
    if (title.match(/简繁|繁简|繁体|简体|中字|中英|中文/i) && !title.match(/无中(字|文)/)) {
      tags.chinese_subtitle = true;
    }
    if (title.match(/Criterion|CC标准/i)) {
      tags.the_criterion_collection = true;
    }
    if (title.match(/禁转|禁轉|严禁转载|嚴禁轉載|谢绝转载|謝絕轉載|禁止转载|exclusive/)) {
      tags.exclusive = true;
    }
    return tags;
  };
  var getBDInfoOrMediaInfo = (bbcode) => {
    var _a3, _b2, _c;
    bbcode = bbcode.replace(/[\u00A0\u1680​\u180e\u2000-\u2009\u200a​\u200b​\u202f\u205f​\u3000]/g, "");
    const quoteList = (_a3 = bbcode == null ? void 0 : bbcode.match(/\[quote\](.|\n)+?\[\/quote\]/g)) != null ? _a3 : [];
    const bdinfo = [];
    const mediaInfo = [];
    quoteList.forEach((quote) => {
      const quoteContent = quote.replace(/\[\/?quote\]/g, "").replace(/\u200D/g, "");
      if (quoteContent.match(/Disc\s?Size|\.mpls/i)) {
        bdinfo.push(quoteContent);
      }
      if (quoteContent.match(/(Unique\s*ID)|(Codec\s*ID)|(Stream\s*size)/i)) {
        mediaInfo.push(quoteContent);
      }
    });
    if (!bdinfo.length) {
      const bdinfoMatch = (_c = (_b2 = bbcode.match(/Disc\s+(Info|Title|Label)[^[]+/i)) == null ? void 0 : _b2[0]) != null ? _c : "";
      if (bdinfoMatch) {
        bdinfo.push(bdinfoMatch);
      }
    }
    return {
      bdinfo,
      mediaInfo
    };
  };
  var replaceRegSymbols = (string) => {
    return string.replace(/([*.?+$^[\](){}|\\/])/g, "\\$1");
  };
  var getRtIdFromTitle = async (title, tv, year) => {
    var _a3;
    console.log("%s", title, year);
    const MAX_YEAR_DIFF = 2;
    tv = tv || false;
    const yearVal = parseInt(year, 10) || 1800;
    const url = `https://www.rottentomatoes.com/api/private/v2.0/search/?limit=2&q=${title}`;
    const data = await fetch(url);
    const movies = tv ? data.tvSeries : data.movies;
    if (!Array.isArray(movies) || movies.length < 1) {
      console.log("no search results");
      return {};
    }
    const sorted = movies.concat();
    if (year && sorted) {
      sorted.sort((a3, b3) => {
        if (Math.abs(a3.year - yearVal) !== Math.abs(b3.year - yearVal)) {
          return Math.abs(a3.year - yearVal) - Math.abs(b3.year - yearVal);
        }
        return b3.year - a3.year;
      });
    }
    let bestMatch, closeMatch;
    for (const m3 of sorted) {
      m3.title = m3.title || m3.name;
      if (m3.title.toLowerCase() === title.toLowerCase()) {
        bestMatch = bestMatch || m3;
        console.log("bestMatch", bestMatch);
      } else if (m3.title.toLowerCase().startsWith(title.toLowerCase())) {
        closeMatch = closeMatch || m3;
        console.log("closeMatch", closeMatch);
      }
      if (bestMatch && closeMatch) {
        break;
      }
    }
    const yearComp = (imdb, rt) => {
      return rt - imdb <= MAX_YEAR_DIFF && imdb - rt < MAX_YEAR_DIFF;
    };
    if (yearVal && (!bestMatch || !yearComp(yearVal, bestMatch.year))) {
      if (closeMatch && yearComp(yearVal, closeMatch.year)) {
        bestMatch = closeMatch;
      } else if (yearComp(yearVal, sorted[0].year)) {
        bestMatch = sorted[0];
      }
    }
    bestMatch = bestMatch || closeMatch || movies[0];
    if (bestMatch) {
      const id = bestMatch && bestMatch.url.replace(/\/s\d{2}\/?$/, "");
      const score = (_a3 = bestMatch == null ? void 0 : bestMatch.meterScore) != null ? _a3 : "0";
      return {
        id,
        score
      };
    }
    console.log("no match found on rt");
    return {};
  };
  var uploadToPtpImg = async (imgArray, isFiles = false) => {
    try {
      const apiKey = getValue("easy-seed.ptp-img-api-key", false);
      if (!apiKey) {
        Notification_default2.open({
          message: $t("ptpimg\u4E0A\u4F20\u5931\u8D25"),
          description: $t("\u8BF7\u5230\u914D\u7F6E\u9762\u677F\u4E2D\u586B\u5165ptpimg\u7684api_key")
        });
        return;
      }
      const options = {
        method: "POST",
        responseType: "json"
      };
      if (isFiles) {
        const formData = new FormData();
        imgArray.forEach((img, index) => {
          formData.append(`file-upload[${index}]`, img);
        });
        formData.append("api_key", apiKey);
        options.data = formData;
      } else {
        const data2 = `link-upload=${imgArray.join("\n")}&api_key=${apiKey}`;
        options.headers = {
          "Content-Type": "application/x-www-form-urlencoded;charset=utf-8"
        };
        options.data = data2;
      }
      const data = await fetch("https://ptpimg.me/upload.php", options);
      if (!data) {
        throw $t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5");
      }
      let imgResultList = [];
      if (data && data.length) {
        imgResultList = data.map((img) => {
          return `https://ptpimg.me/${img.code}.${img.ext}`;
        });
        return imgResultList;
      }
      throw $t("\u4E0A\u4F20\u5931\u8D25\uFF0C\u8BF7\u91CD\u8BD5");
    } catch (error) {
      handleError(error);
    }
  };
  var $t = (key) => {
    const languageKey = BROWSER_LANGUAGE;
    return i18n_default[languageKey][key] || key;
  };
  var urlToFile = async (url) => {
    var _a3, _b2;
    const filename = (_b2 = (_a3 = url.match(/\/([^/]+)$/)) == null ? void 0 : _a3[1]) != null ? _b2 : "filename";
    const data = await fetch(url, {
      responseType: "blob"
    });
    const file = new File([data], filename, { type: data.type });
    return file;
  };
  var saveScreenshotsToPtpimg = async (imgArray) => {
    try {
      const isHdbHost = !!imgArray[0].match(/i\.hdbits\.org/);
      const isPtpHost = !!imgArray[0].match(/ptpimg\.me/);
      if (isPtpHost) {
        throw $t("\u65E0\u9700\u8F6C\u5B58");
      } else if (isHdbHost) {
        const promiseArray = imgArray.map((item) => {
          return urlToFile(item);
        });
        const fileArray = await Promise.all(promiseArray);
        const data = uploadToPtpImg(fileArray, true);
        return data;
      } else {
        const data = await uploadToPtpImg(imgArray);
        return data;
      }
    } catch (error) {
      handleError(error);
    }
  };
  var getValue = (key, needParse = true) => {
    const data = GM_getValue(key);
    if (data && needParse) {
      return JSON.parse(data);
    }
    return data;
  };
  var fetch = (url, options) => {
    return new Promise((resolve, reject) => {
      GM_xmlhttpRequest(__spreadProps(__spreadValues({
        method: "GET",
        url,
        responseType: "json"
      }, options), {
        onload: (res) => {
          const { statusText, status, response } = res;
          if (status !== 200) {
            reject(new Error(statusText || `${status}`));
          } else {
            resolve(response);
          }
        },
        ontimeout: () => {
          reject(new Error("timeout"));
        },
        onerror: (error) => {
          reject(error);
        }
      }));
    });
  };
  var getTvSeasonData = async (data) => {
    var _a3, _b2;
    const { title: torrentTitle } = TORRENT_INFO;
    const { season = "", title } = data;
    if (season) {
      const seasonNumber = (_b2 = (_a3 = torrentTitle.match(/S(?!eason)?0?(\d+)\.?(EP?\d+)?/i)) == null ? void 0 : _a3[1]) != null ? _b2 : "1";
      if (parseInt(seasonNumber, 10) === 1) {
        return data;
      }
      const query = title.replace(/第.+?季/, `\u7B2C${seasonNumber}\u5B63`);
      const response = await getDoubanIdByIMDB(query);
      return response;
    }
  };
  var getSpecsFromMediainfo = (isBluray, mediaInfo) => {
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, resolution, mediaTags } = getInfoFunc(mediaInfo);
    if (videoCodec !== "" && audioCodec !== "" && resolution !== "") {
      return {
        videoCodec,
        audioCodec,
        resolution,
        mediaTags
      };
    }
    return {};
  };

  // src/target/index.ts
  init_preact_shim();

  // src/target/helper.ts
  init_preact_shim();

  // src/target/common.ts
  init_preact_shim();
  var getScreenshotsBBCode = (imgArray) => {
    return imgArray.map((img) => {
      if (img.match(/\[url=.+\]/i)) {
        return img;
      }
      return `[img]${img}[/img]`;
    });
  };
  var getTeamName = (info) => {
    var _a3, _b2, _c;
    const teamMatch = info.title.match(/-([^-]+)$/);
    let teamName = (_c = (_b2 = (_a3 = teamMatch == null ? void 0 : teamMatch[1]) == null ? void 0 : _a3.replace(/-/g, "")) == null ? void 0 : _b2.split("@")) != null ? _c : "";
    if (teamName) {
      teamName = teamName.length > 1 ? teamName[1] : teamName[0];
    } else {
      teamName = "other";
    }
    return teamName;
  };
  var matchSelectForm = (siteInfo, movieInfo, key, selectArray) => {
    const valueArray = siteInfo[key] ? siteInfo[key].map[movieInfo[key]] : "";
    if (Array.isArray(valueArray) && selectArray) {
      if (siteInfo[key].selector) {
        setSelectValue(siteInfo[key].selector, valueArray.shift());
      }
      if (selectArray.length > 1) {
        selectArray = selectArray.filter((item) => valueArray.includes(item));
      }
    } else if (siteInfo[key] && siteInfo[key].selector) {
      setSelectValue(siteInfo[key].selector, valueArray);
    }
    return selectArray;
  };
  function setSelectValue(selector, value) {
    if (CURRENT_SITE_NAME === "MTeam") {
      const select = document.querySelector(selector);
      if (select) {
        const lastValue = select.value;
        select.value = value;
        const tracker = select._valueTracker;
        if (tracker) {
          tracker.setValue(lastValue);
        }
        const event = new Event("change", { bubbles: true });
        select.dispatchEvent(event);
        setTimeout(() => {
          Array.from(document.querySelectorAll(".ant-select-item-option-active .ant-select-item-option-content")).forEach((el) => {
            el.dispatchEvent(new Event("click", { bubbles: true }));
          });
        }, 1e3);
      }
    } else {
      jQuery(selector).val(value);
    }
  }
  function buildPTPDescription(info) {
    let text = info.originalDescription || "";
    text = text.replace(/http:\/\/ptpimg\.me/g, "https://ptpimg.me");
    for (const mediainfo of info.mediaInfos) {
      text = text.replace(mediainfo, "");
    }
    text = text.replace(/\[(mediainfo|bdinfo)\][\s\S]*?\[\/(mediainfo|bdinfo)\]/gi, "");
    text = text.replace(/^(?!\[img\])https:\/\/ptpimg.me.*?png(?!\[\/img\])$/gim, (imgUrl) => {
      return `[img]${imgUrl}[/img]`;
    });
    text = text.replace(/\[comparison.*\][\s\S]*\[\/comparison\]/gi, (comparisonText) => {
      return comparisonText.replace(/\[img\]/g, "").replace(/\[\/img\]/g, "").split("https://ptpimg.me").join("\nhttps://ptpimg.me").replace(/\s*\n\s*/g, "\n");
    });
    text = text.replace(/\[hide(.*)?\]\s*\[url=https:\/\/ptpimg.me.*?png\]\[img\][\s\S]*?\[\/hide\]/gi, (imgText) => {
      var _a3;
      const imgs = [];
      for (const urlMatch of imgText.matchAll(/\[url=(.*?)\]/ig)) {
        imgs.push(urlMatch[1]);
      }
      const rawTitle = ((_a3 = imgText.match(/^\[hide=(.*?)\]/)) == null ? void 0 : _a3[1]) || "";
      const comparisonTitles = rawTitle.trim().split(/\||\/|,|vs\.?| - /i).map((v3) => v3.trim());
      if (comparisonTitles.length >= 2) {
        return `[comparison=${comparisonTitles.join(", ")}]
${imgs.join("\n")}
[/comparison]
`;
      }
      const hideTitle = rawTitle ? `=${rawTitle}` : "";
      return `[hide${hideTitle}]
[img]${imgs.join("[/img]\n[img]")}[/img]
[/hide]
`;
    });
    text = `${text}

`;
    text = text.replace(/\[url=https:\/\/ptpimg.me.*?png\]\[img\][\s\S]*?\n\n/gi, (imgText) => {
      const imgs = [];
      for (const urlMatch of imgText.matchAll(/\[url=(.*?)\]/ig)) {
        imgs.push(urlMatch[1]);
      }
      return `[hide]
[img]${imgs.join("[/img]\n[img]")}[/img]
[/hide]
`;
    });
    text = text.replace(/\[img=(.+)?\](\n\n)?/gi, "[img]$1[/img]");
    text = text.replace(/\[(\/)?IMG\]/g, "[$1img]");
    text = text.replace(/\n\s*\n/g, "\n\n");
    return text.trim();
  }
  var isChineseTacker = (siteType) => {
    return siteType.match(/NexusPHP|TTG|TNode|MTeam/);
  };
  var filterNexusDescription = (info) => {
    const { description } = info;
    let filterDescription = "";
    const quoteList = description.match(/\[quote(=\w+)?\](.|\n)+?\[\/quote\]/g);
    if (quoteList && quoteList.length > 0) {
      quoteList.forEach((quote) => {
        const isMediaInfoOrBDInfo = quote.match(/Disc\s?Size|\.mpls|Unique\s?ID|唯一ID|Resolution/i);
        if (!quote.match(/[\u4e00-\u9fa5]+/i) || isMediaInfoOrBDInfo) {
          filterDescription += `${quote}
`;
        }
      });
    }
    const allImages = getFilterImages(description);
    return `${filterDescription}
${allImages.join("")}`;
  };
  var filterEmptyTags = (description) => {
    const reg = new RegExp("\\[(?!info)([a-zA-Z]+\\d?)(?:=(?:\\w|\\s)+)?\\]\\s*\\[\\/(\\w+)\\]", "g");
    if (description.match(reg)) {
      description = description.replace(reg, (_match, p1, p22) => {
        if (p1 === p22) {
          return "";
        }
        return _match;
      });
      return filterEmptyTags(description);
    }
    return description;
  };
  var fixTorrentTitle = (title, isWebSource) => {
    let fixedTitle = title.replace(" DoVi ", " DV ").replace(" DDP ", " DD+ ");
    if (isWebSource) fixedTitle = fixedTitle.replace(" HEVC", " H.265");
    return fixedTitle;
  };
  var base64ToBlob = (base64, contentType = "application/x-bittorrent", sliceSize = 512) => {
    const regStr = new RegExp(`data:${contentType};base64,`, "i");
    const byteCharacters = window.atob(base64.replace(regStr, ""));
    const byteArrays = [];
    for (let offset = 0; offset < byteCharacters.length; offset += sliceSize) {
      const slice = byteCharacters.slice(offset, offset + sliceSize);
      const byteNumbers = new Array(slice.length);
      for (let i3 = 0; i3 < slice.length; i3++) {
        byteNumbers[i3] = slice.charCodeAt(i3);
      }
      const byteArray = new Uint8Array(byteNumbers);
      byteArrays.push(byteArray);
    }
    return new Blob(byteArrays, { type: contentType });
  };

  // src/target/site-operations.ts
  init_preact_shim();

  // src/target/its.ts
  init_preact_shim();
  var its_default = async (info) => {
    var _a3, _b2, _c, _d, _e, _f, _g;
    let template = `[center]

  [img]$poster$[/img]
  
  [url=$imdbUrl$][img]https://i.ibb.co/KD855ZM/IMDb-Logo-2016.png[/img][/url][size=3]$imdbScore$[/size][*][url=$rtUrl$][img]https://i.ibb.co/BwtmdcV/rottentomatoes-logo.png[/img][/url][size=3]$rtScore$[/size][*][size=3][url=$tmdbUrl$][img]https://i.ibb.co/HhgF1gC/tmdb-logo.png[/img][/url]$tmdbScore$[/size]


  [color=DarkOrange][size=2]\u25E2 SYNOPSIS \u25E3[/size][/color]
  $synopsis$
  
  [color=DarkOrange][size=2]\u25E2 TRAILER \u25E3[/size][/color]
  [youtube]$youtubeUrl$[/youtube]

  [color=DarkOrange][size=2]\u25E2 SCREENSHOTS \u25E3[/size][/color]
  [box][hide]$SCREENSHOTS$[/hide][/box]
  
  [/center]`;
    const collectionMap = {};
    jQuery('select[name="collection_id1"] option').each(function() {
      const option = jQuery(this);
      collectionMap[option.text()] = option.val();
    });
    const collectionValueArr = [];
    const teamName = getTeamName(info);
    if (collectionMap[teamName]) {
      collectionValueArr.push(collectionMap[teamName]);
    }
    const { imdbUrl, category, screenshots, comparisons = [], resolution, movieName } = info;
    if (!resolution.match(/2160|1080|720/) && category === "movie") {
      jQuery('select[name="type"]').val("67");
    }
    const screenshotsBBCode = getScreenshotsBBCode(screenshots);
    template = template.replace("$SCREENSHOTS$", screenshotsBBCode.join("\n"));
    const comparisonImgs = comparisons.flatMap((v3) => v3.imgs);
    if (comparisonImgs.length > 0) {
      const comparisonImgsBBCode = getScreenshotsBBCode(comparisonImgs);
      template = template.replace(/(\[\/center\])$/, `[color=DarkOrange][size=2]\u25E2 COMPARISONS \u25E3[/size][/color]


    [box][hide]${comparisonImgsBBCode.join(" ")}[/hide][/box]

$1`);
    }
    if (category.match(/tv|movie|cartoon|documentary/)) {
      jQuery('textarea[name="descr"]').val($t("\u6570\u636E\u52A0\u8F7D\u4E2D..."));
      try {
        const replaceParams = {
          tmdbUrl: "",
          tmdbScore: "0",
          imdbScore: "0",
          imdbUrl,
          poster: "",
          synopsis: "",
          rtUrl: "",
          rtScore: "0",
          youtubeUrl: ""
        };
        const imdbData = await getIMDBData(imdbUrl);
        if (imdbData) {
          const {
            poster = "",
            imdb_rating_average: imdbRate,
            description = "",
            directors = [],
            details,
            aka,
            year
          } = imdbData;
          let language = details.Languages || "";
          language = (_c = (_b2 = (_a3 = language == null ? void 0 : language.split("|")) == null ? void 0 : _a3[0]) == null ? void 0 : _b2.trim()) != null ? _c : "";
          const director = directors.map((item) => item.name)[0];
          if (collectionMap[director]) {
            collectionValueArr.push(collectionMap[director]);
          }
          if (collectionMap[language]) {
            collectionValueArr.push(collectionMap[language]);
          }
          collectionValueArr.forEach((value, index) => {
            jQuery(`select[name="collection_id${index + 1}"]`).val(value);
          });
          replaceParams.poster = poster;
          replaceParams.synopsis = description;
          replaceParams.imdbScore = imdbRate;
          const searchMovieName = movieName || ((_d = aka.filter((item) => item.country.match(/(World-wide)|UK|USA/))) == null ? void 0 : _d[0].title);
          const rtInfo = await getRtIdFromTitle(searchMovieName, !!category.match(/tv/), year);
          const { score = 0, id = "" } = rtInfo;
          replaceParams.rtScore = `${score}%`;
          replaceParams.rtUrl = `https://www.rottentomatoes.com/${id}`;
          const ptpImgApiKey = GM_getValue("easy-seed.ptp-img-api-key") || "";
          if (ptpImgApiKey) {
            const ptpImgPoster = await uploadToPtpImg([poster]);
            replaceParams.poster = ptpImgPoster ? ptpImgPoster[0] : "";
          }
        }
        const imdbId = getIMDBIdByUrl(imdbUrl);
        const { id: tmdbId, vote_average: tmdbRate } = await getTMDBIdByIMDBId(imdbId);
        if (tmdbId) {
          replaceParams.tmdbUrl = `https://www.themoviedb.org/movie/${tmdbId}`;
          replaceParams.tmdbScore = tmdbRate;
          const videos = await getTMDBVideos(tmdbId);
          const youtubeId = (_g = (_f = (_e = videos.filter((video) => video.site === "YouTube")) == null ? void 0 : _e[0]) == null ? void 0 : _f.key) != null ? _g : "";
          if (youtubeId.length > 0) {
            replaceParams.youtubeUrl = `https://www.youtube.com/watch?v=${youtubeId}`;
          }
        }
        Object.keys(replaceParams).forEach((key) => {
          template = template.replace(`$${key}$`, replaceParams[key] || "");
        });
        jQuery('textarea[name="descr"]').val(template);
      } catch (error) {
        jQuery('textarea[name="descr"]').val(error.message);
      }
    }
  };

  // src/target/tjupt.ts
  init_preact_shim();
  var tjupt_default = (info) => {
    const observer = new MutationObserver(() => {
      if (jQuery("#ename")[0] && jQuery("#cname")[0]) {
        fillInfo(info);
        observer.disconnect();
      }
    });
    const config = { childList: true, subtree: true };
    observer.observe(document.body, config);
  };
  function fillInfo(info) {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j;
    const { title, description, doubanInfo, category, tags } = info;
    jQuery("#ename").val(title);
    const fullDescription = description + doubanInfo;
    let area = (_b2 = (_a3 = fullDescription.match(/(产\s+地|国\s+家)\s+(.+)/)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
    area = area.replace(/\[\/?.+?\]/g, "");
    const originalName = (_d = (_c = fullDescription.match(/(片\s+名)\s+(.+)?/)) == null ? void 0 : _c[2]) != null ? _d : "";
    const translateName = (_h = (_g = (_f = (_e = fullDescription.match(/(译\s+名)\s+(.+)/)) == null ? void 0 : _e[2]) == null ? void 0 : _f.split("/")) == null ? void 0 : _g[0]) != null ? _h : "";
    const language = (_j = (_i = fullDescription.match(/(语\s+言)\s+(.+)/)) == null ? void 0 : _i[2]) != null ? _j : "";
    if (area) {
      const areaString = area.replace(/,/g, "/").replace(/\s|中国/g, "");
      if (category === "movie") {
        jQuery("#district").val(areaString);
      } else if (category.match(/tv/)) {
        const areaToSelectorMap = {
          \u5927\u9646: "#specificcat1",
          "\u53F0|\u6E2F": "#specificcat2",
          \u7F8E\u56FD: "#specificcat3",
          \u65E5\u672C: "#specificcat4",
          \u97E9\u56FD: "#specificcat5",
          \u82F1\u56FD: "#specificcat6",
          \u6CF0\u5267: "#specificcat7"
        };
        let selector = "";
        for (const [key, value] of Object.entries(areaToSelectorMap)) {
          if (area.match(new RegExp(key))) {
            selector = value;
            break;
          }
        }
        if (selector) {
          jQuery(selector).attr("checked", "true");
          getcheckboxvalue("specificcat");
        } else {
          jQuery("#specificcat").val(areaString);
        }
      } else if (category.match(/variety/)) {
        const districtMap = {
          CN: "#district1",
          HK: "#district2",
          TW: "#district2",
          JP: "#district4",
          KR: "#district4",
          US: "#district3",
          EU: "#district3",
          OT: "#district5"
        };
        jQuery(districtMap[info.area]).attr("checked", "true");
        getcheckboxvalue("district");
      }
    }
    if (jQuery("#language")) {
      let selector = "";
      if (language) {
        if (language.match(/汉语/)) {
          selector = "#language1";
        } else if (language.match(/粤/)) {
          selector = "#language2";
        } else if (language.match(/英语/)) {
          selector = "#language3";
        } else if (language.match(/日语/)) {
          selector = "#language4";
        } else if (language.match(/韩语/)) {
          selector = "#language5";
        }
        jQuery(selector).attr("checked", "true");
        getcheckboxvalue("language");
      }
    }
    let chineseName = originalName;
    if (!originalName.match(/[\u4e00-\u9fa5]+/)) {
      chineseName = translateName.match(/[\u4e00-\u9fa5]+/) ? translateName : "";
    }
    jQuery("#cname").val(chineseName);
    if (tags.chinese_subtitle && !tags.chinese_audio) {
      jQuery('input[name="chinese"]').attr("checked", "true");
    }
  }

  // src/target/hdr.ts
  init_preact_shim();
  var hdr_default = (info) => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l;
    const { description, doubanInfo } = info;
    const fullDescription = description + doubanInfo;
    const imdbRank = (_b2 = (_a3 = fullDescription.match(/IMDb评分\s+(\d(\.\d)?)/i)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    jQuery("#upload-imdb").val(imdbRank);
    const originalName = (_d = (_c = fullDescription.match(/(片\s+名)\s+(.+)?/)) == null ? void 0 : _c[2]) != null ? _d : "";
    const translateName = (_h = (_g = (_f = (_e = fullDescription.match(/(译\s+名)\s+(.+)/)) == null ? void 0 : _e[2]) == null ? void 0 : _f.split("/")) == null ? void 0 : _g[0]) != null ? _h : "";
    const summary = (_l = (_k = (_j = (_i = fullDescription.match(/(简\s+介)\s+([^[◎]+)/)) == null ? void 0 : _i[2]) == null ? void 0 : _j.split("/")) == null ? void 0 : _k[0]) != null ? _l : "";
    let chineseName = originalName;
    if (!originalName.match(/[\u4e00-\u9fa5]+/)) {
      chineseName = translateName.match(/[\u4e00-\u9fa5]+/) ? translateName : originalName;
    }
    jQuery("#title_chs").val(chineseName);
    jQuery("#upload_introduction").val(summary);
  };

  // src/target/bib.ts
  init_preact_shim();
  var bib_default = (info) => {
    var _a3;
    if (!info.doubanBookInfo) {
      return;
    }
    const { year, pager, translator, author, publisher, ISBN, book_intro: intro, poster } = info.doubanBookInfo;
    jQuery("#AuthorsField").val(author.join(","));
    jQuery("#PublishersField").val(publisher);
    jQuery("#IsbnField").val(ISBN);
    jQuery("#YearField").val(year);
    jQuery("#PagesField").val(pager);
    jQuery("#LanguageField").val("17");
    jQuery("#inputFileID").replaceWith('<textarea name="DescriptionField" id="DescriptionField" rows="15" cols="90"></textarea>');
    jQuery("#TranslatorsField").val(translator.join(","));
    jQuery("#DescriptionField").val(intro);
    jQuery("#ImageField").val(poster);
    const event = new Event("change");
    (_a3 = document.getElementById("DescriptionField")) == null ? void 0 : _a3.dispatchEvent(event);
  };

  // src/target/ptn.ts
  init_preact_shim();
  var ptn_default = (info) => {
    const { resolution, videoType, source } = info;
    let format = "";
    const formatMap2 = {
      remux: "Remux",
      web: "WebRip",
      dvd: "DVDR",
      dvdrip: "DVDRip",
      "720p": "720P",
      "1080p": "1080P",
      "2160p": "2160P"
    };
    if (videoType.match(/bluray/)) {
      format = "BluRay";
    } else if (videoType === "encode" && source === "bluray") {
      format = formatMap2[resolution];
    } else {
      format = formatMap2[videoType] || "";
    }
    jQuery("#format").val(format);
  };

  // src/target/site-operations.ts
  var SITE_OPERATIONS = {
    PTSBAO: {
      beforeHandler: () => {
        if (localStorage.getItem("autosave")) {
          localStorage.removeItem("autosave");
        }
      },
      afterHandler: (info) => {
        jQuery('a[data-sceditor-command="source"]')[0].click();
        jQuery(CURRENT_SITE_INFO.description.selector).val(info.description);
      }
    },
    Concertos: {
      handleDescription: (info) => {
        let { description, mediaInfos } = info;
        jQuery("#add").trigger("click");
        jQuery(".sceditor-button.sceditor-button-source.has-icon")[0].click();
        mediaInfos.forEach((mediaInfo) => {
          description = description.replace(mediaInfo.trim(), "");
        });
        return description;
      }
    },
    PTer: {
      handleDescription: (info) => {
        var _a3, _b2;
        let description = info.description;
        const { mediaInfo, bdinfo } = getBDInfoOrMediaInfo(description);
        mediaInfo.forEach((info2) => {
          description = description.replace(`[quote]${info2}[/quote]`, `[hide=mediainfo]${info2}[/hide]`);
        });
        bdinfo.forEach((info2) => {
          description = description.replace(`[quote]${info2}[/quote]`, `[hide=BDInfo]${info2}[/hide]`);
        });
        if ((_a3 = info.comparisons) == null ? void 0 : _a3.length) {
          for (const comparison of info.comparisons) {
            const { title, imgs } = comparison;
            const titleCount = (_b2 = title == null ? void 0 : title.split(",").length) != null ? _b2 : "";
            imgs.forEach((img) => {
              description = description.replace(`[img]${img}[/img]`, `[img${titleCount}]${img}[/img]`);
            });
          }
        }
        return description;
      },
      titleHandler: (info) => {
        const isWebSource = !!info.source.match(/web/gi);
        const title = fixTorrentTitle(info.title, isWebSource);
        info.title = title;
        return info;
      },
      afterHandler: (info) => {
        var _a3, _b2;
        const language = (_b2 = (_a3 = info.description.match(/(语\s+言)\s+(.+)/)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
        if (!language.match(/英语/) && info.area === "EU") {
          jQuery(CURRENT_SITE_INFO.area.selector).val("8");
        }
      }
    },
    Blutopia: {
      titleHandler: (info) => {
        const isWebSource = !!info.source.match(/web/gi);
        const title = fixTorrentTitle(info.title, isWebSource);
        info.title = title;
        return info;
      }
    },
    fearnopeer: {
      titleHandler: (info) => {
        const isWebSource = !!info.source.match(/web/gi);
        const title = fixTorrentTitle(info.title, isWebSource);
        info.title = title;
        return info;
      }
    },
    Aither: {
      titleHandler: (info) => {
        const isWebSource = !!info.source.match(/web/gi);
        const title = fixTorrentTitle(info.title, isWebSource);
        info.title = title;
        return info;
      }
    },
    KEEPFRDS: {
      handleDescription: (info) => {
        var _a3, _b2, _c;
        let { description, screenshots } = info;
        description = description.replace(/\[\/?(center|code)\]/g, "");
        if (info.sourceSite === "PTP") {
          description = (_b2 = (_a3 = info == null ? void 0 : info.originalDescription) == null ? void 0 : _a3.replace(/^(\s+)/g, "")) != null ? _b2 : "";
          description = filterEmptyTags(description);
          description = description.replace(/http:\/\/ptpimg/g, "https://ptpimg");
          screenshots.forEach((screenshot) => {
            const regStr = new RegExp(`\\[img${screenshot}\\[\\/img\\]`, "i");
            if (!description.match(regStr)) {
              const regOldFormat = new RegExp(`\\[img=${screenshot}\\]`, "i");
              if (description.match(regOldFormat)) {
                description = description.replace(regOldFormat, `[img]${screenshot}[/img]`);
              } else {
                description = description.replace(new RegExp(`(?<!\\[img\\])${screenshot}`, "gi"), `[img]${screenshot}[/img]`);
              }
            }
          });
        } else if (info.sourceSite === "RED") {
          description = description.replace(/\[#\]/g, "[*]");
        }
        jQuery("#torrent").on("change", () => {
          if (info.category !== "music") {
            jQuery(CURRENT_SITE_INFO.name.selector).val(info.title);
            if (info.subtitle) jQuery(CURRENT_SITE_INFO.subtitle.selector).val(info.subtitle);
          } else {
            jQuery(CURRENT_SITE_INFO.name.selector).val(info.subtitle || "");
            if (info.subtitle) jQuery(CURRENT_SITE_INFO.subtitle.selector).val(info.title);
          }
        });
        (_c = info.mediaInfos) == null ? void 0 : _c.forEach((mediaInfo) => {
          if (!/\[mediainfo\]/.test(description)) {
            description = description.replace(`[quote]${mediaInfo}[/quote]`, `[mediainfo]${mediaInfo}[/mediainfo]`);
          }
        });
        return description;
      },
      titleHandler: (info) => {
        if (info.category === "music") {
          const subtitle = info.title;
          if (info.subtitle !== void 0) info.title = info.subtitle;
          info.subtitle = subtitle;
        } else if (info.subtitle === "") {
          info.subtitle = info.title;
        }
        return info;
      }
    },
    SpeedApp: {
      handleDescription: (info) => {
        let { description } = info;
        description = description.replace(/\[url.*\[\/url\]/g, "").replace(/\[img.*\[\/img\]/g, "").replace(/\[\/?(i|b|center|quote|size|color)\]/g, "").replace(/\[(size|color)=#?[a-zA-Z0-9]*\]/g, "").replace(/\n\n*/g, "\n");
        return description;
      },
      afterHandler: (info) => {
        if (info.imdbId) {
          jQuery(CURRENT_SITE_INFO.imdb.selector).val(`https://www.imdb.com/title/${info.imdbId}/`);
        }
      }
    },
    PTN: {
      handleDescription: (info) => {
        let { description, imdbUrl } = info;
        description = `${imdbUrl}

${description}`;
        return description;
      },
      afterHandler: (info) => {
        ptn_default(info);
      }
    },
    HDT: {
      handleDescription: (info) => {
        let { description } = info;
        description = description.replace(/(\[\/img\])(\[img\])/g, "$1 $2").replace(/(\[\/url\])(\[url)/g, "$1 $2");
        return description;
      },
      afterHandler: (info) => {
        if (info.category !== "tvPack") {
          jQuery('select[name="season"').val("true");
        }
        if (info.imdbId) {
          jQuery(CURRENT_SITE_INFO.imdb.selector).val(`https://www.imdb.com/title/${info.imdbId}/`);
        }
      }
    },
    HDRoute: {
      afterHandler: (info) => {
        hdr_default(info);
      }
    },
    HDBits: {
      titleHandler: (info) => {
        let mediaTitle = info.title.replace(/([^\d]+)\s+([12][90]\d{2})/, (match, p1, p22) => {
          return `${info.movieName || info.movieAkaName} ${p22}`;
        });
        if (info.videoType === "remux") {
          mediaTitle = mediaTitle.replace(/\s+(bluray|blu-ray)/ig, "");
        }
        info.title = mediaTitle;
        return info;
      }
    },
    SSD: {
      afterHandler: (info) => {
        if (info.category === "tvPack" || info.title.match(/Trilogy|Collection/i) || info.subtitle && info.subtitle.match(/合集/)) {
          jQuery('input[name="pack"]').attr("checked", "true");
        }
        jQuery(CURRENT_SITE_INFO.imdb.selector).val(info.doubanUrl || info.imdbUrl);
        jQuery(CURRENT_SITE_INFO.screenshots.selector).val(info.screenshots.join("\n"));
      }
    },
    HDU: {
      afterHandler: (info) => {
        let videoTypeValue = "";
        const { resolution, videoType, category } = info;
        const isTV = category.match(/tv/);
        if (videoType === "remux") {
          if (resolution === "2160p") {
            videoTypeValue = isTV ? "16" : "15";
          } else {
            videoTypeValue = isTV ? "12" : "3";
          }
        }
        if (isTV) {
          if (videoType === "encode") {
            videoTypeValue = "14";
          } else if (videoType === "web") {
            videoTypeValue = "13";
          }
        }
        if (videoTypeValue) {
          jQuery(CURRENT_SITE_INFO.videoType.selector).val(videoTypeValue);
        }
      }
    },
    TJUPT: {
      handleDescription: (info) => {
        let { description } = info;
        const { mediaInfo, bdinfo } = getBDInfoOrMediaInfo(description);
        [...mediaInfo, ...bdinfo].forEach((info2) => {
          description = description.replace(`[quote]${info2}[/quote]`, `[mediainfo]${info2}[/mediainfo]`);
        });
        return description;
      },
      afterHandler: (info) => {
        jQuery("#browsecat").trigger("change");
        tjupt_default(info);
      }
    },
    NYPT: {
      afterHandler: (info) => {
        jQuery("#browsecat").trigger("change");
        const domTimeout = setTimeout(() => {
          const catMap = {
            movie: "#movie_enname",
            tv: "#series_enname",
            tvPack: "#series_enname",
            documentary: "#doc_enname",
            variety: "#show_enname",
            cartoon: "#anime_enname"
          };
          const selector = catMap[info.category];
          if (selector) {
            jQuery(selector).val(info.title);
          }
          clearTimeout(domTimeout);
        }, 2e3);
      }
    },
    iTS: {
      afterHandler: (info) => {
        its_default(info);
      }
    },
    UHDBits: {
      afterHandler: (info) => {
        jQuery(CURRENT_SITE_INFO.imdb.selector).val(info.imdbId || "");
        if (info.title.match(/web-?rip/i)) {
          jQuery(CURRENT_SITE_INFO.videoType.selector).val("WEBRip");
        }
        const teamName = getTeamName(info);
        jQuery("#team").val(teamName === "other" ? "Unknown" : teamName);
        jQuery("#imdb_button").trigger("click");
      }
    },
    "52pt": {
      afterHandler: (info) => {
        const { tags, videoType, resolution } = info;
        let videoTypeValue = videoType;
        if (videoType.match(/bluray/)) {
          if (tags.chinese_audio || tags.cantonese_audio || tags.chinese_subtitle) {
            videoTypeValue = videoType === "bluray" ? "14" : "15";
          }
        } else if (videoType === "remux" && resolution === "2160p") {
          videoTypeValue = "5";
        }
        jQuery(CURRENT_SITE_INFO.videoType.selector).val(videoTypeValue);
      }
    },
    BTSCHOOL: {
      afterHandler: (info) => {
        var _a3, _b2;
        jQuery(CURRENT_SITE_INFO.imdb.selector).val(info.imdbId || "");
        if (info.doubanUrl) {
          const doubanId = (_b2 = (_a3 = info.doubanUrl.match(/\/(\d+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
          jQuery(CURRENT_SITE_INFO.douban.selector).val(doubanId);
        }
      }
    },
    HDTime: {
      afterHandler: (info) => {
        if (info.videoType.match(/bluray/i)) {
          jQuery(CURRENT_SITE_INFO.category.selector).val("424");
        }
      }
    },
    RedLeaves: {
      afterHandler: (info) => {
        try {
          jQuery(CURRENT_SITE_INFO.category.selector).trigger("change");
        } catch (err) {
        }
        jQuery("tr.mode_5").css("display", "");
      }
    },
    HDFans: {
      afterHandler: (info) => {
        const { videoType, resolution, tags } = info;
        if (videoType === "remux") {
          jQuery(CURRENT_SITE_INFO.videoType.selector).val(resolution === "2160p" ? "10" : "8");
        } else if (videoType === "encode") {
          const map = {
            "2160p": "9",
            "1080p": "5",
            "1080i": "5",
            "720p": "11"
          };
          jQuery(CURRENT_SITE_INFO.videoType.selector).val(map[resolution] || "16");
        }
        if (tags.diy) {
          jQuery(CURRENT_SITE_INFO.videoType.selector).val(resolution === "2160p" ? "2" : "4");
        }
      }
    },
    Bib: {
      afterHandler: (info) => {
        if (info.doubanBookInfo) {
          bib_default(info);
        }
      }
    },
    HaresClub: {
      afterHandler: (info) => {
        jQuery(".modesw").trigger("click");
        jQuery(CURRENT_SITE_INFO.screenshots.selector).val(info.screenshots.join("\n"));
        if (layui) {
          setTimeout(() => {
            layui.form.render("select");
            layui.form.render("checkbox");
          }, 1e3);
        }
      }
    },
    TTG: {
      afterHandler: (info) => {
        var _a3, _b2;
        if (info.doubanUrl) {
          const doubanId = (_b2 = (_a3 = info.doubanUrl.match(/\/(\d+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
          jQuery(CURRENT_SITE_INFO.douban.selector).val(doubanId);
        }
      }
    },
    MTV: {
      handleDescription: (info) => {
        var _a3;
        let { description } = info;
        (_a3 = info.mediaInfos) == null ? void 0 : _a3.forEach((mediaInfo) => {
          description = description.replace(`[quote]${mediaInfo}[/quote]`, `[mediainfo]${mediaInfo}[/mediainfo]`);
        });
        return description;
      },
      afterHandler: (info) => {
        var _a3, _b2, _c, _d, _e, _f, _g, _h;
        if (info.resolution !== "") {
          const resolution = info.resolution.replace("p", "");
          (_a3 = jQuery(`input[name="Resolution"][value="${resolution}"]`)[0]) == null ? void 0 : _a3.click();
          jQuery("#taginput").val(info.resolution);
        }
        if (info.videoCodec !== "") {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} ${info.videoCodec}`);
        }
        if (info.audioCodec === "dd+") {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} ddp.audio`);
        } else if ((_b2 = info.audioCodec) == null ? void 0 : _b2.match(/dd|ac3/i)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} dd.audio`);
        } else if ((_c = info.audioCodec) == null ? void 0 : _c.match(/dtshd/i)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} dts.hd.audio`);
        } else if ((_d = info.audioCodec) == null ? void 0 : _d.match(/dtsx/i)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} dts.x.audio`);
        } else {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} ${info.audioCodec}.audio`);
        }
        if (info.title.match(/(\s|.)hybrid(\s|.)/i)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} hybrid`);
        }
        if (/web-dl/i.test(info.title)) {
          const tagvalue = jQuery("#taginput").attr("value");
          (_e = jQuery('input[name="source"][value="9"]')[0]) == null ? void 0 : _e.click();
          if (/NF|Netflix/i.test(info.title)) {
            jQuery("#taginput").val(`${tagvalue} web.dl netflix.source`);
          } else jQuery("#taginput").val(`${tagvalue} web.dl`);
        } else if (/webrip/i.test(info.title)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} webrip`);
          (_f = jQuery('input[name="source"][value="10"]')[0]) == null ? void 0 : _f.click();
        } else if (info.videoType.match(/bluray/i)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} bluray`);
          (_g = jQuery('input[name="source"][value="7"]')[0]) == null ? void 0 : _g.click();
        } else if (info.videoType.match(/remux/i)) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} ${info.videoType}`);
          (_h = jQuery('input[name="source"][value="7"]')[0]) == null ? void 0 : _h.click();
        } else {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} ${info.videoType}`);
        }
        if (info.tags.cantonese_audio === true) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} cantonese.audio.track`);
        }
        if (info.tags.chinese_audio === true) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} chinese.audio.track`);
        }
        if (info.tags.chinese_subtitle === true) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} chinese.subs`);
        }
        if (info.tags.hdr === true) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} hdr`);
        }
        if (info.tags.dolby_vision === true) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} dovi`);
        }
        if (info.tags.hdr10_plus === true) {
          const tagvalue = jQuery("#taginput").attr("value");
          jQuery("#taginput").val(`${tagvalue} hdr10plus`);
        }
      }
    }
  };

  // src/target/helper.ts
  var ExportHelper = class {
    constructor(info) {
      this.info = info;
      this.currentSiteInfo = CURRENT_SITE_INFO;
      this.operation = SITE_OPERATIONS[CURRENT_SITE_NAME];
    }
    prepareToFillInfo() {
      var _a3;
      if ((_a3 = this.operation) == null ? void 0 : _a3.beforeHandler) {
        this.operation.beforeHandler();
      }
    }
    fillTeamName() {
      const teamConfig = this.currentSiteInfo.team;
      const teamName = getTeamName(this.info);
      if (teamName && teamConfig) {
        const formateTeamName = teamConfig.map[teamName.toLowerCase()];
        const matchValue = formateTeamName || teamConfig.map.other;
        if (HDB_TEAM.includes(teamName) && CURRENT_SITE_NAME === "BTSCHOOL") {
          jQuery(teamConfig.selector).val(teamConfig.map.hdbint);
          return;
        }
        if (CURRENT_SITE_NAME === "UHDBits") {
          jQuery("#team").val(teamName === "other" ? "Unknown" : teamName);
          return;
        }
        if (matchValue) {
          jQuery(teamConfig.selector).val(matchValue.toLowerCase());
        }
      }
    }
    disableTorrentChange() {
      var _a3, _b2;
      const nameSelector = (_b2 = (_a3 = this.currentSiteInfo.name) == null ? void 0 : _a3.selector) != null ? _b2 : "";
      if (nameSelector.match(/^#\w+/)) {
        const nameDom = jQuery(nameSelector).clone().attr("name", "").hide();
        jQuery(nameSelector).attr("id", "").after(nameDom);
      }
    }
    getThanksQuote() {
      const isChineseSite = isChineseTacker(this.currentSiteInfo.siteType) || CURRENT_SITE_NAME.match(/HDPOST|GPW/);
      let thanksQuote = `\u8F6C\u81EA[b]${this.info.sourceSite}[/b]\uFF0C\u611F\u8C22\u539F\u53D1\u5E03\u8005\uFF01`;
      if (!isChineseSite) {
        thanksQuote = `Torrent from [b]${this.info.sourceSite}[/b].
All thanks to the original uploader\uFF01`;
      }
      return `[quote]${thanksQuote}[/quote]

`;
    }
    getChineseName() {
      var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j;
      const { description, subtitle } = this.info;
      const originalName = (_b2 = (_a3 = description.match(/(片\s+名)\s+(.+)?/)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
      const translateName = (_f = (_e = (_d = (_c = description.match(/(译\s+名)\s+(.+)/)) == null ? void 0 : _c[2]) == null ? void 0 : _d.split("/")) == null ? void 0 : _e[0]) != null ? _f : "";
      let chineseName = originalName;
      if (!originalName.match(/[\u4e00-\u9fa5]+/)) {
        chineseName = translateName.match(/[\u4e00-\u9fa5]+/) ? translateName : "";
      }
      if (chineseName === "" && subtitle !== "" && subtitle !== void 0) {
        chineseName = (_j = (_i = (_h = (_g = this.info) == null ? void 0 : _g.subtitle) == null ? void 0 : _h.replace(/【|】.*/g, "").split("/")) == null ? void 0 : _i[0]) != null ? _j : "";
      }
      return chineseName.trim();
    }
    torrentTitleHandler() {
      var _a3;
      const fixedTitle = this.info.title.replace("H 265", "H.265").replace("H 264", "H.264");
      this.info.title = fixedTitle;
      if ((_a3 = this.operation) == null ? void 0 : _a3.titleHandler) {
        this.info = this.operation.titleHandler(this.info);
      }
      if (this.currentSiteInfo.name) {
        if (CURRENT_SITE_NAME.match(/SSD|iTS|HDChina|MTV/)) {
          this.info.title = this.info.title.replace(/\s/ig, ".");
        } else if (CURRENT_SITE_NAME.match(/PuTao/)) {
          this.info.title = `[${this.getChineseName()}]${this.info.title}`;
        }
        jQuery(this.currentSiteInfo.name.selector).val(this.info.title);
      }
      return this.info;
    }
    imdbHandler() {
      var _a3, _b2, _c;
      const imdbSelector = (_b2 = (_a3 = this.currentSiteInfo) == null ? void 0 : _a3.imdb) == null ? void 0 : _b2.selector;
      if (!imdbSelector) {
        return;
      }
      const imdbId = getIMDBIdByUrl(this.info.imdbUrl || "");
      this.info.imdbId = imdbId;
      if (CURRENT_SITE_NAME.match(/HDRoute|HDSpace/)) {
        jQuery(imdbSelector).val((_c = imdbId == null ? void 0 : imdbId.replace("tt", "")) != null ? _c : "");
      } else if (CURRENT_SITE_NAME.match(/Blutopia|fearnopeer|HDPOST|ACM|Aither|Concertos|MDU|LST/)) {
        let tmdbId = "";
        const fillIMDBId = this.currentSiteInfo.siteType === "UNIT3D" ? imdbId.replace("tt", "") : imdbId;
        jQuery(imdbSelector).val(fillIMDBId);
        getTMDBIdByIMDBId(imdbId).then((data) => {
          tmdbId = data.id;
          jQuery(this.currentSiteInfo.tmdb.selector).val(tmdbId);
        });
        if (CURRENT_SITE_NAME.match(/Blutopia|fearnopeer|Aither|MDU|LST/)) {
          jQuery("#torrent").on("change", () => {
            jQuery(imdbSelector).val(fillIMDBId);
            jQuery(this.currentSiteInfo.tmdb.selector).val(tmdbId);
            jQuery("#automal").val(0);
          });
        }
      } else {
        jQuery(imdbSelector).val(this.info.imdbUrl || "");
      }
    }
    fillBasicAttributes() {
      const commonInfoKeys = ["subtitle", "douban", "area", "audioCodec"];
      commonInfoKeys.forEach((key) => {
        const siteInfo = this.currentSiteInfo[key];
        if (siteInfo && siteInfo.selector) {
          let value = this.info[key];
          if (key === "douban") {
            value = this.info.doubanUrl;
          } else if (key === "area" || key === "audioCodec") {
            value = siteInfo.map[value];
          }
          jQuery(siteInfo.selector).val(value);
        }
      });
    }
    descriptionHandler() {
      var _a3, _b2, _c, _d;
      let { mediaInfos, isBluray, screenshots = [], description = "", doubanInfo, poster } = this.info;
      if (description) {
        if (this.currentSiteInfo.siteType.match(/NexusPHP|TTG|MTeam/)) {
          description = description.replace(/\[(right|left|center)\]/gi, "[quote]").replace(/\[\/(right|left|center)\]/gi, "[/quote]");
        }
        description = description.replace(/^(\s+)/g, "");
        if (isChineseTacker(this.currentSiteInfo.siteType) && CURRENT_SITE_NAME !== "SSD") {
          if (doubanInfo) {
            description = `${doubanInfo}
${description}`;
          }
        } else {
          const { sourceSiteType } = this.info;
          if (isChineseTacker(sourceSiteType) && CURRENT_SITE_NAME !== "Bib") {
            description = filterNexusDescription(this.info);
          }
        }
      }
      if (this.currentSiteInfo.mediaInfo) {
        if (CURRENT_SITE_NAME.match(/^(Blutopia|fearnopeer|Aither|MDU)/)) {
          const selector = isBluray ? 'textarea[name="bdinfo"]' : this.currentSiteInfo.mediaInfo.selector;
          jQuery(selector).val(mediaInfos[0]);
          description = description.replace(mediaInfos[0].trim(), "");
        } else if (isBluray && CURRENT_SITE_NAME.match(/^(SpeedApp)/)) {
          jQuery(this.currentSiteInfo.bdinfo.selector).val(mediaInfos[0]);
          this.info.mediaInfos = [];
        } else if (!(isBluray && CURRENT_SITE_NAME.match(/^(HDBits)/))) {
          jQuery(this.currentSiteInfo.mediaInfo.selector).val(mediaInfos[0]);
          description = description.replace(mediaInfos[0].trim(), "");
        }
      }
      if (this.currentSiteInfo.screenshots) {
        screenshots.forEach((img) => {
          if (description.includes(img)) {
            description = description.replace(img, "");
            if (!img.match(/\[url=.+?\[url]/)) {
              description = description.replace(/\[img\]\[\/img\]\n*/g, "");
            }
          }
        });
      }
      if (this.currentSiteInfo.poster) {
        if (!poster) {
          const doubanPosterImage = (description + doubanInfo).match(/\[img\](http[^[]+?(poster|(img\d\.doubanio))[^[]+?)\[\/img\]/);
          if (doubanPosterImage && doubanPosterImage[1]) {
            poster = doubanPosterImage[1];
          } else {
            poster = (_b2 = (_a3 = description.match(/\[img\](.+?)\[\/img\]/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
          }
        }
        if (poster) {
          jQuery(this.currentSiteInfo.poster).val(poster);
          if (CURRENT_SITE_NAME === "HDRoute") {
            jQuery('input[name="poster"]').val(poster);
            description = description.replace(poster, "");
          }
        }
      }
      if (CURRENT_SITE_NAME.match(/Blutopia|fearnopeer|Aither|MDU/)) {
        if (this.info.sourceSite === "PTP") {
          description = buildPTPDescription(this.info);
        }
        if (screenshots.length > 0) {
          screenshots.forEach((img) => {
            const regStr = new RegExp(`\\[img\\](${img})\\[\\/img\\](
*)?`);
            if (description.match(regStr)) {
              description = description.replace(regStr, (p1, p22) => {
                return `[url=${p22}][img=350x350]${p22}[/img][/url]`;
              });
            }
          });
        }
        if (description.match(/mobile\.webp\[\/img/gi)) {
          description = description.replace(/\[img\]/g, "[img=350x350]");
        }
      }
      if (CURRENT_SITE_NAME.match(/Blutopia|fearnopeer|Aither/)) {
        description = description.replace(/\[align(=(.+?))\]((.|\n)+?)\[\/align\]/g, "[$2]$3[/$2]");
        description = description.replace(/\[(\/)?hide(?:=(.+?))?\]/g, (match, p1, p22) => {
          const slash = p1 || "";
          return p22 ? `${p22}: [${slash}spoiler]` : `[${slash}spoiler]`;
        });
      }
      if ((_c = this.operation) == null ? void 0 : _c.handleDescription) {
        description = this.operation.handleDescription(__spreadProps(__spreadValues({}, this.info), {
          description
        }));
      }
      description = filterEmptyTags(description);
      const thanksQuoteClosed = GM_getValue("easy-seed.thanks-quote-closed") || "";
      if (!thanksQuoteClosed && this.info.sourceSite !== void 0) {
        description = this.getThanksQuote() + description.trim();
      }
      jQuery((_d = this.currentSiteInfo.description) == null ? void 0 : _d.selector).val(description);
      if (CURRENT_SITE_INFO.siteType === "UNIT3D" && CURRENT_SITE_INFO.description.selector === "#bbcode-description") {
        jQuery(CURRENT_SITE_INFO.description.selector)[0].dispatchEvent(new Event("input"));
      }
      this.info = __spreadProps(__spreadValues({}, this.info), {
        description
      });
    }
    categoryHandler() {
      const { isBluray, category, videoType } = this.info;
      if (CURRENT_SITE_NAME.match(/ACM|Concertos/i)) {
        this.info.category = videoType;
        this.info.videoType = category;
        if (isBluray) {
          let bdType = getBDType(this.info.size);
          if (videoType === "uhdbluray" && bdType === "BD50") {
            bdType = "uhd50";
          }
          this.info.category = bdType || "";
        }
      }
      if (this.currentSiteInfo.category) {
        const category2 = this.currentSiteInfo.category.map[this.info.category];
        const keyArray = ["videoCodec", "videoType", "resolution", "source", "area"];
        let finalSelectArray = [];
        if (Array.isArray(category2)) {
          finalSelectArray = [...category2];
          keyArray.forEach((key) => {
            finalSelectArray = matchSelectForm(this.currentSiteInfo, this.info, key, finalSelectArray);
            if (finalSelectArray.length === 1) {
              setSelectValue(this.currentSiteInfo.category.selector, finalSelectArray[0]);
            }
          });
        } else {
          [...keyArray, "category"].forEach((key) => {
            matchSelectForm(this.currentSiteInfo, this.info, key, finalSelectArray);
          });
        }
      }
    }
    fillRemainingInfo() {
      if (this.currentSiteInfo.format) {
        const formatData = this.currentSiteInfo.format;
        jQuery(formatData.selector).val(formatData.map[this.info.format]);
      }
      if (this.currentSiteInfo.image) {
        jQuery(this.currentSiteInfo.image.selector).val(this.info.image || "");
      }
      if (this.currentSiteInfo.anonymous) {
        const { selector, value = "" } = this.currentSiteInfo.anonymous;
        if (value) {
          jQuery(selector).val(value);
        } else {
          jQuery(selector).attr("checked", "true");
        }
      }
      if (this.currentSiteInfo.tags) {
        Object.keys(this.info.tags).forEach((key) => {
          if (this.info.tags[key] && this.currentSiteInfo.tags[key]) {
            jQuery(this.currentSiteInfo.tags[key]).attr("checked", "true");
          }
        });
      }
      this.fillTeamName();
      if (CURRENT_SITE_NAME.match(/HDHome|PTHome|SoulVoice|1PTBA|HDAtmos|3Wmg/i)) {
        setTimeout(() => {
          var _a3;
          const event = new Event("change");
          (_a3 = document.querySelector(this.currentSiteInfo.category.selector)) == null ? void 0 : _a3.dispatchEvent(event);
        }, 1e3);
      }
    }
    dealWithMoreSites() {
      var _a3, _b2, _c, _d, _e;
      if ((_a3 = this.operation) == null ? void 0 : _a3.afterHandler) {
        this.operation.afterHandler(this.info);
      }
      if (CURRENT_SITE_NAME.match(/PTHome|1PTBA|52pt|Audiences/i)) {
        if (this.info.tags.diy) {
          let categoryValue = "";
          if (CURRENT_SITE_NAME.match(/Audiences|PTHome/)) {
            categoryValue = this.info.videoType === "bluray" ? "14" : "13";
          } else if (CURRENT_SITE_NAME === "1PTBA") {
            categoryValue = this.info.videoType === "bluray" ? "1" : "4";
          } else if (CURRENT_SITE_NAME === "52pt") {
            categoryValue = this.info.videoType === "bluray" ? "2" : "12";
          }
          jQuery(this.currentSiteInfo.videoType.selector).val(categoryValue);
        }
      }
      if (this.currentSiteInfo.siteType === "UNIT3D" && this.info.category.match(/tv/)) {
        const season = (_c = (_b2 = this.info.title.match(/S0?(\d{1,2})/i)) == null ? void 0 : _b2[1]) != null ? _c : 1;
        const episode = (_e = (_d = this.info.title.match(/EP?0?(\d{1,3})/i)) == null ? void 0 : _d[1]) != null ? _e : 0;
        jQuery("#season_number").val(season);
        jQuery("#episode_number").val(episode);
      }
      if (CURRENT_SITE_NAME.match(/HDHome/)) {
        if (this.info.title.match(/iPad/i)) {
          const categoryMap = {
            movie: "412",
            tv: "426",
            tvPack: "433",
            documentary: "418"
          };
          const ipadCat = categoryMap[this.info.category];
          if (ipadCat) {
            jQuery("#browsecat").val(ipadCat);
          }
        }
      }
    }
    fillTorrentFile() {
      var _a3;
      const { torrentData } = this.info;
      if (CURRENT_SITE_INFO.torrent) {
        const fileInput = jQuery(CURRENT_SITE_INFO.torrent.selector);
        if (torrentData && fileInput.length > 0) {
          const blob = base64ToBlob(torrentData);
          const torrentFileName = (_a3 = this.info.title) == null ? void 0 : _a3.replace(/\s/g, ".");
          const file = new File([blob], `${torrentFileName}.torrent`, { type: "application/x-bittorrent" });
          const dataTransfer = new DataTransfer();
          dataTransfer.items.add(file);
          const uploadInput = fileInput[0];
          if (CURRENT_SITE_NAME === "MTeam") {
            setTimeout(() => {
              const lastValue = uploadInput.files;
              uploadInput.files = dataTransfer.files;
              const tracker = uploadInput._valueTracker;
              if (tracker) {
                tracker.setValue(lastValue);
              }
              const event = new Event("change", { bubbles: true });
              uploadInput.dispatchEvent(event);
            }, 100);
          } else {
            uploadInput.files = dataTransfer.files;
          }
        }
      }
    }
  };

  // src/target/ptp.ts
  init_preact_shim();
  var ptp_default = async (info) => {
    const currentSiteInfo5 = PT_SITE.PTP;
    const {
      title,
      imdbUrl,
      tags,
      size,
      videoCodec = "",
      videoType,
      resolution
    } = info;
    const groupId = getUrlParam("groupid");
    if (!groupId) {
      jQuery(currentSiteInfo5.imdb.selector).val(imdbUrl || 0);
      AutoFill();
    }
    info.resolution = getResolution2(resolution, videoType, title);
    info.videoCodec = getVideoCodec(videoCodec, videoType, size);
    const keyArray = ["category", "source", "videoCodec", "resolution"];
    keyArray.forEach((key) => {
      const { selector = "", map } = currentSiteInfo5[key];
      if (map) {
        const mapValue = map[info[key]];
        jQuery(selector).val(mapValue);
      } else {
        jQuery(selector).val(info[key]);
      }
    });
    if (info.sourceSite.match(/PTP/i)) {
      jQuery(currentSiteInfo5.description.selector).val(info.originalDescription || "");
    } else {
      const description = getDescription(info);
      jQuery(currentSiteInfo5.description.selector).val(description);
    }
    const editionInfo = getEditionInfo(videoType, tags);
    if (editionInfo.length > 0) {
      jQuery("#remaster").attr("checked", "true");
      Remaster();
      editionInfo.forEach((edition) => {
        const event = new Event("click");
        jQuery("#remaster_tags a").filter(function() {
          return new RegExp(edition).test(jQuery(this).text());
        })[0].dispatchEvent(event);
      });
    }
    const infoFromMediaInfoinfo = getInfoFromMediaInfo(info.mediaInfos[0]);
    if (infoFromMediaInfoinfo.subtitles && infoFromMediaInfoinfo.subtitles[0]) {
      infoFromMediaInfoinfo.subtitles.forEach((subtitle) => {
        const subtitleSelector = jQuery(".languageselector li").filter(function() {
          return new RegExp(subtitle).test(jQuery(this).text());
        });
        if (subtitle !== "English" && subtitleSelector[0]) {
          subtitleSelector.find("input").attr("checked", "true");
        }
      });
    }
  };
  var getEditionInfo = (videoType, tags) => {
    const editionInfo = [];
    if (videoType === "remux") {
      editionInfo.push("Remux");
    }
    if (tags.hdr) {
      editionInfo.push("HDR10");
    }
    if (tags.hdr10_plus) {
      editionInfo.push("HDR10+");
    }
    if (tags.dolby_vision) {
      editionInfo.push("Dolby Vision");
    }
    if (tags.dolby_atmos) {
      editionInfo.push("Dolby Atmos");
    }
    if (tags.dts_x) {
      editionInfo.push("DTS:X");
    }
    return editionInfo;
  };
  var getVideoCodec = (videoCodec, videoType, size) => {
    if (videoType === "bluray") {
      return getBDType(size);
    } else if (videoType === "dvd") {
      const GBSize = size / 1e9;
      if (GBSize < 5) {
        return "DVD5";
      }
      return "DVD9";
    }
    return videoCodec;
  };
  var getResolution2 = (resolution, videoType, title) => {
    if (videoType === "DVD" && title.match(/NTSC/i)) {
      return "NTSC";
    } else if (videoType === "DVD" && title.match(/PAL/i)) {
      return "PAL";
    }
    return resolution;
  };
  var getDescription = (info) => {
    const { mediaInfos, comparisons, screenshots } = info;
    let filterDescription = "";
    if (mediaInfos.length > 0) {
      mediaInfos.forEach((mediaInfo) => {
        filterDescription += `[mediainfo]${mediaInfo}[/mediainfo]
`;
      });
    }
    if (comparisons && comparisons.length > 0) {
      for (const comparison of comparisons) {
        filterDescription += `
${comparison.reason}[comparison=${comparison.title}]
${comparison.imgs.join("\n")}
[/comparison]

`;
      }
    }
    return `${filterDescription}
${screenshots.map((item) => `[img]${item}[/img]`).join("\n")}`;
  };

  // src/target/gpw.ts
  init_preact_shim();
  var currentSiteInfo = PT_SITE.GPW;
  var gpw_default = async (info) => {
    const isUploadSuccess = !jQuery("#mediainfo")[0];
    if (isUploadSuccess) {
      return;
    }
    transformInfo(info);
    const isAddFormat = getUrlParam("groupid");
    if (!isAddFormat) {
      jQuery(currentSiteInfo.imdb.selector).val(info.imdbUrl || 0);
      jQuery("#imdb_button").trigger("click");
      jQuery("#upload .collapse").show();
    }
    jQuery(currentSiteInfo.category.selector).val(currentSiteInfo.category.map[info.category]);
    fillEditionInfo(info);
    fillMediaInfo(info);
    setTimeout(() => {
      if (!jQuery(currentSiteInfo.source.selector).val() || !jQuery(currentSiteInfo.format.selector).val()) {
        handleNoAutoCheck(info);
      }
    }, 0);
    fillScene(info);
    fillProcessing(info);
    fillDescription(info);
    jQuery(".u-bbcodePreview-button").trigger("click");
  };
  function buildDescription(info) {
    let description = "";
    if (info.comparisons && info.comparisons.length > 0) {
      for (const comparison of info.comparisons) {
        description += `${comparison.reason}[comparison=${comparison.title}]
${comparison.imgs.join("\n")}
[/comparison]

`;
      }
    }
    if (info.screenshots.length > 0) {
      description += `${info.screenshots.map((v3) => `[img]${v3}[/img]`).join("\n")}

`;
    }
    return description.trim();
  }
  function fillEditionInfo(info) {
    const editionTags = Object.keys(info.tags).map((tag) => info.tags[tag] && currentSiteInfo.targetInfo.editionTags[tag]).filter(Boolean);
    let otherTag;
    if (Object.keys(info.otherTags).length > 0) {
      otherTag = Object.keys(info.otherTags).join(", ");
    }
    if (editionTags.length > 0 || otherTag) {
      jQuery("#movie_edition_information").trigger("click");
    }
    if (editionTags.length > 0) {
      for (const tag of editionTags) {
        jQuery(`#movie_remaster_tags a[onclick*="'${tag}'"]`).trigger("click");
      }
    }
    if (otherTag) {
      jQuery("#other-button").trigger("click");
      jQuery("[name=remaster_custom_title]").val(otherTag);
    }
  }
  function fillMediaInfo(info) {
    if (!info.mediaInfos) {
      return;
    }
    for (let i3 = 1; i3 < info.mediaInfos.length; i3++) {
      jQuery("#add-mediainfo")[0].click();
    }
    const textareas = Array.from(jQuery('[name="mediainfo[]"]'));
    for (const [index, textarea] of textareas.entries()) {
      textarea.value = info.mediaInfos[index];
      textarea.dispatchEvent(new Event("input"));
    }
    jQuery('[name="mediainfo[]"]')[0].dispatchEvent(new Event("change"));
  }
  function fillScene(info) {
    if (info.tags.scene) {
      jQuery("#scene").prop("checked", true);
    }
  }
  function fillProcessing(info) {
    let { videoType, size, source, tags } = info;
    if (source.match(/bluray|hddvd|dvd/)) {
      if (tags.diy) {
        videoType = "DIY";
      }
      const videoTypeConfig = currentSiteInfo.videoType;
      const { selector, map } = videoTypeConfig;
      jQuery(selector).val(map[videoType]);
      jQuery(selector)[0].dispatchEvent(new Event("change"));
      if (map[videoType] === "Untouched") {
        const bdType = getBDType(size);
        jQuery('select[name="processing_other"]').val(bdType || "");
      }
      jQuery(selector)[0].dispatchEvent(new Event("input"));
    }
  }
  function handleNoAutoCheck(info) {
    var _a3;
    const {
      mediaInfos,
      videoType
    } = info;
    const mediaInfo = (mediaInfos == null ? void 0 : mediaInfos[0]) || "";
    const isBluray = videoType.match(/bluray/i);
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { format = "", subtitles = [] } = getInfoFunc(mediaInfo);
    info.format = getFormat(format, videoType);
    const keyArray = ["source", "videoCodec", "format", "resolution"];
    keyArray.forEach((key) => {
      var _a4, _b2;
      const { selector = "", map } = currentSiteInfo[key];
      if (map) {
        const mapValue = map[info[key]];
        jQuery(selector).val(mapValue);
        if (key === "videoCodec" && mapValue === "Other") {
          document.querySelector(selector).dispatchEvent(new Event("change"));
          jQuery('input[name="codec_other"]').val((_b2 = (_a4 = info[key]) == null ? void 0 : _a4.toUpperCase()) != null ? _b2 : "");
        }
      } else {
        jQuery(selector).val(info[key] || "");
      }
    });
    if (subtitles.length > 0) {
      jQuery("#mixed_subtitles").attr("checked", "true");
      jQuery('input[name="subtitles[]"][type="checkbox"]').each(function() {
        var _a4, _b2;
        const language = (_b2 = (_a4 = jQuery(this).attr("id")) == null ? void 0 : _a4.replace(/^\S|(_\S)/g, (letter) => letter.replace("_", " ").toUpperCase())) != null ? _b2 : "";
        if (subtitles.includes(language)) {
          jQuery(this).attr("checked", "true");
        }
      });
      const event = new Event("change");
      (_a3 = document.querySelector("#mixed_subtitles")) == null ? void 0 : _a3.dispatchEvent(event);
      const chineseLanguages = subtitles.filter((item) => item.match(/Chinese|Traditional|Simplified/i));
      if (chineseLanguages.length === 1 && chineseLanguages[0] === "Chinese") {
        const selector = chineseLanguages[0].match(/Traditional/i) ? "#chinese_traditional" : "#chinese_simplified";
        jQuery(selector).attr("checked", "true");
      } else if (chineseLanguages.length >= 2) {
        jQuery("#chinese_traditional,#chinese_simplified").attr("checked", "true");
      }
    }
  }
  var getFormat = (format, videoType) => {
    if (videoType.match(/bluray/) && format !== "iso") {
      format = "m2ts";
    } else if (videoType.match(/dvd/)) {
      format = "vob";
    }
    return format || "mkv";
  };
  function transformInfo(info) {
    if (["encode", "remux"].includes(info.videoType) && info.mediaInfos) {
      const newMediaInfos = [];
      for (const mediaInfo of info.mediaInfos) {
        if (mediaInfo.match(/Disc Title|Disc Label/i)) {
          continue;
        }
        newMediaInfos.push(mediaInfo);
      }
      info.mediaInfos = newMediaInfos;
    }
  }
  function fillDescription(info) {
    let description = "";
    if (info.sourceSite === "PTP") {
      description = buildPTPDescription(info);
    } else if (info.sourceSite === "BeyondHD") {
      description = info.originalDescription || "";
    } else {
      description = buildDescription(info);
    }
    jQuery(currentSiteInfo.description.selector).val(description);
    jQuery(currentSiteInfo.description.selector)[0].dispatchEvent(new Event("input"));
  }

  // src/target/npubits.ts
  init_preact_shim();
  var npubits_default = (info) => {
    var _a3, _b2;
    const currentSiteInfo5 = PT_SITE.NPUBits;
    let { title, year, movieName, category, doubanInfo, description, subtitle } = info;
    jQuery(currentSiteInfo5.subtitle.selector).val(subtitle || "");
    if (doubanInfo) {
      description = `${doubanInfo}
${description}`;
    }
    jQuery(currentSiteInfo5.description.selector).val(description);
    jQuery("#torrent_name_checkbox").attr("checked", "true");
    jQuery(currentSiteInfo5.name.selector).val(title);
    jQuery(currentSiteInfo5.category.selector).val(
      currentSiteInfo5.category.map[category]
    );
    jQuery(currentSiteInfo5.category.selector)[0].dispatchEvent(new Event("change"));
    if (category.match(/tv/)) {
      const districtMap = {
        CN: "23",
        HK: "24",
        TW: "24",
        JP: "26",
        KR: "27",
        US: "25",
        EU: "65",
        OT: "63"
      };
      jQuery(currentSiteInfo5.area.selector).val(districtMap[info.area]);
    } else if (category.match(/movie/)) {
      jQuery(currentSiteInfo5.area.selector).val(currentSiteInfo5.area.map[info.area]);
    }
    jQuery(currentSiteInfo5.area.selector)[0].dispatchEvent(new Event("change"));
    const keyArray = ["videoCodec", "videoType", "resolution"];
    keyArray.forEach((key) => {
      const { selector, map } = currentSiteInfo5[key];
      fill_field(
        selector,
        map[info[key]]
      );
    });
    const teamName = getTeamName(info);
    const teamConfig = currentSiteInfo5.team;
    jQuery(`${teamConfig.selector}`).val(teamConfig.map[teamName]);
    jQuery("#torrent_name_field0").val(movieName);
    if (category === "movie") {
      jQuery("#torrent_name_field1").val(year);
    } else if (category.match(/tv/)) {
      const episode = (_b2 = (_a3 = title.match(/S\d+(E\d+)?/i)) == null ? void 0 : _a3[0]) != null ? _b2 : "";
      jQuery("#torrent_name_field1").val(episode);
    }
    jQuery('input[name="uplver"]').attr("checked", "true");
  };

  // src/target/byr.ts
  init_preact_shim();
  var byr_default = (info) => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n;
    const currentSiteInfo5 = PT_SITE.BYR;
    const {
      title,
      description,
      doubanInfo,
      category,
      videoType,
      mediaInfo,
      subtitle,
      imdbUrl,
      doubanUrl
    } = info;
    jQuery(currentSiteInfo5.subtitle.selector).val(subtitle || "");
    jQuery(currentSiteInfo5.imdb.selector).val(imdbUrl || "");
    jQuery(currentSiteInfo5.douban.selector).val(doubanUrl || "");
    CKEDITOR.on("instanceReady", () => {
      CKEDITOR.instances.descr.setData(bbcode2Html(description));
    });
    jQuery("#ename0day").val(title);
    const fullDescription = description + doubanInfo;
    let area = (_b2 = (_a3 = fullDescription.match(/(产\s+地|国\s+家)\s+(.+)/)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
    area = area.replace(/\[\/?.+?\]/g, "");
    const originalName = (_d = (_c = fullDescription.match(/(片\s+名)\s+(.+)?/)) == null ? void 0 : _c[2]) != null ? _d : "";
    const translateName = (_h = (_g = (_f = (_e = fullDescription.match(/(译\s+名)\s+(.+)/)) == null ? void 0 : _e[2]) == null ? void 0 : _f.split("/")) == null ? void 0 : _g[0]) != null ? _h : "";
    const movieType = (_j = (_i = fullDescription.match(/(类\s+别)\s+(.+)/)) == null ? void 0 : _i[2]) != null ? _j : "";
    const language = (_l = (_k = fullDescription.match(/(语\s+言)\s+(.+)/)) == null ? void 0 : _k[2]) != null ? _l : "";
    let chineseName = originalName;
    if (!originalName.match(/[\u4e00-\u9fa5]+/)) {
      chineseName = translateName.match(/[\u4e00-\u9fa5]+/) ? translateName : "";
    }
    if (category.match(/movie/)) {
      let selector = "";
      if (area.match(/华语|台|港/)) {
        selector = "\u534E\u8BED";
      } else if (area.match(/日本|韩国|泰国/)) {
        selector = "\u4E9A\u6D32";
      } else if (area.match(/美国|加拿大/)) {
        selector = "\u5317\u7F8E";
      } else if (area.match(/欧|英|法|德|俄|意|苏联|EU/)) {
        selector = "\u6B27\u6D32";
      } else {
        selector = "\u5176\u4ED6";
      }
      const typeMap = {
        \u534E\u8BED: "11",
        \u6B27\u6D32: "12",
        \u5317\u7F8E: "13",
        \u4E9A\u6D32: "14",
        \u5176\u4ED6: "1"
      };
      jQuery('select[name="second_type"]').val(typeMap[selector]);
      jQuery('select[name="second_type"]')[0].dispatchEvent(new Event("change"));
      const movieTypeArr = movieType.split(/\s\//);
      jQuery("#movie_type").val(movieTypeArr.join("/"));
      fillField(selector, category === "movie" ? "movie_country" : "show_country");
      jQuery("#movie_cname").val(chineseName);
    } else if (category.match(/tv/)) {
      let selector = "movie_country";
      if (area.match(/大陆/)) {
        selector = "\u5927\u9646";
      } else if (area.match(/台|港/)) {
        selector = "\u6E2F\u53F0";
      } else if (area.match(/美国|欧|英|法|德|俄|意|苏联|EU/)) {
        selector = "\u6B27\u7F8E";
      } else if (area.match(/日本|韩国/)) {
        selector = "\u65E5\u97E9";
      } else {
        selector = "\u5176\u4ED6";
      }
      const typeMap = {
        \u5927\u9646: "15",
        \u6E2F\u53F0: "16",
        \u6B27\u7F8E: "17",
        \u65E5\u97E9: "18",
        \u5176\u4ED6: "2"
      };
      jQuery('select[name="second_type"]').val(typeMap[selector]);
      jQuery('select[name="second_type"]')[0].dispatchEvent(new Event("change"));
      fillField(selector, "tv_type");
      jQuery("#tv_ename").val(title);
      jQuery("#cname").val(chineseName);
      const episode = (_n = (_m = title.match(/S\d+(E\d+)?/i)) == null ? void 0 : _m[0]) != null ? _n : "";
      jQuery("#tv_season").val(episode);
      const isBluray = videoType.match(/bluray/i);
      const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
      const { format } = getInfoFunc(mediaInfo);
      fillField((format == null ? void 0 : format.toUpperCase()) || "MKV", "tv_filetype");
    } else if (category.match(/variety/)) {
      let selector = "";
      if (area.match(/大陆/)) {
        selector = "\u5927\u9646";
      } else if (area.match(/台|港/)) {
        selector = "\u6E2F\u53F0";
      } else if (area.match(/美国|欧|英|法|德|俄|意|苏联|EU/)) {
        selector = "\u6B27\u7F8E";
      } else if (area.match(/日本|韩国/)) {
        selector = "\u65E5\u97E9";
      } else {
        selector = "\u5176\u4ED6";
      }
      const typeMap = {
        \u5927\u9646: "27",
        \u6E2F\u53F0: "29",
        \u6B27\u7F8E: "30",
        \u65E5\u97E9: "28",
        \u5176\u4ED6: "5"
      };
      jQuery('select[name="second_type"]').val(typeMap[selector]);
      jQuery('select[name="second_type"]')[0].dispatchEvent(new Event("change"));
      fillField(selector, "show_country");
      jQuery("#show_cname").val(chineseName);
      jQuery("#show_ename").val(title);
      let languageVal = "";
      if (language.match(/汉语/)) {
        languageVal = "\u56FD\u8BED";
      } else if (language.match(/粤/)) {
        languageVal = "\u7CA4\u8BED";
      } else if (language.match(/英语/)) {
        languageVal = "\u82F1\u8BED";
      } else if (language.match(/日语/)) {
        languageVal = "\u65E5\u8BED";
      } else if (language.match(/韩语/)) {
        languageVal = "\u97E9\u8BED";
      }
      fillField(languageVal, "show_language");
    }
    function bbcode2Html(bbcode) {
      let html = bbcode.replace(/\[\*\]([^\n]+)/ig, "<li>$1</li>");
      html = html.replace(/(\r\n)|\n/g, "<br>");
      html = html.replace(/\[(quote|hide=.+?)\]/ig, "<fieldset><legend>\u5F15\u7528</legend>");
      html = html.replace(/\[(\/)(quote|hide)\]/ig, "<$1fieldset>");
      html = html.replace(/(?!\[url=(http(s)*:\/{2}.+?)\])\[img\](.+?)\[\/img]\[url\]/g, '<a href="$1"><img src="$2"/></a>');
      html = html.replace(/\[img\](.+?)\[\/img]/g, '<img src="$1"/>');
      html = html.replace(/\[(\/)?(left|right|center)\]/ig, "<$1$2>");
      html = html.replace(/\[(\/)?b\]/ig, "<$1strong>");
      html = html.replace(/\[color=(.+?)\]/ig, '<span style="color: $1">').replace(/\[\/color\]/g, "</span>");
      html = html.replace(/\[size=(.+?)\]/ig, '<font size="$1">').replace(/\[\/size\]/g, "</font>");
      html = html.replace(/\[url=(.+?)\](.+?)\[\/url\]/ig, '<a href="$1">$2</a>');
      return html;
    }
  };

  // src/target/sc.ts
  init_preact_shim();
  var sc_default = async (info) => {
    const { imdbUrl = "" } = info;
    const imdbId = getIMDBIdByUrl(imdbUrl);
    jQuery("#catalogue_number").val(imdbId);
    jQuery("#imdb_autofill").trigger("click");
    fillMedia(info);
    jQuery(".modesw").trigger("click");
    jQuery("#release_desc").val(buildDescription2(info));
    await fillIMDb(imdbUrl);
  };
  function buildDescription2(info) {
    const { screenshots, mediaInfo } = info;
    let description = "";
    if (screenshots.length > 0) {
      description = screenshots.slice(0, 3).map((img) => {
        return `[img]${img}[/img]`;
      }).join("");
    }
    if (mediaInfo) {
      description += `

[hide=MediaInfo]${mediaInfo}[/hide]`;
    }
    return description;
  }
  function fillMedia(info) {
    const { videoType, resolution } = info;
    let value;
    if (videoType.match(/bluray/i)) {
      value = "BDMV";
    } else if (videoType === "DVD") {
      value = "DVD-R";
    } else if (parseInt(resolution, 10) < 720) {
      value = "SD";
    } else {
      value = resolution;
    }
    jQuery("#media").val(value);
  }
  async function fillIMDb(imdbUrl) {
    var _a3, _b2, _c, _d;
    if (imdbUrl) {
      const imdbData = await getIMDBData(imdbUrl);
      if (imdbData && ((_a3 = imdbData == null ? void 0 : imdbData.details) == null ? void 0 : _a3.country)) {
        jQuery("#country").val(imdbData.details.country);
      }
      const akaName = imdbData && ((_b2 = imdbData == null ? void 0 : imdbData.details) == null ? void 0 : _b2["Also known as"]);
      const originalName = (_c = imdbData == null ? void 0 : imdbData.name) != null ? _c : "";
      if (akaName && akaName !== originalName) {
        jQuery("#alternate_title").val(imdbData.details["Also known as"]);
        jQuery("#title").val(originalName);
      }
      if (imdbData && imdbData.poster) {
        let poster;
        const ptpImgApiKey = GM_getValue("easy-seed.ptp-img-api-key");
        if (ptpImgApiKey) {
          poster = await uploadToPtpImg([imdbData.poster]);
        } else {
          const gifyuHtml = await fetch("https://gifyu.com", {
            responseType: void 0
          });
          const authToken = (_d = gifyuHtml.match(/PF\.obj\.config\.auth_token\s*=\s*"(.+)?"/)) == null ? void 0 : _d[1];
          const data = await transferImgs(imdbData.poster, authToken, "https://gifyu.com/json");
          poster = data.url;
        }
        jQuery("#image").val(poster);
      }
    }
  }

  // src/target/kg.ts
  init_preact_shim();
  var kg_default = async (info) => {
    var _a3;
    const { imdbUrl, screenshots, mediaInfos, resolution, source, videoType } = info;
    const siteInfo = PT_SITE.KG;
    const mediaInfo = (_a3 = mediaInfos == null ? void 0 : mediaInfos[0]) != null ? _a3 : "";
    if (imdbUrl) {
      jQuery('input[type="submit"][value="next >>"]').hide().after("<p>loading...</p>");
      jQuery('input[name="title"]').val(imdbUrl);
      const formData = new FormData();
      formData.append("upstep", "2");
      formData.append("type", "1");
      formData.append("title", imdbUrl);
      const doc = await fetch(`${PT_SITE.KG.url}/upload.php`, {
        method: "POST",
        responseType: void 0,
        data: formData
      });
      const uploadPage = new DOMParser().parseFromString(doc, "text/html");
      jQuery("#upside+div").html(jQuery("#upside+div", uploadPage).html());
      const imdbData = await getIMDBData(imdbUrl);
      if (imdbData) {
        const { country, Languages: languages } = imdbData.details;
        jQuery('input[name="lang"]').val(languages);
        let { description, genre, poster = "" } = imdbData;
        const genreMap = siteInfo.genres.map;
        const countryMap = siteInfo.country.map;
        let countryValue = "";
        if (country) {
          countryValue = country.split(",")[0];
          if (countryValue === "United States") {
            countryValue = "USA";
          } else if (countryValue === "United Kingdom") {
            countryValue = "UK";
          }
        }
        if (!poster) {
          poster = info.poster || "";
        }
        jQuery('select[name="country_id"]').val(countryMap[countryValue]);
        const descriptionBBCode = `[img]${poster}[/img]
      
Synopsis:
[quote]${description}[/quote]
      

${screenshots.map((img) => `[img]${encodeURI(img)}[/img]`).join("")}`;
        jQuery("#bbcodetextarea").html(descriptionBBCode);
        const [mainGenre, otherGenre = ""] = genre;
        jQuery('select[name="genre_main_id"]').val(genreMap[mainGenre]);
        jQuery('select[name="subgenre"]').val(genreMap[otherGenre]);
      }
      jQuery(siteInfo.source.selector).val(siteInfo.source.map[source]);
      if (!videoType.match("bluray")) {
        jQuery(siteInfo.resolution.selector).val(siteInfo.resolution.map[resolution]);
      } else {
        jQuery(siteInfo.resolution.selector).val("3");
      }
      const isBluray = videoType.match(/bluray/i);
      const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
      const { subtitles = [] } = getInfoFunc(mediaInfo);
      if (subtitles.length) {
        jQuery('input[name="subs"]').val(subtitles.join(","));
      }
      if (videoType === "dvd") {
        jQuery('input[name="dvdr"]').attr("checked", "true");
      }
      const specs = videoType === "dvd" ? buildDvdSpecs(info) : mediaInfo;
      jQuery("#ripspecs").val(specs);
    }
  };
  function buildDvdSpecs(info) {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k;
    const { mediaInfos, size, audioCodec } = info;
    const mediaInfo = (_a3 = mediaInfos == null ? void 0 : mediaInfos[0]) != null ? _a3 : "";
    const scanType = mediaInfo.includes("NTSC") ? "NTSC" : "PAL";
    const dvdType = getBDType(size);
    const audioChannelNumber = ((_b2 = mediaInfo.match(/Channel\(s\)\s+:\s+(\d)/)) == null ? void 0 : _b2[1]) || "2";
    const audioName = `${audioCodec == null ? void 0 : audioCodec.toUpperCase()} ${audioChannelNumber === "6" ? "5.1" : `${audioChannelNumber}.0`}`;
    const IFOMediaInfo = (_d = (_c = info.mediaInfos) == null ? void 0 : _c.find((info2) => info2.includes(".IFO"))) != null ? _d : "";
    const runtime = (_g = (_f = (_e = IFOMediaInfo.match(/Duration\s*?:([^\n]+)/)) == null ? void 0 : _e[1]) == null ? void 0 : _f.replace(/\s/g, "")) != null ? _g : "";
    const hour = (_i = (_h = runtime.match(/(\d)+h/)) == null ? void 0 : _h[1]) != null ? _i : "00";
    const minute = (_k = (_j = runtime.match(/(\d+)(mn|min)/)) == null ? void 0 : _j[1]) != null ? _k : "";
    return `DVD Label:
DVD Format: ${dvdType} ${scanType}
DVD Audio: ${audioName}
Program(s): Unknown
Menus: Untouched
Video: Untouched
Audio: Untouched
DVD extras: Untouched
Extras contain: 
DVD runtime(s): ${+hour < 10 ? `0${hour}` : hour}:${minute}`;
  }

  // src/target/bhd.ts
  init_preact_shim();
  var currentSiteInfo2 = PT_SITE.BeyondHD;
  var bhd_default = (info) => {
    let title = info.title;
    if (info.videoType === "dvd") {
      title = buildDVDTitle(info);
    }
    jQuery(currentSiteInfo2.name.selector).val(title);
    fillSpecs(info);
    fillTMDBId(info);
    fillMediaInfo2(info);
    selectTag(info);
    fillDescription2(info);
    jQuery(currentSiteInfo2.anonymous.selector).attr("checked", "true");
    if (info.videoType === "tvPack") {
      jQuery('input[name="pack"]').attr("checked", "true");
    }
    jQuery("#torrent").on("change", () => {
      let title2 = info.title;
      if (info.videoType === "dvd") {
        title2 = buildDVDTitle(info);
      }
      jQuery(currentSiteInfo2.name.selector).val(title2);
      const categoryMap = currentSiteInfo2.category.map;
      const categoryValueArr = categoryMap[info.category];
      const keyArray = ["resolution"];
      let finalSelectArray = [];
      if (Array.isArray(categoryValueArr)) {
        finalSelectArray = [...categoryValueArr];
        keyArray.forEach((key) => {
          finalSelectArray = matchSelectForm(currentSiteInfo2, info, key, finalSelectArray);
          console.log(finalSelectArray);
          if (finalSelectArray.length === 1) {
            jQuery(currentSiteInfo2.category.selector).val(finalSelectArray[0]);
          }
        });
      } else {
        [...keyArray, "category"].forEach((key) => {
          matchSelectForm(currentSiteInfo2, info, key, finalSelectArray);
        });
      }
    });
  };
  function fillTMDBId(info) {
    const imdbId = getIMDBIdByUrl(info.imdbUrl || "");
    jQuery(currentSiteInfo2.imdb.selector).val(imdbId);
    getTMDBIdByIMDBId(imdbId).then((data) => {
      jQuery(currentSiteInfo2.tmdb.selector).val(data.id);
    });
  }
  function fillMediaInfo2(info) {
    var _a3, _b2;
    jQuery(currentSiteInfo2.mediaInfo.selector).val((_b2 = (_a3 = info.mediaInfos) == null ? void 0 : _a3[0]) != null ? _b2 : "");
  }
  function fillSpecs(info) {
    const { category, videoType } = info;
    const isBluray = videoType.match(/bluray/i);
    info.category = videoType;
    info.videoType = category;
    if (isBluray || videoType === "dvd") {
      let bdType = getBDType(info.size);
      if (videoType === "uhdbluray" && bdType === "BD50") {
        bdType = "UHD50";
      }
      info.category = bdType || "";
    }
    const categoryMap = currentSiteInfo2.category.map;
    const categoryValueArr = categoryMap[info.category];
    const keyArray = ["videoType", "resolution", "source", "category"];
    let finalSelectArray = [];
    if (Array.isArray(categoryValueArr)) {
      finalSelectArray = [...categoryValueArr];
      keyArray.forEach((key) => {
        finalSelectArray = matchSelectForm(currentSiteInfo2, info, key, finalSelectArray);
        if (finalSelectArray.length === 1) {
          jQuery(currentSiteInfo2.category.selector).val(finalSelectArray[0]);
        }
      });
    } else {
      [...keyArray, "category"].forEach((key) => {
        matchSelectForm(currentSiteInfo2, info, key, finalSelectArray);
      });
    }
  }
  function selectTag(info) {
    const editionTags = Object.keys(info.tags).map((tag) => info.tags[tag] && currentSiteInfo2.targetInfo.editionTags[tag]).filter(Boolean);
    const editionOption = Array.from(jQuery('select[name="edition"] option')).map((opt) => jQuery(opt).attr("value"));
    if (editionTags.length > 0) {
      for (const tag of editionTags) {
        setTimeout(() => {
          var _a3;
          (_a3 = document.querySelector(`.bhd-tag #${tag}`)) == null ? void 0 : _a3.dispatchEvent(new Event("click"));
        }, 0);
        if (editionOption.includes(tag)) {
          jQuery('select[name="edition"]').val(tag);
        }
      }
    }
  }
  function fillDescription2(info) {
    let description = info.description;
    if (info.sourceSite === "PTP") {
      description = buildPTPDescription(info);
    } else if (info.sourceSite.match(/BeyondHD|UHDBits/)) {
      description = info.originalDescription || "";
    } else {
      description = buildDescription3(info);
    }
    if (info.screenshots.length > 0) {
      info.screenshots.forEach((img) => {
        const regStr = new RegExp(`\\[img\\](${img})\\[\\/img\\](
*)?`);
        if (description.match(regStr)) {
          description = description.replace(regStr, (p1, p22) => {
            return `[url=${p22}][img=350x350]${p22}[/img][/url]`;
          });
        }
      });
    }
    jQuery(currentSiteInfo2.description.selector).val(description);
    jQuery(currentSiteInfo2.description.selector)[0].dispatchEvent(new Event("input"));
  }
  function buildDescription3(info) {
    var _a3, _b2;
    let description = info.description;
    const { sourceSiteType } = info;
    if (isChineseTacker(sourceSiteType)) {
      description = filterNexusDescription(info);
    }
    description = description.replace(`[quote]${(_b2 = (_a3 = info.mediaInfos) == null ? void 0 : _a3[0]) != null ? _b2 : ""}[/quote]`, "").replace(/\[url.*\[\/url\]/g, "").replace(/\[img.*\[\/img\]/g, "");
    const { comparisons, screenshots } = info;
    if (comparisons && comparisons.length > 0) {
      for (const comparison of comparisons) {
        description += `
${comparison.reason}[comparison=${comparison.title}]
${comparison.imgs.join("\n")}
[/comparison]

`;
      }
    }
    if (screenshots.length > 0) {
      description += `${screenshots.map((v3) => `[img]${v3}[/img]`).join("\n")}

`;
    }
    return description.trim();
  }
  function buildDVDTitle(info) {
    var _a3, _b2;
    const { movieName, movieAkaName, year, mediaInfos, size, audioCodec } = info;
    const mediaInfo = (_a3 = mediaInfos == null ? void 0 : mediaInfos[0]) != null ? _a3 : "";
    const scanType = mediaInfo.includes("NTSC") ? "NTSC" : "PAL";
    const dvdType = getBDType(size);
    const audioChannelNumber = ((_b2 = mediaInfo.match(/Channel\(s\)\s+:\s+(\d)/)) == null ? void 0 : _b2[1]) || "2";
    const audio = audioCodec === "ac3" ? "dd" : audioCodec;
    const audioName = `${audio == null ? void 0 : audio.toUpperCase()}${audioChannelNumber === "6" ? "5.1" : `${audioChannelNumber}.0`}`;
    const akaName = movieAkaName ? ` AKA ${movieAkaName} ` : " ";
    return `${movieName}${akaName}${year} ${scanType} ${dvdType} ${audioName}`;
  }

  // src/target/bdc.ts
  init_preact_shim();
  var currentSiteInfo3 = PT_SITE.Bdc;
  var bdc_default = async (info) => {
    jQuery(currentSiteInfo3.name.selector).val(info.title);
    jQuery(currentSiteInfo3.imdb.selector).val(info.imdbUrl || "");
    jQuery(currentSiteInfo3.anonymous.selector).attr("checked", "true");
    fillCategory(info);
    fillDescription3(info);
  };
  function fillCategory(info) {
    const { resolution, videoType, category } = info;
    const teamName = getTeamName(info);
    let categoryValue = "";
    if (teamName === "PTer") {
      categoryValue = "40";
    } else if (videoType.match(/bluray/)) {
      categoryValue = "31";
    } else if (category.match(/tv/)) {
      categoryValue = "19";
    } else {
      categoryValue = `${currentSiteInfo3.resolution.map[resolution][videoType]}`;
    }
    jQuery('select[name="category"]').val(categoryValue);
  }
  async function fillDescription3(info) {
    var _a3, _b2, _c, _d;
    jQuery(currentSiteInfo3.description.selector).val($t("\u6570\u636E\u52A0\u8F7D\u4E2D..."));
    let template = `
  [align=center][color=#FF0000][size=large][font=Trebuchet MS][b]${info.title}[/b][/font][/size][/color]
  
  [URL=$originalPoster$][IMG]$poster$[/IMG][/URL]
  
  
  [img]https://images.broadcity.eu/images/82619845736635909964.png[/img]
  [size=medium]$synopsis$[/size]
  
  [img]https://images.broadcity.eu/images/87704049718067240949.png[/img]
  
  [php]${(_a3 = info.mediaInfos) == null ? void 0 : _a3[0]}[/php][/align]
  
  [align=center][img]https://images.broadcity.eu/images/11622644009097018297.png[/img] 
  $screenshots$
  [/align]
  [align=center][img]https://images.broadcity.eu/images/54926797285164478472.png[/img]
  [youtube]$youtubeUrl$[/youtube]
  [/align]
  [align=center][img]https://images.broadcity.eu/images/44846549843542759058.png[/img]
  [/align]
  `;
    const { imdbUrl, screenshots } = info;
    const screenshotsBBCode = getScreenshotsBBCode(screenshots);
    template = template.replace("$screenshots$", screenshotsBBCode.join("\n"));
    try {
      const replaceParams = {
        synopsis: "",
        youtubeUrl: "",
        poster: "",
        originalPoster: ""
      };
      const imdbId = getIMDBIdByUrl(imdbUrl);
      const { id: tmdbId, overview, poster_path: posterPath } = await getTMDBIdByIMDBId(imdbId);
      if (tmdbId) {
        const poster = `https://image.tmdb.org/t/p/w500${posterPath}`;
        const originalPoster = `https://image.tmdb.org/t/p/original${posterPath}`;
        replaceParams.poster = poster;
        replaceParams.synopsis = overview;
        replaceParams.originalPoster = originalPoster;
        jQuery('input[name="t_image_url"]').val(poster);
        const videos = await getTMDBVideos(tmdbId);
        const youtubeId = (_d = (_c = (_b2 = videos.filter((video) => video.site === "YouTube")) == null ? void 0 : _b2[0]) == null ? void 0 : _c.key) != null ? _d : "";
        if (youtubeId.length > 0) {
          replaceParams.youtubeUrl = `https://www.youtube.com/watch?v=${youtubeId}`;
        }
        Object.keys(replaceParams).forEach((key) => {
          template = template.replace(`$${key}$`, replaceParams[key] || "");
        });
        setTimeout(() => {
          tinymce.activeEditor.setContent(template);
        }, 0);
      }
    } catch (error) {
      jQuery(currentSiteInfo3.description.selector).val(error.message);
    }
  }

  // src/target/zhuque.ts
  init_preact_shim();
  var currentSiteInfo4 = PT_SITE.ZHUQUE;
  var zhuque_default = (info) => {
    const targetNode = document;
    const imdbId = getIMDBIdByUrl(info.imdbUrl || "");
    const insert = new MutationObserver((mutationRecords) => {
      jQuery("input.ant-select-selection-search-input[id]").each(function() {
        this.dispatchEvent(new Event("keydown"));
      });
      jQuery(currentSiteInfo4.name.selector).val(info.title);
      jQuery(currentSiteInfo4.name.selector)[0].dispatchEvent(new Event("input"));
      jQuery(currentSiteInfo4.imdb.selector).val(imdbId);
      jQuery(currentSiteInfo4.imdb.selector)[0].dispatchEvent(new Event("input"));
      if (info.subtitle) {
        jQuery(currentSiteInfo4.subtitle.selector).val(info.subtitle);
        jQuery(currentSiteInfo4.subtitle.selector)[0].dispatchEvent(new Event("input"));
      }
      let screenshotStr = "";
      if (info.screenshots.length > 0) {
        info.screenshots.forEach((img) => {
          screenshotStr += `${img}
`;
        });
      }
      jQuery(currentSiteInfo4.screenshots.selector).val(screenshotStr);
      jQuery(currentSiteInfo4.screenshots.selector)[0].dispatchEvent(new Event("input"));
      fillMediaInfo3(info);
      fillDescription4(info);
      const selectNodeParent = document.querySelector("form");
      const select = new MutationObserver(async (mutationRecords2) => {
        var _a3;
        const { category: categoryConfig } = currentSiteInfo4;
        jQuery(`div.ant-select-item-option-content:contains(${categoryConfig.map[info.category]})`).click();
        const keyArray = ["videoType", "videoCodec", "audioCodec"];
        select.disconnect();
        const sleep = (ms) => {
          return new Promise((resolve) => setTimeout(resolve, ms));
        };
        const { tags } = currentSiteInfo4;
        for (const tag in info.tags) {
          if (tags[tag]) {
            await sleep(100).then((v3) => jQuery(tags[tag])[0].click());
          }
        }
        keyArray.forEach((key) => {
          const { map } = currentSiteInfo4[key];
          if (map) {
            const mapValue = map[info[key]];
            if (mapValue) {
              if (key !== "videoType" && jQuery(`div.ant-select-item-option-content:contains(${mapValue})`).length > 0) {
                jQuery(`div.ant-select-item-option-content:contains(${mapValue})`)[0].click();
              } else if (mapValue === "Blu-ray") {
                jQuery(`div.ant-select-item-option-content:contains(${mapValue})`)[2].click();
              } else if (jQuery(`div.ant-select-item-option-content:contains(${mapValue})`).length > 0) {
                jQuery(`div.ant-select-item-option-content:contains(${mapValue})`)[0].click();
              }
            }
          }
        });
        if (info.resolution !== "") (_a3 = jQuery(`div.ant-select-item-option-content:contains(${info.resolution})`)[0]) == null ? void 0 : _a3.click();
      });
      if (selectNodeParent) {
        select.observe(selectNodeParent, { attributes: false, childList: true, subtree: true, characterDataOldValue: false });
      }
      insert.disconnect();
    });
    insert.observe(targetNode, { attributes: false, childList: false, subtree: true, characterDataOldValue: false });
  };
  function fillMediaInfo3(info) {
    var _a3, _b2;
    jQuery(currentSiteInfo4.mediaInfo.selector).val((_b2 = (_a3 = info.mediaInfos) == null ? void 0 : _a3[0]) != null ? _b2 : "");
    jQuery(currentSiteInfo4.mediaInfo.selector)[0].dispatchEvent(new Event("input"));
  }
  function fillDescription4(info) {
    var _a3, _b2;
    let description = info.description.replace(`[quote]${(_b2 = (_a3 = info.mediaInfos) == null ? void 0 : _a3[0]) != null ? _b2 : ""}[/quote]`, "").trim();
    if (info.mediaInfos && info.mediaInfos[1]) {
      info.mediaInfos.forEach((mediaInfo) => {
        description = description.replace(`[quote]${mediaInfo}[/quote]`, "");
      });
    }
    if (info.sourceSite === "PTP") {
      description = buildPTPDescription(info);
      description = description.replace(/\[comparison[^[]*\[\/comparison\]/gi, "");
    } else if (info.sourceSite.match(/BeyondHD|UHDBits/)) {
      description = info.originalDescription || "";
    }
    description = description.replace(/\[url.*\[\/url\]/g, "").replace(/\[img.*\[\/img\]/g, "").replace(/\[\/?(i|b|center|quote|size|color)\]/g, "").replace(/\[(size|color)=#?[a-zA-Z0-9]*\]/g, "").replace(/\n\n*/g, "\n");
    description = description.replace(/Screen(shot)?s:(\s*)\n?/gi, "").trim();
    if (info.sourceSite === "KEEPFRDS") {
      description = description.replace(/截图对比:[^\n]*\n?/gi, "");
    }
    if (description !== "") description = `\`\`\`
${description}
\`\`\``;
    if (info.comparisons && info.comparisons[0]) {
      for (const comparison in info.comparisons) {
        description += `
\u5BF9\u6BD4\u56FE ${info.comparisons[comparison].title}

`;
        for (const img in info.comparisons[comparison].imgs) {
          description += `${info.comparisons[comparison].imgs[img]}

`;
        }
      }
    }
    const thanksQuoteClosed = GM_getValue("easy-seed.thanks-quote-closed") || "";
    if (!thanksQuoteClosed && info.sourceSite !== void 0) {
      description = `\`\`\`
\u8F6C\u81EA ${info.sourceSite} \uFF0C\u611F\u8C22\u539F\u53D1\u5E03\u8005\uFF01
\`\`\`
${description}`;
    }
    jQuery(currentSiteInfo4.description.selector).val(description);
    jQuery(currentSiteInfo4.description.selector)[0].dispatchEvent(new Event("input"));
  }

  // src/target/autofill.ts
  init_preact_shim();
  async function autoFillDoubanInfo(selfDom, info) {
    try {
      jQuery(selfDom).text($t("\u83B7\u53D6\u4E2D..."));
      const {
        imdbUrl,
        movieName,
        doubanUrl,
        description: descriptionData,
        title: torrentTitle
      } = info;
      if (!imdbUrl && !doubanUrl) {
        throw new Error($t("\u8BF7\u586B\u5199\u6B63\u786E\u94FE\u63A5"));
      }
      let doubanLink = "";
      if (doubanUrl && doubanUrl.match(/movie\.douban\.com/)) {
        doubanLink = doubanUrl;
      } else {
        const doubanData = await getDoubanIdByIMDB(imdbUrl || movieName);
        if (doubanData) {
          let { id, season = "" } = doubanData;
          const tvData = await getTvSeasonData(doubanData);
          if (season && tvData) {
            id = tvData && tvData.id;
          }
          doubanLink = `https://movie.douban.com/subject/${id}`;
        }
      }
      if (doubanLink) {
        const {
          douban,
          imdb,
          subtitle,
          description,
          name
        } = CURRENT_SITE_INFO;
        if (CURRENT_SITE_NAME === "SSD") {
          jQuery(imdb.selector).val(doubanLink);
        } else {
          jQuery(douban == null ? void 0 : douban.selector).val(doubanLink);
        }
        if (!(descriptionData == null ? void 0 : descriptionData.match(/(片|译)\s*名/))) {
          const movieData = await getDoubanInfo(doubanLink);
          if (movieData) {
            Notification_default2.open({
              message: $t("\u6210\u529F"),
              description: $t("\u83B7\u53D6\u6210\u529F")
            });
            const imdbLink = movieData.imdbLink;
            if (jQuery(imdb.selector).val() !== imdbLink && CURRENT_SITE_NAME !== "SSD") {
              jQuery(imdb.selector).val(imdbLink);
            }
            const torrentSubtitle = getSubTitle(movieData);
            if (CURRENT_SITE_NAME === "TTG") {
              jQuery(name.selector).val(`${torrentTitle || ""}[${torrentSubtitle}]`);
            } else {
              jQuery(subtitle.selector).val(torrentSubtitle);
            }
            if (CURRENT_SITE_NAME !== "SSD") {
              jQuery(description.selector).val(`${movieData.format}
${jQuery(description.selector).val()}`);
            }
          }
        } else {
          Notification_default2.open({
            message: $t("\u6210\u529F"),
            description: $t("\u83B7\u53D6\u6210\u529F")
          });
        }
      }
    } catch (error) {
      Notification_default2.open({
        message: $t("\u9519\u8BEF"),
        description: error.message
      });
    } finally {
      jQuery(selfDom).text($t("\u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB"));
    }
  }
  var autofill_default = (info) => {
    if (info.doubanInfo) {
      return;
    }
    if (CURRENT_SITE_INFO.siteType.match(/NexusPHP|TTG/)) {
      const { imdb, douban } = CURRENT_SITE_INFO;
      let selector = jQuery("");
      if (douban && (douban.selector && jQuery(douban.selector)) && jQuery(douban.selector).val()) {
        selector = jQuery(douban.selector);
      } else if (imdb) {
        selector = jQuery(imdb.selector);
      }
      if (selector) {
        selector.after(`<span id="auto-fill-douban">${$t("\u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB")}</span>`);
      }
      jQuery("#auto-fill-douban").on("click", (e4) => {
        const url = selector.val();
        if (url.match(/subject\/(\d+)/)) {
          info.doubanUrl = url;
        } else if (url.match(/imdb\.com\/title\/tt\d+/)) {
          info.imdbUrl = url;
        }
        autoFillDoubanInfo(jQuery("#auto-fill-douban"), info);
      });
    }
  };

  // src/target/mt.ts
  init_preact_shim();
  var mt_default = async (info) => {
    const targetNode = document.getElementById("root");
    const config = { childList: true, subtree: true };
    const observer = new MutationObserver((mutationsList, observer2) => {
      for (const mutation of mutationsList) {
        if (mutation.type === "childList") {
          const targetElement = document.querySelector("#name");
          const editor = document.querySelector(".editor-input");
          if (targetElement && editor) {
            observer2.disconnect();
            fillMTInfo(info);
            break;
          }
        }
      }
    });
    observer.observe(targetNode, config);
  };
  var fillMTInfo = async (info) => {
    var _a3;
    const currentSiteInfo5 = PT_SITE.MTeam;
    const { title, subtitle, audioCodec, doubanUrl, imdbUrl, mediaInfos, tags } = info;
    const mediaInfo = (_a3 = mediaInfos == null ? void 0 : mediaInfos[0]) != null ? _a3 : "";
    setInputValue(currentSiteInfo5.name.selector, title);
    setInputValue(currentSiteInfo5.subtitle.selector, subtitle || "");
    setInputValue(currentSiteInfo5.douban.selector, doubanUrl || "");
    setInputValue(currentSiteInfo5.imdb.selector, imdbUrl || "");
    setInputValue(currentSiteInfo5.mediainfo.selector, mediaInfo);
    setSelectValue(currentSiteInfo5.audioCodec.selector, currentSiteInfo5.audioCodec.map[audioCodec]);
    info.description = info.description.replace(mediaInfo.trim(), "");
    const targetHelper = new ExportHelper(info);
    targetHelper.descriptionHandler();
    targetHelper.disableTorrentChange();
    targetHelper.categoryHandler();
    let timeout = 0;
    Object.keys(tags).forEach((key) => {
      const siteTagMap = currentSiteInfo5.tags[key];
      if (tags[key] && siteTagMap) {
        setTimeout(() => {
          setInputValue(siteTagMap, "", true);
        }, timeout);
        timeout += 100;
      }
    });
    fillDescription5(targetHelper.info.description);
  };
  function setInputValue(selector, value, isCheckbox = false) {
    const input = document.querySelector(selector);
    if (input) {
      const lastValue = input.value;
      input.value = value;
      const tracker = input._valueTracker;
      if (tracker) {
        tracker.setValue(lastValue);
      }
      const event = new Event(isCheckbox ? "click" : "input", { bubbles: true });
      input.dispatchEvent(event);
    }
  }
  function fillDescription5(description) {
    var _a3;
    const editor = (_a3 = document.querySelector(".editor-input")) == null ? void 0 : _a3.__lexicalEditor;
    const descriptionArray = description.split("\n").map((line) => {
      return {
        type: "paragraph",
        children: [
          {
            type: "text",
            text: line
          }
        ]
      };
    });
    const content = JSON.stringify({
      root: {
        children: descriptionArray,
        type: "root"
      }
    });
    const editorState = editor.parseEditorState(content);
    editor.update(() => {
      editor.setEditorState(editorState);
    });
  }

  // src/target/red.ts
  init_preact_shim();
  var red_default = async (info) => {
    var _a3;
    const { musicJson } = info;
    if (!musicJson) {
      return;
    }
    document.forms.upload_table.reset = () => {
    };
    const { name, year, musicInfo, bbBody, tags, releaseType, categoryId, wikiImage } = musicJson.group;
    const groupId = getUrlParam("groupid");
    if (!groupId) {
      const url = `/ajax.php?action=browse&searchstr=${name} ${year}`;
      const searchResult = await fetch(url);
      if (searchResult.status === "success" && searchResult.response.results.length > 0) {
        const groupId2 = searchResult.response.results[0].groupId;
        const timestampMatchArray2 = location.hash && location.hash.match(/(^|#)timestamp=([^#]*)(#|$)/);
        const timestamp = (_a3 = timestampMatchArray2 == null ? void 0 : timestampMatchArray2[2]) != null ? _a3 : "";
        location.href = `${CURRENT_SITE_INFO.url}${CURRENT_SITE_INFO.uploadPath}?groupid=${groupId2}#timestamp=${timestamp}`;
        return;
      }
      jQuery("#categories").val(categoryId - 1);
      jQuery("#title").val(name);
      jQuery("#year").val(year);
      jQuery("#releasetype").val(releaseType);
      jQuery("#tags").val(tags.join(", "));
      jQuery("#album_desc").val(bbBody);
      jQuery("#image").val(wikiImage);
      fillArtistsForm(musicInfo);
    }
    fillReleaseInfo(musicJson.torrent);
  };
  function fillArtistsForm(musicInfo) {
    const artistTypeMap = {
      artists: "1",
      with: "2",
      composers: "4",
      conductor: "5",
      dj: "6",
      producer: "7",
      remixedBy: "3"
    };
    const artists = [];
    Object.keys(musicInfo).forEach((key) => {
      const typeKey = key;
      const values = musicInfo[typeKey].map((value) => {
        return __spreadProps(__spreadValues({}, value), {
          type: artistTypeMap[typeKey]
        });
      });
      artists.push(...values);
    });
    for (let i3 = 1; i3 < artists.length; i3++) {
      AddArtistField();
    }
    artists.forEach((artist, index) => {
      const selector = index > 0 ? `#artist_${index}` : "#artist";
      jQuery(selector).val(artist.name).next().val(artist.type || "");
    });
  }
  function fillReleaseInfo(info) {
    var _a3;
    const { remasterYear, remasterRecordLabel, remasterCatalogueNumber, format, encoding, media, description, scene, remasterTitle } = info;
    jQuery("#remaster_record_label").val(remasterRecordLabel);
    jQuery("#remaster_catalogue_number").val(remasterCatalogueNumber);
    jQuery("#format").val(format);
    jQuery("#bitrate").val(encoding);
    jQuery("#media").val(media);
    if (media === "CD" && format === "FLAC") {
      (_a3 = document.querySelector("#format")) == null ? void 0 : _a3.dispatchEvent(new Event("change"));
    }
    jQuery("#remaster_year").val(remasterYear);
    jQuery("#release_desc").val(description);
    if (scene) {
      jQuery("#scene").attr("checked", "true");
    }
    if (remasterTitle) {
      jQuery("#remaster_title").val(remasterTitle);
    }
  }

  // src/target/gazelle-music.ts
  init_preact_shim();
  var import_buffer = __toESM(require_buffer(), 1);
  var gazelle_music_default = async (info) => {
    var _a3;
    const { musicJson } = info;
    if (!musicJson) {
      return;
    }
    const { name, year, recordLabel, catalogueNumber } = musicJson.group;
    const { remasterTitle, remasterCatalogueNumber, remasterRecordLabel } = musicJson.torrent;
    const groupId = getUrlParam("groupid");
    if (!groupId) {
      const searchResult = await fetch(`/ajax.php?action=browse&searchstr=${name} ${year}`);
      if (searchResult.status === "success" && searchResult.response.results.length > 0) {
        const groupId2 = searchResult.response.results[0].groupId;
        const timestampMatchArray2 = location.hash && location.hash.match(/(^|#)timestamp=([^#]*)(#|$)/);
        const timestamp = (_a3 = timestampMatchArray2 == null ? void 0 : timestampMatchArray2[2]) != null ? _a3 : "";
        location.href = `${CURRENT_SITE_INFO.url}${CURRENT_SITE_INFO.uploadPath}?groupid=${groupId2}#timestamp=${timestamp}`;
        return;
      }
    }
    if (CURRENT_SITE_NAME === "Orpheus") {
      if (!remasterCatalogueNumber && !remasterRecordLabel && !remasterTitle && !recordLabel && !catalogueNumber) {
        musicJson.torrent.remastered = false;
      }
    }
    if (CURRENT_SITE_NAME === "DicMusic") {
      musicJson.group.wikiBody = toUnicodeEntities(musicJson.group.wikiBody);
    }
    fillJsonToUploadTable(musicJson, name);
  };
  function fillJsonToUploadTable(musicJson, name) {
    const buf = import_buffer.Buffer.from(JSON.stringify({
      status: "success",
      response: musicJson
    }));
    attachFile(buf, "#torrent-json-file", "application/json", name, "json");
  }
  function attachFile(data, selector, contentType, fileName, format, charset = "UTF-8") {
    const buf = import_buffer.Buffer.from(data, charset);
    const base64Data = buf.toString("base64");
    const fileInput = jQuery(selector);
    if (base64Data && fileInput.length > 0) {
      const blob = base64ToBlob(base64Data, contentType);
      const file = new File([blob], `${fileName}.${format}`, { type: contentType });
      const dataTransfer = new DataTransfer();
      dataTransfer.items.add(file);
      const uploadInput = fileInput[0];
      uploadInput.files = dataTransfer.files;
      uploadInput.dispatchEvent(new Event("change", { bubbles: true }));
    }
  }
  function toUnicodeEntities(str) {
    const excludedChars = ["<", ">", "&", ";", "/"];
    return str.split("").map((char) => {
      const code = char.charCodeAt(0);
      if (code > 127 && !excludedChars.includes(char)) {
        const hexCode = code.toString(16);
        return `&#${parseInt(hexCode, 16)};`;
      }
      return char;
    }).join("");
  }

  // src/target/index.ts
  var siteHandlers = {
    PTP: ptp_default,
    GPW: gpw_default,
    NPUBits: npubits_default,
    BYR: byr_default,
    SC: sc_default,
    KG: kg_default,
    BeyondHD: bhd_default,
    Bdc: bdc_default,
    ZHUQUE: zhuque_default,
    MTeam: mt_default,
    RED: red_default,
    HDRoute: hdr_default,
    DicMusic: gazelle_music_default,
    Orpheus: gazelle_music_default,
    iTS: its_default,
    PTN: ptn_default
  };
  var fillTargetForm = (info) => {
    var _a3;
    autofill_default(info || {});
    if (!info) {
      return;
    }
    console.log(info);
    const handler = siteHandlers[CURRENT_SITE_NAME];
    if (handler) {
      handler(info);
    }
    const targetTorrentInfo = __spreadValues({}, info);
    const isBluray = !!((_a3 = info == null ? void 0 : info.videoType) == null ? void 0 : _a3.match(/bluray/i));
    targetTorrentInfo.isBluray = isBluray;
    const targetHelper = new ExportHelper(targetTorrentInfo);
    targetHelper.disableTorrentChange();
    targetHelper.fillTorrentFile();
    if (!!handler && !CURRENT_SITE_NAME.match(/TJUPT|HDRoute|PTN|iTS/)) {
      return;
    }
    targetHelper.prepareToFillInfo();
    targetHelper.torrentTitleHandler();
    targetHelper.imdbHandler();
    targetHelper.descriptionHandler();
    targetHelper.fillBasicAttributes();
    targetHelper.categoryHandler();
    targetHelper.fillRemainingInfo();
    targetHelper.dealWithMoreSites();
  };

  // src/source/index.ts
  init_preact_shim();

  // src/source/ptp.ts
  init_preact_shim();
  var ptp_default2 = async () => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h;
    const torrentId = getUrlParam("torrentid");
    if (!torrentId) {
      return false;
    }
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const torrentDom = jQuery(`#torrent_${torrentId}`);
    const ptpMovieTitle = (_d = (_c = (_b2 = (_a3 = jQuery(".page__title").text()) == null ? void 0 : _a3.match(/]?([^[]+)/)) == null ? void 0 : _b2[1]) == null ? void 0 : _c.trim()) != null ? _d : "";
    const [movieName, movieAkaName = ""] = ptpMovieTitle.split(" AKA ");
    const mediaInfoArray = [];
    torrentDom.find(".mediainfo.mediainfo--in-release-description").next("blockquote").each(function() {
      const textContent = jQuery(this).text();
      if (textContent.match(/(Codec\s*ID)|mpls|(Stream\s*size)|Video/i)) {
        mediaInfoArray.push(textContent);
      }
    });
    TORRENT_INFO.movieName = movieName;
    TORRENT_INFO.movieAkaName = movieAkaName;
    TORRENT_INFO.imdbUrl = (_f = (_e = jQuery("#imdb-title-link")) == null ? void 0 : _e.attr("href")) != null ? _f : "";
    TORRENT_INFO.year = (_h = (_g = jQuery(".page__title").text().match(/\[(\d+)\]/)) == null ? void 0 : _g[1]) != null ? _h : "";
    const torrentHeaderDom = jQuery(`#group_torrent_header_${torrentId}`);
    const torrentLink = torrentHeaderDom.find('a[title="Download"]').attr("href");
    CURRENT_SITE_INFO.torrentLink = torrentLink;
    TORRENT_INFO.category = getPTPType();
    const screenshots = getPTPImage();
    getDescription2(torrentId).then((res) => {
      var _a4, _b3, _c2;
      const releaseName = torrentHeaderDom.data("releasename");
      const releaseGroup = getReleaseGroup(releaseName);
      const descriptionData = formatDescriptionData(res, screenshots, mediaInfoArray);
      TORRENT_INFO.description = descriptionData;
      const infoArray = torrentHeaderDom.find("#PermaLinkedTorrentToggler").text().trim().split(" / ");
      const [codes, container, source, resolution, ...otherInfo] = infoArray;
      const isRemux = otherInfo.includes("Remux");
      const { knownTags, otherTags } = getTags(otherInfo, [releaseGroup]);
      TORRENT_INFO.videoType = source === "WEB" ? "web" : getVideoType(container, isRemux, codes, source);
      const isBluray = TORRENT_INFO.videoType.match(/bluray/i);
      TORRENT_INFO.tags = __spreadValues({}, knownTags);
      TORRENT_INFO.otherTags = otherTags;
      TORRENT_INFO.resolution = resolution;
      const mediaInfoOrBDInfo = mediaInfoArray.filter((media) => {
        return TORRENT_INFO.videoType.match(/bluray/) ? media.match(/mpls/i) : !media.match(/mpls/i);
      });
      const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
      TORRENT_INFO.mediaInfos = mediaInfoOrBDInfo.map((v3) => v3.trim());
      const infoFromMediaInfoinfo = getInfoFromMediaInfo(TORRENT_INFO.mediaInfos[0]);
      if (infoFromMediaInfoinfo.subtitles) {
        for (let i3 = 0; i3 < ((_a4 = infoFromMediaInfoinfo.subtitles) == null ? void 0 : _a4.length); i3++) {
          if (/Chinese|Traditional|Simplified|Cantonese|Mandarin/i.test(infoFromMediaInfoinfo.subtitles[i3])) {
            TORRENT_INFO.tags.chinese_subtitle = true;
            break;
          }
        }
      }
      const { videoCodec, audioCodec, mediaTags } = getInfoFunc(mediaInfoOrBDInfo.join("\n\n"));
      TORRENT_INFO.videoCodec = videoCodec;
      TORRENT_INFO.audioCodec = audioCodec;
      TORRENT_INFO.tags = __spreadValues(__spreadValues({}, TORRENT_INFO.tags), mediaTags);
      const torrentName = formatTorrentTitle(releaseName);
      TORRENT_INFO.title = torrentName;
      TORRENT_INFO.source = getPTPSource(source, codes, resolution);
      const size = (_c2 = (_b3 = torrentHeaderDom.find(".nobr span").attr("title")) == null ? void 0 : _b3.replace(/[^\d]/g, "")) != null ? _c2 : "";
      TORRENT_INFO.size = parseFloat(size);
      TORRENT_INFO.screenshots = screenshots;
      TORRENT_INFO.poster = jQuery(".sidebar-cover-image").attr("src") || "";
      console.log(TORRENT_INFO);
    });
    let country = [];
    const matchArray = jQuery("#movieinfo div").text().match(/Country:\s+([^\n]+)/);
    if (matchArray && matchArray.length > 0) {
      country = matchArray == null ? void 0 : matchArray[1].replace(/(,)\s+/g, "$1").split(",");
    }
    TORRENT_INFO.area = getAreaCode(country == null ? void 0 : country[0]);
    const trumpReason = jQuery(`#trumpable_${torrentId} span`).text() || "";
    TORRENT_INFO.hardcodedSub = trumpReason.includes("Hardcoded Subtitles");
    return TORRENT_INFO;
  };
  var getPTPType = () => {
    const typeMap = {
      "Feature Film": "movie",
      "Short Film": "movie",
      "Stand-up Comedy": "other",
      Miniseries: "tvPack",
      "Live Performance": "concert",
      "Movie Collection": "movie"
    };
    const ptpType = jQuery("#torrent-table .basic-movie-list__torrent-edition__main").eq(0).text();
    return typeMap[ptpType];
  };
  var getPTPImage = () => {
    var _a3;
    const imgList = [];
    const torrentInfoPanel = jQuery(".movie-page__torrent__panel");
    const imageDom = torrentInfoPanel.find(".bbcode__image");
    for (let i3 = 0; i3 < imageDom.length; i3++) {
      const parent = imageDom[i3].parentElement;
      if ((parent == null ? void 0 : parent.tagName) === "A" && ((_a3 = parent == null ? void 0 : parent.getAttribute("href")) == null ? void 0 : _a3.match(/\.png$/))) {
        imgList.push(parent.getAttribute("href") || "");
      } else {
        const imgDom = imageDom[i3];
        const imgSrc = imgDom.getAttribute("src") || imgDom.getAttribute("alt");
        imgList.push(imgSrc || "");
      }
    }
    return imgList;
  };
  var getPTPSource = (source, codes, resolution) => {
    if (codes.match(/BD100|BD66/i)) {
      return "uhdbluray";
    }
    if (source.match(/Blu-ray/i) && resolution.match(/2160P|4K/i)) {
      return "uhdbluray";
    }
    return source.replace(/-/g, "").toLowerCase();
  };
  var getVideoType = (container, isRemux, codes, source) => {
    let type = "";
    if (isRemux) {
      type = "remux";
    } else if (codes.match(/BD50|BD25/ig)) {
      type = "bluray";
    } else if (codes.match(/BD66|BD100/ig)) {
      type = "uhdbluray";
    } else if (source.match(/DVD/ig) && container.match(/MKV|AVI/ig)) {
      type = "dvdrip";
    } else if (codes.match(/DVD5|DVD9/ig) && container.match(/VOB|ISO/ig)) {
      type = "dvd";
    } else if (container.match(/MKV|MP4/i)) {
      type = "encode";
    }
    return type;
  };
  var getDescription2 = async (id) => {
    const url = `${PT_SITE.PTP.url}/torrents.php?action=get_description&id=${id}`;
    const data = await fetch(url, {
      responseType: void 0
    });
    if (data) {
      const element = document.createElement("span");
      element.innerHTML = data;
      return element.innerText || element.textContent || "";
    }
    return "";
  };
  var formatDescriptionData = (data, screenshots, mediaInfoArray) => {
    let descriptionData = data.replace(/\r\n/g, "\n");
    descriptionData = descriptionData.split("\n").map((line) => {
      return line.trim();
    }).join("\n").replace(/http:\/\/ptpimg.me/g, "https://ptpimg.me");
    TORRENT_INFO.originalDescription = descriptionData;
    screenshots.forEach((screenshot) => {
      const regStr = new RegExp(`\\[img${screenshot}\\[\\/img\\]`, "i");
      if (!descriptionData.match(regStr)) {
        const regOldFormat = new RegExp(`\\[img=${screenshot}\\]`, "i");
        if (descriptionData.match(regOldFormat)) {
          descriptionData = descriptionData.replace(regOldFormat, `[img]${screenshot}[/img]`);
        } else {
          descriptionData = descriptionData.replace(new RegExp(`(?<!\\[img\\])${screenshot}`, "ig"), `[img]${screenshot}[/img]`);
        }
      }
    });
    descriptionData = descriptionData.replace(/\[(\/)?mediainfo\]/g, "[$1quote]");
    descriptionData = descriptionData.replace(/\[(\/)?hide(?:=(.+?))?\]/g, (match, p1, p22) => {
      const slash = p1 || "";
      return p22 ? `${p22}: [${slash}quote]` : `[${slash}quote]`;
    });
    descriptionData = descriptionData.replace(/\[(\/)?pre\]/g, "[$1quote]");
    descriptionData = descriptionData.replace(/\[align(=(.+?))\]((.|\n)+?)\[\/align\]/g, "[quote][$2]$3[/$2][/quote]");
    const comparisonArray = descriptionData.match(/(\n.+\n)?\[comparison=(?:.+?)\]((.|\n)+?)\[\/comparison\]/ig) || [];
    const comparisons = [];
    comparisonArray.forEach((item) => {
      var _a3, _b2, _c, _d;
      descriptionData = descriptionData.replace(item, item.replace(/\s/g, ""));
      const reason = (_b2 = (_a3 = item.match(/(\n.*\n)?\[comparison=/i)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
      const title = (_d = (_c = item.match(/\[comparison=(.*?)\]/i)) == null ? void 0 : _c[1]) != null ? _d : "";
      const comparisonImgArray = item.replace(/\[\/?comparison(=(.+?))?\]/ig, "").split(/[ \r\n]/);
      const imgs = [];
      Array.from(new Set(comparisonImgArray)).forEach((item2) => {
        const formatImg = item2.replace(/\s*/g, "");
        if (item2.match(/^https?.+/)) {
          imgs.push(formatImg);
          descriptionData = descriptionData.replace(new RegExp(`(?<!(\\[img\\]))${item2}`, "gi"), `[img]${formatImg}[/img]`);
        } else if (item2.match(/^\[img\]/i)) {
          imgs.push(formatImg.replace(/\[\/?img\]/g, ""));
        }
      });
      comparisons.push({
        title,
        imgs,
        reason
      });
    });
    TORRENT_INFO.comparisons = comparisons;
    descriptionData = descriptionData.replace(/\[comparison=(.+?)\]/ig, "\n[b]$1 Comparison:[/b]\n").replace(/\[\/comparison\]/ig, "");
    mediaInfoArray.forEach((mediaInfo) => {
      const regStr = new RegExp(`\\[quote\\]\\s*?${replaceRegSymbols(mediaInfo).slice(0, 1e4)}`, "i");
      if (!descriptionData.match(regStr)) {
        descriptionData = descriptionData.replace(mediaInfo, `[quote]${mediaInfo}[/quote]`);
      }
    });
    if (TORRENT_INFO.category === "concert") {
      descriptionData = `${jQuery("#synopsis").text()}
${descriptionData}`;
    }
    return descriptionData;
  };
  function getTags(rawTags, exclude = []) {
    const { editionTags } = PT_SITE.PTP.sourceInfo;
    const knownTags = {};
    const otherTags = {};
    for (const rawTag of rawTags) {
      const tag = editionTags[rawTag];
      if (tag) {
        knownTags[tag] = true;
      } else if (tag === null || exclude.includes(rawTag) || rawTag.match(/Freeleech|Halfleech|Half-Leech/i)) {
      } else {
        otherTags[rawTag] = true;
      }
    }
    return {
      knownTags,
      otherTags
    };
  }
  function getReleaseGroup(releasename) {
    var _a3, _b2;
    return (_b2 = (_a3 = releasename.match(/-(\w+?)$/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
  }

  // src/source/bhd.ts
  init_preact_shim();
  var bhd_default2 = async () => {
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const basicInfo = getBasicInfo();
    const editionTags = getEditionTags(basicInfo);
    const { Category, Name, Source, Type, Size } = basicInfo;
    TORRENT_INFO.size = getSize(Size);
    TORRENT_INFO.title = formatTorrentTitle(Name);
    const tags = getTagsFromSubtitle(TORRENT_INFO.title);
    const TMDBYear = jQuery(".movie-heading a:last").text();
    const movieName = jQuery(".movie-heading a:first").text();
    if (!TMDBYear) {
      const matchYear = TORRENT_INFO.title.match(/\s([12][90]\d{2})/);
      TORRENT_INFO.year = matchYear ? matchYear[0] : "";
    } else {
      TORRENT_INFO.year = TMDBYear;
    }
    const descriptionDom = jQuery(".panel-heading:contains(Description)").next(".panel-body").find(".forced-nfo");
    const descriptionBBCode = getFilterBBCode(descriptionDom[0]);
    TORRENT_INFO.comparisons = getComparisonImgs();
    const { category: movieCat, countries, imdbUrl } = getMovieDetails();
    TORRENT_INFO.movieName = movieName;
    let category = Category.toLowerCase().replace(/s/, "");
    category = movieCat === "Animation" ? "cartoon" : category;
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
    TORRENT_INFO.source = getSource(Source, Type);
    TORRENT_INFO.area = getAreaCode(countries);
    TORRENT_INFO.videoType = getVideoType2(Source, Type);
    const isBluray = TORRENT_INFO.videoType.match(/bluray/i);
    const mediaInfo = jQuery("#stats-full code").text();
    TORRENT_INFO.mediaInfos = [mediaInfo];
    TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
    TORRENT_INFO.originalDescription = `${descriptionBBCode}`;
    TORRENT_INFO.description = `
[quote]${mediaInfo}[/quote]
${descriptionBBCode}`;
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, resolution = "", mediaTags } = getInfoFunc(mediaInfo);
    TORRENT_INFO.videoCodec = videoCodec;
    TORRENT_INFO.audioCodec = audioCodec;
    TORRENT_INFO.resolution = resolution;
    TORRENT_INFO.tags = __spreadValues(__spreadValues(__spreadValues({}, tags), mediaTags), editionTags.knownTags);
    TORRENT_INFO.otherTags = editionTags.otherTags;
    TORRENT_INFO.imdbUrl = imdbUrl;
  };
  var getBasicInfo = () => {
    const basicInfo = {
      Category: "",
      Name: "",
      Source: "",
      Type: "",
      Size: "",
      Video: "",
      Audio: "",
      Hybrid: "",
      Edition: "",
      Region: "",
      Extras: ""
    };
    jQuery(".dotborder").each((index, element) => {
      const key = jQuery(element).find("td:first").text();
      const value = jQuery(element).find("td:last").text();
      basicInfo[key] = value.replace(/\n/g, "").trim();
    });
    console.log(basicInfo);
    return basicInfo;
  };
  var getMovieDetails = () => {
    const infoList = jQuery(".movie-details a");
    const movieDetail = {
      category: "",
      countries: "",
      imdbUrl: ""
    };
    movieDetail.imdbUrl = jQuery('span.badge-meta[title*="IMDb"] > a').attr("href") || "";
    infoList.each((index, element) => {
      var _a3, _b2;
      const urlParams = (_b2 = (_a3 = jQuery(element).attr("href")) == null ? void 0 : _a3.replace(/.+\//g, "").split("=")) != null ? _b2 : "";
      if (urlParams.length > 1) {
        let key = decodeURI(urlParams[0]);
        const value = urlParams[1];
        if (key === "g[]") {
          key = "category";
        }
        movieDetail[key] = value;
      }
    });
    return movieDetail;
  };
  var getSource = (source, resolution) => {
    if (resolution.match(/BD100|BD66/i)) {
      return "uhdbluray";
    }
    if (source.match(/Blu-ray/i) && resolution.match(/UHD/i)) {
      return "uhdbluray";
    }
    if (source.match(/WEB|WEB-DL/i)) {
      return "web";
    }
    return source.replace(/-/g, "").toLowerCase();
  };
  var getVideoType2 = (source, type) => {
    type = type.replace(/\s/g, "");
    if (type.match(/Remux/i)) {
      return "remux";
    } else if (type.match(/BD50|BD25/i)) {
      return "bluray";
    } else if (type.match(/UHD50|UHD66|UHD100/i)) {
      return "uhdbluray";
    } else if (type.match(/DVD5|DVD9/i)) {
      return "dvd";
    } else if (source.match(/WEB|WEB-DL/i)) {
      return "web";
    } else if (type.match(/\d{3,4}p/i)) {
      return "encode";
    }
    return type;
  };
  var getEditionTags = (basicInfo) => {
    const editionTags = PT_SITE.BeyondHD.sourceInfo.editionTags;
    const knownTags = {};
    const otherTags = {
      Hybrid: false
    };
    const { Video, Audio, Edition, Extras, Hybrid } = basicInfo;
    const text = [Video, Audio, Edition, Extras].filter((v3) => Boolean(v3)).join(" / ");
    const mediaTags = Object.entries(editionTags);
    for (const [source, target] of mediaTags) {
      if (text.includes(source)) {
        knownTags[target] = true;
      }
    }
    if (Hybrid) {
      otherTags.Hybrid = true;
    }
    if (knownTags.hdr10_plus && knownTags.hdr) {
      delete knownTags.hdr;
    }
    return {
      knownTags,
      otherTags
    };
  };
  function getComparisonImgs() {
    var _a3, _b2;
    const title = (_b2 = (_a3 = jQuery("#screenMain .screenParent").text()) == null ? void 0 : _a3.replace(/\[Show\]|Comparison/g, "")) == null ? void 0 : _b2.trim();
    const imgs = Array.from(jQuery(".screenComparison img")).map((img) => {
      var _a4, _b3;
      return (_b3 = (_a4 = jQuery(img)) == null ? void 0 : _a4.attr("src")) != null ? _b3 : "";
    });
    if (title !== "") {
      return [
        {
          title,
          imgs,
          reason: ""
        }
      ];
    }
  }

  // src/source/hdb.ts
  init_preact_shim();
  var hdb_default = async () => {
    var _a3, _b2;
    const torrentId = getUrlParam("id");
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const editDom = jQuery("#details tr").has("a:contains(Edit torrent)");
    const descriptionDom = editDom.length > 0 ? editDom.prev() : jQuery("#details >tbody >tr:contains(tags) + tr");
    let descriptionBBCode = getFilterBBCode(descriptionDom.find(">td")[0]);
    descriptionBBCode = (_b2 = (_a3 = descriptionBBCode.match(/\[quote\]((.|\n)+)\[\/quote\]/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    TORRENT_INFO.description = descriptionBBCode;
    const { size, category, videoType } = getBasicInfo2();
    const title = jQuery("h1").eq(0).text();
    TORRENT_INFO.title = formatTorrentTitle(title);
    const tags = getTagsFromSubtitle(title);
    const isMovieType = jQuery(".contentlayout h1").length > 0;
    const IMDBLinkDom = isMovieType ? jQuery(".contentlayout h1") : jQuery("#details .showlinks li").eq(1);
    if (isMovieType) {
      const IMDBYear = IMDBLinkDom.prop("lastChild").nodeValue.replace(/\s|\(|\)/g, "");
      const movieName = IMDBLinkDom.find("a").text();
      TORRENT_INFO.movieName = movieName;
      if (!IMDBYear) {
        const matchYear = TORRENT_INFO.title.match(/\s([12][90]\d{2})/);
        TORRENT_INFO.year = matchYear ? matchYear[0] : "";
      } else {
        TORRENT_INFO.year = IMDBYear;
      }
    }
    TORRENT_INFO.imdbUrl = IMDBLinkDom.find("a").attr("href") || "";
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
    TORRENT_INFO.source = getSourceFromTitle(TORRENT_INFO.title);
    TORRENT_INFO.videoType = videoType;
    const isBluray = TORRENT_INFO.videoType.match(/bluray/i);
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { bdinfo } = getBDInfoOrMediaInfo(descriptionBBCode);
    if (!isBluray) {
      getMediaInfo(torrentId).then((data) => {
        if (data) {
          TORRENT_INFO.mediaInfos = [data];
          descriptionBBCode += `
[quote]${data}[/quote]`;
          TORRENT_INFO.description = descriptionBBCode;
          const { videoCodec, audioCodec, resolution, mediaTags } = getInfoFunc(data);
          TORRENT_INFO.videoCodec = videoCodec;
          TORRENT_INFO.audioCodec = audioCodec;
          TORRENT_INFO.resolution = resolution || "";
          TORRENT_INFO.tags = __spreadValues(__spreadValues({}, tags), mediaTags);
        }
      });
    } else {
      TORRENT_INFO.mediaInfos = bdinfo;
      const { videoCodec, audioCodec, resolution, mediaTags } = getInfoFunc((bdinfo == null ? void 0 : bdinfo[0]) || descriptionBBCode);
      TORRENT_INFO.videoCodec = videoCodec;
      TORRENT_INFO.audioCodec = audioCodec;
      TORRENT_INFO.resolution = resolution || "";
      TORRENT_INFO.tags = __spreadValues(__spreadValues({}, tags), mediaTags);
    }
    TORRENT_INFO.size = size;
    TORRENT_INFO.screenshots = await getImages(descriptionBBCode);
  };
  var getBasicInfo2 = () => {
    const videoTypeMap = {
      "Blu-ray/HD DVD": "bluray",
      Capture: "hdtv",
      Encode: "encode",
      Remux: "remux",
      "WEB-DL": "web"
    };
    const info = jQuery("th:contains(Category)").next().text();
    const size = jQuery("th:contains(Size)").eq(0).next().text();
    const splitArray = info.split("(");
    const category = splitArray[0].trim().toLowerCase();
    const videoCodec = splitArray[1].split(",")[0].toLowerCase().replace(/\./g, "");
    const videoType = splitArray[1].split(",")[1].replace(/\)/g, "").trim();
    return {
      size: getSize(size),
      category,
      videoCodec,
      videoType: videoTypeMap[videoType]
    };
  };
  var getMediaInfo = async (torrentId) => {
    const res = await fetch(`https://hdbits.org/details/mediainfo?id=${torrentId}`, {
      responseType: void 0
    });
    const data = res.replace(/\r\n/g, "\n");
    return data || "";
  };
  var getImages = async (description) => {
    const screenshots = await getScreenshotsFromBBCode(description);
    return screenshots;
  };

  // src/source/tik.ts
  init_preact_shim();
  var tik_default = async () => {
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const typeText = jQuery("td.heading:contains(Type)").eq(0).next().text();
    const isMovie = typeText !== "TV-Series";
    const tags = [];
    jQuery("td.heading:contains(Tags)").eq(0).next().children().each((_3, child) => {
      tags.push(child.textContent);
    });
    const size = jQuery("td.heading:contains(Size)").eq(0).next().text().replace(/[0-9.]+ GB\s+\(([0-9,]+) bytes\)/i, (_3, size2) => size2.replace(/,/g, ""));
    const title = jQuery("h1").eq(0).text();
    const imdbNumber = jQuery('span:contains("IMDB id:") a').text();
    const descContainer = jQuery("td.heading:contains(Description)").eq(0).next();
    const desc = descContainer.text();
    const rawDesc = descContainer.html();
    TORRENT_INFO.mediaInfos = [jQuery("td[style~=dotted]").text()];
    const { videoCodec, audioCodec, resolution = "", mediaTags = {} } = getInfoFromBDInfo(TORRENT_INFO.mediaInfos[0]);
    TORRENT_INFO.size = parseInt(size, 10);
    TORRENT_INFO.title = formatTorrentTitle(title);
    TORRENT_INFO.description = desc;
    TORRENT_INFO.screenshots = getImagesFromDesc(rawDesc);
    TORRENT_INFO.year = jQuery("span.gr_hsep:contains(Year)").text().replace("Year: ", "").trim();
    TORRENT_INFO.movieName = jQuery("div.gr_tdsep h1:first-child").text();
    TORRENT_INFO.imdbUrl = `https://www.imdb.com/title/tt${imdbNumber}/`;
    TORRENT_INFO.category = isMovie ? "movie" : "tvPack";
    TORRENT_INFO.source = getSourceFromTitle(TORRENT_INFO.title);
    TORRENT_INFO.videoType = tags.includes("Blu-ray") ? "bluray" : "dvd";
    TORRENT_INFO.videoCodec = videoCodec;
    TORRENT_INFO.audioCodec = audioCodec;
    TORRENT_INFO.resolution = resolution;
    TORRENT_INFO.tags = mediaTags;
  };
  function getImagesFromDesc(desc) {
    const screenshots = [];
    if (!desc) {
      return screenshots;
    }
    const matches = desc.match(/[a-z0-9]{32}/g);
    if (!matches) {
      return screenshots;
    }
    for (const m3 of matches) {
      screenshots.push(`https://hostik.cinematik.net/gal/ori/${m3[0]}/${m3[1]}/${m3}.jpg`);
    }
    return screenshots;
  }

  // src/source/ttg.ts
  init_preact_shim();
  var ttg_default = async () => {
    var _a3, _b2, _c, _d, _e;
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const headTitle = jQuery("#main_table h1").eq(0).text();
    const title = formatTorrentTitle((_b2 = (_a3 = headTitle.match(/[^[]+/)) == null ? void 0 : _a3[0]) != null ? _b2 : "");
    TORRENT_INFO.title = title;
    TORRENT_INFO.subtitle = headTitle.replace(title, "").replace(/\[|\]/g, "");
    const tags = getTagsFromSubtitle(TORRENT_INFO.subtitle + TORRENT_INFO.title);
    const mediaTecInfo = getTorrentValueDom("\u7C7B\u578B").text();
    const { category, area, videoType } = getCategoryAndArea(mediaTecInfo);
    TORRENT_INFO.area = area;
    TORRENT_INFO.videoType = getVideoType3(title, videoType);
    const year = (_c = TORRENT_INFO.title.match(/(18|19|20)\d{2}/g)) != null ? _c : [];
    TORRENT_INFO.year = year ? year.pop() : "";
    const imdbUrl = getTorrentValueDom("IMDb").find("a").attr("href");
    TORRENT_INFO.source = getSourceFromTitle(TORRENT_INFO.title);
    const sizeStr = (_e = (_d = getTorrentValueDom("\u5C3A\u5BF8").text().match(/\(((\d|,)+)\s*字节\)/i)) == null ? void 0 : _d[1]) != null ? _e : "";
    TORRENT_INFO.size = parseInt(sizeStr.replace(/,/g, ""), 10);
    const isBluray = TORRENT_INFO.videoType.match(/bluray/i);
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    TORRENT_INFO.isForbidden = !!jQuery("#kt_d").text().match(/禁转/);
    window.onload = async () => {
      var _a4, _b3, _c2, _d2, _e2, _f, _g;
      const descriptionDom = jQuery("#kt_d");
      const bbCodes = getFilterBBCode(descriptionDom[0]);
      if (!imdbUrl) {
        TORRENT_INFO.imdbUrl = (_a4 = bbCodes.match(/https:\/\/www\.imdb\.com\/title\/tt\d+/)) == null ? void 0 : _a4[0];
      } else {
        TORRENT_INFO.imdbUrl = imdbUrl;
      }
      const description = getDescription3(bbCodes, title);
      TORRENT_INFO.description = description;
      const comparisons = getComparisonImgs2(description);
      TORRENT_INFO.comparisons = comparisons;
      const doubanUrl = (_b3 = bbCodes.match(/https:\/\/(movie\.)?douban.com\/subject\/\d+/)) == null ? void 0 : _b3[0];
      if (doubanUrl) {
        TORRENT_INFO.doubanUrl = doubanUrl;
      }
      const areaMatch = (_c2 = bbCodes.match(/(产\s+地|国\s+家)\s+(.+)/)) == null ? void 0 : _c2[2];
      if (areaMatch) {
        TORRENT_INFO.area = getAreaCode(areaMatch);
      }
      if (!category) {
        TORRENT_INFO.category = getCategoryFromDesc(bbCodes);
      } else {
        TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
      }
      const { bdinfo, mediaInfo } = getBDInfoOrMediaInfo(bbCodes);
      const mediaInfoOrBDInfo = isBluray ? bdinfo : mediaInfo;
      if (mediaInfoOrBDInfo) {
        TORRENT_INFO.mediaInfos = mediaInfoOrBDInfo;
        const { videoCodec, audioCodec, resolution, mediaTags } = getInfoFunc(mediaInfoOrBDInfo == null ? void 0 : mediaInfoOrBDInfo[0]);
        TORRENT_INFO.videoCodec = videoCodec;
        TORRENT_INFO.audioCodec = audioCodec;
        TORRENT_INFO.resolution = resolution || "";
        TORRENT_INFO.tags = __spreadValues(__spreadValues({}, tags), mediaTags);
      } else {
        let resolution = (_e2 = (_d2 = TORRENT_INFO.title.match(/\d{3,4}(p|i)/i)) == null ? void 0 : _d2[0]) != null ? _e2 : "";
        if (!resolution && resolution.match(/4k|uhd/i)) {
          resolution = "2160p";
        }
        TORRENT_INFO.resolution = resolution;
        TORRENT_INFO.audioCodec = getAudioCodecFromTitle(TORRENT_INFO.title);
        if (bbCodes.match(/VIDEO(\.| )*CODEC/i)) {
          const matchCodec = (_f = bbCodes.match(/VIDEO(\.| )*CODEC\.*:?\s*([^\s_:]+)?/i)) == null ? void 0 : _f[2];
          if (matchCodec) {
            TORRENT_INFO.videoCodec = matchCodec.replace(/\.|-/g, "").toLowerCase();
          } else {
            const { title: title2 } = TORRENT_INFO;
            TORRENT_INFO.videoCodec = getVideoCodecFromTitle(title2);
          }
        }
        if (bbCodes.match(/AUDIO\s*CODEC/i)) {
          const matchCodec = (_g = bbCodes.match(/AUDIO\s*CODEC\.*:?\s*(.+)/i)) == null ? void 0 : _g[1];
          if (matchCodec) {
            TORRENT_INFO.audioCodec = getAudioCodecFromTitle(matchCodec);
          }
        }
      }
      let screenshots = await getImages2(bbCodes);
      comparisons.forEach((comparison) => {
        screenshots = screenshots.filter((img) => !comparison.imgs.includes(img));
      });
      TORRENT_INFO.screenshots = screenshots;
    };
  };
  var getCategoryAndArea = (mediaInfo) => {
    let category = "";
    let area = "";
    let videoType = "";
    if (mediaInfo.match(/电影/)) {
      category = "movie";
    } else if (mediaInfo.match(/剧包/)) {
      category = "tvPack";
    } else if (mediaInfo.match(/剧/)) {
      category = "tv";
    } else if (mediaInfo.match(/纪录/)) {
      category = "documentary";
    } else if (mediaInfo.match(/综艺/)) {
      category = "variety";
    } else if (mediaInfo.match(/体育/)) {
      category = "sport";
    } else if (mediaInfo.match(/演唱会/)) {
      category = "concert";
    } else if (mediaInfo.match(/动漫/)) {
      category = "cartoon";
    }
    if (mediaInfo.match(/韩/)) {
      area = "KR";
    } else if (mediaInfo.match(/日/)) {
      area = "JP";
    } else if (mediaInfo.match(/华/)) {
      area = "CN";
    } else if (mediaInfo.match(/欧/)) {
      area = "US";
    }
    if (mediaInfo.match(/UHD原盘/i)) {
      videoType = "uhdbluray";
    } else if (mediaInfo.match(/bluray原盘/i)) {
      videoType = "bluray";
    } else if (mediaInfo.match(/DVD/i)) {
      videoType = "dvd";
    }
    return {
      category,
      area,
      videoType
    };
  };
  var getImages2 = (bbcode) => {
    var _a3, _b2;
    if (bbcode.match(/More\.Screens/i)) {
      const moreScreen = (_b2 = (_a3 = bbcode.match(/\.More\.Screens\[\/u\]\[\/color\]\n((.|\n)+\[\/(url|img)\])/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
      return getScreenshotsFromBBCode(moreScreen);
    }
    return getScreenshotsFromBBCode(bbcode);
  };
  var getVideoType3 = (title, videoType) => {
    if (title.match(/HDTV/i)) {
      return "hdtv";
    } else if (title.match(/web(-)*(dl|rip)/i)) {
      return "web";
    } else if (title.match(/remux/i)) {
      return "remux";
    } else if (title.match(/dvdrip/i)) {
      return "dvdrip";
    } else if (title.match(/x264|x265/i)) {
      return "encode";
    }
    return videoType;
  };
  var getTorrentValueDom = (key) => {
    return jQuery(`#main_table td.heading:contains(${key})`).next();
  };
  var getCategoryFromDesc = (desc) => {
    let category = "movie";
    const { title, subtitle } = TORRENT_INFO;
    if (title.match(/s0?\d{1,2}/i) || desc.match(/集\s*数/)) {
      if (title.match(/s0?\d{1,2}e0\d{1,2}/i) || (subtitle == null ? void 0 : subtitle.match(/第[^\s]集/))) {
        category = "tv";
      } else {
        category = "tvPack";
      }
    } else if (desc.match(/动画/)) {
      category = "cartoon";
    } else if (desc.match(/纪录/)) {
      category = "documentary";
    }
    return category;
  };
  function getDescription3(bbcode, title) {
    var _a3, _b2, _c, _d, _e, _f;
    const discountMatch = (_b2 = (_a3 = bbcode.match(/\[color=\w+\]本种子.+?\[\/color\]/)) == null ? void 0 : _a3[0]) != null ? _b2 : "";
    if (discountMatch) {
      bbcode = bbcode.replace(discountMatch, "");
    }
    const noneSenseNumberMatch = (_d = (_c = bbcode.match(/@\d+?\(\d+?\)/)) == null ? void 0 : _c[0]) != null ? _d : "";
    if (noneSenseNumberMatch) {
      bbcode = bbcode.replace(noneSenseNumberMatch, "");
    }
    if (title.match(/-WiKi$/)) {
      const doubanPart = (_f = (_e = bbcode.match(/◎译\s+名(.|\n)+/)) == null ? void 0 : _e[0]) != null ? _f : "";
      bbcode = bbcode.replace(doubanPart, "");
      bbcode = bbcode.replace(/(\[img\].+?\[\/img\])/, `$1

${doubanPart}`);
    }
    return bbcode;
  }
  function getComparisonImgs2(description) {
    var _a3, _b2, _c;
    const comparisonPart = (_a3 = description.match(/\.Comparisons(.|\n)+\[\/img\]\[\/url\]/)) == null ? void 0 : _a3[0];
    if (!comparisonPart) {
      return [];
    }
    const title = (_c = (_b2 = comparisonPart.match(/(\[color=.+?\])(.+?)\[\/color\]/g)) == null ? void 0 : _b2.map((item) => {
      var _a4, _b3;
      return (_b3 = (_a4 = item.match(/\[color=.+?\](.+?)\[\/color\]/)) == null ? void 0 : _a4[1]) != null ? _b3 : "";
    })) != null ? _c : [];
    const comparisonImgArray = [];
    const allImages = comparisonPart == null ? void 0 : comparisonPart.match(/(\[url=(http(s)*:\/{2}.+?)\])?\[img\](.+?)\[\/img](\[url\])?/g);
    if (allImages && allImages.length > 0) {
      allImages.forEach((img) => {
        var _a4;
        const matchUrl = (_a4 = img.match(/\[url=(.+?)\]/)) == null ? void 0 : _a4[1];
        if (matchUrl) {
          comparisonImgArray.push(matchUrl);
        }
      });
    }
    return [{
      imgs: comparisonImgArray,
      title: title.join(","),
      reason: ""
    }];
  }

  // src/source/unit3d.ts
  init_preact_shim();
  var unit3d_default = async () => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h;
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const { Category, Name, Type, Size, Resolution } = getBasicInfo3();
    TORRENT_INFO.size = getSize(Size);
    let title = formatTorrentTitle(Name);
    const tags = getTagsFromSubtitle(TORRENT_INFO.title);
    const category = getCategory(Category);
    const videoType = getVideoType4(Type, Resolution);
    let IMDBYear = jQuery(".movie-heading span:last").text();
    let movieName = jQuery(".movie-heading span:first").text();
    let imdbUrl = jQuery(".movie-details a:contains(IMDB)").attr("href");
    let poster = jQuery(".movie-poster").attr("src");
    if (CURRENT_SITE_NAME === "HDPOST") {
      const englishTitle = (_b2 = (_a3 = title.match(/[\s\W\d]+(.+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
      TORRENT_INFO.subtitle = (_c = title.replace(englishTitle, "")) == null ? void 0 : _c.trim();
      title = englishTitle;
    }
    if (CURRENT_SITE_NAME === "ACM") {
      title = title.replace(/\/\s+\W+/, "");
    }
    if (CURRENT_SITE_NAME === "MDU") {
      title = jQuery("h1.text-center").text().trim();
      TORRENT_INFO.subtitle = jQuery("h2.text-center").text().trim();
    }
    if (!IMDBYear) {
      const matchYear = TORRENT_INFO.title.match(/(19|20)\d{2}/g);
      IMDBYear = (_d = matchYear == null ? void 0 : matchYear.pop()) != null ? _d : "";
    } else {
      IMDBYear = IMDBYear.replace(/\(|\)|\s/g, "");
    }
    const resolution = (_f = (_e = Resolution.match(/\d+(i|p)/i)) == null ? void 0 : _e[0]) != null ? _f : "";
    let descriptionDom = jQuery(".fa-sticky-note").parents(".panel-heading").siblings(".table-responsive").find(".panel-body").clone();
    descriptionDom.find("#collection_waypoint").remove();
    let mediaInfoOrBDInfo = jQuery(".decoda-code code").text();
    if (CURRENT_SITE_NAME.match(/Blutopia|Aither|fearnopeer/i)) {
      const title2 = jQuery(".meta__title").text().trim();
      movieName = title2.replace(/\(.+\)/g, "");
      IMDBYear = (_h = (_g = title2.match(/\((\d{4})\)/)) == null ? void 0 : _g[1]) != null ? _h : "";
      imdbUrl = jQuery(".meta__imdb a").attr("href");
      descriptionDom = jQuery(".panel__body.bbcode-rendered");
      mediaInfoOrBDInfo = jQuery(".bbcode-rendered code").text();
      poster = jQuery(".meta__poster-link img").attr("src");
    }
    let descriptionBBCode = getFilterBBCode(descriptionDom[0]);
    if (mediaInfoOrBDInfo) {
      descriptionBBCode = `
[quote]${mediaInfoOrBDInfo}[/quote]${descriptionBBCode}`;
    }
    const isBluray = videoType.match(/bluray/i);
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, mediaTags } = getInfoFunc(mediaInfoOrBDInfo);
    TORRENT_INFO.mediaInfos = [mediaInfoOrBDInfo];
    TORRENT_INFO.videoCodec = videoCodec;
    TORRENT_INFO.audioCodec = audioCodec;
    TORRENT_INFO.tags = __spreadValues(__spreadValues({}, tags), mediaTags);
    TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
    TORRENT_INFO.title = title;
    TORRENT_INFO.year = IMDBYear;
    TORRENT_INFO.movieName = CURRENT_SITE_NAME === "HDPOST" ? "" : movieName;
    TORRENT_INFO.resolution = resolution;
    TORRENT_INFO.imdbUrl = imdbUrl;
    TORRENT_INFO.poster = poster;
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
    TORRENT_INFO.source = getSourceFromTitle(title);
    TORRENT_INFO.videoType = videoType.toLowerCase();
    TORRENT_INFO.description = descriptionBBCode;
    const fullInformation = TORRENT_INFO.subtitle + descriptionBBCode;
    const isForbidden = fullInformation.match(/禁转|禁轉|严禁转载|嚴禁轉載|谢绝转载|謝絕轉載|请勿转载|禁止转载|exclusive/);
    TORRENT_INFO.isForbidden = !!isForbidden;
  };
  var getBasicInfo3 = () => {
    const basicInfo = {
      Category: "",
      Name: "",
      Type: "",
      Size: "",
      Resolution: ""
    };
    const keyMap = {
      Name: "Name",
      \u540D\u79F0: "Name",
      \u540D\u7A31: "Name",
      Size: "Size",
      \u4F53\u79EF: "Size",
      \u9AD4\u7A4D: "Size",
      size: "Size",
      Category: "Category",
      \u7C7B\u522B: "Category",
      \u985E\u5225: "Category",
      category: "Category",
      Type: "Type",
      \u89C4\u683C: "Type",
      \u898F\u683C: "Type",
      type: "Type",
      Resolution: "Resolution",
      resolution: "Resolution"
    };
    if (!CURRENT_SITE_NAME.match(/Blutopia|Aither|fearnopeer/i)) {
      const lineSelector = jQuery('#meta-info+.meta-general>.panel:has(".table-responsive"):first table tr');
      lineSelector.each((index, element) => {
        var _a3, _b2, _c;
        const key = jQuery(element).find("td:first").text().replace(/\s|\n/g, "");
        const basicKey = keyMap[key];
        if (basicKey) {
          let value = jQuery(element).find("td:last").text();
          if (basicKey === "Name") {
            value = (_c = (_b2 = (_a3 = jQuery(element).find("td:last")[0]) == null ? void 0 : _a3.firstChild) == null ? void 0 : _b2.textContent) != null ? _c : "";
          }
          basicInfo[basicKey] = value.replace(/\n/g, "").trim();
        }
      });
    } else {
      const formats = jQuery(".torrent__tags li");
      formats.each((index, item) => {
        var _a3;
        const className = (_a3 = jQuery(item).attr("class")) == null ? void 0 : _a3.replace("torrent__", "");
        basicInfo[keyMap[className]] = jQuery(item).text().trim();
      });
      const title = jQuery("h1.torrent__name").text().trim();
      basicInfo.Name = title;
      console.log(basicInfo);
    }
    return basicInfo;
  };
  var getCategory = (key) => {
    if (!key) {
      return "";
    }
    if (key.match(/movie|电影/i)) {
      return "movie";
    } else if (key.match(/tv|电视|剧集/i)) {
      return "tv";
    }
    return "";
  };
  var getVideoType4 = (type, resolution) => {
    type = type.replace(/\s/g, "");
    if (type.match(/FullDisc|BD/g)) {
      if (resolution.match(/2160p/i)) {
        return "uhdbluray";
      } else if (resolution.match(/1080/)) {
        return "bluray";
      }
      return "dvd";
    } else if (type.match(/Encode/i)) {
      return "encode";
    } else if (type.match(/web/i)) {
      return "web";
    } else if (type.match(/HDTV/i)) {
      return "hdtv";
    } else if (type.match(/DVD/i)) {
      return "dvd";
    }
    return type;
  };

  // src/source/nexusphp.ts
  init_preact_shim();

  // src/source/helper.ts
  init_preact_shim();

  // node_modules/parse-torrent/index.js
  init_preact_shim();

  // node_modules/bencode/index.js
  init_preact_shim();

  // node_modules/bencode/lib/encode.js
  init_preact_shim();

  // node_modules/uint8-util/browser.js
  init_preact_shim();

  // node_modules/uint8-util/util.js
  init_preact_shim();
  var alphabet = "0123456789abcdef";
  var encodeLookup = [];
  var decodeLookup = [];
  for (let i3 = 0; i3 < 256; i3++) {
    encodeLookup[i3] = alphabet[i3 >> 4 & 15] + alphabet[i3 & 15];
    if (i3 < 16) {
      if (i3 < 10) {
        decodeLookup[48 + i3] = i3;
      } else {
        decodeLookup[97 - 10 + i3] = i3;
      }
    }
  }
  var arr2hex = (data) => {
    const length = data.length;
    let string = "";
    let i3 = 0;
    while (i3 < length) {
      string += encodeLookup[data[i3++]];
    }
    return string;
  };
  var hex2arr = (str) => {
    const sizeof = str.length >> 1;
    const length = sizeof << 1;
    const array = new Uint8Array(sizeof);
    let n2 = 0;
    let i3 = 0;
    while (i3 < length) {
      array[n2++] = decodeLookup[str.charCodeAt(i3++)] << 4 | decodeLookup[str.charCodeAt(i3++)];
    }
    return array;
  };
  var concat = (chunks, size = 0) => {
    const length = chunks.length || 0;
    if (!size) {
      let i4 = length;
      while (i4--) size += chunks[i4].length;
    }
    const b3 = new Uint8Array(size);
    let offset = size;
    let i3 = length;
    while (i3--) {
      offset -= chunks[i3].length;
      b3.set(chunks[i3], offset);
    }
    return b3;
  };

  // node_modules/base64-arraybuffer/dist/base64-arraybuffer.es5.js
  init_preact_shim();
  var chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
  var lookup = typeof Uint8Array === "undefined" ? [] : new Uint8Array(256);
  for (i3 = 0; i3 < chars.length; i3++) {
    lookup[chars.charCodeAt(i3)] = i3;
  }
  var i3;
  var encode = function(arraybuffer) {
    var bytes = new Uint8Array(arraybuffer), i3, len = bytes.length, base64 = "";
    for (i3 = 0; i3 < len; i3 += 3) {
      base64 += chars[bytes[i3] >> 2];
      base64 += chars[(bytes[i3] & 3) << 4 | bytes[i3 + 1] >> 4];
      base64 += chars[(bytes[i3 + 1] & 15) << 2 | bytes[i3 + 2] >> 6];
      base64 += chars[bytes[i3 + 2] & 63];
    }
    if (len % 3 === 2) {
      base64 = base64.substring(0, base64.length - 1) + "=";
    } else if (len % 3 === 1) {
      base64 = base64.substring(0, base64.length - 2) + "==";
    }
    return base64;
  };

  // node_modules/uint8-util/browser.js
  var decoder = new TextDecoder();
  var arr2text = (data, enc) => {
    if (!enc) return decoder.decode(data);
    const dec = new TextDecoder(enc);
    return dec.decode(data);
  };
  var encoder = new TextEncoder();
  var text2arr = (str) => encoder.encode(str);
  var arr2base = (data) => encode(data);
  var scope = typeof window !== "undefined" ? window : self;
  var crypto = scope.crypto || scope.msCrypto || {};
  var subtle = crypto.subtle || crypto.webkitSubtle;
  var formatMap = {
    hex: arr2hex,
    base64: arr2base
  };
  var hash = async (data, format, algo = "sha-1") => {
    if (!subtle) throw new Error("no web crypto support");
    if (typeof data === "string") data = text2arr(data);
    const out = new Uint8Array(await subtle.digest(algo, data));
    return format ? formatMap[format](out) : out;
  };

  // node_modules/bencode/lib/util.js
  init_preact_shim();
  function digitCount(value) {
    const sign = value < 0 ? 1 : 0;
    value = Math.abs(Number(value || 1));
    return Math.floor(Math.log10(value)) + 1 + sign;
  }
  function getType(value) {
    if (ArrayBuffer.isView(value)) return "arraybufferview";
    if (Array.isArray(value)) return "array";
    if (value instanceof Number) return "number";
    if (value instanceof Boolean) return "boolean";
    if (value instanceof Set) return "set";
    if (value instanceof Map) return "map";
    if (value instanceof String) return "string";
    if (value instanceof ArrayBuffer) return "arraybuffer";
    return typeof value;
  }

  // node_modules/bencode/lib/encode.js
  function encode2(data, buffer, offset) {
    const buffers = [];
    let result = null;
    encode2._encode(buffers, data);
    result = concat(buffers);
    encode2.bytes = result.length;
    if (ArrayBuffer.isView(buffer)) {
      buffer.set(result, offset);
      return buffer;
    }
    return result;
  }
  encode2.bytes = -1;
  encode2._floatConversionDetected = false;
  encode2._encode = function(buffers, data) {
    if (data == null) {
      return;
    }
    switch (getType(data)) {
      case "object":
        encode2.dict(buffers, data);
        break;
      case "map":
        encode2.dictMap(buffers, data);
        break;
      case "array":
        encode2.list(buffers, data);
        break;
      case "set":
        encode2.listSet(buffers, data);
        break;
      case "string":
        encode2.string(buffers, data);
        break;
      case "number":
        encode2.number(buffers, data);
        break;
      case "boolean":
        encode2.number(buffers, data);
        break;
      case "arraybufferview":
        encode2.buffer(buffers, new Uint8Array(data.buffer, data.byteOffset, data.byteLength));
        break;
      case "arraybuffer":
        encode2.buffer(buffers, new Uint8Array(data));
        break;
    }
  };
  var buffE = new Uint8Array([101]);
  var buffD = new Uint8Array([100]);
  var buffL = new Uint8Array([108]);
  encode2.buffer = function(buffers, data) {
    buffers.push(text2arr(data.length + ":"), data);
  };
  encode2.string = function(buffers, data) {
    buffers.push(text2arr(text2arr(data).byteLength + ":" + data));
  };
  encode2.number = function(buffers, data) {
    if (Number.isInteger(data)) return buffers.push(text2arr("i" + BigInt(data) + "e"));
    const maxLo = 2147483648;
    const hi = data / maxLo << 0;
    const lo = data % maxLo << 0;
    const val = hi * maxLo + lo;
    buffers.push(text2arr("i" + val + "e"));
    if (val !== data && !encode2._floatConversionDetected) {
      encode2._floatConversionDetected = true;
      console.warn(
        'WARNING: Possible data corruption detected with value "' + data + '":',
        'Bencoding only defines support for integers, value was converted to "' + val + '"'
      );
      console.trace();
    }
  };
  encode2.dict = function(buffers, data) {
    buffers.push(buffD);
    let j4 = 0;
    let k4;
    const keys = Object.keys(data).sort();
    const kl = keys.length;
    for (; j4 < kl; j4++) {
      k4 = keys[j4];
      if (data[k4] == null) continue;
      encode2.string(buffers, k4);
      encode2._encode(buffers, data[k4]);
    }
    buffers.push(buffE);
  };
  encode2.dictMap = function(buffers, data) {
    buffers.push(buffD);
    const keys = Array.from(data.keys()).sort();
    for (const key of keys) {
      if (data.get(key) == null) continue;
      ArrayBuffer.isView(key) ? encode2._encode(buffers, key) : encode2.string(buffers, String(key));
      encode2._encode(buffers, data.get(key));
    }
    buffers.push(buffE);
  };
  encode2.list = function(buffers, data) {
    let i3 = 0;
    const c3 = data.length;
    buffers.push(buffL);
    for (; i3 < c3; i3++) {
      if (data[i3] == null) continue;
      encode2._encode(buffers, data[i3]);
    }
    buffers.push(buffE);
  };
  encode2.listSet = function(buffers, data) {
    buffers.push(buffL);
    for (const item of data) {
      if (item == null) continue;
      encode2._encode(buffers, item);
    }
    buffers.push(buffE);
  };
  var encode_default = encode2;

  // node_modules/bencode/lib/decode.js
  init_preact_shim();
  var INTEGER_START = 105;
  var STRING_DELIM = 58;
  var DICTIONARY_START = 100;
  var LIST_START = 108;
  var END_OF_TYPE = 101;
  function getIntFromBuffer(buffer, start, end) {
    let sum = 0;
    let sign = 1;
    for (let i3 = start; i3 < end; i3++) {
      const num = buffer[i3];
      if (num < 58 && num >= 48) {
        sum = sum * 10 + (num - 48);
        continue;
      }
      if (i3 === start && num === 43) {
        continue;
      }
      if (i3 === start && num === 45) {
        sign = -1;
        continue;
      }
      if (num === 46) {
        break;
      }
      throw new Error("not a number: buffer[" + i3 + "] = " + num);
    }
    return sum * sign;
  }
  function decode2(data, start, end, encoding) {
    if (data == null || data.length === 0) {
      return null;
    }
    if (typeof start !== "number" && encoding == null) {
      encoding = start;
      start = void 0;
    }
    if (typeof end !== "number" && encoding == null) {
      encoding = end;
      end = void 0;
    }
    decode2.position = 0;
    decode2.encoding = encoding || null;
    decode2.data = !ArrayBuffer.isView(data) ? text2arr(data) : new Uint8Array(data.slice(start, end));
    decode2.bytes = decode2.data.length;
    return decode2.next();
  }
  decode2.bytes = 0;
  decode2.position = 0;
  decode2.data = null;
  decode2.encoding = null;
  decode2.next = function() {
    switch (decode2.data[decode2.position]) {
      case DICTIONARY_START:
        return decode2.dictionary();
      case LIST_START:
        return decode2.list();
      case INTEGER_START:
        return decode2.integer();
      default:
        return decode2.buffer();
    }
  };
  decode2.find = function(chr) {
    let i3 = decode2.position;
    const c3 = decode2.data.length;
    const d3 = decode2.data;
    while (i3 < c3) {
      if (d3[i3] === chr) return i3;
      i3++;
    }
    throw new Error(
      'Invalid data: Missing delimiter "' + String.fromCharCode(chr) + '" [0x' + chr.toString(16) + "]"
    );
  };
  decode2.dictionary = function() {
    decode2.position++;
    const dict = {};
    while (decode2.data[decode2.position] !== END_OF_TYPE) {
      const buffer = decode2.buffer();
      let key = arr2text(buffer);
      if (key.includes("\uFFFD")) key = arr2hex(buffer);
      dict[key] = decode2.next();
    }
    decode2.position++;
    return dict;
  };
  decode2.list = function() {
    decode2.position++;
    const lst = [];
    while (decode2.data[decode2.position] !== END_OF_TYPE) {
      lst.push(decode2.next());
    }
    decode2.position++;
    return lst;
  };
  decode2.integer = function() {
    const end = decode2.find(END_OF_TYPE);
    const number = getIntFromBuffer(decode2.data, decode2.position + 1, end);
    decode2.position += end + 1 - decode2.position;
    return number;
  };
  decode2.buffer = function() {
    let sep = decode2.find(STRING_DELIM);
    const length = getIntFromBuffer(decode2.data, decode2.position, sep);
    const end = ++sep + length;
    decode2.position = end;
    return decode2.encoding ? arr2text(decode2.data.slice(sep, end)) : decode2.data.slice(sep, end);
  };
  var decode_default = decode2;

  // node_modules/bencode/lib/encoding-length.js
  init_preact_shim();
  function listLength(list) {
    let length = 1 + 1;
    for (const value of list) {
      length += encodingLength(value);
    }
    return length;
  }
  function mapLength(map) {
    let length = 1 + 1;
    for (const [key, value] of map) {
      const keyLength = text2arr(key).byteLength;
      length += digitCount(keyLength) + 1 + keyLength;
      length += encodingLength(value);
    }
    return length;
  }
  function objectLength(value) {
    let length = 1 + 1;
    const keys = Object.keys(value);
    for (let i3 = 0; i3 < keys.length; i3++) {
      const keyLength = text2arr(keys[i3]).byteLength;
      length += digitCount(keyLength) + 1 + keyLength;
      length += encodingLength(value[keys[i3]]);
    }
    return length;
  }
  function stringLength(value) {
    const length = text2arr(value).byteLength;
    return digitCount(length) + 1 + length;
  }
  function arrayBufferLength(value) {
    const length = value.byteLength - value.byteOffset;
    return digitCount(length) + 1 + length;
  }
  function encodingLength(value) {
    const length = 0;
    if (value == null) return length;
    const type = getType(value);
    switch (type) {
      case "arraybufferview":
        return arrayBufferLength(value);
      case "string":
        return stringLength(value);
      case "array":
      case "set":
        return listLength(value);
      case "number":
        return 1 + digitCount(Math.floor(value)) + 1;
      case "bigint":
        return 1 + value.toString().length + 1;
      case "object":
        return objectLength(value);
      case "map":
        return mapLength(value);
      default:
        throw new TypeError(`Unsupported value of type "${type}"`);
    }
  }
  var encoding_length_default = encodingLength;

  // node_modules/bencode/index.js
  var encodingLength2 = encoding_length_default;
  var bencode_default = { encode: encode_default, decode: decode_default, byteLength: encoding_length_default, encodingLength: encodingLength2 };

  // node_modules/parse-torrent/index.js
  var import_fs = __toESM(require_fs(), 1);

  // node_modules/cross-fetch-ponyfill/browser.js
  init_preact_shim();
  var Blob2 = self.Blob;
  var File2 = self.File;
  var FormData2 = self.FormData;
  var Headers = self.Headers;
  var Request = self.Request;
  var Response = self.Response;
  var AbortController = self.AbortController;
  var AbortSignal2 = self.AbortSignal;
  var fetch2 = self.fetch || (() => {
    throw new Error("global fetch is not available!");
  });

  // node_modules/magnet-uri/index.js
  init_preact_shim();

  // node_modules/@thaunknown/thirty-two/lib/thirty-two/index.js
  init_preact_shim();
  var byteTable = [
    255,
    255,
    26,
    27,
    28,
    29,
    30,
    31,
    255,
    255,
    255,
    255,
    255,
    255,
    255,
    255,
    255,
    0,
    1,
    2,
    3,
    4,
    5,
    6,
    7,
    8,
    9,
    10,
    11,
    12,
    13,
    14,
    15,
    16,
    17,
    18,
    19,
    20,
    21,
    22,
    23,
    24,
    25,
    255,
    255,
    255,
    255,
    255,
    255,
    0,
    1,
    2,
    3,
    4,
    5,
    6,
    7,
    8,
    9,
    10,
    11,
    12,
    13,
    14,
    15,
    16,
    17,
    18,
    19,
    20,
    21,
    22,
    23,
    24,
    25,
    255,
    255,
    255,
    255,
    255
  ];
  var decode3 = function(encoded) {
    if (!ArrayBuffer.isView(encoded) && typeof encoded !== "string") {
      throw new TypeError("base32.decode only takes Buffer or string as parameter");
    }
    let shiftIndex = 0;
    let plainDigit = 0;
    let plainChar;
    let plainPos = 0;
    if (!ArrayBuffer.isView(encoded)) {
      encoded = text2arr(encoded);
    }
    const decoded = new Uint8Array(Math.ceil(encoded.length * 5 / 8));
    for (let i3 = 0; i3 < encoded.length; i3++) {
      if (encoded[i3] === 61) {
        break;
      }
      const encodedByte = encoded[i3] - 48;
      if (encodedByte < byteTable.length) {
        plainDigit = byteTable[encodedByte];
        if (shiftIndex <= 3) {
          shiftIndex = (shiftIndex + 5) % 8;
          if (shiftIndex === 0) {
            plainChar |= plainDigit;
            decoded[plainPos] = plainChar;
            plainPos++;
            plainChar = 0;
          } else {
            plainChar |= 255 & plainDigit << 8 - shiftIndex;
          }
        } else {
          shiftIndex = (shiftIndex + 5) % 8;
          plainChar |= 255 & plainDigit >>> shiftIndex;
          decoded[plainPos] = plainChar;
          plainPos++;
          plainChar = 255 & plainDigit << 8 - shiftIndex;
        }
      } else {
        throw new Error("Invalid input - it is not base32 encoded string");
      }
    }
    return decoded.subarray(0, plainPos);
  };

  // node_modules/bep53-range/index.js
  init_preact_shim();
  function parseRange(range) {
    const generateRange = (start, end = start) => Array.from({ length: end - start + 1 }, (cur, idx) => idx + start);
    return range.reduce((acc, cur, idx, arr) => {
      const r3 = cur.split("-").map((cur2) => parseInt(cur2));
      return acc.concat(generateRange(...r3));
    }, []);
  }

  // node_modules/magnet-uri/index.js
  function magnetURIDecode(uri) {
    const result = {};
    const data = uri.split("magnet:?")[1];
    const params = data && data.length >= 0 ? data.split("&") : [];
    params.forEach((param) => {
      const keyval = param.split("=");
      if (keyval.length !== 2) return;
      const key = keyval[0];
      let val = keyval[1];
      if (key === "dn") val = decodeURIComponent(val).replace(/\+/g, " ");
      if (key === "tr" || key === "xs" || key === "as" || key === "ws") {
        val = decodeURIComponent(val);
      }
      if (key === "kt") val = decodeURIComponent(val).split("+");
      if (key === "ix") val = Number(val);
      if (key === "so") val = parseRange(decodeURIComponent(val).split(","));
      if (result[key]) {
        if (!Array.isArray(result[key])) {
          result[key] = [result[key]];
        }
        result[key].push(val);
      } else {
        result[key] = val;
      }
    });
    let m3;
    if (result.xt) {
      const xts = Array.isArray(result.xt) ? result.xt : [result.xt];
      xts.forEach((xt) => {
        if (m3 = xt.match(/^urn:btih:(.{40})/)) {
          result.infoHash = m3[1].toLowerCase();
        } else if (m3 = xt.match(/^urn:btih:(.{32})/)) {
          result.infoHash = arr2hex(decode3(m3[1]));
        } else if (m3 = xt.match(/^urn:btmh:1220(.{64})/)) {
          result.infoHashV2 = m3[1].toLowerCase();
        }
      });
    }
    if (result.xs) {
      const xss = Array.isArray(result.xs) ? result.xs : [result.xs];
      xss.forEach((xs) => {
        if (m3 = xs.match(/^urn:btpk:(.{64})/)) {
          result.publicKey = m3[1].toLowerCase();
        }
      });
    }
    if (result.infoHash) result.infoHashBuffer = hex2arr(result.infoHash);
    if (result.infoHashV2) result.infoHashV2Buffer = hex2arr(result.infoHashV2);
    if (result.publicKey) result.publicKeyBuffer = hex2arr(result.publicKey);
    if (result.dn) result.name = result.dn;
    if (result.kt) result.keywords = result.kt;
    result.announce = [];
    if (typeof result.tr === "string" || Array.isArray(result.tr)) {
      result.announce = result.announce.concat(result.tr);
    }
    result.urlList = [];
    if (typeof result.as === "string" || Array.isArray(result.as)) {
      result.urlList = result.urlList.concat(result.as);
    }
    if (typeof result.ws === "string" || Array.isArray(result.ws)) {
      result.urlList = result.urlList.concat(result.ws);
    }
    result.peerAddresses = [];
    if (typeof result["x.pe"] === "string" || Array.isArray(result["x.pe"])) {
      result.peerAddresses = result.peerAddresses.concat(result["x.pe"]);
    }
    result.announce = Array.from(new Set(result.announce));
    result.urlList = Array.from(new Set(result.urlList));
    result.peerAddresses = Array.from(new Set(result.peerAddresses));
    return result;
  }
  var magnet_uri_default = magnetURIDecode;

  // node_modules/parse-torrent/index.js
  var import_path = __toESM(require_path_browserify(), 1);
  var import_queue_microtask = __toESM(require_queue_microtask(), 1);
  async function parseTorrent(torrentId) {
    if (typeof torrentId === "string" && /^(stream-)?magnet:/.test(torrentId)) {
      const torrentObj = magnet_uri_default(torrentId);
      if (!torrentObj.infoHash) {
        throw new Error("Invalid torrent identifier");
      }
      return torrentObj;
    } else if (typeof torrentId === "string" && (/^[a-f0-9]{40}$/i.test(torrentId) || /^[a-z2-7]{32}$/i.test(torrentId))) {
      return magnet_uri_default(`magnet:?xt=urn:btih:${torrentId}`);
    } else if (ArrayBuffer.isView(torrentId) && torrentId.length === 20) {
      return magnet_uri_default(`magnet:?xt=urn:btih:${arr2hex(torrentId)}`);
    } else if (ArrayBuffer.isView(torrentId)) {
      return await decodeTorrentFile(torrentId);
    } else if (torrentId && torrentId.infoHash) {
      torrentId.infoHash = torrentId.infoHash.toLowerCase();
      if (!torrentId.announce) torrentId.announce = [];
      if (typeof torrentId.announce === "string") {
        torrentId.announce = [torrentId.announce];
      }
      if (!torrentId.urlList) torrentId.urlList = [];
      return torrentId;
    } else {
      throw new Error("Invalid torrent identifier");
    }
  }
  async function decodeTorrentFile(torrent) {
    if (ArrayBuffer.isView(torrent)) {
      torrent = bencode_default.decode(torrent);
    }
    ensure(torrent.info, "info");
    ensure(torrent.info["name.utf-8"] || torrent.info.name, "info.name");
    ensure(torrent.info["piece length"], "info['piece length']");
    ensure(torrent.info.pieces, "info.pieces");
    if (torrent.info.files) {
      torrent.info.files.forEach((file) => {
        ensure(typeof file.length === "number", "info.files[0].length");
        ensure(file["path.utf-8"] || file.path, "info.files[0].path");
      });
    } else {
      ensure(typeof torrent.info.length === "number", "info.length");
    }
    const result = {
      info: torrent.info,
      infoBuffer: bencode_default.encode(torrent.info),
      name: arr2text(torrent.info["name.utf-8"] || torrent.info.name),
      announce: []
    };
    result.infoHashBuffer = await hash(result.infoBuffer);
    result.infoHash = arr2hex(result.infoHashBuffer);
    if (torrent.info.private !== void 0) result.private = !!torrent.info.private;
    if (torrent["creation date"]) result.created = new Date(torrent["creation date"] * 1e3);
    if (torrent["created by"]) result.createdBy = arr2text(torrent["created by"]);
    if (ArrayBuffer.isView(torrent.comment)) result.comment = arr2text(torrent.comment);
    if (Array.isArray(torrent["announce-list"]) && torrent["announce-list"].length > 0) {
      torrent["announce-list"].forEach((urls) => {
        urls.forEach((url) => {
          result.announce.push(arr2text(url));
        });
      });
    } else if (torrent.announce) {
      result.announce.push(arr2text(torrent.announce));
    }
    if (ArrayBuffer.isView(torrent["url-list"])) {
      torrent["url-list"] = torrent["url-list"].length > 0 ? [torrent["url-list"]] : [];
    }
    result.urlList = (torrent["url-list"] || []).map((url) => arr2text(url));
    result.announce = Array.from(new Set(result.announce));
    result.urlList = Array.from(new Set(result.urlList));
    const files = torrent.info.files || [torrent.info];
    result.files = files.map((file, i3) => {
      const parts = [].concat(result.name, file["path.utf-8"] || file.path || []).map((p3) => ArrayBuffer.isView(p3) ? arr2text(p3) : p3);
      return {
        path: import_path.default.join.apply(null, [import_path.default.sep].concat(parts)).slice(1),
        name: parts[parts.length - 1],
        length: file.length,
        offset: files.slice(0, i3).reduce(sumLength, 0)
      };
    });
    result.length = files.reduce(sumLength, 0);
    const lastFile = result.files[result.files.length - 1];
    result.pieceLength = torrent.info["piece length"];
    result.lastPieceLength = (lastFile.offset + lastFile.length) % result.pieceLength || result.pieceLength;
    result.pieces = splitPieces(torrent.info.pieces);
    return result;
  }
  function encodeTorrentFile(parsed) {
    const torrent = {
      info: parsed.info
    };
    torrent["announce-list"] = (parsed.announce || []).map((url) => {
      if (!torrent.announce) torrent.announce = url;
      url = text2arr(url);
      return [url];
    });
    torrent["url-list"] = parsed.urlList || [];
    if (parsed.private !== void 0) {
      torrent.private = Number(parsed.private);
    }
    if (parsed.created) {
      torrent["creation date"] = parsed.created.getTime() / 1e3 | 0;
    }
    if (parsed.createdBy) {
      torrent["created by"] = parsed.createdBy;
    }
    if (parsed.comment) {
      torrent.comment = parsed.comment;
    }
    return bencode_default.encode(torrent);
  }
  function sumLength(sum, file) {
    return sum + file.length;
  }
  function splitPieces(buf) {
    const pieces = [];
    for (let i3 = 0; i3 < buf.length; i3 += 20) {
      pieces.push(arr2hex(buf.slice(i3, i3 + 20)));
    }
    return pieces;
  }
  function ensure(bool, fieldName) {
    if (!bool) throw new Error(`Torrent is missing required field: ${fieldName}`);
  }
  var parse_torrent_default = parseTorrent;

  // src/source/helper.ts
  var import_buffer2 = __toESM(require_buffer(), 1);
  var getVideoType5 = (videoType) => {
    if (!videoType) {
      return "";
    }
    videoType = videoType.replace(/[.-]/g, "").toLowerCase();
    if (videoType.match(/encode|x264|x265|bdrip|hdrip|压制/ig)) {
      return "encode";
    } else if (videoType.match(/remux/ig)) {
      return "remux";
    } else if (videoType.match(/uhd|ultra/ig)) {
      return "uhdbluray";
    } else if (videoType.match(/blu|discs/ig)) {
      return "bluray";
    } else if (videoType.match(/webdl/ig)) {
      return "web";
    } else if (videoType.match(/hdtv/ig)) {
      return "hdtv";
    } else if (videoType.match(/dvdr/ig)) {
      return "dvdrip";
    } else if (videoType.match(/dvd/ig)) {
      return "dvd";
    }
    return "";
  };
  var getCategory2 = (category) => {
    if (!category) {
      return "";
    }
    category = category.replace(/[.-]/g, "").toLowerCase();
    if (category.match(/movie|bd|ultra|电影/ig)) {
      return "movie";
    } else if (category.match(/综艺/ig)) {
      return "variety";
    } else if (category.match(/tv|drama|剧集|电视/ig)) {
      return "tv";
    } else if (category.match(/TVSeries/ig)) {
      return "tvPack";
    } else if (category.match(/document|纪录|紀錄|Doc/ig)) {
      return "documentary";
    } else if (category.match(/sport|体育/ig)) {
      return "sport";
    } else if (category.match(/mv|演唱|concert/ig)) {
      return "concert";
    } else if (category.match(/anim|动(画|漫)/ig)) {
      return "cartoon";
    } else if (category.match(/App|软件|Software|軟體/ig)) {
      return "app";
    } else if (category.match(/电子书|小说|Ebook/ig)) {
      return "ebook";
    } else if (category.match(/有声书|AudioBook/ig)) {
      return "audiobook";
    } else if (category.match(/杂志|magazine/ig)) {
      return "magazine";
    } else if (category.match(/漫画|comics/ig)) {
      return "comics";
    } else if (category.match(/公开课/ig)) {
      return "onlineCourse";
    } else if (category.match(/资料/ig)) {
      return "ebook";
    }
    return "";
  };
  var getResolution3 = (resolution) => {
    resolution = resolution.toLowerCase();
    if (resolution.match(/4k|2160|UHD/ig)) {
      return "2160p";
    } else if (resolution.match(/1080(p)?/ig)) {
      return "1080p";
    } else if (resolution.match(/1080i/ig)) {
      return "1080i";
    } else if (resolution.match(/720(p)?/ig)) {
      return "720p";
    } else if (resolution.match(/sd/ig)) {
      return "480p";
    }
    return resolution;
  };
  var getFormat2 = (data) => {
    if (data.match(/pdf/i)) {
      return "pdf";
    } else if (data.match(/EPUB/i)) {
      return "epub";
    } else if (data.match(/MOBI/i)) {
      return "mobi";
    } else if (data.match(/mp3/i)) {
      return "mp3";
    } else if (data.match(/mp4/i)) {
      return "mp4";
    } else if (data.match(/txt/i)) {
      return "txt";
    } else if (data.match(/azw3/i)) {
      return "azw3";
    } else if (data.match(/镜像/i)) {
      return "iso";
    }
    return "other";
  };
  var blobToBase64 = (blob) => {
    return new Promise((resolve, reject) => {
      const fileReader = new FileReader();
      fileReader.onload = (e4) => {
        var _a3;
        resolve((_a3 = e4.target) == null ? void 0 : _a3.result);
      };
      fileReader.readAsDataURL(blob);
      fileReader.onerror = () => {
        reject(new Error("blobToBase64 error"));
      };
    });
  };
  var getTorrentFileData = async (selector = "", torrentLink = "") => {
    let downloadLink = torrentLink || jQuery(selector).attr("href");
    if (!downloadLink) {
      console.warn("Failed to get torrent file download link");
      return null;
    }
    if (!downloadLink.startsWith("http") && !downloadLink.startsWith("/")) {
      downloadLink = `${CURRENT_SITE_INFO.url}/${downloadLink}`;
    } else if (downloadLink.startsWith("/")) {
      downloadLink = `${CURRENT_SITE_INFO.url}${downloadLink}`;
    }
    try {
      const file = await fetch(downloadLink, {
        method: "GET",
        responseType: "arraybuffer",
        timeout: 1e4
      });
      const result = await parse_torrent_default(import_buffer2.Buffer.from(file));
      const buf = encodeTorrentFile(__spreadProps(__spreadValues({}, result), {
        comment: "",
        announce: ["tracker.com"],
        info: __spreadProps(__spreadValues({}, result.info), {
          source: ""
        })
      }));
      const blob = new Blob([buf], { type: "application/x-bittorrent" });
      const base64 = await blobToBase64(blob);
      return base64;
    } catch (error) {
      Notification_default2.open({
        message: $t("\u79CD\u5B50\u6587\u4EF6\u4E0B\u8F7D\u5931\u8D25"),
        description: $t("\u8BF7\u624B\u52A8\u4E0B\u8F7D")
      });
      console.log(error);
      return "";
    }
  };

  // src/source/nexusphp.ts
  var nexusphp_default = async () => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D;
    let title = formatTorrentTitle((_b2 = (_a3 = jQuery("#top").text().split(/\s{3,}/)) == null ? void 0 : _a3[0]) == null ? void 0 : _b2.trim());
    let metaInfo = jQuery("td.rowhead:contains('\u57FA\u672C\u4FE1\u606F'), td.rowhead:contains('\u57FA\u672C\u8CC7\u8A0A'),.layui-table td:contains('\u57FA\u672C\u4FE1\u606F')").next().text().replace(/:/g, ":");
    let subtitle = jQuery("td.rowhead:contains('\u526F\u6807\u9898'), td.rowhead:contains('\u526F\u6A19\u984C')").next().text();
    let siteImdbUrl = jQuery("#kimdb>a").attr("href");
    let descriptionBBCode = getFilterBBCode(jQuery("#kdescr")[0]);
    descriptionBBCode = descriptionBBCode.replace(/\u00A0\u3000/g, " ");
    if (CURRENT_SITE_NAME === "MTeam") {
      descriptionBBCode = descriptionBBCode.replace(/https:\/\/\w+?\.m-team\.cc\/imagecache.php\?url=/g, "").replace(/(http(s)?)%3A/g, "$1:").replace(/%2F/g, "/");
    }
    if (CURRENT_SITE_NAME === "HDArea") {
      title = (_d = (_c = jQuery("h1#top").text().split(/\s{3,}/)) == null ? void 0 : _c[0]) == null ? void 0 : _d.trim();
    }
    if (CURRENT_SITE_NAME === "SSD") {
      title = formatTorrentTitle(jQuery("#torrent-name").text());
    }
    if (CURRENT_SITE_NAME === "PuTao") {
      title = formatTorrentTitle((_e = jQuery("h1").text().replace(/\[.+?\]|\(.+?\)/g, "")) == null ? void 0 : _e.trim());
    }
    if (CURRENT_SITE_NAME === "TJUPT") {
      const matchArray = title.match(/\[[^\]]+(\.|\s)+[^\]]+\]/g) || [];
      const realTitle = (_g = (_f = matchArray.filter((item) => item.match(/\.| /))) == null ? void 0 : _f[0]) != null ? _g : "";
      title = realTitle.replace(/\[|\]/g, "");
    }
    if (CURRENT_SITE_NAME === "PTer") {
      if (jQuery("#descrcopyandpaster")[0]) {
        descriptionBBCode = (_h = jQuery("#descrcopyandpaster").val()) == null ? void 0 : _h.replace(/hide(=(MediaInfo|BDInfo))?\]/ig, "quote]");
      } else {
        descriptionBBCode = getFilterBBCode(jQuery("#kdescr")[0]);
      }
      descriptionBBCode = descriptionBBCode.replace(/\[img\d\]/g, "[img]");
    }
    if (CURRENT_SITE_NAME === "HDChina") {
      const meta = [];
      jQuery("li:contains('\u57FA\u672C\u4FE1\u606F'):last").next("li").children("i").each(function() {
        meta.push(jQuery(this).text().replace("\uFF1A", ":"));
      });
      metaInfo = meta.join("\xA0\xA0\xA0");
      subtitle = jQuery("#top").next("h3").text();
    }
    if (CURRENT_SITE_NAME === "OurBits") {
      siteImdbUrl = jQuery(".imdbnew2 a:first").attr("href");
      TORRENT_INFO.doubanUrl = jQuery("#doubaninfo .doubannew a").attr("href");
      if (TORRENT_INFO.doubanUrl) {
        const doubanInfo = getFilterBBCode((_i = jQuery(".doubannew2 .doubaninfo")) == null ? void 0 : _i[0]);
        const doubanPoster = `[img]${jQuery("#doubaninfo .doubannew a img").attr("src")}[/img]
`;
        TORRENT_INFO.doubanInfo = doubanPoster + doubanInfo;
      }
    }
    if (CURRENT_SITE_NAME === "KEEPFRDS") {
      [title, subtitle] = [subtitle, title];
      siteImdbUrl = jQuery("#kimdb .imdbwp__link").attr("href");
      TORRENT_INFO.doubanUrl = jQuery("#kdouban .imdbwp__link").attr("href");
      const element = document.createElement("div");
      jQuery(element).html(jQuery("#outer td").has("#kdescr").html());
      descriptionBBCode = getFilterBBCode(element);
      descriptionBBCode = descriptionBBCode.replace("  [url=", "\n  [url=").replace(/\[\/img\]\[\/url\]\n/g, "[/img][/url]");
      const mediainfo = jQuery("div.codemain > pre:contains('Unique ID')");
      if (mediainfo[0]) {
        mediainfo.each(function() {
          var _a4;
          (_a4 = TORRENT_INFO.mediaInfos) == null ? void 0 : _a4.push(jQuery(this).text());
        });
      }
      descriptionBBCode = descriptionBBCode.replace(/ 截图对比\(点击空白处展开\)/g, "\u622A\u56FE\u5BF9\u6BD4");
      const comparisonArray = jQuery("fieldset[onclick]").toArray() || [];
      const comparisons = [];
      comparisonArray.forEach((item) => {
        const imgs = [];
        jQuery(item).find("a").toArray().forEach((img) => {
          if (img.href) imgs.push(img.href);
        });
        const title2 = jQuery(item).find("legend").text().replace(" \u622A\u56FE\u5BF9\u6BD4(\u70B9\u51FB\u7A7A\u767D\u5904\u5C55\u5F00):", "").trim();
        const reason = "";
        comparisons.push({
          title: title2,
          imgs,
          reason
        });
      });
      TORRENT_INFO.comparisons = comparisons;
      if (!descriptionBBCode.match("\u8C46\u74E3\u8BC4\u5206")) {
        const imdbRate = jQuery("#kimdb span.imdbwp__rating").text().replace("\nRating: ", "");
        const doubanInfo = jQuery("#kdouban .imdbwp__content").text().replace(/\n{2,}/g, "\n").replace(/\n[0-9]?[0-9]\.[0-9]\n/g, "\n").replace(/\n/g, "\n\u25CE").replace(/\n◎$/, "\n").replace("\u25CERating:", `\u25CEIMDb\u94FE\u63A5:${siteImdbUrl}
\u25CEIMDb\u8BC4\u5206: ${imdbRate}
\u25CE\u8C46\u74E3\u94FE\u63A5: ${TORRENT_INFO.doubanUrl}
\u25CE\u8C46\u74E3\u8BC4\u5206:`);
        const postUrl = (_k = (_j = jQuery("#kimdb img.imdbwp__img")) == null ? void 0 : _j.attr("src")) != null ? _k : "";
        const doubanPoster = postUrl ? `[img]${postUrl}[/img]
` : "";
        TORRENT_INFO.doubanInfo = doubanPoster + doubanInfo || "";
      }
      descriptionBBCode = descriptionBBCode.replace(/\[quote\]GeneralVideo[^[]*\[\/quote\]/, "");
    }
    if (CURRENT_SITE_NAME === "SSD") {
      TORRENT_INFO.doubanUrl = jQuery(".douban_info a:contains('://movie.douban.com/subject/')").attr("href");
      const doubanInfo = getFilterBBCode((_l = jQuery(".douban-info artical")) == null ? void 0 : _l[0]);
      const postUrl = (_n = (_m = jQuery("#kposter").find("img")) == null ? void 0 : _m.attr("src")) != null ? _n : "";
      const doubanPoster = postUrl ? `[img]${postUrl}[/img]
` : "";
      TORRENT_INFO.doubanInfo = doubanPoster + (doubanInfo == null ? void 0 : doubanInfo.replace(/\n{2,}/g, "\n")) || "";
      if (descriptionBBCode === "" || descriptionBBCode === void 0) {
        let extraTextInfo = getFilterBBCode((_o = jQuery(".torrent-extra-text-container .extra-text")) == null ? void 0 : _o[0]);
        extraTextInfo = extraTextInfo ? `
[quote]${extraTextInfo}[/quote]
` : "";
        const extraScreenshotDom = jQuery(".screenshot").find("img");
        const imgs = [];
        if (extraScreenshotDom) {
          extraScreenshotDom.each((index, item) => {
            var _a4, _b3;
            imgs.push(`[img]${(_b3 = (_a4 = jQuery(item).attr("src")) == null ? void 0 : _a4.trim()) != null ? _b3 : ""}[/img]`);
          });
        }
        const extraScreenshot = imgs.join("");
        const mediaInfo = jQuery("section[data-group='mediainfo'] .codemain").text();
        const extraMediaInfo = `
[quote]${mediaInfo}[/quote]
`;
        TORRENT_INFO.mediaInfos = [mediaInfo];
        descriptionBBCode = extraTextInfo + extraMediaInfo + extraScreenshot;
      }
      siteImdbUrl = jQuery(".douban_info a:contains('://www.imdb.com/title/')").attr("href");
    }
    if (CURRENT_SITE_NAME === "HaresClub") {
      subtitle = jQuery("h3.layui-font-16:first").text();
      const extraScreenshotDom = jQuery("#layer-photos-demo").find("img");
      const imgs = [];
      if (extraScreenshotDom) {
        extraScreenshotDom.each((index, item) => {
          var _a4, _b3;
          imgs.push(`[img]${(_b3 = (_a4 = jQuery(item).attr("src")) == null ? void 0 : _a4.trim()) != null ? _b3 : ""}[/img]`);
        });
      }
      const extraScreenshot = imgs.join("");
      descriptionBBCode = getFilterBBCode(jQuery(".layui-colla-content:first")[0]);
      const extraMediaInfo = (_q = (_p = jQuery("#kfmedia").html()) == null ? void 0 : _p.replace(/<br>/g, "\n")) != null ? _q : "";
      descriptionBBCode = `${descriptionBBCode}
[quote]${extraMediaInfo}[/quote]
${extraScreenshot}`;
      TORRENT_INFO.doubanUrl = jQuery('.layui-interval a[href*="douban.com/subject"]').attr("href");
      TORRENT_INFO.mediaInfos = [extraMediaInfo];
      siteImdbUrl = jQuery('.layui-interval a[href*="imdb.com/title"]').attr("href");
    }
    const year = (_r = title == null ? void 0 : title.match(/(19|20)\d{2}/g)) != null ? _r : [];
    const { category, videoType, videoCodec, audioCodec, resolution, processing, size } = getMetaInfo(metaInfo);
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const doubanUrl = (_s = descriptionBBCode.match(/https:\/\/((movie|book)\.)?douban\.com\/subject\/\d+/)) == null ? void 0 : _s[0];
    if (doubanUrl) {
      TORRENT_INFO.doubanUrl = doubanUrl;
    }
    const imdbUrl = (_t = descriptionBBCode.match(/http(s)?:\/\/www\.imdb\.com\/title\/tt\d+/)) == null ? void 0 : _t[0];
    if (imdbUrl) {
      TORRENT_INFO.imdbUrl = imdbUrl;
    } else if (siteImdbUrl) {
      TORRENT_INFO.imdbUrl = siteImdbUrl.match(/www\.imdb\.com\/title/) ? siteImdbUrl : "";
    }
    TORRENT_INFO.year = year.length > 0 ? year.pop() : "";
    TORRENT_INFO.title = title;
    TORRENT_INFO.subtitle = subtitle;
    TORRENT_INFO.description = descriptionBBCode;
    const originalName = (_v = (_u = descriptionBBCode.match(/(片\s+名)\s+(.+)?/)) == null ? void 0 : _u[2]) != null ? _v : "";
    const translateName = (_x = (_w = descriptionBBCode.match(/(译\s+名)\s+(.+)/)) == null ? void 0 : _w[2]) != null ? _x : "";
    if (!originalName.match(/[\u4e00-\u9fa5]+/)) {
      TORRENT_INFO.movieName = originalName;
    } else {
      TORRENT_INFO.movieName = (_A = (_z = (_y = translateName.match(/(\w|\s){2,}/)) == null ? void 0 : _y[0]) == null ? void 0 : _z.trim()) != null ? _A : "";
    }
    const fullInformation = jQuery("#top").text() + subtitle + descriptionBBCode;
    const isForbidden = fullInformation.match(/禁转|禁轉|严禁转载|嚴禁轉載|谢绝转载|謝絕轉載|exclusive/);
    TORRENT_INFO.isForbidden = !!isForbidden;
    if (!processing || processing.match(/raw|encode/)) {
      const areaMatch = (_B = descriptionBBCode.match(/(产\s*地|国\s*家|地\s*区)】?\s*(.+)/)) == null ? void 0 : _B[2];
      if (areaMatch) {
        TORRENT_INFO.area = getAreaCode(areaMatch);
      }
    } else {
      TORRENT_INFO.area = getAreaCode(processing);
    }
    const specificCategory = getPreciseCategory(TORRENT_INFO, getCategory2(category || descriptionBBCode));
    TORRENT_INFO.category = specificCategory;
    TORRENT_INFO.videoType = getVideoType5(videoType || TORRENT_INFO.title);
    TORRENT_INFO.source = getSourceFromTitle(TORRENT_INFO.title);
    TORRENT_INFO.size = size ? getSize(size) : 0;
    if (CURRENT_SITE_NAME === "KEEPFRDS") {
      TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode.replace(/\[quote\]截图对比[^\n]*\n[^\n]*/gi, ""));
    } else TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
    const tags = getTagsFromSubtitle(TORRENT_INFO.subtitle);
    const pageTags = getTagsFromPage();
    TORRENT_INFO.tags = __spreadValues(__spreadValues({}, tags), pageTags);
    if (!TORRENT_INFO.isForbidden && TORRENT_INFO.tags.exclusive) {
      TORRENT_INFO.isForbidden = true;
    }
    const infoFromMediaInfoinfo = getInfoFromMediaInfo((_C = TORRENT_INFO.mediaInfos) == null ? void 0 : _C[0]);
    if (infoFromMediaInfoinfo.subtitles) {
      for (let i3 = 0; i3 < ((_D = infoFromMediaInfoinfo.subtitles) == null ? void 0 : _D.length); i3++) {
        if (/Chinese|Traditional|Simplified|Cantonese|Mandarin/i.test(infoFromMediaInfoinfo.subtitles[i3])) {
          TORRENT_INFO.tags.chinese_subtitle = true;
          break;
        }
      }
    }
    TORRENT_INFO.videoCodec = getVideoCodecFromTitle(TORRENT_INFO.title || videoCodec, TORRENT_INFO.videoType);
    TORRENT_INFO.resolution = getResolution3(resolution || TORRENT_INFO.title);
    TORRENT_INFO.audioCodec = getAudioCodecFromTitle(audioCodec || TORRENT_INFO.title);
    const isBluray = !!TORRENT_INFO.videoType.match(/bluray/i);
    if (TORRENT_INFO.mediaInfos.length === 0) {
      getSpecsFromMediainfo2(isBluray);
    } else {
      const { bdinfo, mediaInfo } = getBDInfoOrMediaInfo(descriptionBBCode);
      const mediaInfoOrBDInfo = isBluray ? bdinfo : mediaInfo;
      if (mediaInfoOrBDInfo) {
        TORRENT_INFO.mediaInfos = CURRENT_SITE_NAME === "HaresClub" ? mediaInfoOrBDInfo : mediaInfoOrBDInfo;
        getSpecsFromMediainfo2(isBluray);
      }
    }
    if (CURRENT_SITE_NAME === "TCCF") {
      TORRENT_INFO.format = getFormat2(videoType);
    } else {
      TORRENT_INFO.format = getFormat2(jQuery("#top").text() + subtitle);
    }
  };
  var getMetaInfo = (metaInfo) => {
    let resolutionKey = "\u5206\u8FA8\u7387|\u89E3\u6790\u5EA6|\u683C\u5F0F";
    let videoTypeKey = "\u5A92\u4ECB|\u6765\u6E90|\u8D28\u91CF";
    if (CURRENT_SITE_NAME === "SSD") {
      resolutionKey = "\u5206\u8FA8\u7387|\u89E3\u6790\u5EA6";
      videoTypeKey = "\u683C\u5F0F";
    }
    if (CURRENT_SITE_NAME === "KEEPFRDS") {
      videoTypeKey = "encode";
    }
    if (CURRENT_SITE_NAME.match(/TLF|HDHome/i)) {
      videoTypeKey = "\u5A92\u4ECB";
    }
    if (CURRENT_SITE_NAME.match(/HDFans/)) {
      videoTypeKey = "\u6765\u6E90";
    }
    const category = getMetaValue("\u7C7B\u578B|\u5206\u7C7B|\u985E\u5225", metaInfo);
    const videoType = getMetaValue(videoTypeKey, metaInfo);
    const videoCodec = getMetaValue("\u7F16\u7801|\u7DE8\u78BC", metaInfo);
    const audioCodec = getMetaValue("\u97F3\u9891|\u97F3\u9891\u7F16\u7801", metaInfo);
    const resolution = getMetaValue(resolutionKey, metaInfo);
    const processing = getMetaValue("\u5904\u7406|\u8655\u7406|\u5730\u533A", metaInfo);
    const size = getMetaValue("\u5927\u5C0F", metaInfo);
    console.log({
      category,
      videoType,
      videoCodec,
      audioCodec,
      resolution,
      processing,
      size
    });
    return {
      category,
      videoType,
      videoCodec,
      audioCodec,
      resolution,
      processing,
      size
    };
  };
  var getMetaValue = (key, metaInfo) => {
    var _a3, _b2;
    let regStr = `(${key}):\\s?([^\u4E00-\u9FA5]+)?`;
    if (key.match(/大小/)) {
      regStr = `(${key}):\\s?((\\d|\\.)+\\s+(G|M|T|K)(i)?B)`;
    }
    if (CURRENT_SITE_NAME.match(/KEEPFRDS|TJUPT|PTSBAO|PTHome|HDTime|BTSCHOOL|TLF|SoulVoice|PuTao/) && key.match(/类型/)) {
      regStr = `(${key}):\\s?([^\\s]+)?`;
    }
    if (CURRENT_SITE_NAME === "PTer" && key.match(/类型|地区/)) {
      regStr = `(${key}):\\s?([^\\s]+)?`;
    }
    if (CURRENT_SITE_NAME === "TCCF" && key.match(/类型/)) {
      regStr = `(${key}):(.+?)\\s{2,}`;
    }
    if (CURRENT_SITE_NAME === "HDFans" && key.match(/来源/)) {
      regStr = `(${key}):(.+?)\\s{2,}`;
    }
    if (CURRENT_SITE_NAME === "HDChina" && key.match(/类型/)) {
      regStr = `(${key}):.+?([^\u4E00-\u9FA5]+)`;
    }
    const reg = new RegExp(regStr, "i");
    const matchValue = (_b2 = (_a3 = metaInfo.match(reg)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
    if (matchValue) {
      return matchValue.replace(/\s/g, "").trim().toLowerCase();
    }
    return "";
  };
  var getTagsFromPage = () => {
    let tags = {};
    if (CURRENT_SITE_NAME === "PTer") {
      const tagImgs = jQuery("td.rowhead:contains('\u7C7B\u522B\u4E0E\u6807\u7B7E')").next().find("img");
      const links = Array.from(tagImgs.map((index, item) => {
        var _a3, _b2;
        return (_b2 = (_a3 = jQuery(item).attr("src")) == null ? void 0 : _a3.replace(/(lang\/chs\/)|(\.gif)/g, "")) != null ? _b2 : "";
      }));
      if (links.includes("pter-zz")) {
        tags.chinese_subtitle = true;
      }
      if (links.includes("pter-gy")) {
        tags.chinese_audio = true;
      }
      if (links.includes("pter-yy")) {
        tags.cantonese_audio = true;
      }
      if (links.includes("pter-diy")) {
        tags.diy = true;
      }
    } else {
      const tagText = jQuery("td.rowhead:contains('\u6807\u7B7E')").next().text();
      tags = getTagsFromSubtitle(tagText);
    }
    return tags;
  };
  function getSpecsFromMediainfo2(isBluray) {
    var _a3, _b2;
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, resolution, mediaTags } = getInfoFunc((_b2 = (_a3 = TORRENT_INFO.mediaInfos) == null ? void 0 : _a3[0]) != null ? _b2 : "");
    if (videoCodec !== "" && audioCodec !== "" && resolution !== "") {
      TORRENT_INFO.videoCodec = videoCodec;
      TORRENT_INFO.audioCodec = audioCodec;
      TORRENT_INFO.resolution = resolution || "";
      TORRENT_INFO.tags = __spreadValues(__spreadValues({}, TORRENT_INFO.tags), mediaTags);
    }
  }

  // src/source/hdt.ts
  init_preact_shim();
  var hdt_default = async () => {
    var _a3, _b2, _c, _d, _e, _f;
    const title = document.title.replace(/HD-Torrents.org\s*-/ig, "").trim();
    const imdbInfoDom = jQuery("#IMDBDetailsInfoHideShowTR .imdbnew2");
    const imdbUlrDom = imdbInfoDom.find(">a");
    const imdbUrl = imdbUlrDom.attr("href") || "";
    const movieName = imdbUlrDom.text();
    const year = (_b2 = (_a3 = imdbInfoDom.text().match(/Year:\s*(\d{4})/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    const country = (_d = (_c = imdbInfoDom.text().match(/Country:\s*([^\n]+)/)) == null ? void 0 : _c[1]) != null ? _d : "";
    const { Category, Size, Genre } = getBasicInfo4();
    let tags = getTagsFromSubtitle(title);
    let category = Category.toLowerCase().split(/\s|\//)[0];
    category = Genre.match(/Animation/i) ? "cartoon" : category;
    const videoType = getVideoType6(Category, title);
    const source = getSourceFromTitle(title);
    let resolution = (_f = (_e = title.match(/\d{3,4}(p|i)/i)) == null ? void 0 : _e[0]) != null ? _f : "";
    if (!resolution && (resolution == null ? void 0 : resolution.match(/4k|uhd/i))) {
      resolution = "2160p";
    }
    TORRENT_INFO.videoCodec = getVideoCodecFromTitle(title);
    TORRENT_INFO.audioCodec = getAudioCodecFromTitle(title);
    const descriptionDom = jQuery("#technicalInfoHideShowTR");
    let descriptionBBCode = getFilterBBCode(descriptionDom[0]);
    descriptionBBCode = descriptionBBCode.replace(/\[center\]((?:.|\n)+?)\[\/center\]/g, (match, p1) => {
      if (p1.match(/(keep seeding)|(spank your ass)/)) {
        return "";
      }
      return match;
    });
    const isBluray = videoType.match(/bluray/i);
    const { bdinfo, mediaInfo } = getBDInfoOrMediaInfo(descriptionBBCode);
    const mediaInfoOrBDInfo = isBluray ? bdinfo : mediaInfo;
    if (mediaInfoOrBDInfo) {
      TORRENT_INFO.mediaInfos = mediaInfoOrBDInfo;
      const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
      const { videoCodec, audioCodec, resolution: mediaResolution, mediaTags } = getInfoFunc(mediaInfoOrBDInfo == null ? void 0 : mediaInfoOrBDInfo[0]);
      if (videoCodec !== "" && audioCodec !== "" && resolution !== "") {
        TORRENT_INFO.videoCodec = videoCodec;
        TORRENT_INFO.audioCodec = audioCodec;
        resolution = mediaResolution || "";
        tags = __spreadValues(__spreadValues({}, tags), mediaTags);
      }
    }
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    TORRENT_INFO.title = formatTorrentTitle(title);
    TORRENT_INFO.year = year;
    TORRENT_INFO.movieName = movieName;
    TORRENT_INFO.source = source;
    TORRENT_INFO.area = getAreaCode(country);
    TORRENT_INFO.size = getSize(Size);
    TORRENT_INFO.videoType = videoType;
    TORRENT_INFO.resolution = resolution;
    TORRENT_INFO.tags = tags;
    TORRENT_INFO.imdbUrl = imdbUrl;
    TORRENT_INFO.description = descriptionBBCode;
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
    TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
  };
  var getBasicInfo4 = () => {
    const basicInfo = {
      Category: "",
      Size: "",
      Title: "",
      Genre: ""
    };
    jQuery(".detailsleft").each((index, element) => {
      const key = jQuery(element).text().replace(/:/g, "").trim();
      const value = jQuery(element).next("td").text();
      if (value) {
        basicInfo[key] = value.replace(/\n/g, "").trim();
      }
    });
    return basicInfo;
  };
  var getVideoType6 = (type, title) => {
    if (type.match(/Remux/i)) {
      return "remux";
    } else if (type.match(/UHD\/Blu-Ray/i)) {
      return "uhdbluray";
    } else if (type.match(/Blu-Ray/i)) {
      return "bluray";
    }
    if (title.match(/HDTV/i)) {
      return "hdtv";
    } else if (title.match(/web(-)*(dl|rip)/i)) {
      return "web";
    } else if (title.match(/dvdrip/i)) {
      return "dvdrip";
    } else if (title.match(/x264|x265/i)) {
      return "encode";
    }
    return "";
  };

  // src/source/kg.ts
  init_preact_shim();
  var kg_default2 = async () => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j;
    const {
      InternetLink,
      Year,
      Type,
      Genres,
      Source,
      Size,
      Filename = "",
      RipSpecs = "",
      Subtitles,
      "Language(s)": language
    } = getBasicInfo5();
    const torrentFileDom = getBasicInfoDom("Download").find("a.index");
    const torrentFileName = torrentFileDom.text().replace(/\.torrent$/, "");
    const fileName = Filename.replace(/\.\w+$/, "");
    const title = formatTorrentTitle(fileName || torrentFileName);
    const imdbUrl = (InternetLink == null ? void 0 : InternetLink.match(/imdb/)) ? InternetLink : "";
    const [movieName, movieAkaName = ""] = (_a3 = jQuery(".outer h1").text().split("- ")) == null ? void 0 : _a3[1].replace(/\(\d+\)/, "").trim().split(/AKA/i);
    const country = jQuery(".outer h1 img").attr("alt") || "";
    const year = Year;
    const size = (_c = (_b2 = Size.match(/\((.+?)\)/)) == null ? void 0 : _b2[1].replace(/,|(bytes)/g, "")) != null ? _c : "";
    let tags = getTagsFromSubtitle(title);
    if (Subtitles.match(/Chinese/i)) {
      tags.chinese_subtitle = true;
    }
    if (language.match(/Chinese|Mandarin/i)) {
      tags.chinese_audio = true;
    }
    if (language.match(/Cantonese/)) {
      tags.cantonese_audio = true;
    }
    let category = Type.toLowerCase();
    category = Genres.match(/Animation/i) ? "cartoon" : category;
    const mediaInfo = jQuery("div.mediainfo").text();
    let source = Source.replace(/-/g, "").toLowerCase();
    if (source === "tv") {
      source = "hdtv";
    }
    let genreVideoType = (_f = (_e = (_d = getBasicInfoDom("Genres").find("tr td>img").attr("src")) == null ? void 0 : _d.match(/genreimages\/(\w+)\.\w+/)) == null ? void 0 : _e[1]) != null ? _f : "";
    genreVideoType = RipSpecs.match(/DVD\sFormat/) ? "dvdr" : genreVideoType;
    const videoType = getVideoType7(title, source, genreVideoType, !!mediaInfo);
    let resolution = (_h = (_g = title.match(/\d{3,4}(p|i)/i)) == null ? void 0 : _g[0]) != null ? _h : "";
    if (!resolution && resolution.match(/4k|uhd/i)) {
      resolution = "2160p";
    }
    TORRENT_INFO.videoCodec = getVideoCodecFromTitle(title);
    TORRENT_INFO.audioCodec = getAudioCodecFromTitle(title);
    if (genreVideoType === "dvdr" && RipSpecs) {
      TORRENT_INFO.videoCodec = "mpeg2";
      const audioCodec = (_j = (_i = RipSpecs.match(/DVD\sAudio:(.+)/)) == null ? void 0 : _i[1]) != null ? _j : "";
      TORRENT_INFO.audioCodec = getAudioCodecFromTitle(audioCodec);
      resolution = "480p";
    }
    const descriptionDom = getBasicInfoDom("Description");
    let descriptionBBCode = getFilterBBCode(descriptionDom.find("article")[0]);
    descriptionBBCode = descriptionBBCode.replace(/(.|\n)+?_{5,}/g, "");
    const isBluray = videoType.match(/bluray/i);
    const { bdinfo } = getBDInfoOrMediaInfo(descriptionBBCode);
    const mediaInfoOrBDInfo = isBluray ? bdinfo : [mediaInfo];
    if (mediaInfoOrBDInfo) {
      TORRENT_INFO.mediaInfos = mediaInfoOrBDInfo;
      const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
      const { videoCodec, audioCodec, resolution: mediaResolution, mediaTags } = getInfoFunc(mediaInfoOrBDInfo == null ? void 0 : mediaInfoOrBDInfo[0]);
      if (videoCodec !== "" && audioCodec !== "" && mediaResolution !== "") {
        TORRENT_INFO.videoCodec = videoCodec;
        TORRENT_INFO.audioCodec = audioCodec;
        resolution = mediaResolution || "";
        tags = __spreadValues(__spreadValues({}, tags), mediaTags);
      }
    }
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    TORRENT_INFO.title = formatTorrentTitle(title);
    TORRENT_INFO.year = year;
    TORRENT_INFO.movieName = movieName.trim();
    TORRENT_INFO.movieAkaName = movieAkaName.trim();
    TORRENT_INFO.source = source;
    TORRENT_INFO.size = Number(size);
    TORRENT_INFO.videoType = videoType;
    TORRENT_INFO.resolution = resolution;
    TORRENT_INFO.tags = tags;
    TORRENT_INFO.imdbUrl = imdbUrl;
    TORRENT_INFO.area = getAreaCode(country);
    TORRENT_INFO.description = descriptionBBCode;
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
    TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
  };
  var getBasicInfo5 = () => {
    const basicInfo = {};
    jQuery(".outer h1~table:first>tbody>tr").each((index, element) => {
      const key = jQuery(element).find("td.heading").text().replace(/\s/g, "");
      const value = jQuery(element).find("td.heading").next("td").text();
      if (value) {
        basicInfo[key] = value.replace(/\n/g, "").trim();
      }
    });
    return basicInfo;
  };
  var getVideoType7 = (title, source, genreVideoType, hasMediainfo) => {
    if (source) {
      if (source === "bluray") {
        const blurayFlag = genreVideoType === "bluray" || !hasMediainfo;
        return blurayFlag ? "bluray" : "encode";
      } else if (source === "dvd") {
        const dvdFlag = genreVideoType === "dvdr" || !hasMediainfo;
        return dvdFlag ? "dvd" : "dvdrip";
      }
      return source;
    }
    if (title.match(/UHD/i) && title.match(/Blu-Ray/i)) {
      return "uhdbluray";
    } else if (title.match(/Blu-Ray/i)) {
      return "bluray";
    } else if (title.match(/HDTV/i)) {
      return "hdtv";
    } else if (title.match(/web(-)*(dl|rip)/i)) {
      return "web";
    } else if (title.match(/dvdrip/i)) {
      return "dvdrip";
    } else if (title.match(/x264|x265/i)) {
      return "encode";
    }
    return "";
  };
  var getBasicInfoDom = (key) => {
    return jQuery(`.outer h1~table:first>tbody>tr td:contains(${key})`).next("td");
  };

  // src/source/uhd.ts
  init_preact_shim();
  var uhd_default = async () => {
    var _a3, _b2, _c, _d, _e, _f;
    const torrentId = getUrlParam("torrentid");
    if (!torrentId) {
      return false;
    }
    const torrentFilePathDom = jQuery(`#files_${torrentId} .filelist_path`);
    const torrentFileDom = jQuery(`#files_${torrentId} .filelist_table>tbody>tr:nth-child(2) td`).eq(0);
    const torrentFileName = ((_a3 = torrentFilePathDom.text()) == null ? void 0 : _a3.replace(/\//g, "")) || ((_b2 = torrentFileDom.text()) == null ? void 0 : _b2.replace(/\.(mkv|mp4|avi|mpg|ts|iso)$/i, ""));
    const title = formatTorrentTitle(torrentFileName);
    const imdbUrl = jQuery(".imovie_title .tooltip.imdb_icon").attr("href") || "";
    const titleText = jQuery("#scontent h2").text();
    const [movieName = "", movieAkaName = ""] = (_d = (_c = titleText.match(/(.+?)\[/)) == null ? void 0 : _c[1].split("/")) != null ? _d : [];
    const year = (_f = (_e = titleText.match(/\[(\d+)\]/)) == null ? void 0 : _e[1]) != null ? _f : "";
    const torrentLink = jQuery(`#torrent${torrentId}`).find('a[href*="action=download"]').attr("href");
    CURRENT_SITE_INFO.torrentLink = torrentLink;
    let tags = getTagsFromSubtitle(title);
    const source = getSourceFromTitle(title);
    const category = title.match(/Season\s+\d+/) ? "tv" : "movie";
    const size = getSize(jQuery(`#torrent${torrentId} td`).eq(1).text());
    const infoArray = jQuery(`#torrent${torrentId} td:first-child>a`).text().replace(/\s/g, "").split("/");
    let [resolution, ...specArray] = infoArray;
    let videoType = specArray.join("|");
    videoType = getVideoType8(videoType, resolution);
    TORRENT_INFO.videoCodec = getVideoCodecFromTitle(title);
    TORRENT_INFO.audioCodec = getAudioCodecFromTitle(title);
    const descriptionDom = jQuery(`#torrent_${torrentId} #description`);
    let descriptionBBCode = getFilterBBCode(descriptionDom[0]);
    descriptionBBCode = descriptionBBCode.replace(/https?:\/\/anonym\.to\/\?/g, "");
    TORRENT_INFO.originalDescription = descriptionBBCode;
    getMediaInfo2(torrentId).then(async (data) => {
      if (data) {
        TORRENT_INFO.mediaInfos = [data];
        TORRENT_INFO.description = `${descriptionBBCode}
[quote]${data}[/quote]`;
        TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
        TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
        const isBluray = data.match(/\.(iso|m2ts|mpls)/i);
        const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
        const { videoCodec, audioCodec, mediaTags, resolution: mediaResolution } = getInfoFunc(data);
        if (resolution === "mHD" && mediaResolution) {
          resolution = mediaResolution;
        }
        if (videoCodec !== "" && audioCodec !== "") {
          TORRENT_INFO.videoCodec = videoCodec;
          TORRENT_INFO.audioCodec = audioCodec;
          tags = __spreadValues(__spreadValues({}, tags), mediaTags);
        }
      }
      TORRENT_INFO.tags = tags;
      TORRENT_INFO.resolution = resolution;
    });
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    TORRENT_INFO.title = title;
    TORRENT_INFO.year = year;
    TORRENT_INFO.movieName = movieName.trim();
    TORRENT_INFO.movieAkaName = movieAkaName.trim();
    TORRENT_INFO.source = source;
    TORRENT_INFO.size = size;
    TORRENT_INFO.imdbUrl = imdbUrl;
    TORRENT_INFO.videoType = videoType;
  };
  var getMediaInfo2 = async (torrentId) => {
    const url = `/torrents.php?action=mediainfo&id=${torrentId}`;
    const data = await fetch(url, {
      responseType: void 0
    });
    return data || "";
  };
  var getVideoType8 = (videoType, resolution) => {
    videoType = videoType.replace("-", "").toLowerCase();
    if (videoType.match(/bluray/)) {
      if (resolution === "2160p") {
        return "uhdbluray";
      }
      return "bluray";
    } else if (videoType.match(/web/)) {
      return "web";
    } else if (videoType.match(/x264|x265/)) {
      return "encode";
    } else if (videoType.match(/WEB/i)) {
      return "web";
    }
    return videoType;
  };

  // src/source/btn.ts
  init_preact_shim();
  var btn_default = async () => {
    const torrentId = getUrlParam("torrentid");
    if (!torrentId) {
      return false;
    }
    const torrentInfo2 = getTorrentInfo(torrentId);
    const showInfo = await getShowInfo();
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    Object.assign(TORRENT_INFO, torrentInfo2);
    Object.assign(TORRENT_INFO, showInfo);
    return TORRENT_INFO;
  };
  function getTorrentInfo(torrentId) {
    var _a3, _b2, _c;
    const torrentName = jQuery(`#torrent_${torrentId}`).prev().find("> td").text().replace(/»/, "").trim();
    const { container, source, size } = getSpecs(torrentId);
    const seasonTitle = jQuery("#content > div > h2").contents().last().text().trim();
    const [season = "", year = ""] = (_b2 = (_a3 = seasonTitle == null ? void 0 : seasonTitle.match(/(.*) \[(\d+)\]/)) == null ? void 0 : _a3.slice(1)) != null ? _b2 : [];
    const movieName = (_c = jQuery("#content > div > h2 > a > img").attr("alt")) == null ? void 0 : _c.replace(/\(\d+\)/, "").trim();
    const description = getFilterBBCode(jQuery(`#torrent_${torrentId} > td > blockquote`).last()[0]);
    const videoType = getVideoType9({ torrentName, source });
    const isBluray = videoType.match(/bluray/i);
    const mediaInfoOrBDInfo = getBDInfoOrMediaInfo(description);
    const mediaInfos = isBluray ? mediaInfoOrBDInfo.bdinfo : mediaInfoOrBDInfo.mediaInfo;
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { resolution, videoCodec, audioCodec, mediaTags: tags } = getInfoFunc(mediaInfos == null ? void 0 : mediaInfos[0]);
    const category = getCategory3(season);
    const sourceFrom = getSourceFromTitle(torrentName);
    const torrentLink = jQuery(`#torrent_${torrentId}`).prev().prev().find('a[title="Download"]').attr("href");
    CURRENT_SITE_INFO.torrentLink = torrentLink;
    return {
      title: formatTorrentTitle(torrentName),
      format: container.toLowerCase(),
      source: sourceFrom,
      size: getSize(size),
      resolution,
      year,
      movieName,
      description,
      videoType,
      mediaInfos,
      videoCodec,
      audioCodec,
      tags,
      category
    };
  }
  async function getShowInfo() {
    var _a3;
    const seriesUrl = jQuery("#content > .thin > h2 > a").prop("href");
    const html = await fetch(seriesUrl, {
      responseType: void 0
    });
    const infoHtml = html.match(/Series Info[\s\S]*?(<ul[\s\S]+?<\/ul>)/)[1];
    const infoDom = new DOMParser().parseFromString(infoHtml, "text/html");
    const info = Object.fromEntries(Array.from(infoDom.querySelectorAll("tr")).map((tr) => {
      const tds = Array.from(tr.children);
      return [tds[0].innerText.trim(), tds[1]];
    }));
    const country = info["Country:"].innerText;
    const imdbUrl = (_a3 = info["External Links:"].innerHTML.match(/https:\/\/www\.imdb\.com\/title\/tt\d+/)) == null ? void 0 : _a3[0];
    return {
      area: getAreaCode(country),
      imdbUrl
    };
  }
  var getVideoType9 = ({ torrentName = "", source = "" }) => {
    if (torrentName.match(/remux/i)) {
      return "remux";
    } else if (["BD50", "BD25"].includes(source)) {
      return "bluray";
    } else if (["BD66", "BD100"].includes(source)) {
      return "uhdbluray";
    } else if (["WEB-DL"].includes(source)) {
      return "web";
    } else if (["HDTV"].includes(source)) {
      return "encode";
    }
    return "";
  };
  function getCategory3(season) {
    return season.match(/season/i) ? "tvPack" : "tv";
  }
  function getSpecs(torrentId) {
    const specsDom = jQuery(`#torrent_${torrentId}`).prev().prev();
    const rawSpecs = specsDom.find("> td > a").text().replace(/»/, "").split("/").map((v3) => v3.trim());
    const specs = rawSpecs.filter((v3) => !["NFO"].includes(v3));
    const size = specsDom.find("> td").next("td").text().replace(/\s/g, "");
    const [container, videoCodec, source, resolution, group] = specs;
    return {
      container,
      videoCodec,
      source,
      resolution,
      group,
      size
    };
  }

  // src/source/avistaz.ts
  init_preact_shim();
  var avistaz_default = async () => {
    const torrentInfo2 = await getTorrentInfo2();
    torrentInfo2.category = getPreciseCategory(torrentInfo2, torrentInfo2.category);
    Object.assign(TORRENT_INFO, torrentInfo2);
  };
  var getTorrentInfo2 = async () => {
    var _a3, _b2, _c, _d, _e;
    const imdbUrl = (_c = (_b2 = (_a3 = jQuery('.badge-extra a[href*="www.imdb.com/title"]').attr("href")) == null ? void 0 : _a3.split("?")) == null ? void 0 : _b2[1]) != null ? _c : "";
    const movieTitle = jQuery(".block-titled h3 a").text();
    const movieName = movieTitle.split("(")[0].trim();
    const year = (_e = (_d = movieTitle.match(/\((\d+)\)/)) == null ? void 0 : _d[1]) != null ? _e : "";
    let { Type, "File Size": size, Title, "Video Quality": resolution, "Rip Type": videoType } = getBasicInfo6();
    const category = Type == null ? void 0 : Type.toLowerCase().replace("-", "");
    const title = formatTorrentTitle(Title);
    videoType = getVideoType10(videoType, resolution);
    const country = jQuery(".fa-flag~.badge-extra:first a").text();
    const area = getAreaCode(country);
    const source = getSourceFromTitle(title);
    const tags = getTagsFromSubtitle(title);
    const mediaInfoOrBDInfo = jQuery("#collapseMediaInfo pre").text();
    const screenshotsBBCode = jQuery("#collapseScreens a").map(function() {
      return `[url=${jQuery(this).attr("href")}][img]${jQuery(this).find("img").attr("src")}[/img][/url]`;
    }).get();
    const screenshots = await getScreenshotsFromBBCode(screenshotsBBCode.join("\n"));
    const isBluray = videoType.match(/bluray/i);
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, mediaTags } = getInfoFunc(mediaInfoOrBDInfo);
    const descriptionBBCode = getFilterBBCode(jQuery(".torrent-desc")[0]);
    const description = `${descriptionBBCode}

[quote]${mediaInfoOrBDInfo}[/quote]

${screenshotsBBCode.join("")}`;
    return {
      sourceSite: CURRENT_SITE_NAME,
      sourceSiteType: CURRENT_SITE_INFO.siteType,
      title,
      imdbUrl,
      movieName,
      year,
      size: getSize(size),
      category,
      videoType,
      resolution,
      area,
      source,
      videoCodec,
      audioCodec,
      screenshots,
      mediaInfos: [mediaInfoOrBDInfo],
      description,
      tags: __spreadValues(__spreadValues({}, tags), mediaTags)
    };
  };
  var getBasicInfo6 = () => {
    const basicInfo = {
      Type: "",
      "File Size": "",
      Title: "",
      "Video Quality": "",
      resolution: "",
      "Rip Type": ""
    };
    jQuery("#content-area .block:last table:first>tbody>tr").each((index, element) => {
      const key = jQuery(element).find("td:first").text();
      const value = jQuery(element).find("td:last").text();
      basicInfo[key] = value.replace(/\n/g, "").trim();
    });
    return basicInfo;
  };
  var getVideoType10 = (type, resolution) => {
    if (type.match(/Remux/i)) {
      return "remux";
    } else if (type.match(/BluRay\s*Raw/i)) {
      if (resolution === "2160p") {
        return "uhdbluray";
      }
      return "bluray";
    } else if (type.match(/HDTV/i)) {
      return "hdtv";
    } else if (type.match(/web(-)*(dl|rip)/i)) {
      return "web";
    } else if (type.match(/dvdrip/i)) {
      return "dvdrip";
    } else if (type.match(/DVD/)) {
      return "dvd";
    } else if (type.match(/rip/i)) {
      return "encode";
    }
    return "";
  };

  // src/source/teamhd.ts
  init_preact_shim();
  var teamhd_default = async () => {
    const torrentInfo2 = await getTorrentInfo3();
    torrentInfo2.category = getPreciseCategory(torrentInfo2, torrentInfo2.category);
    try {
      let { movieName = "", year } = torrentInfo2;
      movieName = movieName.toLowerCase().replace(/\s/g, "_");
      const url = `https://v2.sg.media-imdb.com/suggestion/${movieName[0]}/${movieName}_${year}.json`;
      const imdbSearch = await fetch(url);
      if (imdbSearch && imdbSearch.d.length) {
        torrentInfo2.imdbUrl = `https://www.imdb.com/title/${imdbSearch.d[0].id}`;
      }
    } catch (error) {
      console.log(error);
    }
    Object.assign(TORRENT_INFO, torrentInfo2);
  };
  var getTorrentInfo3 = async () => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l;
    const basicInfoText = jQuery(".download").text().replace(/.+?\//g, "").trim();
    const year = (_b2 = (_a3 = basicInfoText.match(/\((\d{4})\)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    const movieName = (_d = (_c = basicInfoText.match(/(.+)\(\d{4}\)/)) == null ? void 0 : _c[1].trim()) != null ? _d : "";
    const resolution = (_f = (_e = basicInfoText.match(/(\s*(\d+(p|i)))$/i)) == null ? void 0 : _e[2]) != null ? _f : "";
    const videoType = getVideoType11(basicInfoText, resolution);
    const size = getSize((_h = (_g = jQuery("#details_hop").text().match(/-\s*(.+?GB)/)) == null ? void 0 : _g[1]) != null ? _h : "");
    const category = getCategory4(jQuery('#details_hop a[href*="browse/cat"]').attr("href") || "");
    const fileName = (_l = (_k = (_j = (_i = jQuery(".download").attr("href")) == null ? void 0 : _i.match(/name=(.+)/)) == null ? void 0 : _j[1].replace(/\.torrent/g, "")) == null ? void 0 : _k.replace(/\.(mkv|mp4|avi|mpg|ts|iso)$/i, "")) != null ? _l : "";
    const title = formatTorrentTitle(fileName);
    const source = getSourceFromTitle(title);
    const tags = getTagsFromSubtitle(title);
    const isBluray = videoType.match(/bluray/i);
    const mediaInfo = jQuery('.card-header:contains("MediaInfo") + .card-collapse .card-body').text();
    const bdInfo = jQuery('.card-header:contains("BDInfo") + .card-collapse .card-body').text();
    const eacLogs = jQuery('.card-header:contains("eac3to Log") + .card-collapse .card-body').text();
    const mediaInfoOrBDInfo = isBluray ? bdInfo : mediaInfo;
    const screenshotsBBCode = jQuery('#details a[href*="teamhd.org/redirector.php"]').map(function() {
      var _a4;
      const url = (_a4 = jQuery(this).attr("href")) == null ? void 0 : _a4.replace(/.+?url=/g, "");
      return `[url=${url}][img]${jQuery(this).find("img").attr("src")}[/img][/url]`;
    }).get();
    const screenshots = await getScreenshotsFromBBCode(screenshotsBBCode.join("\n"));
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, mediaTags } = getInfoFunc(mediaInfoOrBDInfo);
    const description = `[quote]${eacLogs}[/quote]

[quote]${mediaInfoOrBDInfo}[/quote]

${screenshotsBBCode.join("")}`;
    return {
      sourceSite: CURRENT_SITE_NAME,
      sourceSiteType: CURRENT_SITE_INFO.siteType,
      title,
      movieName,
      year,
      size,
      category,
      videoType,
      resolution,
      source,
      videoCodec,
      audioCodec,
      screenshots,
      mediaInfos: [mediaInfoOrBDInfo],
      description,
      tags: __spreadValues(__spreadValues({}, tags), mediaTags),
      imdbUrl: ""
    };
  };
  var getCategory4 = (link) => {
    var _a3, _b2;
    const catNum = (_b2 = (_a3 = link == null ? void 0 : link.match(/cat(\d+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    const map = {
      29: "movie",
      25: "cartoon",
      28: "document",
      31: "sport",
      32: "tv",
      33: "tvPack"
    };
    return map[parseInt(catNum, 10)] || "";
  };
  var getVideoType11 = (type, resolution) => {
    if (type.match(/Remux/i)) {
      return "remux";
    } else if (type.match(/Blu-Ray.+?Disc/i)) {
      if (resolution === "2160p") {
        return "uhdbluray";
      }
      return "bluray";
    } else if (type.match(/HDTV/i)) {
      return "hdtv";
    } else if (type.match(/web(-)*(dl|rip)/i)) {
      return "web";
    } else if (type.match(/rip/i)) {
      return "encode";
    }
    return "";
  };

  // src/source/hdspace.ts
  init_preact_shim();
  var hdspace_default = async () => {
    var _a3, _b2, _c, _d, _e, _f;
    const { Name, Category, Size, Description } = getBasicInfo7();
    const title = formatTorrentTitle(Name);
    let tags = getTagsFromSubtitle(title);
    const category = getCategory5(Category, title);
    let resolution = (_a3 = title.match(/\d{3,4}(p|i)/i)) == null ? void 0 : _a3[0];
    if (!resolution && title.match(/4k|uhd/i)) {
      resolution = "2160p";
    }
    const videoType = getVideoType12(Category, title);
    const source = getSourceFromTitle(title);
    TORRENT_INFO.videoCodec = getVideoCodecFromTitle(title);
    TORRENT_INFO.audioCodec = getAudioCodecFromTitle(title);
    const div = document.createElement("div");
    div.innerHTML = Description.html();
    jQuery(div).find('#slidenfo,a[href*="#nfo"]').remove();
    const descriptionBBCode = getFilterBBCode(div);
    const isBluray = videoType.match(/bluray/i);
    const { bdinfo, mediaInfo } = getBDInfoOrMediaInfo(descriptionBBCode);
    const mediaInfoOrBDInfo = isBluray ? bdinfo : mediaInfo;
    if (mediaInfoOrBDInfo) {
      TORRENT_INFO.mediaInfos = mediaInfoOrBDInfo;
      const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
      const { videoCodec, audioCodec, resolution: mediaResolution, mediaTags } = getInfoFunc(mediaInfoOrBDInfo == null ? void 0 : mediaInfoOrBDInfo[0]);
      if (videoCodec !== "" && audioCodec !== "" && resolution !== "") {
        TORRENT_INFO.videoCodec = videoCodec;
        TORRENT_INFO.audioCodec = audioCodec;
        resolution = mediaResolution;
        tags = __spreadValues(__spreadValues({}, tags), mediaTags);
      }
    }
    const imdbId = (_d = (_c = (_b2 = jQuery("#imdb").next("script").text()) == null ? void 0 : _b2.match(/mid=(\d+)/)) == null ? void 0 : _c[1]) != null ? _d : "";
    const imdbData = await fetch(`${CURRENT_SITE_INFO.url}/getimdb.php?mid=${imdbId}`, {
      responseType: void 0
    });
    const imdbDom = new DOMParser().parseFromString(imdbData, "text/html");
    const imdbUlrDom = jQuery('a[href*="imdb.com/title"]', imdbDom);
    const imdbUrl = imdbUlrDom.attr("href");
    const movieName = imdbUlrDom.text().replace(/\(\d+\)/g, "");
    const year = (_f = (_e = imdbUlrDom.text().match(/\((\d{4})\)/)) == null ? void 0 : _e[1]) != null ? _f : "";
    const country = jQuery('td:contains("Country")', imdbDom).next("td").text();
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    TORRENT_INFO.title = formatTorrentTitle(title);
    TORRENT_INFO.year = year;
    TORRENT_INFO.movieName = movieName;
    TORRENT_INFO.source = source;
    TORRENT_INFO.size = getSize(Size);
    TORRENT_INFO.videoType = videoType;
    TORRENT_INFO.resolution = resolution || "";
    TORRENT_INFO.area = getAreaCode(country);
    TORRENT_INFO.tags = tags;
    TORRENT_INFO.imdbUrl = imdbUrl || "";
    TORRENT_INFO.description = descriptionBBCode;
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
    TORRENT_INFO.screenshots = await getScreenshotsFromBBCode(descriptionBBCode);
  };
  var getBasicInfo7 = () => {
    const basicInfo = {
      Name: "",
      Category: "",
      Size: "",
      Description: jQuery("")
    };
    jQuery("#mcol .header").each(function() {
      var _a3;
      const key = jQuery(this).text().trim();
      if (!basicInfo[key]) {
        if (key === "Description") {
          basicInfo.Description = jQuery(this).next("td");
        } else {
          basicInfo[key] = (_a3 = jQuery(this).next("td").text()) == null ? void 0 : _a3.replace(/\n/g, "").trim();
        }
      }
    });
    return basicInfo;
  };
  var getCategory5 = (cat, title) => {
    if (cat.match(/movie/i)) {
      return "movie";
    } else if (cat.match(/hdtv/i)) {
      return "tv";
    } else if (cat.match(/doc/i)) {
      return "documentary";
    } else if (cat.match(/Animation/i)) {
      return "cartoon";
    } else if (cat.match(/Music\sVideos/i)) {
      return "concert";
    } else if (title.match(/S\d+(E\d+)?/i)) {
      return "tv";
    }
    return "movie";
  };
  var getVideoType12 = (type, title) => {
    if (type.match(/Remux/i)) {
      return "remux";
    } else if (type.match(/Blu-Ray/i) && title.match(/2160p|4k|uhd/i)) {
      return "uhdbluray";
    } else if (type.match(/Blu-Ray/i)) {
      return "bluray";
    }
    if (title.match(/HDTV/i)) {
      return "hdtv";
    } else if (title.match(/blu-ray/i) && title.match(/2160p|4k|uhd/i)) {
      return "uhdbluray";
    } else if (title.match(/web(-)*(dl|rip)/i)) {
      return "web";
    } else if (title.match(/x264|x265/i)) {
      return "encode";
    }
    return "";
  };

  // src/source/gpw.ts
  init_preact_shim();
  var gpw_default2 = async () => {
    const torrentId = getUrlParam("torrentid");
    if (!torrentId) {
      return false;
    }
    const data = await getTorrentInfo4(torrentId);
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    Object.assign(TORRENT_INFO, data);
  };
  var getTorrentInfo4 = async (torrentId) => {
    const { response } = await fetch(`/ajax.php?action=torrent&id=${torrentId}`);
    const { torrent, group } = response;
    const { name: movieName, year, conver: poster, releaseType, region, imdbId, doubanId } = group;
    const imdbUrl = `https://www.imdb.com/title${imdbId}`;
    const doubanUrl = `https://movie.douban.com/subject/${doubanId}`;
    const area = getAreaCode(region);
    let { description, fileList, filePath, size, source, resolution, processing, container, mediainfos, remasterTitle } = torrent;
    fileList = fileList.replace(/\.\w+?{{{\d+}}}/g, "");
    const title = formatTorrentTitle(filePath.replace(/\[.+\]/g, "") || fileList);
    const category = getCategory6(releaseType);
    const torrentHeaderDom = jQuery(`#torrent${torrentId}`);
    const infoArray = remasterTitle.split(" / ");
    const isRemux = processing.includes("Remux");
    const videoType = source === "WEB" ? "web" : getVideoType13(container, isRemux, source, resolution, processing);
    source = getSource2(source, processing, resolution);
    const tags = getTags2(infoArray);
    const torrentLink = torrentHeaderDom.find('a[href*="action=download"]').attr("href");
    CURRENT_SITE_INFO.torrentLink = torrentLink;
    const torrentDom = jQuery(`#torrent${torrentId}`).next(".TableTorrent-rowDetail");
    const screenshots = getScreenshots(torrentDom);
    const mediaInfoArray = mediainfos.map((info) => info.replace(/\r\n/g, "\n"));
    const isBluray = videoType.match(/bluray/i);
    const mediaInfoOrBDInfo = mediaInfoArray.filter((media) => {
      return videoType.match(/bluray/) ? media.match(/mpls/i) : !media.match(/mpls/i);
    });
    const mediaInfos = mediaInfoOrBDInfo.map((v3) => v3.trim());
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { videoCodec, audioCodec, mediaTags } = getInfoFunc(mediaInfoOrBDInfo.join("\n\n"));
    const descriptionData = formatDescriptionData2(description, screenshots, mediaInfoArray);
    return {
      sourceSite: CURRENT_SITE_NAME,
      sourceSiteType: CURRENT_SITE_INFO.siteType,
      title,
      imdbUrl,
      doubanUrl,
      movieName,
      year,
      size,
      category,
      poster,
      videoType,
      resolution,
      area,
      source,
      videoCodec,
      audioCodec,
      screenshots,
      mediaInfos,
      description: descriptionData,
      tags: __spreadValues(__spreadValues({}, tags), mediaTags)
    };
  };
  var getCategory6 = (releaseType) => {
    const typeMap = {
      \u957F\u7247: "movie",
      \u77ED\u7247: "movie",
      \u5355\u53E3\u559C\u5267: "other",
      \u8FF7\u4F60\u5267: "tvPack",
      \u73B0\u573A\u6F14\u51FA: "concert",
      \u7535\u5F71\u96C6: "movie"
    };
    return typeMap[releaseType];
  };
  var getScreenshots = (torrentDom) => {
    var _a3;
    const imgList = [];
    const imageDom = torrentDom.find(".scale_image");
    for (let i3 = 0; i3 < imageDom.length; i3++) {
      const parent = imageDom[i3].parentElement;
      if ((parent == null ? void 0 : parent.tagName) === "A" && ((_a3 = parent == null ? void 0 : parent.getAttribute("href")) == null ? void 0 : _a3.match(/\.png$/))) {
        imgList.push(parent.getAttribute("href") || "");
      } else {
        imgList.push(imageDom[i3].getAttribute("src") || "");
      }
    }
    return imgList;
  };
  var getSource2 = (source, codes, resolution) => {
    if (codes.match(/BD100|BD66/i)) {
      return "uhdbluray";
    }
    if (source.match(/Blu-ray/i) && resolution.match(/2160P|4K/i)) {
      return "uhdbluray";
    }
    return source.replace(/-/g, "").toLowerCase();
  };
  var getVideoType13 = (container, isRemux, source, resolution, processing) => {
    let type = "";
    if (isRemux) {
      type = "remux";
    } else if (processing.match(/DIY/ig)) {
      type = resolution === "2160p" ? "uhdbluray" : "bluray";
    } else if (processing.match(/BD50|BD25/ig)) {
      type = "bluray";
    } else if (processing.match(/BD66|BD100/ig) || source.match(/Blu-ray/i) && processing.match(/DIY/i)) {
      type = "uhdbluray";
    } else if (source.match(/DVD/ig) && container.match(/MKV|AVI/ig)) {
      type = "dvdrip";
    } else if (processing.match(/DVD5|DVD9/ig) && container.match(/VOB|ISO/ig)) {
      type = "dvd";
    } else if (container.match(/MKV|MP4/i)) {
      type = "encode";
    }
    return type;
  };
  var formatDescriptionData2 = (data, screenshots, mediaInfoArray) => {
    const element = document.createElement("span");
    element.innerHTML = data;
    let descriptionData = element.textContent || "";
    descriptionData = descriptionData == null ? void 0 : descriptionData.replace(/\r\n/g, "\n");
    descriptionData = descriptionData.split("\n").map((line) => {
      return line.trim();
    }).join("\n");
    TORRENT_INFO.originalDescription = descriptionData;
    screenshots.forEach((screenshot) => {
      const regStr = new RegExp(`\\[img\\]${screenshot}\\[\\/img\\]`, "i");
      if (!descriptionData.match(regStr)) {
        descriptionData = descriptionData.replace(new RegExp(screenshot, "g"), `[img]${screenshot}[/img]`);
      }
    });
    descriptionData = descriptionData.replace(/\[(\/)?hide(?:=(.+?))?\]/g, (match, p1, p22) => {
      const slash = p1 || "";
      return p22 ? `${p22}: [${slash}quote]` : `[${slash}quote]`;
    });
    descriptionData = descriptionData.replace(/\[(\/)?pre\]/g, "[$1quote]");
    descriptionData = descriptionData.replace(/\[align(=(.+?))\]((.|\n)+?)\[\/align\]/g, "[$2]$3[/$2]");
    const comparisonArray = descriptionData.match(/(\n.+\n)?\[comparison=(?:.+?)\]((.|\n)+?)\[\/comparison\]/ig) || [];
    const comparisons = [];
    comparisonArray.forEach((item) => {
      var _a3, _b2, _c, _d;
      descriptionData = descriptionData.replace(item, item.replace(/\s/g, ""));
      const reason = (_b2 = (_a3 = item.match(/(\n.*\n)?\[comparison=/i)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
      const title = (_d = (_c = item.match(/\[comparison=(.*?)\]/i)) == null ? void 0 : _c[1]) != null ? _d : "";
      const comparisonImgArray = item.replace(/\[\/?comparison(=(.+?))?\]/ig, "").split(/[ \r\n]/);
      const imgs = [];
      Array.from(new Set(comparisonImgArray)).forEach((item2) => {
        const formatImg = item2.replace(/\s*/g, "");
        if (item2.match(/^https?.+/)) {
          imgs.push(formatImg);
          descriptionData = descriptionData.replace(new RegExp(`(?<!(\\[img\\]))${item2}`, "gi"), `[img]${formatImg}[/img]`);
        } else if (item2.match(/^\[img\]/i)) {
          imgs.push(formatImg.replace(/\[\/?img\]/g, ""));
        }
      });
      comparisons.push({
        title,
        imgs,
        reason
      });
    });
    TORRENT_INFO.comparisons = comparisons;
    descriptionData = descriptionData.replace(/\[comparison=(.+?)\]/ig, "\n[b]$1 Comparison:[/b]\n").replace(/\[\/comparison\]/ig, "");
    mediaInfoArray.forEach((mediaInfo) => {
      descriptionData += `[quote]${mediaInfo}[/quote]`;
    });
    if (TORRENT_INFO.category === "concert") {
      descriptionData = `${jQuery("#synopsis").text()}
${descriptionData}`;
    }
    return descriptionData;
  };
  function getTags2(rawTags) {
    const knownTags = {};
    for (const rawTag of rawTags) {
      knownTags[rawTag] = true;
    }
    return knownTags;
  }

  // src/source/emp.ts
  init_preact_shim();
  var emp_default = async () => {
    const torrentId = getUrlParam("id");
    if (!torrentId) {
      return false;
    }
    const title = jQuery("#content > .details > h2").text().trim();
    const descriptionBBCode = getFilterBBCode(jQuery(`#content${torrentId}`)[0]);
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    TORRENT_INFO.title = title;
    TORRENT_INFO.description = descriptionBBCode.replace(/\[color=#ffffff\]/g, "[color=#000]").replace(/\n\n*/g, "\n");
  };

  // src/source/bdc.ts
  init_preact_shim();
  var bdc_default2 = async () => {
    const torrentInfo2 = await getTorrentInfo5();
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = PT_SITE.Bdc.siteType;
    const imdbInfo = getIMDBInfo();
    Object.assign(TORRENT_INFO, torrentInfo2, imdbInfo);
    return TORRENT_INFO;
  };
  async function getTorrentInfo5() {
    var _a3, _b2;
    const containerDom = jQuery(".yui-content #details");
    const torrentName = containerDom.find(">table>tbody>tr:first").text();
    const size = containerDom.find(">table:first-child>tbody>tr:nth-child(5) td:last").text();
    const isTV = (_a3 = containerDom.find(">table:first-child>tbody>tr:nth-child(4) td:last").text()) == null ? void 0 : _a3.includes("TV");
    const source = getSourceFromTitle(torrentName);
    const videoCodec = getVideoCodecFromTitle(torrentName);
    const audioCodec = getAudioCodecFromTitle(torrentName);
    const videoType = getVideoType14({ torrentName, source });
    const description = getFilterBBCode(containerDom.find("table").eq(4).find("tr:last-child td")[0]);
    const isBluray = videoType.match(/bluray/i);
    const mediaInfoOrBDInfo = getBDInfoOrMediaInfo(description);
    const mediaInfos = isBluray ? mediaInfoOrBDInfo.bdinfo : mediaInfoOrBDInfo.mediaInfo;
    const screenshots = await getScreenshotsFromBBCode(description);
    const tags = getTagsFromSubtitle(torrentName);
    const year = (_b2 = torrentName.match(/(18|19|20)\d{2}/g)) != null ? _b2 : [];
    return {
      title: formatTorrentTitle(torrentName),
      size: getSize(size),
      source,
      videoCodec,
      audioCodec,
      videoType,
      description,
      mediaInfos,
      resolution: getResolution4(torrentName),
      tags,
      screenshots,
      category: isTV ? "tv" : "movie",
      year: year.pop() || ""
    };
  }
  function getVideoType14({ torrentName = "", source = "" }) {
    if (torrentName.match(/remux/i)) {
      return "remux";
    } else if (["BD50", "BD25"].includes(source)) {
      return "bluray";
    } else if (["BD66", "BD100"].includes(source)) {
      return "uhdbluray";
    } else if (["web"].includes(source)) {
      return "web";
    } else if (["HDTV"].includes(source)) {
      return "hdtv";
    }
    return "encode";
  }
  function getResolution4(title) {
    title = title.toLowerCase();
    if (title.match(/4k|2160|UHD/ig)) {
      return "2160p";
    } else if (title.match(/1080(p)?/ig)) {
      return "1080p";
    } else if (title.match(/1080i/ig)) {
      return "1080i";
    } else if (title.match(/720(p)?/ig)) {
      return "720p";
    } else if (title.match(/sd/ig)) {
      return "480p";
    }
    return "";
  }
  function getIMDBInfo() {
    const infoDom = jQuery("#imdbdetails tr td").last();
    const imdbUrl = infoDom.find('a[href*="imdb.com/title"]').attr("href");
    const info = Object.fromEntries(Array.from(infoDom.find("b")).map((text) => {
      var _a3, _b2, _c;
      return [jQuery(text).text().replace(":", ""), (_c = (_b2 = (_a3 = jQuery(text)[0]) == null ? void 0 : _a3.nextSibling) == null ? void 0 : _b2.nodeValue) == null ? void 0 : _c.trim()];
    }));
    const movieName = jQuery("#imdbdetails tr").first().text();
    return {
      imdbUrl,
      movieName,
      area: getAreaCode(info.Country)
    };
  }

  // src/source/gazelle-music.ts
  init_preact_shim();
  var gazelle_music_default2 = async () => {
    const torrentId = getUrlParam("torrentid");
    if (!torrentId) {
      return false;
    }
    try {
      TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
      TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
      const torrentInfo2 = await getTorrentInfo6(torrentId);
      Object.assign(TORRENT_INFO, torrentInfo2);
    } catch (error) {
      console.log(error);
    }
  };
  async function getTorrentInfo6(torrentId) {
    const { response } = await fetch(`/ajax.php?action=torrent&id=${torrentId}`);
    if (response.group) {
      if (CURRENT_SITE_NAME === "DicMusic") {
        response.group.name = getUTF8String(response.group.name);
        const div2 = document.createElement("div");
        div2.innerHTML = response.group.wikiBody;
        response.group.bbBody = htmlToBBCode(div2);
      } else if (CURRENT_SITE_NAME === "Orpheus") {
        response.group.bbBody = response.group.wikiBBcode;
      }
    }
    const { torrent, group } = response;
    const { name, year, wikiImage, musicInfo, categoryName, bbBody, tags, wikiBody } = group;
    const { format, media, encoding, logScore, ripLogIds = [] } = torrent;
    const catMap = {
      Applications: "app",
      "E-Books": "ebook",
      Audiobooks: "audioBook",
      Comics: "comics",
      Music: "music",
      "E-Learning Videos": "other",
      Comedy: "other"
    };
    const div = document.createElement("div");
    div.innerHTML = wikiBody;
    let description = bbBody || htmlToBBCode(div);
    description = `[img]${wikiImage}[/img]
${description}`;
    const descSource = new DOMParser().parseFromString(description, "text/html");
    if (descSource.documentElement.textContent) {
      description = descSource.documentElement.textContent.replace(/\[\/?artist\]/g, "").replace(/\[url=https:\/\/redacted\.ch\/torrents\.php\?(taglist|recordlabel)=[a-zA-Z%0-9]*\]/g, "").replace(new RegExp("(?<=(\\[\\/b\\]|,)[\\s\\\\.a-zA-Z]*)\\[\\/url\\]", "g"), "");
    }
    const log = [];
    if (ripLogIds.length > 0) {
      for (let i3 = 1; i3 < ripLogIds.length; i3++) {
        log.push(await getLog(logScore, torrentId, ripLogIds[i3]));
      }
    } else if (media === "CD") {
      const logData = await getLog(logScore, torrentId, "0");
      if (logData) {
        log.push(logData);
      }
    }
    response.torrent.log = log;
    CURRENT_SITE_INFO.torrentLink = jQuery(`#torrent${torrentId} a[href*="action=download"]`).attr("href");
    return {
      title: jQuery(".header h2").text(),
      subtitle: `${jQuery(`#torrent${torrentId}`).prev().find("strong").contents().last().text().trim()} / ${jQuery(`#torrent${torrentId} td:first-child a[onclick*="$("]`).text()}`,
      year: `${year}`,
      poster: wikiImage,
      description,
      category: catMap[categoryName] || "other",
      audioCodec: format.toLowerCase(),
      videoType: media.toLowerCase().replace("-", ""),
      musicInfo: {
        name,
        tags,
        artists: musicInfo.artists.map((item) => item.name),
        media,
        encoding,
        log
      },
      musicJson: response
    };
  }
  function getUTF8String(entityString) {
    const tempElement = document.createElement("textarea");
    tempElement.innerHTML = entityString;
    const utf8String = tempElement.value;
    return utf8String;
  }
  async function getLog(logScore, torrentId, ripLogId) {
    let url = `/torrents.php?action=viewlog&logscore=${logScore}&torrentid=${torrentId}`;
    if (CURRENT_SITE_NAME === "RED") {
      url = `/torrents.php?action=loglist&torrentid=${torrentId}`;
    } else if (CURRENT_SITE_NAME === "Orpheus") {
      url = `/view.php?type=riplog&id=${torrentId}.${ripLogId}`;
    } else if (CURRENT_SITE_NAME === "DicMusic") {
      url = `torrents.php?action=viewlog&logscore=${logScore}&torrentid=${torrentId}`;
    }
    const response = await fetch(url, {
      responseType: void 0
    });
    if (CURRENT_SITE_NAME.match(/DicMusic|RED/)) {
      const div = document.createElement("div");
      div.innerHTML = response;
      return jQuery(div).find("pre").text() || "";
    } else if (CURRENT_SITE_NAME.match(/Orpheus|/)) {
      return response;
    }
  }

  // src/source/mtv.ts
  init_preact_shim();
  var mtv_default = async () => {
    const torrentId = getUrlParam("torrentid");
    if (!torrentId) {
      return false;
    }
    const torrentInfo2 = await getTorrentInfo7(torrentId);
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    Object.assign(TORRENT_INFO, torrentInfo2);
    return TORRENT_INFO;
  };
  async function getTorrentInfo7(torrentId) {
    var _a3, _b2;
    const imdbUrl = jQuery('.metalinks a[href*="imdb.com/title"]').attr("href");
    const torrentContainer = jQuery(`#torrent${torrentId}`);
    const [showName] = (_b2 = (_a3 = jQuery(".details>h2").text()) == null ? void 0 : _a3.split("-")) != null ? _b2 : [];
    const torrentName = torrentContainer.find(".permalink").text().trim();
    const size = torrentContainer.find(">td").eq(1).text().trim();
    const source = getSourceFromTitle(torrentName);
    const descriptionContainer = jQuery(`#content${torrentId}`).clone();
    descriptionContainer.find(">div").remove();
    const description = getFilterBBCode(descriptionContainer[0]);
    const screenshots = await getScreenshotsFromBBCode(description);
    const isBluray = !!jQuery(`#files_${torrentId}`).text().match(/\.(iso|m2ts|mpls)/i);
    const videoType = getVideoType15({ torrentName, source, isBluray });
    const mediaInfo = jQuery("div.mediainfo").text();
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { resolution, videoCodec, audioCodec, mediaTags: tags } = mediaInfo ? getInfoFunc(mediaInfo) : getSpecsFromTitle(torrentName);
    const category = getCategory7(torrentName);
    return {
      title: formatTorrentTitle(torrentName),
      imdbUrl,
      source,
      size: getSize(size),
      resolution,
      movieName: showName.replace(/\n/g, "").trim(),
      description,
      videoType,
      mediaInfos: [mediaInfo],
      videoCodec,
      audioCodec,
      tags,
      screenshots,
      category
    };
  }
  var getVideoType15 = ({ torrentName = "", source = "", isBluray = false }) => {
    if (torrentName.match(/remux/i)) {
      return "remux";
    } else if (source.match(/bluray/) && !isBluray) {
      return "encode";
    }
    return source;
  };
  function getCategory7(season) {
    return season.match(/S\d+E(P)\d+/i) ? "tv" : "tvPack";
  }
  function getSpecsFromTitle(torrentName) {
    var _a3;
    return {
      videoCodec: getVideoCodecFromTitle(torrentName),
      audioCodec: getAudioCodecFromTitle(torrentName),
      mediaTags: getTagsFromSubtitle(torrentName),
      resolution: (_a3 = torrentName.match(/\d{3,4}(p|i)/)) == null ? void 0 : _a3[0]
    };
  }

  // src/source/speedapp.ts
  init_preact_shim();
  var speedapp_default = async () => {
    TORRENT_INFO.sourceSite = CURRENT_SITE_NAME;
    TORRENT_INFO.sourceSiteType = CURRENT_SITE_INFO.siteType;
    const imdbUrl = jQuery('a[href*="imdb.com/title"]').attr("href");
    const movieName = jQuery("div.container > div.row div.cover-body h1.text-emphasis").text().trim();
    const torrentName = jQuery("h5.text-emphasis").text().trim();
    const source = getSourceFromTitle(torrentName);
    const descriptionContainer = jQuery("div.description.description-modern");
    const descriptionBBCode = getFilterBBCode(descriptionContainer[0]);
    const extraScreenshotDom = jQuery(descriptionContainer[0]).find("img");
    const imgs = [];
    if (extraScreenshotDom) {
      extraScreenshotDom.each((index, item) => {
        var _a3, _b2;
        if (!/\.svg/.test(jQuery(item).attr("src") || "")) imgs.push(`[img]${(_b2 = (_a3 = jQuery(item).attr("src")) == null ? void 0 : _a3.trim()) != null ? _b2 : ""}[/img]`);
      });
    }
    const extraScreenshot = imgs.join("");
    const screenshots = await getScreenshotsFromBBCode(extraScreenshot);
    const isBluray = !!jQuery('span.nav-text:contains("BD Info")');
    const videoType = getVideoType16({ torrentName, source, isBluray });
    const mediaInfo = jQuery("div.mediainfo").text();
    const getInfoFunc = isBluray ? getInfoFromBDInfo : getInfoFromMediaInfo;
    const { resolution, videoCodec, audioCodec } = mediaInfo ? getInfoFunc(mediaInfo) : getSpecsFromTitle2(torrentName);
    TORRENT_INFO.mediaInfos = [mediaInfo];
    TORRENT_INFO.videoCodec = videoCodec;
    TORRENT_INFO.audioCodec = audioCodec;
    TORRENT_INFO.description = descriptionBBCode.replace(/\n\n*/g, "\n").replace(/\s+/g, "").trim().replace(/\[img\]https:\/\/speedapp\.io\/img\/descr\/(screens|release_info)\.svg\[\/img\]/g, "").replace("[img]https://speedapp.io/img/descr/release_info.svg[/img]", "").replace(/original\.(png|webp)\]\n?\[img\]/g, "original.webp][img]").replace(/original\.(png|webp)\[\/img\]\n?\[\/url\]/g, "mobile.webp[/img][/url]").replace(/\[\/url\]\n*/g, "[/url]");
    TORRENT_INFO.screenshots = screenshots;
    TORRENT_INFO.title = torrentName;
    TORRENT_INFO.movieName = movieName;
    TORRENT_INFO.resolution = resolution || "";
    TORRENT_INFO.imdbUrl = imdbUrl;
    TORRENT_INFO.poster = jQuery(".movie-poster").attr("src");
    TORRENT_INFO.videoType = videoType.toLowerCase();
  };
  var getVideoType16 = ({ torrentName = "", source = "", isBluray = false }) => {
    if (torrentName.match(/remux/i)) {
      return "remux";
    } else if (source.match(/bluray/) && !isBluray) {
      return "encode";
    }
    return source;
  };
  function getSpecsFromTitle2(torrentName) {
    var _a3;
    return {
      videoCodec: getVideoCodecFromTitle(torrentName),
      audioCodec: getAudioCodecFromTitle(torrentName),
      mediaTags: getTagsFromSubtitle(torrentName),
      resolution: (_a3 = torrentName.match(/\d{3,4}(p|i)/)) == null ? void 0 : _a3[0]
    };
  }

  // src/source/hh.ts
  init_preact_shim();
  var hh_default = async () => {
    var _a3, _b2, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l;
    const title = formatTorrentTitle(((_a3 = document.title.match(/"(.+)"/)) == null ? void 0 : _a3[1]) || "");
    const subTitle = jQuery("div.font-bold.leading-6:contains('\u526F\u6807\u9898')").next().text().replace(/:/g, ":");
    const metaInfo = getMetaInfo2();
    const isBluray = !!((_b2 = metaInfo.videoType) == null ? void 0 : _b2.match(/bluray|Blu-ray/i));
    const mediaInfo = jQuery("#mediainfo-raw code").text() || "";
    const specs = getSpecsFromMediainfo(isBluray, mediaInfo);
    if (Object.keys(specs).length > 0) {
      Object.assign(metaInfo, specs);
    }
    const imbdDom = jQuery('#kimdb a[href*="imdb.com/title"]');
    const siteImdbUrl = (_c = imbdDom == null ? void 0 : imbdDom.attr("href")) != null ? _c : "";
    let movieName = (_e = (_d = imbdDom == null ? void 0 : imbdDom.text()) == null ? void 0 : _d.replace(/\n/g, "").trim()) != null ? _e : "";
    const { category, videoType, videoCodec, audioCodec, resolution, size } = metaInfo;
    const categoryResult = getCategory2(category);
    const formatSize = getSize(size);
    const year = (_f = title == null ? void 0 : title.match(/(19|20)\d{2}/g)) != null ? _f : [];
    const screenshots = jQuery("#screenshot-content img").toArray().map((el) => jQuery(el).attr("src")).filter((url) => url && url !== "");
    const doubanUrl = (_g = jQuery("#douban_info-content").prev().find('a[href*="douban.com"]').attr("href")) != null ? _g : "";
    const isTVCategory = !!categoryResult.match(/tv/);
    const doubanInfo = await getDoubanInfo(doubanUrl, isTVCategory);
    if (!movieName) {
      movieName = (_i = (_h = [doubanInfo == null ? void 0 : doubanInfo.foreignTitle].concat(doubanInfo == null ? void 0 : doubanInfo.aka).filter((name) => name == null ? void 0 : name.match(/^(\w|\s|:)+$/i))) == null ? void 0 : _h.shift()) != null ? _i : "";
    }
    let description = "";
    if (doubanInfo) {
      description += doubanInfo.format;
    }
    description += `
    [quote]${mediaInfo}[/quote]
  `;
    screenshots.forEach((url) => {
      description += `[img]${url}[/img]`;
    });
    const tags = getTagsFromPage2();
    Object.assign(TORRENT_INFO, {
      title,
      subtitle: subTitle,
      imdbUrl: siteImdbUrl || (doubanInfo == null ? void 0 : doubanInfo.imdbLink),
      description,
      year: year.length > 0 ? year.pop() : "",
      source: getSourceFromTitle(title),
      mediaInfos: [mediaInfo],
      screenshots,
      movieName,
      sourceSite: CURRENT_SITE_NAME,
      sourceSiteType: TORRENT_INFO.sourceSiteType,
      category: categoryResult,
      size: formatSize,
      tags: __spreadValues(__spreadValues({}, specs.mediaTags), tags),
      videoType: getVideoType5(videoType),
      videoCodec,
      audioCodec,
      resolution,
      doubanUrl,
      poster: (_k = (_j = jQuery("#cover-content")) == null ? void 0 : _j.attr("src")) != null ? _k : "",
      area: getAreaCode((_l = doubanInfo == null ? void 0 : doubanInfo.region) != null ? _l : "")
    });
  };
  var getMetaInfo2 = () => {
    const meta = getMetaValue2();
    const category = meta["\u7C7B\u578B"];
    const videoType = meta["\u6765\u6E90"];
    const videoCodec = meta["\u7F16\u7801"];
    const audioCodec = meta["\u97F3\u9891\u7F16\u7801"];
    const resolution = meta["\u5206\u8FA8\u7387"];
    const processing = meta["\u5904\u7406"];
    const size = meta["\u5927\u5C0F"];
    console.log({
      category,
      videoType,
      videoCodec,
      audioCodec,
      resolution,
      size
    });
    return {
      category,
      videoType,
      videoCodec,
      audioCodec,
      resolution,
      processing,
      size
    };
  };
  var getMetaValue2 = () => {
    const result = {};
    jQuery("div.font-bold.leading-6:contains('\u57FA\u672C\u4FE1\u606F')").next().find("div span").each((index, el) => {
      if (index % 2 === 0) {
        const key = jQuery(el).text().replace(/:|:/g, "").trim();
        result[key] = jQuery(el).next().text();
      }
    });
    return result;
  };
  var getTagsFromPage2 = () => {
    const tags = {};
    const tagText = jQuery("div.font-bold.leading-6:contains('\u6807\u7B7E')").next().text();
    if (tagText.includes("\u4E2D\u5B57")) {
      tags.chinese_subtitle = true;
    }
    if (tagText.includes("\u56FD\u8BED")) {
      tags.chinese_audio = true;
    }
    if (tagText.includes("\u7CA4\u8BED")) {
      tags.cantonese_audio = true;
    }
    if (tagText.includes("DIY")) {
      tags.diy = true;
    }
    if (tagText.includes("\u675C\u6BD4\u89C6\u754C")) {
      tags.dolbyVision = true;
    }
    if (tagText.includes("HDR")) {
      tags.dolbyVision = true;
    }
    return tags;
  };

  // src/source/mt.ts
  init_preact_shim();
  var MT_SPECS_MAP = {
    source: {
      8: "web",
      1: "bluray",
      3: "dvd",
      4: "hdtv",
      5: "hdtv",
      6: "other",
      7: "cd"
    },
    medium: {
      1: "bluray",
      2: "hddvd",
      3: "remux",
      7: "encode",
      4: "bluray",
      5: "hdtv",
      6: "dvd",
      8: "cd",
      10: "web"
    },
    standard: {
      1: "1080p",
      2: "1080i",
      3: "720p",
      5: "480p",
      6: "2160p"
    }
  };
  var mt_default2 = async () => {
    const originalOpen = XMLHttpRequest.prototype.open;
    XMLHttpRequest.prototype.open = function(method, url) {
      this.addEventListener("readystatechange", async function() {
        if (this.readyState === 4) {
          if (url.includes("/api/torrent/detail")) {
            const detailData = JSON.parse(this.responseText);
            if (detailData.code === "0") {
              const info = await getTorrentInfo8(detailData.data);
              Object.assign(TORRENT_INFO, info);
            }
          }
          if (url.includes("/api/torrent/imdbInfo")) {
            const imdbData = JSON.parse(this.responseText);
            if (imdbData.code === "0") {
              const imdbInfo = getMovieInfo(imdbData.data);
              Object.assign(TORRENT_INFO, imdbInfo);
            }
          }
        }
      });
      originalOpen.apply(this, arguments);
    };
  };
  var getTorrentInfo8 = async (info) => {
    var _a3, _b2;
    const { name, imdb, douban, category, source, medium, standard, size, mediainfo, descr, smallDescr } = info;
    const title = formatTorrentTitle(name);
    const year = (_a3 = title == null ? void 0 : title.match(/(19|20)\d{2}/g)) != null ? _a3 : [];
    let resolution = getResolution5(standard);
    const videoType = getVideoType17(medium, title, resolution);
    let sourceName = getSource3(source, resolution);
    if (!sourceName) {
      sourceName = getSourceFromTitle(title);
    }
    let videoCodec = getVideoCodecFromTitle(title);
    const audioCodec = getAudioCodecFromTitle(title);
    const screenshots = await getScreenshotsFromBBCode(descr);
    let mediaTags = {};
    let mediaInfoOrBDInfo = [mediainfo];
    const isBluray = !!(videoType == null ? void 0 : videoType.match(/bluray/i));
    if (!mediaInfoOrBDInfo) {
      const { bdinfo, mediaInfo } = getBDInfoOrMediaInfo(descr);
      mediaInfoOrBDInfo = isBluray ? bdinfo : mediaInfo;
    }
    if (mediaInfoOrBDInfo) {
      const infoString = mediaInfoOrBDInfo == null ? void 0 : mediaInfoOrBDInfo[0].replace(/\n{1,}/g, "\n");
      const specs = await getSpecsFromMediainfo(isBluray, infoString);
      videoCodec = specs.videoCodec ? specs.videoCodec : videoCodec;
      resolution = specs.resolution ? specs.resolution : resolution;
      mediaTags = specs.mediaTags || {};
    }
    let area = "";
    const areaMatch = (_b2 = descr.match(/(产\s*地|国\s*家|地\s*区)】?\s*(.+)/)) == null ? void 0 : _b2[2];
    if (areaMatch) {
      area = getAreaCode(areaMatch);
    }
    await getTorrentURL();
    return {
      sourceSite: CURRENT_SITE_NAME,
      sourceSiteType: CURRENT_SITE_INFO.siteType,
      subtitle: smallDescr,
      title,
      area,
      imdbUrl: imdb,
      doubanUrl: douban,
      size: parseInt(size, 10),
      category: getCategory8(category),
      videoType,
      resolution,
      source: sourceName,
      videoCodec,
      audioCodec,
      screenshots,
      mediaInfos: mediaInfoOrBDInfo,
      description: descr,
      year: year.length > 0 ? year.pop() : "",
      movieName: "",
      tags: __spreadValues({}, mediaTags)
    };
  };
  var getCategory8 = (id) => {
    const catMap = PT_SITE.MTeam.category.map;
    for (const [key, value] of Object.entries(catMap)) {
      if (value.includes(id)) {
        return key;
      }
    }
    return "";
  };
  var getSource3 = (id, resolution) => {
    const sourceName = MT_SPECS_MAP.source[id];
    if (sourceName === "bluray" && resolution === "2160p") {
      return "uhdbluray";
    }
    return sourceName;
  };
  var getResolution5 = (id) => {
    return MT_SPECS_MAP.standard[id];
  };
  var getVideoType17 = (id, title, resolution) => {
    const videoType = MT_SPECS_MAP.medium[id];
    if (videoType === "bluray" && resolution === "2160p") {
      return "uhdbluray";
    } else if (videoType === "dvd" && title.match(/dvdrip/i)) {
      return "dvdrip";
    }
    return videoType;
  };
  var getMovieInfo = (data) => {
    const { year, title, photo } = data;
    return {
      year,
      movieName: title,
      poster: photo.full || photo.thumb
    };
  };
  var getTorrentURL = async () => {
    var _a3, _b2, _c;
    const torrentId = (_b2 = (_a3 = location.pathname.match(/detail\/(\d+)/)) == null ? void 0 : _a3[1]) != null ? _b2 : "";
    if (!torrentId) {
      return "";
    }
    const formData = new FormData();
    formData.append("id", torrentId);
    const response = await fetch("https://api.m-team.cc/api/torrent/genDlToken", {
      method: "POST",
      data: formData,
      headers: {
        Authorization: localStorage.getItem("auth") || "",
        "User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10_15_7) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/125.0.0.0 Safari/537.36"
      }
    });
    CURRENT_SITE_INFO.torrentLink = (_c = response == null ? void 0 : response.data) != null ? _c : "";
  };

  // src/source/index.ts
  var siteNameMap = {
    BeyondHD: bhd_default2,
    HDBits: hdb_default,
    Cinematik: tik_default,
    TTG: ttg_default,
    HDT: hdt_default,
    KG: kg_default2,
    UHDBits: uhd_default,
    PTP: ptp_default2,
    BTN: btn_default,
    TeamHD: teamhd_default,
    HDSpace: hdspace_default,
    GPW: gpw_default2,
    EMP: emp_default,
    Bdc: bdc_default2,
    RED: gazelle_music_default2,
    DicMusic: gazelle_music_default2,
    MTV: mtv_default,
    SpeedApp: speedapp_default,
    HH: hh_default,
    MTeam: mt_default2,
    Orpheus: gazelle_music_default2
  };
  var siteTypeInfoMap = {
    NexusPHP: nexusphp_default,
    UNIT3D: unit3d_default,
    AvistaZ: avistaz_default
  };
  var getTorrentInfo9 = () => Promise.resolve();
  if (!CURRENT_SITE_INFO) {
    console.log("do nothing");
  } else if (siteNameMap[CURRENT_SITE_NAME]) {
    getTorrentInfo9 = siteNameMap[CURRENT_SITE_NAME];
  } else if (siteTypeInfoMap[CURRENT_SITE_INFO.siteType]) {
    getTorrentInfo9 = siteTypeInfoMap[CURRENT_SITE_INFO.siteType];
  }
  var source_default = getTorrentInfo9;

  // src/site-dom/quick-search.ts
  init_preact_shim();
  var filterBluTorrent = (imdb = "", name = "") => {
    if (imdb) {
      jQuery("#imdb").val(imdb);
    } else if (name) {
      jQuery("#search").val(name);
    }
    const token = jQuery('meta[name="csrf_token"]').attr("content");
    const url = `${CURRENT_SITE_INFO.url}/torrents/filter?search=${name}&imdb=${imdb}&_token=${token}&sorting=size&direction=desc`;
    fetch(url, {
      responseType: void 0
    }).then((data) => {
      jQuery("#facetedSearch").html(data);
    });
  };
  var fillSearchImdb = () => {
    const imdbParam = getUrlParam("imdb");
    const nameParam = getUrlParam("name");
    const searchType = getUrlParam("search_area");
    if (imdbParam || nameParam) {
      if (CURRENT_SITE_INFO.siteType === "UNIT3D" && CURRENT_SITE_NAME !== "Blutopia") {
        filterBluTorrent(imdbParam, nameParam);
      } else if (CURRENT_SITE_NAME === "Bdc") {
        jQuery("#tsstac").val(imdbParam);
        jQuery("#search_type").val(searchType);
      } else if (CURRENT_SITE_NAME === "PTN") {
        jQuery("#movieimdb").val(imdbParam);
        jQuery("#moviename").val(nameParam);
      }
    }
  };

  // src/site-dom/ptpimg.tsx
  init_preact_shim();
  init_preact_module();
  var _a;
  if (location.host === "ptpimg.me") {
    const ptpImgApiKey = GM_getValue("easy-seed.ptp-img-api-key") || "";
    if (!ptpImgApiKey) {
      const div = document.createElement("div");
      S(/* @__PURE__ */ e3("div", { class: "ptp-api-key-btn", children: /* @__PURE__ */ e3("button", { class: "btn btn-info", onClick: () => {
        const apiKey = jQuery("#api_key").val();
        GM_setValue("easy-seed.ptp-img-api-key", apiKey);
        Notification_default2.open({
          message: "Success!",
          description: "Saved to EasyUpload."
        });
      }, children: [
        /* @__PURE__ */ e3("i", { class: "glyphicon glyphicon-floppy-saved" }),
        /* @__PURE__ */ e3("span", { children: "Save ApiKey" })
      ] }) }), div);
      (_a = document.querySelector("#form_file_upload")) == null ? void 0 : _a.appendChild(div);
    }
  }

  // src/style.ts
  init_preact_shim();
  var style_default = GM_addStyle(`
td.title-td{
  min-width: 80px;
  vertical-align: middle !important;
}
td.title-td h4{
  text-align: right;
  margin: 0;
  font-size: 13px;
  font-weight: 500;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
#seed-dom button{
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  background: #fff;
  border: 1px solid #dcdfe6;
  color: #606266;
  -webkit-appearance: none;
  text-align: center;
  box-sizing: border-box;
  outline: none;
  transition: .1s;
  font-weight: 500;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  padding: 6px 16px;
  font-size: 13px;
  border-radius: 4px;
  margin:0;
  margin-right: 5px;
}
#seed-dom button:hover {
  background: #fff;
  border-color: #409eff;
  color: #409eff
}
#seed-dom button.is-disabled, #seed-dom button.is-disabled:hover {
  color: #c0c4cc;
  cursor: not-allowed;
  background-image: none;
  background-color: #fff;
  border-color: #ebeef5;
}
.site-list,.search-list{
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.site-list .site-icon{
  width: 12px;
  margin-right: 5px;
}
.search-list .site-icon{
  width: 12px;
  margin-right: 5px;
}
.ptp-search-list{
  display: flex;
  align-items: center;
  padding-top:10px;
  justify-content: center;
}
.ptp-search-list h4{
  margin: 0;
  min-width: 60px;
  margin-right: 15px;
}
#seed-dom li,.search-list li,.site-list li {
  font-weight: 600;
  line-height: 24px;
  margin-right: 5px;
  margin-top: 0;
  margin-bottom: 0;
  margin-left: 0;
  padding: 0px;
  display: flex;
  align-items: center;
}
#seed-dom li a,.search-list li a,.site-list li a {
  padding-right: 3px;
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}
.search-list li:last-child span{
  display: none;
}
.easy-seed-function-list{
  display: flex;
  justify-content: space-around; 
  padding: 6px 20px;
  flex-wrap: wrap;
}
.easy-seed-function-list button{
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  background: #fff;
  border: 1px solid #dcdfe6;
  color: #606266;
  -webkit-appearance: none;
  text-align: center;
  box-sizing: border-box;
  outline: none;
  transition: .1s;
  font-weight: 500;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  padding: 8px 20px;
  font-size: 14px;
  border-radius: 4px;
  margin:0;
  margin-right: 5px;
}
.easy-seed-function-list button:hover {
  background: #fff;
  border-color: #409eff;
  color: #409eff
}
.easy-seed-function-list button.is-disabled, .easy-seed-function-list button.is-disabled:hover {
  color: #c0c4cc;
  cursor: not-allowed;
  background-image: none;
  background-color: #fff;
  border-color: #ebeef5;
}
.function-list-item{
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
}
.function-list-item input{
    -webkit-appearance: none;
    background-color: #fff;
    background-image: none;
    border-radius: 4px;
    border: 1px solid #dcdfe6;
    box-sizing: border-box;
    color: #606266;
    display: inline-block;
    font-size: inherit;
    height: 34px;
    line-height: 40px;
    outline: none;
    width: 200px;
    padding: 0 12px;
    transition: border-color .2s cubic-bezier(.645,.045,.355,1);
}
.function-list-item select{
  border: 0;
  font-family: inherit;
  padding: 5px;
  font-size: 14px;
  border-radius: 3px;
  text-transform: none;
}
.function-list-item input::placeholder {
  color: #c0c4cc
}
.function-list-item input:hover {
  border-color: #c0c4cc
}
.function-list-item input:focus {
    outline: none;
    border-color: #409eff
}
.hdb-tr{
  display: flex;
}
.hdb-tr td:last-child{
  flex: 1;
}
.hdb-tr td:first-child>h4{
  width:100px;
}
.function-list-item h4{
  margin: 0;
  padding: 0;
  margin-right: 10px;
  font-weight: 600;
  font-size: 14px;
}
.upload-section,.douban-section,.douban-book-section{
  display: flex;
  justify-content: center;
  align-items: center;
}
.upload-section #nsfw{
  margin-left: 0;
  position: static;
}
.upload-section label{
  padding-left: 0;
}
#kdescr img{
  max-width: 100%;
}
.easy-seed-setting-btn{
  display: inline-flex;
  align-items: center;
  margin-left: 3px;
}
svg.setting-svg{
  height: 20px;
  width: 20px;
  vertical-align: middle;
  animation: 5s linear rotate infinite;
  cursor: pointer;
}
@keyframes rotate {
  100% {
    transform: rotate(360deg);
  };
}
.easy-seed-setting-panel{
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2000;
  background: rgba(0,0,0,0.5);
  color: #000;
}
#batch-seed-btn,#auto-fill-douban{
  border-color: transparent;
  color: #409eff;
  background: transparent;
  padding-left: 0;
  padding-right: 0;
  font-weight: 600;
  cursor: pointer;
}
#batch-seed-btn:hover,#auto-fill-douban:hover {
  color: #66b1ff;
  border-color: transparent;
  background-color: transparent
}
#batch-seed-btn:active,#auto-fill-douban:active {
  color: #3a8ee6;
  background-color: transparent
}
#auto-fill-douban{
  font-size: 14px;
  display:inline-block;
}
.easy-seed-setting-panel *{
  padding: 0;
  margin: 0;
}
.easy-seed-setting-panel input[type="text"]{
  -webkit-appearance: none;
  background-color: #fff;
  background-image: none;
  border-radius: 4px;
  border: 1px solid #dcdfe6;
  box-sizing: border-box;
  color: #606266;
  display: inline-block;
  font-size: inherit;
  height: 34px;
  line-height: 40px;
  outline: none;
  width: 200px;
  padding: 0 12px;
  transition: border-color .2s cubic-bezier(.645,.045,.355,1);
}
.easy-seed-setting-panel input[type="text"]::placeholder {
  color: #c0c4cc
}
.easy-seed-setting-panel input[type="text"]:hover {
  border-color: #c0c4cc
}
.easy-seed-setting-panel input[type="text"]:focus {
    outline: none;
    border-color: #409eff
}
.easy-seed-setting-panel h3,.easy-seed-setting-panel h1{ 
  color: #000;
  margin-bottom: 15px;
}
.easy-seed-setting-panel .panel-content-wrap{
  margin-top: 200px;
  max-width: 800px;
  box-sizing: border-box;
  margin: 50px auto;
  border-radius: 8px;
  background: #fff;
  position: relative;
  text-align:center;
  box-shadow: 0 1px 3px rgb(0 0 0 / 30%);
  padding: 20px 10px 10px 20px;
}
.easy-seed-setting-panel .panel-content{
  height: 500px;
  overflow-y: auto;
}
.easy-seed-setting-panel .panel-content ul{
  list-style: none;
  display: flex;
  flex-direction:row;
  flex-wrap: wrap;
  margin: 0 auto;
  padding: 0 10px;
}
.easy-seed-setting-panel .panel-content li{
  width: 90px;
  text-align: left;
  margin-bottom: 10px;
}
.easy-seed-setting-panel .panel-content label{
  cursor: pointer;
  color: #000 !important;
  font-size: 12px;
  display: flex;
  align-items: center;
}
.easy-seed-setting-panel .panel-content label input{
  margin: 0;
  margin-right: 3px;
  padding:0;
}
.panel-content p{
  display: block;
  margin-bottom: 10px;
  font-size: 12px;
}
.easy-seed-setting-panel button{
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
  background: #fff;
  border: 1px solid #dcdfe6;
  color: #606266;
  -webkit-appearance: none;
  text-align: center;
  box-sizing: border-box;
  outline: none;
  transition: .1s;
  font-weight: 500;
  -moz-user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  padding: 8px 20px;
  font-size: 14px;
  border-radius: 4px;
  margin:0;
  margin-right: 5px;
  margin-bottom: 10px;
}
.easy-seed-setting-panel button:hover {
  background: #fff;
  border-color: #409eff;
  color: #409eff
}
.easy-seed-setting-panel .confirm-btns {
  padding-top: 15px;
}
.easy-seed-setting-panel .img-upload-setting{
  margin-bottom: 10px;
}
.easy-seed-setting-panel .img-upload-setting label{
  justify-content: center;
}
.easy-seed-setting-panel .img-upload-setting label input{
  margin-left: 8px;
  margin-right: 8px;
}
.easy-seed-setting-panel .img-upload-setting label a{
  color: #000;
  font-weight: 500;
}
.easy-seed-setting-panel .img-upload-setting label a:hover{
  color: #f7d584;
}
.feature-list{
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 0 50px;
}
.feature-list .site-enable-setting{
  width: 250px;
  padding-top: 5px;
  margin-bottom: 8px;
  text-align: center;
}
.easy-seed-setting-panel .save-setting-btn{
  background-color: #007bff;
  border-color: #007bff;
  color:#fff;
}
.easy-seed-setting-panel .save-setting-btn:hover{
  background: #66b1ff;
  border-color: #66b1ff;
  color: #fff
}
.ptp-api-key-btn{
  text-align: center;
}
.easy-notification{
  box-sizing: border-box;
  position: fixed;
  transition: opacity .3s,transform .3s,left .3s,right .3s,top .4s,bottom .3s;
  overflow: hidden;
  right:0;
  margin: 0 24px 0 0;
  color: #000000d9;
  font-size: 14px;
  line-height: 1.5715;
  z-index: 2010;
}
.easy-notification-enter{
  right: 16px;
  transform: translateX(0);
}
.easy-notification-notice{
    position: relative;
    width: 300px;
    max-width: calc(100vw - 48px);
    margin-bottom: 16px;
    margin-left: auto;
    padding: 16px 24px;
    overflow: hidden;
    line-height: 1.5715;
    word-wrap: break-word;
    background: #fff;
    border-radius: 2px;
    box-sizing: border-box;
    box-shadow: 0 2px 12px 0 rgba(0,0,0,.1);
}
.notification-message {
  margin-bottom: 8px;
  color: #000000d9;
  font-size: 16px;
  line-height: 24px;
}

.notification-description{
  font-size: 14px;
  line-height: 21px;
  margin: 6px 0 0;
  text-align: justify;
  padding-right: 10px;
}

.notification-description p {
  margin: 0
}

.easy-notification-notice-close svg {
  height: 14px;
  width: 14px;
  font-size: 14px
}
.easy-notification-notice-close {
  position: absolute;
  top: 13px;
  right: 15px;
  cursor: pointer;
  color: #909399;
  font-size: 16px
}

.easy-notification-notice-close:hover {
  color: #606266
}
#transfer-progress{
  display: none;
}
.custom-site{
  display: flex;
  align-items: center;
  width: 100%;
}
.custom-site h4{
  flex-shrink: 0;
  margin: 0;
  line-height: initial;
  margin-right: 10px;
}
.custom-site .easy-seed-function-list{
  flex: 1;
}
.custom-site img{
  border-radius: 0px;
}
tr.pad[id*="torrent_"]{
  font-family: 'Proxima Nova','Lato','Segoe UI',sans-serif;
}
.easy-seed-function-list .copy-img{
  margin-left: 5px;
}
.quick-search{
  cursor: pointer;
  color: #409eff;
  font-weight: 600;
}
.ptp-title-wrapper{
  position: relative;
}
#seed-dom .ptp-title-wrapper h4{
  position: absolute;
  left:0;
  top: 0;
  margin: 0 !important;
  display: flex !important;
  align-items: center;
  line-height: 24px;
}
#seed-dom .ptp-title-wrapper .site-list li:first-child{
  padding: 0;
  padding-left: 95px;
}
#seed-dom .ptp-title-wrapper .search-list li:first-child{
  padding-left: 65px;
}
#seed-dom.use-eng  .ptp-title-wrapper .search-list li:first-child{
  padding-left: 85px;
}
#batch-search-btn{
  color: #409eff;
  padding-left: 0;
  padding-right: 0;
  font-weight: 600;
  cursor: pointer;
}
.douban-config {
  display: flex;
  justify-content: center;
}
.douban-config textarea{
  resize: none;
  width: 300px;
  height: 100px;
  margin-left: 6px;
}
`);

  // src/components/Container.tsx
  init_preact_shim();

  // src/components/FunctionList.tsx
  init_preact_shim();

  // src/components/Douban.tsx
  init_preact_shim();
  var getTvSeasonData2 = async (data) => {
    var _a3, _b2;
    const { title: torrentTitle } = TORRENT_INFO;
    const { season = "", title } = data;
    if (season) {
      const seasonNumber = (_b2 = (_a3 = torrentTitle.match(/S(?!eason)?0?(\d+)\.?(EP?\d+)?/i)) == null ? void 0 : _a3[1]) != null ? _b2 : "1";
      if (parseInt(seasonNumber, 10) === 1) {
        return data;
      }
      const query = title.replace(/第.+?季/, `\u7B2C${seasonNumber}\u5B63`);
      const response = await getDoubanIdByIMDB(query);
      return response;
    }
  };
  var updateTorrentInfo = (data) => {
    var _a3, _b2;
    const desc = data.format;
    TORRENT_INFO.doubanInfo = data.format;
    TORRENT_INFO.subtitle = getSubTitle(data);
    const areaMatch = (_b2 = (_a3 = desc == null ? void 0 : desc.match(/(产\s+地|国\s+家)\s+(.+)/)) == null ? void 0 : _a3[2]) != null ? _b2 : "";
    if (areaMatch) {
      TORRENT_INFO.area = getAreaCode(areaMatch);
    }
    const category = TORRENT_INFO.category;
    TORRENT_INFO.category = getPreciseCategory(TORRENT_INFO, category);
  };
  var Douban = () => {
    const [btnText, setBtnText] = d2("\u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB");
    const [bookBtnText, setBookBtnText] = d2("\u83B7\u53D6\u8C46\u74E3\u8BFB\u4E66\u7B80\u4ECB");
    const [btnDisable, setBtnDisable] = d2(false);
    const [searchValue, setSearchValue] = d2("");
    const doubanClosed = GM_getValue("easy-seed.douban-closed") || "";
    const { needDoubanBookInfo, needDoubanInfo } = CURRENT_SITE_INFO;
    const showSearch = (needDoubanBookInfo || needDoubanInfo || !TORRENT_INFO.doubanUrl) && !doubanClosed;
    const getDoubanData = async () => {
      try {
        setBtnText("\u83B7\u53D6\u4E2D...");
        setBtnDisable(true);
        const scriptDoubanLink = jQuery(".douban-dom").attr("douban-link");
        const doubanLink = jQuery(".page__title>a").attr("href") || scriptDoubanLink || TORRENT_INFO.doubanUrl || searchValue;
        let doubanUrl = "";
        if (doubanLink && doubanLink.match(/movie\.douban\.com/)) {
          doubanUrl = doubanLink;
        } else {
          const { imdbUrl, movieName } = TORRENT_INFO;
          const doubanData = await getDoubanIdByIMDB(imdbUrl || movieName);
          if (doubanData) {
            let { id, season = "" } = doubanData;
            if (season) {
              const tvData = await getTvSeasonData2(doubanData);
              if (tvData) {
                id = tvData.id;
              }
            }
            doubanUrl = `https://movie.douban.com/subject/${id}`;
          }
        }
        if (doubanUrl) {
          TORRENT_INFO.doubanUrl = doubanUrl;
          setSearchValue(doubanUrl);
          if (!TORRENT_INFO.description.match(/(片|译)\s*名/)) {
            const isTVCategory = !!TORRENT_INFO.category.match(/tv/);
            const movieData = await getDoubanInfo(doubanUrl, isTVCategory);
            if (movieData) {
              Notification_default2.open({
                message: $t("\u6210\u529F"),
                description: $t("\u83B7\u53D6\u6210\u529F")
              });
              updateTorrentInfo(movieData);
            }
          } else {
            Notification_default2.open({
              message: $t("\u6210\u529F"),
              description: $t("\u83B7\u53D6\u6210\u529F")
            });
          }
        }
      } catch (error) {
      } finally {
        setBtnText("\u83B7\u53D6\u8C46\u74E3\u7B80\u4ECB");
        setBtnDisable(false);
      }
    };
    const getBookData = () => {
      let { doubanUrl } = TORRENT_INFO;
      if (!doubanUrl) {
        doubanUrl = searchValue;
      } else {
        setSearchValue(doubanUrl);
      }
      if (doubanUrl) {
        setBookBtnText("\u83B7\u53D6\u4E2D...");
        setBtnDisable(true);
        getDoubanBookInfo(doubanUrl).then((data) => {
          if (data) {
            TORRENT_INFO.title = data.chineseTitle || data.foreignTitle;
            TORRENT_INFO.poster = data.poster;
            TORRENT_INFO.description = data.book_intro || "";
            TORRENT_INFO.doubanBookInfo = data || null;
          }
          Notification_default2.open({
            message: $t("\u6210\u529F"),
            description: $t("\u83B7\u53D6\u6210\u529F")
          });
        }).catch((error) => {
          console.log(error);
          Notification_default2.open({
            message: $t("\u9519\u8BEF"),
            description: error.message
          });
        }).finally(() => {
          setBookBtnText("\u83B7\u53D6\u8C46\u74E3\u8BFB\u4E66\u7B80\u4ECB");
          setBtnDisable(false);
        });
      } else {
        Notification_default2.open({
          message: $t("\u9519\u8BEF"),
          description: $t("\u7F3A\u5C11\u8C46\u74E3\u94FE\u63A5")
        });
      }
    };
    return showSearch ? /* @__PURE__ */ e3(d, { children: [
      /* @__PURE__ */ e3("div", { className: "function-list-item", children: /* @__PURE__ */ e3("div", { className: "douban-section", children: /* @__PURE__ */ e3(
        "input",
        {
          type: "text",
          placeholder: $t("\u624B\u52A8\u8F93\u5165\u8C46\u74E3\u94FE\u63A5"),
          value: searchValue,
          onChange: (e4) => setSearchValue(e4.target.value)
        }
      ) }) }),
      /* @__PURE__ */ e3("div", { className: "function-list-item", children: /* @__PURE__ */ e3("div", { className: "douban-section", children: [
        showSearch && CURRENT_SITE_NAME !== "SoulVoice" && /* @__PURE__ */ e3(
          "button",
          {
            id: "douban-info",
            disabled: btnDisable,
            className: btnDisable ? "is-disabled" : "",
            onClick: getDoubanData,
            children: $t(btnText)
          }
        ),
        showSearch && CURRENT_SITE_NAME === "SoulVoice" && /* @__PURE__ */ e3(
          "button",
          {
            disabled: btnDisable,
            className: btnDisable ? "is-disabled" : "",
            id: "douban-book-info",
            onClick: getBookData,
            children: $t(bookBtnText)
          }
        )
      ] }) })
    ] }) : null;
  };
  var Douban_default = Douban;

  // src/components/Transfer.tsx
  init_preact_shim();
  var Transfer = () => {
    const [imgHost, setImgHost] = d2("imgbox");
    const [btnDisable, setBtnDisable] = d2(false);
    const [btnText, setBtnText] = d2("\u8F6C\u7F29\u7565\u56FE");
    const [progress, setProgress] = d2(-1);
    const [imgList, setImgList] = d2([]);
    const getThumbnailImgs = async () => {
      var _a3, _b2, _c;
      try {
        const comparisons = TORRENT_INFO.comparisons || [];
        const allImgs = TORRENT_INFO.screenshots.concat(...comparisons.map((v3) => v3.imgs));
        const imgList2 = [...new Set(allImgs)];
        setImgList(imgList2);
        if (imgList2.length < 1) {
          throw new Error($t("\u83B7\u53D6\u56FE\u7247\u5217\u8868\u5931\u8D25"));
        }
        setBtnText("\u8F6C\u6362\u4E2D...");
        setBtnDisable(true);
        setProgress(0);
        const hostMap = {
          imgbb: "https://imgbb.com/json",
          gifyu: "https://gifyu.com/json",
          pixhost: "https://pixhost.to",
          imgbox: "https://imgbox.com",
          HDB: "https://img.hdbits.org"
        };
        const selectHost = hostMap[imgHost];
        let uploadedImgs = [];
        let authToken, tokenSecret;
        if (imgHost.match(/imgbb|gifyu/)) {
          const rawHtml = await fetch(selectHost.replace("/json", ""), {
            responseType: void 0
          });
          authToken = (_a3 = rawHtml.match(/PF\.obj\.config\.auth_token\s*=\s*"(\w+)"/)) == null ? void 0 : _a3[1];
        } else if (imgHost === "imgbox") {
          const rawHtml = await fetch("https://imgbox.com", {
            responseType: void 0
          });
          authToken = (_b2 = rawHtml.match(/content="(.+)" name="csrf-token"/)) == null ? void 0 : _b2[1];
          tokenSecret = await fetch("https://imgbox.com/ajax/token/generate", {
            responseType: "json",
            method: "POST",
            headers: {
              "X-CSRF-Token": authToken
            }
          });
        }
        if (imgHost === "HDB") {
          const imgContent = await uploadToHDB(imgList2, TORRENT_INFO.title);
          uploadedImgs = (_c = imgContent == null ? void 0 : imgContent.split("\n")) != null ? _c : [];
        } else {
          for (let index = 0; index < imgList2.length; index++) {
            let data;
            if (imgHost.match(/imgbb|gifyu/)) {
              const transferData = await transferImgs(imgList2[index], authToken, selectHost);
              data = `[url=${transferData.url}][img]${transferData.thumb.url}[/img][/url]`;
            } else if (imgHost === "pixhost") {
              const [transferData] = await uploadToPixhost([imgList2[index]]);
              data = `[url=${transferData.show_url}][img]${transferData.th_url}[/img][/url]`;
            } else if (imgHost === "imgbox") {
              const transferData = await uploadToImgbox(imgList2[index], authToken, tokenSecret);
              data = `[url=${transferData.original_url}][img]${transferData.thumbnail_url}[/img][/url]`;
            }
            if (data) {
              uploadedImgs.push(data);
              setProgress(uploadedImgs.length);
            }
          }
        }
        if (uploadedImgs.length) {
          TORRENT_INFO.screenshots = uploadedImgs.slice(0, TORRENT_INFO.screenshots.length);
          let { description } = TORRENT_INFO;
          imgList2.forEach((img, index) => {
            var _a4, _b3;
            if (img.match(/i\.hdbits\.org/)) {
              const imgId = (_b3 = (_a4 = img.match(/i\.hdbits\.org\/(.+)\./)) == null ? void 0 : _a4[1]) != null ? _b3 : "";
              const urlReg = new RegExp(`\\[url=https://img.hdbits.org/${imgId}\\].+?\\[\\/url\\]
*`, "ig");
              if (description.match(urlReg)) {
                description = description.replace(urlReg, uploadedImgs[index] || "");
              }
            } else if (description.includes(img)) {
              const urlReg = new RegExp(`\\[url=${img}\\].+?\\[\\/url\\]
*`, "ig");
              if (description.match(urlReg)) {
                description = description.replace(urlReg, uploadedImgs[index] || "");
              } else {
                description = description.replace(new RegExp(`\\[img\\]${img}\\[\\/img\\]
*`, "ig"), uploadedImgs[index] || "");
              }
            }
          });
          TORRENT_INFO.description = description;
          Notification_default2.open({
            message: $t("\u6210\u529F"),
            description: $t("\u8F6C\u6362\u6210\u529F\uFF01")
          });
        }
      } catch (error) {
        Notification_default2.open({
          message: $t("\u9519\u8BEF"),
          description: error.message
        });
      } finally {
        setBtnText("\u8F6C\u7F29\u7565\u56FE");
        setBtnDisable(false);
      }
    };
    const transferImgClosed = getValue("easy-seed.transfer-img-closed", false) || "";
    return !(transferImgClosed || CURRENT_SITE_NAME === "BTN") ? /* @__PURE__ */ e3("div", { className: "function-list-item", children: /* @__PURE__ */ e3("div", { className: "upload-section", children: [
      /* @__PURE__ */ e3(
        "button",
        {
          className: btnDisable ? "is-disabled" : "",
          onClick: getThumbnailImgs,
          disabled: btnDisable,
          children: $t(btnText)
        }
      ),
      /* @__PURE__ */ e3(
        "select",
        {
          value: imgHost,
          onChange: (e4) => setImgHost(e4.target.value),
          children: [
            /* @__PURE__ */ e3("option", { value: "imgbox", children: "imgbox" }),
            /* @__PURE__ */ e3("option", { value: "imgbb", children: "imgbb" }),
            /* @__PURE__ */ e3("option", { value: "gifyu", children: "gifyu" }),
            /* @__PURE__ */ e3("option", { value: "pixhost", children: "pixhost" }),
            /* @__PURE__ */ e3("option", { value: "HDB", children: "HDB" })
          ]
        }
      ),
      /* @__PURE__ */ e3(
        "div",
        {
          id: "transfer-progress",
          hidden: progress < 0,
          children: `${progress} / ${imgList.length}`
        }
      )
    ] }) }) : null;
  };
  var Transfer_default = Transfer;

  // src/components/UploadImg.tsx
  init_preact_shim();
  var UploadImg = () => {
    const [selectHost, setSelectHost] = d2("ptpimg");
    const [btnDisable, setBtnDisable] = d2(false);
    const [btnText, setBtnText] = d2("\u8F6C\u5B58\u622A\u56FE");
    const [canCopy, setCanCopy] = d2(false);
    const [screenBBCode, setScreenBBCode] = d2([]);
    const [copyText, setCopyText] = d2("\u62F7\u8D1D");
    const uploadScreenshotsToAnother = async () => {
      var _a3;
      const screenshots = TORRENT_INFO.screenshots;
      setBtnText("\u4E0A\u4F20\u4E2D\uFF0C\u8BF7\u7A0D\u5019...");
      setBtnDisable(true);
      try {
        setCanCopy(false);
        setCopyText("\u62F7\u8D1D");
        const imgData = [];
        if (selectHost === "ptpimg") {
          for (let index = 0; index < screenshots.length; index++) {
            const originalImg = await getOriginalImgUrl(screenshots[index]);
            const data = await saveScreenshotsToPtpimg([originalImg]);
            if (data) {
              imgData.push(data[0]);
            } else {
              return;
            }
          }
        } else {
          const gifyuHtml = await fetch("https://gifyu.com", {
            responseType: void 0
          });
          const authToken = (_a3 = gifyuHtml.match(/PF\.obj\.config\.auth_token\s*=\s*"(.+)?"/)) == null ? void 0 : _a3[1];
          for (let index = 0; index < screenshots.length; index++) {
            const originalImg = await getOriginalImgUrl(screenshots[index]);
            const data = await transferImgs(originalImg, authToken, "https://gifyu.com/json");
            if (data) {
              imgData.push(data.url);
            }
          }
        }
        if (imgData.length > 0) {
          Notification_default2.open({
            message: $t("\u6210\u529F"),
            description: ""
          });
        }
        let { description, originalDescription } = TORRENT_INFO;
        TORRENT_INFO.screenshots = imgData;
        const screenBBcodeArray = imgData.map((img) => {
          return `[img]${img}[/img]`;
        });
        setScreenBBCode(screenBBcodeArray);
        setCanCopy(true);
        const allImages = description.match(/(\[url=(http(s)*:\/{2}.+?)\])?\[img\](.+?)\[\/img](\[url\])?/ig);
        if (allImages && allImages.length > 0) {
          allImages.forEach((img) => {
            if (img.match(/\[url=.+?\]/)) {
              img += "[/url]";
            }
            originalDescription = originalDescription == null ? void 0 : originalDescription.replace(img, "");
            description = description.replace(img, "");
          });
        }
        TORRENT_INFO.originalDescription = `${originalDescription}
${screenBBcodeArray.join("")}`;
        TORRENT_INFO.description = `${description}
${screenBBcodeArray.join("")}`;
      } catch (error) {
        Notification_default2.open({
          message: $t("\u9519\u8BEF"),
          description: error.message
        });
      } finally {
        setBtnText("\u8F6C\u5B58\u622A\u56FE");
        setBtnDisable(false);
      }
    };
    const uploadImgClosed = GM_getValue("easy-seed.upload-img-closed") || "";
    return !(uploadImgClosed || CURRENT_SITE_NAME === "BTN") ? /* @__PURE__ */ e3("div", { className: "function-list-item", children: /* @__PURE__ */ e3("div", { className: "upload-section", children: [
      /* @__PURE__ */ e3(
        "button",
        {
          disabled: btnDisable,
          className: btnDisable ? "is-disabled" : "",
          onClick: uploadScreenshotsToAnother,
          children: $t(btnText)
        }
      ),
      /* @__PURE__ */ e3("select", { value: selectHost, onChange: (e4) => setSelectHost(e4.target.value), children: [
        /* @__PURE__ */ e3("option", { value: "ptpimg", children: "ptpimg" }),
        /* @__PURE__ */ e3("option", { value: "gifyu", children: "gifyu" })
      ] }),
      /* @__PURE__ */ e3(
        "button",
        {
          className: "copy-img",
          hidden: !canCopy,
          onClick: () => {
            GM_setClipboard(screenBBCode.join(""));
            setCopyText("\u5DF2\u62F7\u8D1D");
          },
          children: $t(copyText)
        }
      )
    ] }) }) : null;
  };
  var UploadImg_default = UploadImg;

  // src/components/FunctionList.tsx
  var FunctionList = () => {
    return /* @__PURE__ */ e3("section", { className: "easy-seed-function-list", children: [
      /* @__PURE__ */ e3(Douban_default, {}),
      /* @__PURE__ */ e3(Transfer_default, {}),
      /* @__PURE__ */ e3(UploadImg_default, {})
    ] });
  };
  var FunctionList_default = FunctionList;

  // src/components/SearchList.tsx
  init_preact_shim();

  // src/components/common.ts
  init_preact_shim();
  var getQuickSearchUrl = (siteName) => {
    var _a3;
    const siteInfo = PT_SITE[siteName];
    const searchConfig = siteInfo.search;
    const { params = {}, imdbOptionKey, nameOptionKey, path: path2, replaceKey } = searchConfig;
    let imdbId = getIMDBIdByUrl(TORRENT_INFO.imdbUrl);
    let searchKeyWord = "";
    const { movieAkaName, movieName, title, musicJson } = TORRENT_INFO;
    if (imdbId && !siteName.match(/(nzbs.in|HDF|TMDB|豆瓣读书|TeamHD|NPUBits)$/) && siteInfo.siteType !== "AvistaZ") {
      if (replaceKey) {
        searchKeyWord = imdbId.replace(replaceKey[0], replaceKey[1]);
      } else {
        searchKeyWord = imdbId;
      }
    } else if (CURRENT_SITE_NAME.match(/RED|DicMusic|Orpheus/)) {
      const { year = "", name = "" } = (_a3 = musicJson == null ? void 0 : musicJson.group) != null ? _a3 : {};
      searchKeyWord = `${name} ${year}`;
    } else {
      searchKeyWord = movieAkaName || movieName || title;
      imdbId = "";
    }
    let searchParams = Object.keys(params).map((key) => {
      return `${key}=${params[key]}`;
    }).join("&");
    if (imdbId) {
      searchParams = searchParams.replace(/\w+={name}&{0,1}?/, "").replace(/{imdb}/, searchKeyWord).replace(/{optionKey}/, imdbOptionKey || "");
    } else {
      if (searchParams.match(/{name}/)) {
        searchParams = searchParams.replace(/\w+={imdb}&{0,1}?/, "").replace(/{name}/, searchKeyWord);
      } else {
        searchParams = searchParams.replace(/{imdb}/, searchKeyWord);
      }
      searchParams = searchParams.replace(/{optionKey}/, nameOptionKey || "");
    }
    let url = `${siteInfo.url + path2}${searchParams ? `?${searchParams}` : ""}`;
    if (siteName.match(/nzb|TMDB|豆瓣读书|SubHD|OpenSub/)) {
      url = url.replace(/{name}/, searchKeyWord);
    }
    return url;
  };

  // src/components/SearchList.tsx
  var SearchList = () => {
    const handleSearchClickEvent = (siteName) => {
      let openUrl = "";
      const attrUrl = jQuery(`.search-list li>a[data-site="${siteName}"]`).data("url");
      if (attrUrl) {
        openUrl = attrUrl;
      } else {
        openUrl = getQuickSearchUrl(siteName);
      }
      GM_openInTab(openUrl);
    };
    const searchListSetting = getValue("easy-seed.enabled-search-site-list");
    const searchSitesEnabled = searchListSetting || [];
    const siteFaviconClosed = getValue("easy-seed.site-favicon-closed", false);
    const getSearchSites = () => {
      const commonSites = [];
      const subtitlesSites = [];
      SORTED_SITE_KEYS.forEach((siteName) => {
        const siteInfo = PT_SITE[siteName];
        if (siteInfo.search) {
          if (searchSitesEnabled.length === 0 || searchSitesEnabled.includes(siteName)) {
            if (siteInfo.siteType === "subtitles") {
              subtitlesSites.push(siteName);
            } else {
              commonSites.push(siteName);
            }
          }
        }
      });
      return {
        commonSites,
        subtitlesSites
      };
    };
    const batchSearchClick = () => {
      const { commonSites, subtitlesSites } = getSearchSites();
      [...commonSites, ...subtitlesSites].forEach((site) => {
        handleSearchClickEvent(site);
      });
    };
    return /* @__PURE__ */ e3(d, { children: ["commonSites", "subtitlesSites"].map((key, index) => {
      const siteList = getSearchSites()[key];
      return siteList.length > 0 ? /* @__PURE__ */ e3("ul", { className: "search-list", children: [
        siteList.map((siteName) => {
          const siteInfo = PT_SITE[siteName];
          const favIcon = !siteFaviconClosed && siteInfo.icon ? siteInfo.icon : "";
          return /* @__PURE__ */ e3("li", { children: [
            /* @__PURE__ */ e3(
              "a",
              {
                "data-site": siteName,
                onClick: () => handleSearchClickEvent(siteName),
                children: [
                  !!favIcon && /* @__PURE__ */ e3("img", { src: favIcon, className: "site-icon" }),
                  siteName
                ]
              }
            ),
            /* @__PURE__ */ e3("span", { children: "|" })
          ] }, siteName);
        }),
        index === 0 && /* @__PURE__ */ e3("li", { id: "batch-search-btn", onClick: batchSearchClick, title: $t("\u540C\u65F6\u6253\u5F00\u591A\u4E2A\u641C\u7D22\u6807\u7B7E\u9875"), children: $t("\u6279\u91CF\u68C0\u7D22") })
      ] }) : "";
    }) });
  };
  var SearchList_default = SearchList;

  // src/components/UploadSiteList.tsx
  init_preact_shim();
  var getPTPGroupId = async (imdbUrl) => {
    if (!imdbUrl) {
      return "";
    }
    const imdbId = getIMDBIdByUrl(imdbUrl);
    if (imdbId) {
      const url = `${PT_SITE.PTP.url}/torrents.php?searchstr=${imdbId}&grouping=0&json=noredirect`;
      const data = await fetch(url);
      if (data && data.Movies && data.Movies.length > 0) {
        return data.Movies[0].GroupId;
      }
      return "";
    }
    return "";
  };
  var openBatchSeedTabs = () => {
    const batchSeedSetting = getValue("easy-seed.enabled-batch-seed-sites") || [];
    if (batchSeedSetting.length === 0) {
      Notification_default2.open({
        message: $t("\u9519\u8BEF"),
        description: $t("\u8BF7\u5148\u8BBE\u7F6E\u7FA4\u8F6C\u5217\u8868")
      });
      return false;
    }
    SORTED_SITE_KEYS.forEach(async (siteName) => {
      const siteInfo = PT_SITE[siteName];
      const { url, uploadPath = "" } = siteInfo;
      if (siteInfo.asTarget) {
        if (batchSeedSetting.includes(siteName)) {
          if (!TORRENT_INFO.torrentData) {
            const torrentData = await getTorrentFileData(CURRENT_SITE_INFO.torrentDownloadLinkSelector, CURRENT_SITE_INFO.torrentLink);
            if (torrentData) {
              TORRENT_INFO.torrentData = torrentData;
            }
          }
          const timestamp = `${Date.now()}`;
          GM_setValue("uploadInfo", TORRENT_INFO);
          GM_openInTab(`${url + uploadPath}#timestamp=${timestamp}`);
        }
      }
    });
    Notification_default2.open({
      message: $t("\u6210\u529F"),
      description: $t("\u8F6C\u79CD\u9875\u9762\u5DF2\u6253\u5F00\uFF0C\u8BF7\u524D\u5F80\u5BF9\u5E94\u9875\u9762\u64CD\u4F5C")
    });
  };
  var getGPWGroupId = async (imdbUrl) => {
    if (!imdbUrl) {
      return "";
    }
    const imdbId = getIMDBIdByUrl(imdbUrl);
    if (imdbId) {
      const url = `${PT_SITE.GPW.url}/upload.php?action=movie_info&imdbid=${imdbId}&check_only=1`;
      const data = await fetch(url);
      if (data && data.response && data.response.GroupID) {
        return data.response.GroupID;
      }
      return "";
    }
    return "";
  };
  var UploadSiteList = () => {
    const handleSiteClickEvent = async (url) => {
      if (url.match(/hdpost|blutopia|fearnopeer|asiancinema|monikadesign|lst/)) {
        const catMap = {
          movie: "1",
          tv: "2",
          tvPack: "2",
          documentary: "1"
        };
        const path2 = catMap[TORRENT_INFO.category] || "1";
        url = url.replace("1", path2);
      }
      if (url.match(/aither/)) {
        const catMap = {
          movie: "1",
          tv: "2",
          tvPack: "2",
          documentary: "1",
          concert: "1",
          sport: "9",
          cartoon: "1",
          app: "10",
          ebook: "11",
          magazine: "11",
          audioBook: "14"
        };
        const path2 = catMap[TORRENT_INFO.category] || "1";
        url = url.replace("1", path2);
      }
      if (url.match(/bibliotik/)) {
        const catMap = {
          ebook: "ebooks",
          magazine: "magazines",
          audioBook: "audiobooks"
        };
        url = url.replace("/upload", `/upload/${catMap[TORRENT_INFO.category] || "ebooks"}`);
      }
      if (url.match(PT_SITE.BYR.host)) {
        const catMap = {
          movie: "408",
          tv: "401",
          tvPack: "401",
          documentary: "410",
          concert: "402",
          sport: "409",
          cartoon: "404",
          variety: "405"
        };
        url = url.replace("/upload.php", `/upload.php?type=${catMap[TORRENT_INFO.category]}`);
      }
      if (url.match(PT_SITE.PTP.host)) {
        const groupId = await getPTPGroupId(TORRENT_INFO.imdbUrl);
        url = url.replace(/(upload.php)/, `$1?groupid=${groupId}`);
      }
      if (url.match(PT_SITE.GPW.host)) {
        const groupId = await getGPWGroupId(TORRENT_INFO.imdbUrl);
        if (groupId) {
          url = url.replace(/(upload.php)/, `$1?groupid=${groupId}`);
        }
      }
      if (TORRENT_INFO.isForbidden) {
        const result = window.confirm($t("\u672C\u79CD\u5B50\u53EF\u80FD\u7981\u6B62\u8F6C\u8F7D\uFF0C\u786E\u5B9A\u8981\u7EE7\u7EED\u8F6C\u8F7D\u4E48\uFF1F"));
        if (!result) {
          return;
        }
      }
      if (CURRENT_SITE_NAME === "TTG" && !TORRENT_INFO.description) {
        Notification_default2.open({
          description: $t("\u8BF7\u7B49\u5F85\u9875\u9762\u52A0\u8F7D\u5B8C\u6210")
        });
        return;
      }
      const timestamp = `${Date.now()}`;
      if (!TORRENT_INFO.torrentData) {
        const torrentData = await getTorrentFileData(CURRENT_SITE_INFO.torrentDownloadLinkSelector, CURRENT_SITE_INFO.torrentLink);
        if (torrentData) {
          TORRENT_INFO.torrentData = torrentData;
        }
      }
      GM_setValue("uploadInfo", TORRENT_INFO);
      url = `${url}#timestamp=${timestamp}`;
      GM_openInTab(url);
    };
    const targetSitesEnabled = getValue("easy-seed.enabled-target-sites") || [];
    const siteFaviconClosed = getValue("easy-seed.site-favicon-closed", false) || "";
    return /* @__PURE__ */ e3("ul", { className: "site-list", children: [
      SORTED_SITE_KEYS.map((siteName) => {
        const siteInfo = PT_SITE[siteName];
        const { url, uploadPath } = siteInfo;
        const favIcon = siteFaviconClosed === "" && siteInfo.icon ? siteInfo.icon : "";
        if (siteInfo.asTarget) {
          if (targetSitesEnabled.length === 0 || targetSitesEnabled.includes(siteName)) {
            return /* @__PURE__ */ e3("li", { children: [
              /* @__PURE__ */ e3(
                "a",
                {
                  className: "site-item",
                  onClick: () => handleSiteClickEvent(`${url}${uploadPath}`),
                  children: [
                    !!favIcon && /* @__PURE__ */ e3("img", { src: favIcon, className: "site-icon" }),
                    siteName
                  ]
                }
              ),
              /* @__PURE__ */ e3("span", { children: "|" })
            ] }, siteName);
          }
        }
        return "";
      }),
      /* @__PURE__ */ e3("li", { children: /* @__PURE__ */ e3("button", { id: "batch-seed-btn", onClick: openBatchSeedTabs, children: $t("\u4E00\u952E\u7FA4\u8F6C") }) })
    ] });
  };
  var UploadSiteList_default = UploadSiteList;

  // src/components/SettingPanel.tsx
  init_preact_shim();

  // src/components/conf/index.ts
  init_preact_shim();
  var SiteListConfig = [
    {
      name: "enabled-target-sites",
      class: "target-sites-enable-list",
      title: "\u8F6C\u79CD\u7AD9\u70B9\u542F\u7528",
      key: "targetEnabled"
    },
    {
      name: "enabled-search-site-list",
      class: "search-sites-enable-list",
      title: "\u7AD9\u70B9\u641C\u7D22\u542F\u7528",
      key: "searchEnabled"
    },
    {
      name: "enabled-batch-seed-sites",
      class: "batch-seed-sites-enable-list",
      title: "\u6279\u91CF\u8F6C\u79CD\u542F\u7528",
      key: "batchEnabled",
      des: "\u4E00\u952E\u6279\u91CF\u8F6C\u53D1\u5230\u4EE5\u4E0B\u9009\u4E2D\u7684\u7AD9\u70B9"
    }
  ];
  var FeatureSwitchList = [
    {
      name: "quick-search-closed",
      des: "\u5173\u95ED\u5FEB\u901F\u68C0\u7D22",
      type: "checkbox",
      key: "quickSearchClosed"
    },
    {
      name: "transfer-img-closed",
      des: "\u5173\u95ED\u8F6C\u7F29\u7565\u56FE\u529F\u80FD",
      type: "checkbox",
      key: "transferImgClosed"
    },
    {
      name: "upload-img-closed",
      des: "\u5173\u95ED\u8F6C\u5B58ptpimg\u529F\u80FD",
      type: "checkbox",
      key: "uploadImgClosed"
    },
    {
      name: "site-favicon-closed",
      des: "\u5173\u95ED\u7AD9\u70B9\u56FE\u6807\u663E\u793A",
      type: "checkbox",
      key: "siteFaviconClosed"
    },
    {
      name: "thanks-quote-closed",
      des: "\u4E0D\u663E\u793A\u81F4\u8C22\u5185\u5BB9",
      type: "checkbox",
      key: "thanksQuoteClosed"
    },
    {
      name: "douban-closed",
      des: "\u4E0D\u663E\u793A\u8C46\u74E3\u6309\u94AE\u548C\u8C46\u74E3\u94FE\u63A5",
      type: "checkbox",
      key: "doubanClosed"
    }
  ];

  // src/components/SettingPanel.tsx
  var SettingPanel = (props) => {
    const getSiteSetList = () => {
      const targetSitesEnabled = getValue("easy-seed.enabled-target-sites") || [];
      const batchSeedSiteEnabled = getValue("easy-seed.enabled-batch-seed-sites") || [];
      const searchSitesEnabled = getValue("easy-seed.enabled-search-site-list") || [];
      return SORTED_SITE_KEYS.map((site) => {
        const targetEnabled = targetSitesEnabled.includes(site);
        const batchEnabled = batchSeedSiteEnabled.includes(site);
        const searchEnabled = searchSitesEnabled.includes(site);
        return {
          site,
          targetEnabled,
          batchEnabled,
          searchEnabled
        };
      });
    };
    const getFeatureList = () => {
      return FeatureSwitchList.map((feature) => {
        const isChecked = getValue(`easy-seed.${feature.name}`, false) || false;
        return __spreadProps(__spreadValues({}, feature), {
          checked: !!isChecked
        });
      });
    };
    const featureList = getFeatureList();
    const siteList = getSiteSetList();
    const { closePanel } = props;
    const [ptpImgApiKey, setPtpImgApiKey] = d2(getValue("easy-seed.ptp-img-api-key", false) || "");
    const [doubanCookie, setDoubanCookie] = d2(getValue("easy-seed.douban-cookie", false) || "");
    const saveSetting = () => {
      const targetSitesEnabled = [];
      const searchSitesEnabled = [];
      const batchSeedSiteEnabled = [];
      siteList.forEach(({ site, targetEnabled, batchEnabled, searchEnabled }) => {
        if (batchEnabled) {
          batchSeedSiteEnabled.push(site);
        }
        if (searchEnabled) {
          searchSitesEnabled.push(site);
        }
        if (targetEnabled) {
          targetSitesEnabled.push(site);
        }
      });
      try {
        GM_setValue("easy-seed.enabled-target-sites", JSON.stringify(targetSitesEnabled));
        GM_setValue("easy-seed.enabled-search-site-list", JSON.stringify(searchSitesEnabled));
        GM_setValue("easy-seed.enabled-batch-seed-sites", JSON.stringify(batchSeedSiteEnabled));
        GM_setValue("easy-seed.ptp-img-api-key", ptpImgApiKey);
        GM_setValue("easy-seed.douban-cookie", doubanCookie);
        featureList.forEach((feature) => {
          GM_setValue(`easy-seed.${feature.name}`, feature.checked ? "checked" : "");
        });
        window.location.reload();
      } catch (error) {
        Notification_default2.open({
          message: $t("\u9519\u8BEF"),
          description: $t("\u4FDD\u5B58\u672C\u5730\u7AD9\u70B9\u8BBE\u7F6E\u5931\u8D25")
        });
      }
    };
    const handleCheckChange = (key, index) => {
      const siteInfo = siteList[index];
      siteInfo[key] = !siteInfo[key];
      siteList[index] = siteInfo;
    };
    const handleFeatureChange = (index) => {
      const featureInfo = featureList[index];
      featureInfo.checked = !featureInfo.checked;
      featureList[index] = featureInfo;
    };
    return /* @__PURE__ */ e3("div", { className: "easy-seed-setting-panel", children: /* @__PURE__ */ e3("div", { className: "panel-content-wrap", children: [
      /* @__PURE__ */ e3("div", { className: "panel-content", children: [
        SiteListConfig.map((config) => {
          return /* @__PURE__ */ e3("div", { children: [
            /* @__PURE__ */ e3("h3", { children: $t(config.title) }),
            config.des && /* @__PURE__ */ e3("p", { children: $t(config.des) }),
            /* @__PURE__ */ e3("section", { className: "site-enable-setting", children: /* @__PURE__ */ e3("ul", { className: config.class, children: siteList.map((siteInfo, index) => {
              const siteData = PT_SITE[siteInfo.site];
              if (siteData.asTarget && config.key !== "searchEnabled" || config.key === "searchEnabled" && siteData.search) {
                return /* @__PURE__ */ e3("li", { children: /* @__PURE__ */ e3("label", { children: [
                  /* @__PURE__ */ e3(
                    "input",
                    {
                      onChange: () => handleCheckChange(config.key, index),
                      name: "target-site-enabled",
                      type: "checkbox",
                      checked: siteInfo[config.key]
                    }
                  ),
                  siteInfo.site
                ] }) }, siteInfo.site);
              }
              return "";
            }) }) })
          ] }, config.name);
        }),
        /* @__PURE__ */ e3("h3", { children: $t("\u56FE\u5E8A\u914D\u7F6E") }),
        /* @__PURE__ */ e3("section", { className: "site-enable-setting img-upload-setting", children: /* @__PURE__ */ e3("label", { children: [
          "ptpimg ApiKey:",
          /* @__PURE__ */ e3(
            "input",
            {
              name: "ptp-img-api-key",
              type: "text",
              value: ptpImgApiKey,
              onChange: (e4) => setPtpImgApiKey(e4.target.value)
            }
          ),
          /* @__PURE__ */ e3(
            "a",
            {
              target: "_blank",
              href: "https://github.com/techmovie/easy-seed/wiki/%E5%A6%82%E4%BD%95%E8%8E%B7%E5%8F%96ptpimg%E7%9A%84apiKey",
              rel: "noreferrer",
              children: $t("\u5982\u4F55\u83B7\u53D6\uFF1F")
            }
          )
        ] }) }),
        /* @__PURE__ */ e3("h3", { children: $t("\u989D\u5916\u529F\u80FD\u5173\u95ED") }),
        /* @__PURE__ */ e3("div", { className: "feature-list", children: featureList.map((feature, index) => {
          return /* @__PURE__ */ e3("section", { className: "site-enable-setting", children: /* @__PURE__ */ e3("label", { children: [
            /* @__PURE__ */ e3(
              "input",
              {
                onChange: () => handleFeatureChange(index),
                name: feature.name,
                type: feature.type,
                checked: feature.checked
              }
            ),
            $t(feature.des)
          ] }) }, feature.name);
        }) }),
        /* @__PURE__ */ e3("h3", { children: $t("\u8C46\u74E3\u914D\u7F6E") }),
        /* @__PURE__ */ e3("div", { className: "douban-config", children: /* @__PURE__ */ e3("label", { children: [
          $t("\u8C46\u74E3Cookie"),
          /* @__PURE__ */ e3(
            "textarea",
            {
              value: doubanCookie,
              onChange: (e4) => setDoubanCookie(e4.target.value)
            }
          )
        ] }) })
      ] }),
      /* @__PURE__ */ e3("div", { className: "confirm-btns", children: [
        /* @__PURE__ */ e3("button", { onClick: closePanel, children: $t("\u53D6\u6D88") }),
        /* @__PURE__ */ e3("button", { onClick: saveSetting, className: "save-setting-btn", children: $t("\u4FDD\u5B58") })
      ] })
    ] }) });
  };
  var SettingPanel_default = SettingPanel;

  // src/assets/setting.svg
  init_preact_shim();
  var SvgSetting = (props) => /* @__PURE__ */ e3("svg", __spreadProps(__spreadValues({ className: "icon", viewBox: "0 0 1024 1024", xmlns: "http://www.w3.org/2000/svg", width: 200, height: 200 }, props), { children: [
    /* @__PURE__ */ e3("path", { d: "M636.211 847.77c5.735-42.548 39.885-76.75 82.432-82.381 20.122-2.663 39.22.87 55.655 9.011 32.563 16.077 72.345 4.864 92.313-25.395a375.948 375.948 0 0 0 22.221-38.4c16.691-33.127 4.813-72.807-25.754-93.85a79.944 79.944 0 0 1-4.198-3.072c-34.202-26.265-46.848-73.216-30.26-113.05 7.732-18.636 20.327-33.28 35.482-43.417 30.31-20.275 40.704-60.467 24.218-92.98a383.375 383.375 0 0 0-19.302-33.74c-20.224-31.54-60.468-42.138-94.516-26.42a102.363 102.363 0 0 1-4.761 2.049c-39.936 15.974-86.63 2.97-112.487-31.437-12.083-16.077-18.33-34.304-19.404-52.429-2.15-36.505-31.693-65.69-68.148-67.993a388.598 388.598 0 0 0-47.974-.052c-36.915 2.253-65.178 32.205-68.25 69.07-.153 1.689-.307 3.378-.563 5.068-5.734 42.394-39.731 76.442-82.073 82.227-20.02 2.714-39.066-.717-55.45-8.704-32.563-15.82-72.192-4.505-92.006 25.754a386.852 386.852 0 0 0-22.17 38.502c-16.538 32.973-4.864 72.397 25.395 93.543a120.61 120.61 0 0 1 4.096 3.02c33.69 26.112 46.131 72.397 30.106 111.872-7.629 18.79-20.173 33.639-35.38 43.93-29.951 20.275-39.884 60.211-23.603 92.467 5.94 11.725 12.39 23.091 19.456 34.1 20.07 31.385 59.956 42.035 93.901 26.623a76.381 76.381 0 0 1 4.71-1.996c39.68-15.668 85.863-2.765 111.668 31.232 12.288 16.23 18.637 34.61 19.712 52.94 2.099 36.352 31.744 65.23 68.096 67.687 8.601.563 17.254.87 25.958.87 7.475 0 14.9-.205 22.323-.665 36.813-2.15 65.024-32.103 68.096-68.864.052-1.69.256-3.43.461-5.12z", fill: "#FFF7E6" }),
    /* @__PURE__ */ e3("path", { d: "M387.994 514.816a127.795 127.795 0 1 0 255.59 0 127.795 127.795 0 1 0-255.59 0Z", fill: "#FD973F" }),
    /* @__PURE__ */ e3("path", { d: "M515.789 668.211c-84.583 0-153.395-68.813-153.395-153.395 0-84.582 68.812-153.395 153.395-153.395s153.395 68.813 153.395 153.395c-.051 84.582-68.813 153.395-153.395 153.395zm0-255.539c-56.32 0-102.195 45.824-102.195 102.195s45.824 102.195 102.195 102.195 102.195-45.824 102.195-102.195-45.875-102.195-102.195-102.195zm370.38 24.525c-6.041 0-12.083-2.1-16.947-6.4a25.6 25.6 0 0 1-2.201-36.147c14.899-16.845 18.073-41.575 7.936-61.543a388.557 388.557 0 0 0-20.224-35.328c-12.442-19.405-35.533-29.03-58.778-24.576a25.605 25.605 0 0 1-29.952-20.326 25.605 25.605 0 0 1 20.327-29.952c43.98-8.397 87.705 10.086 111.513 47.206a437.184 437.184 0 0 1 22.784 39.834c19.559 38.553 13.415 86.22-15.257 118.63-5.12 5.683-12.135 8.602-19.2 8.602z", fill: "#44454A" }),
    /* @__PURE__ */ e3("path", { d: "M515.789 968.448c-10.189 0-20.48-.358-30.618-1.024-53.709-3.635-96.563-46.387-99.635-99.43-.922-16.18-6.758-31.693-16.794-44.954-21.913-28.877-60.774-39.731-94.515-26.42a46.724 46.724 0 0 0-3.993 1.69c-50.125 22.784-107.623 6.298-136.704-39.116a459.955 459.955 0 0 1-22.938-40.244c-24.064-47.667-9.114-105.984 34.816-135.68 13.363-9.062 23.757-21.964 30.003-37.324 13.62-33.536 3.175-72.448-25.497-94.72a78.127 78.127 0 0 0-3.533-2.612c-45.005-31.436-60.365-88.883-36.506-136.55a450.35 450.35 0 0 1 26.163-45.466c29.236-44.646 87.296-60.825 135.015-37.683 14.438 7.015 30.72 9.523 47.104 7.322 35.993-4.915 64.563-33.536 69.478-69.632a61.27 61.27 0 0 0 .461-4.301c4.66-54.886 46.643-97.075 99.942-100.352 18.688-1.126 37.837-1.126 56.628.102 53.76 3.43 96.665 46.336 99.788 99.79.922 15.974 6.656 31.385 16.487 44.543 14.438 19.2 37.632 31.232 62.157 32.205 14.13.563 25.139 12.493 24.576 26.573-.564 14.131-12.698 25.088-26.573 24.576-40.295-1.587-77.159-20.787-101.069-52.685-15.923-21.197-25.14-46.182-26.675-72.243-1.639-27.648-23.962-49.869-51.917-51.661-16.64-1.075-33.69-1.075-50.227-.051-27.7 1.69-49.613 24.166-52.07 53.453-.205 2.252-.461 4.608-.769 6.912-7.987 58.828-54.579 105.472-113.305 113.51-26.42 3.584-52.787-.563-76.39-11.98-24.628-11.93-54.682-3.534-69.837 19.66a404.157 404.157 0 0 0-23.194 40.294c-12.39 24.781-3.994 54.938 20.02 71.68a144.56 144.56 0 0 1 5.631 4.148c46.643 36.198 63.744 99.737 41.472 154.419-10.086 24.78-26.931 45.67-48.742 60.416-22.63 15.309-30.26 45.517-17.818 70.246 6.144 12.186 13.005 24.167 20.378 35.687 15.257 23.808 45.67 32.256 72.397 20.172 2.099-.921 4.25-1.843 6.4-2.713 55.04-21.709 118.374-3.994 154.112 43.11 16.23 21.402 25.6 46.592 27.084 72.96 1.588 27.341 23.91 49.408 51.968 51.303a405.713 405.713 0 0 0 50.535.256c27.545-1.588 49.305-24.013 51.763-53.248.205-2.356.46-4.66.768-6.964 7.987-59.136 54.784-105.83 113.818-113.664 26.521-3.532 53.043.768 76.646 12.442 24.627 12.186 54.784 3.84 70.042-19.405 8.499-12.902 16.332-26.419 23.244-40.192 12.544-24.883 3.994-55.142-20.326-71.885a109.227 109.227 0 0 1-5.734-4.198c-47.565-36.557-64.717-100.71-41.728-155.955a25.559 25.559 0 0 1 33.484-13.773 25.559 25.559 0 0 1 13.773 33.485c-13.875 33.382-3.123 73.625 25.651 95.693a58.07 58.07 0 0 0 3.584 2.61c45.62 31.438 61.184 89.14 37.018 137.114a464.45 464.45 0 0 1-26.214 45.312c-29.492 44.75-87.706 60.724-135.476 37.172-14.49-7.168-30.873-9.78-47.257-7.578-35.635 4.71-64.973 34.048-69.786 69.734a67.705 67.705 0 0 0-.46 4.404c-4.557 54.835-46.541 96.972-99.79 100.044-8.755.41-17.612.666-26.316.666z", fill: "#44454A" })
  ] }));
  var setting_default = SvgSetting;

  // src/components/Container.tsx
  var Container = () => {
    var _a3, _b2;
    const [settingPanelOpen, setSettingPanelOpen] = d2(false);
    const isNexusPHP = CURRENT_SITE_INFO.siteType.match(/NexusPHP|AvistaZ/) || ((_a3 = CURRENT_SITE_NAME) == null ? void 0 : _a3.match(/BeyondHD|TTG|Blutopia|HDPOST|Aither|ACM|KG|iTS|MDU|LST|fearnopeer/));
    const isHDB = CURRENT_SITE_NAME === "HDBits";
    const baseTitleClass = ["title-td"];
    const baseContentClass = ["easy-seed-td"];
    if (isNexusPHP) {
      baseTitleClass.push("rowhead", "nowrap");
      baseContentClass.push("rowfollow");
    } else if (CURRENT_SITE_NAME === "HDT") {
      baseTitleClass.push("detailsleft");
      baseContentClass.push("detailshash");
    } else if (CURRENT_SITE_NAME === "HDSpace") {
      baseTitleClass.push("header");
      baseContentClass.push("lista");
    } else if (isHDB) {
      baseTitleClass.push("rowfollow", "hdb-td");
      baseContentClass.push("rowfollow", "hdb-td");
    }
    const openSettingPanel = () => {
      setSettingPanelOpen(true);
    };
    const closePanel = () => {
      setSettingPanelOpen(false);
    };
    const checkQuickResult = () => {
      let searchListSetting = getValue("easy-seed.enabled-search-site-list");
      if (searchListSetting.length === 0) {
        searchListSetting = SORTED_SITE_KEYS;
      }
      searchListSetting.forEach(async (site) => {
        var _a4;
        const siteInfo = PT_SITE[site];
        const resultConfig = (_a4 = siteInfo.search) == null ? void 0 : _a4.result;
        const siteUrl = siteInfo.url;
        if (resultConfig) {
          const { list, name, size, url: urlDom } = resultConfig;
          const { title, size: searchSize } = TORRENT_INFO;
          const url = getQuickSearchUrl(site);
          const domString = await fetch(url, {
            responseType: void 0
          });
          const dom = new DOMParser().parseFromString(domString, "text/html");
          const torrentList = jQuery(list, dom);
          const sameTorrent = Array.prototype.find.call(torrentList, (item) => {
            var _a5, _b3, _c, _d, _e;
            let torrentName;
            if (site === "TTG") {
              torrentName = (_c = (_b3 = (_a5 = jQuery(item).find(name).prop("firstChild")) == null ? void 0 : _a5.textContent) == null ? void 0 : _b3.trim()) != null ? _c : "";
            } else {
              torrentName = jQuery(item).find(name).attr("title") || jQuery(item).find(name).text();
            }
            if (site === "TJUPT") {
              const matchArray = torrentName.match(/\[[^\]]+(\.|\s)+[^\]]+\]/g) || [];
              const realTitle = (_e = (_d = matchArray.filter((item2) => item2.match(/\.| /))) == null ? void 0 : _d[0]) != null ? _e : "";
              torrentName = realTitle.replace(/\[|\]/g, "");
            }
            torrentName = torrentName == null ? void 0 : torrentName.replace(/\s|\./g, "");
            const sizeBytes = getSize(jQuery(item).find(size).text());
            return torrentName === (title == null ? void 0 : title.replace(/\s|\./g, "")) && Math.abs(sizeBytes - searchSize) < Math.pow(1024, 2) * 1e3;
          });
          if (sameTorrent) {
            const url2 = `${siteUrl}/${jQuery(sameTorrent).find(urlDom).attr("href")}`;
            jQuery(`.search-list li>a[data-site=${site}]`).attr("data-url", url2).css("color", "#218380");
          } else {
            jQuery(`.search-list li>a[data-site=${site}]`).css("color", "#D81159");
          }
        }
      });
    };
    const Title = () => {
      return /* @__PURE__ */ e3("h4", { children: [
        $t("\u4E00\u952E\u8F6C\u79CD"),
        /* @__PURE__ */ e3("span", { id: "easy-seed-setting", className: "easy-seed-setting-btn" }),
        /* @__PURE__ */ e3(setting_default, { onClick: openSettingPanel, className: "setting-svg" })
      ] });
    };
    const quickSearchClosed = getValue("easy-seed.quick-search-closed", false) || "";
    return /* @__PURE__ */ e3(d, { children: [
      CURRENT_SITE_NAME === "HH" && /* @__PURE__ */ e3(d, { children: [
        /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: /* @__PURE__ */ e3(Title, {}) }),
        /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: /* @__PURE__ */ e3(UploadSiteList_default, {}) }),
        /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: $t("\u5FEB\u6377\u64CD\u4F5C") }),
        /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: /* @__PURE__ */ e3(FunctionList_default, {}) }),
        /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: $t("\u5FEB\u901F\u68C0\u7D22") }),
        /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: /* @__PURE__ */ e3(SearchList_default, {}) })
      ] }),
      CURRENT_SITE_NAME === "MTeam" && /* @__PURE__ */ e3(d, { children: [
        /* @__PURE__ */ e3("tr", { class: "ant-descriptions-row", children: [
          /* @__PURE__ */ e3("th", { class: "ant-descriptions-item-label", colSpan: 1, style: "width: 135px; text-align: right;", children: /* @__PURE__ */ e3("span", { children: /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: /* @__PURE__ */ e3(Title, {}) }) }) }),
          /* @__PURE__ */ e3("td", { class: "ant-descriptions-item-content", colSpan: 1, children: /* @__PURE__ */ e3(UploadSiteList_default, {}) })
        ] }),
        /* @__PURE__ */ e3("tr", { class: "ant-descriptions-row", children: [
          /* @__PURE__ */ e3("th", { class: "ant-descriptions-item-label", colSpan: 1, style: "width: 135px; text-align: right;", children: /* @__PURE__ */ e3("span", { children: /* @__PURE__ */ e3("div", { class: "font-bold leading-6", children: $t("\u5FEB\u901F\u68C0\u7D22") }) }) }),
          /* @__PURE__ */ e3("td", { class: "ant-descriptions-item-content", colSpan: 1, children: /* @__PURE__ */ e3(SearchList_default, {}) })
        ] })
      ] }),
      (isNexusPHP || isHDB || ((_b2 = CURRENT_SITE_NAME) == null ? void 0 : _b2.match(/(HDSpace|HDT)$/))) && /* @__PURE__ */ e3(d, { children: [
        /* @__PURE__ */ e3("tr", { className: isHDB ? "hdb-tr" : "", children: [
          /* @__PURE__ */ e3("td", { className: baseTitleClass.join(" "), children: /* @__PURE__ */ e3(Title, {}) }),
          /* @__PURE__ */ e3("td", { className: baseContentClass.join(" "), children: /* @__PURE__ */ e3("div", { id: "seed-dom", className: BROWSER_LANGUAGE === "en" ? "use-eng" : "", children: /* @__PURE__ */ e3(UploadSiteList_default, {}) }) })
        ] }),
        /* @__PURE__ */ e3("tr", { className: isHDB ? "hdb-tr" : "", children: [
          /* @__PURE__ */ e3("td", { className: baseTitleClass.join(" "), children: /* @__PURE__ */ e3("h4", { children: $t("\u5FEB\u6377\u64CD\u4F5C") }) }),
          /* @__PURE__ */ e3("td", { className: baseContentClass.join(" "), children: /* @__PURE__ */ e3(FunctionList_default, {}) })
        ] }),
        !quickSearchClosed && /* @__PURE__ */ e3("tr", { className: isHDB ? "hdb-tr" : "", children: [
          /* @__PURE__ */ e3("td", { className: baseTitleClass.join(" "), children: /* @__PURE__ */ e3("h4", { className: "quick-search", onClick: checkQuickResult, children: $t("\u5FEB\u901F\u68C0\u7D22") }) }),
          /* @__PURE__ */ e3("td", { className: baseContentClass.join(" "), children: /* @__PURE__ */ e3(SearchList_default, {}) })
        ] })
      ] }),
      CURRENT_SITE_NAME === "Cinematik" && /* @__PURE__ */ e3(d, { children: [
        /* @__PURE__ */ e3("tr", { children: [
          /* @__PURE__ */ e3("td", { className: "rowhead", children: /* @__PURE__ */ e3(Title, {}) }),
          /* @__PURE__ */ e3("td", { children: /* @__PURE__ */ e3(UploadSiteList_default, {}) })
        ] }),
        /* @__PURE__ */ e3("tr", { children: [
          /* @__PURE__ */ e3("td", { className: "rowhead", children: $t("\u5FEB\u6377\u64CD\u4F5C") }),
          /* @__PURE__ */ e3("td", { children: /* @__PURE__ */ e3(FunctionList_default, {}) })
        ] }),
        !quickSearchClosed && /* @__PURE__ */ e3("tr", { children: [
          /* @__PURE__ */ e3("td", { className: "rowhead", children: /* @__PURE__ */ e3("h4", { className: "quick-search", onClick: checkQuickResult, children: $t("\u5FEB\u901F\u68C0\u7D22") }) }),
          /* @__PURE__ */ e3("td", { children: /* @__PURE__ */ e3(SearchList_default, {}) })
        ] })
      ] }),
      CURRENT_SITE_NAME === "TeamHD" && /* @__PURE__ */ e3(d, { children: [
        /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3(Title, {}),
          /* @__PURE__ */ e3("div", { className: "easy-seed-td", style: { flexWrap: "wrap" }, children: /* @__PURE__ */ e3("div", { id: "seed-dom", className: BROWSER_LANGUAGE === "en" ? "use-eng" : "", children: /* @__PURE__ */ e3(UploadSiteList_default, {}) }) })
        ] }),
        /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3("h4", { children: $t("\u5FEB\u6377\u64CD\u4F5C") }),
          /* @__PURE__ */ e3(FunctionList_default, {})
        ] }),
        !quickSearchClosed && /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3("h4", { onClick: checkQuickResult, children: $t("\u5FEB\u901F\u68C0\u7D22") }),
          /* @__PURE__ */ e3("div", { children: /* @__PURE__ */ e3(SearchList_default, {}) })
        ] })
      ] }),
      CURRENT_SITE_NAME === "SpeedApp" && /* @__PURE__ */ e3(d, { children: [
        /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3(Title, {}),
          /* @__PURE__ */ e3("div", { className: "easy-seed-td", style: { flexWrap: "wrap" }, children: /* @__PURE__ */ e3("div", { id: "seed-dom", className: BROWSER_LANGUAGE === "en" ? "use-eng" : "", children: /* @__PURE__ */ e3(UploadSiteList_default, {}) }) })
        ] }),
        /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3("h4", { children: $t("\u5FEB\u6377\u64CD\u4F5C") }),
          /* @__PURE__ */ e3(FunctionList_default, {})
        ] }),
        !quickSearchClosed && /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3("h4", { onClick: checkQuickResult, children: $t("\u5FEB\u901F\u68C0\u7D22") }),
          /* @__PURE__ */ e3("div", { children: /* @__PURE__ */ e3(SearchList_default, {}) })
        ] })
      ] }),
      CURRENT_SITE_NAME === "Bdc" && /* @__PURE__ */ e3(d, { children: /* @__PURE__ */ e3("tr", { children: /* @__PURE__ */ e3("td", { colSpan: 4, children: [
        /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3(Title, {}),
          /* @__PURE__ */ e3("div", { className: "easy-seed-td", style: { flexWrap: "wrap" }, children: /* @__PURE__ */ e3("div", { id: "seed-dom", className: BROWSER_LANGUAGE === "en" ? "use-eng" : "", children: /* @__PURE__ */ e3(UploadSiteList_default, {}) }) })
        ] }),
        /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3("h4", { children: $t("\u5FEB\u6377\u64CD\u4F5C") }),
          /* @__PURE__ */ e3(FunctionList_default, {})
        ] }),
        !quickSearchClosed && /* @__PURE__ */ e3("div", { className: "custom-site", children: [
          /* @__PURE__ */ e3("h4", { onClick: checkQuickResult, children: $t("\u5FEB\u901F\u68C0\u7D22") }),
          /* @__PURE__ */ e3("div", { children: /* @__PURE__ */ e3(SearchList_default, {}) })
        ] })
      ] }) }) }),
      CURRENT_SITE_INFO.siteType === "gazelle" && /* @__PURE__ */ e3("div", { id: "seed-dom", className: ["movie-page__torrent__panel", BROWSER_LANGUAGE === "en" ? "use-eng" : ""].join(" "), children: [
        /* @__PURE__ */ e3("div", { className: "ptp-title-wrapper", children: [
          /* @__PURE__ */ e3(Title, {}),
          /* @__PURE__ */ e3(UploadSiteList_default, {})
        ] }),
        CURRENT_SITE_NAME !== "EMP" && /* @__PURE__ */ e3(FunctionList_default, {}),
        /* @__PURE__ */ e3("div", { class: "ptp-search-list", children: !quickSearchClosed && /* @__PURE__ */ e3("div", { class: "ptp-title-wrapper", children: [
          /* @__PURE__ */ e3("h4", { className: "quick-search", onClick: checkQuickResult, children: $t("\u5FEB\u901F\u68C0\u7D22") }),
          /* @__PURE__ */ e3(SearchList_default, {})
        ] }) })
      ] }),
      /* @__PURE__ */ e3("div", { style: { display: settingPanelOpen ? "block" : "none" }, children: /* @__PURE__ */ e3(SettingPanel_default, { closePanel }) })
    ] });
  };
  var Container_default = Container;

  // src/index.tsx
  var torrentInfoMatchArray = location.hash && location.hash.match(/(^|#)torrentInfo=([^#]*)(#|$)/);
  var timestampMatchArray = location.hash && location.hash.match(/(^|#)timestamp=([^#]*)(#|$)/);
  var torrentTimestamp = timestampMatchArray && timestampMatchArray.length > 0 ? timestampMatchArray[2] : null;
  var torrentInfoRaw = torrentInfoMatchArray && torrentInfoMatchArray.length > 0 ? torrentInfoMatchArray[2] : null;
  var torrentInfo = null;
  var _a2, _b;
  if (CURRENT_SITE_NAME) {
    fillSearchImdb();
    if (CURRENT_SITE_INFO.asTarget) {
      if (torrentInfoRaw) {
        torrentInfo = JSON.parse(decodeURIComponent(torrentInfoRaw));
      } else if (torrentTimestamp) {
        torrentInfo = GM_getValue("uploadInfo");
      }
      fillTargetForm(torrentInfo);
    }
    if (CURRENT_SITE_INFO.asSource && !location.href.match(/upload|offer/ig) && !(CURRENT_SITE_INFO.search && location.pathname.match(CURRENT_SITE_INFO.search.path) && (getUrlParam("imdb") || getUrlParam("name")))) {
      source_default().then(() => {
        console.log(TORRENT_INFO);
      });
      let refNode = jQuery(CURRENT_SITE_INFO.seedDomSelector)[0];
      const app = document.createElement("div");
      S(/* @__PURE__ */ e3(Container_default, {}), app);
      if (["PTP", "BTN", "GPW", "EMP", "RED", "DicMusic", "MTV", "Orpheus"].includes(CURRENT_SITE_NAME)) {
        const torrentId = getUrlParam("torrentid");
        if (CURRENT_SITE_NAME === "GPW") {
          refNode = document.querySelector(`#torrent_detail_${torrentId} >td`);
        } else if (CURRENT_SITE_NAME === "EMP") {
          const groupId = getUrlParam("id");
          refNode = document.querySelector(`.groupid_${groupId}.torrentdetails>td`);
        } else if (CURRENT_SITE_NAME === "MTV") {
          refNode = document.querySelector(`#torrentinfo${torrentId}>td`);
        } else {
          refNode = document.querySelector(`#torrent_${torrentId} >td`);
        }
        refNode == null ? void 0 : refNode.prepend(app);
      } else if (CURRENT_SITE_NAME === "UHDBits") {
        const torrentId = getUrlParam("torrentid");
        jQuery(`#torrent_${torrentId} >td`).prepend(document.createElement("blockquote"));
        (_a2 = jQuery(`#torrent_${torrentId} >td blockquote:first`)) == null ? void 0 : _a2.prepend(app);
      } else if (CURRENT_SITE_NAME === "SpeedApp") {
        const div = document.createElement("div");
        div.setAttribute("class", "row col-md-12 mt-5");
        app.setAttribute("class", "card-body card");
        div.appendChild(app);
        (_b = refNode == null ? void 0 : refNode.parentNode) == null ? void 0 : _b.insertBefore(div, refNode);
      } else if (CURRENT_SITE_NAME === "MTeam") {
        const targetNode = document.getElementById("root");
        const config = { childList: true, subtree: true };
        const observer = new MutationObserver((mutationsList, observer2) => {
          for (const mutation of mutationsList) {
            if (mutation.type === "childList") {
              const targetElement = jQuery(CURRENT_SITE_INFO.seedDomSelector)[0];
              if (targetElement) {
                observer2.disconnect();
                refNode = jQuery(CURRENT_SITE_INFO.seedDomSelector)[0];
                Array.from(app.childNodes).forEach((child) => {
                  var _a3;
                  (_a3 = refNode == null ? void 0 : refNode.parentNode) == null ? void 0 : _a3.insertBefore(child, refNode);
                });
                break;
              }
            }
          }
        });
        observer.observe(targetNode, config);
      } else {
        Array.from(app.childNodes).forEach((child) => {
          var _a3;
          (_a3 = refNode == null ? void 0 : refNode.parentNode) == null ? void 0 : _a3.insertBefore(child, refNode);
        });
      }
    }
  }
})();
/*! Bundled license information:

classnames/index.js:
  (*!
    Copyright (c) 2018 Jed Watson.
    Licensed under the MIT License (MIT), see
    http://jedwatson.github.io/classnames
  *)

ieee754/index.js:
  (*! ieee754. BSD-3-Clause License. Feross Aboukhadijeh <https://feross.org/opensource> *)

buffer/index.js:
  (*!
   * The buffer module from node.js, for the browser.
   *
   * @author   Feross Aboukhadijeh <https://feross.org>
   * @license  MIT
   *)

queue-microtask/index.js:
  (*! queue-microtask. MIT License. Feross Aboukhadijeh <https://feross.org/opensource> *)

uint8-util/util.js:
  (* Common package for dealing with hex/string/uint8 conversions (and sha1 hashing)
  *
  * @author   Jimmy Wärting <jimmy@warting.se> (https://jimmy.warting.se/opensource)
  * @license  MIT
  *)

magnet-uri/index.js:
  (*! magnet-uri. MIT License. WebTorrent LLC <https://webtorrent.io/opensource> *)

parse-torrent/index.js:
  (*! parse-torrent. MIT License. WebTorrent LLC <https://webtorrent.io/opensource> *)
*/