百度云插件+APIKey

在百度云网盘的页面添加一个搜索框,调用谷歌的搜索API搜索所有公开分享文件// To add a search frame that calls the google cse api for searching some public shared files in BaiduYun cloud netdisk.

目前為 2014-09-06 提交的版本,檢視 最新版本

您需要先安裝使用者腳本管理器擴展,如 TampermonkeyGreasemonkeyViolentmonkey 之後才能安裝該腳本。

You will need to install an extension such as Tampermonkey to install this script.

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyViolentmonkey 後才能安裝該腳本。

您需要先安裝使用者腳本管理器擴充功能,如 TampermonkeyUserscripts 後才能安裝該腳本。

你需要先安裝一款使用者腳本管理器擴展,比如 Tampermonkey,才能安裝此腳本

您需要先安裝使用者腳本管理器擴充功能後才能安裝該腳本。

(我已經安裝了使用者腳本管理器,讓我安裝!)

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展,比如 Stylus,才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

你需要先安裝一款使用者樣式管理器擴展後才能安裝此樣式

(我已經安裝了使用者樣式管理器,讓我安裝!)

// ==UserScript==
// @name       百度云插件+APIKey
// @namespace  
// @version    4.3 beta
// @description  在百度云网盘的页面添加一个搜索框,调用谷歌的搜索API搜索所有公开分享文件// To add a search frame that calls the google cse api for searching some public shared files in BaiduYun cloud netdisk. 
// @require        http://code.jquery.com/jquery-2.1.1.min.js
// @description  For more imformation,please email me at [email protected]. 
// @include       http://pan.baidu.com/disk/*
// @include      https://pan.baidu.com/disk/*
// @include      https://yun.baidu.com/#from=share_yun_logo/
// @include      http://yun.baidu.com/#from=share_yun_logo/
// @grant       GM_xmlhttpRequest
// @run-at document-end
// @copyright  2014,04,20 __By Wang Hsin-che   
// ==/UserScript==

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// my custom jquery draggable plugin//////////////////////////////////////////////////////////////////////////////
// by Wang Hsin-che @ 2014.07 
// version : 0.1
// usage: $("#element").draggable({handle:"#childElement"});  or $("#element").draggable(); 

(function($) {
	$.fn.draggable = function(option) {
		var x0, y0, ele, setting;
		ele = this; //save the selector 
		setting = $.extend({
			handle: this.selector
		}, option); //deal with the "handle" parameter,default is the selector
		ele.css({
			position: "absolute"
		}); //make sure that the "postion" is "absolute"
		$(setting.handle).bind('mousedown', function(e0) {
			$(setting.handle).css({
				cursor: "move"
			}); //set the appearance of cursor 
			x0 = ele.offset().left - e0.pageX; //*1
			y0 = ele.offset().top - e0.pageY; //*1
			$(document).bind('mousemove', function(e1) { //bind the mousemove event, caution:this event must be bind to "document"
				$(document).bind('mouseup', function() { //when the mouse up,unbind the mousemove event
					$(document).unbind('mousemove');
					$(setting.handle).css({
						cursor: "auto"
					});
				});
				ele.css({
					left: x0 + e1.pageX,
					top: y0 + e1.pageY
				}); //this expression and the expression of *1 equal to "ele.origin_offset+mouse.current_offset-mouse.origin_offset"
			});
		});

		return this;
	};
}(jQuery));
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////

