// ==UserScript== // @name 老男人助手 // @namespace http://tampermonkey.net/ // @version 0.2 // @description 适用于老男人游戏论坛:https://bbs.oldmanemu.net/ 的小工具 // @author rock128 // @match https://bbs.oldmanemu.net/* // @icon  // @grant none // @require https://cdn.bootcdn.net/ajax/libs/jscolor/2.4.7/jscolor.min.js // @license GPL-3.0 License // @downloadURL none // ==/UserScript== (function() { 'use strict'; var SIGN_TITLE = "签到" var HAS_HIDDEN_CONTENT_KEYWORD = "本帖含有隐藏内容" var AUTO_REPLY_MSG = [] var BLACK_LIST = [] var BACKGROUND_COLOR = '#C7EDCC'; var FONT_COLOR = '#000000'; jscolor.presets.default = { position: 'right', palette: [ '#FFFFFF', '#FAF9DE', '#FFF2E2', '#FDE6E0', '#E3EDCD', '#DCE2F1', '#E9EBFE', '#EAEAEF', '#C7EDCC', '#CCE8CF', '#6E7B6C' ] }; var actionArray = [ { describe : "页面自动签到", open : false, matchCondition : function(){ return isMatchPageCategory("index") }, doAction : function(){ if($("#sign_title").text() == SIGN_TITLE){ $.xpost(xn.url("my-sign"),"",function(message){}); } }, settingPanelHtml: '签到按钮文本:

' }, { describe : "去除灯笼", open : false, matchCondition : function(){ return true }, doAction : function(){ $(".deng") && $(".deng").remove() } }, { describe : "屏蔽用户帖子", open : false, matchCondition : function(){ return isMatchPageCategory("") || isMatchPageCategory("index") }, doAction : function(){ $(".media.thread.tap") && $(".media.thread.tap").each(function(i,item){ var id = $(item).children().eq(0).attr("href") id = id.replace("user-","").replace(".htm","") if(BLACK_LIST.indexOf(id)!=-1){ $(item).hide() } }) }, settingPanelHtml: '黑名单列表:

' }, { describe : "自动回复隐藏帖子", open : false, matchCondition : function(){ return isMatchPageCategory("thread") }, doAction : function(){ if($(".alert-warning") && $(".alert-warning").text().indexOf(HAS_HIDDEN_CONTENT_KEYWORD) != -1){ var msg = AUTO_REPLY_MSG[Math.floor(Math.random()*AUTO_REPLY_MSG.length)]; $(".message .form-control").val(msg) $("#quick_reply_form").submit() } }, settingPanelHtml:'识别页面是否有隐藏内容的关键词:


自动回复消息模板:

