diff --git a/packages/gui/extra/scripts/tampermonkey.script b/packages/gui/extra/scripts/tampermonkey.script index cd71b71..0885b86 100644 --- a/packages/gui/extra/scripts/tampermonkey.script +++ b/packages/gui/extra/scripts/tampermonkey.script @@ -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(); // 回调 };