Sleazy Fork is available in English.

JAV老司机

JAV老司机神器,支持各Jav老司机站点。拥有高效浏览Jav的页面排版,JAV高清预览大图,JAV列表无限滚动自动加载,合成“挊”的自动获取JAV磁链接,一键自动115离线下载。。。。没时间解释了,快上车!

As of 01/01/2020. See the latest version.

  1. // ==UserScript==
  2. // @name JAV老司机
  3. // @namespace https://sleazyfork.org/zh-CN/users/25794
  4. // @version 3.1.1
  5. // @supportURL https://sleazyfork.org/zh-CN/scripts/25781/feedback
  6. // @source https://github.com/hobbyfang/javOldDriver
  7. // @description JAV老司机神器,支持各Jav老司机站点。拥有高效浏览Jav的页面排版,JAV高清预览大图,JAV列表无限滚动自动加载,合成“挊”的自动获取JAV磁链接,一键自动115离线下载。。。。没时间解释了,快上车!
  8. // @author Hobby
  9.  
  10. // @require https://cdn.jsdelivr.net/npm/jquery@2.2.4/dist/jquery.min.js
  11. // @require https://cdn.jsdelivr.net/npm/lovefield@2.1.12/dist/lovefield.min.js
  12. // @resource icon http://geekdream.com/image/115helper_icon_001.jpg
  13.  
  14. // @include *://*javlibrary.com/*
  15. // @include *://*javlib.com/*
  16. // @include *://*javbus.com/*
  17. // @include *://tellme.pw/avsox
  18. // @include *://tellme.pw/avmoo
  19. // @include *://115.com/*
  20. // @include *://onejav.com/*
  21. // @include *://*jav321.com/video/*
  22.  
  23. // @include *://*/vl_update*
  24. // @include *://*/vl_newrelease*
  25. // @include *://*/vl_newentries*
  26. // @include *://*/vl_mostwanted*
  27. // @include *://*/vl_bestrated*
  28. // @include *://*/vl_genre*
  29. // @include *://*/vl_star*
  30. // @include *://*/?v=jav*
  31. // @include *://*/mv_owned*
  32. // @include *://*/mv_watched*
  33. // @include *://*/mv_wanted*
  34. // @include *://*/mv_visited*
  35.  
  36. // @include *://www.*bus*/*
  37. // @include *://www.*dmm*/*
  38.  
  39. // @include *://*/movie/*
  40. // @include *://*/cn*
  41. // @include *://*/tw*
  42. // @include *://*/ja*
  43. // @include *://*/en*
  44.  
  45. // @run-at document-idle
  46. // @grant GM_xmlhttpRequest
  47. // @grant GM_addStyle
  48. // @grant GM_getValue
  49. // @grant GM_setValue
  50. // @grant GM_notification
  51. // @grant GM_setClipboard
  52. // @grant GM_getResourceURL
  53.  
  54. // @connect *
  55. // @copyright hobby 2016-12-18
  56.  
  57. // 大陆用户推荐Chrome(V52+) + Tampermonkey(必须扩展) + V2ray/ShadowsocksR(代理) + Proxy SwitchyOmega(扩展)的环境下配合使用。
  58. // 上车请使用chrome浏览器,其他浏览器的问题本人不支持发现和修复相关问题。
  59.  
  60. // 注意:2.0在每个版本号更新后,javlibrary每个不同域名站点在登录javlibrary的情况下,都会分别首次运行此脚本,
  61. // 根据电脑性能及访问网速情况不同,需消耗约2分钟左右(以1000个车牌量计算)缓存个人数据到本地浏览器中.
  62. // 此目的用于过滤个人已阅览过的内容提供快速判断.目前在同步过程中如果浏览器当前页面不在javlibrary站点,同步会被暂停或中止,需注意.
  63. // 当然如果不登录javlibrary或同版本号已经同步过,则不会运行同步,并无此影响.
  64.  
  65. // v3.1.1 更新了磁链站点。
  66. // v3.1.0 优化javbus/avmoo/avsox瀑布流排版。
  67. // v3.0.5 排版做了一些微调。
  68. // v3.0.4 屏蔽了失效的磁链站点。
  69. // v3.0.3 修复了已知问题。
  70. // v3.0.2 修复了已知问题。
  71. // v3.0.1 修复了已知问题。
  72. // v3.0.0 增加115在线播放的关联入口。同时本代码重新梳理及优化。
  73.  
  74. // v2.3.0 增加jav321网站内容排版的支持,增加查找已登录115网盘是否拥有当前番号显示。
  75. // v2.2.2 修复了已知问题。
  76. // v2.2.0 增加onejav网站内容排版的支持,热门Jav预览搜集更省时省力。更换两个磁链资源新地址。
  77. // v2.1.5 增加点击番号完成复制功能。
  78. // v2.1.3 增加btdigg磁链资源站点。修复了已知问题。
  79. // v2.1.1 增加jav站点瀑布流控制按钮功能。
  80. // v2.1.0 增加javbus站内磁链列表的复制、115离线的快捷键功能。
  81.  
  82. // v2.0.7 增加一种情况Jav列表排序功能支持(仅javlib)。
  83. // v2.0.5 增加Jav列表“按评分排序”、“按时间排序”功能(仅javlib),及更新Jav站点域名。
  84. // v2.0.0 增加自动同步个人数据缓存到本地,jav列表能识别个人已阅览过的内容(需登录javlibray),针对javlibrary的高评价栏目,增加过滤"不看我阅览过"功能。
  85.  
  86. // v1.2.0 针对javlibrary的高评价栏目,增加过滤“只看当前月份”、“只看近两月份”功能。另默认此栏目近两月份的内容增加背景颜色区分。
  87. // v1.2.0 更新了合成“挊”脚本的更多网站的支持,感谢作者thunderhit,同时修复原脚本部分网站功能失效问题。
  88. // v1.1.0 优化更新了JAV列表无限滚动自动加载的代码,增加JAV列表中显示"发行日期"和"评分"的排版,以及修复了已知问题。
  89. // v1.0.3 优化了高清预览大图的获取。
  90. // v1.0.2 优化了javlibrary排版,做了最低分辨率1280x800的排版适配调整,及修复了已知问题。
  91. // v1.0.0 支持javlibrary.com、javbus.com、avmo.pw、avso.pw等老司机站点,第一版发布。
  92.  
  93. // ==/UserScript==
  94. /* jshint -W097 */
  95. (function () {
  96. 'use strict';
  97. // 115用户ID
  98. let jav_userID = GM_getValue('jav_user_id', 0);
  99. // icon图标
  100. let icon = GM_getResourceURL('icon');
  101. // 瀑布流状态:1:开启、0:关闭
  102. let waterfallScrollStatus = GM_getValue('scroll_status', 1);
  103. // 当前网页域名
  104. let domain = location.host;
  105. // 数据库
  106. let javDb;
  107. // 表
  108. let myMovie;
  109.  
  110. /**
  111. * 对Date的扩展,将 Date 转化为指定格式的String
  112. * 月(M)、日(d)、小时(h)、分(m)、秒(s)、季度(q) 可以用 1-2 个占位符,/';
  113. * 年(y)可以用 1-4 个占位符,毫秒(S)只能用 1 个占位符(是 1-3 位的数字)
  114. * 例子:(new Date()).Format("yyyy-MM-dd hh:mm:ss.S") ==> 2006-07-02 08:09:04.423f
  115. * (new Date()).Format("yyyy-M-d h:m:s.S") ==> 2006-7-2 8:9:4.18
  116. * @param fmt 日期格式
  117. * @returns {void | string} 格式化后的日期字符串
  118. */
  119. Date.prototype.Format = function (fmt) { //author: meizz
  120. var o = {
  121. "M+": this.getMonth() + 1, //月份
  122. "d+": this.getDate(), //日
  123. "h+": this.getHours(), //小时
  124. "m+": this.getMinutes(), //分
  125. "s+": this.getSeconds(), //秒
  126. "q+": Math.floor((this.getMonth() + 3) / 3), //季度
  127. "S": this.getMilliseconds() //毫秒
  128. };
  129. if (/(y+)/.test(fmt))
  130. fmt = fmt.replace(RegExp.$1, (this.getFullYear() + "").substr(4 - RegExp.$1.length));
  131. for (var k in o)
  132. if (new RegExp("(" + k + ")").test(fmt))
  133. fmt = fmt.replace(RegExp.$1, (RegExp.$1.length == 1) ? (o[k]) : (("00" + o[k]).substr(("" + o[k]).length)));
  134. return fmt;
  135. };
  136.  
  137. /**
  138. * 多线程异步队列 依赖 jQuery 1.8+
  139. * @n {Number} 正整数, 线程数量
  140. */
  141. function Queue (n) {
  142. n = parseInt(n, 10);
  143. return new Queue.prototype.init( (n && n > 0) ? n : 1 )
  144. }
  145.  
  146. Queue.prototype = {
  147. init: function (n) {
  148. this.threads = [];
  149. this.taskList = [];
  150. while (n--) {
  151. this.threads.push(new this.Thread)
  152. }
  153. },
  154. /**
  155. * @callback {Fucntion} promise对象done时的回调函数,它的返回值必须是一个promise对象
  156. */
  157. push: function (callback) {
  158. if (typeof callback !== 'function') return;
  159. var index = this.indexOfIdle();
  160. if (index != -1) {
  161. this.threads[index].idle(callback);
  162. //try { console.log('Thread-' + (index+1) + ' accept the task!') } catch (e) {}
  163. }
  164. else {
  165. this.taskList.push(callback);
  166. for (var i = 0, l = this.threads.length; i < l; i++) {
  167. (function(thread, self, id){
  168. thread.idle(function(){
  169. if (self.taskList.length > 0) {
  170. //try { console.log('Thread-' + (id+1) + ' accept the task!') } catch (e) {}
  171. let promise = self.taskList.shift()(); // 正确的返回值应该是一个promise对象
  172. return promise.promise ? promise : $.Deferred().resolve().promise();
  173. } else {
  174. return $.Deferred().resolve().promise();
  175. }
  176. })
  177. })(this.threads[i], this, i);
  178.  
  179. }
  180. }
  181. },
  182. indexOfIdle: function () {
  183. var threads = this.threads,
  184. thread = null,
  185. index = -1;
  186. for (var i = 0, l = threads.length; i < l; i++) {
  187. thread = threads[i];
  188. if (thread.promise.state() === 'resolved') {
  189. index = i;
  190. break;
  191. }
  192. }
  193. return index;
  194. },
  195. Thread: function () {
  196. this.promise = $.Deferred().resolve().promise();
  197. this.idle = function (callback) {
  198. this.promise = this.promise.then(callback)
  199. }
  200. }
  201. };
  202. Queue.prototype.init.prototype = Queue.prototype;
  203.  
  204. /**
  205. * 公用类
  206. * @Class
  207. */
  208. let Common = {
  209. /**
  210. * 设置cookie
  211. * @param cname 名字
  212. * @param cvalue 值
  213. */
  214. setCookie: function(cname, cvalue) {
  215. let d = new Date();
  216. d.setTime(d.getTime() + (30*24*60*60*1000));
  217. let expires = "expires="+ d.toUTCString();
  218. document.cookie = cname + "=" + cvalue + ";" + expires + ";path=/";
  219. },
  220. /**
  221. * html文本转换为Document对象 https://jsperf.com/domparser-vs-createelement-innerhtml/3
  222. * @param {String} text
  223. * @returns {Document}
  224. */
  225. parsetext: function (text) {
  226. try {
  227. let doc = document.implementation.createHTMLDocument('');
  228. doc.documentElement.innerHTML = text;
  229. return doc;
  230. }
  231. catch (e) {
  232. alert('parse error');
  233. }
  234. },
  235.  
  236. /**
  237. * 判断日期是否最近X个月份的日期
  238. * @param {String} DateStr 日期
  239. * @param {Number} MonthNum 月数(X)
  240. * @returns {boolean}
  241. */
  242. isLastXMonth: function (DateStr, MonthNum) {
  243. let now = new Date(); //当前日期
  244. let compDate = new Date(DateStr);
  245. let m2 = now.getFullYear() * 12 + now.getMonth();
  246. let m1 = compDate.getFullYear() * 12 + compDate.getMonth();
  247. if ((m2 - m1) < MonthNum) {
  248. return true;
  249. }
  250. return false;
  251. },
  252.  
  253. /**
  254. * 方法: 通用chrome通知
  255. * @param title
  256. * @param body
  257. * @param icon
  258. * @param click_url
  259. */
  260. notifiy: function (title, body, icon, click_url) {
  261. var notificationDetails = {
  262. text: body,
  263. title: title,
  264. timeout: 3000,
  265. image: icon,
  266. onclick: function () {
  267. window.open(click_url);
  268. }
  269. };
  270. GM_notification(notificationDetails);
  271. },
  272. /**
  273. * 获取带-的番号
  274. * @param {String} avid 番号如:ABP888
  275. * @returns {String} 带-的番号
  276. */
  277. getAvCode:function (avid) {
  278. let letter = avid.match(/^[a-z|A-Z]+/gi);
  279. let num = avid.match(/\d+$/gi);
  280. return letter+"-"+num;
  281. },
  282. /**
  283. * 加入AV预览内容图
  284. * @param avid av唯一码
  285. * @param @function func 函数
  286. * @param {boolean} isZoom 是否放大,默认true
  287. */
  288. addAvImg: function (avid, func, isZoom) {
  289. //异步请求搜索blogjav.net的番号
  290. let promise1 = request('http://blogjav.net/?s=' + avid);//大图地址
  291. promise1.then((result) => {
  292. var doc = Common.parsetext(result.responseText);
  293. let a_array = $(doc).find(".more-link");
  294. let a = a_array[0];
  295. for (let i = 0; i < a_array.length; i++) {
  296. var fhd_idx = a_array[i].innerHTML.search(/FHD/);
  297. //debugger;
  298. if (fhd_idx > 0) {
  299. a = a_array[i];
  300. break;
  301. }
  302. }
  303. if (a) {
  304. //异步请求调用内页详情的访问地址
  305. GM_xmlhttpRequest({
  306. method: "GET",
  307. //大图地址
  308. url: a.href,
  309. headers: {
  310. referrer: "http://pixhost.to/" //绕过防盗图的关键
  311. },
  312. onload: function (XMLHttpRequest) {
  313. var bodyStr = XMLHttpRequest.responseText;
  314. var yixieBody = bodyStr.substring(bodyStr.search(/<span id="more-(\S*)"><\/span>/), bodyStr.search(/<div class="category/));
  315.  
  316. var img_start_idx = yixieBody.search(/"><img .*src="https*:\/\/(\S*)pixhost.*\/thumbs\//);
  317. //debugger;
  318. //如果找到内容大图
  319. if (img_start_idx > 0) {
  320. var new_img_src = yixieBody.substring(yixieBody.indexOf('src', img_start_idx) + 5, yixieBody.indexOf('alt') - 2);
  321. var targetImgUrl = new_img_src.replace('thumbs', 'images').replace('//t', '//img').replace(/[\?*\"*]/, '').replace('https', 'http');
  322.  
  323. //如果找到全高清大图优先显示全高清的
  324. console.log("图片地址:" + targetImgUrl);
  325. //创建img元素,加载目标图片地址
  326. //创建新img元素
  327. let className = "";
  328. if(isZoom != undefined && !isZoom){
  329. className = "min";
  330. }
  331. var $img = $('<img name="javRealImg" title="点击可放大缩小 (图片正常时)" class="' + className + '"></img>');
  332. $img.attr("src", targetImgUrl);
  333. $img.attr("style", "float: left;cursor: pointer;max-width: 100%;");
  334.  
  335. //将新img元素插入指定位置
  336. func($img);
  337. }
  338. },
  339. onerror: function (e) {
  340. console.log(e);
  341. }
  342. });//end GM_xmlhttpRequest
  343. }
  344. });
  345. },
  346.  
  347. /**
  348. * 查询115网盘是否拥有番号
  349. * @param javId 番号
  350. * @param callback 回调函数
  351. */
  352. search115Data: function (javId, callback) {
  353. //异步请求搜索115番号 //115查询
  354. let javId2 = javId.replace(/(-)/g, "");
  355. let promise1 = request(`https://webapi.115.com/files/search?search_value=${javId}%20${javId2}&format=json`);
  356. promise1.then((result) => {
  357. let resultJson = JSON.parse(result.responseText);
  358. if(resultJson.count > 0) {
  359. let pickcode = '';
  360. for (let i = 0; i < resultJson.data.length; i++) {
  361. let row = resultJson.data[i];
  362. if(row.vdi){//iv vdi ico
  363. pickcode = row.pc;
  364. callback(true,`http://120.78.32.31/play.html?pickcode=${pickcode}`);
  365. return;
  366. }
  367. }
  368. }
  369. callback(false,null);
  370. });
  371. },
  372. getSchemaBuilder: function() {
  373. // 构造jav库
  374. let ds = lf.schema.create('jav', 1);
  375. // 创建MyMovie表
  376. ds.createTable('MyMovie').
  377. //addColumn('id', lf.Type.INTEGER).
  378. //索引编码 如javlikqu54
  379. addColumn('index_cd',lf.Type.STRING).
  380. //识别编码 如CHN-141
  381. addColumn('code', lf.Type.STRING).
  382. //缩略图路径
  383. addColumn('thumbnail_url', lf.Type.STRING).
  384. //片名
  385. addColumn('movie_name', lf.Type.STRING).
  386. //演员
  387. addColumn('actor', lf.Type.STRING).
  388. //封面图路径
  389. addColumn('cover_img_url', lf.Type.STRING).
  390. //发布日期
  391. addColumn('release_date', lf.Type.STRING).
  392. //评分
  393. addColumn('score', lf.Type.INTEGER).
  394. //片长(分钟)
  395. addColumn('duration', lf.Type.INTEGER).
  396. //导演
  397. addColumn('director', lf.Type.STRING).
  398. //制作商
  399. addColumn('maker', lf.Type.STRING).
  400. //发行商
  401. addColumn('publisher', lf.Type.STRING).
  402. //加入时间
  403. addColumn('add_time', lf.Type.STRING).
  404. //是否已阅
  405. addColumn('is_browse', lf.Type.BOOLEAN).
  406. //是否想要
  407. addColumn('is_want', lf.Type.BOOLEAN).
  408. //是否看过
  409. addColumn('is_seen', lf.Type.BOOLEAN).
  410. //是否拥有
  411. addColumn('is_have', lf.Type.BOOLEAN).
  412. //定义主键
  413. addPrimaryKey(['index_cd']).
  414. //定义索引
  415. addIndex('idxaddtime', ['add_time'], false, lf.Order.DESC);
  416. return ds;
  417. },
  418. };
  419.  
  420. let main = { // todo
  421. //av信息查询类
  422. //avsox|avmoo
  423. jav: {
  424. type: 0,
  425. re: /.*movie.*/,
  426. vid: function () {
  427. return $('.header_hobby')[0].nextElementSibling.getAttribute("avid");
  428. },
  429. proc: function () {
  430. var divE = $("div[class='col-md-3 info']")[0];
  431. $(divE).after(main.cur_tab);
  432. }
  433. },
  434. javbus: {
  435. type: 0,
  436. re: /bus|dmm/,
  437. vid: function () {
  438. var a = $('.header_hobby')[0].nextElementSibling;
  439. return a ? a.getAttribute("avid") : '';
  440. },
  441. proc: function () {
  442. var divE = $("div[class='col-md-3 info']")[0];
  443. $(divE).after(main.cur_tab);
  444. }
  445. },
  446. javlibrary: {
  447. type: 0,
  448. re: /.*\?v=jav.*/,
  449. vid: function () {
  450. return $('#video_id')[0].getElementsByClassName('text')[0].getAttribute("avid");
  451. },
  452. proc: function () {
  453. //去十八岁警告
  454. Common.setCookie("over18", 18);
  455. $('.socialmedia').remove();
  456. GM_addStyle(`
  457. #video_info {text-align: left;font: 14px Arial;min-width: 230px;max-width: 250px;padding: 0px 0px 0px 0px;}
  458. #video_jacket_info {overflow: hidden;} //table-layout: fixed;
  459. #coverimg {vertical-align: top;overflow: hidden;max-width: 50%;}
  460. #javtext {vertical-align: top;width: 250px;}
  461. #video_info td.header {width: 75px;}
  462. #video_info td.icon {width: 0px;}
  463. #content {padding-top: 0px;}
  464. `);
  465.  
  466. var tdE = $("td[style='vertical-align: top;']")[0];
  467. tdE.id = "coverimg";
  468. $("td[style='vertical-align: top;']")[1].id = 'javtext';
  469. $('#leftmenu').remove();
  470. $('#rightcolumn').attr("style", "margin: 0px 0px 0px 0px;width: 100%;padding: initial;");
  471. $(tdE.parentElement).append('<td id="hobby" style="vertical-align: top;"></td>');
  472. $('#hobby').append(main.cur_tab);
  473. }
  474. },
  475. };
  476.  
  477. function request(url) {
  478. return new Promise(resolve => {
  479. //let time1 = new Date();
  480. GM_xmlhttpRequest({
  481. url,
  482. method: 'GET',
  483. headers: {
  484. "Cache-Control": "no-cache"
  485. },
  486. timeout: 30000,
  487. onload: response => { //console.log(url + " reqTime:" + (new Date() - time1));
  488. resolve(response);
  489. },
  490. onabort: (e) =>{
  491. console.log(url + " abort");
  492. resolve("wrong");
  493. },
  494. onerror: (e) =>{
  495. console.log(url + " error");
  496. console.log(e);
  497. resolve("wrong");
  498. },
  499. ontimeout: (e) =>{
  500. console.log(url + " timeout");
  501. resolve("wrong");
  502. },
  503. });
  504. });
  505. }
  506.  
  507. // 挊
  508. let main_keys = Object.keys(main); //下面的不要出现
  509. main.cur_tab = null;
  510. main.cur_vid = '';
  511.  
  512. // 瀑布流脚本使用类
  513. class Lock {
  514. constructor(d = false) {
  515. this.locked = d;
  516. }
  517. lock() {
  518. this.locked = true;
  519. }
  520. unlock() {
  521. this.locked = false;
  522. }
  523. }
  524.  
  525. // 第三方脚本调用
  526. var thirdparty = {
  527. // javbus详情页增加多类别联合查找功能
  528. busTypeSearch : () => {
  529. let se = () => {
  530. let curGenres = '', a = document.querySelectorAll('input[name="gr_sel"]:checked'), arr = [];
  531. a.forEach(e => {
  532. arr.push(e.value);
  533. });
  534. //console.log(arr.join('-'));
  535. arr = arr.join('-');
  536. if (arr[0]) {
  537. window.location.href = 'genre/' + arr;
  538. }
  539. };
  540. let CreateSearch = () => { //get <p>
  541. let p = document.querySelector('span.genre > a[href*="https://www.javbus.com/genre/"]');
  542. if (!p) return;
  543. p = p.parentNode.parentNode;
  544. p.querySelectorAll('a').forEach(e => {
  545. let i = document.createElement('input'), val = e.href.split('/');
  546. //https://www.javbus.com/genre/4 --> get > 4
  547. val = val[val.length - 1];
  548. i.setAttribute('type', 'checkbox');
  549. i.setAttribute('name', 'gr_sel');
  550. i.setAttribute('value', val);
  551. i.setAttribute('style', 'margin-right: 5px;');
  552. e.parentNode.insertBefore(i, e);
  553. });
  554. let a = document.createElement('a');
  555. a.setAttribute('style', 'cursor: pointer; display: block; color: blue;');
  556. a.textContent = '搜索';
  557. p.appendChild(a);
  558. a.addEventListener('click', se, false);
  559. };
  560. CreateSearch();
  561. },
  562. // 登录115执行脚本,自动离线下载准备步骤
  563. login115Run: function () {
  564. if (location.host.indexOf('115.com') >= 0) {
  565. jav_userID = GM_getValue('jav_user_id', 0); //115用户ID缓存
  566. //获取115ID
  567. if (jav_userID === 0) {
  568. if (location.host.indexOf('115.com') >= 0) {
  569. if (typeof (window.wrappedJSObject.user_id) != 'undefined') {
  570. jav_userID = window.wrappedJSObject.user_id;
  571. GM_setValue('jav_user_id', jav_userID);
  572. alert('115登陆成功!');
  573. return;
  574. }
  575. } else {
  576. //alert('请先登录115账户!');
  577. Common.notifiy("115还没有登录",
  578. '请先登录115账户后,再离线下载!',
  579. icon,
  580. 'http://115.com/?mode=login'
  581. );
  582. GM_setValue('jav_user_id', 0);
  583. }
  584. }
  585.  
  586. if (location.host.indexOf('115.com') >= 0) {
  587. console.log('jav老司机:115.com,尝试获取userid.');
  588. jav_userID = GM_getValue('jav_user_id', 0);
  589. //debugger;
  590. if (jav_userID !== 0) {
  591. console.log("jav老司机: 115账号:" + jav_userID + ",无需初始化.");
  592. return false;
  593. }
  594. jav_userID = $.cookie("OOFL");
  595. console.log("jav老司机: 115账号:" + jav_userID);
  596. if (!jav_userID) {
  597. console.log("jav老司机: 尚未登录115账号");
  598. return false;
  599. } else {
  600. console.log("jav老司机: 初始化成功");
  601. Common.notifiy('老司机自动开车', '登陆初始化成功,赶紧上车把!', icon, "");
  602. GM_setValue('jav_user_id', jav_userID);
  603. }
  604. return false;
  605. }
  606. }
  607. },
  608. // 瀑布流脚本
  609. waterfallScrollInit: function () {
  610. var w = new thirdparty.waterfall({});
  611. // javbus.com、avmo.pw、avso.pw
  612. var $pages = $('div#waterfall div.item');
  613. if ($pages.length) {
  614. // javbus.com
  615. if ($("footer:contains('JavBus')").length) {
  616. w = new thirdparty.waterfall({
  617. next: 'a#next',
  618. item: 'div#waterfall div.item',
  619. cont: '#waterfall',
  620. pagi: '.pagination-lg',
  621. });
  622. }
  623. //avmo.pw、avso.pw
  624. if ((/(AVMOO|AVSOX)/g).test(document.title)) {
  625. w = new thirdparty.waterfall({
  626. next: 'a[name="nextpage"]',//nextpage
  627. item: 'div#waterfall div.item',
  628. cont: '#waterfall',
  629. pagi: '.pagination',
  630. });
  631. }
  632. }
  633. // javlibrary
  634. var $pages2 = $('div.videos div.video');
  635. if ($pages2.length) {
  636. GM_addStyle(`
  637. .videothumblist .videos .video {height: 265px;padding: 0px;margin: 4px;}
  638. `);
  639. $pages2[0].parentElement.id = "waterfall";
  640. w = new thirdparty.waterfall({
  641. next: 'a[class="page next"]',
  642. item: 'div.videos div.video',
  643. cont: '#waterfall',
  644. pagi: '.page_selector',
  645. });
  646. }
  647. // onejav
  648. var $pages3 = $('div.container div.card.mb-3');
  649. if ($pages3.length) {
  650. $pages3[0].parentElement.id = "waterfall";
  651. w = new thirdparty.waterfall({
  652. next: 'a.pagination-next.button.is-primary',
  653. item: 'div.container div.card.mb-3',
  654. cont: '#waterfall',
  655. pagi: '.pagination.is-centered',
  656. });
  657. }
  658.  
  659. w.setSecondCallback(function (cont, elems) {
  660. if (location.pathname.includes('/star/') && elems) {
  661. cont.append(elems.slice(1));
  662. } else {
  663. cont.append(elems);
  664. }
  665. });
  666.  
  667. w.setThirdCallback(function (elems) {
  668. // hobby mod script
  669. function filerMonth(indexCd_id, dateString) {
  670. //过滤最新X月份的影片
  671. if ($(indexCd_id).context.URL.indexOf("bestrated.php?delete") > 0) {
  672. if ($(indexCd_id).context.URL.indexOf("bestrated.php?deleteOneMonthAway") > 0 && !Common.isLastXMonth(dateString, 1)) {
  673. $(indexCd_id).remove();
  674. }
  675. else if ($(indexCd_id).context.URL.indexOf("bestrated.php?deleteTwoMonthAway") > 0 && !Common.isLastXMonth(dateString, 2)) {
  676. $(indexCd_id).remove();
  677. }
  678. }
  679. }
  680. function filerScore(indexCd_id, pingfengString) {
  681. //过滤X评分以下的影片 //if(vid == 'javlikq7qu')debugger;
  682. if ($(indexCd_id).context.URL.indexOf("?delete") > 0) {
  683. if ($(indexCd_id).context.URL.indexOf("delete7down") > 0 && Number(pingfengString.replace('(', '').replace(')', '')) <= 7) {
  684. $(indexCd_id).remove();
  685. }
  686. else if ($(indexCd_id).context.URL.indexOf("delete8down") > 0 && Number(pingfengString.replace('(', '').replace(')', '')) <= 8) {
  687. $(indexCd_id).remove();
  688. }
  689. else if ($(indexCd_id).context.URL.indexOf("delete9down") > 0 && Number(pingfengString.replace('(', '').replace(')', '')) <= 9) {
  690. $(indexCd_id).remove();
  691. }
  692. }
  693. }
  694. function setbgcolor(indexCd_id, dateString) {
  695. // 如果是最近两个月份的影片标上背景色
  696. if ($(indexCd_id).context.URL.indexOf("bestrated") > 0 && Common.isLastXMonth(dateString, 2)) {
  697. //$(indexCd_id).css("background-color", "blanchedalmond");
  698. $('div[class="hobby_add"]', $(indexCd_id)).css("background-color", "#ffffc9");
  699. //debugger;
  700. }
  701. }
  702.  
  703. function extCode(indexCd_id, dateString, pingfengString) {
  704. $(indexCd_id).children("a").append(`<div class='hobby_add'style='color: red;font-size: 14px;'>
  705. ${dateString}&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;${pingfengString}</div>`);
  706. $(indexCd_id).children("a").attr("release_date", dateString);
  707. let s = 0;
  708. let r = Math.random() / 100;
  709. if (pingfengString.replace(/[\\(\\)]/g, "") != '') {
  710. s = r + parseFloat(pingfengString.replace(/[\\(\\)]/g, ""));
  711. } else {
  712. s = 0 + r;
  713. }
  714. $(indexCd_id).children("a").attr("score", s);
  715. setbgcolor(indexCd_id, dateString);
  716. filerMonth(indexCd_id, dateString);
  717. filerScore(indexCd_id, pingfengString);
  718. }
  719.  
  720. if (document.title.search(/JAVLibrary/) > 0 && elems) {
  721. for (let i = 0; i < elems.length; i++) {
  722. let _vid = $(elems[i]).attr("id").replace('vid_', '');//vid_javlikd42y
  723. // 给列表中的影片添加鼠标点击事件
  724. $("a", $("#vid_" + _vid)).first().mousedown(function (event) {
  725. // 判断鼠标左键或中间才执行
  726. if (event.button < 2) {
  727. // 设置点击后填充新的背景色peachpuff
  728. $("#vid_" + _vid).css("background-color", "#ffe7d3");
  729. }
  730. });
  731. let indexCd_id;
  732. let dateString;
  733. let pingfengString;
  734. // 查找影片是否存在我浏览过的MyMovie表中
  735. let prom =javDb.select().from(myMovie).
  736. where(lf.op.and(myMovie.is_browse.eq(true),myMovie.index_cd.eq(_vid))).exec();
  737. prom.then( results =>{
  738. //let promise1 = Promise.resolve();
  739. //return new Promise(resolve => {
  740. if(results.length != 0 ){//存在
  741. indexCd_id = "#vid_" + results[0].index_cd;
  742. if ($(indexCd_id).context.URL.indexOf("bestrated.php?filterMyBrowse") > 0) {
  743. $(indexCd_id).remove();
  744. }
  745. else{
  746. $(indexCd_id).css("background-color", "#ffe7d3");//hotpink,khaki,indianred,peachpuff
  747. extCode(indexCd_id, results[0].release_date, results[0].score);
  748. }
  749. }
  750. else {//不存在
  751. let promise1 = request(location.origin + "/ja/?v=" + _vid);
  752. promise1.then((result) => {
  753. indexCd_id = "#vid_" + result.finalUrl.split("=")[1];//例如:http://www.j12lib.com/cn/?v=javlikd42a
  754. let doc = result.responseText;
  755. let movie_info = doc.substring(doc.search(/<table id="video_jacket_info">/),
  756. doc.search(/<div id="video_favorite_edit" class="">/));
  757. // 阻止构造Document对象时加载src内容
  758. movie_info = movie_info.replace("src", "hobbysrc");
  759. let $doc = $(Common.parsetext(movie_info));
  760. dateString = $('#video_date .text', $doc).text();
  761. pingfengString = $('#video_review .text .score', $doc).text();
  762. extCode(indexCd_id, dateString, pingfengString);
  763. });
  764. }
  765. });
  766. }
  767. }
  768. });
  769.  
  770. w.setFourthCallback(function (elems) { // todo 20190404
  771. if (document.title.search(/OneJAV/) > 0 && elems) {
  772. // 增加对应所有番号的Javlib的跳转链接,
  773. for (let index = 0; index < elems.length; index++) {
  774. let aEle = $(elems[index]).find("h5.title.is-4.is-spaced a")[0];
  775. let avid = $(aEle).text().replace(/[ ]/g,"").replace(/[\r\n]/g,"")//去掉空格//去掉回车换行
  776. //修改样式
  777. $(aEle.parentElement.parentElement).attr("style","flex-direction: column;");
  778. // Javlib的跳转链接
  779. $(aEle.parentElement).append("<a style='color:red;' href='http://www.javlibrary.com/cn/vl_searchbyid.php?keyword="
  780. + Common.getAvCode(avid) +"&"+avid+ "' target='_blank' title='点击到Javlib看看'>&nbsp;&nbsp;Javlib</a>");
  781. // 番号预览大图
  782. Common.addAvImg(Common.getAvCode(avid), function ($img) {
  783. //debugger;
  784. let divEle = $(elems[index]).find("div.column.is-5")[0];
  785. if (divEle) {
  786. $(divEle).append($img);
  787. $img.click(function () {
  788. //如果存在min就去除min,否则不存在则添加上min
  789. $(this).toggleClass('min');
  790. if ($(this).attr("class")) {
  791. this.parentElement.parentElement.scrollIntoView();
  792. }
  793. });
  794. }
  795. },false);
  796. }
  797. }
  798.  
  799. if(((/(JavBus|AVMOO|AVSOX)/g).test(document.title) || $("footer:contains('JavBus')").length) && elems) {
  800. if(!location.pathname.includes('/actresses')){//排除actresses页面
  801. for (let i = 0; i < elems.length; i++) {
  802. $(elems[i]).css("height","385px");
  803. if($(elems[i]).find("div.avatar-box").length > 0) continue;
  804. let spanEle = $(elems[i]).find("div.photo-info span")[0];
  805. let t1 = $(spanEle).html().substr($(spanEle).html().indexOf("<br>") + 4);
  806. let t2 = $(spanEle).html().substr(0,$(spanEle).html().indexOf("<br>"));
  807. $(spanEle).html(t1 + "<br>" + t2);
  808. }
  809. }
  810. }
  811. });
  812.  
  813. if((/(JavBus|AVMOO|AVSOX)/g).test(document.title) || $("footer:contains('JavBus')").length) {
  814. // javbus.com、avmo.pw、avso.pw 样式
  815. GM_addStyle(`
  816. #waterfall {height: initial !important;width: initial !important;flex-direction: row;flex-wrap: wrap;margin: 5px 15px !important;}
  817. #waterfall .item {position: relative !important;top: initial !important;left: initial !important;}
  818. #waterfall .movie-box .photo-frame {position: relative;} #waterfall .movie-box .photo-info {height: 145px;}
  819. #waterfall .movie-box img {position: absolute; top: -200px; bottom: -200px; left: -200px; right: -200px; margin: auto;}
  820. #waterfall .movie-box {width: 167px;} #waterfall .avatar-box .photo-info p {margin: 0 0 2px;}
  821. #waterfall .avatar-box .photo-info {line-height: 15px; padding: 6px;height: 220px;}
  822. #waterfall .avatar-box .photo-frame {margin: 10px;text-align: center;}
  823. #waterfall .avatar-box.text-center {height: 195px;}//actresses页面
  824. `);
  825.  
  826. if($('#waterfall').length == 0 && location.pathname.search(/search/) > 0
  827. && location.pathname.search(/uncensored/) < 1){
  828. window.location.href = $('li[role="presentation"]:eq(1) a').attr("href");
  829. }
  830. }
  831. },
  832. // 瀑布流脚本
  833. waterfall: (function () {
  834. function waterfall(selectorcfg = {}) {
  835. this.lock = new Lock();
  836. this.baseURI = this.getBaseURI();
  837. this.selector = {
  838. next: 'a.next',
  839. item: '',
  840. cont: '#waterfall', //container
  841. pagi: '.pagination',
  842. };
  843. Object.assign(this.selector, selectorcfg);
  844. this.pagegen = this.fetchSync(location.href);
  845. this.anchor = $(this.selector.pagi)[0];
  846. this._count = 0;
  847. this._1func = function (cont, elems) {
  848. cont.empty().append(elems);
  849. };
  850. this._2func = function (cont, elems) {
  851. cont.append(elems);
  852. };
  853. this._3func = function (elems) {
  854. };
  855. if ($(this.selector.item).length) {
  856. // 开启关闭瀑布流判断
  857. if(waterfallScrollStatus > 0) {
  858. document.addEventListener('scroll', this.scroll.bind(this));
  859. document.addEventListener('wheel', this.wheel.bind(this));
  860. }
  861. this.appendElems(this._1func);
  862. }
  863. }
  864.  
  865. waterfall.prototype.getBaseURI = function () {
  866. let _ = location;
  867. return `${_.protocol}//${_.hostname}${(_.port && `:${_.port}`)}`;
  868. };
  869. waterfall.prototype.getNextURL = function (href) {
  870. let a = document.createElement('a');
  871. a.href = href;
  872. return `${this.baseURI}${a.pathname}${a.search}`;
  873. };
  874. // 瀑布流脚本
  875. waterfall.prototype.fetchURL = function (url) {
  876. console.log(`fetchUrl = ${url}`);
  877. const fetchwithcookie = fetch(url, {credentials: 'same-origin'});
  878. return fetchwithcookie.then(response => response.text())
  879. .then(html => new DOMParser().parseFromString(html, 'text/html'))
  880. .then(doc => {
  881. let $doc = $(doc);
  882. let href = $doc.find(this.selector.next).attr('href');
  883. let nextURL = href ? this.getNextURL(href) : undefined;
  884. let elems = $doc.find(this.selector.item);
  885. return {
  886. nextURL,
  887. elems
  888. };
  889. });
  890. };
  891. // 瀑布流脚本
  892. waterfall.prototype.fetchSync = function* (urli) {
  893. let url = urli;
  894. do {
  895. yield new Promise((resolve, reject) => {
  896. if (this.lock.locked) {
  897. reject();
  898. }
  899. else {
  900. this.lock.lock();
  901. resolve();
  902. }
  903. }).then(() => {
  904. return this.fetchURL(url).then(info => {
  905. url = info.nextURL;
  906. return info.elems;
  907. })
  908. ;
  909. }).then(elems => {
  910. this.lock.unlock();
  911. return elems;
  912. }).catch((err) => {
  913. // Locked!
  914. }
  915. )
  916. ;
  917. } while (url);
  918. };
  919. // 瀑布流脚本
  920. waterfall.prototype.appendElems = function () {
  921. let nextpage = this.pagegen.next();
  922. if (!nextpage.done) {
  923. nextpage.value.then(elems => {
  924. const cb = (this._count === 0) ? this._1func : this._2func;
  925. cb($(this.selector.cont), elems);
  926. this._count += 1;
  927. // hobby mod script
  928. this._3func(elems);
  929. this._4func(elems);
  930. })
  931. ;
  932. }
  933. return nextpage.done;
  934. };
  935. // 瀑布流脚本
  936. waterfall.prototype.end = function () {
  937. document.removeEventListener('scroll', this.scroll.bind(this));
  938. document.removeEventListener('wheel', this.wheel.bind(this));
  939. let $end = $(`<h1>The End</h1>`);
  940. $(this.anchor).replaceWith($end);
  941. };
  942. waterfall.prototype.reachBottom = function (elem, limit) {
  943. return (elem.getBoundingClientRect().top - $(window).height()) < limit;
  944. };
  945. waterfall.prototype.scroll = function () {
  946. if (this.reachBottom(this.anchor, 500) && this.appendElems(this._2func)) {
  947. this.end();
  948. }
  949. };
  950. waterfall.prototype.wheel = function () {
  951. if (this.reachBottom(this.anchor, 1000) && this.appendElems(this._2func)) {
  952. this.end();
  953. }
  954. };
  955. waterfall.prototype.setFirstCallback = function (f) {
  956. this._1func = f;
  957. };
  958. waterfall.prototype.setSecondCallback = function (f) {
  959. this._2func = f;
  960. };
  961. waterfall.prototype.setThirdCallback = function (f) {
  962. this._3func = f;
  963. };
  964. waterfall.prototype.setFourthCallback = function (f) {
  965. this._4func = f;
  966. };
  967. return waterfall;
  968. })(),
  969. // 挊
  970. nong: {
  971. offline_sites: {
  972. 115: {
  973. name: '115离线',
  974. url: 'http://115.com/?tab=offline&mode=wangpan',
  975. enable: true,
  976. },
  977. },
  978. resource_sites:{
  979. "btos.pw": function (kw, cb) { //btsow
  980. let promise = request("https://" + GM_getValue('search_index') + "/search/" + kw);
  981. promise.then((result) => {
  982. thirdparty.nong.search_engines.full_url = result.finalUrl;
  983. var doc = Common.parsetext(result.responseText);
  984. if (!doc) {
  985. thirdparty.nong.search_engines.parse_error(GM_getValue('search_index'));
  986. }
  987. var data = [];
  988. var t = doc.getElementsByClassName('data-list')[0];
  989. if (t) {
  990. var a = t.getElementsByTagName('a');
  991. for (var i = 0; i < a.length; i++) {
  992. if (!a[i].className.match('btn')) {
  993. data.push({
  994. 'title': a[i].title,
  995. 'maglink': 'magnet:?xt=urn:btih:' + a[i].outerHTML.replace(/.*hash\//, '').replace(/" .*\n.*\n.*\n.*/, ''),
  996. 'size': a[i].nextElementSibling.textContent,
  997. 'src': a[i].href,
  998. });
  999. }
  1000. }
  1001. }
  1002. cb(result.finalUrl, data);
  1003. });
  1004. },
  1005. // "www.btlibrary.info": function (kw, cb) {
  1006. // GM_xmlhttpRequest({
  1007. // method: "POST",
  1008. // url: "https://"+ GM_getValue('search_index') +"/btlibrary/" + kw + "/1-2-2-1.html",
  1009. // data: "keyword=" + kw,
  1010. // headers: {
  1011. // "Content-Type": "application/x-www-form-urlencoded",
  1012. // withCredentials:true
  1013. // },
  1014. // onload: function (result) {
  1015. // thirdparty.nong.search_engines.full_url = result.finalUrl;
  1016. // let doc = Common.parsetext(result.responseText);
  1017. // let data = [];
  1018. // let t = doc.querySelectorAll(".item");
  1019. // if (t) {
  1020. // for (let elem of t) {
  1021. // data.push({
  1022. // "title": elem.querySelector("dt>a").textContent,
  1023. // "maglink": "magnet:?xt=urn:btih:" + elem.querySelector(".attr>span:nth-child(6)>a").href.match(/[0-9a-zA-Z]{40,}/g),
  1024. // "size": elem.querySelector(".attr>span:nth-child(2)>b").textContent,
  1025. // "src": elem.querySelector("dt>a").href,
  1026. // });
  1027. // }
  1028. // }
  1029. // cb(result.finalUrl, data);
  1030. // },
  1031. // onerror: function (e) {
  1032. // console.error(e);
  1033. // throw "search error";
  1034. // }
  1035. // });
  1036. // },
  1037. "www.btdig.com": function (kw, cb) {
  1038. let promise = request("https://" + GM_getValue('search_index') + "/search?q=" + kw);
  1039. promise.then((result) => {
  1040. thirdparty.nong.search_engines.full_url = result.finalUrl;
  1041. let doc = Common.parsetext(result.responseText);
  1042. let data = [];
  1043. let t = doc.querySelectorAll("div.one_result");
  1044. if (t) {
  1045. for (let elem of t) {
  1046. data.push({
  1047. "title": elem.querySelector(".torrent_name a").textContent,
  1048. "maglink": elem.querySelector(".fa.fa-magnet a").href,
  1049. "size": elem.querySelector(".torrent_size").textContent,
  1050. "src": elem.querySelector(".torrent_name a").href,
  1051. });
  1052. }
  1053. }
  1054. else {
  1055. data.push({
  1056. "title": "没有找到磁链接",
  1057. "maglink": "",
  1058. "size": "0",
  1059. "src": result.finalUrl,
  1060. });
  1061. }
  1062. cb(result.finalUrl, data);
  1063. });
  1064. },
  1065. "sukebei.nyaa.si": function (kw, cb) {
  1066. let promise = request("https://" + GM_getValue('search_index') + "/?f=0&c=0_0&q=" + kw);
  1067. promise.then((result) => {
  1068. thirdparty.nong.search_engines.full_url = result.finalUrl;
  1069. let doc = Common.parsetext(result.responseText);
  1070. if (!doc) {
  1071. thirdparty.nong.search_engines.parse_error(GM_getValue('search_index'));
  1072. }
  1073. let data = [];
  1074. let t = doc.querySelectorAll("tr.default,tr.success");
  1075. if (t.length !== 0) {
  1076. for (let elem of t) {
  1077. //debugger;
  1078. data.push({
  1079. "title": elem.querySelector("td:nth-child(2)>a:nth-child(1)").title,
  1080. "maglink": elem.querySelector("td:nth-child(3)>a:nth-last-child(1)").href,
  1081. //"torrent_url": "https://nyaa.si" + elem.querySelector("td:nth-child(3)>a:nth-child(1)").href,
  1082. "size": elem.querySelector("td:nth-child(4)").textContent,
  1083. "src": "https://sukebei.nyaa.si"
  1084. + elem.querySelector("td:nth-child(2)>a:nth-child(1)").getAttribute('href'),
  1085. });
  1086. }
  1087. }
  1088. cb(result.finalUrl, data);
  1089. });
  1090. },
  1091. // "btdb.to": function (kw, cb) {
  1092. // GM_xmlhttpRequest({
  1093. // method: 'GET',
  1094. // url: 'https://" + GM_getValue('search_index') + "/q/' + kw + '/',
  1095. // onload: function (result) {
  1096. // thirdparty.nong.search_engines.full_url = result.finalUrl;
  1097. // var doc = Common.parsetext(result.responseText);
  1098. // if (!doc) {
  1099. // thirdparty.nong.search_engines.parse_error(GM_getValue('search_index'));
  1100. // }
  1101. // var data = [];
  1102. // var elems = doc.getElementsByClassName('item-title');
  1103. // for (var i = 0; i < elems.length; i++) {
  1104. // data.push({
  1105. // 'title': elems[i].firstChild.title,
  1106. // 'maglink': elems[i].nextElementSibling.firstElementChild.href,
  1107. // 'size': elems[i].nextElementSibling.children[1].textContent,
  1108. // 'src': 'https://btdb.to' + elems[i].firstChild.getAttribute('href'),
  1109. // });
  1110. // }
  1111. //
  1112. // cb(result.finalUrl, data);
  1113. // },
  1114. // onerror: function (e) {
  1115. // console.log(e);
  1116. // }
  1117. // });
  1118. // },
  1119. // "btkittyba.ws": function (kw, cb) {
  1120. // GM_xmlhttpRequest({
  1121. // method: "POST",
  1122. // url: "http://"+ GM_getValue('search_index') +"/", //地址不对则无法搜索
  1123. // data: "keyword=" + kw + "&hidden=true",
  1124. // headers: {
  1125. // "Content-Type": "application/x-www-form-urlencoded",
  1126. // withCredentials:true,
  1127. // Origin: "http://"+ GM_getValue('search_index')
  1128. // },
  1129. // onload: function (result) {
  1130. // let hostString = GM_getValue('search_index');
  1131. // thirdparty.nong.search_engines.full_url = result.finalUrl;
  1132. // let doc = Common.parsetext(result.responseText);
  1133. // let data = [];
  1134. // let t = doc.getElementsByClassName("list-con");
  1135. // if (t) {
  1136. // for (let elem of t) {
  1137. // data.push({
  1138. // "title": elem.querySelector("dt a").textContent,
  1139. // "maglink": elem.querySelector(".option span:nth-child(2) a").href.replace(location.host,hostString),//.match(/[0-9a-zA-Z]{40,}/g)
  1140. // //elem.querySelector("dd a").href todo 111
  1141. // "size": elem.querySelector(".option span:nth-child(4) b").textContent,
  1142. // "src": elem.querySelector("dt a").href.replace(location.host,hostString),
  1143. // "id": elem.querySelector("dt a").href.replace("https","").replace("http","").replace("://"+ location.host +"/t/","").replace(".html",""),
  1144. // });
  1145. // }
  1146. // }
  1147. // cb(result.finalUrl, data); // todo 181224
  1148. // },
  1149. // onerror: function (e) {
  1150. // console.error(e);
  1151. // throw "search error";
  1152. // }
  1153. // });
  1154. // },
  1155. //btdiggs.cc
  1156. // "btdiggcn.xyz": function (kw, cb) {
  1157. // GM_xmlhttpRequest({
  1158. // method: "POST",
  1159. // url: "http://"+ GM_getValue('search_index') +"/", //地址不对则无法搜索
  1160. // data: "keyword=" + kw + "&hidden=true",
  1161. // headers: {
  1162. // "Content-Type": "application/x-www-form-urlencoded",
  1163. // withCredentials:true
  1164. // },
  1165. // onload: function (result) {
  1166. // let hostString = "btdiggcn.xyz";
  1167. // thirdparty.nong.search_engines.full_url = result.finalUrl;
  1168. // let doc = Common.parsetext(result.responseText);
  1169. // let data = [];
  1170. // let t = doc.querySelectorAll(".list dl");
  1171. // if (t) {
  1172. // for (let elem of t) {
  1173. // data.push({
  1174. // "title": elem.querySelector("dt a").textContent,
  1175. // "maglink": elem.querySelector(".attr span:nth-child(6) a").href.replace(location.host,hostString),//.match(/[0-9a-zA-Z]{40,}/g)
  1176. // //elem.querySelector("dd a").href todo 111
  1177. // "size": elem.querySelector(".attr span:nth-child(2) b").textContent,
  1178. // "src": elem.querySelector("dt a").href.replace(location.host,hostString),
  1179. // "id": elem.querySelector("dt a").href.replace("https","").replace("http","").replace("://"+ location.host +"/","").replace(".html",""),
  1180. // });
  1181. // }
  1182. // }
  1183. //
  1184. // cb(result.finalUrl, data);
  1185. // },
  1186. // onerror: function (e) {
  1187. // console.error(e);
  1188. // throw "search error";
  1189. // }
  1190. // });
  1191. // },
  1192. "www.torrentkitty.tv": function (kw, cb) {
  1193. let promise = request("https://" + GM_getValue('search_index') + "/search/" + kw);
  1194. promise.then((result) => {
  1195. thirdparty.nong.search_engines.full_url = result.finalUrl;
  1196. let doc = Common.parsetext(result.responseText);
  1197. let data = [];
  1198. let t = doc.querySelectorAll("#archiveResult tr");
  1199. if (t) {
  1200. t = Array.slice(t, 1, t.length);
  1201. for (let elem of t) {
  1202. if((/(No result)/g).test(elem.querySelector(".name").textContent))
  1203. break;
  1204. data.push({
  1205. "title": elem.querySelector(".name").textContent,
  1206. "maglink": elem.querySelector(".action>a:nth-child(2)").href,
  1207. "size": elem.querySelector(".size").textContent,
  1208. "src": "https://www.torrentkitty.tv" + elem.querySelector(".action>a:nth-child(1)").getAttribute('href'),
  1209. });
  1210. }
  1211. }
  1212. else {
  1213. data.push({
  1214. "title": "没有找到磁链接",
  1215. "maglink": "",
  1216. "size": "0",
  1217. "src": result.finalUrl,
  1218. });
  1219. }
  1220. cb(result.finalUrl, data);
  1221. });
  1222. },
  1223.  
  1224. },
  1225. // 挊
  1226. search_engines: {
  1227. switch_engine: function (i) {
  1228. // var index = GM_getValue("search_index",0);
  1229. GM_setValue('search_index', i);
  1230. return i;
  1231. },
  1232. cur_engine: function (kw, cb) {
  1233. let ops = Object.keys(thirdparty.nong.resource_sites);
  1234. let z = thirdparty.nong.resource_sites[GM_getValue('search_index', ops[0])];
  1235. if (!z) {
  1236. //alert("search engine not found");
  1237. GM_setValue('search_index', Object.keys(thirdparty.nong.resource_sites)[0]);
  1238. z = thirdparty.nong.resource_sites[GM_getValue('search_index')];
  1239. }
  1240. return z(kw, cb);
  1241. },
  1242. parse_error: function (a) {
  1243. alert("调用搜索引擎错误,可能需要更新,请向作者反馈。i=" + a);
  1244. },
  1245. full_url: '',
  1246.  
  1247. },
  1248. // 挊
  1249. magnet_table: {
  1250. template: {
  1251. create_head: function () {
  1252. var a = document.createElement('tr');
  1253. a.className = 'jav-nong-row';
  1254. a.id = 'jav-nong-head';
  1255. var list = ['标题','大小','操作','离线下载'];
  1256. for (var i = 0; i < list.length; i++) {
  1257. var b = this.head.cloneNode(true);
  1258. if (i === 0) {
  1259. var select = document.createElement("select");
  1260. var ops = Object.keys(thirdparty.nong.resource_sites); // todo 181225
  1261. var cur_index = GM_getValue("search_index", ops[0]);
  1262. for (var j = 0; j < ops.length; j++) {
  1263. var op = document.createElement("option");
  1264. op.value = ops[j];
  1265. op.textContent = ops[j];
  1266. if (cur_index == ops[j]) {
  1267. op.setAttribute("selected", "selected");
  1268. }
  1269. select.appendChild(op);
  1270. }
  1271. b.removeChild(b.firstChild);
  1272. b.appendChild(select);
  1273. a.appendChild(b);
  1274. continue;
  1275. }
  1276. b.firstChild.textContent = list[i];
  1277. a.appendChild(b);
  1278. }
  1279. // var select_box = this.create_select_box();
  1280. // a.firstChild.appendChild(select_box);
  1281.  
  1282. return a;
  1283. },
  1284. create_row: function (data) {
  1285. var a = document.createElement('tr');
  1286. a.className = 'jav-nong-row';
  1287. a.setAttribute('maglink', data.maglink);
  1288. //debugger;
  1289. // 暂时针对cnbtkitty.pw站点生效。
  1290. if(data.maglink.indexOf("#magnetlink")>-1){
  1291. a.setAttribute('id', data.id);
  1292. let promise1 = request(data.maglink + "?hobbyId=" + data.id);// 传递修改hobbyId,用于修改时定位。
  1293. promise1.then((result) => {
  1294. //定位磁链编码开始下标位置
  1295. let indexNum = result.responseText.indexOf('#website#infohash#');
  1296. if (indexNum >= 0) {
  1297. let magnetlink = result.responseText.substring(indexNum + 18, indexNum + 58);
  1298. let hobbyId = result.finalUrl.substring(result.finalUrl.indexOf('?hobbyId=') + 9, result.finalUrl.length);
  1299. $("#" + hobbyId).attr("maglink", "magnet:?xt=urn:btih:" + magnetlink);
  1300. }
  1301. });
  1302. }
  1303.  
  1304. var b = document.createElement('td');
  1305. var list = [
  1306. this.create_info(data.title, data.maglink),
  1307. this.create_size(data.size, data.src),
  1308. this.create_operation(data.maglink),
  1309. this.create_offline()
  1310. ];
  1311. for (var i = 0; i < list.length; i++) {
  1312. var c = b.cloneNode(true);
  1313. c.appendChild(list[i]);
  1314. a.appendChild(c);
  1315. }
  1316. return a;
  1317. },
  1318. create_loading: function () {
  1319. var a = document.createElement('tr');
  1320. a.className = 'jav-nong-row';
  1321. var p = document.createElement('p');
  1322. p.textContent = 'Loading';
  1323. p.id = 'notice';
  1324. a.appendChild(p);
  1325. return a;
  1326. },
  1327. create_info: function (title, maglink) {
  1328. var a = this.info.cloneNode(true);
  1329. a.firstChild.textContent = title.length < 20 ? title : title.substr(0, 20) + '...';
  1330. a.firstChild.href = maglink;
  1331. a.title = title;
  1332. return a;
  1333. },
  1334. create_size: function (size, src) {
  1335. var a = this.size.cloneNode(true);
  1336. a.textContent = size;
  1337. a.href = src;
  1338. return a;
  1339. },
  1340. create_operation: function (maglink) {
  1341. var a = this.operation.cloneNode(true);
  1342. a.firstChild.href = maglink;
  1343. return a;
  1344. },
  1345. create_offline: function () { //有用 hobby
  1346. var a = this.offline();
  1347. a.className = 'nong-offline';
  1348. return a;
  1349. },
  1350. create_select_box: function () {
  1351. var select_box = document.createElement('select');
  1352. select_box.id = 'nong-search-select';
  1353. select_box.setAttribute('title', '切换搜索结果');
  1354. var search_name = GM_getValue('search', default_search_name);
  1355. for (var k in thirdparty.nong.search_engines) {
  1356. var o = document.createElement('option');
  1357. if (k == search_name) {
  1358. o.setAttribute('selected', 'selected');
  1359. }
  1360. o.setAttribute('value', k);
  1361. o.textContent = k;
  1362. select_box.appendChild(o);
  1363. }
  1364. return select_box;
  1365. },
  1366. head: (function () {
  1367. var a = document.createElement('th');
  1368. var b = document.createElement('a');
  1369. a.appendChild(b);
  1370. return a;
  1371. })(),
  1372. info: (function () {
  1373. var a = document.createElement('div');
  1374. var b = document.createElement('a');
  1375. b.textContent = 'name';
  1376. b.href = 'src';
  1377. a.appendChild(b);
  1378. return a;
  1379. })(),
  1380. size: function () {
  1381. var a = document.createElement('a');
  1382. a.textContent = 'size';
  1383. return a;
  1384. }(),
  1385. operation: (function () {
  1386. var a = document.createElement('div');
  1387. var copy = document.createElement('a');
  1388. copy.className = 'nong-copy';
  1389. copy.textContent = '复制';
  1390. a.appendChild(copy);
  1391. return a;
  1392. })(),
  1393. offline: function () {
  1394. var a = document.createElement('div');
  1395. var b = document.createElement('a');
  1396. b.className = 'nong-offline-download';
  1397. b.target = '_blank';
  1398. //debugger;
  1399. for (var k in thirdparty.nong.offline_sites) {
  1400. if (thirdparty.nong.offline_sites[k].enable) {
  1401. var c = b.cloneNode(true);
  1402. c.href = thirdparty.nong.offline_sites[k].url;
  1403. c.textContent = thirdparty.nong.offline_sites[k].name;
  1404. a.appendChild(c);
  1405. }
  1406. }
  1407. return a;
  1408. },
  1409. },
  1410. create_empty_table: function () { //有用 hobby
  1411. var a = document.createElement('table');
  1412. a.id = 'nong-table-new';
  1413. return a;
  1414. },
  1415. updata_table: function (src, data, type) {
  1416. if (type == 'full') {
  1417. var tab = $('#nong-table-new')[0];
  1418. tab.removeChild(tab.querySelector("#notice").parentElement);
  1419. for (var i = 0; i < data.length; i++) {
  1420. tab.appendChild(thirdparty.nong.magnet_table.template.create_row(data[i]));
  1421. }
  1422. }
  1423. this.reg_event();
  1424. },
  1425. full: function (src, data) {
  1426. var tab = this.create_empty_table();
  1427. tab.appendChild(thirdparty.nong.magnet_table.template.create_head());
  1428. // for (var i = 0; i < data.length; i++) {
  1429. // tab.appendChild(thirdparty.nong.magnet_table.template.create_row(data[i]))
  1430. // }
  1431. var loading = thirdparty.nong.magnet_table.template.create_loading();
  1432. tab.appendChild(loading);
  1433. return tab;
  1434. },
  1435. handle_event: function (event) {
  1436. var maglink = event.target.parentElement.parentElement.getAttribute('maglink')
  1437. || event.target.parentElement.parentElement.parentElement.getAttribute('maglink');
  1438. if (event.target.className == 'nong-copy') {
  1439. event.target.innerHTML = '成功';
  1440. maglink = maglink.substr(0,60);
  1441. GM_setClipboard(maglink);
  1442. setTimeout(function () {
  1443. event.target.innerHTML = '复制';
  1444. }, 1000);
  1445. event.preventDefault(); //阻止跳转
  1446. }
  1447. else if (event.target.className == 'nong-offline-download') {
  1448. maglink = maglink.substr(0,60);
  1449. GM_setValue('magnet', maglink);
  1450. //获取115 token接口
  1451. let promise = request('http://115.com/?ct=offline&ac=space&_='+ new Date().getTime());
  1452. promise.then((responseDetails) => {
  1453. if (responseDetails.responseText.indexOf('html') >= 0) {
  1454. //未登录处理
  1455. Common.notifiy("115还没有登录",
  1456. '请先登录115账户后,再离线下载!',
  1457. icon,
  1458. 'http://115.com/?mode=login'
  1459. );
  1460. return false;
  1461. }
  1462. var sign115 = JSON.parse(responseDetails.response).sign;
  1463. var time115 = JSON.parse(responseDetails.response).time;
  1464. console.log("uid=" + jav_userID + " sign:" + sign115 + " time:" + time115);
  1465. console.log("rsp:" + responseDetails.response);
  1466. GM_xmlhttpRequest({
  1467. method: 'POST',
  1468. url: 'http://115.com/web/lixian/?ct=lixian&ac=add_task_url', //添加115离线任务接口
  1469. headers: {
  1470. "Content-Type": "application/x-www-form-urlencoded"
  1471. },
  1472. data: "url=" + encodeURIComponent(maglink) + "&uid=" + jav_userID + "&sign=" + sign115
  1473. + "&time=" + time115,
  1474. onload: function (responseDetails) {
  1475. var lxRs = JSON.parse(responseDetails.responseText); //离线结果
  1476. if (lxRs.state) {
  1477. //离线任务添加成功
  1478. Common.notifiy("115老司机自动开车",
  1479. '离线任务添加成功',
  1480. icon,
  1481. 'http://115.com/?tab=offline&mode=wangpan'
  1482. );
  1483. }
  1484. else {
  1485. //离线任务添加失败
  1486. if (lxRs.errcode == '911') {
  1487. lxRs.error_msg = '你的帐号使用异常,需要在线手工重新验证即可正常使用。';
  1488. }
  1489. Common.notifiy("失败了",
  1490. '请重新打开115,' + lxRs.error_msg,
  1491. icon,
  1492. 'http://115.com/?tab=offline&mode=wangpan'
  1493. );
  1494. }
  1495. console.log("sign:" + sign115 + " time:" + time115);
  1496. console.log("磁链:" + maglink + " 下载结果:" + lxRs.state + " 原因:" + lxRs.error_msg);
  1497. console.log("rsp:" + responseDetails.response);
  1498. }
  1499. });
  1500.  
  1501. });
  1502. event.preventDefault(); //阻止跳转
  1503. }
  1504. },
  1505. reg_event: function () { // target 处理 更精准
  1506. var list = [
  1507. '.nong-copy',
  1508. '.nong-offline-download'
  1509. ];
  1510. for (var i = 0; i < list.length; i++) {
  1511. var a = document.querySelectorAll(list[i]);
  1512. for (var u = 0; u < a.length; u++) {
  1513. a[u].addEventListener('click', this.handle_event, false);
  1514. }
  1515. }
  1516. },
  1517. },
  1518. // 挊
  1519. searchMagnetRun: function () {
  1520. for (var i = 0; i < main_keys.length; i++) {
  1521. var v = main[main_keys[i]];
  1522.  
  1523. // //for javlibrary
  1524. // if ($("#adultwarningprompt")[0] !== null) {
  1525. // //$("#adultwarningprompt input")[0].click();
  1526. // }
  1527. if (v.re.test(location.href)) {
  1528. if (v.type === 0) {
  1529. try {
  1530. main.cur_vid = v.vid();
  1531. }
  1532. catch (e) {
  1533. main.cur_vid = '';
  1534. }
  1535. if (main.cur_vid) {
  1536. GM_addStyle(`
  1537. #nong-table-new{margin:10px auto;color:#666 !important;font-size:13px;text-align:center;background-color: #F2F2F2;}
  1538. #nong-table-new th,#nong-table-new td{text-align: center;height:30px;background-color: #FFF;padding:0 1em 0;border: 1px solid #EFEFEF;}
  1539. .jav-nong-row{text-align: center;height:30px;background-color: #FFF;padding:0 1em 0;border: 1px solid #EFEFEF;}
  1540. .nong-copy{color:#08c !important;}
  1541. .nong-offline{text-align: center;}
  1542. #jav-nong-head a {margin-right: 5px;}
  1543. .nong-offline-download{color: rgb(0, 180, 30) !important; margin-right: 4px !important;}
  1544. .nong-offline-download:hover{color:red !important;}
  1545. `);
  1546. main.cur_tab = thirdparty.nong.magnet_table.full();
  1547. console.log('h1026 挊的番号:', main.cur_vid);
  1548. v.proc();
  1549.  
  1550. // console.log(main.cur_tab)
  1551. let t = $('#jav-nong-head')[0].firstChild;
  1552. t.firstChild.addEventListener('change', function (e) {
  1553. //debugger;
  1554. console.log("url: http://" + e.target.value);
  1555. GM_setValue('search_index', e.target.value);
  1556. let s = $('#nong-table-new')[0];
  1557. s.parentElement.removeChild(s);
  1558. thirdparty.nong.searchMagnetRun();
  1559. });
  1560.  
  1561. if (GM_getValue('search_index', null) === null) {
  1562. GM_setValue('search_index', Object.keys(thirdparty.nong.resource_sites)[0]);
  1563. }
  1564. thirdparty.nong.search_engines.cur_engine(main.cur_vid, function (src, data) {
  1565. if (data.length === 0) {
  1566. let url = thirdparty.nong.search_engines.full_url;
  1567. $('#nong-table-new #notice').text('No search result! '); //todo 181224
  1568. $('#nong-table-new #notice').append(
  1569. `<a href="${url}" target="_blank" style="color: red;">&nbsp;Go</a>`); //todo 190630
  1570. }
  1571. else {
  1572. thirdparty.nong.magnet_table.updata_table(src, data, 'full');
  1573. /*display search url*/
  1574. var y = $('#jav-nong-head th')[1].firstChild;
  1575. y.href = thirdparty.nong.search_engines.full_url;
  1576. }
  1577. });
  1578. }
  1579. }
  1580. break;
  1581. }
  1582. }
  1583. },
  1584. },
  1585. };
  1586.  
  1587. /**
  1588. * 加载数据 todo 改进
  1589. * @param pageName 访问网页名
  1590. */
  1591. function loadData(pageName , queue) {
  1592. Common.toString();// 无此步骤Common作用域失效,暂时未知原因
  1593. let todo = async ()=>{ // todo 190628
  1594. await loadPageNumData(pageName, 1);
  1595. for (let i = 2; i < GM_getValue(pageName + "_pageNum") + 1; i++) {
  1596. queue.push(()=>{
  1597. let defer = $.Deferred();
  1598. loadPageNumData(pageName, i).then(() => {
  1599. defer.resolve();
  1600. });
  1601. return defer.promise();
  1602. });
  1603. }
  1604. };
  1605. return todo();
  1606. }
  1607.  
  1608. function loadPageNumData(pageName, PageNum) {
  1609. let url = location.origin + "/cn/" + pageName + ".php?&sort=added&page=" + PageNum;// console.log("打开链接url:" + url);
  1610. let commonClass = Common;// 无此步骤Common作用域失效,暂时未知原因
  1611. let promise1 = request(url);
  1612. promise1.then((result) => {
  1613. return new Promise(resolve => {
  1614. if($.type(result) !== "function" && result === "wrong"){
  1615. return resolve();
  1616. }
  1617. let doc = result.responseText;
  1618. //设置初始化总页数
  1619. if(PageNum == 1){
  1620. let docArr = doc.split("的影片: ");
  1621. let totalNum = parseInt(docArr[1].substring(0, docArr[1].search(/<\/div/)));
  1622. GM_setValue(pageName + "_pageNum", parseInt((totalNum + 19) / 20));
  1623. }
  1624. let tableText = doc.substring(doc.search(/<table class="videotextlist">/), doc.search(/<table style="width: 95%; margin: 10px auto;">/));
  1625. //<table class="videotextlist"> //<table style="width: 95%; margin: 10px auto;">
  1626. let $movList = $(commonClass.parsetext(tableText)).find("tr");
  1627. let indexArrStr = "0";
  1628. let timeArrStr = "0";
  1629. let myBrowseJson = "";
  1630. for (let i = 1; i < $movList.length; i++) {
  1631. let movie = $movList.get(i);
  1632. let $aEle = $($(movie).children("td.title").find("a").get(0));
  1633. // 索引编码
  1634. let index_cd = $aEle.attr("href").split("=")[1];
  1635. // 创建时间
  1636. let add_time = $($(movie).children("td").get(2)).text();
  1637. indexArrStr = indexArrStr + index_cd + ',';
  1638. timeArrStr = timeArrStr + add_time + "|";
  1639. myBrowseJson = myBrowseJson + '{"index_cd":"' + index_cd + '","add_time":"' + add_time + '"},';
  1640. }
  1641.  
  1642. // 保存当前页的json格式数据
  1643. GM_setValue(pageName + "_myBrowseJson" + result.finalUrl.split("page=")[1], myBrowseJson);
  1644. console.log("处理完url:" + location.origin + "/ja/" + pageName + ".php?&sort=added&page=" + PageNum);
  1645. resolve();
  1646. });
  1647. });
  1648. return promise1;
  1649. }
  1650. /**
  1651. * 合并json数据
  1652. * @param pageName 访问网页名
  1653. */
  1654. function mergeJson(pageName) {
  1655. // 读取访问指定网页的页数量
  1656. var p = GM_getValue(pageName + "_pageNum");
  1657. if (p > 0) {
  1658. GM_setValue(pageName + "_myBrowseJsonAll", "");
  1659. // 循环合并Json,以同步方式保存.
  1660. let loopMerge = async () => {
  1661. for (let i = 1; i < p; i++) {
  1662. let tempJson = GM_getValue(pageName + "_myBrowseJson" + i);
  1663. if (tempJson && tempJson !== "") {
  1664. await new Promise(resolve => {
  1665. GM_setValue(pageName + "_myBrowseJsonAll", GM_getValue(pageName + "_myBrowseJsonAll") + tempJson);
  1666. resolve();
  1667. })
  1668. }
  1669. }
  1670. };
  1671. return loopMerge().then(()=>{
  1672. console.log("doNum:" + (GM_getValue("doNum") + 1) + " --" +pageName);
  1673. GM_setValue("doNum", GM_getValue("doNum") + 1);
  1674. });
  1675. }
  1676. }
  1677. /**
  1678. * JSON数组去重
  1679. * @param: [array] json Array
  1680. * @param: [string] 唯一的key名,根据此键名进行去重
  1681. */
  1682. function uniqueArray(array, key, func) {
  1683. var result = [array[0]];
  1684. for (var i = 1; i < array.length; i++) {
  1685. var item = array[i];
  1686. var repeat = false;
  1687. for (var j = 0; j < result.length; j++) {
  1688. if (item[key] == result[j][key]) {
  1689. func(item, result[j]);
  1690. repeat = true;
  1691. break;
  1692. }
  1693. }
  1694. if (!repeat) {
  1695. result.push(item);
  1696. }
  1697. }
  1698. return result;
  1699. }
  1700.  
  1701. /**
  1702. * 添加movie信息到myMovie表中
  1703. * @param index_cd 索引编码(网页)
  1704. */
  1705. function addMovie(index_cd) {
  1706. let url = location.origin + "/ja/?v=" + index_cd;
  1707. let commonClass = Common;// 无此步骤Common作用域失效,暂时未知原因
  1708. let promise1 = request(url);
  1709. promise1.then((result) => {
  1710. if($.type(result) !== "function" && result === "wrong"){
  1711. return Promise.resolve();
  1712. }
  1713. let doc = result.responseText;
  1714. let movie_name = doc.substring(doc.search(/<title>/) + 7, doc.search(/ - JAVLibrary<\/title>/));
  1715. let movie_info = doc.substring(doc.search(/<table id="video_jacket_info">/), doc.search(/<div class="socialmedia">/));
  1716. movie_info = movie_info.replace("src", "hobbysrc");
  1717. let $doc = $(commonClass.parsetext(movie_info));
  1718. let movie = {};
  1719. //console.log($doc); // todo
  1720. movie.index_cd = result.finalUrl.split("v=")[1];
  1721. movie.code = $('.header', $doc)[0].nextElementSibling.textContent;
  1722. movie.release_date = $('#video_date .text', $doc).text();
  1723. movie.duration = $('#video_length .text', $doc).text();
  1724. movie.director = $('#video_director .text', $doc).text();
  1725. movie.maker = $('#video_maker .text', $doc).text();
  1726. movie.score = $('#video_review .text .score', $doc).text();
  1727. movie.actor = $('#video_cast .text', $doc).text();
  1728. movie.cover_img_url = $('#video_jacket_img', $doc).attr("hobbysrc").replace("//", "");
  1729. movie.thumbnail_url = movie.cover_img_url.replace("pl", "ps");
  1730. movie.movie_name = movie_name;
  1731. movie.publisher = $('#video_label .text a', $doc).text();
  1732. movie.add_time = (new Date()).Format("yyyy-MM-dd hh:mm:ss");
  1733. movie.is_browse = true;
  1734. movie.is_want = ($('#subscribed .smallbutton.hidden', $doc).length > 0) ? true : false;
  1735. movie.is_seen = ($('#watched .smallbutton.hidden', $doc).length > 0) ? true : false;
  1736. movie.is_have = ($('#owned .smallbutton.hidden', $doc).length > 0) ? true : false;
  1737.  
  1738. let myBrowseJsonArray = JSON.parse(GM_getValue("myBrowseAllData"));
  1739. let jsonObj = myBrowseJsonArray.filter((p) => {
  1740. return p.index_cd == result.finalUrl.split("v=")[1];
  1741. });
  1742. movie.add_time = jsonObj[0].add_time;
  1743. let row = myMovie.createRow(movie);
  1744. javDb.insertOrReplace().into(myMovie).values([row]).exec();
  1745. return Promise.resolve();
  1746. }).catch((e)=>{
  1747. console.log(e);//debugger;
  1748. });
  1749. return promise1;
  1750. }
  1751.  
  1752. /**
  1753. * javbus详情页磁链列表增加复制、115离线快捷键功能函数
  1754. */
  1755. function javbusUs() {
  1756. $('#magnet-table tbody tr td[colspan="4"]').attr("colspan","5");
  1757. let tr_array = $('#magnet-table tr[height="35px"]');
  1758. for (var i = 0; i < tr_array.length; i++) {
  1759. let trEle = tr_array[i];
  1760. //debugger;
  1761. let magnetUrl = $(trEle).find("td a")[0].href;
  1762. $(trEle).append("<td style='text-align:center;'><div><a class='nong-copy' href='" + magnetUrl + "'>复制</a></div></td>");
  1763. $(trEle).append("<td><div class='nong-offline'><a class='nong-offline-download' target='_blank' "
  1764. + "href='http://115.com/?tab=offline&amp;mode=wangpan'>115离线</a></div></td>");
  1765. $(trEle).attr("maglink", magnetUrl);
  1766. $(trEle).find(".nong-copy")[0].addEventListener('click', thirdparty.nong.magnet_table.handle_event, false);
  1767. $(trEle).find(".nong-offline-download")[0].addEventListener('click', thirdparty.nong.magnet_table.handle_event, false);
  1768. //.addEventListener('click', this.handle_event, false);
  1769. }
  1770. }
  1771.  
  1772. function saveData() {
  1773. GM_setValue("doNum", 0);//console.log("saveData");
  1774. let pm1 = mergeJson("mv_wanted");
  1775. let pm2 = mergeJson("mv_watched");
  1776. let pm3 = mergeJson("mv_owned");
  1777.  
  1778. Promise.all([pm1,pm2,pm3]).then(()=>{
  1779. console.log("mergeJson处理完毕");
  1780. if (GM_getValue("doNum") === 3) {
  1781. let j1 = GM_getValue("mv_wanted_myBrowseJsonAll");
  1782. let j2 = GM_getValue("mv_watched_myBrowseJsonAll");
  1783. let j3 = GM_getValue("mv_owned_myBrowseJsonAll");
  1784. //let myBrowseAll = j3.substring(0, j3.length - 1);
  1785. let myBrowseAll = j1 + j2 + j3.substring(0, j3.length - 1);
  1786. let myBrowseArray = JSON.parse("[" + myBrowseAll + "]");
  1787.  
  1788. myBrowseArray = uniqueArray(myBrowseArray, "index_cd", function (item, resultObj) {
  1789. if (item["add_time"] < resultObj["add_time"]) {
  1790. resultObj["add_time"] = item["add_time"];
  1791. }
  1792. });
  1793. GM_setValue("myBrowseAllData", JSON.stringify(myBrowseArray));
  1794. GM_setValue("myBrowseAllNum", myBrowseArray.length);//console.log(JSON.stringify(myBrowseArray));
  1795.  
  1796. let startTime = new Date();//console.log("startTime: " + startTime);
  1797. let b = GM_getValue(domain + "_stepTwo_V2", false);
  1798. if (!b) {
  1799. GM_setValue(domain + "_addMovieNum", 0);
  1800. // 创建请求队列 //浏览器对同一域名进行请求的最大并发连接数:chrome为6
  1801. let queue2 = new Queue(7);
  1802. // 循环数组,将请求数据数组全部添加到并发处理队列中,然后并发执行指定数量的多线程.
  1803. for (let i = 0; i < myBrowseArray.length; i++) {
  1804. let jsonObj = myBrowseArray[i];
  1805. queue2.push(function(){
  1806. let defer = $.Deferred();
  1807. javDb.select().from(myMovie).where(myMovie.index_cd.eq(jsonObj.index_cd)).exec()
  1808. .then((results)=>{
  1809. let log = ()=>{
  1810. console.log(domain + "_addmovieNum:" + (GM_getValue(domain + "_addMovieNum") + 1));
  1811. GM_setValue(domain + "_addMovieNum", (GM_getValue(domain + "_addMovieNum") + 1));
  1812. };
  1813. if (results.length == 0){
  1814. return addMovie(jsonObj.index_cd).then(()=>{
  1815. log();
  1816. defer.resolve();
  1817. return Promise.resolve();
  1818. });
  1819. }
  1820. else {
  1821. log();
  1822. defer.resolve();
  1823. return Promise.resolve();
  1824. }
  1825. });
  1826. return defer.promise();
  1827. });
  1828. }
  1829. var s4 = setInterval(function () {
  1830. if(GM_getValue(domain + "_addMovieNum",0) == myBrowseArray.length){
  1831. console.log(domain + "_stepTwoTime:" + (new Date() - startTime));
  1832. //alert(domain + "_stepTwoTime:" + (new Date() - startTime));
  1833. //GM_setValue(domain + "_stepTwo_V2", true); // todo 需使用
  1834. GM_setValue(domain + "_doDataSyncStepAll_V2", true); // todo 需使用
  1835. clearInterval(s4);
  1836. }
  1837. }, 500);
  1838. }
  1839. }
  1840. });
  1841. }
  1842. /**
  1843. * 针对页面的番号信息增加功能及样式修改. javlib和javbus共同使用
  1844. * @returns {string} 番号
  1845. */
  1846. function getAvidAndChgPage() {
  1847. let AVID = $('.header')[0].nextElementSibling.textContent;
  1848. // 实现点击番号复制到系统剪贴板 todo 181221v1
  1849. $('.header')[0].nextElementSibling.id = "avid";
  1850. $('#avid').empty().attr("title", "点击复制番号").attr("avid", AVID);
  1851. let a_avid = document.createElement('a');
  1852. $(a_avid).attr("href", "#").append(AVID);
  1853. $(a_avid).click(function () {
  1854. GM_setClipboard($('#avid').attr("avid"));
  1855. });
  1856. $('#avid').append(a_avid);
  1857. $('#avid').after("<span style='color:red;'>(←点击复制)</span>");
  1858. $($('.header')[0]).attr("class", "header_hobby");
  1859. return AVID;
  1860. }
  1861.  
  1862. function waterfallButton() {
  1863. // 瀑布流ui按钮
  1864. let a3 = document.createElement('a');
  1865. (waterfallScrollStatus > 0) ? $(a3).append('关闭瀑布流&nbsp;&nbsp;') : $(a3).append('开启瀑布流&nbsp;&nbsp;');
  1866. $(a3).css({
  1867. "color": "blue",
  1868. "font": "bold 12px monospace"
  1869. });
  1870. $(a3).attr("href", "#");
  1871. $(a3).click(function () {
  1872. if ((/关闭/g).test($(this).html())) {
  1873. //$(this).html('&nbsp;&nbsp;开启瀑布流');
  1874. GM_setValue('scroll_status', 0);
  1875. } else {
  1876. //$(this).html('&nbsp;&nbsp;关闭瀑布流');
  1877. GM_setValue('scroll_status', 1);
  1878. }
  1879. window.location.reload();
  1880. });
  1881. return a3;
  1882. }
  1883.  
  1884. function javlibaryScript() {
  1885. let a3 = waterfallButton();
  1886. if ((/(JAVLibrary)/g).test(document.title)) {
  1887. //数据库初始化 start01
  1888. var pm_mater = Common.getSchemaBuilder().connect({
  1889. storeType: lf.schema.DataStoreType.INDEXED_DB
  1890. }).then(function (database) {
  1891. javDb = database;
  1892. myMovie = javDb.getSchema().table('MyMovie');
  1893. //javDb.delete().from(myMovie).exec();// 清空MyMovie表数据.
  1894. return javDb.select().from(myMovie).where(myMovie.is_browse.eq(true)).exec();
  1895. }).then(function (results) {
  1896. console.log("已经保存已阅影片数量:" + results.length);
  1897. // results.forEach(function(row) {
  1898. // console.log(row['index_cd'],'|',row['code'],'|', row['add_time'],'|',row['movie_name']);
  1899. // });
  1900. if (document.URL.indexOf("bestrated") > 0) {
  1901. $(".left select").after("<a href='/cn/vl_bestrated.php?deleteTwoMonthAway' class='hobby-a'>&nbsp;&nbsp;只看近两月份</a>");
  1902. $(".left select").after("<a href='/cn/vl_bestrated.php?deleteOneMonthAway' class='hobby-a'>&nbsp;&nbsp;只看当前月份</a>");
  1903. $(".left select").after("<a href='/cn/vl_bestrated.php?filterMyBrowse' class='hobby-a'>&nbsp;&nbsp;不看我阅览过(上个月)</a>");
  1904. $(".left select").after("<a href='/cn/vl_bestrated.php?filterMyBrowse&mode=2' class='hobby-a'>&nbsp;&nbsp;不看我阅览过(全部)</a>");
  1905. //todo
  1906. } else if (document.URL.indexOf("vl_newrelease") > 0 || document.URL.indexOf("vl_update") > 0
  1907. || document.URL.indexOf("vl_genre") > 0 || document.URL.indexOf("vl_mostwanted") > 0) {
  1908. $(".displaymode .right").prepend("<a href='" + document.location.origin + document.location.pathname
  1909. + "?delete9down" + document.location.search.replace('?', '&') + "' class='hobby-a'>只看9分以上&nbsp;&nbsp;</a>");
  1910. $(".displaymode .right").prepend("<a href='" + document.location.origin + document.location.pathname
  1911. + "?delete8down" + document.location.search.replace('?', '&') + "' class='hobby-a'>只看8分以上&nbsp;&nbsp;</a>");
  1912. $(".displaymode .right").prepend("<a href='" + document.location.origin + document.location.pathname
  1913. + "?delete7down" + document.location.search.replace('?', '&') + "' class='hobby-a'>只看7分以上&nbsp;&nbsp;</a>");
  1914. }
  1915.  
  1916. if ((/(bestrated|newrelease|newentries|vl_update|mostwanted|vl_star)/g).test(document.URL) ||
  1917. (/(vl_genre|vl_searchbycombo|mv_owned|mv_watched|mv_wanted|mv_visited)/g).test(document.URL)||
  1918. (/(vl_label|vl_maker|vl_director|vl_searchbyid|userwanted|userowned)/g).test(document.URL)) {
  1919.  
  1920. // 指定站点页面加入瀑布流控制按钮
  1921. $(".displaymode .right").prepend($(a3));
  1922.  
  1923. // 瀑布流脚本
  1924. thirdparty.waterfallScrollInit();
  1925.  
  1926. let a1 = document.createElement('a');
  1927.  
  1928. $(a1).append('按评分排序&nbsp;&nbsp;');
  1929. $(a1).css({
  1930. "color": "blue",
  1931. "font": "bold 12px monospace"
  1932. });
  1933. $(a1).attr("href", "#");
  1934. $(a1).click(function () {
  1935. let div_array = $("div.videos div.video");
  1936. div_array.sort(function (a, b) {
  1937. //debugger;
  1938. let a_score = parseFloat($(a).children("a").attr("score"));
  1939. let b_score = parseFloat($(b).children("a").attr("score"));
  1940. if (a_score > b_score) {
  1941. return -1;
  1942. } else if (a_score === b_score) {
  1943. return 0;
  1944. } else {
  1945. return 1;
  1946. }
  1947. });
  1948. // 删除Dom列表数据关系,重新添加排序数据
  1949. div_array.detach().appendTo("#waterfall");
  1950. });
  1951.  
  1952. let a2 = $(a1).clone();
  1953. $(a2).html('按时间排序&nbsp;&nbsp;');
  1954. $(a2).click(function () {
  1955. let div_array = $("div.videos div.video");
  1956. div_array.sort(function (a, b) {
  1957. let a_time = new Date($(a).children("a").attr("release_date").replace(/-/g, "\/")).getTime();
  1958. let b_time = new Date($(b).children("a").attr("release_date").replace(/-/g, "\/")).getTime();
  1959. let a_score = parseFloat($(a).children("a").attr("score"));
  1960. let b_score = parseFloat($(b).children("a").attr("score"));
  1961. if (a_time > b_time) {
  1962. return -1;
  1963. } else if (a_time === b_time) {
  1964. return (a_score > b_score) ? -1 : 1;
  1965. } else {
  1966. return 1;
  1967. }
  1968. });
  1969.  
  1970. // 删除Dom列表数据关系,重新添加排序数据
  1971. div_array.detach().appendTo("#waterfall");
  1972. });
  1973. $(".displaymode .right").prepend($(a2));
  1974. $(".displaymode .right").prepend($(a1));
  1975. }
  1976. });
  1977. //JavWebSql.DBinit();
  1978. if ($('a[href="myaccount.php"]').length) {
  1979. // 已经登录
  1980. // 从未同步过,同步云数据到本地数据库
  1981. let isSync = GM_getValue(domain + "_doDataSyncStepAll_V2", false);
  1982. console.log(domain + " 是否同步过:" + isSync);
  1983. if (!isSync) {
  1984. pm_mater.then(() => {
  1985. return new Promise(resolve => {
  1986. var hasStepOne = GM_getValue(domain + "_stepOne_V2", false);
  1987. let stepOneStartTime = new Date();
  1988. console.log(domain + " 同步是否完成第一步:" + hasStepOne);
  1989. if (!hasStepOne) {
  1990. // 立即下载数据
  1991. GM_setValue("mv_wanted_pageNum", 0);
  1992. GM_setValue("mv_watched_pageNum", 0);
  1993. GM_setValue("mv_owned_pageNum", 0);
  1994.  
  1995. //start02 todo lovefieldDB
  1996. // 创建请求队列 //浏览器对同一域名进行请求的最大并发连接数:chrome为6
  1997. let queue = new Queue(7);
  1998. // 读取想要的影片
  1999. loadData("mv_wanted", queue);
  2000. // 读取看过的影片
  2001. loadData("mv_watched", queue);
  2002. // 读取拥有的影片
  2003. loadData("mv_owned", queue);
  2004. // 延迟1秒运行定时循环函数
  2005. setTimeout(() => {
  2006. // 定时循环函数,当队列执行完成时结束
  2007. var s4 = setInterval(function () {
  2008. //console.log("queue.taskList.length : " + queue.taskList.length);
  2009. if (queue.taskList.length == 0) {
  2010. let end_num = 0;
  2011. for (let i = 0, l = queue.threads.length; i < l; i++) {
  2012. if (queue.threads[i].promise.state() === 'resolved') {
  2013. end_num++;
  2014. }
  2015. }
  2016. if (end_num == queue.threads.length) {
  2017. GM_setValue(domain + "_stepOne_V2", true); // todo 需打开
  2018. console.log(domain + "_stepOneTime:" + (new Date() - stepOneStartTime));
  2019. //alert(location.host + "_stepOneTime:" + (new Date() - stepOneStartTime));
  2020. clearInterval(s4);
  2021. resolve();
  2022. }
  2023. }
  2024. }, 300);
  2025. }, 1000);
  2026. } else {
  2027. resolve();
  2028. }
  2029. });
  2030. }).then(() => {
  2031. saveData();
  2032. }
  2033. );
  2034. }
  2035. // 增加同步数据到本地的触发按钮
  2036. }
  2037.  
  2038. //获取番号影片详情页的番号 例如:http://www.javlibrary.com/cn/?v=javli7j724
  2039. if ($('.header').length && $('meta[name="keywords"]').length) {
  2040. let AVID = getAvidAndChgPage();
  2041. $('#video_title h3').html($('#video_title a').html());
  2042. window.onload = function () {
  2043. $('iframe').remove();
  2044.  
  2045. };
  2046.  
  2047. // 只支持javlibray处理已阅影片
  2048. let movie = {};
  2049. movie.index_cd = location.search.split("=")[1];
  2050. movie.code = AVID;
  2051. movie.release_date = $('#video_date .text').text();
  2052. movie.duration = $('#video_length .text').text();
  2053. movie.director = $('#video_director .text').text();
  2054. movie.maker = $('#video_maker .text').text();
  2055. movie.score = $('#video_review .text .score').text();
  2056. movie.actor = $('#video_cast .text').text();
  2057. movie.cover_img_url = $('#video_jacket_img').attr("src").replace("//", "");
  2058. movie.thumbnail_url = movie.cover_img_url.replace("pl", "ps");
  2059. movie.movie_name = $('#video_title a').text();
  2060. movie.publisher = $('#video_label .text a').text();
  2061. movie.add_time = (new Date()).Format("yyyy-MM-dd hh:mm:ss");
  2062. movie.is_browse = true;
  2063. movie.is_want = ($('#subscribed .smallbutton.hidden').length > 0) ? true : false;
  2064. movie.is_seen = ($('#watched .smallbutton.hidden').length > 0) ? true : false;
  2065. movie.is_have = ($('#owned .smallbutton.hidden').length > 0) ? true : false;
  2066. pm_mater.then(() => {
  2067. //查找是否存在此番号数据
  2068. return javDb.select().from(myMovie).where(myMovie.index_cd.eq(movie.index_cd)).exec()
  2069. .then((results) => {
  2070. if (results.length > 0) {
  2071. movie.add_time = results[0].add_time;
  2072. }
  2073. let row = myMovie.createRow(movie);
  2074. javDb.insertOrReplace().into(myMovie).values([row]).exec();
  2075. });
  2076. });
  2077.  
  2078. //查找115是否有此番号
  2079. Common.search115Data(AVID, function (BOOLEAN_TYPE, playUrl) {
  2080. if (BOOLEAN_TYPE) {
  2081. let $imgObj = $('#video_jacket_img');
  2082. $imgObj.after(`
  2083. <div style="position: absolute;width: 100%;height: 12%;background: rgba(0,0,0,0.5);top: 88%;left: 0;">
  2084. <p style="color: white;font-size: 46px;margin: 0 0 0px;display: inline-block;text-align: left;">115网盘已拥有此片</p>
  2085. <a target="_blank" href="${playUrl}">
  2086. <p style="color: white;font-size: 46px;margin: 0 0 0px;display: inline-block;text-align: right;width: 50%;">115在线播放 ►</p></a>
  2087. </div>
  2088. `);
  2089. }
  2090. console.log("番号输出:" + AVID);
  2091. Common.addAvImg(AVID, function ($img) {
  2092. // http://www.javlibrary.com/cn/?v=javlilzo4e
  2093. let divEle = $("div[id='video_title']")[0]; // todo 190604
  2094. if (divEle) {
  2095. $(divEle).after(
  2096. '<div style="width: 100%;height: 100%;display: inline-block;margin: 0px 0px 0px 0px;">' +
  2097. '<div id="hobby_div_left" style="float: left;min-width: 60%;"></div>' +
  2098. '<div id="hobby_div_right" style="float: left;min-width: 66px;"></div>' +
  2099. '</div>'
  2100. );
  2101. $('#hobby_div_left').append($('#video_jacket_info'));
  2102. $('#hobby_div_left').append($('#video_favorite_edit'));
  2103. $('#hobby_div_right').append($img);
  2104. $img.click(function () {
  2105. $(this).toggleClass('min');
  2106. if ($(this).attr("class")) {
  2107. this.parentElement.parentElement.scrollIntoView();
  2108. }
  2109. });
  2110. }
  2111. }, !BOOLEAN_TYPE);
  2112. });
  2113.  
  2114. // 挊
  2115. thirdparty.nong.searchMagnetRun();
  2116. }//番号影片详情页处理end
  2117. }
  2118. }
  2119.  
  2120. function javBusScript() {
  2121. let a3 = waterfallButton();
  2122. if ((/(JavBus|AVMOO|AVSOX)/g).test(document.title) || $("footer:contains('JavBus')").length) {
  2123. // 指定站点页面加入瀑布流控制按钮
  2124. let li_elem = document.createElement('li');
  2125. $(li_elem).append($(a3));
  2126. // JavBus
  2127. $(".visible-md-block").closest(".dropdown").after($(li_elem));
  2128. // AVMOO|AVSOX
  2129. $(".active").closest(".navbar-nav").append($(li_elem));
  2130.  
  2131. // 瀑布流脚本
  2132. thirdparty.waterfallScrollInit();
  2133.  
  2134. //获取番号影片详情页的番号 例如:https://www.javbus.com/AVVR-323
  2135. if ($('.header').length && $('meta[name="keywords"]').length) {
  2136. let AVID = getAvidAndChgPage();
  2137.  
  2138. //查找115是否有此番号
  2139. Common.search115Data(AVID, function (BOOLEAN_TYPE, playUrl) {
  2140. if (BOOLEAN_TYPE) {
  2141. let $imgObj = $('.bigImage');
  2142. $imgObj.after(`
  2143. <div style="position: absolute;width: 100%;height: 12%;background: rgba(0,0,0,0.5);top: 88%;left: 0;">
  2144. <p style="color: white;font-size: 46px;margin: 0 0 0px;display: inline-block;text-align: left;">115网盘已拥有此片</p>
  2145. <a target="_blank" href="${playUrl}">
  2146. <p style="color: white;font-size: 46px;margin: 0 0 0px;display: inline-block;text-align: right;width: 50%;">115在线播放 ►</p></a>
  2147. </div>
  2148. `);
  2149. }
  2150. console.log("番号输出:" + AVID);
  2151. Common.addAvImg(AVID, function ($img) {
  2152. //https://www.javbus.com/CHN-141
  2153. let divEle = $("div[class='col-md-3 info']")[0];
  2154. $(divEle).attr("id", "video_info");
  2155. if (divEle) {
  2156. $(divEle.parentElement).append($img);
  2157. $img.click(function () {
  2158. $(this).toggleClass('min');
  2159. if ($(this).attr("class")) {
  2160. this.parentElement.parentElement.scrollIntoView();
  2161. }
  2162. });
  2163. }
  2164. }, false);//javbus 默认不放大
  2165. });
  2166.  
  2167. thirdparty.busTypeSearch();
  2168. // 加入javlibry的跳转链接
  2169. $('.col-md-3.info').append(`<a href="http://www.javlibrary.com/cn/vl_searchbyid.php?keyword=${AVID}" style="color: rgb(204, 0, 0);">JavLibrary&nbsp;</a>`);
  2170. // 修改javbus磁链列表头,增加两列
  2171. $('#magnet-table tbody tr').append('<td style="text-align:center;white-space:nowrap">操作</td><td style="text-align:center;white-space:nowrap">离线下载</td>');
  2172. // 先执行一次,针对已经提前加载出磁链列表结果时有效
  2173. javbusUs();
  2174. // 针对为提前加载出磁链列表结果,通过dom元素是否改变事件来判断是否执行功能。
  2175. $('#magnet-table').on("DOMNodeInserted", function () {
  2176. // 触发后关闭监听事件
  2177. $('#magnet-table').off();
  2178. javbusUs();
  2179. });
  2180.  
  2181. // 挊
  2182. thirdparty.nong.searchMagnetRun();
  2183. }
  2184. }
  2185. }
  2186.  
  2187. function oneJavScript() {
  2188. if ((/(OneJAV)/g).test(document.title)) { //todo 190404
  2189. GM_addStyle(`
  2190. .min {width:66px;min-height: 233px;height:auto;cursor: pointer;} /*Common.addAvImg使用*/
  2191. .column.is-5 {width: auto;max-width: 82%;}
  2192. .column {flex-basis: inherit;flex-grow: inherit;}
  2193. .container {max-width: 100%;width: 100%;}
  2194. .image {width: 800px;}
  2195. .has-text-grey-dark {max-width: 1000px;}
  2196. `);
  2197. // 插入自己创建的div
  2198. $('div.container nav.pagination.is-centered').before("<div id='card' ></div>");
  2199. // 将所有番号内容移到新建的div里
  2200. $('div#card').append($('div.container div.card.mb-3'));
  2201. // 瀑布流脚本
  2202. thirdparty.waterfallScrollInit();
  2203. }
  2204. }
  2205.  
  2206. function jav321Script() {
  2207. if ((/(jav321)*\/video\/*/g).test(document.URL)) { //todo 190531
  2208. GM_addStyle(`
  2209. .min {width:66px;min-height: 233px;height:auto;cursor: pointer;} /*Common.addAvImg使用*/
  2210. .col-md-3 {width: 20%;padding-left: 18px; padding-right: 2px;}
  2211. .col-xs-12,.col-md-12 {padding-left: 2px; padding-right: 0px;}
  2212. .col-md-7 {width: 79%;padding-left: 2px;padding-right: 0px;}
  2213. .col-md-9 {width: max-content;}
  2214. .col-md-offset-1 {margin-left: auto;}
  2215. .hobby {display: inline-block;float: left;}
  2216. .hobby_mov {width: 75%;}
  2217. .hobby_p {color: white;font-size: 40px;margin: 0 0 0px;display: inline-block;text-align: right;width: 100%;}
  2218. `);
  2219. $(".col-md-7.col-md-offset-1.col-xs-12 .row .col-md-3 .img-responsive:eq(0)").offsetParent().attr("class", "hobby");
  2220. $("#video_overlay_sample").offsetParent().attr("class", "hobby_mov");
  2221. // 调整div位置
  2222. $('div.col-md-7.col-md-offset-1.col-xs-12').before($('div.col-xs-12.col-md-12')[0].parentElement);
  2223.  
  2224. let meta = $('small')[0];
  2225. let arr = meta.textContent.split(" ");
  2226. let javID = arr[0];
  2227.  
  2228. //查找115是否有此番号
  2229. Common.search115Data(javID, function (BOOLEAN_TYPE, playUrl) {
  2230. if (BOOLEAN_TYPE) {
  2231. let $imgObj = $('div.col-xs-12.col-md-12 img.img-responsive');
  2232. $imgObj.after(`
  2233. <div style="position: absolute;width: 100%;height: 22%;background: rgba(0,0,0,0.5);top: 78%;left: 0;">
  2234. <a target="_blank" href="${playUrl}"><p class="hobby_p">115在线播放 ►</p></a>
  2235. </div>
  2236. `);
  2237. }
  2238.  
  2239. //插入预览图
  2240. Common.addAvImg(javID, function ($img) {
  2241. //https://www.jav321.com/video/300mium-391
  2242. var divEle = $("div.col-md-9")[0];
  2243. //$(divEle).attr("id", "video_info");
  2244. if (divEle) {
  2245. $(divEle).after($img);
  2246. $img.click(function () {
  2247. $(this).toggleClass('min');
  2248. if ($(this).attr("class")) {
  2249. this.parentElement.parentElement.scrollIntoView();
  2250. }
  2251. });
  2252. }
  2253. }, !BOOLEAN_TYPE);
  2254. });
  2255.  
  2256. // 修改jav321磁链列表头,增加两列
  2257. $('table.table.table-striped tbody tr:eq(0)').append('<th>操作</th><th>离线下载</th>');
  2258.  
  2259. //详情页磁链列表增加复制、115离线快捷键功能函数
  2260. let tr_array = $('table.table.table-striped tbody tr:gt(0)');
  2261. for (var i = 0; i < tr_array.length; i++) {
  2262. let trEle = tr_array[i];
  2263. //debugger;
  2264. let magnetUrl = $(trEle).find("td a")[0].href;
  2265. $(trEle).append(`
  2266. <td style='text-align:center;'><div><a class='nong-copy' href='${magnetUrl}'>复制</a></div></td>
  2267. <td><div class='nong-offline'>
  2268. <a class='nong-offline-download' target='_blank' href='http://115.com/?tab=offline&amp;mode=wangpan'>115离线</a>
  2269. </div></td>
  2270. `);
  2271. $(trEle).attr("maglink", magnetUrl);
  2272. $(trEle).find(".nong-copy")[0].addEventListener('click', thirdparty.nong.magnet_table.handle_event, false);
  2273. $(trEle).find(".nong-offline-download")[0].addEventListener('click', thirdparty.nong.magnet_table.handle_event, false);
  2274. //.addEventListener('click', this.handle_event, false);
  2275. }
  2276. }
  2277. }
  2278.  
  2279. function mainRun() {
  2280. if ((/(JAVLibrary|JavBus|AVMOO|AVSOX)/g).test(document.title) || $("footer:contains('JavBus')").length){
  2281. GM_addStyle(`
  2282. .min {width:66px;min-height: 233px;height:auto;cursor: pointer;} /*Common.addAvImg使用*/
  2283. .container {width: 100%;float: left;}
  2284. .col-md-3 {float: left;max-width: 260px;}
  2285. .col-md-9 {width: inherit;}
  2286. .hobby-a {color: red; font: bold 12px monospace;} /*javlib*/
  2287. .footer {padding: 20px 0;background: #1d1a18;float: left;} /*javbus*/
  2288. #nong-table-new {margin: initial !important;important;color: #666 !important;font-size: 13px;text-align: center;background-color: #F2F2F2;float: left;}
  2289. .header_hobby {font-weight: bold;text-align: right;width: 75px;} /*javbus*/
  2290. `);
  2291.  
  2292. //获取所有番号影片链接的a元素
  2293. var a_array = $("div[class='item'] a");
  2294. for (var index = 0; index < a_array.length; index++) {
  2295. var aEle = a_array[index];
  2296. $(aEle).attr("target", "_blank");
  2297. }
  2298.  
  2299. javlibaryScript();
  2300. javBusScript();
  2301. }
  2302.  
  2303. oneJavScript();
  2304. jav321Script();
  2305. thirdparty.login115Run();
  2306. }
  2307. mainRun();
  2308. })();