添加箭头,用于隐藏插件

scripts
王良 7 months ago
parent 3388811bbe
commit 66d7413848

@ -63,7 +63,7 @@
// 设置<style>元素的内容 // 设置<style>元素的内容
let cssContent = ` let cssContent = `
.____ds-tampermonkey____{ .___ds-tampermonkey___{
position: fixed; position: fixed;
right: 11px; right: 11px;
top: 30%; top: 30%;
@ -76,10 +76,10 @@
background-size: cover; background-size: cover;
background-image: url(""); background-image: url("");
} }
.____ds-tampermonkey-hide____{ .___ds-tampermonkey-hide___{
width: 0; width: 0;
} }
.____ds-menus____ { .___ds-menus___ {
display: none; display: none;
position: absolute; position: absolute;
right: 36px; right: 36px;
@ -92,10 +92,10 @@
border: 1px solid #52525E; border: 1px solid #52525E;
overflow: hidden; overflow: hidden;
} }
.____ds-tampermonkey____:hover .____ds-menus____ { .___ds-tampermonkey___:hover .___ds-menus___ {
display: block; display: block;
} }
.____ds-menu____ { .___ds-menu___ {
height: 35px; height: 35px;
line-height: 35px; line-height: 35px;
padding: 0 10px; padding: 0 10px;
@ -104,31 +104,32 @@
cursor: pointer; cursor: pointer;
margin-left: 26px; margin-left: 26px;
} }
.____ds-menu____:hover { .___ds-menu___:hover {
background-color: #855F16; background-color: #855F16;
} }
.____ds-menu0____ { .___ds-menu0___ {
margin-left: 0; margin-left: 0;
font-size: 16px; font-size: 16px;
font-weight: bold; font-weight: bold;
} }
.____ds-menu0____ img{ .___ds-menu0___ img{
width: 23px; width: 23px;
height: 23px; height: 23px;
vertical-align: middle; vertical-align: middle;
margin: 0 8px 3px 8px; margin: 0 8px 3px 8px;
} }
.____ds-arrow____{ .___ds-arrow___{
width: 0; width: 0;
height: 0; height: 0;
position: absolute; position: absolute;
top: 10px; top: 10px;
left: 37px; left: 37px;
cursor: pointer;
border-top: 8px solid transparent; border-top: 8px solid transparent;
border-bottom: 8px solid transparent; border-bottom: 8px solid transparent;
border-left: 10px solid #665c5c; border-left: 10px solid #665c5c;
} }
.____ds-tampermonkey-hide____ .____ds-arrow____{ .___ds-tampermonkey-hide___ .___ds-arrow___{
border-top: 8px solid transparent; border-top: 8px solid transparent;
border-bottom: 8px solid transparent; border-bottom: 8px solid transparent;
border-right: 10px solid #665c5c; border-right: 10px solid #665c5c;
@ -167,12 +168,15 @@
context.pluginElement = document.createElement('div'); context.pluginElement = document.createElement('div');
context.pluginElement.id = PRE + "plugin"; context.pluginElement.id = PRE + "plugin";
context.pluginElement.title = "油猴脚本" + (options.name ? "" + options.name : ""); context.pluginElement.title = "油猴脚本" + (options.name ? "" + options.name : "");
context.pluginElement.className = "____ds-tampermonkey____"; context.pluginElement.className = "___ds-tampermonkey___";
if (api.GM_getValue("ds_hide")) {
context.pluginElement.classList.add("___ds-tampermonkey-hide___");
}
// 创建菜单列表div // 创建菜单列表div
context.menusElement = document.createElement('div'); context.menusElement = document.createElement('div');
context.menusElement.id = PRE + "menus"; context.menusElement.id = PRE + "menus";
context.menusElement.className = "____ds-menus____"; context.menusElement.className = "___ds-menus___";
if (options.width > 0) { if (options.width > 0) {
context.menusElement.style['min-width'] = options.width + "px"; context.menusElement.style['min-width'] = options.width + "px";
} }
@ -184,7 +188,7 @@
const switchMenuElement = document.createElement('div'); const switchMenuElement = document.createElement('div');
const icon = (options.icon ? `<img alt="icon" src="${options.icon}"/>` : " "); const icon = (options.icon ? `<img alt="icon" src="${options.icon}"/>` : " ");
switchMenuElement.id = PRE + "menu-0"; switchMenuElement.id = PRE + "menu-0";
switchMenuElement.className = "____ds-menu____ ____ds-menu0____"; switchMenuElement.className = "___ds-menu___ ___ds-menu0___";
switchMenuElement.innerHTML = (enabled ? "✅" : "❌") + icon + options.name; switchMenuElement.innerHTML = (enabled ? "✅" : "❌") + icon + options.name;
switchMenuElement.title = `点击${enabled ? "关闭" : "开启"}此脚本功能`; switchMenuElement.title = `点击${enabled ? "关闭" : "开启"}此脚本功能`;
switchMenuElement.onclick = function () { switchMenuElement.onclick = function () {
@ -210,7 +214,7 @@
// 创建用户菜单列表div // 创建用户菜单列表div
context.userMenusElement = document.createElement('div'); context.userMenusElement = document.createElement('div');
context.userMenusElement.id = PRE + "user-menus"; context.userMenusElement.id = PRE + "user-menus";
context.userMenusElement.className = "____ds-user-menus____"; context.userMenusElement.className = "___ds-user-menus___";
// 将用户菜单div添加到菜单div中 // 将用户菜单div添加到菜单div中
context.menusElement.append(context.userMenusElement); context.menusElement.append(context.userMenusElement);
@ -225,22 +229,48 @@
// 创建箭头元素 // 创建箭头元素
context.arrowElement = document.createElement('div'); context.arrowElement = document.createElement('div');
context.arrowElement.id = PRE + "arrow"; context.arrowElement.id = PRE + "arrow";
context.arrowElement.className = "____ds-arrow____"; context.arrowElement.className = "___ds-arrow___";
// 初始化title
api.initArrowTitle();
// 绑定点击事件
context.arrowElement.onclick = () => {
if (__ds_global__.getContext().pluginElement.classList.contains("___ds-tampermonkey-hide___")) {
__ds_global__.getContext().pluginElement.classList.remove("___ds-tampermonkey-hide___");
api.initArrowTitle(false);
} else {
__ds_global__.getContext().pluginElement.classList.add("___ds-tampermonkey-hide___");
api.initArrowTitle(true);
}
}
// 将箭头元素添加到插件div中 // 将箭头元素添加到插件div中
context.pluginElement.append(context.arrowElement); context.pluginElement.append(context.arrowElement);
} }
api.initArrowTitle = (isHidden) => {
if (isHidden == null) {
isHidden = context.pluginElement.classList.contains("___ds-tampermonkey-hide___");
}
if (isHidden) {
context.arrowElement.title = "点击展示";
} else {
context.arrowElement.title = "点击隐藏";
}
}
// 隐藏插件 // 隐藏插件
api.hidePlugin = () => { api.hidePlugin = () => {
if (context.pluginElement) { if (context.pluginElement) {
context.pluginElement.classList.add("____ds-tampermonkey-hide____"); context.pluginElement.classList.add("___ds-tampermonkey-hide___");
api.GM_setValue("ds_hide", true);
} }
} }
// 显示插件 // 显示插件
api.showPlugin = () => { api.showPlugin = () => {
if (context.pluginElement) { if (context.pluginElement) {
context.pluginElement.classList.remove("____ds-tampermonkey-hide____"); context.pluginElement.classList.remove("___ds-tampermonkey-hide___");
api.GM_deleteValue("ds_hide");
} }
} }
@ -274,6 +304,8 @@
api.createPluginStyle(options); api.createPluginStyle(options);
// 创建插件div // 创建插件div
api.createPluginDiv(options); api.createPluginDiv(options);
// 创建箭头
api.createArrow(options);
// 保存参数 // 保存参数
context.pluginOptions = options; context.pluginOptions = options;
@ -318,7 +350,7 @@
// 创建菜单元素 // 创建菜单元素
const menuElement = document.createElement('div'); const menuElement = document.createElement('div');
menuElement.id = menuCmdId; menuElement.id = menuCmdId;
menuElement.className = "____ds-menu____"; menuElement.className = "___ds-menu___";
menuElement.innerHTML = name; menuElement.innerHTML = name;
if (options.title) { if (options.title) {
menuElement.title = typeof options.title === "function" ? options.title() : options.title; menuElement.title = typeof options.title === "function" ? options.title() : options.title;

Loading…
Cancel
Save