海角社区免费版

可以免费观看海角社区钻石和金币付费帖子、vip帖子,包括视频、图片、音频。

// ==UserScript==
// @name         海角社区免费版
// @namespace    http://tampermonkey.net/
// @version      0.1.2
// @description  可以免费观看海角社区钻石和金币付费帖子、vip帖子,包括视频、图片、音频。
// @author       JamToday
// @match        https://*.haijiao.com/*
// @include      *://hj*.*/*
// @include      *://*.hj*.*/*
// @include      *://*.hai*.*/*
// @include      *://hai*.*/*
// @include      *://hj*/*
// @include      *://*.hj*/*
// @include      */post/details/*
// @match        *://*/post/details*
// @exclude      *://hjai*/*
// @exclude      *://haijiao.ai/*
// @exclude      *://haijiao.pro/*
// @exclude      *://*.kittymao.xyz/*
// @exclude      https://hjfb.org/*
// @exclude      *://tool.liumingye.cn/*
// @icon         https://www.hjadbf.top/images/common/project/favicon.ico
// @grant        none
// @run-at       document-start
// ==/UserScript==
(function () {
    let kitty_StatusColor = {
      success: "#67C23A",
      warning: "#E6A23C",
      info: "#909399",
      danger: "#F56C6C",
      200: "#67C23A",
      300: "#E6A23C",
      400: "#909399",
      500: "#F56C6C",
    };
    let kitty_config = {
      name: "海角社区免费版",
      id: "hjfree",
      version: "0.1.2",
      homePageName: "kitty猫",
      homePageUrl: "www.kittymao.xyz",
   
      update: 3,
      logListMaxLength: 19,
      logItemLength: 20,
   
      updateUrl: "https://sleazyfork.org/zh-CN/scripts/440819-cao",
      requestHostList: ["https://baixiaodu.uk/api"],
    };
    let kitty_isrun = {
      getNewVersion: false,
    };
    let kitty_tabIndex = 0;
    let kitty_logListTarget = [];
    let kitty_logList = new Proxy(kitty_logListTarget, {
      set: function (target, property, value) {
        if (property === "length") {
          console.log("Cannot change the length of the array.");
          return true;
        } else {
          target[property] = value;
          let appendDiv = document.createElement("div");
          appendDiv.innerHTML = value;
          let kitty_logListDiv =
            document.getElementsByClassName("kitty_logList")[0];
          kitty_logListDiv.appendChild(appendDiv);
          return true;
        }
      },
    });
    function kitty_setCookie(cname, cvalue, exdays) {
      var d = new Date();
      d.setTime(d.getTime() + exdays * 24 * 60 * 60 * 1000);
      var expires = "expires=" + d.toGMTString();
      document.cookie = cname + "=" + cvalue + "; " + expires;
    }
    function kitty_insertStyle() {
      let style = document.createElement("style");
      style.innerHTML = `
                /* 整体-start */
                #kitty_vipPanel {
                    width: 310px;
                    height: 500px;
                    box-shadow: 0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%);
                    border-left: 1px solid transparent;
                    border-right: none;
                    border-top: 1px solid transparent;
                    border-bottom: 1px solid transparent;
                    background-color: #FFFFFF;
                    position: fixed;
                    left: 6px;
                    bottom: 6px;
                    z-index: 99999;
                    font-size: 16px;
                    --script-panel-main-color: #4178b0;
                }
                #kitty_vipPanel a {
                    text-decoration: underline;
                }
                .kitty_panelMain {
                    font-size: 0.85em;
                }
                .kitty_hiddenPanel {
                    left: -310px !important;
                }
                /* 整体-end */
                /* panelHead-start */
                .kitty_panelHead {
                    display: flex;
                    border-bottom: 1px solid #ececec;
                }
                .kitty_panelHead>div {
                    color: #444;
                    padding: 0 10px;
                    height: 40px;
                    line-height: 40px;
                    box-sizing: border-box;
                    user-select: none;
                    text-align: center;
                    width: 76px;
                    font-size: 1em;
                }
                .kitty_panelHead>div:not(.kitty_headDivActive):hover {
                    border-bottom: 3px solid #ccc;
                    cursor: pointer;
                }
                .kitty_headDivActive {
                    border-bottom: 3px solid var(--script-panel-main-color);
                    color: #444;
                    font-weight: bold;
                }
                /* panelHead-end */
                /* 界面显示按钮 */
                .kitty_showPanelBtn, .kitty_jiexiBtn {
                    position: absolute;
                    left: 320px;
                    top: 150px;
                    width: 50px;
                    height: 50px;
                    line-height: 50px;
                    color: var(--script-panel-main-color);
                    user-select: none;
                    background-color: #FFFFFF;
                    position: absolute;
                    bottom: 20px;
                    display: none;
                    cursor: pointer;
                    border-radius: 50px;
                    text-align: center;
                    box-shadow:0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%);
                }
                .kitty_jiexiBtn {
                  top: 85px;
                }
                /* 身体 */
                .kitty_panelBody  {
                    padding: 0 10px;
                }
                .kitty_panelBody p {
                    margin: 10px 0;
                }
                /* 输入框-start */
                .kitty_searchInput {
                    width: 98%;
                    border-radius: 24px;
                    box-shadow: 0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%);
                    height: 40px;
                    border-left: 1px solid transparent;
                    border-right: none;
                    border-top: 1px solid transparent;
                    border-bottom: 1px solid transparent;
                    overflow: hidden;
                    margin: 0 auto;
                    margin-top: 40px;
                    margin-bottom: 50px;
                    display: flex;
                }
                .kitty_searchInput:hover {
                    border-top-left-radius: 24px;
                    box-shadow: 0 0 0 1px rgb(0 0 0 / 10%), 0 2px 4px 1px rgb(0 0 0 / 18%);
                    border-left: 1px solid transparent;
                    border-right: none;
                    border-top: 1px solid transparent;
                    border-bottom: 1px solid transparent;
                }
                .kitty_searchInput input {
                    height: 100%;
                    border: 0;
                    outline: 0;
                    padding: 0 10px;
                    color: black;
                    width: 100%;
                }
                /* 输入框-end */
                /* go按钮-start */
                .kitty_goToVipBtn {
                    color: #FFFFFF;
                    font-weight: bold;
                    background-color: var(--script-panel-main-color);
                    height: 100px;
                    width: 100px;
                    border-radius: 50px;
                    text-align: center;
                    line-height: 100px;
                    margin: 20px auto;
                    box-shadow: 0 0 0 1px rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 9%);
                    user-select: none;
                }
                .kitty_goToVipBtn:hover {
                    cursor: pointer;
                    box-shadow: 0 0 0 0 rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 18%);
                    -webkit-box-shadow: 0 0 0 0 rgb(0 0 0 / 5%), 0 2px 4px 1px rgb(0 0 0 / 18%);
                    -moz-box-shadow: 0 0 0 0 rgba(0,0,0,.05),0 2px 4px 1px rgba(0,0,0,.18);
                }
                /* 动画 */
                @keyframes kitty_float {
                    0% {
                        transform: translateY(0px);
                    }
                    5% {
                        transform: translateY(-10px);
                    }
                    10%,100% {
                        transform: translateY(0px);
                    }
                }
    
                .kitty_navy {
                    position: relative;
                }
    
                .kitty_navy span {
                    position: relative;
                    display: inline-block;
                    color: white;
                    animation: kitty_float 9s ease-in-out infinite;
                    animation-delay: 2s;
                    font-size: 1.5em;
                }
                /* go按钮-end */
                .kitty_logOutput {
                    color: #71777d;
                    font-size: 0.9em;
                    margin-top: 10px;
                }
                .kitty_logOutput div {
                    margin: 0;
                    padding: 0;
                    line-height: 1.5;
                }
                .kitty_downloadText {
                    font-size: 20px;
                    font-weight: bold;
                }
                .kitty_downloadText a {
                    cursor:pointer;
                }
            `;
      document.querySelector("head").appendChild(style);
    }
    function kitty_createPanel() {
      let panel = document.createElement("div");
      panel.setAttribute("id", "kitty_vipPanel");
      panel.innerHTML = `
                <div class="kitty_showPanelBtn">显示</div>
                <div class="kitty_jiexiBtn">解析</div>
                <div class="kitty_panelMain">
                    <div class="kitty_panelHead">
                        <div class="kitty_headDivActive">运行日志</div>
                        <div>重要说明</div>
                        <div>使用指南</div>
                    </div>
                    <div class="kitty_panelBody kitty_panelBody_0">
                        <div class="kitty_logOutput">
                            <div>脚本--><span class="kitty_scriptName"></span>-<span class="kitty_version"></span>-<span class="kitty_update"></span></div>
                            <div>主页--><a class="kitty_homepage" target="_blank" href="">主页地址</a></div>
                            <div>邮箱-->JamJamToday@protonmail.com</div>
                            <div>操作--><span style="color: red;cursor:pointer;" class="kitty_hiddenPanelBtn">点此隐藏此脚本操作界面&lt;&lt;</span></div>
                            <div class="kitty_logList">
                            </div>
                        </div>
                    </div>
                    <div class="kitty_panelBody kitty_panelBody_1" style="display:none;">
                      <p>+ 本脚本完全免费</p>
                      <p>+ 本脚本无恶意代码放心使用</p>
                      <p>+ 更多脚本可看 <a target="_blank" href="https://docs.kittymao.xyz">www.kittymao.xyz</a></p>
                      <p>+ 脚本仅支持正版海角</p>
                      <p>+ 如果脚本在非正版海角网站运行, 请关闭即可</p>
                  </div>
                    <div class="kitty_panelBody kitty_panelBody_2" style="display:none;">
                        <p>+ 使用方法线路1: <a target="_blank" href="https://www.kittymao.xyz">www.kittymao.xyz</a></p>
                    </div>
                </div>
            `;
      document.body.appendChild(panel);
      let ishidden = localStorage.getItem("kitty_isHiddenPanel");
      if (ishidden) {
        ishidden = JSON.parse(ishidden);
        if (ishidden) {
          kitty_hiddenPanel();
        } else {
          kitty_showPanel();
        }
      }
    }
   
    function kitty_eventBind() {
      let tabs = document.querySelectorAll(".kitty_panelHead>div");
      for (let i = 0; i < tabs.length; i++) {
        tabs[i].addEventListener("click", function () {
          for (let ii = 0; ii < tabs.length; ii++) {
            tabs[ii].className = "";
          }
          tabs[i].className = "kitty_headDivActive";
          kitty_changeTab(i);
        });
      }
      document
        .querySelector(".kitty_hiddenPanelBtn")
        .addEventListener("click", function () {
          kitty_hiddenPanel();
        });
      document
        .querySelector(".kitty_showPanelBtn")
        .addEventListener("click", function () {
          kitty_showPanel();
        });
      document
        .querySelector(".kitty_jiexiBtn")
        .addEventListener("click", function () {
          if (location.href.includes("post/details?pid")) {
            if (kitty_isLogin()) {
              document.querySelector(".kitty_jiexiBtn").innerHTML = "稍等";
            } else {
              document.querySelector(".kitty_jiexiBtn").innerHTML = "暂无";
              kitty_checkLogin();
              kitty_showPanel();
            }
          } else {
            document.querySelector(".kitty_jiexiBtn").innerHTML = "暂无";
          }
        });
    }
   
    function kitty_changeTab(index) {
      kitty_tabIndex = index;
      let panelBodys = document.querySelectorAll(".kitty_panelBody");
      if (!panelBodys[kitty_tabIndex]) {
        return;
      }
      for (let i = 0; i < panelBodys.length; i++) {
        panelBodys[i].style.display = "none";
      }
      panelBodys[kitty_tabIndex].style.display = "block";
    }
   
    function kitty_hiddenPanel() {
      document.querySelector("#kitty_vipPanel").className = "kitty_hiddenPanel";
      document.querySelector(".kitty_showPanelBtn").style.display = "block";
      document.querySelector(".kitty_jiexiBtn").style.display = "block";
      localStorage.setItem("kitty_isHiddenPanel", JSON.stringify(true));
    }
    function kitty_showPanel() {
      document.querySelector("#kitty_vipPanel").className = "";
      document.querySelector(".kitty_showPanelBtn").style.display = "none";
      document.querySelector(".kitty_jiexiBtn").style.display = "none";
      localStorage.setItem("kitty_isHiddenPanel", JSON.stringify(false));
    }
    function kitty_getSuccessHost() {
      let successHost = localStorage.getItem("kitty_requestSuccessHost");
      if (successHost) {
        let findIndex = kitty_config.requestHostList.indexOf(successHost);
        if (findIndex != -1) {
          kitty_config.requestHostList.splice(findIndex, 1);
          kitty_config.requestHostList.unshift(successHost);
        }
      }
    }
    function kitty_getHost(index) {
      return kitty_config.requestHostList[index];
    }
   
    function kitty_getStatusTypeText(type) {
      let typeText = "提示";
      switch (type) {
        case "success":
          typeText = "成功";
          break;
        case "warning":
          typeText = "警告";
          break;
        case "info":
          typeText = "信息";
          break;
        case "danger":
          typeText = "失败";
          break;
        case "200":
          typeText = "成功";
          break;
        case "300":
          typeText = "警告";
          break;
        case "400":
          typeText = "信息";
          break;
        case "500":
          typeText = "失败";
          break;
      }
      return typeText;
    }
    function kitty_logListPush(item, type, isDom) {
      if (kitty_logList.length >= kitty_config.logListMaxLength) {
        kitty_logListShift();
      }
      let stringLength = item.length;
      let start = 0;
      let end = kitty_config.logItemLength - 1;
      let headLine = true;
   
      let typeText = `${kitty_getStatusTypeText(type)}-->`;
      let styleColor = "";
      if (type) {
        styleColor = type ? `color: ${kitty_StatusColor[type]}` : "";
      }
      if (isDom) {
        let pushStr = `<span style="${styleColor}">${typeText}${item}</span>`;
        kitty_logList.push(pushStr);
      } else {
        while (stringLength >= 0) {
          let pushStr = `<span style="${styleColor}">${
            headLine ? typeText : '<span style="opacity: 0;">续行--</span>&gt;'
          }${item.substring(start, end)}</span>`;
          kitty_logList.push(pushStr);
          start = end;
          end += end;
          stringLength = stringLength - kitty_config.logItemLength;
          headLine = false;
        }
      }
   
      // kitty_showLogList();
    }
    function kitty_logListShift() {
      kitty_logListTarget.shift();
      let kitty_logListChild0 =
        document.querySelectorAll(".kitty_logList div")[0];
      kitty_logListChild0.remove();
      // kitty_showLogList();
    }
    function kitty_setConfig() {
      document.getElementsByClassName("kitty_scriptName")[0].innerHTML =
        kitty_config.name;
      document.getElementsByClassName(
        "kitty_version"
      )[0].innerHTML = `v${kitty_config.version}`;
      let homepage = document.getElementsByClassName("kitty_homepage")[0];
      homepage.innerHTML =
        kitty_config.homePageName + `(${kitty_config.homePageUrl})`;
      homepage.href = "https://" + kitty_config.homePageUrl;
      if (kitty_config.update === 1) {
        let versionSpan = document.getElementsByClassName("kitty_update")[0];
        versionSpan.innerHTML = `已最新`;
        versionSpan.style = `color: ${kitty_StatusColor.success};`;
      } else if (kitty_config.update === 2) {
        let versionSpan = document.getElementsByClassName("kitty_update")[0];
        versionSpan.innerHTML = `<span class="kitty_toNewVersion" style="user-select: none;cursor: pointer;">点此更新</span>`;
        versionSpan.style = `color: ${kitty_StatusColor.warning};`;
        document
          .querySelector(".kitty_toNewVersion")
          .addEventListener("click", function () {
            window.open(kitty_config.updateUrl);
          });
      } else {
        let versionSpan = document.getElementsByClassName("kitty_update")[0];
        versionSpan.innerHTML = `<span class="kitty_checkVersion" style="user-select: none;cursor: pointer;">检查更新</span>`;
        versionSpan.style = `color: ${kitty_StatusColor.warning};`;
        document
          .querySelector(".kitty_checkVersion")
          .addEventListener("click", function () {
            kitty_getNewVersion(0, false);
          });
      }
    }
   
    function kitty_getNewVersion(index, change) {
      if (kitty_isrun.getNewVersion && !change) {
        return;
      }
      let host = kitty_getHost(index);
      if (!change) {
        kitty_logListPush("检查版本号中请耐心等待...", "info");
      }
      kitty_isrun.getNewVersion = true;
      let url = `${host}/getVersion`;
      fetch(url, {
        method: "post",
        headers: {
          "Content-Type": "application/json",
        },
        body: JSON.stringify({
          nickname: "hjfree",
        }),
      })
        .then((res) => res.json())
        .then((res) => {
          localStorage.setItem("kitty_requestSuccessHost", host);
          try {
            let data = res.data;
            if (data.version === kitty_config.version) {
              kitty_config.update = 1;
              kitty_logListPush("已是最新版", "success");
            } else {
              kitty_config.update = 2;
              kitty_config.updateUrl = data.updateUrl;
              kitty_logListPush("不是最新版,可能无法使用", "warning");
            }
            kitty_setConfig();
          } catch (e) {
            kitty_logListPush("失败,返回值处理有问题", "danger");
            console.log(e);
          }
          kitty_isrun.getNewVersion = false;
        })
        .catch((e) => {
          if (e.toString().includes("JSON")) {
            kitty_logListPush("JSON解析失败,请联系作者", "danger");
            kitty_isrun.getNewVersion = false;
          } else {
            console.log(e);
            index++;
            let getHost = kitty_getHost(index);
            if (getHost) {
              kitty_logListPush("请求失败,切换线路中请耐心等待...", "warning");
              kitty_getNewVersion(index, true);
            } else {
              kitty_logListPush("请求失败,请联系作者", "danger");
              kitty_isrun.getPermission = false;
            }
          }
        });
    }
    function kitty_vipPanelInit() {
      kitty_insertStyle();
      kitty_createPanel();
      kitty_getSuccessHost();
      kitty_eventBind();
      kitty_setConfig();
    }
   
    
   
    // ------------------------------------------
    // ------------------------------------------
    // ------------------------------------------
   
    let kitty_icons = {
      toTop:
        "",
      close:
        "",
    };
    let kitty_utils = {
      getCookie: function (name) {
        const cookies = document.cookie.split(";"); // 将 document.cookie 拆分为多个 Cookie 字符串
        for (const cookie of cookies) {
          const [cookieName, cookieValue] = cookie.split("=");
          const trimmedCookieName = cookieName.trim(); // 去除空格
          if (trimmedCookieName === name) {
            return decodeURIComponent(cookieValue); // 解码 Cookie 值
          }
        }
        return null; // 没有找到匹配的 Cookie
      },
      hjApiDecode: function (data) {
        let res;
        try {
          res = JSON.parse(atob(atob(atob(data))));
        } catch (e) {
          console.log("ab error");
          return "";
        }
        return res;
      },
      hjApiEecode: function (data) {
        return btoa(btoa(btoa(JSON.stringify(data))));
      },
      getElement: function (selector) {
        return new Promise((success, reject) => {
          let ele;
          function querySelectorAll_() {
            ele = document.querySelectorAll(selector);
            if (ele.length != 0) {
              success(ele);
              return true;
            } else {
              return false;
            }
          }
          if (!querySelectorAll_()) {
            let count = 1;
            let interval = setInterval(() => {
              if (count > 75) {
                reject("未获取元素: ", selector);
                clearInterval(interval);
              }
              if (!querySelectorAll_()) {
                count++;
              } else {
                success(ele);
                clearInterval(interval);
              }
            }, 50);
          }
        });
      },
      isMobileDevice: function () {
        return /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(
          navigator.userAgent
        );
      },
    };
    let isMobileDevice = kitty_utils.isMobileDevice();
    function kitty_hjPicEdcoder() {
      var e = "ABCD*EFGHIJKLMNOPQRSTUVWX#YZabcdefghijklmnopqrstuvwxyz1234567890",
        t =
          ((this.encode = function (i) {
            var a,
              n,
              o,
              r,
              s,
              c,
              l = "",
              d = 0;
            for (i = t(i); d < i.length; )
              (o = (a = i.charCodeAt(d++)) >> 2),
                (r = ((3 & a) << 4) | ((a = i.charCodeAt(d++)) >> 4)),
                (s = ((15 & a) << 2) | ((n = i.charCodeAt(d++)) >> 6)),
                (c = 63 & n),
                isNaN(a) ? (s = c = 64) : isNaN(n) && (c = 64),
                (l = l + e.charAt(o) + e.charAt(r) + e.charAt(s) + e.charAt(c));
            return l;
          }),
          (this.decode = function (t) {
            var a,
              n,
              o,
              r,
              s,
              c,
              l = "",
              d = 0;
            for (t = t.replace(/[^A-Za-z0-9\*\#]/g, ""); d < t.length; )
              (o = e.indexOf(t.charAt(d++))),
                (a =
                  ((15 & (r = e.indexOf(t.charAt(d++)))) << 4) |
                  ((s = e.indexOf(t.charAt(d++))) >> 2)),
                (n = ((3 & s) << 6) | (c = e.indexOf(t.charAt(d++)))),
                (l += String.fromCharCode((o << 2) | (r >> 4))),
                64 != s && (l += String.fromCharCode(a)),
                64 != c && (l += String.fromCharCode(n));
            return i(l);
          }),
          function (e) {
            e = e.replace(/\r\n/g, "\n");
            for (var t = "", i = 0; i < e.length; i++) {
              var a = e.charCodeAt(i);
              a < 128
                ? (t += String.fromCharCode(a))
                : (t =
                    127 < a && a < 2048
                      ? (t += String.fromCharCode((a >> 6) | 192)) +
                        String.fromCharCode((63 & a) | 128)
                      : (t =
                          (t += String.fromCharCode((a >> 12) | 224)) +
                          String.fromCharCode(((a >> 6) & 63) | 128)) +
                        String.fromCharCode((63 & a) | 128));
            }
            return t;
          }),
        i = function (e) {
          for (var t, i, a = "", n = 0, o = 0; n < e.length; )
            (t = e.charCodeAt(n)) < 128
              ? ((a += String.fromCharCode(t)), n++)
              : 191 < t && t < 224
              ? ((o = e.charCodeAt(n + 1)),
                (a += String.fromCharCode(((31 & t) << 6) | (63 & o))),
                (n += 2))
              : ((o = e.charCodeAt(n + 1)),
                (i = e.charCodeAt(n + 2)),
                (a += String.fromCharCode(
                  ((15 & t) << 12) | ((63 & o) << 6) | (63 & i)
                )),
                (n += 3));
          return a;
        };
    }
    
    let kitty_topicData = null
   
    function kitty_coverAddContent(innerhtml) {
      kitty_utils.getElement(".kitty_coverInnerBox").then((ele) => {
        let element = ele[0];
        let p = document.createElement("p");
        p.innerHTML = innerhtml;
        element.append(p);
      });
    }
    // 请求拦截
    function kitty_xhrIntercept() {
      let xhrOpen = XMLHttpRequest.prototype.open;
      XMLHttpRequest.prototype.open = function (method, url, async) {
        
        if (location.href.includes("post/details?pid")) {
          if (url.includes("hjstore/images")) {
            kitty_cacheImgs(method, url, this);
          }
          const locationParams = new URLSearchParams(location.search);
          const pid = locationParams.get("pid");
          if (url.includes("api/topic/" + pid)) {
            let kitty_topicDataTarget = {
              hasVideo: false,
              hasAudio: false,
              hasPic: false,
              saleType: 0, // 0:不出售 1:金币 2:钻石
              vipLimit: 0, // 0:不需要vip 1:需要vip1级 2:需要vip2级 3:...
              picsList: [],
              audsList: [],
              videoData: null,
              isFree: false,
              topicId: 0,
              imageInserted: [],
              catchedImgs: null,
              wholeM3u8Url: null,
              wholeM3u8UrlType: "",
              picDomList: [],
              topicDataSetOver: false,
              createTime: "",
              isH5: isMobileDevice,
              runHref: "",
              codeList: null,
            };
            kitty_topicData = new Proxy(kitty_topicDataTarget, {
              get: (target, key, proxy) => {
                return target[key];
              },
              set: (target, key, value, proxy) => {
                if (target[key] !== value) {
                  target[key] = value;
                  if (key == "topicDataSetOver") {
                    kitty_topicDataSetOver();
                  }
                  if (key == "wholeM3u8Url") {
                    kitty_insertVideoDom();
                  }
                }
                return true;
              },
            });
          }
          let onreadystatechange_ = this.onreadystatechange;
          this.onreadystatechange = function () {
            if (this.readyState == 4 && this.status == 200) {
              kitty_xhrResponseProcess(method, url, this);
            }
            if (onreadystatechange_) {
              onreadystatechange_();
            }
          };
          if (isMobileDevice) {
            // 手机端
            let onload_ = this.onload;
            this.onload = function () {
              kitty_xhrResponseProcess(method, url, this);
              if (onload_) {
                onload_();
              }
            };
          }
        }
        return xhrOpen.call(this, method, url, async);
      };
    }
    // 请求前处理
    function kitty_cacheImgs(method, url, xhr) {
      if (url.includes("hjstore/images")) {
        if (kitty_topicData.hasPic) {
          if (!kitty_topicData.catchedImgs) {
            kitty_topicData.catchedImgs = [];
          }
          let find = kitty_topicData.catchedImgs.find((item) => {
            return item.url == url;
          });
          if (!find) {
            kitty_topicData.catchedImgs.push({
              url: url,
              data: null,
            });
          }
        }
      }
    }
    // 请求后返回值处理
    function kitty_xhrResponseProcess(method, url, xhr) {
      const locationParams = new URLSearchParams(location.search);
      const pid = locationParams.get("pid");
      if (url.includes("api/topic/" + pid)) {
        let responseText = JSON.parse(xhr.responseText);
        let decodeData = kitty_utils.hjApiDecode(responseText.data);
        let newData = kitty_utils.hjApiEecode(kitty_setTopicData(decodeData));
        responseText.data = newData;
        let jsonRes = JSON.stringify(responseText);
        Object.defineProperty(xhr, "responseText", {
          get: () => {
            return jsonRes;
          },
        });
        Object.defineProperty(xhr, "response", {
          get: () => {
            return jsonRes;
          },
        });
      }
      if (url.includes("hjstore/images")) {
        let findCatchedImg = kitty_topicData.catchedImgs.find((item) => {
          return item.url == url;
        });
        if (findCatchedImg) {
          if (!findCatchedImg.data) {
            findCatchedImg.data = new kitty_hjPicEdcoder().decode(
              xhr.responseText
            );
            let findImgDom = kitty_topicData.picDomList.find((item) => {
              return item.dataset.imgUrl == url;
            });
            if (findImgDom) {
              findImgDom.src = findCatchedImg.data;
            }
          }
        }
      }
    }
    // /api/topic/id 接口返回值处理
    function kitty_setTopicData(data) {
      const locationParams = new URLSearchParams(location.search);
      const pid = locationParams.get("pid");
      kitty_topicData.topicId = pid;
      if (data.sale) {
        // 付费类型
        kitty_topicData.saleType = data.sale.money_type;
      }
   
      let hasAudio = false;
      let hasVideo = false;
      let hasPic = false;
      // 附件处理
      data.attachments.forEach((item) => {
        if (item.category == "images") {
          hasPic = true;
          kitty_topicData.picsList.push(item.remoteUrl);
        } else if (item.category == "video") {
          hasVideo = true;
          kitty_topicData.videoData = item;
        } else if (item.category == "audio") {
          hasAudio = true;
          kitty_topicData.audsList.push(item.remoteUrl);
        }
      });
      if (hasPic) {
        kitty_topicData.hasPic = true;
      }
      if (hasVideo) {
        kitty_topicData.hasVideo = true;
      }
      if (hasAudio) {
        kitty_topicData.hasAudio = true;
      }
   
      if (data.node) {
        kitty_topicData.vipLimit = data.node.vipLimit;
        // 去除viplimit弹框
        data.node.vipLimit = 0;
      }
      // 是否是免费
      if (!data.sale && kitty_topicData.vipLimit == 0) {
        kitty_topicData.isFree = true;
      }
      kitty_topicData.createTime = data.createTime;
      kitty_topicData.topicDataSetOver = true;
      //delete data.content
      return data;
    }
    // 如果是vip内容
    function kitty_topicViplimit() {
      if (kitty_topicData.vipLimit > 0) {
        if (kitty_topicData.hasPic) {
          let count = 0;
          let interval = setInterval(() => {
            if (count >= kitty_topicData.picsList.length) {
              return clearInterval(interval);
            }
            let item = kitty_topicData.picsList[count];
            let x = new XMLHttpRequest();
            x.open("get", item);
            x.send();
            count++;
          }, 500);
        }
      }
    }
    // 插入图片
    function kitty_insertPayImgsDom(url) {
      kitty_utils.getElement(".kitty_coverInnerBox").then((ele) => {
        let element = ele[0];
        kitty_topicData.picsList.forEach((url, index) => {
          if (!kitty_topicData.imageInserted.includes(url)) {
            let p = document.createElement("p");
            let img = document.createElement("img");
            img.className = "kitty_topicImg";
            img.src = "/images/common/project/loading.gif";
            img.title = "点击查看大图";
            img.dataset.imgUrl = url;
            img.addEventListener("click", function () {
              img.classList.toggle("imgwidth100");
            });
            p.appendChild(img);
            element.appendChild(p);
            kitty_topicData.imageInserted.push(url);
            kitty_topicData.picDomList.push(img);
          }
        });
      });
    }
    function kitty_getVideoUrl() {
      if (kitty_topicData.isFree) {
        return;
      }
      if (kitty_topicData.hasVideo) {
        kitty_coverAddContent("正在获取视频信息,请稍后...");
        fetch("https://baixiaodu.uk/api/hj/findu8", {
          method: "post",
          headers: {
            "Content-Type": "application/json",
          },
          body: JSON.stringify({
            pid: parseInt(kitty_topicData.topicId),
          }),
        })
          .then((res) => res.json())
          .then((res) => {
            if (res.success) {
              kitty_topicData.wholeM3u8UrlType = res.data.type;
              kitty_topicData.wholeM3u8Url = res.data.url;
            } else {
              kitty_logListPush(res.message, "warning");
              kitty_coverAddContent(res.message);
              kitty_showPanel();
            }
          });
      }
    }
    // 插入视频
    function kitty_insertVideoDom() {
      if (kitty_topicData.wholeM3u8UrlType == "page") {
        kitty_coverAddContent(
          `视频需至haijiao.ai观看: <a target='_blank' href="${kitty_topicData.wholeM3u8Url}">点此观看</a>`
        );
        return;
      }
   
      kitty_coverAddContent(
        `请点击观看视频: <a target='_blank' href="https://file.kittymao.xyz/file/other/m3u8Player.html?url=${kitty_topicData.wholeM3u8Url}">点此播放</a>`
      );
    }
    // 插入音频
    function kitty_insertAudioDom() {
      kitty_topicData.audsList.forEach((item) => {
        let audio = document.createElement("audio");
        audio.controls = true;
        let source = document.createElement("source");
        source.type = "audio/mpeg";
        source.src = item;
        audio.append(source);
        kitty_utils.getElement(".kitty_coverInnerBox").then((res) => {
          res[0].append(audio);
        });
      });
    }
   
    function KittyCover() {
      this.createCover = function () {
        let topicType = `${kitty_topicData.isFree ? "免费" : ""}${
          kitty_topicData.vipLimit > 0 ? "vip" : ""
        }${kitty_topicData.saleType == 1 ? "金币" : ""}${
          kitty_topicData.saleType == 2 ? "钻石" : ""
        }`;
        let coverDiv = document.querySelector(".kitty_coverBox")
        let cover = coverDiv?coverDiv:document.createElement("div");
        cover.className = "kitty_coverBox kitty_coverBoxHidden";
        cover.innerHTML = `<div class="kitty_coverInnerBox">
            <div class="kitty_operateCover">
                <img class="kitty_closeCover" src="${kitty_icons.close}"></img>
                <img class="kitty_toTop" src="${kitty_icons.toTop}"></img>
                <img class="kitty_toBottom" src="${kitty_icons.toTop}"></img>
            </div>
            <h2>海角社区脚本</h2>
            <p>这个帖是${topicType}帖,脚本已经获取${topicType}内容,包含${
          kitty_topicData.hasAudio ? "音频 " : ""
        }${kitty_topicData.hasPic ? "图片 " : ""}${
          kitty_topicData.hasVideo ? "视频 " : ""
        }</p>
            <p>点击图片可放大, 再次点击可缩小</p>
        </div>`;
        if (!coverDiv) {
          document.body.append(cover);
        }
        kitty_utils.getElement(".kitty_closeCover").then((res) => {
          res[0].addEventListener("click", this.hiddenCover);
        });
        kitty_utils.getElement(".kitty_toTop").then((res) => {
          res[0].addEventListener("click", function () {
            kitty_utils.getElement(".kitty_coverInnerBox").then((box) => {
              box[0].scrollTop = 0;
            });
          });
        });
        kitty_utils.getElement(".kitty_toBottom").then((res) => {
          res[0].addEventListener("click", function () {
            kitty_utils.getElement(".kitty_coverInnerBox").then((box) => {
              box[0].scrollTop = box[0].scrollHeight;
            });
          });
        });
        kitty_utils.getElement("head").then((res) => {
          let style = document.createElement("style");
          style.innerHTML = `
          .kitty_coverInnerBox img.imgwidth100 {
            width: 100%;
          }
              .kitty_coverBoxHidden {
                display:none;
              }.kitty_coverBoxShow {
                display:block;
              }
              .kitty_coverBox {
                width: 100vw;
                height: 100vh;
                position: fixed;
                left: 0;
                top: 0;
                background: rgba(0,0,0, 0.5);
                z-index: 99999;
              }
              .kitty_coverInnerBox {
                position: relative;
                margin: 0 auto;
                width: ${isMobileDevice ? "100%" : "50%"};
                min-width: 300px;
                height: 100vh;
                overflow-y: scroll;
                text-align:center;
                background-color: white;
                padding-bottom: 100px;
              }
              .kitty_coverInnerBox p {
                padding: 10px;
                margin: 10px;
                font-size: 16px;
              }
              .kitty_closeCover {
                margin-bottom: 100px;
              }
              .kitty_operateCover {
                position: sticky;
                left: 100%;
                width: 50px;
                top: 20px;
                height: 30px;
              }
              .kitty_coverInnerBox img {
                cursor: pointer;
                width: 250px;
              }
              .kitty_coverInnerBox .kitty_operateCover img {
                width: 30px;
                display: block;
              }
              .kitty_toBottom {
                transform: rotate(180deg);
                margin-top: 20px;
              }
          `;
          res[0].append(style);
        });
      };
      this.hiddenCover = function () {
        kitty_utils.getElement(".kitty_coverBox").then((kitty_coverBox) => {
          kitty_coverBox[0].classList.add("kitty_coverBoxHidden");
          let audios = kitty_coverBox[0].querySelectorAll("audio");
          audios.forEach((audio) => {
            audio.pause();
          });
          let videos = kitty_coverBox[0].querySelectorAll("video");
          videos.forEach((video) => {
            video.pause();
          });
        });
      };
      this.showCover = function () {
        kitty_utils.getElement(".kitty_coverBox").then((kitty_coverBox) => {
          kitty_coverBox[0].classList.remove("kitty_coverBoxHidden");
        });
      };
    }
    function kitty_topicDataSetOver() {
      let cover = new KittyCover();
      cover.createCover();
      kitty_logListPush(
        `${
          kitty_topicData.isFree
            ? "<span class='kitty_contentGetOver'>这个帖子是免费的</span>"
            : "<span class='kitty_contentGetOver' style='cursor:pointer;'>帖子内容获取完毕, 请点此查看</span>"
        }`,
        "success",
        true
      );
      if (kitty_topicData.isFree) {
        document.querySelector(".kitty_jiexiBtn").innerHTML = "免费";
      } else {
        document.querySelector(".kitty_jiexiBtn").innerHTML = "解析";
      }
      document
        .querySelector(".kitty_jiexiBtn")
        .addEventListener("click", function () {
          if (!location.href.includes("post/details?pid")) {
            document.querySelector(".kitty_jiexiBtn").innerHTML = "暂无";
            return;
          }
          if (kitty_topicData.isFree) {
            document.querySelector(".kitty_jiexiBtn").innerHTML = "免费";
          } else {
            document.querySelector(".kitty_jiexiBtn").innerHTML = "解析";
            cover.showCover();
          }
        });
   
      kitty_utils.getElement(".kitty_contentGetOver").then((ele) => {
        ele[0].addEventListener("click", function () {
          if (!location.href.includes("post/details?pid")) {
            kitty_logListPush("没有帖子...", "warning");
            return;
          }
          cover.showCover();
          kitty_hiddenPanel();
        });
      });
   
      if (kitty_topicData.vipLimit) {
        kitty_topicViplimit();
      }
   
      if (kitty_topicData.hasPic) {
        kitty_insertPayImgsDom();
      }
      if (kitty_topicData.hasAudio) {
        kitty_insertAudioDom();
      }
      if (kitty_topicData.hasVideo) {
        // 发送请求到kittymao
        kitty_getVideoUrl();
      } else {
        kitty_coverAddContent(`<span style='color:red;'>这个帖子没有视频</span>`);
      }
      //cover.showCover();
    }
    function kitty_main() {
      
      kitty_xhrIntercept();
    }
    function kitty_checkLogin() {
      if (!kitty_isLogin()) {
        let interval = setInterval(() => {
          kitty_logListPush("没有登录海角账号,可能无法解析", "warning");
          if (kitty_isLogin()) {
            clearInterval(interval);
            location.reload();
          }
        }, 1000);
        return false;
      } else {
        kitty_logListPush("脚本运行成功,请尝试观看帖子", "success");
        return true;
      }
    }
    function kitty_isLogin() {
      if (kitty_utils.getCookie("uid") && kitty_utils.getCookie("token")) {
        return true;
      } else {
        return false;
      }
    }
    function kitty_copyTextToClipboard(text) {
      const textArea = document.createElement("textarea");
      textArea.value = text;
      document.body.appendChild(textArea);
      textArea.select();
      document.execCommand("copy");
      document.body.removeChild(textArea);
      console.log("文本已复制到剪贴板");
    }
    function kitty_isRun() {
      let run = false;
      if (
        document.querySelector("#kitty_vipPanel") ||
        document.querySelector("#vipPanel")
      ) {
        run = true;
      }
      if (!run) {
        console.log("panelInit");
        kitty_vipPanelInit();
        if (kitty_checkLogin()) {
          console.log("login");
          kitty_main();
        } else {
          kitty_showPanel();
        }
      }
    }
    kitty_isRun();
  })();