// ==UserScript==
// @name VIP会员视频在线解析大集合
// @namespace https://greasyfork.org/zh-CN/users/505018
// @iconURL https://v.qq.com/favicon.ico
// @version 1.0.3
// @description [腾讯|爱奇艺|优酷|乐视|芒果|AB站|音悦台]等VIP或会员视频,在线解析接口插件
// @author DreamFly
// @noframes
// @match http*://v.qq.com/x/cover/*
// @match http*://*.iqiyi.com/v*
// @match http*://v.youku.com/v_show/*
// @match http*://*.le.com/*
// @match http*://*.letv.com/*
// @match http*://*.tudou.com/*
// @match http*://*.mgtv.com/*
// @match http*://film.sohu.com/*
// @match http*://tv.sohu.com/*
// @match http*://*.acfun.cn/v/*
// @match http*://*.bilibili.com/*
// @match http*://vip.1905.com/play/*
// @match http*://*.pptv.com/*
// @match http*://v.yinyuetai.com/video/*
// @match http*://v.yinyuetai.com/playlist/*
// @match http*://*.fun.tv/vplay/*
// @match http*://*.wasu.cn/Play/show/*
// @match http*://*.56.com/*
// @exclude http*://*.bilibili.com/blackboard/*
// @grant GM.getValue
// @grant GM.setValue
// @grant GM_getValue
// @grant GM_setValue
// @grant unsafeWindow
// @grant GM_xmlhttpRequest
// @grant GM.xmlHttpRequest
// @grant GM_openInTab
// @grant GM.openInTab
// ==/UserScript==
(function() {
'use strict';
const VQQIcon = '<svg height="1.2em" width="1.2em" viewbox="0 0 185 170"><defs><path id="vQQ" d="M7 20 Q14 -10 55 7 Q100 23 145 60 Q170 80 145 102 Q108 138 47 165 Q15 175 4 146 Q-5 80 7 20"></path></defs><use style="fill:#44B9FD;" transform="translate(27,0)" xlink:href="#vQQ"></use><use style="fill:#FF9F01;" transform="translate(0,18),scale(0.8,0.75)" xlink:href="#vQQ"></use><use style="fill:#97E61B;" transform="translate(23,18),scale(0.80.75)" xlink:href="#vQQ"></use><use style="fill:#fff;" transform="translate(50,45),scale(0.4)" xlink:href="#vQQ"></use></svg>';
const IQiyiIcon = '<svg xmlns="http://www.w3.org/2000/svg" x="0" y="0" width="12" height="12"><image width="12" height="12" x="0" y="0" href=" AAB6JgAAgIQAAPoAAACA6AAAdTAAAOpgAAA6mAAAF3CculE8AAAABmJLR0T///////8JWPfcAAAA B3RJTUUH4wgJFC0QN86G4AAAA8FJREFUOMsFwX1MlHUAwPHv73meu5PjnWMSkSZYDHRuzj8UEbXN CudEQXQunAOzWnO1+V5BC5i6U7NcqPmW4cK0mSaWIYWJQbrKNSCiVGwnKHpyceDD2z33PPf8+nyE c/judTh3jQamQ2GZ7KALVJ/soxtA5tEDwBkeA6ARBqCIWABxjWcBRCI5AGI2z0NkKkX4of6kcMZ3 u8FUtZep13Zplme9OsPjh8Sl6s7EnyC6Rfkz5mlwbRVB5+dANhGRAeF+OdlogZG37byRKTDksvcN HYSBYqtt4DqEe8gyf7Y0kZx150psh5Tlucn5H3wI6XOV/Rn7QLetXL0XzDq5x/wM7DRZZieCXMYd uQTUcXFTBVwlSvuEzRC9RPW4C+DhXftgXwvsXDhQUd0JWmoueWmLIcFt3UisgOOr9DnHciA1yrE9 tQru9Zu7fT/AvQ7zG58B7iPKafdfoFVxWTsB+opIly5g2rDz9PTbULgvzrviCDzj4/CkvaCJ3Eir 2A4PDhiLHpyD/A1x8xaXQ/JsdifnQ/ze+OL4m9CxJxRoL4CYI+LNGBU8L2plHjfoL8iA/hqELlsF 4W0Q9bX6vdsBCRPF/oRaUBw75B5HMyQsUI2EcYhtZU7MGugtNk/dbwe73z4kN0L0CZke7YbRj6zV YzXwz9nR0VvLYEV03L8rl8B1j36q9SJMaBFRrpdAO2Ab2gNQ3CVybfS3MMXrqkyfBsph2a02AXX2 PO4DvfIWIcBvzweQbfKCXQu/TNNLW9PAVzxe6/NB++8jt9s6QZkrtyk5QE9kHYAS2RDZFCmHcZ/V O74Y+meFegOX4Lkapzb1PrjWYjjjYKzQzBkvhHC7NSncBU8qTNdQJvStNi48fAfGqqzvxtJhNGJO HTsKps9Ktx6Bps8xFj3JgsH1xuygA85/2b/1bBdMXCMcKQZk/u1uzUyCplf0vh+/AP1Xe7peDEPL ZdLgVdj1ru+r6hhwNyp/uL3wX6PRF6iB4KdGVrASNH9BKOzXwVpgLYy8Du95J22pOAPB49beoBfC Jfal8ElIb499I6MH5HzxvqwCx0bqHevAuVJsdh6FxAa1JakDAtmhmYFK8BeFmh/FgtDym7PBdDob I1tcqZrx1BQlLSUFkoJaadJGiKlVumN7wHVD2eTSgIWYzIJwtX0gvBqG6+yS4VIYfMs6HRwEf5P9 yeMGMPJVbyhoOYUj7aoK5yfLHXIAlsfJj6kBtdP+TW4DIA8vgDzGFQAkQQBRwioAmigHUGaKQwCi mlchMkMcFh64OPI/QLSjdm0wihoAAAAldEVYdGRhdGU6Y3JlYXRlADIwMTktMDgtMTBUMDM6NDU6 MTYtMDc6MDBV2/HBAAAAJXRFWHRkYXRlOm1vZGlmeQAyMDE5LTA4LTEwVDAzOjQ1OjE2LTA3OjAw JIZJfQAAABl0RVh0U29mdHdhcmUAQWRvYmUgSW1hZ2VSZWFkeXHJZTwAAAAASUVORK5CYII="/></svg>';
const YoukuIcon = '<svg width="1.2em" height="1.2em" viewbox="0 0 72 72"><defs><circle id="youkuC1" r="5.5" style="stroke:none;;fill:#0B9BFF;"></circle><path id="youkuArow" d="m0,10 a5,5 0,0,1 0,-10 h20 a5,5 0,0,1 0,10z" style="fill:#FF4242;"></path></defs><circle cx="36" cy="36" r="30.5" style="stroke:#30B4FF;stroke-width:11;fill:none;"></circle><use x="10.5" y="19" xlink:href="#youkuC1"/><use x="61.5" y="53" xlink:href="#youkuC1"/><use x="39" y="1" transform="rotate(30)" xlink:href="#youkuArow"/><use x="-1" y="52" transform="rotate(-35)" xlink:href="#youkuArow"/></svg>';
var websites = [/qq.com/i, /iqiyi.com/i, /youku.com/i]
var webIcons = [VQQIcon, IQiyiIcon, YoukuIcon]
var icon = '';
for (let i in websites) {
if (websites[i].test(location.href)) {
icon = webIcons[i];
}
}
var defaultApi = {
title: "618G,失效请更换接口",
url: "http://jx.618g.com/?url="
};
//fixedApis name:显示的文字 url:接口 title:提示文字 intab:是否适合内嵌(嵌入判断:GMgetValue("replaceRaw",false)值||intab值)
var fixedApis = [
{ name: "618G" + icon, url: "http://jx.618g.com/?url=", title: "618G", intab: 0 },
{ name: "玩的嗨" + icon, url: "http://tv.wandhi.com/go.html?url=", title: "综合接口,一键VIP*** 更新可用【作者mark zhang】脚本的接口", intab: 0 },
{ name: "搜你妹" + icon, url: "http://www.sonimei.cn/?url=", title: "综合接口,VIP视频*** 更新可用【作者sonimei134】脚本的接口", intab: 0 },
{ name: "TIMERD" + icon, url: "https://timerd.me/static/cv.html?zwx=", title: "不稳定,广告过滤软件可能有影响", intab: 1 },
{ name: "石头解析" + icon, url: "https://jiexi.071811.cc/jx.php?url=", title: "手动点播放", intab: 1 },
{ name: "乐乐云" + icon, url: "https://660e.com/?url=", title: "乐乐云,未知效果", intab: 1 },
{ name: "无名小站" + icon, url: "http://www.sfsft.com/admin.php?url=", title: "无名小站同源", intab: 1 },
{ name: "无名小站2" + icon, url: "http://www.wmxz.wang/video.php?url=", title: "转圈圈就换线路", intab: 1 },
{ name: "人人发布" + icon, url: "http://v.renrenfabu.com/jiexi.php?url=", title: "综合,多线路", intab: 0 },
{ name: "金桥解析" + icon, url: "http://jqaaa.com/jx.php?url=", title: "金桥解析接口", intab: 0 },
{ name: "927解析" + icon, url: "http://api.927jx.com/vip/?url=", title: "927解析接口", intab: 0 },
{ name: "古思视频" + icon, url: "https://api.sigujx.com/?url=", title: "古思视频解析接口", intab: 0 },
{ name: "yangju视频" + icon, url: "http://cdn.yangju.vip/k/?url=", title: "yangju,未知效果", intab: 0 },
{ name: "古思解析" + icon, url: "https://jsap.attakids.com/?url=", title: "古思解析", intab: 0 },
{ name: "17Kyun解析" + icon, url: "http://17kyun.com/api.php?url=", title: "17Kyun解析", intab: 0 },
{ name: "人人视频解析" + icon, url: "https://vip.mpos.ren/v/?url=", title: "人人视频解析", intab: 0 },
{ name: "云网解析" + icon, url: "https://www.41478.net/?url=", title: "云网解析", intab: 0 }
];
var cssStyle = `
/*TMDFVideoContainer*/
#TMDFVideoContainer {
z-index: 999998;
background: rgba(0, 0, 0, .7);
position: fixed;
top: 7em;
left: 5em;
height: 65%;
width: 65%;
resize: both;
overflow: auto;
box-shadow: 2px 2px 5px 5px rgba(125, 125, 250, .8);
}
#TMDFVideoContainer button {
top: .1em;
cursor: pointer;
visibility: hidden;
font-size: 3em;
color: #ffffffff;
background: transparent;
border: 0;
}
#TMDFVideoContainer:hover button {
visibility: visible;
}
#TMDFVideoContainer:hover button:hover {
color: #ff0;
}
/*TMDFIframe*/
#TMDFiframe {
height: 100%;
width: 100%;
overflow: auto;
position: absolute;
top: 0;
left: 0;
margin: auto;
border: 0;
box-shadow: 0 0 3em rgba(0, 0, 0, .4);
z-index: -1;
}
/*TMDFVideoSetting*/
#TMDFVideoSetting {
text-align: center;
}
/*TMDFCustomApi*/
#TMDFCustomApi li {
margin: 5px;
width: 100%;
list-style-type: none;
}
/*TMDFul*/
#TMDFul {
position: fixed;
top: 5em;
left: 0;
padding: 0;
z-index: 999999;
}
#TMDFul li {
list-style: none;
}
#TMDFul svg {
float: right;
}
.TMDFul2 {
position: absolute;
top: 0;
left: 1.5em;
display: none;
border-radius: .3em;
margin: 0;
padding: 0;
}
.TMDFul2 li {
float: none;
width: 7em;
margin: 0;
font-size: 1em;
padding: .15em 1em;
cursor: pointer;
color: #3a3a3a!important;
background: rgba(125, 125, 250, 0.8);
}
.TMDFul2 li:hover {
color: white!important;
background: rgba(0, 0, 0, .8);
}
.TMDFul2 li:first-child {
border-radius: .35em .35em 0 0;
}
.TMDFul2 li:last-child {
border-radius: 0 0 .35em .35em;
}
.TMDFli1 {
opacity: 0.3;
position: relative;
padding-right: .5em;
width: 1.5em;
cursor: pointer;
}
.TMDFli1:hover {
opacity: 1;
}
.TMDFli1 span {
display: block;
border-radius: 0 .3em .3em 0;
background-color: rgba(125, 125, 250, 1.0);
border: 0;
font: bold 1em "微软雅黑"!important;
color: rgb(0, 255, 255);
margin: 0;
padding: 1em .3em;
}
.TMDFli1:hover .TMDFul2 {
display: block;
}
.TMDFli2 {
text-align: center;
}
/*自定义解析接口,本页播放窗口设置*/
.TMDFp {
position: fixed;
top: 20%;
left: 20%;
z-index: 999999;
background: rgba(125, 125, 250, 0.9);
padding: 30px 20px 10px 20px;
border-radius: 10px;
text-align: left;
}
.TMDFp * {
font-size: 16px;
font-family: '微软雅黑';
color: #3a3a3a;
//box-shadow: 0 0 3em rgba(0, 0, 0, .4);
}
.TMDFp fieldset {
margin: 0;
padding: 10px;
}
.TMDFp legend {
padding: 0 10px;
text-align: center;
}
.TMDFp label {
display: inline-block;
}
.TMDFp input[type=text] {
border-radius: 5px !important;
border: 1px solid #3a3a3a;
margin: 2px 10px 2px 5px;
padding: 2px 5px;
}
.TMDFp button {
border: 1px solid #3a3a3a;
border-radius: 5px;
cursor: pointer;
padding: 2px 10px;
margin: 10px 20px 0 20px;
}
.TMDFp button:hover {
background: #3a3a3a;
color: yellow;
}
.TMDFtext1 {
width: 350px;
}
.TMDFtext2 {
width: 160px;
}
.TMDFClose {
position: absolute;
top: 3px;
left: 3px;
margin: 0!important;
}
.TMDFspan80 {
display: inline-block;
text-align: right;
width: 80px;
}
.TMDFspan120 {
display: inline-block;
text-align: right;
width: 120px;
}
.TMDFDelete {
float: left;
display: inline-block;
color: red;
padding: 0 10px !important;
cursor: pointer;
}
.TMDFCheckbox {
margin-left: 4px;
margin-right: 4px;
}
.TMDFName {
}
.TMDFLink {
}
input[type=checkbox] {
-webkit-appearance: checkbox;
}
li:hover .TMDFDelete,
li:hover .TMDFCheckbox,
li:hover .TMDFName,
li:hover .TMDFLink {
background: rgba(73,163,230,0.62);
}
`;
/* 兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+
* 为了兼容GreasyMonkey 4.0 获取结构化数据,比如 json Array 等,
* 应当先将字符串还原为对象,再执行后续操作
* GMgetValue(name,defaultValue)
*/
function GMgetValue(name, defaultValue) {
if (typeof GM_getValue === 'function') {
return GM_getValue(name, defaultValue);
} else {
return GM.getValue(name, defaultValue);
}
}
/* 兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+
* 为了兼容GreasyMonkey 4.0 储存结构化数据,比如 json Array 等,
* 应当先将对象字符串化,
* GMsetValue(name, JSON.stringify(defaultValue))
*/
function GMsetValue(name, defaultValue) {
if (typeof GM_setValue === 'function') {
GM_setValue(name, defaultValue);
} else {
GM.setValue(name, defaultValue);
}
}
/* 兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+ */
function GMxmlhttpRequest(obj) {
if (GM_xmlhttpRequest === "function") {
GM_xmlhttpRequest(obj);
} else {
GM.xmlhttpRequest(obj);
}
}
/* 兼容 Tampermonkey | Violentmonkey | Greasymonkey 4.0+ */
function GMaddStyle(cssText) {
let doc = document.head || document.documentElement;
let tag = document.createElement('style');
tag.textContent = cssText;
doc.appendChild(tag);
}
//开启全屏的element调用,找到支持的方法
function launchFullScreen(element) {
if (element.requestFullscreen) {
element.requestFullscreen();
} else if (element.mozRequestFullScreen) {
element.mozRequestFullScreen();
} else if (element.webkitRequestFullscreen) {
element.webkitRequestFullscreen();
} else if (element.msRequestFullscreen) {
element.msRequestFullscreen();
}
}
//打开视频解析
function openVideoResolve(evt) {
if (evt.target.dataset.intab === '1') {
//如果页面有播放窗口,只需更新播放窗口的 src, 如果没有播放窗口,读取播放窗口位置信息,新建一个播放窗
let iframeTag = document.querySelector('#TMDFiframe');
if (iframeTag === null) {
let videoRect = JSON.parse(GMgetValue('videoRect', '{"left":"0","top":"0","width":"800","height":"600"}'));
let divTag = document.createElement('div');
divTag.id = 'TMDFVideoContainer';
divTag.setAttribute('style', 'left:' + videoRect.left + ';top:' + videoRect.top + ';width:' + videoRect.width + ';height:' + videoRect.height + ';');
divTag.innerHTML = '<button id="TMDFIframeClose" title="关闭">☒</button><button id="TMDFFullScreen" title="全屏">✠</button>';
let iframeTag = document.createElement('iframe');
iframeTag.id = 'TMDFiframe';
iframeTag.allowfullscreen = "true";
iframeTag.src = evt.target.dataset.url + location.href;
divTag.appendChild(iframeTag);
document.body.appendChild(divTag);
document.querySelector('#TMDFIframeClose').addEventListener('click', () => { document.body.removeChild(document.querySelector('#TMDFVideoContainer')); }, false);
document.querySelector('#TMDFFullScreen').addEventListener('click', () => { launchFullScreen(document.querySelector('#TMDFiframe')); }, false);
} else {
iframeTag.src = evt.target.dataset.url + location.href;
}
} else {
//不适合页内播放的,打开新标签
window.open(evt.target.dataset.url + location.href);
}
}
//保存视频设置
function saveVideoSetting() {
var videoRect = {
left: document.querySelector('#TMDFpL').value,
top: document.querySelector('#TMDFpT').value,
width: document.querySelector('#TMDFpW').value,
height: document.querySelector('#TMDFpH').value
};
GMsetValue('videoRect', JSON.stringify(videoRect));
}
//检查是否勾选页内解析
function checkThisPageResolve() {
let enablePageResolve = document.querySelector("#TMDFPageResolve").checked;
GMsetValue("enablePageResolve", enablePageResolve);
var x, arr = document.querySelectorAll('.TMDFul3 li');
for (x = 0; x < arr.length; x++) {
if (enablePageResolve) {
arr[x].addEventListener('click', openVideoResolve, false);
arr[x].setAttribute('onclick','');
} else {
arr[x].removeEventListener('click', openVideoResolve, false);
arr[x].setAttribute('onclick', 'window.open(this.dataset.url + location.href)');
}
}
}
/* 正确选集 */
function rightVideoEpisodes() {
let enableVideoEpisodes = document.querySelector("#TMDFVideoEpisodes").checked;
GMsetValue("enableVideoEpisodes", enableVideoEpisodes);
function getLink(e) {
var target = e.target.parentNode.tagName == "li" ? e.target.parentNode : (e.target.parentNode.parentNode.tagName == "li" ? e.target.parentNode.parentNode : e.target.parentNode.parentNode.parentNode);
if (target.tagName != "li") return;
GMxmlhttpRequest({
method: 'GET',
url: "http://cache.video.qiyi.com/jp/vi/" + target.dataset.videolistTvid + "/" + target.dataset.videolistVid + "/?callback=crackIqiyi",
onload: function(result) {
var crackIqiyi = function(d) { location.href = d.vu; };
eval(result.responseText);
}
});
}
try {
if (enableVideoEpisodes) {
document.querySelector('#widget-dramaseries').addEventListener('click', getLink);
} else {
document.querySelector('#widget-dramaseries').removeEventListener('click', getLink);
}
} catch (e) {}
}
/* 显示增加接口的面板 */
function showAddCustomApiPanel() {
let apiPanel = document.querySelector('#TMDFCustomApi');
if (apiPanel) {
apiPanel.style.display = "block";
} else {
alert(`(● ̄(エ) ̄●)づ\n\n未启用[增加接口]功能\n请把 '▣增加接口'→'☑增加接口'!`);
}
}
/* 勾选自定义接口 */
function checkAddCustomApi() {
let enableCustomApi = document.querySelector('#TMDFAddApi').checked;
GMsetValue('enableCustomApi', enableCustomApi);
if (enableCustomApi) {
showCustomApiPanel();
setTimeout(showAddCustomApiPanel, 200);
}
}
/* 保存按钮执行函数:获取值并 await GM.setValue() */
function getCustomUserApis() {
let userApis = document.querySelectorAll('.TMDFLink');
let apiName = document.querySelector('#TMDFname').value;
let apiUrl = document.querySelector('#TMDFurl').value;
let apiIntab = document.querySelector('#TMDFintab').checked ? 1 : 0;
let customUserApis = [];
if (apiName || apiUrl) {
customUserApis.push({ name: apiName, url: apiUrl, intab: apiIntab });
}
let n, u, l;
for (let i = 0; i < userApis.length; i++) {
u = userApis[i].innerText;
n = userApis[i].previousSibling.innerText.split(':')[0];
l = userApis[i].previousSibling.previousSibling.checked ? '1' : '0';
customUserApis.push({ name: n, url: u, intab: l });
}
return customUserApis;
}
//生成"嵌入页面大小位置设置"面板
function showVideoSettingPanel() {
let videoRect = JSON.parse(GMgetValue('videoRect', '{"left":"0","top":"0","width":"800","height":"600"}'));
let innerHtml = `
<button class="TMDFClose" onclick="document.body.removeChild(this.parentNode)">☒</button>
<fieldset>
<legend>页内播放窗口位置大小</legend>
<li>
<label for="TMDFpL"><span class="TMDFspan80">左边距:</span><input type="text" id="TMDFpL" value="${videoRect.left}" class="TMDFtext2" placeholder='如"300px"或者"65%"'/></label>
<label for="TMDFpT"><span class="TMDFspan80">上边距:</span><input type="text" id="TMDFpT" value="${videoRect.top}" class="TMDFtext2" placeholder='如"300px"或者"65%"'/></label>
</li>
<li>
<label for="TMDFpW"><span class="TMDFspan80">宽度:</span><input type="text" id="TMDFpW" value="${videoRect.width}" class="TMDFtext2" placeholder='如"300px"或者"65%"'/></label>
<label for="TMDFpH"><span class="TMDFspan80">高度:</span><input type="text" id="TMDFpH" value="${videoRect.height}" class="TMDFtext2" placeholder='如"300px"或者"65%"'/></label>
</li>
</fieldset>
<li>
<button id="TMDFSettingCurrentView">获取当前播放窗尺寸</button>
<button id="TMDFSettingPreview">预览</button>
<button id="TMDFSettingSave">保存</button>
</li>`;
let divTag = document.createElement('div');
divTag.id = 'TMDFVideoSetting';
divTag.setAttribute('class', 'TMDFp');
divTag.innerHTML = innerHtml;
document.body.appendChild(divTag);
//添加事件
document.querySelector('#TMDFSettingCurrentView').addEventListener('click', function() {
let videoTag = document.querySelector('#TMDFVideoContainer');
if (videoTag) {
let videoStyle = getComputedStyle(videoTag)
document.querySelector('#TMDFpL').value = videoStyle.left;
document.querySelector('#TMDFpT').value = videoStyle.top;
document.querySelector('#TMDFpW').value = videoStyle.width;
document.querySelector('#TMDFpH').value = videoStyle.height;
}
}, false);
document.querySelector('#TMDFSettingPreview').addEventListener('click', function() {
let videoTag = document.querySelector('#TMDFVideoContainer');
if (videoTag) {
videoTag.style.cssText = ''
videoTag.style.cssText += 'left:' + document.querySelector('#TMDFpL').value + ';';
videoTag.style.cssText += 'top:' + document.querySelector('#TMDFpT').value + ';';
videoTag.style.cssText += 'width:' + document.querySelector('#TMDFpW').value + ';';
videoTag.style.cssText += 'height:' + document.querySelector('#TMDFpH').value + ';';
}
}, false);
document.querySelector('#TMDFSettingSave').addEventListener('click', function() {
saveVideoSetting();
setTimeout(function() { document.body.removeChild(document.querySelector("#TMDFVideoSetting")); }, 30);
}, false);
}
/* 生成增加接口面板 */
function showCustomApiPanel() {
let innerHtml = `
<button class="TMDFClose" onclick="document.querySelector('#TMDFCustomApi').style.display='none';">☒</button>
<legend>添加解析接口</legend>
<li><span class="TMDFspan120">解析接口名称:</span><input type="text" id="TMDFname" class="TMDFtext1" placeholder="显示的名称"></li>
<li><span class="TMDFspan120">解析接口地址:</span><input type="text" id="TMDFurl" class="TMDFtext1" placeholder="接口需要包含 http 或者 https"></li>
<li><span class="TMDFspan120">解析内嵌本页:</span><label for="TMDFintab"><input type="checkbox" id="TMDFintab"/>适合</label></li>
<li class="TMDFli2">
<button id="TMDFTest">测试</button>
<button id="TMDFAdd">增加</button>
<button id="TMDFSave">保存</button>
</li>`;
try {
let customUserApis = JSON.parse(GMgetValue('customUserApis', "[{}]"));
let checkStatus = '';
if (customUserApis[0].name !== undefined) {
for (let i = 0; i < customUserApis.length; i++) {
checkStatus = (customUserApis[i].intab === "1") ? 'checked' : '';
innerHtml += `<li><span class="TMDFDelete" title="删除" onclick="document.getElementById('TMDFCustomApi').removeChild(this.parentNode)">✘</span><input class="TMDFCheckbox" type="checkbox" ${checkStatus}><span class="TMDFName">${customUserApis[i].name}:</span><span class="TMDFLink">${customUserApis[i].url}</span></li>`;
}
}
} catch (e) {}
let divTag = document.createElement('div');
divTag.id = 'TMDFCustomApi';
divTag.setAttribute('class', 'TMDFp');
divTag.setAttribute('style', 'display:none');
divTag.innerHTML = innerHtml;
document.body.appendChild(divTag);
/*事件绑定*/
document.querySelector('#TMDFTest').addEventListener('click', function() {
let apiUrl = document.querySelector('#TMDFurl').value;
if (apiUrl && apiUrl.match('^http')){
window.open(apiUrl + location.href);
}
else{
alert('测试无效,请先添加解析接口地址');
}
}, false);
document.querySelector('#TMDFAdd').addEventListener('click', function() {
if (document.querySelector('#TMDFname').value && document.querySelector('#TMDFurl').value) {
let checkStatus = document.querySelector("#TMDFintab").checked ? "checked" : "";
let liTag = document.createElement('li');
liTag.innerHTML = `<span class="TMDFDelete" title="删除" onclick="document.getElementById('TMDFCustomApi').removeChild(this.parentNode)">✘</span><input class="TMDFCheckbox" type="checkbox" ${checkStatus}><span class="TMDFName">${document.querySelector('#TMDFname').value}:</span><span class="TMDFLink">${document.querySelector('#TMDFurl').value}</span>`;
if (document.querySelector('span[class=TMDFName]') === null) {
document.querySelector('#TMDFCustomApi').appendChild(liTag);
document.querySelector('#TMDFname').value = '';
document.querySelector('#TMDFurl').value = '';
} else {
document.querySelector('#TMDFCustomApi').insertBefore(liTag, document.querySelector('span[class=TMDFName]').parentNode);
document.querySelector('#TMDFname').value = '';
document.querySelector('#TMDFurl').value = '';
}
} else {
alert('添加解析接口名称与地址不能为空,且符合规范');
}
}, false);
document.querySelector('#TMDFSave').addEventListener('click', function() {
var customUserApis = getCustomUserApis();
GMsetValue('customUserApis', JSON.stringify(customUserApis));
console.log(customUserApis);
alert('解析接口列表已保存');
}, false);
}
/* 显示解析界面 */
function showResolveApiPanel() {
/*提供的接口列表*/
let apisText = ''
for (let i in fixedApis) {
apisText += `<li data-order=${i} data-url="${fixedApis[i].url}" data-intab=${fixedApis[i].intab} title="${fixedApis[i].title}" onclick="window.open(this.dataset.url+location.href)">${fixedApis[i].name}</li>`;
}
let innerHtml = `
<ul id="TMDFul">
<li class="TMDFli1"><span id="TMDFList" title="${defaultApi.title}" onclick="window.open(\'${defaultApi.url}\'+window.location.href)">▶</span>
<ul class="TMDFul2 TMDFul3">${apisText}</ul></li>
<li class="TMDFli1"><span id="TMDFSet">▣</span>
<ul class="TMDFul2">
<li><label><input type="checkbox" id="TMDFPageResolve" style="vertical-align: middle;">本页解析</label></li>
<li><label><input type="checkbox" id="TMDFVideoEpisodes" style="vertical-align: middle;">播放选集</label></li>
<li><input type="checkbox" id="TMDFAddApi" style="vertical-align: middle;"><label id="TMDFAddApiSettingBtn">增加接口</label></li>
<li><label id="TMDFVideoSettingBtn">播放设置</label></li>
</ul></li>
</ul>
`;
let divTag = document.createElement("div");
divTag.id = "TMDFResolveApi";
divTag.innerHTML = innerHtml;
document.body.appendChild(divTag);
//事件绑定
document.querySelector("#TMDFAddApi").addEventListener('change', checkAddCustomApi, false);
let enableCustomApi = GMgetValue('enableCustomApi', false)
document.querySelector("#TMDFAddApi").checked = enableCustomApi;
/*看看是否需要加载自定义的接口列表*/
if (enableCustomApi) {
let customUserApis = JSON.parse(GMgetValue('customUserApis', "[{}]"));
let innerHtml = '';
for (let i in customUserApis) {
try {
if (customUserApis[i].url !== null) {
innerHtml += `<li data-order=${i} data-url="${customUserApis[i].url}" data-intab=${customUserApis[i].intab} onclick="window.open(this.dataset.url+location.href)">${customUserApis[i].name}</li>`;
}
} catch (e) { /*console.log(e);*/ }
}
document.querySelector('ul.TMDFul2.TMDFul3').innerHTML = innerHtml + document.querySelector('ul.TMDFul2.TMDFul3').innerHTML;
showCustomApiPanel();
}
//本页解析
document.querySelector("#TMDFPageResolve").addEventListener("click", checkThisPageResolve, false);
let enablePageResolve = GMgetValue('enablePageResolve', false);
document.querySelector("#TMDFPageResolve").checked = enablePageResolve;
if (enablePageResolve) {
checkThisPageResolve();
}
//正确选集
document.querySelector("#TMDFVideoEpisodes").addEventListener("click", rightVideoEpisodes, false);
let enableVideoEpisodes = GMgetValue('enableVideoEpisodes', false);
document.querySelector("#TMDFVideoEpisodes").checked = enableVideoEpisodes;
if (enableVideoEpisodes && location.href.indexOf("iqiyi") != -1) {
rightVideoEpisodes();
}
//添加接口
document.querySelector("#TMDFAddApiSettingBtn").addEventListener('click', showAddCustomApiPanel, false);
//播放设置
document.querySelector("#TMDFVideoSettingBtn").addEventListener('click', showVideoSettingPanel, false);
}
/* 执行 */
function execute() {
//添加css
GMaddStyle(cssStyle);
//显示界面
showResolveApiPanel();
}
//调用执行
execute();
})();