Skip to content

Instantly share code, notes, and snippets.

@jae-jae
Last active February 20, 2024 03:08
Show Gist options
  • Star 13 You must be signed in to star a gist
  • Fork 4 You must be signed in to fork a gist
  • Save jae-jae/39d526079cb2408389129caf98debc29 to your computer and use it in GitHub Desktop.
Save jae-jae/39d526079cb2408389129caf98debc29 to your computer and use it in GitHub Desktop.
显示当前网站的所有可用Tampermonkey脚本.user.js
// ==UserScript==
// @name Show Site All UserJS | 显示当前网站所有可用的UserJS脚本 Jaeger
// @namespace https://gist.github.com/jae-jae/39d526079cb2408389129caf98debc29
// @version 1.1
// @description 显示当前网站的所有可用UserJS(Tampermonkey)脚本,交流QQ群:104267383
// @author Jaeger <JaegerCode@gmail.com>
// @icon https://greasyfork.org/assets/blacklogo16-b3c5358e47023ea84cbeac99a018eb28.png
// @include *
// @require https://cdn.bootcss.com/babel-core/5.6.15/browser-polyfill.min.js
// @require https://cdn.bootcss.com/babel-core/5.6.15/browser.min.js
// @require https://raw.githubusercontent.com/jae-jae/l.js/master/userjs/l.userjs.min.js
// @require https://gist.githubusercontent.com/jae-jae/35a1833079d26e6c9d9c6d5bed982353/raw/userjs-base.js
// @grant GM_xmlhttpRequest
// @noframes
// @connect cdn.bootcss.com
// @connect raw.githubusercontent.com
// @connect gist.githubusercontent.com
// @connect greasyfork.org
// ==/UserScript==
/* jshint ignore:start */
var inline_src = (<><![CDATA[
/* jshint ignore:end */
/* jshint esnext: true */
class FetchUserjs{
constructor(){
this.homeUrl = 'https://greasyfork.org/zh-CN/scripts/24508';
this.api = 'https://greasyfork.org/en/scripts/by-site/${host}.json';
this.host = location.host.split('.').splice(-2).join('.');
this.showTime = 10;
this.quietKey = 'jae_fetch_userjs_quiet';
this.cacheKey = 'jae_fetch_userjs_cache';
this.tplBox = '<div id="jae_fetch_userjs_wrapper"><style>#jae_fetch_userjs{position:fixed;width:400px;background-color:#f5f6f7;border:1px solid #adb1bb;color:#424e67;z-index:1000;bottom:10px;right:20px;z-index:9999}#jae_fetch_userjs span{height:22px;display:inline;overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-family:"microsoft yahei",tahoma,arial}#jae_fetch_userjs_info{width:380px;padding:5px 10px;font-size:14px;line-height:22px;overflow:hidden}#jae_fetch_userjs_info_file,#jae_fetch_userjs_info_count{max-width:150px;padding:0 5px;font-weight:700;color:#3b8cff}#jae_fetch_userjs i,#jae_fetch_userjs_close,#jae_fetch_userjs_switch{height:22px;background:url() no-repeat 0 0}#jae_fetch_userjs_close{width:16px;float:right;background-position:0 -22px}#jae_fetch_userjs_switch{width:78px;float:right;margin-right:10px;background-position:0 -44px}.jae_fetch_userjs_show_file #jae_fetch_userjs_switch.expand{background-position:0 -66px}.jae_fetch_userjs_show_file #jae_fetch_userjs_file_list{display:block;max-height:400px;overflow-y:scroll;}#jae_fetch_userjs i{display:inline-block;float:left;width:22px}#jae_fetch_userjs_file_list{display:none;padding:0 10px;border-top:1px solid #adb1bb;font-size:12px}#jae_fetch_userjs_file_list .jae_fetch_userjs_file{padding:10px 0;border-bottom:1px solid #dfdfdf;line-height:22px;overflow:hidden}#jae_fetch_userjs_file_list .jae_fetch_userjs_file a{float:right;text-decoration:none;color:#5a5f65}#jae_fetch_userjs_file_list .jae_fetch_userjs_file span{width:420px}.jae_fetch_userjs_file_name{cursor:pointer}.jae_fetch_userjs_file{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}#jae_fetch_userjs_home{cursor:pointer;}</style><div id="jae_fetch_userjs" class=""><div id="jae_fetch_userjs_info"><a href="javascript:void(0)" id="jae_fetch_userjs_close"></a> <a href="javascript:void(0)" id="jae_fetch_userjs_switch" class="expand"></a> <i id="jae_fetch_userjs_home"></i> <span>发现</span> <span id="jae_fetch_userjs_info_count">${count}</span><span>个脚本适用于当前页面</span></div><div id="jae_fetch_userjs_file_list">{@each list as item,index}<div class="jae_fetch_userjs_file"><a class="jae_fetch_userjs_install" href="${item.code_url}"><i></i>安装</a><span class="jae_fetch_userjs_file_name" data-url="${item.url}" title="${item.description}" >${parseInt(index)+1}.${item.name}</span><span style="color:#afa8a8;margin-left:4px;" title="${item.code_updated_at}">(${item.code_updated_at|timeago})</span></div>{@/each}</div></div></div>';
this.timeago = new timeago(null,'zh_CN');
juicer.register('timeago', this.timeago.format);
}
getJSON(url,callback){
GM_xmlhttpRequest({
method:'GET',
url:url,
onload:(res)=>{
let json = JSON.parse(res.responseText);
callback(json);
}
});
}
getData(host,callback){
let data = sessionStorage.getItem(this.cacheKey);
if(data)
{
data = JSON.parse(data);
callback(data);
}else{
let api = juicer(this.api,{host:this.host});
this.getJSON(api,(json)=>{
sessionStorage.setItem(this.cacheKey,JSON.stringify(json));
callback(json);
});
}
}
bindEvent(){
$('#jae_fetch_userjs_switch').click(()=>{
$('#jae_fetch_userjs').toggleClass('jae_fetch_userjs_show_file');
clearTimeout(this.timeId);
});
$(".jae_fetch_userjs_file_name").click(function(){
let url = $(this).data('url');
window.open(url);
});
$("#jae_fetch_userjs_close").click(()=>{
sessionStorage.setItem(this.quietKey,1);
$('#jae_fetch_userjs_wrapper').remove();
});
$(".jae_fetch_userjs_install").click(function(){
$(this).html('<i></i>下载中...');
});
$("#jae_fetch_userjs_home").click(()=>{
window.open(this.homeUrl);
});
this.timeId = setTimeout(()=>{
$('#jae_fetch_userjs_wrapper').remove();
},this.showTime*1000);
}
get isQuiet(){
let quiet = sessionStorage.getItem(this.quietKey);
return quiet?true:false;
}
render(){
this.isQuiet || this.getData(this.host,(json)=>{
if(json.length){
let box = juicer(this.tplBox,{list:json,count:json.length});
$('body').append(box);
this.bindEvent();
}
});
}
}
ljs.exec(['jQuery','juicer','timeago'],()=>{
let fu = new FetchUserjs();
fu.render();
});
/* jshint ignore:start */
]]></>).toString();
var c = babel.transform(inline_src);
eval(c.code);
/* jshint ignore:end */
@Cologler
Copy link

// @name Show Site All UserJS | 显示当前网站所有可用的UserJS脚本 Jaeger

改成

// @name Show Site All UserJS // @name:zh-CN 显示当前网站所有可用的UserJS脚本

比较好。

@bayllech
Copy link

当把可用列表关闭后,下次再进入这个网站,如何能再显示列表呢

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment