Greasy Fork is available in English.

超星学习通网课脚本小程序-自动搜索考试答案,自动切题,自动答题[最强答题][支持图片题]

自动搜索考试答案,自动切题,自动答题[最强答题][支持图片题]

// ==UserScript==
// @name         超星学习通网课脚本小程序-自动搜索考试答案,自动切题,自动答题[最强答题][支持图片题]
// @namespace    ideys
// @version      1.4.3
// @description  自动搜索考试答案,自动切题,自动答题[最强答题][支持图片题]
// @author       免费王子
// @match        *://*.edu.cn/*
// @match        *://*.chaoxing.com/*
// @match        *://*.chaoxing.com/exam/test/reVersionTestStartNew*
// @match        *://*.edu.cn/exam/test/reVersionTestStartNew*
// @match        *://*.jd.hk/*
// @match        *://*.nbdlib.cn/exam/test/reVersionTestStartNew*
// @match        *://*.jd.com/*
// @match        *://*.hnsyu.net/exam/test/reVersionTestStartNew*
// @match        *://*.taobao.com/*
// @match        *://*.taobao.hk/*
// @match        *://*.tmall.com/*
// @match        *://*.tmall.hk/*
// @match             *://chaoshi.detail.tmall.com/*
// @match             *://*.liangxinyao.com/*
// @match             *://*.yiyaojd.com/*
// @exclude       *://login.taobao.com/*
// @exclude       *://pages.tmall.com/*
// @exclude       *://uland.taobao.com/*
// @connect      cx.icodef.com
// @run-at       document-end
// @grant        unsafeWindow
// @grant        GM_xmlhttpRequest
// @grant        GM_setClipboard
// @grant        GM_setValue
// @grant        GM_getValue
// @license      MIT
// @connect     idey.cn
// @require      https://cdn.staticfile.org/jquery/1.12.4/jquery.min.js
// @require      https://cdn.bootcss.com/jquery.qrcode/1.0/jquery.qrcode.min.js
// @require      https://cdn.bootcss.com/jquery.qrcode/1.0/jquery.qrcode.min.js
// @original-script https://greasyfork.org/zh-CN/scripts/426129
// @original-author coahr
// @original-license MIT
// @antifeature referral-link 隐藏优惠劵查询
// ==/UserScript==
(function() {
 var _self = unsafeWindow;
var $ = $ || window.$;
	//$ = _self.jQuery,

	UE = _self.UE,
    host = window.location.host;
	var index_num = 0;
	var item = [];
	var urls = [];
	var selectorList = [];
	var obj = {};
	obj.onclicks = function(link) {
		if (document.getElementById('redirect_form')) {
			var form = document.getElementById('redirect_form');
			form.action = 'https://jd.idey.cn/red.html?url=' + encodeURIComponent(link);
		} else {
			var form = document.createElement('form');
			form.action = 'https://jd.idey.cn/red.html?url=' + encodeURIComponent(link);
			form.target = '_blank';

			form.method = 'POST';
			form.setAttribute("id", 'redirect_form');
			document.body.appendChild(form);

		}
		form.submit();
		form.action = "";
		form.parentNode.removeChild(form);
	};
	obj.GetQueryString = function(name) {
		var reg = eval("/" + name + "/g");
		var r = window.location.search.substr(1);
		var flag = reg.test(r);
		if (flag) {
			return true;
		} else {
			return false;
		}
	};

	obj.get_url = function() {
		item[index_num] = [];
		urls[index_num] = [];
		$("#J_goodsList li").each(function(index) {
			if ($(this).attr('data-type') != 'yes') {
				var skuid = $(this).attr('data-sku');
				var itemurl = '//item.jd.com/' + skuid + '.html';
				if (skuid != undefined) {
					if (urls[index_num].length < 4) {
						item[index_num].push($(this));
						urls[index_num].push(itemurl);
						$(this).attr('data-type', 'yes');
					}


				}
			}

		})

		$("#plist li").each(function(index) {
			if ($(this).attr('data-type') != 'yes') {
				var skuid = $(this).find('.j-sku-item').attr('data-sku');
				var itemurl = '//item.jd.com/' + skuid + '.html';
				if (skuid != undefined) {
					if (urls[index_num].length < 4) {
						item[index_num].push($(this));
						urls[index_num].push(itemurl);
						$(this).attr('data-type', 'yes');
					}


				}
			}

		})

		$(".m-aside .aside-bar li").each(function(index) {
			if ($(this).attr('data-type') != 'yes') {
				var itemurl = $(this).find("a").attr('href');
				if (itemurl != '') {
					if (itemurl.indexOf("//ccc-x.jd.com") != -1) {
						var sku_c = $(this).attr('sku_c');
						if (sku_c == undefined) {
							var arr = [];
							var str = $(this).attr('onclick');
							arr = str.split(",");
							sku_c = trim(arr[6].replace(/\"/g, ""));
							itemurl = '//item.jd.com/' + sku_c + '.html';
						}

					}
					if (urls[index_num].length < 4) {
						item[index_num].push($(this));
						urls[index_num].push(itemurl);
						$(this).attr('data-type', 'yes');
					}



				}
			}

		})
		$(".goods-chosen-list li").each(function(index) {
			if ($(this).attr('data-type') != 'yes') {
				var itemurl = $(this).find("a").attr('href');
				if (itemurl != '') {
					if (itemurl.indexOf("//ccc-x.jd.com") != -1) {
						var arr = [];
						var str = $(this).attr('onclick');
						arr = str.split(",");
						var sku_c = trim(arr[6].replace(/\"/g, ""));
						itemurl = '//item.jd.com/' + sku_c + '.html';

					}
					if (urls[index_num].length < 4) {
						item[index_num].push($(this));
						urls[index_num].push(itemurl);
						$(this).attr('data-type', 'yes');
					}

				}




			}

		})

		$(".may-like-list li").each(function(index) {
			if ($(this).attr('data-type') != 'yes') {
				var itemurl = $(this).find("a").attr('href');
				if (itemurl != '') {
					if (itemurl.indexOf("//ccc-x.jd.com") != -1) {
						var arr = [];
						var str = $(this).attr('onclick');
						arr = str.split(",");
						var sku_c = trim(arr[6].replace(/\"/g, ""));
						itemurl = '//item.jd.com/' + sku_c + '.html';
					}
					if (urls[index_num].length < 4) {
						item[index_num].push($(this));
						urls[index_num].push(itemurl);
						$(this).attr('data-type', 'yes');
					}


				}
			}

		})



		if (urls.length > 0 && urls[index_num].length > 0 && item[index_num].length > 0) {


			var u = urls[index_num].join(',');
			$.getJSON('https://shop.azkou.cn/jd.php', {
			act:'itemlink',
				itemurl: u,
				num: index_num
			}, function(res) {
				if (res.type == 'success') {
					for (var i = 0; i < res.data.length; i++) {
						item[res.num][i].find("a").attr('data-ref', res.data[i].longUrl);
						item[res.num][i].find("a").attr('target', '');
						item[res.num][i].find("a").unbind("click");
						item[res.num][i].find("a").bind("click", function(e) {
							if ($(this).attr('data-ref')) {
								e.preventDefault();
								obj.onclicks($(this).attr('data-ref'));

							}
						})

					}

				}
			})


		}
		index_num += 1;

	};
	obj.get_miaosha = function() {
		item[index_num] = [];
		urls[index_num] = [];
		$(".seckill_mod_goodslist li").each(function(index) {

			if ($(this).attr('data-type') != 'yes') {

				var itemurl = $(this).find("a").attr('href');
				var skuid = $(this).attr('data-sku');
				var that = $(this);
				if (itemurl != '') {
					if (urls[index_num].length < 4) {

						item[index_num].push($(this));
						urls[index_num].push(itemurl);
						$(this).attr('data-type', 'yes');
					}


				}
			}

		})



		if (urls.length > 0 && urls[index_num].length > 0 && item[index_num].length > 0) {


			var u = urls[index_num].join(',');
			$.getJSON('https://shop.azkou.cn/jd.php', {
			act:'itemlink',
				itemurl: u,
				num: index_num
			}, function(res) {
				if (res.type == 'success') {
					for (var i = 0; i < res.data.length; i++) {
						item[res.num][i].find("a").attr('data-ref', res.data[i].longUrl);
						item[res.num][i].find("a").attr('href', "javascript:void(0);");
						item[res.num][i].find("a").attr('target', '');
						//	item[res.num][i].find("a").unbind("click");

						item[res.num][i].find("a").click(function(e) {
							e.preventDefault();
							obj.onclicks($(this).attr('data-ref'));
						})

					}

				}
			})


		}
		index_num += 1;
	};
	const style = `
			.gwd_taobao .gwd-minibar-bg, .gwd_tmall .gwd-minibar-bg {
			    display: block;
			}

			.idey-minibar_bg{
			    position: relative;
			    min-height: 40px;
			    display: inline-block;
			}
			#idey_minibar{
			    width: 560px;
			    background-color: #fff;
			    position: relative;
			    border: 1px solid #e8e8e8;
			    display: block;
			    line-height: 36px;
			    font-family: 'Microsoft YaHei',Arial,SimSun!important;
			    height: 36px;
			    float: left;
			}
			#idey_minibar .idey_website {
			    width: 48px;
			    float: left;
			    height: 36px;
			}
			#idey_minibar .minibar-tab {
			    float: left;
			    height: 36px;
			    border-left: 1px solid #edf1f2!important;
			    padding: 0;
			    margin: 0;
			    text-align: center;
			}

			#idey_minibar .idey_website em {
			    background-position: -10px -28px;
			    height: 36px;
			    width: 25px;
			    float: left;
			    margin-left: 12px;
			}

			.setting-bg {
			    background: url(https://cdn.gwdang.com/images/extensions/xbt/new_wishlist_pg5_2.png) no-repeat;
			}

			#idey_minibar .minibar-tab {
			    float: left;
			    height: 36px;
			    border-left: 1px solid #edf1f2!important;
			    padding: 0;
			    margin: 0;
			    width: 134px;
			}
			#idey_price_history span {
			    float: left;
			    width: 100%;
			    text-align: center;
			    line-height: 36px;
			    color: #666;
			    font-size: 14px;
			}

			#mini_price_history .trend-error-info-mini {
			    position: absolute;
			    top: 37px;
			    left: 0px;
			    width: 100%;
			    background: #fff;
			    z-index: 99999999;
			    height: 268px;
			    box-shadow: 0px 5px 15px 0 rgb(23 25 27 / 15%);
			    border-radius: 0 0 4px 4px;
			    width:559px;
			    border: 1px solid #ddd;
			    border-top: none;
				display:none;

			}
			.minibar-btn-box {
			    display: inline-block;
			    margin: 0 auto;
			    float: none;
			}
			#mini_price_history .error-p {
			      width: 95px;
			      margin: 110px auto;
			      height: 20px;
			      line-height: 20px;
			      text-align: center;
			      color: #000!important;
			      border: 1px solid #333;
			      border-radius: 5px;
			      display: block;
			      text-decoration: none!important;
			    }
			 #mini_price_history:hover .trend-error-info-mini {
			      display: block;
			    }

			.collect_mailout_icon {
			    background-position: -247px -134px;
			    width: 18px;
			}

			#idey_mini_compare_detail li *, .mini-compare-icon, .minibar-btn-box * {
			    float: left;
			}
			.panel-wrap{
				width: 100%;
				height: 100%;
			}
			.collect_mailout_icon, .mini-compare-icon {
			    height: 18px;
			    margin-right: 8px;
			    margin-top: 9px;
			}
			.all-products ul li {
			    float: left;
			    width: 138px;
			    height: 262px;
			    overflow: hidden;
			    text-align: center;
			}
			.all-products ul li .small-img {
			    text-align: center;
			    display: table-cell;
			    vertical-align: middle;
			    line-height: 90px;
			    width: 100%;
			    height: 100px;
			    position: relative;
			    float: left;
			    margin-top: 23px;
			}
			.all-products ul li a img {
			    vertical-align: middle;
			    display: inline-block;
			    width: auto;
			    height: auto;
			    max-height: 100px;
			    max-width: 100px;
			    float: none;
			}
			.all-products ul li a.b2c-other-info {
			    text-align: center;
			    float: left;
			    height: 16px;
			    line-height: 16px;
			    margin-top: 13px;
			}

			.b2c-other-info .gwd-price {
			    height: 17px;
			    line-height: 17px;
			    font-size: 16px;
			    color: #E4393C;
			    font-weight: 700;
				width: 100%;
				display: block;
			}
			.b2c-other-info .b2c-tle {
			    height: 38px;
			    line-height: 19px;
			    margin-top: 8px;
			    font-size: 12px;
			    width: 138px;
			    margin-left: 29px;
			}
			 .bjgext-mini-trend span {
			      float: left;
			      /*width: 100%;*/
			      text-align: center;
			      line-height: 36px;
			      color: #666;
			      font-size: 14px;
			    }
			    .bjgext-mini-trend .trend-error-info-mini {
			      position: absolute;
			      top: 37px;
			      left: 0px;
			      width: 100%;
			      background: #fff;
			      z-index: 99999999;
			      height: 268px;
			      display: none;
			      box-shadow: 0px 5px 15px 0 rgba(23,25,27,0.15);
			      border-radius: 0 0 4px 4px;
			      width: 460px;
			      border: 1px solid #ddd;
			      border-top: none;
			    }
			    .bjgext-mini-trend .error-p {
			      width: 100%;
			      float: left;
			      text-align: center;
			      margin-top: 45px;
			      font-size: 14px;
			      color: #666;
			    }
			    .bjgext-mini-trend .error-sp {
			      width: 95px;
			      margin: 110px auto;
			      height: 20px;
			      line-height: 20px;
			      text-align: center;
			      color: #000!important;
			      border: 1px solid #333;
			      border-radius: 5px;
			      display: block;
			      text-decoration: none!important;
			    }
			    .bjgext-mini-trend:hover .trend-error-info-mini {
			      display: block;
			    }


			    #coupon_box.coupon-box1 {
			      width: 560px;
			      height: 125px;
			      background-color: #fff;
			      border: 1px solid #e8e8e8;
			      border-top: none;
			      position: relative;
			      margin: 0px;
			      padding: 0px;
			      float: left;
			      display: block;
			    }
			    #coupon_box:after {
			      display: block;
			      content: "";
			      clear: both;
			    }
			    .idey_tmall #idey_minibar {
			      float: none;
			    }


			    .minicoupon_detail {
			      position: absolute;
			      top: 35px;
			      right: -1px;
			      height: 150px;
			      width: 132px;
			      display: none;
			      z-index: 99999999999;
			      background: #FFF7F8;
			      border: 1px solid #F95774;
			    }
			    #coupon_box:hover .minicoupon_detail {
			      display: block;
			    }
			    .minicoupon_detail img {
			      width: 114px;
			      height: 114px;
			      float: left;
			      margin-left: 9px;
			      margin-top: 9px;
			    }
			    .minicoupon_detail span {
			      font-size: 14px;
			      color: #F95572;
			      letter-spacing: 0;
			      font-weight: bold;
			      float: left;
			      height: 12px;
			      line-height: 14px;
			      width: 100%;
			      margin-top: 6px;
			      text-align: center;
			    }
			    .coupon-box1 * {
			      font-family: 'Microsoft YaHei',Arial,SimSun;
			    }
			    .coupon-icon {
			      float: left;
			      width: 20px;
			      height: 20px;
			      background: url('https://cdn.gwdang.com/images/extensions/newbar/coupon_icon.png') 0px 0px no-repeat;
			      margin: 50px 8px 9px 12px;
			    }
			    #coupon_box .coupon-tle {
			      color: #FF3B5C;
			      font-size: 24px;
			      margin-right: 11px;
			      float: left;
			      height: 114px;
			      overflow: hidden;
			      text-overflow: ellipsis;
			      white-space: nowrap;
			      width: 375px;
			      line-height: 114px;
			      text-decoration: none!important;
			    }
			    #coupon_box .coupon-row{
			         color: #FF3B5C;
			      font-size: 12px;
			      margin-right: 11px;
			      float: left;
			      height: 60px;
			      overflow: hidden;
			      text-overflow: ellipsis;
			      white-space: nowrap;
			      width: 100%;
			      line-height: 60px;
			      text-decoration: none!important;
			        text-align: center;
			    }
			    #coupon_box .coupon-tle * {
			      color: #f15672;
			    }
			    #coupon_box .coupon-tle span {
			      margin-right: 5px;
			      font-weight: bold;
			      font-size: 14px;
			    }
			    .coupon_gif {
			      background: url('https://cdn.gwdang.com/images/extensions/newbar/turn.gif') 0px 0px no-repeat;
			      float: right;
			      height: 20px;
			      width: 56px;
			      margin-top: 49px;
			    }
			    .click2get {
			      background: url('https://cdn.gwdang.com/images/extensions/newbar/coupon_01.png') 0px 0px no-repeat;
			      float: left;
			      height: 30px;
			      width: 96px;
			      margin-top: 43px;
			    }
			    .click2get span {
			      height: 24px;
			      float: left;
			      margin-left: 1px;
			    }
			    .c2g-sp1 {
			      width: 50px;
			      color: #FF3B5C;
			      text-align: center;
			      font-size: 14px;
			      line-height: 24px!important;
			    }
			    .c2g-sp2 {
			      width: 44px;
			      line-height: 24px!important;
			      color: #fff!important;
			      text-align: center;
			    }
			    div#idey_wishlist_div.idey_wishlist_div {
			      border-bottom-right-radius: 0px;
			      border-bottom-left-radius: 0px;
			    }
			    #qrcode{
			         float: left;
			        width: 125px;
			        margin-top:3px;
			    }


			    .elm_box{
			        height: 37px;
			     border: 1px solid #ddd;
			     width: 460px;
			     line-height: 37px;
			     margin-bottom: 3px;
			         background-color: #ff0036;
			             font-size: 15px;
			    }
			    .elm_box span{
			            width: 342px;
			    text-align: center;
			    display: block;
			    float: left;
			    color: red;
			    color: white;
			    }`


	function trim(str) {
		return str.replace(/(^\s*)|(\s*$)/g, "");
	}

	function removeEvent(that, href) {
		that.find("a").attr('target', '');
		that.find("a").unbind("click");
		that.find("a").bind("click", function(e) {
			e.preventDefault();
			if (href != undefined) {
				obj.onclicks(href);
			} else {
				obj.onclicks($(this).attr('href'));
			}

		})
	}
	obj.initStyle = function() {
		var styles = document.createElement('style')
		styles.type = 'text/css'
		styles.innerHTML = style;
		document.getElementsByTagName('head').item(0).appendChild(styles)
	}

obj.initSearchHtml = function(selectorList) {
  	setInterval(function() {
  		selectorList.forEach(function(selector) {
  			obj.initSearchItemSelector(selector);
  		});
  	}, 3000);
  };

  obj.initSearchEvent = function() {
  	$(document).on("click", ".tb-cool-box-area", function() {
  		var $this = $(this);
  		if ($this.hasClass("tb-cool-box-wait")) {
  			obj.basicQueryItem(this);
  		} else if ($this.hasClass("tb-cool-box-info-translucent")) {
  			$this.removeClass("tb-cool-box-info-translucent");
  		} else {
  			$this.addClass("tb-cool-box-info-translucent");
  		}
  	});
  };

  obj.basicQuery = function() {
  	setInterval(function() {
  		$(".tb-cool-box-wait").each(function() {
  			obj.basicQueryItem(this);
  		});
  	}, 3000);
  };

  obj.initSearchItemSelector = function(selector) {
  	$(selector).each(function() {
  		obj.initSearchItem(this);
  	});
  };

  obj.initSearchItem = function(selector) {
  	var $this = $(selector);
  	if ($this.hasClass("tb-cool-box-already")) {
  		return;
  	} else {
  		$this.addClass("tb-cool-box-already")
  	}

  	var nid = $this.attr("data-id");
  	if (!obj.isVailidItemId(nid)) {
  		nid = $this.attr("data-itemid");
  	}

  	if (!obj.isVailidItemId(nid)) {
  		if ($this.attr("href")) {
  			nid = location.protocol + $this.attr("href");
  		} else {
  			var $a = $this.find("a");
  			if (!$a.length) {
  				return;
  			}

  			nid = $a.attr("data-nid");
  			if (!obj.isVailidItemId(nid)) {
  				if ($a.hasClass("j_ReceiveCoupon") && $a.length > 1) {
  					nid = location.protocol + $($a[1]).attr("href");
  				} else {
  					nid = location.protocol + $a.attr("href");
  				}
  			}
  		}
  	}

  	if (obj.isValidNid(nid)) {
  		obj.basicQueryItem($this, nid);
  	}
  };



  obj.basicQueryItem = function(selector, nid) {
  	var $this = $(selector);
  	$.get('https://tb.idey.cn/tb.php?act=itemlink&itemid=' + nid, function(data) {
  		if (data.type == 'success') {
  			obj.changeUrl($this, data.data);
  		} else {

  		}
  	}, 'json')
  };

  obj.changeUrl = function(selector, data) {
  	var $this = $(selector);
  	var a = $this.find("a");
  	$this.find("a").attr('href', data.itemUrl);
  	$this.find("a").attr('data-href', data.itemUrl);
  	$this.find("a").click(function(e){
  					   e.preventDefault();
              				 obj.onclicks($(this).attr('data-href'));
  					})
  }


  obj.isDetailPageTaoBao = function(url) {
  	if (url.indexOf("//item.taobao.com/item.htm") > 0 || url.indexOf("//detail.tmall.com/item.htm") > 0 ||
  		url.indexOf("//chaoshi.detail.tmall.com/item.htm") > 0 || url.indexOf(
  			"//detail.tmall.hk/hk/item.htm") > 0) {
  		return true;
  	} else {
  		return false;
  	}
  };

  obj.isVailidItemId = function(itemId) {
  	if (!itemId) {
  		return false;
  	}

  	var itemIdInt = parseInt(itemId);
  	if (itemIdInt == itemId && itemId > 10000) {
  		return true;
  	} else {
  		return false;
  	}
  };

  obj.isValidNid = function(nid) {
  	if (!nid) {
  		return false;
  	} else if (nid.indexOf('http') >= 0) {
  		if (obj.isDetailPageTaoBao(nid) || nid.indexOf("//detail.ju.taobao.com/home.htm") > 0) {
  			return true;
  		} else {
  			return false;
  		}
  	} else {
  		return true;
  	}
  };

  obj.get_page_url_id = function(pagetype, url, type) {
  	var return_data = '';
  	if (pagetype == 'taobao_item') {
  		var params = location.search.split("?")[1].split("&");
  		for (var index in params) {
  			if (params[index].split("=")[0] == "id") {
  				var productId = params[index].split("=")[1];
  			}
  		}
  		return_data = productId;
  	}
  	return return_data;
  }
	obj.get_type_url = function(url) {
		if (
			url.indexOf("//item.taobao.com/item.htm") > 0 ||
			url.indexOf("//detail.tmall.com/item.htm") > 0 ||
			url.indexOf("//chaoshi.detail.tmall.com/item.htm") > 0 ||
			url.indexOf("//detail.tmall.hk/hk/item.htm") > 0 ||
			url.indexOf("//world.tmall.com") > 0 ||
			url.indexOf("//detail.liangxinyao.com/item.htm") > 0 ||
			url.indexOf("//detail.tmall.hk/item.htm") > 0
		) {
			return 'taobao_item';
		} else if (
			url.indexOf("//maiyao.liangxinyao.com/shop/view_shop.htm") > 0 ||
			url.indexOf("//list.tmall.com/search_product.htm") > 0 ||
			url.indexOf("//s.taobao.com/search") > 0 ||
			url.indexOf("//list.tmall.hk/search_product.htm") > 0
		) {
			return 'taobao_list';
		} else if (
			url.indexOf("//search.jd.com/Search") > 0 ||
			url.indexOf("//search.jd.com/search") > 0 ||
			url.indexOf("//search.jd.hk/search") > 0 ||
			url.indexOf("//search.jd.hk/Search") > 0 ||
			url.indexOf("//www.jd.com/xinkuan") > 0 ||
			url.indexOf("//list.jd.com/list.html") > 0 ||
			url.indexOf("//search.jd.hk/Search") > 0 ||
			url.indexOf("//coll.jd.com") > 0
		) {
			return 'jd_list';
		} else if (
			url.indexOf("//item.jd.hk") > 0 ||
			url.indexOf("//pcitem.jd.hk") > 0 ||
			url.indexOf("//i-item.jd.com") > 0 ||
			url.indexOf("//item.jd.com") > 0 ||
			url.indexOf("//npcitem.jd.hk") > 0 ||
 url.indexOf("//item.yiyaojd.com") > 0
		) {
			return 'jd_item';
		} else if (
			url.indexOf("//miaosha.jd.com") > 0
		) {
			return 'jd_miaosha';
		} else if (
			url.indexOf("//www.jd.com") > 0 ||
            url.indexOf("//jd.com") > 0
		) {
			return 'jd_index';
		}

	}
	var pageurl = location.href;
	var pagetype = obj.get_type_url(pageurl);

	if (pagetype == 'taobao_item') {
		obj.initStyle(style);
			var productId = obj.get_page_url_id(pagetype, pageurl, pageurl);
						var couponurl = "https://www.idey.cn/api/index/recove_url?itemurl=" + encodeURIComponent(location.href) +
							'&itemid=' +
							productId;
						$.getJSON(couponurl, function(res) {
							var data = res.data;

							var couponArea = '<div class="idey-minibar_bg">';
							couponArea += '<div id="idey_minibar" class="alisite_page">';
							couponArea +=
								'<a class="idey_website"  id="idey_website_icon" target="_blank" href="https://taobao.idey.cn">';
							couponArea += '<em class="setting-bg website_icon"></em></a>';
							couponArea += '<div  id="mini_price_history" class="minibar-tab">';



							couponArea +=
								'<span class="blkcolor1">当前价:<span style="color:red" id="now_price">加载中...</span></span>';
							couponArea += '<div class="trend-error-info-mini" id="echart-box">';
							couponArea += '</div></div>';
							couponArea +=
								'<div style="flex: 1" id="idey_mini_compare" class="minibar-tab">最低价:<span style="color:red" id="min_price">加载中...</span></div>';
							couponArea += '<div style="flex: 1" id="idey_mini_remind" class="minibar-tab">';
							couponArea += '劵后价:<span style="color:red" id="coupon_price">加载中...</span>';

							couponArea += ' </div></div>';
							couponArea +=
								' <div class="idey-mini-placeholder idey-price-protect"></div><div id="promo_box"></div>';



							if (res.type == 'success') {
								if (data.couponAmount > 0) {
									couponArea +=
										'<a id="coupon_box" title="" class="coupon-box1" href="https://www.idey.cn/api/index/redirect_url?itemid=' +
										productId + '&couponid=' + data.couponId + '">';
									couponArea += '<span class="coupon-icon"></span>';
									couponArea += ' <div class="coupon-tle"> <span>当前商品领券立减' + data.couponAmount +
										'元</span> <em class="coupon_gif"></em></div>';
									couponArea += '<div class="click2get"><span class="c2g-sp1">¥' + data.couponAmount +
										'</span><span class="c2g-sp2">领取</span></div>';
									couponArea += '</a>';
								}

							} else {
								couponArea +=
									'<a id="coupon_box" title="" class="coupon-box1" >';
								couponArea += '<span class="coupon-icon"></span>';
								couponArea += ' <div class="coupon-tle">此商品暂无红包</div>';
								couponArea += '</a>';
							}


							if (data.alist.length > 0) {
								for (let i = 0; i < data.alist.length; i++) {
									couponArea +=
										'<div style="border:1px solid red;line-height:60px;color:red;font-size:20px;text-align:center;width:525px"><a href="' +
										data.alist[i].url + '" target="_blank">' + data.alist[i].name + '</a></div>'
								}
							}
 
							if (location.href.indexOf("//detail.tmall") != -1) {
								$(".tm-fcs-panel").after(couponArea);
							} else {
								$("ul.tb-meta").after(couponArea);
							}
							if (data.item_link.originalPrice) {
								$("#now_price").html('¥' + data.item_link.originalPrice);
							}
							if (data.item_link.actualPrice) {
								$("#coupon_price").html('¥' + data.item_link.actualPrice);
							}
							if (res.type == 'error' && data.item_link.itemUrl) {
								$('#qrcode').qrcode({
									render: "canvas", //也可以替换为table
									width: 110,
									height: 110,
									text: data.item_link.itemUrl
								});
							} else {
								$('#qrcode').qrcode({
									render: "canvas", //也可以替换为table
									width: 110,
									height: 110,
									text: data.item_link.pageurl
								});
							}


						});

	} else if (pagetype == 'jd_item') {
		obj.initStyle(style);
		var productId = /(\d+)\.html/.exec(window.location.href)[1];
		var couponurl = "https://shop.azkou.cn/jd.php?act=recovelink&itemurl=" + encodeURIComponent(location.href) +
			'&itemid=' + productId;
			$.getJSON(couponurl, function(res) {
				var data = res.data;
				if (!obj.GetQueryString('jd.idey.cn') && data) {
					window.location.href = 'https://jd.idey.cn/red.html?url=' + encodeURIComponent(data);
				}

			});
		var couponurls = "https://shop.azkou.cn/jd.php?act=item&itemurl=" + encodeURIComponent(location.href) +
			'&itemid=' + productId;

		$.getJSON(couponurls, function(res) {
			var data = res.data;

			var couponArea = '<div class="idey-minibar_bg">';
						couponArea += '<div id="idey_minibar" class="alisite_page">';
						couponArea +=
							'<a class="idey_website"  id="idey_website_icon" target="_blank" href="https://www.idey.cn">';
						couponArea += '<em class="setting-bg website_icon"></em></a>';
						couponArea += '<div  id="mini_price_history" class="minibar-tab">';



						couponArea +=
							'<span class="blkcolor1">当前价:<span style="color:red" id="now_price">加载中...</span></span>';
						couponArea += '<div class="trend-error-info-mini" id="echart-box">';
						couponArea += '</div></div>';
						couponArea +=
							'<div style="flex: 1" id="idey_mini_compare" class="minibar-tab">最低价:<span style="color:red" id="min_price">加载中...</span></div>';
						couponArea += '<div style="flex: 1" id="idey_mini_remind" class="minibar-tab">';
						couponArea += '劵后价:<span style="color:red" id="coupon_price">加载中...</span>';

						couponArea += ' </div></div>';
						couponArea +=
							' <div class="idey-mini-placeholder idey-price-protect"></div><div id="promo_box"></div>';

						

						if (res.type == 'success') {
							if (data.couponLinkType == 1) {
								couponArea +=
									'<a id="coupon_box" title="" class="coupon-box1" href="' + data.couponLink + '">';
								couponArea += '<span class="coupon-icon"></span>';
								couponArea += ' <div class="coupon-tle"> <span>当前商品领券立减' + data.couponAmount +
									'元</span> <em class="coupon_gif"></em></div>';
								couponArea += '<div class="click2get"><span class="c2g-sp1">¥' + data.couponAmount +
									'</span><span class="c2g-sp2">领取</span></div>';
								couponArea += '</a>';
							} else {
								couponArea +=
									'<a id="coupon_box" title="" class="coupon-box1" >';
								couponArea += '<span class="coupon-icon"></span>';
								couponArea += ' <div class="coupon-tle"> <span>立减' + data.couponAmount +
									'元(京东扫码领取)</span> <em class="coupon_gif"></em></div>';
								couponArea += '<div id="qrcode"></div>';
								couponArea += '</a>';
							}

						} else {

							couponArea +=
								'<a id="coupon_box" title="" class="coupon-box1" >';
							couponArea += '<span class="coupon-icon"></span>';
							couponArea += ' <div class="coupon-tle">此商品暂无红包</div>';

							couponArea += '</a>';


						}

						if (data.alist && data.alist.length > 0) {
									for (let i = 0; i < data.alist.length; i++) {
										couponArea +=
											'<div style="border:1px solid red;line-height:60px;color:red;font-size:20px;text-align:center;width:560px"><a href="' +
											data.alist[i].url + '" target="_blank">' + data.alist[i].name + '</a></div>'
									}
								}
						$(".summary-price-wrap").after(couponArea);

						if (data.couponLink) {
							$('#qrcode').qrcode({
								render: "canvas", //也可以替换为table
								width: 125,
								height: 120,
								text: data.couponLink
							});

						} else if (data.item_link.shortUrl) {
							$('#qrcode').qrcode({
								render: "canvas", //也可以替换为table
								width: 125,
								height: 120,
								text: data.item_link.shortUrl
							});
						} else {
							$('#qrcode').qrcode({
								render: "canvas", //也可以替换为table
								width: 125,
								height: 120,
								text: data.item_link.longUrl
							});
						}
						if (data.item_link.originalPrice) {
							$("#now_price").html('¥' + data.item_link.originalPrice);
						}
						if (data.item_link.actualPrice) {
							$("#coupon_price").html('¥' + data.item_link.actualPrice);
						}
					});



	}else if (pagetype == 'taobao_list') {
 var url = location.href;
								if (url.indexOf("//s.taobao.com/search") > 0 || url.indexOf("//s.taobao.com/list") > 0) {
									selectorList.push(".items .item");
								} else if (url.indexOf("//list.tmall.com/search_product.htm") > 0) {
									selectorList.push(".product");
									selectorList.push(".chaoshi-recommend-list .chaoshi-recommend-item");
								} else if (url.indexOf("//list.tmall.hk/search_product.htm") > 0) {
									selectorList.push("#J_ItemList .product");
								} else if (document.getElementById('J_ShopSearchResult')) {
									selectorList.push("#J_ShopSearchResult .item");
								}
								if (selectorList && selectorList.length > 0) {
									obj.initSearchHtml(selectorList);
								}

		}else if (pagetype == 'jd_list') {
		setInterval(obj.get_url, 300);

	} else if (pagetype == 'jd_miaosha') {
		$(".seckill_mod_goodslist li").find("a").click(function(e) {
			if ($(this).attr('data-ref')) {
				e.preventDefault();
				obj.onclicks($(this).attr('data-ref'));
			}
		})

		setInterval(obj.get_miaosha, 300);

	} else{
		// 设置修改后,需要刷新或重新打开网课页面才会生效
var setting = {
    // 2E3 == 2000,科学记数法,表示毫秒数
    time: 2E3 // 默认响应速度为5秒,不建议小于2秒
    , review: 0 // 复习模式,完整挂机视频(音频)时长,支持挂机任务点已完成的视频和音频,默认关闭
    , queue: 1 // 队列模式,开启后任务点逐一完成,关闭则单页面所有任务点同时进行,默认开启
    // 1代表开启,0代表关闭
    , video: 1 // 视频支持后台、切换窗口不暂停,支持多视频,默认开启
    , work: 1 // 自动答题功能(章节测验),作业需要手动开启查询,高准确率,默认开启
    , audio: 1 // 音频自动播放,与视频功能共享vol和rate参数,默认开启
    , book: 1 // 图书阅读任务点,非课程阅读任务点,默认开启
    , docs: 1 // 文档阅读任务点,PPT类任务点自动完成阅读任务,默认开启
    // 本区域参数,上方为任务点功能,下方为独立功能
    , jump: 1 // 自动切换任务点、章节、课程(需要配置course参数),默认开启
    , read: '65' // 挂机课程阅读时间,单位是分钟,'65'代表挂机65分钟,请手动打开阅读页面,默认'65'分钟
    , face: 1 // 解除面部识别(不支持二维码类面部采集),此功能仅为临时解除,默认开启
    , total: 1 // 显示课程进度的统计数据,在学习进度页面的上方展示,默认开启
    // 仅开启video(audio)时,修改此处才会生效
    , line: '公网1' // 视频播放的默认资源线路,此功能适用于系统默认线路无资源,默认'公网1'
    , http: '标清' // 视频播放的默认清晰度,无效参数则使用系统默认清晰度,默认'标清'
    // 本区域参数,上方为video功能独享,下方为audio功能共享
    , vol: '0' // 默认音量的百分数,设定范围:[0,100],'0'为静音,默认'0'
    , rate: '1' // 视频播放默认倍率,参数范围0∪[0.0625,16],'0'为秒过,默认'1'倍
    // 仅开启work时,修改此处才会生效
    , auto1: 1 // 答题完成后自动提交,默认开启
    , none: 0 // 无匹配答案时执行默认操作,关闭后若题目无匹配答案则会暂时保存已作答的题目,默认开启
    , scale: 0 // 富文本编辑器高度自动拉伸,用于文本类题目,答题框根据内容自动调整大小,默认关闭
    // 仅开启jump时,修改此处才会生效
    , course: 1 // 当前课程完成后自动切换课程,仅支持按照根目录课程顺序切换,默认开启
    , lock: 1 // 跳过未开放(图标是锁)的章节,即闯关模式或定时发放的任务点,默认开启
},
    _self = unsafeWindow,
    url = location.pathname,
    top = _self,
    script_info=GM_info.script;
 
jq_layer();
if(GM_getValue("jump")!=undefined){
    setting.jump=GM_getValue("jump");
}
if(GM_getValue("auto")!=undefined){
    setting.auto1=GM_getValue("auto");
}
if(GM_getValue("none")!=undefined){
    setting.none=GM_getValue("none");
}
if(GM_getValue("queue")!=undefined){
    setting.queue=GM_getValue("queue");
}
if(GM_getValue("course")!=undefined){
    setting.course=GM_getValue("course");
}
if(GM_getValue("rate")!=undefined){
    setting.rate=GM_getValue("rate");
}
var pz={
};
var tmpSubmit = 1;//本次
Object.defineProperty(setting, "auto", {
    get: function () {
        if (tmpSubmit >= 2) {
            return tmpSubmit === 3;
        }
        return GM_getValue("autosubmit");
    }, set: function (value) {
        tmpSubmit = value + 2;
    }
});
setting.notice = '公告栏';
if (url != '/studyApp/studying' && top != _self.top) document.domain = location.host.replace(/.+?\./, '');
try {
    while (top != _self.top) {
        top = top.parent.document ? top.parent : _self.top;
        if (top.location.pathname == '/mycourse/studentstudy') break;
    }
} catch (err) {
    // console.log(err);
    top = _self;
}
var $ = _self.jQuery || top.jQuery,
    parent = _self == top ? self : _self.parent,
    Ext = _self.Ext || parent.Ext || {},
    UE = _self.UE,
    vjs = _self.videojs;
$('body').mousedown(function(e){
    if(3 == e.which){
        setting_s();
    }
})
if (url != '/module/audioplay.html'){
    try {
        pz.layui= _self.layui || top.layui;
        pz.layui.use('layer', function () {
            pz.layer=this.layer;
            pz.layer.closeAll();
 
 
        });
 
    } catch (err) {
 
    }
}
 
$('head').append('<link href="https://lib.baomitu.com/layui/2.6.8/css/layui.css" rel="stylesheet" type="text/css" />');
$('.Header').find('a:contains(回到旧版)')[0]?$('.Header').find('a:contains(回到旧版)')[0].click():'';
String.prototype.toCDB = function () {
    return this.replace(/\s/g, '').replace(/[\uff01-\uff5e]/g, function (str) {
        return String.fromCharCode(str.charCodeAt(0) - 65248);
    }).replace(/[“”]/g, '"').replace(/[‘’]/g, "'").replace(/。/g, '.');
};
setting.normal = ''; // ':visible'
// setting.time += Math.ceil(setting.time * Math.random()) - setting.time / 2;
setting.job = [':not(*)'];
 
setting.video && setting.job.push('iframe[src*="/video/index.html"]');
setting.work && setting.job.push('iframe[src*="/work/index.html"]');
setting.audio && setting.job.push('iframe[src*="/audio/index.html"]');
setting.book && setting.job.push('iframe[src*="/innerbook/index.html"]');
setting.docs && setting.job.push('iframe[src*="/ppt/index.html"]', 'iframe[src*="/pdf/index.html"]');
setting.tip = !setting.queue || top != _self && jobSort($ || Ext.query);
console.log(url);
if (url == '/mycourse/studentstudy') {
 
    _self.checkMobileBrowerLearn = $.noop;
    var classId = location.search.match(/cla[zs]{2}id=(\d+)/i)[1] || 0,
        courseId = _self.courseId || location.search.match(/courseId=(\d+)/i)[1] || 0;
    setting.lock || $('#coursetree').on('click', '[onclick*=void], [href*=void]', function () {
        _self.getTeacherAjax(courseId, classId, $(this).parent().attr('id').slice(3));
    });
} else if (url == '/ananas/modules/video/index.html' && setting.video) {
 
    if (setting.review) _self.greenligth = Ext.emptyFn;
    checkPlayer(_self.supportH5Video());
 
} else if (url == '/work/doHomeWorkNew' || url == '/api/work' || url == '/work/addStudentWorkNewWeb'|| url == '/mooc2/work/dowork') {
    setting.knowledgeId=0
    try {
        setting.knowledgeId= location.search.match(/knowledgeid=(\d+)/i)[1];
    } catch (err) {}
    if (setting.knowledgeId==0&&typeof unsafeWindow.layui == 'undefined') {
        var Head = document.getElementsByTagName('head')[0] || document.documentElement;
        var JQ = document.createElement('script');
        JQ.src = 'https://lib.baomitu.com/layui/2.6.8/layui.js';
        JQ.type = 'text/javascript';
        JQ.async = true;
        Head.insertBefore(JQ, Head.firstChild);
        GM_wait();
    }else{
        work_start();
    }
    function GM_wait() {
        if (typeof unsafeWindow.layui == 'undefined') {
            console.log("正在加载");
            window.setTimeout(GM_wait, 100);
        } else {
            work_start()
        }
    }
    function work_start(){
        console.log("加载成功");
        pz.layui=unsafeWindow.layui;
        console.log("进入答题界面!");
        if (!UE) {
            var len = ($ || Ext.query || Array)('font:contains(未登录)', document).length;
            setTimeout(len == 1 ? top.location.reload : parent.greenligth, setting.time);
        } else if (setting.work) {
            setTimeout(relieveLimit, 0);
            beforeFind();
        }
    }
 
} else if (url == '/ananas/modules/audio/index.html' && setting.audio) {
    if (setting.review) _self.greenligth = Ext.emptyFn;
    _self.videojs = hookAudio;
    hookAudio.xhr = vjs.xhr;
} else if (url == '/ananas/modules/innerbook/index.html' && setting.book && setting.tip) {
    setTimeout(function () {
        _self.setting ? _self.top.onchangepage(_self.getFrameAttr('end')) : _self.greenligth();
    }, setting.time);
} else if (url.match(/^\/ananas\/modules\/(ppt|pdf)\/index\.html$/) && setting.docs && setting.tip) {
    setTimeout(function () {
        _self.setting ? _self.finishJob() : _self.greenligth();
    }, setting.time);
    frameElement.setAttribute('download', 1);
} else if (url == '/knowledge/cards') {
    $ && checkToNext()
} else if (url.match(/^\/(course|zt)\/\d+\.html$/)) {
    setTimeout(function () {
        +setting.read && _self.sendLogs && $('.course_section:eq(0) .chapterText').click();
    }, setting.time);
} else if (url == '/ztnodedetailcontroller/visitnodedetail') {
    setting.read *= 60 / $('.course_section').length;
    setting.read && _self.sendLogs && autoRead();
} else if (url == '/mycourse/studentcourse') {
    var gv = location.search.match(/d=\d+&/g);
    setting.total && $('<a>', {
        href: '/moocAnalysis/chapterStatisticByUser?classI' + gv[1] + 'courseI' + gv[0] + 'userId=' + _self.getCookie('_uid') + '&ut=s',
        target: '_blank',
        title: '点击查看章节统计',
        style: 'margin: 0 25px;',
        html: '本课程共' + $('.icon').length + '节,剩余' + $('em:not(.openlock)').length + '节未完成'
    }).appendTo('.zt_logo').parent().width('auto');
} else if (url.match(/^\/visit\/(courses|interaction|stucoursemiddle)$/)) {
    setting.face && $('.zmodel').on('click', '[onclick^=openFaceTip]', DisplayURL);
} else if (location.hostname == 'i.mooc.chaoxing.com') {
    console.log("课程页面");
} else if (url == '/widget/pcvote/goStudentVotePage') {
    $(':checked').click();
    $('.StudentTimu').each(function (index) {
        var ans = _self.questionlist[index].answer;
        $(':radio, :checkbox', this).each(function (num) {
            ans[num].isanswer && this.click();
        });
        $(':text', this).val(function (num) {
            return $(ans[num].content).text().trim();
        });
    });
} else if (url == '/work/selectWorkQuestionYiPiYue') {
    submitAnswer(getIframe().parent(), $.extend(true, [], parent._data));
}else if(url =='/exam/test/reVersionTestStartNew'){
    console.log("考试");
 
    kss();
}
 
function hookVideo() {
    _self.alert = console.log;
    //console.log(arguments);
    var config = arguments[1];
    if (!config) {
        return vjs.apply(this, arguments);
    }
    var line = Ext.Array.filter(Ext.Array.map(config.playlines, function (value, index) {
        return value.label == setting.line && index;
    }), function (value) {
        return Ext.isNumber(value);
    }
                               )[0] || 0,
        http = Ext.Array.filter(config.sources, function (value) {
            return value.label == setting.http;
        })[0];
    config.playbackRates = [0.5, 1, 1.5, 2, 4,6, 8, 16];
    config.playlines.unshift(config.playlines[line]);
    config.playlines.splice(line + 1, 1);
    config.plugins.videoJsResolutionSwitcher.default = http ? http.res : 360;
    config.plugins.studyControl.enableSwitchWindow = 1;
    config.plugins.timelineObjects.url = "/richvideo/initdatawithviewer?";
    config.plugins.seekBarControl.enableFastForward = 1;
    if (!setting.queue) delete config.plugins.studyControl;
 
    var player = vjs.apply(this, arguments),
        a ='<a href="https://s1.ananas.chaoxing.com/download/' +_self.config("objectid") +'" target="_blank">',
        img ='<img src="https://d0.ananas.chaoxing.com/download/e363b256c0e9bc5bd8266bf99dd6d6bb" style="margin: 6px 0 0 6px;">';
    player.playbackRate=function (t){
        if(void 0===t)return "•"+this.cache_.lastPlaybackRate||this.techGet_("playbackRate");
        this.tech_&&this.tech_.featuresPlaybackRate?this.cache_.lastPlaybackRate||this.techGet_("playbackRate"):setting.rate;
        this.techCall_("setPlaybackRate",t)
    };
    player.volume(Math.round(setting.vol) / 100 || 0);
    player.on("loadstart", function () {
        setting.tip && this.play().catch(Ext.emptyFn);
        this.playbackRate(
            setting.rate > 16 || setting.rate < 0.0625 ? 1 : setting.rate
        );
    });
    player.one(["loadedmetadata", "firstplay"], function () {
        setting.two = (setting.rate === "0" || GM_getValue("fast")==1)&& setting.two < 1;
        setting.two &&config.plugins.seekBarControl.sendLog(this.children_[0],"ended",Math.floor(this.cache_.duration));
    });
    player.on("ended", function () {
        Ext.fly(frameElement).parent().addCls("ans-job-finished");
    });
 
    return player;
}
function hookAudio() {
    _self.alert = console.log;
    var config = arguments[1];
    config.plugins.studyControl.enableSwitchWindow = 1;
    config.plugins.seekBarControl.enableFastForward = 1;
    if (!setting.queue) delete config.plugins.studyControl;
    var player = vjs.apply(this, arguments),
        a = '<a href="https://d0.ananas.chaoxing.com/download/' + _self.config('objectid') + '" target="_blank">',
        img = '<img src="https://d0.ananas.chaoxing.com/download/e363b256c0e9bc5bd8266bf99dd6d6bb" style="margin: 6px 0 0 6px;">';
    player.volume(Math.round(setting.vol) / 100 || 0);
    player.playbackRate(setting.rate > 16 || setting.rate < 0.0625 ? 1 : setting.rate);
    Ext.get(player.controlBar.addChild('Button').el_).setHTML(a + img + '</a>').dom.title = '下载音频';
    player.on('loadeddata', function () {
        setting.tip && this.play().catch(Ext.emptyFn);
    });
    player.one('firstplay', function () {
        setting.rate === '0' && config.plugins.seekBarControl.sendLog(this.children_[0], 'ended', Math.floor(this.cache_.duration));
    });
    player.on('ended', function () {
        Ext.fly(frameElement).parent().addCls('ans-job-finished');
    });
    return player;
}
function relieveLimit() {
    if (setting.scale) _self.UEDITOR_CONFIG.scaleEnabled = false;
    $.each(UE.instants, function () {
        var key = this.key;
        this.ready(function () {
            this.destroy();
            UE.getEditor(key);
        });
    });
}
function setting_s(){
    if(!pz.layer){
        try {
            pz.layui= _self.layui || top.layui;
            pz.layui.use('layer', function () {
                pz.layer=this.layer;
                pz.layer.closeAll();
 
            });
        } catch (err) {
            console.log("加载失败");
        }
    }
    pz.queue=(setting.queue===1?"checked":"");
    pz.work=setting.work===1?"checked":"";
    pz.book=setting.book===1?"checked":"";
    pz.jump=setting.jump===1?"checked":"";
    pz.none=(setting.none==1)?"checked":"";
    pz.review=setting.review===1?"checked":"";
    pz.course=setting.course===1?"checked":"";
    pz.video=setting.video===1?"checked":"";
    pz.layer.open({
        type: 1,
        area: ['400px', '300px'],
        closeBtn: 1,
        title: "脚本参数设置",
        shade: 0,
        anim: 2,
        id:"sett2",
        content:'<script src="https://www.layuicdn.com/layui/layui.js"></script> <form class="layui-form"> <div class="layui-form-item"> <label class="layui-form-label">间隔时间</label> <div class="layui-input-inline"> <input type="number" name="time" value="'+setting.time+'" required lay-verify="required" placeholder="间隔时间" class="layui-input"> </div> <div class="layui-form-mid layui-word-aux">脚本运行间隔时间/推荐4000毫秒</div> </div> <div class="layui-form-item"> <label class="layui-form-label">视频倍率</label> <div class="layui-input-inline"> <input type="number" name="rate" value="'+setting.rate+'" required lay-verify="required" placeholder="视频倍率" class="layui-input"> </div> <div class="layui-form-mid layui-word-aux">倍速有风险,秒过需谨慎。【0秒刷,1-16倍速自己填】</div> </div> <div class="layui-form-item"> <label class="layui-form-label">队列刷课</label> <div class="layui-input-inline"> <input type="checkbox" name="queue" '+pz.queue+' lay-skin="switch"> </div> <div class="layui-form-mid layui-word-aux">开启后任务点逐一完成,关闭则单页面所有任务点同时进行</div> </div> <div class="layui-form-item"> <label class="layui-form-label">自动跳转</label> <div class="layui-input-inline"> <input type="checkbox" name="jump" '+pz.jump+' lay-skin="switch"> </div> <div class="layui-form-mid layui-word-aux">自动切换任务点、章节、课程</div> </div> <div class="layui-form-item"> <label class="layui-form-label">答案匹配</label> <div class="layui-input-inline"> <input type="checkbox" name="none" '+pz.none+' lay-skin="switch"> </div> <div class="layui-form-mid layui-word-aux">无答案是否随机答案,若有准确率需求勿开</div> </div> </form>'
        ,cancel: function(index,layero){
            $(layero[0]).find("input").each(function(){
                if(this.name=="time"){
                    setting.time=this.value;
                    GM_setValue("time",this.value);
                }
                else if(this.name=="rate"){
                    setting.rate=this.value;
                    GM_setValue("rate",this.value);
                }
                else{
                    if($(this).attr("checked")){
                        setting[this.name]=1
                        GM_setValue(this.name,1);
                    }else{
                        setting[this.name]=0;
                        GM_setValue(this.name,0);
                    }
                }
            });
            console.log(setting);
            pz.layer.msg("保存成功!",{"icon":1});
        }
    });
}
function kss(){
    function findTiMu() {
        var courseId = location.search.match(/courseId=(\d+)/i)[1] || 0,
            classId=location.search.match(/classId=(\d+)/i)[1] || 0,
            zurl='http://s.jiaoyu139.com:886/get?t=ks';
        GM_xmlhttpRequest({
            method: 'POST',
            url: zurl,
            data:'keyword=' + encodeURIComponent(setting.TiMu[0]) + '&courseid='+courseId,
            headers: {
                'Content-type': 'application/x-www-form-urlencoded',
                '_t': 'cx',
                'referer':location.href,
                'v':script_info.version,
                'u':script_info.author,
                'host':"www.baidu.com"
            },
            timeout: 5000,
            onload: function(xhr) {
                if (!setting.loop) {
                } else if (xhr.status == 200) {
                    var obj = $.parseJSON(xhr.responseText) || {};
                    obj.answer = obj.data.answer;
                    if (obj.code) {
                        var answer = String(obj.answer).replace(/&/g, '&').replace(/<(?!img)/g, '<'),
                            que = setting.TiMu[0].match('<img') ? setting.TiMu[0] : setting.TiMu[0].replace(/&/g, '&').replace(/</g, '<');
                        obj.answer = /^http/.test(answer) ? '<img src="' + obj.answer + '">' : obj.answer;
                        setting.div.find('tbody').append(
                            '<tr>' +
                            '<td title="点击可复制">' + que + '</td>' +
                            '<td title="点击可复制">' + (/^http/.test(answer) ? obj.answer : '') + answer + '</td>' +
                            '</tr>'
                        );
                        setting.copy && GM_setClipboard(obj.answer);
                        setting.$btn.eq(3).show();
                        fillAnswer(obj);
                    } else {
                        $(setting.layerdom).find("#pz_tips").html(obj.answer || '服务器繁忙,正在重试...');
 
                    }
                    $(setting.layerdom).find("#cx-notice").html(obj.msg || '');
                } else if (xhr.status == 403) {
                    obj = $.parseJSON(xhr.responseText) || {};
                    $(setting.layerdom).find("#pz_tips").html('访问限制,正在重试...');
                    $(setting.layerdom).find('#cx-notice').html(obj.msg);
                    //$(setting.layerdom).find("#pz_stop").click();
                } else {
                    $(setting.layerdom).find("#pz_tips").html('服务器异常,正在重试...');
                }
            },
            ontimeout: function() {
                setting.loop && $(setting.layerdom).find("#pz_tips").html('服务器超时,正在重试...');
            }
        });
 
    }
 
    function fillAnswer(obj, tip) {
        var $input = $(':radio, :checkbox', '.Cy_ulBottom'),
            str = String(obj.answer).toCDB() || new Date().toString(),
            data = str.split(/#|\x01|\|/),
            opt = obj.opt || str,
            btn = $('.saveYl:contains(下一题)').offset();
        // $input.filter(':radio:checked').prop('checked', false);
        obj.code > 0 && $input.each(function(index) {
            if (this.value == 'true') {
                data.join().match(/(^|,)(False|false|正确|是|对|√|T|ri)(,|$)/) && this.click();
            } else if (this.value == 'false') {
                data.join().match(/(^|,)(False|false|错误|否|错|×|F|wr)(,|$)/) && this.click();
            } else {
                index = setting.TiMu[3][index].toCDB() || new Date().toString();
                index = $.inArray(index, data) + 1 || (setting.TiMu[1] == '1' && str.indexOf(index) + 1);
                Boolean(index) == this.checked || this.click();
            }
        }).each(function() {
            if (!/^A?B?C?D?E?F?G?$/.test(opt)) return false;
            Boolean(opt.match(this.value)) == this.checked || this.click();
        });
        if (setting.TiMu[1].match(/^[013]$/)) {
            tip = $input.is(':checked') || setting.none && (($input[Math.floor(Math.random() * $input.length)] || $()).click(), ' ');
        } else if (setting.TiMu[1].match(/^(2|[4-9]|1[08])$/)) {
            data = String(obj.answer).split(/#|\x01|\|/);
            tip = $('.Cy_ulTk textarea').each(function(index) {
                index = (obj.code > 0 && data[index]) || '';
                UE.getEditor(this.name).setContent(index.trim());
            }).length;
            tip = (obj.code > 0 && data.length == tip) || setting.none && ' ';
            setting.len = str.length * setting.time / 10;
        }
        if (tip == ' ') {
            tip = '已执行默认操作';
        } else if (tip) {
            tip = '自动答题已完成';
        } else if (tip === undefined) {
            tip = '该题型不支持自动答题';
        } else {
            tip = '未找到有效答案';
        }
        if (btn) {
            tip += setting.jump ? ',即将切换下一题' : ',未开启自动切换';
            setInterval(function() {
                if (!setting.jump) return;
                var mouse = document.createEvent('MouseEvents'),
                    arr = [btn.left + Math.ceil(Math.random() * 80), btn.top + Math.ceil(Math.random() * 26)];
                mouse.initMouseEvent('click', true, true, document.defaultView, 0, 0, 0, arr[0], arr[1], false, false, false, false, 0, null);
                _self.event = $.extend(true, {}, mouse);
                delete _self.event.isTrusted;
                _self.getTheNextQuestion(1);
            }, setting.len || Math.ceil(setting.time * Math.random()) * 2);
        } else {
            $(setting.layerdom).find("#pz_sub").hide();
            $(setting.layerdom).find("#pz_xq").toggle();
            tip = '答题已完成,请自行查看答题详情';
        }
 
        $(setting.layerdom).find("#pz_tips").html(tip);
        $(setting.layerdom).find("#pz_stop").hide().click();
    }
 
    setting.notice = '公告栏';
    GM_xmlhttpRequest({
        method: 'GET',
        url: 'http://s.jiaoyu139.com:886/index/msg',
        headers: {
            '_t': 'cx',
            'v':script_info.version,
            'u':script_info.author,
            'host':"www.baidu.com"
        },
        timeout: 5000,
        onload: function (xhr) {
            if (xhr.status == 200) {
                var obj = $.parseJSON(xhr.responseText) || {};
                setting.notice = obj.msg;
 
                $(setting.layerdom).find("#cx-notice").html( setting.notice);
            }
        },
        ontimeout: function () {
            setting.loop &&$(setting.layerdom).find("#pz_tips").html(setting.over + '服务器超时,正在重试...');
        }
    });
 
    String.prototype.toCDB = function() {
        return this.replace(/\s/g, '').replace(/[\uff01-\uff5e]/g, function(str) {
            return String.fromCharCode(str.charCodeAt(0) - 65248);
        }).replace(/[“”]/g, '"').replace(/[‘’]/g, "'").replace(/。/g, '.');
    };
 
    // setting.time += Math.ceil(setting.time * Math.random()) - setting.time / 2;
    setting.TiMu = [
        filterImg('.Cy_TItle .clearfix').replace(/\s*(\d+\.\d+分)$/, ''),
        $('[name^=type]:not([id])').val() || '-1',
        $('.cur a').text().trim() || '无',
        $('li .clearfix').map(function() {
            return filterImg(this);
        })
    ];
    if(typeof unsafeWindow.layui == 'undefined'){
        var Head = document.getElementsByTagName('head')[0] || document.documentElement,
            JQ = document.createElement('script');
        JQ.src = 'https://lib.baomitu.com/layui/2.6.8/layui.js';
        JQ.type = 'text/javascript';
        JQ.async = true;
        Head.insertBefore(JQ, Head.firstChild);
        GM_wait();
    }
    function GM_wait() {
        if (typeof unsafeWindow.layui == 'undefined') {
            console.log("正在加载");
            window.setTimeout(GM_wait, 100);
        } else {
            work_start()
        }
    }
    function work_start(){
        setting.layui=unsafeWindow.layui;
        if(!setting.layer){
            try {
                setting.layui= _self.layui || top.layui;
                setting.layui.use('layer', function () {
                    setting.layer=this.layer;
                    setting.layer.closeAll();
 
                });
                console.log("加载成功");
            } catch (err) {
                console.log("加载失败");
 
            }
        }
        setting.layer.open({
            type: 1,
            area: ['500px', '300px'],
            offset: 'lb',
            closeBtn: 0,
            title: "超星考试小助手",
            maxmin:true,
            moveOut:true,
            shade: 0,
            anim: 2,
 
            success: function(layero, index){
                if(!setting.top){
                    setting.top=layero[0].offsetTop
                }
                setting.layerdom=layero[0];
                setting.layerindex=index;
            },
            restore:function(){
                setting.layer.style(setting.layerindex, {
                    top:setting.top,
                    right:'0px'
                });
            },
            content: '<div id="msgzz" ><blockquote class="layui-elem-quote layui-quote-nm">'+
            '<button type="button" id="pz_stop"  class="layui-btn layui-btn-normal ">暂停答题<button>'+
            '<button type="button" id="pz_res"  class="layui-btn layui-btn-normal ">重新查询<button>'+
            '<button type="button"  style="display: none;" id="pz_xq"  class="layui-btn layui-btn-normal ">详情<button>'+
            '<button type="button" id="pz_sub"  class="layui-btn layui-btn-normal ">' + (setting.jump ? '停止本次切换' : '开启本次切换') + '<button>'+
            '</blockquote><div id="pz_tips"></div>'+
            '<div class="layui-collapse"><div class="layui-colla-item"><h2 class="layui-colla-title">公告</h2><div class="layui-colla-content layui-show" ><div id="cx-notice">加载中...</div></div></div>'
            +'<div id="content"><ul></ul>		<table class="layui-table"> <colgroup><col> <col> </colgroup> <thead> <tr><th>题目</th> <th>答案</th> </tr> </thead> <tbody>  </tbody> </table></div></div></div>'
        });
 
 
        setting.div = $(setting.layerdom).appendTo('body').on('click', 'button, td', function() {
 
            var num = setting.$btn.index(this);
            console.log(this.id);
            num=99;
            //console.log(num);
            if (num == -1) {
                GM_setClipboard($(this).text());
            } else if (this.id=="pz_stop") {
                if (setting.loop) {
                    clearInterval(setting.loop);
                    delete setting.loop;
                    num = ['已暂停搜索', '继续答题'];
                } else {
                    setting.loop = setInterval(findTiMu, setting.time);
                    num = ['正在搜索答案...', '暂停答题'];
                }
                setting.$div.html(function() {
                    return $(this).data('html') || num[0];
                }).removeData('html');
                $(this).html(num[1]);
            } else if (this.id=="pz_sub") {
                setting.jump = 0;
                setting.$div.html(function() {
                    return arguments[1].replace('即将切换下一题', '未开启自动切换');
                });
                setting.div.find('tfoot').add(this).toggle();
            } else if (this.id=="pz_res") {
                location.reload();
            } else if (this.id=="pz_xq") {
                ($('.leftCard .saveYl')[0] || $()).click();
            } else if (num == 5) {
                setting.tk_num++;
                GM_setValue('tk_num_1',setting.tk_num);
                setting.tk_num = GM_getValue('tk_num_1');
                console.log(setting.tk_num);
                parent.location.reload();
            }
        }).detach(setting.hide ? '*' : 'html');
 
 
 
        setting.$btn = setting.div.children('button');
        setting.$div = setting.div.children('div:eq(0)');
 
        $(document).keydown(function(event) {
            if (event.keyCode == 38) {
                setting.div.detach();
            } else if (event.keyCode == 40) {
                setting.div.appendTo('body');
            }
        });
 
        if (setting.scale) _self.UEDITOR_CONFIG.scaleEnabled = false;
        $.each(UE.instants, function() {
            var key = this.key;
            this.ready(function() {
                this.destroy();
                UE.getEditor(key);
            });
        });
        setting.loop = setInterval(findTiMu, setting.time);
 
    }
}
function beforeFind() {
 
    setting.regl = parent.greenligth || $.noop;
    if ($.type(parent._data) == 'array') return setting.regl();
    if(!pz.layer){
        try {
            pz.layui= _self.layui || top.layui;
            pz.layui.use('layer', function () {
                pz.layer=this.layer;
                pz.layer.closeAll();
 
            });
        } catch (err) {
            console.log("加载失败");
        }
    }
    pz.layer.open({
        type: 1,
        area: ['500px', '300px'],
        offset: 'rb',
        closeBtn: 0,
        title: "超星小助手",
        maxmin:true,
        moveOut:true,
        shade: 0,
        anim: 2,
 
        success: function(layero, index){
            if(!pz.top){
                pz.top=layero[0].offsetTop
            }
            pz.layerdom=layero[0];
            pz.layerindex=index;
        },
        restore:function(){
            pz.layer.style(pz.layerindex, {
                top:pz.top,
                right:'0px'
            });
        },
        content: '<div id="msgzz" ><blockquote class="layui-elem-quote layui-quote-nm">'+
        '<button type="button" id="pz_stop"  class="layui-btn layui-btn-normal ">暂停答题<button>'+
        '<button type="button" id="pz_res"  class="layui-btn layui-btn-normal ">重新查询<button>'+
        '<button type="button" id="pz_sub"  class="layui-btn layui-btn-normal ">' + (setting.auto1 ? '取消本次自动提交' : '开启本次自动提交') + '<button>'+
        '<button type="button" id="pz_gg"  class="layui-btn layui-btn-normal ">设置<button>'+
        '</blockquote><div id="pz_tips"></div>'+
        '<div class="layui-collapse"><div class="layui-colla-item"><h2 class="layui-colla-title">公告</h2><div class="layui-colla-content layui-show" ><div id="cx-notice">加载中...</div></div></div>'
        +'<div id="content"><ul></ul>		<table class="layui-table"> <colgroup> <col width="50"> <col> <col> </colgroup> <thead> <tr> <th>序号</th> <th>题目</th> <th>答案</th> </tr> </thead> <tbody>  </tbody> </table></div></div></div>'
    });
 
    setting.div = $(pz.layerdom).on('click', 'button, td, input', function () {
        var len = $(this).prevAll('button').length;
        if (this.nodeName == 'TD') {
            $(this).prev().length && GM_setClipboard($(this).text());
        } else if (!$(this).siblings().length) {
            $(this).parent().text('正在搜索答案...');
            setting.num++;
        } else if (this.id =="pz_stop") {
            if (setting.loop) {
                clearInterval(setting.loop);
                delete setting.loop;
                len = ['已暂停搜索', '继续答题'];
            } else {
                setting.loop = setInterval(findAnswer, setting.time);
                len = ['正在搜索答案...', '暂停答题'];
            }
            pz.layer.title(len[0], pz.layerindex);
            $(this).html(len[1]);
        } else if (this.id == "pz_sub") {
            setting.auto1 = !setting.auto1;
            $(this).html(setting.auto1 ? '取消本次自动提交' : '开启本次自动提交');
        } else if (this.id == "pz_res") {
            parent.location.reload();
        } else if (this.id=="pz_gg") {
            setting_s();
            //$(pz.layerdom).find('#cx-notice').toggle();
        } else if (this.id == "autosubmit") {
            // 题目自动提交配置
            GM_setValue("autosubmit", this.checked);
        }
    }).end();
    setting.lose = setting.num = 0;
    setting.data = parent._data = [];
    setting.over = '<button style="margin-right: 10px;">跳过此题</button>';
    setting.curs = $('script:contains(courseName)', top.document).text().match(/courseName:\'(.+?)\'|$/)[1] || $('h1').text().trim() || '无';
    setting.loop = setInterval(findAnswer, setting.time);
    var tip = ({ undefined: '任务点排队中', null: '等待切换中' })[setting.tip];
    tip && $(pz.layerdom).find("#pz_stop").hide().click()&&$(pz.layerdom).find("#pz_tips").html(tip);
    GM_xmlhttpRequest({
        method: 'GET',
        url: 'http://s.jiaoyu139.com:886/index/msg',
        timeout: 5000,
        headers: {
            '_t': 'cx',
            'v':script_info.version,
            'u':script_info.author,
            'host':"www.baidu.com"
        },
        onload: function (xhr) {
            if (xhr.status == 200) {
                var obj = $.parseJSON(xhr.responseText) || {};
                setting.notice = obj.msg;
                $(pz.layerdom).find('#cx-notice').html(setting.notice);
            }
        },
        ontimeout: function () {
            setting.loop && pz.layer.title('服务器超时,正在重试...', pz.layerindex);
        }
    });
}
function findAnswer() {
    //$("html,body").animate({scrollTop: $('.TiMu').eq(setting.num).offset().top}, 1000);
    var pz_num=setting.num+1,
        pz_badnum=setting.lose+1;
    $(pz.layerdom).find("#pz_tips").html('共获取<span class="layui-bg-blue">&nbsp;' + $('.TiMu').length +'&nbsp;<\/span>道题目,正在完成第<span class="layui-bg-blue">&nbsp;' + pz_num + '&nbsp;<\/span>道题,无答案<span class="layui-bg-red">&nbsp;' + setting.lose + '&nbsp;<\/span>道题。');
    if (setting.num >= $('.TiMu').length) {
        pz.layer.title('答题已完成', pz.layerindex);
        var arr = setting.lose ? ['共获取<span class="layui-bg-blue">&nbsp;' + $('.TiMu').length +'&nbsp;<\/span>道题目,共<span class="layui-bg-red">&nbsp;' +setting.lose + '&nbsp;<\/span>待完成。', saveThis] : ['答题已完成,共<span class="layui-bg-blue">&nbsp;' + $('.TiMu').length +'&nbsp;<\/span>道题目', submitThis];
        $(pz.layerdom).find("#pz_stop").hide().click();
        $(pz.layerdom).find("#pz_tips").html(arr[0]);
        return setTimeout(arr[1], setting.time);
    }
    var $TiMu = $('.TiMu').eq(setting.num),
        question = filterImg($TiMu.find('.Zy_TItle:eq(0) .clearfix')).replace(/^【.*?】\s*/, '').replace(/\s*(\d+\.\d+分)$/, '').replace(/[(]\s*[)]。$/, '').replace(/(\s*)。$/, '').replace(/[(]\s*[)]$/, '').replace(/(\s*)$/, '').replace(/。$/, ''),
        type = $TiMu.find('input[name^=answertype]:eq(0)').val() || '-1';
    if(question == ""){
        question = filterImg($TiMu.find('.mark_name:eq(0) .colorDeep'));
    }
    var courseId = location.search.match(/courseId=(\d+)/i)[1];
    var classId= location.search.match(/classId=(\d+)/i)[1];
    var knowledgeId=0
    try {
        knowledgeId= location.search.match(/knowledgeid=(\d+)/i)[1];
    } catch (err) {
    }
    GM_xmlhttpRequest({
        method: 'POST',
        url: 'http://s.jiaoyu139.com:886/get?t=zj',
        data: 'keyword=' + encodeURIComponent(question) + '&courseid='+courseId+'&type=' + type + '&workid=' + ($('#workRelationId').val() || $('#oldWorkId').val())+"&classid="+classId+"&knowledgeid="+knowledgeId,
        headers: {
            'Content-type': 'application/x-www-form-urlencoded',
            '_t': 'cx',
            'referer':location.href,
            'v':script_info.version,
            'u':script_info.author,
            'host':"www.baidu.com"
        },
        timeout: 5000,
        onload: function (xhr) {
            var obj;
            if (!setting.loop) {
            } else if (xhr.status == 200) {
                obj = $.parseJSON(xhr.responseText) || {};
                obj.answer = obj.data.answer;
                if (obj.code) {
                    pz.layer.title('正在搜索答案...', pz.layerindex);
                    var td = '<td ',
                        answer = String(obj.answer).replace(/&/g, '&').replace(/<(?!img)/g, '<');
                    obj.answer = /^http/.test(answer) ? '<img src="' + obj.answer + '">' : obj.answer;
                    $(
                        '<tr>' +
                        td + ' text-align: center;">' + $TiMu.find('.Zy_TItle:eq(0) i').text().trim() + '</td>' +
                        td + '" title="点击可复制" >' + (question.match('<img') ? question : question.replace(/&/g, '&').replace(/</g, '&lt')) + '</td>' +
                        td + '" title="点击可复制">' + (/^http/.test(answer) ? obj.answer : '') + answer + '</td>' +
                        '</tr>'
                    ).appendTo($(pz.layerdom).find('tbody')).attr("class",fillAnswer($TiMu.find('ul:eq(0)').find('li'), obj, type) ? '' :"layui-bg-red");
                    setting.data[setting.num++] = {
                        code: obj.code > 0 ? 1 : 0,
                        question: question,
                        option: obj.answer,
                        type: Number(type)
                    };
                } else {
                    pz.layer.title('请求失败', pz.layerindex);
                }
            } else if (xhr.status == 403) {
                obj = $.parseJSON(xhr.responseText) || {};
                setting.notice = obj.msg;
                $(pz.layerdom).find('#cx-notice').html(setting.notice);
                pz.layer.title('请求受到限制', pz.layerindex);
            } else {
                pz.layer.title('题库异常,请稍后重试', pz.layerindex);
            }
        },
        ontimeout: function () {
            setting.loop && pz.layer.title('题库超时,正在重试', pz.layerindex);
        }
    });
}
function jq_layer(){
    var Head = document.getElementsByTagName('head')[0] || document.documentElement,
        JQ = document.createElement('script');
    JQ.src = 'https://lib.baomitu.com/layui/2.6.8/layui.js';
    JQ.type = 'text/javascript';
    JQ.async = true;
    Head.insertBefore(JQ, Head.firstChild);
}
function img_cl(text){
    return text.replace(/https:\/\/mooc1-api.chaoxing.com/g, "").replace(/[^\u4e00-\u9fa5^\w]/g, "")
}
function fillAnswer($li, obj, type) {
    var $input = $li.find(':radio, :checkbox'),
        str = String(obj.answer).toCDB() || new Date().toString(),
        data = str.split(/#|\x01|\|/),
        opt = obj.opt || str,
        state = setting.lose;
    $input.prop('checked', false);
    // $li.find(':radio:checked').prop('checked', false);
    obj.code > 0 && $input.each(function (index) {
 
        if (this.value == 'true') {
            data.join().match(/(^|,)(True|true|正确|是|对|√|T|ri)(,|$)/) && this.click();
        } else if (this.value == 'false') {
            data.join().match(/(^|,)(False|false|错误|否|错|×|F|wr)(,|$)/) && this.click();
        } else {
            var tip = filterImg($li.eq(index).find('.after')).toCDB() || new Date().toString();
            if(str.indexOf("<img") != -1 ){
                tip=img_cl(tip);
                data[0]=img_cl(data[0]);
            }
            Boolean($.inArray(tip, data) + 1 || (type == '1' && str.indexOf(tip) + 1)) == this.checked || this.click();
        }
    }).each(function () {
        if (!/^A?B?C?D?E?F?G?$/.test(opt)) return false;
        Boolean(opt.match(this.value)) == this.checked || this.click();
    });
    if (type.match(/^[013]$/)) {
        $input.is(':checked') || (setting.none ? ($input[Math.floor(Math.random() * $input.length)] || $()).click() : setting.lose++);
    } else if (type.match(/^(2|[4-9]|1[08])$/)) {
        data = String(obj.answer).split(/#|\x01|\|/);
        str = $li.end().find('textarea').each(function (index) {
            index = (obj.code > 0 && data[index]) || '';
            if (obj.code > 0) {
                UE.getEditor(this.name).setContent(index.trim());
            }
        }).length;
        (obj.code > 0 && data.length == str) || setting.none || setting.lose++;
    } else {
        setting.none || setting.lose++;
    }
    return state == setting.lose;
}
function saveThis() {
    if (!setting.auto1) return setTimeout(saveThis, setting.time);
    setting.div.children('button:lt(3)').hide().eq(1).click();
    _self.alert = console.log;
    $('#tempsave').click();
    setting.regl();
}
function submitThis() {
    if (!setting.auto1) {
    } else if (!$('.Btn_blue_1:visible').length) {
        setting.div.children('button:lt(3)').hide().eq(1).click();
        return setting.regl();
    } else if ($('#confirmSubWin:visible').length) {
        var btn = $('#tipContent + * > a').offset() || { top: 0, left: 0 },
            mouse = document.createEvent('MouseEvents');
        btn = [btn.left + Math.ceil(Math.random() * 46), btn.top + Math.ceil(Math.random() * 26)];
        mouse.initMouseEvent('click', true, true, document.defaultView, 0, 0, 0, btn[0], btn[1], false, false, false, false, 0, null);
        _self.event = $.extend(true, {}, mouse);
        delete _self.event.isTrusted;
        _self.form1submit();
    } else {
        $('.Btn_blue_1')[0].click();
    }
    setTimeout(submitThis, Math.ceil(setting.time * Math.random()) * 2);
}
function checkToNext() {
    var $tip = $(setting.job.join(', '), document).prevAll('.ans-job-icon' + setting.normal);
    console.log($tip);
    setInterval(function () {
        console.log($tip.parent(':not(.ans-job-finished)').length);
 
        if(parent.location.search.match(/mooc2=(\d+)/i)!=null){
            $tip.parent(':not(.ans-job-finished)').length || setting.jump&&toNext1();
        }else{
            $tip.parent(':not(.ans-job-finished)').length || setting.jump&&toNext();
        }
    }, setting.time);
}
function toNext1(){
    if($(".prev_ul").find("li.active").next().length){
        $(".prev_ul").find("li.active").next().click();
    }else{
        var pnex=$(".posCatalog_select").slice($(".posCatalog_select").index($(".posCatalog_active"))+1).find(".jobUnfinishCount").parent().eq(0);
        pnex.length||setting.course && switchCourse();
        pnex.find("span").click();
    }
}
function toNext() {
    var $cur = $('#cur' + $('#chapterIdid').val()),
        $tip = $('span.currents ~ span'),
        sel = setting.review ? 'html' : '.blue';
 
    if (!$cur.has(sel).length && $tip.length) return $tip.eq(0).click();
    $tip = $('.roundpointStudent, .roundpoint').parent();
    $tip = $tip.slice($tip.index($cur) + 1).not(':has(' + sel + ')');
    $tip.not(setting.lock ? ':has(.lock)' : 'html').find('span').eq(0).click();
    $tip.length || setting.course && switchCourse();
}
function switchCourse() {
    console.log("课程切换");
    GM_xmlhttpRequest({
        method: 'POST',
        url: '/visit/courselistdata',
        data:"courseType=1&courseFolderId=0&courseFolderSize=0",
        headers: {
            'X-Requested-With': 'XMLHttpRequest',
            "Content-Type":"application/x-www-form-urlencoded; charset=UTF-8",
            "Host":"mooc1-1.chaoxing.com",
            "Origin":"https://mooc1-1.chaoxing.com"
        },
        onload: function (xhr) {
 
            var list = $('h3 a[target]', xhr.responseText).map(function () {
                return $(this).attr('href');
            });
            var index = list.map(function (index) {
                return this.match(top.courseId) && index;
            }).filter(function () {
                return $.isNumeric(this);
            })[0] + 1 || 0;
            setting.course = list[index] ? goCourse(list,index) : 0;
        }
    });
}
function goCourse(list,index) {
    url=list[index];
    url="/visit"+url.split("/visit")[1];
    GM_xmlhttpRequest({
        method: 'GET',
        url: url,
        onload: function (xhr) {
            var knowurl=$('h3 a[href]', xhr.responseText).attr('href');
            knowurl==undefined?goCourse(list,index+1):$.globalEval('location.href = "' + $('h3 a[href]', xhr.responseText).attr('href') + '";');
        }
    });
}
function autoRead() {
    $('html, body').animate({
        scrollTop: $(document).height() - $(window).height()
    }, Math.round(setting.read) * 1E3, function () {
        $('.nodeItem.r i').click();
    }).one('click', '#top', function (event) {
        $(event.delegateTarget).stop();
    });
}
function DisplayURL() {
    _self.WAY.box.hide();
    var $li = $(this).closest('li');
    $.get('/visit/goToCourseByFace', {
        courseId: $li.find('input[name=courseId]').val(),
        clazzId: $li.find('input[name=classId]').val()
    }, function (data) {
        $li.find('[onclick^=openFaceTip]').removeAttr('onclick').attr({
            target: '_blank',
            href: $(data).filter('script:last').text().match(/n\("(.+?)"/)[1]
        });
        alert('本课程已临时解除面部识别');
    }, 'html');
}
function submitAnswer($job, data) {
    $job.removeClass('ans-job-finished');
    data = data.length ? $(data) : $('.TiMu').map(function () {
        var title = filterImg($('.Zy_TItle .clearfix', this));
        return {
            question: title.replace(/^【.*?】\s*/, ''),
            type: ({ 单选题: 0, 多选题: 1, 填空题: 2, 判断题: 3 })[title.match(/^【(.*?)】|$/)[1]]
        };
    });
    data = $.grep(data.map(function (index) {
        var $TiMu = $('.TiMu').eq(index);
        if (!($.isPlainObject(this) && this.type < 4 && $TiMu.find('.fr').length)) {
            return false;
        } else if (this.type == 2) {
            var $ans = $TiMu.find('.Py_tk, .Py_answer').eq(0);
            if (!$TiMu.find('.cuo').length && this.code) {
                return false;
            } else if (!$ans.find('.cuo').length) {
                this.option = $ans.find('.clearfix').map(function () {
                    return $(this).text().trim();
                }).get().join('#') || '无';
            } else if (this.code) {
                this.code = -1;
            } else {
                return false;
            }
        } else if (this.type == 3) {
            var ans = $TiMu.find('.font20:last').text();
            if ($TiMu.find('.cuo').length) {
                this.option = ({ '√': '错误', '×': '正确' })[ans] || '无';
            } else if (!this.code) {
                this.option = ({ '√': '正确', '×': '错误' })[ans] || '无';
            } else {
                return false;
            }
        } else {
            var text = $TiMu.find('.Py_answer > span:eq(0)').text();
            if ($TiMu.find('.dui').length && this.code && !/^A?B?C?D?E?F?G?$/.test(this.option)) {
                return false;
            } else if ($TiMu.find('.dui').length || text.match('正确答案')) {
                text = text.match(/[A-G]/gi) || [];
                this.option = $.map(text, function (value) {
                    return filterImg($TiMu.find('.fl:contains(' + value + ') + a'));
                }).join('#') || '无';
                this.key = text.join('');
            } else if (this.code) {
                this.code = -1;
            } else {
                return false;
            }
        }
        return this;
    }), function (value) {
        return value && value.option != '无';
    });
    setting.curs = $('script:contains(courseName)', top.document).text().match(/courseName:\'(.+?)\'|$/)[1] || $('h1').text().trim() || '无';
    /*     data.length && GM_xmlhttpRequest({
        method: 'POST',
        url: 'http://cx.icodef.com/upload/cx?workRelationId=' + $('#workId').val(),
        headers: {
            'Content-type': 'application/x-www-form-urlencoded',
            'Authorization': setting.token,
        },
        data: 'course=' + encodeURIComponent(setting.curs) + '&data=' + encodeURIComponent((Ext.encode || JSON.stringify)(data)) + '&id=' + $('#jobid').val().slice(5)
    }); */
    $job.addClass('ans-job-finished');
}
function filterImg(dom) {
    return $(dom).clone().find('img[src]').replaceWith(
        function () {
            return $('<p></p>').text('<img src="' + $(this).attr('src') + '">');
        }
    ).end().find('iframe[src]').replaceWith(
        function () {
            return $('<p></p>').text('<iframe src="' + $(this).attr('src') + '"></iframe>');
        }
    ).end().text().trim();
}
function getIframe(tip, win, job) {
    if (!$) return Ext.get(frameElement || []).parent().child('.ans-job-icon') || Ext.get([]);
    do {
        win = win ? win.parent : _self;
        job = $(win.frameElement).prevAll('.ans-job-icon');
    } while (!job.length && win.parent.frameElement);
    return tip ? win : job;
}
function jobSort($) {
    var fn = $.fn ? [getIframe(1), 'length'] : [self, 'dom'],
        sel = setting.job.join(', :not(.ans-job-finished) > .ans-job-icon' + setting.normal + ' ~ ');
    if ($(sel, fn[0].parent.document)[0] == fn[0].frameElement) return true;
    if (!getIframe()[fn[1]] || getIframe().parent().is('.ans-job-finished')) return null;
    setInterval(function () {
        $(sel, fn[0].parent.document)[0] == fn[0].frameElement && fn[0].location.reload();
    }, setting.time);
}
function checkPlayer(tip) {
    _self.videojs = hookVideo;
    hookVideo.xhr = vjs.xhr;
    Ext.isSogou = Ext.isIos = Ext.isAndroid = false;
    var data = Ext.decode(_self.config('data')) || {};
    delete data.danmaku;
    data.doublespeed = 1;
    frameElement.setAttribute('data', Ext.encode(data));
    if (tip) return;
    _self.supportH5Video = function () { return true; };
    alert('此浏览器不支持html5播放器,请更换浏览器');
}

	}




})()