// ==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">点此隐藏此脚本操作界面<<</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>>'
}${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();
})();