|
|
|
@ -1,8 +1,8 @@
|
|
|
|
|
/**
|
|
|
|
|
* 篡改猴(Tampermonkey)| 油猴(Greasemonkey)浏览器脚本扩展
|
|
|
|
|
*
|
|
|
|
|
* @version 0.1.1
|
|
|
|
|
* @since 2024-04-24 12:00
|
|
|
|
|
* @version 0.1.3
|
|
|
|
|
* @since 2024-04-24 15:26
|
|
|
|
|
* @author 王良
|
|
|
|
|
* @authorHomePage https://wangliang1024.cn
|
|
|
|
|
* @remark 当前脚本为仿照的版本,并非篡改猴插件的源码,仅供学习参考。
|
|
|
|
@ -16,9 +16,10 @@
|
|
|
|
|
*/
|
|
|
|
|
'use strict';
|
|
|
|
|
(function () {
|
|
|
|
|
const version = "0.1.1";
|
|
|
|
|
const version = "0.1.3";
|
|
|
|
|
const PRE = "DS-Tampermonkey:"; // 前缀
|
|
|
|
|
const MENU_ID_PRE = PRE + "menu-";
|
|
|
|
|
const icon = "";
|
|
|
|
|
|
|
|
|
|
const context = {
|
|
|
|
|
initialized: false, // 是否已经初始化
|
|
|
|
@ -45,6 +46,11 @@
|
|
|
|
|
// 创建插件API
|
|
|
|
|
const api = {};
|
|
|
|
|
|
|
|
|
|
// 监听页面关闭事件,用于关闭最后一个通知
|
|
|
|
|
window.addEventListener('beforeunload', function(event) {
|
|
|
|
|
api.closeLastNotification();
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//region DS自定义的API start
|
|
|
|
|
|
|
|
|
@ -77,7 +83,7 @@
|
|
|
|
|
background-color: #DDD;
|
|
|
|
|
background-repeat: no-repeat;
|
|
|
|
|
background-size: cover;
|
|
|
|
|
background-image: url("");
|
|
|
|
|
background-image: url("${icon}");
|
|
|
|
|
}
|
|
|
|
|
.___ds-tampermonkey-hide___{
|
|
|
|
|
width: 0;
|
|
|
|
@ -215,8 +221,10 @@
|
|
|
|
|
switchMenuElement.title = `点击${enabled ? "关闭" : "开启"}此脚本功能`;
|
|
|
|
|
api.GM_setValue("ds_enabled", enabled)
|
|
|
|
|
api.GM_notification({
|
|
|
|
|
text: `已${enabled ? "开启" : "关闭"} 「${options.name}」 功能\n(刷新网页后生效)`,
|
|
|
|
|
timeout: 3500
|
|
|
|
|
title: "脚本状态变更通知",
|
|
|
|
|
text: `已${enabled ? "开启" : "关闭"} 「${options.name}」 功能\n(点击刷新网页后生效)`,
|
|
|
|
|
timeout: 3500,
|
|
|
|
|
onclick: () => location.reload()
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
// 将开关菜单添加到菜单列表div中
|
|
|
|
@ -329,6 +337,20 @@
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// 关闭上一个通知
|
|
|
|
|
api.closeLastNotification = () => {
|
|
|
|
|
let lastNotification = context.lastNotification;
|
|
|
|
|
if (lastNotification) {
|
|
|
|
|
context.lastNotification = null;
|
|
|
|
|
lastNotification.timeout && clearTimeout(lastNotification.timeout);
|
|
|
|
|
try {
|
|
|
|
|
lastNotification.obj && lastNotification.obj.close();
|
|
|
|
|
} catch (e) {
|
|
|
|
|
console.error(`ds_tampermonkey_${version}: GM_notification: 关闭上一个通知失败:`, e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//endregion DS自定义的API end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -468,7 +490,7 @@
|
|
|
|
|
// param3
|
|
|
|
|
if (typeof image === "string") {
|
|
|
|
|
options.image = image;
|
|
|
|
|
} else if (onclick != null) {
|
|
|
|
|
} else if (image != null) {
|
|
|
|
|
console.warn(`ds_tampermonkey_${version}: GM_notification: 无效的参数值:image = ` + image);
|
|
|
|
|
}
|
|
|
|
|
// param4
|
|
|
|
@ -478,41 +500,68 @@
|
|
|
|
|
console.warn(`ds_tampermonkey_${version}: GM_notification: 无效的参数值:onclick = ` + onclick);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
let text = options.text;
|
|
|
|
|
if (options.title) {
|
|
|
|
|
text = options.title + ": " + text;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// 显示通知方法
|
|
|
|
|
const showNotification = () => {
|
|
|
|
|
// 先关闭上一个通知
|
|
|
|
|
let lastNotification = context.lastNotification;
|
|
|
|
|
if (lastNotification) {
|
|
|
|
|
if (lastNotification.timeout) {
|
|
|
|
|
clearTimeout(lastNotification.timeout);
|
|
|
|
|
}
|
|
|
|
|
lastNotification.obj.close();
|
|
|
|
|
if (lastNotification.options && typeof lastNotification.options.ondone === "function") lastNotification.options.ondone();
|
|
|
|
|
context.lastNotification = null;
|
|
|
|
|
api.closeLastNotification();
|
|
|
|
|
|
|
|
|
|
// 获取标题和文本
|
|
|
|
|
let text = options.text;
|
|
|
|
|
let title = options.title;
|
|
|
|
|
if (title == null) {
|
|
|
|
|
title = text;
|
|
|
|
|
text = null;
|
|
|
|
|
} else {
|
|
|
|
|
delete options.title;
|
|
|
|
|
}
|
|
|
|
|
delete options.text;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const notification = new Notification(text);
|
|
|
|
|
lastNotification = {
|
|
|
|
|
// 创建通知属性
|
|
|
|
|
const notificationOptions = {
|
|
|
|
|
...options,
|
|
|
|
|
icon: options.image || options.icon || (context.pluginOptions ? context.pluginOptions.icon : null) || icon
|
|
|
|
|
};
|
|
|
|
|
if (text) notificationOptions.body = text;
|
|
|
|
|
// 创建通知
|
|
|
|
|
const notification = new Notification(title, notificationOptions);
|
|
|
|
|
// 将通知对象保存到context中
|
|
|
|
|
const lastNotification = {
|
|
|
|
|
obj: notification,
|
|
|
|
|
options: options,
|
|
|
|
|
timeout: null
|
|
|
|
|
}
|
|
|
|
|
context.lastNotification = lastNotification;
|
|
|
|
|
// 设置通知的各种属性或事件
|
|
|
|
|
if (options.onclick) {
|
|
|
|
|
notification.onclick = () => options.onclick();
|
|
|
|
|
}
|
|
|
|
|
notification.onclose = () => {
|
|
|
|
|
// 清除最后一个通知
|
|
|
|
|
context.lastNotification = null;
|
|
|
|
|
|
|
|
|
|
// 执行回调方法
|
|
|
|
|
if (typeof options.ondone === "function") {
|
|
|
|
|
try {
|
|
|
|
|
options.ondone();
|
|
|
|
|
} catch (e) {
|
|
|
|
|
console.error(`ds_tampermonkey_${version}: GM_notification: ondone回调函数执行失败:`, e);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (options.timeout) {
|
|
|
|
|
lastNotification.timeout = setTimeout(function () {
|
|
|
|
|
context.lastNotification = null // 清除最后一个通知
|
|
|
|
|
notification.close();
|
|
|
|
|
if (options.ondone) options.ondone(); // 回调
|
|
|
|
|
}, options.timeout)
|
|
|
|
|
// 设置定时关闭
|
|
|
|
|
lastNotification.timeout = setTimeout(() => notification.close(), options.timeout);
|
|
|
|
|
}
|
|
|
|
|
return notification;
|
|
|
|
|
};
|
|
|
|
|
// 当不支持Notification API,则使用alert显示通知
|
|
|
|
|
const showAlert = () => {
|
|
|
|
|
let text = options.text;
|
|
|
|
|
if (options.title) {
|
|
|
|
|
text = options.title + ": " + text;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
alert(text);
|
|
|
|
|
if (options.ondone) options.ondone(); // 回调
|
|
|
|
|
};
|
|
|
|
|