' }, { describe : "键盘左右键翻页", open : false, matchCondition : function(){ return true }, doAction : function(){ $(document).keydown(function(event){ if(event.keyCode == 37){ let preA = $(".page-link:contains('◀')") if(preA && preA.length > 0){ window.location.href = preA.attr("href") } }else if(event.keyCode == 39){ let nextA = $(".page-link:contains('▶')") if(nextA && nextA.length > 0){ window.location.href = nextA.attr("href") } } }); } }, { describe : "阅读模式", open : false, matchCondition : function(){ return true }, doAction : function(){ $(document).find("*").each(function(i,item){ if($(item).parents('#helper-setting-panel').length > 0){ return } let oldCss = item.style.cssText || "" $(item).css("cssText",oldCss+"background-color:"+BACKGROUND_COLOR+"!important;color:"+FONT_COLOR+"!important;background-image:none!important;") }) }, settingPanelHtml:'背景色:    文字颜色:
' } ] Function.prototype.getMultiLine = function() { var lines = new String(this); lines = lines.substring(lines.indexOf("/*") + 3, lines.lastIndexOf("*/")); return lines; } String.prototype.format= function() { if(arguments.length === 0) return this; var param = arguments[0], str= this; if(typeof(param) === 'object') { for(var key in param) str = str.replace(new RegExp("\\{" + key + "\\}", "g"), param[key]); return str; } else { for(var i = 0; i < arguments.length; i++) str = str.replace(new RegExp("\\{" + i + "\\}", "g"), arguments[i]); return str; } } function localStorageGetItem(key,defaultVal){ let val = localStorage.getItem(key) return val ? val : defaultVal } function localStorageGetStringArray(key,defaultVal,split=","){ let value = localStorage.getItem(key) return (value && value.length > 0) ? value.split(split) : defaultVal } function loadSettingFromLocalStorage(){ SIGN_TITLE = localStorageGetItem("SIGN_TITLE","签到") HAS_HIDDEN_CONTENT_KEYWORD = localStorageGetItem("HAS_HIDDEN_CONTENT_KEYWORD","本帖含有隐藏内容") AUTO_REPLY_MSG = localStorageGetStringArray("AUTO_REPLY_MSG",[]) BLACK_LIST = localStorageGetStringArray("BLACK_LIST",[]) BACKGROUND_COLOR = localStorageGetItem("BACKGROUND_COLOR","#E3EDCD") FONT_COLOR = localStorageGetItem("FONT_COLOR","#000000") let fnOpenStatus = localStorageGetStringArray("fnOpenStatus",[]) for(let i =0;i {describe}
{settingPanelHtml}
*/ } function updateFunctionSwitch(){ actionArray.forEach(function(e,i){ e.open = $("#fn-checkbox-"+i)[0].checked }) } function loadJSColor(){ var input = $("[data-jscolor]"); for(var i=0;i' new $Msg({ useHTML:true, content:html, type:"success", cancle:function(){}, confirm:function(){ SIGN_TITLE = $("#sign-key").val(); HAS_HIDDEN_CONTENT_KEYWORD = $("#hide-key").val(); AUTO_REPLY_MSG = $("#auto-reply").val().split("\n"); BLACK_LIST = $("#black-list").val().split("\n"); BACKGROUND_COLOR = $("#background-color-input").val(); FONT_COLOR = $("#font-color-input").val(); updateFunctionSwitch() saveSettingFromLocalStorage() window.location.reload(); new $Msg({content:"设置已经保存",contentStyle:{ backgroundColor:white, color:black }}) } },function(){ loadJSColor(); }) } // 设置按钮代码参考:https://greasyfork.org/zh-CN/scripts/419215-%E8%87%AA%E5%8A%A8%E6%97%A0%E7%BC%9D%E7%BF%BB%E9%A1%B5 let _style = `` let _html = `
` document.documentElement.insertAdjacentHTML('beforeend', _style + _html); function isMatchPageCategory(pagePrefix){ return window.location.href.startsWith(window.location.protocol + "//" + window.location.host + "/" + pagePrefix) } actionArray.forEach(function(e){ e.open && e.matchCondition() && e.doAction() }) })(); // 弹窗代码地址:https://www.jb51.net/article/145251.htm (function (window, document) { //定义一个构造函数Msg 作为弹窗实例的构造函数。 let Msg = function (options,callback) { //执行初始化操作 this._init(options); callback && callback(); } //定义初始化方法 并对方法传递的参数进行初始化 Msg.prototype = { _init({ content = "", //文本内容 type = "info", //信息类型 useHTML = false, //是否解析html字符串 showIcon = false, //是否展示弹窗图标 confirm = null, //确认后得回调 cancle = null, //取消后得回调 footer = true, //是否显示底部的确认按钮 header = true, //是否显示头部信息及关闭按钮 title = "提示", //弹窗标题 contentStyle = {}, //内容样式 contentFontSize = "1.5em", //内容字体大小 btnName = ["确定", "取消"] //按钮文字内容 }) { //将传入的值绑定到this上 this.content = content; this.type = type; this.useHTML = useHTML; this.showIcon = showIcon; this.confirm = confirm; this.cancle = cancle; this.footer = footer; this.header = header; this.title = title; this.contentStyle = contentStyle; this.contentFontSize = contentFontSize; this.btnName = btnName; //执行创建元素方法 this._creatElement(); //显示弹窗及遮罩 this._show({ el: this._el, overlay: this._overlay }); //绑定事件处理函数 this._bind({ el: this._el, overlay: this._overlay }); }, //创建弹窗元素方法 _creatElement() { //创建最外层得包裹元素 let wrap = document.createElement("div"); wrap.className = "msg__wrap"; //定义弹窗得两个按钮 const [confirmBtnName, cancelBtnName] = this.btnName; //判断是否显示弹窗标题 const headerHTML = this.header ? `
${this.title} ×
` : ""; //判断是否显示图标 const iconHTML = this.showIcon ? `
` : ""; //判断是否显示弹窗底部按钮 const footerHTML = this.footer ? `` : ""; //拼接完整html const innerHTML = `${headerHTML}
${iconHTML}
${footerHTML}`; //将拼接的html赋值到wrap中 wrap.innerHTML = innerHTML; //把自定义的样式进行合并 const contentStyle = { fontSize: this.contentFontSize, ...this.contentStyle } //获取内容所属DOM let content = wrap.querySelector(".msg-body .msg-body-content"); //将传过来的样式添加到contentDOM for (const key in contentStyle) { if (contentStyle.hasOwnProperty(key)) { content.style[key] = contentStyle[key]; } } //给弹窗的conntent赋值 if (this.useHTML) { content.innerHTML = this.content; } else { content.innerText = this.content; } //创建遮罩层 let overlay = document.createElement("div"); overlay.className = "msg__overlay"; //把dom挂载到当前实例上 this._overlay = overlay; this._el = wrap; }, //弹窗展现方法 _show({ el, overlay }) { //把弹窗的dom和遮罩插入到页面中 document.body.appendChild(el); document.body.appendChild(overlay); //将弹窗显示出来 timeout进行异步处理显示动画 setTimeout(() => { el.style.transform = "translate(-50%,-50%) scale(1,1)"; overlay.style.opacity = "1"; }) }, //关闭弹窗方法 _close({ el, overlay }) { //隐藏dom el.style.transform = "translate(-50%,-50%) scale(0,0)"; overlay.style.opcity = "0"; //根据动画时间 动画完成再移除 setTimeout(() => { //把弹窗的dom和遮罩移除 document.body.removeChild(el) document.body.removeChild(overlay); }, 300); }, //事件处理函数,为DOM绑定事件 _bind({ el, overlay }) { //保存当前this //const _this = this; const cancle = (e) => { this.cancle && this.cancle.call(this, e); //隐藏弹窗 //hideMsg(); this._close({ el, overlay }); } //确认弹窗 const confirm = (e) => { this.confirm && this.confirm.call(this, e); this._close({ el, overlay }); } //顶部关闭按钮绑定事件 if (this.header) { el.querySelector(".msg-header-close-button").addEventListener("click", cancle); } //弹窗底部两个按钮事件监听 if (this.footer) { el.querySelector(".msg-footer-cancel-button").addEventListener("click", cancle); el.querySelector(".msg-footer-confirm-button").addEventListener("click", confirm) } } } //将构造函数暴露到window,这样才能在全局作用域下直接调用 window.$Msg = Msg; })(window, document);