/////定义
var SearchObject = (function($, replaceEle) {
	var
		url = 'https://www.googleapis.com/customsearch/v1element?key=AIzaSyCVAXiUzRYsML1Pv6RwSG1gunmMikTzQqY&rsz=filtered_cse&num=10&hl=en&prettyPrint=true&source=gcsc&gss=.com&sig=ee93f9aae9c9e9dba5eea831d506e69a&cx=018177143380893153305:yk0qpgydx_e&q=',
		keyword = '',
		//搜索框的html
		html_1 = '<div class="search-form"><input class="search-query" placeholder=" 搜索公开分享文件" id="wxz_input">\
				<input type="button" value="GO" class="search-button" id="wxz_searchButton"></div>',
		//显示页面的html

		html_2 = '\
	<div class="b-panel b-dialog share-dialog" id="wxz_myDiv">\
	<div class="dlg-hd b-rlv" id="wxz_myDiv_title">\
	<div title="关闭" id="wxz_closeButton" class="dlg-cnr dlg-cnr-r"></div>\
	<h3 >搜索</h3>\
	</div>\
	<div class="wxz-content">\
	</div>\
	<div class="offline-bottom">\
	<div class="offline-pageing">\
	<div class="pagese " id="wxz-pagese">\
	</div>\
	</div>\
	</div>\
	</div>\
	',

		//插入的css
		cssText = '\
	<style type="text/css">\
		#wxz_searchButton{background-image:none;cursor:pointer;background-color: rgb(155, 154, 154);color: #ffffff;}\
			.wxz-myDiv{display:none;z-index:99;box-shadow:0 0 9px rgba(0,0,0,.9);background:#FFFFFF;position:absolute;outline:0 none;}\
			.wxz-content{line-height: 200%;text-align: left;white-space: normal;margin-left:20px;overflow:auto;}\
			.wxz-close{margin-right:20px;important;height:20px;cursor:pointer}\
			.wxz-next{margin-right:20px;float:right;height:20px;cursor:pointer}\
			.wxz-front{margin-right:40px;float:right;height:20px;cursor:pointer}\
			.wxz-content a{color:#0066FF!important;font: 14px/1.5 arial,sans-serif!important;}\
	</style>\
					';
	return {
		searchClear: function() {
			$('#wxz_myDiv').slideUp();
			$('#wxz_input').val('');
			keyword = '';
			$('.wxz-content').empty(); //清空原来的内容
			console.log('clear');
		},
		search_2: function(keyword, startIndex) {
			console.log('search');
			var self = this;
			if (keyword === '') {
				console.log('fail');
				return 0;
			}
			//显示loading条
			$('.wxz-content').html('<img src="" />');
			$('#wxz_myDiv').slideDown();
			GM_xmlhttpRequest({
				method: "GET",
				url: url + keyword + '&start=' + startIndex,
				headers: {
					"User-Agent": "Mozilla/5.0", // If not specified, navigator.userAgent will be used.
					"Accept": "text/xml" // If not specified, browser defaults will be used.
				},
				onload: function(response) {
					var
						data = JSON.parse(response.responseText),
						showList,
						tempNode,
						totalPage = 1,
						totalResults = parseInt(data.cursor.estimatedResultCount, 10);
					//把json数据转为html,存入缓存showlist
					if (parseInt(data.cursor.resultCount, 10) === 0) {
						$('.wxz-content').html('<div class="loading-tips" align="center">无搜索结果...换个关键词重新试试?</div>');
					} //无结果时提示
					else {
						totalPage = parseInt((totalResults - 1) / 10, 10) + 1 > 10 ? 10 : parseInt((totalResults - 1) / 10, 10) + 1; //坑比,google自定义搜索只提供最大10页(每页10条)
						showList = "<p align='right'>---- by Google Custome Search </p><p white-space='normal' class='temp' >keyword is    '" + keyword + "'    found  '" + data.cursor.resultCount + "'  Results</p><p>--------------------------------------------------<p>";
						$.each(data.results, function(index, element) {
							tempNode = '<a href="' + element.unescapedUrl + '"target="_blank">' + element.titleNoFormatting + '</a>';
							showList += '<p><p class="myTitle">' + tempNode + '</p>';
							showList += '<p class="mySnippet">' + element.contentNoFormatting + '</p>';
						});
						showList += '<p><p>-------------------------------------------------------------<p class="temp" margin-left="20px">"' + data.results.length + '"  items have been load </p><p align="right"><a href="javascript:alert(' + "'By WangHsinche @ 2014.04'" + ')" ><font color="#333">About me</font></a></p>';
						$('.wxz-content').html(showList); //替换原来内容,之所以用了showlist作为缓存是为了提升速度
						$('.wxz-content').scrollTop(0); //滚到顶端
					}
					self.pageBar(parseInt(startIndex / 10, 10) + 1, totalPage);
					data = null;
					tempNode = null;
					totalPage = null;
					totalResults = null;
					showList = null;


				},
				onerror: function() {
					$('.wxz-content').html('<div class="loading-tips" align="center">出错了......google登陆不了?!</div>');
					console.log("error");
					return 0;
				}
			});
		},
		pageBar: function(page, totalPage) {
			var
				html = '\
				<div class="pagese "id="wxz-pagese">\
				<a href="javascript:void(0)" class="page-prev mou-evt">上一页</a>\
				<span class="page-content"></span>\
				<a href="javascript:void(0)" class="page-next mou-evt">下一页</a>\
				</div>\
				',
				pageNodeHtml = '<span class="page-number"></span>',
				i, c,
				self = this,
				startPage = 10 * parseInt((page - 1) / 10, 10) + 1;
			$('#wxz-pagese').replaceWith(html);
			c = $('#wxz-pagese').find('.page-content').eq(0);
			for (i = 0; i < 10; i++) {
				if (i + startPage > totalPage) {
					break;
				}
				if (i + startPage === page) {
					$(pageNodeHtml).html(i + startPage).addClass('global-disabled').appendTo(c);
				} else {
					$(pageNodeHtml).html(i + startPage)
						.bind('click', {
							msg: i + startPage
						}, function(e) {
							self.search_2(keyword, (e.data.msg - 1) * 10);
						})
						.appendTo(c);
				}
			}
			if (page <= 1) {
				$('#wxz-pagese').find('.page-prev').eq(0).addClass('global-disabled');
			} else {
				$('#wxz-pagese').find('.page-prev').eq(0).bind('click', {
					msg: page - 1
				}, function(event) {
					self.search_2(keyword, (event.data.msg - 1) * 10);
				});
			}
			if (page >= totalPage) {
				$('#wxz-pagese').find('.page-next').eq(0).addClass('global-disabled');

			} else {
				$('#wxz-pagese').find('.page-next').eq(0).bind('click', {
					msg: page + 1
				}, function(event) {
					self.search_2(keyword, (event.data.msg - 1) * 10);
				});
			}
			html = null;
			pageNodeHtml = null;
			i = null;
			c = null;
			startPage = null;


		},
		setUI: function() {
			//根据屏幕设置div的大小位置
			var
				myDivHeight = window.innerHeight / 3 * 2,
				myDivLeft = -window.innerWidth / 6,
				myDivTop = window.innerHeight / 8;
			//应用大小和页面
			$('.wxz-content').css({
				height: myDivHeight
			});
			$('.wxz-myDiv').css({
				top: myDivTop,
				left: myDivLeft
			});
			//应用拖拽
			$("#wxz_myDiv").draggable({
				handle: "#wxz_myDiv_title"
			});
			myDivHeight = null;
			myDivLeft = null;
			myDivTop = null;

		},
		replaceAndInsert: function() {
			$(replaceEle).replaceWith(html_1); //搜索栏替换了广告	
			$('body').append(html_2);
			$('head:first').append(cssText); //插入css
		},
		bind_2: function() {
			var self = this;
			//绑定各种函数
			$('#wxz_searchButton').click(function() {
				keyword = $('#wxz_input').val();
				self.search_2(keyword, 0);
			});
			$('#wxz_closeButton').click(function() {
				self.searchClear();
			});
			$('#wxz_input').keyup(function(event) {
				if (event.which == 13) {
					$('#wxz_searchButton').trigger('click');
				}
			});
		},
		init: function() {
			var
				self = this,
				t = window.setInterval(function() { //百度云把一些内容放到后面加载,因此我设置了一个延时循环,每隔100ms选择一下所需的元素,当所需的元素存在时,开始脚本,同时停止延时循环
					if ($(replaceEle).length > 0) {
						window.clearInterval(t);
						self.replaceAndInsert();
						self.setUI();
						self.bind_2();

					}
					console.log('waiting');
				}, 100);
		},
	};
}(jQuery, '#top_menu_other'));

//启动
SearchObject.init();