// ==UserScript==
// @name 【移动端】MT论坛优化
// @namespace https://greasyfork.org/zh-CN/scripts/401359
// @version 2024.11.26
// @author WhiteSevs
// @description MT论坛效果增强,如自动签到、自动展开帖子、滚动加载评论、显示UID、自定义屏蔽、手机版小黑屋、编辑器优化、在线用户查看、便捷式图床、自定义用户标签、积分商城商品上架提醒等
// @license GPL-3.0-only
// @icon 
// @supportURL https://github.com/WhiteSevs/TamperMonkeyScript/issues
// @match *://bbs.binmt.cc/*
// @exclude /^http(s|)://bbs.binmt.cc/uc_server.*$/
// @require https://update.greasyfork.org/scripts/494167/1413255/CoverUMD.js
// @require https://update.greasyfork.org/scripts/452322/1470429/js-watermark.js
// @require https://fastly.jsdelivr.net/npm/@whitesev/utils@2.5.3/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/@whitesev/domutils@1.4.2/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/@whitesev/pops@1.9.4/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/qmsg@1.2.7/dist/index.umd.js
// @require https://fastly.jsdelivr.net/npm/viewerjs@1.11.6/dist/viewer.min.js
// @require https://fastly.jsdelivr.net/npm/@highlightjs/cdn-assets@11.10.0/highlight.min.js
// @resource HljsCSS https://fastly.jsdelivr.net/npm/highlight.js@11.10.0/styles/github-dark.min.css
// @resource ViewerCSS https://fastly.jsdelivr.net/npm/viewerjs@1.11.6/dist/viewer.min.css
// @connect *
// @connect *
// @connect helloimg.com
// @connect z4a.net
// @connect kggzs.cn
// @connect woozooo.com
// @grant GM_deleteValue
// @grant GM_getResourceText
// @grant GM_getValue
// @grant GM_info
// @grant GM_registerMenuCommand
// @grant GM_setValue
// @grant GM_unregisterMenuCommand
// @grant GM_xmlhttpRequest
// @grant unsafeWindow
// @run-at document-start
// ==/UserScript==
(function (Qmsg, DOMUtils, Utils, pops, Viewer, hljs) {
'use strict';
var __defProp = Object.defineProperty;
var __getOwnPropNames = Object.getOwnPropertyNames;
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
var __commonJS = (cb, mod) => function __require() {
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
};
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
var require_entrance_001 = __commonJS({
"entrance-Ba2iaBB7.js"(exports, module) {
var _a;
var _GM_deleteValue = /* @__PURE__ */ (() => typeof GM_deleteValue != "undefined" ? GM_deleteValue : void 0)();
var _GM_getResourceText = /* @__PURE__ */ (() => typeof GM_getResourceText != "undefined" ? GM_getResourceText : void 0)();
var _GM_getValue = /* @__PURE__ */ (() => typeof GM_getValue != "undefined" ? GM_getValue : void 0)();
var _GM_info = /* @__PURE__ */ (() => typeof GM_info != "undefined" ? GM_info : void 0)();
var _GM_registerMenuCommand = /* @__PURE__ */ (() => typeof GM_registerMenuCommand != "undefined" ? GM_registerMenuCommand : void 0)();
var _GM_setValue = /* @__PURE__ */ (() => typeof GM_setValue != "undefined" ? GM_setValue : void 0)();
var _GM_unregisterMenuCommand = /* @__PURE__ */ (() => typeof GM_unregisterMenuCommand != "undefined" ? GM_unregisterMenuCommand : void 0)();
var _GM_xmlhttpRequest = /* @__PURE__ */ (() => typeof GM_xmlhttpRequest != "undefined" ? GM_xmlhttpRequest : void 0)();
var _unsafeWindow = /* @__PURE__ */ (() => typeof unsafeWindow != "undefined" ? unsafeWindow : void 0)();
var _monkeyWindow = /* @__PURE__ */ (() => window)();
const HttpxCookieManager = {
$data: {
/** 是否启用 */
get enable() {
return PopsPanel.getValue("httpx-use-cookie-enable");
},
/** 是否使用document.cookie */
get useDocumentCookie() {
return PopsPanel.getValue("httpx-use-document-cookie");
},
cookieRule: [
{
key: "httpx-cookie-bbs.binmt.cc",
hostname: /bbs.binmt.cc/g
}
]
},
/**
* 补充cookie末尾分号
*/
fixCookieSplit(str) {
if (utils.isNotNull(str) && !str.trim().endsWith(";")) {
str += ";";
}
return str;
},
/**
* 合并两个cookie
*/
concatCookie(targetCookie, newCookie) {
if (utils.isNull(targetCookie)) {
return newCookie;
}
targetCookie = targetCookie.trim();
newCookie = newCookie.trim();
targetCookie = this.fixCookieSplit(targetCookie);
if (newCookie.startsWith(";")) {
newCookie = newCookie.substring(1);
}
return targetCookie.concat(newCookie);
},
/**
* 处理cookie
* @param details
* @returns
*/
handle(details) {
if (details.fetch) {
return;
}
if (!this.$data.enable) {
return;
}
let ownCookie = "";
let url = details.url;
if (url.startsWith("//")) {
url = window.location.protocol + url;
}
let urlObj = new URL(url);
if (this.$data.useDocumentCookie && urlObj.hostname.endsWith(
window.location.hostname.split(".").slice(-2).join(".")
)) {
ownCookie = this.concatCookie(ownCookie, document.cookie.trim());
}
for (let index = 0; index < this.$data.cookieRule.length; index++) {
let rule = this.$data.cookieRule[index];
if (urlObj.hostname.match(rule.hostname)) {
let cookie = PopsPanel.getValue(rule.key);
if (utils.isNull(cookie)) {
break;
}
ownCookie = this.concatCookie(ownCookie, cookie);
}
}
if (utils.isNotNull(ownCookie)) {
if (details.headers && details.headers["Cookie"]) {
details.headers.Cookie = this.concatCookie(
details.headers.Cookie,
ownCookie
);
} else {
details.headers["Cookie"] = ownCookie;
}
log.info(["Httpx => 设置cookie:", details]);
}
if (details.headers && details.headers.Cookie != null && utils.isNull(details.headers.Cookie)) {
delete details.headers.Cookie;
}
}
};
const GM_RESOURCE_MAPPING = {
ElementPlus: {
keyName: "ElementPlusResourceCSS",
url: "https://fastly.jsdelivr.net/npm/element-plus@latest/dist/index.min.css"
},
Viewer: {
keyName: "ViewerCSS",
url: "https://fastly.jsdelivr.net/npm/viewerjs@latest/dist/viewer.min.css"
},
Hljs: {
keyName: "HljsCSS",
url: "https://fastly.jsdelivr.net/npm/highlight.js@latest/styles/github-dark.min.css"
}
};
(function(global, factory) {
if (typeof exports === "object" && typeof module !== "undefined") {
module.exports = factory();
} else {
global = typeof globalThis !== "undefined" ? globalThis : global || self;
global.Watermark = factory(global.Watermark);
}
})(typeof window !== "undefined" ? window : void 0, function(AnotherWatermark) {
let Watermark = function() {
};
CanvasRenderingContext2D.prototype.letterSpacingText = function(text, x, y, letterSpacing) {
var context = this;
var canvas = context.canvas;
if (!letterSpacing && canvas) {
letterSpacing = parseFloat(window.getComputedStyle(canvas).letterSpacing);
}
if (!letterSpacing) {
return this.fillText(text, x, y);
}
var arrText = text.split("");
var align = context.textAlign || "left";
var originWidth = context.measureText(text).width;
var actualWidth = originWidth + letterSpacing * (arrText.length - 1);
if (align == "center") {
x = x - actualWidth / 2;
} else if (align == "right") {
x = x - actualWidth;
}
context.textAlign = "left";
arrText.forEach(function(letter) {
var letterWidth = context.measureText(letter).width;
context.fillText(letter, x, y);
x = x + letterWidth + letterSpacing;
});
context.textAlign = align;
};
CanvasRenderingContext2D.prototype.wrapText = function(text, x, y, maxWidth, lineHeight, stroke) {
if (typeof text != "string" || typeof x != "number" || typeof y != "number") {
return;
}
var context = this;
var canvas = context.canvas;
if (typeof maxWidth == "undefined") {
maxWidth = canvas && canvas.width || 300;
}
if (typeof lineHeight == "undefined") {
lineHeight = canvas && parseInt(window.getComputedStyle(canvas).lineHeight) || parseInt(window.getComputedStyle(document.body).lineHeight);
}
var arrText = text.split("");
var line = "";
for (var n = 0; n < arrText.length; n++) {
var testLine = line + arrText[n];
var metrics = context.measureText(testLine);
var testWidth = metrics.width;
if (testWidth > maxWidth && n > 0) {
if (stroke) {
context.strokeText(line, x, y, canvas.width);
} else {
context.fillText(line, x, y);
}
line = arrText[n];
y += lineHeight;
} else {
line = testLine;
}
}
if (stroke) {
context.strokeText(line, x, y, canvas.width);
} else {
context.fillText(line, x, y);
}
};
CanvasRenderingContext2D.prototype.fillTextVertical = function(text, x, y) {
var context = this;
context.canvas;
var arrText = text.split("");
var arrWidth = arrText.map(function(letter) {
return context.measureText(letter).width;
});
var align = context.textAlign;
var baseline = context.textBaseline;
if (align == "left") {
x = x + Math.max.apply(null, arrWidth) / 2;
} else if (align == "right") {
x = x - Math.max.apply(null, arrWidth) / 2;
}
if (baseline == "bottom" || baseline == "alphabetic" || baseline == "ideographic") {
y = y - arrWidth[0] / 2;
} else if (baseline == "top" || baseline == "hanging") {
y = y + arrWidth[0] / 2;
}
context.textAlign = "center";
context.textBaseline = "middle";
arrText.forEach(function(letter, index) {
var letterWidth = arrWidth[index];
var code = letter.charCodeAt(0);
if (code <= 256) {
context.translate(x, y);
context.rotate(90 * Math.PI / 180);
context.translate(-x, -y);
} else if (index > 0 && text.charCodeAt(index - 1) < 256) {
y = y + arrWidth[index - 1] / 2;
}
context.fillText(letter, x, y);
context.setTransform(1, 0, 0, 1, 0, 0);
var letterWidth = arrWidth[index];
y = y + letterWidth;
});
context.textAlign = align;
context.textBaseline = baseline;
};
function loadFile(file) {
let fileReader = new FileReader();
return new Promise((resolve) => {
fileReader.onloadend = async function(event) {
resolve(event);
};
fileReader.readAsDataURL(file);
});
}
function loadImage(src) {
let image = new Image();
return new Promise((resolve) => {
image.onload = () => {
resolve(image);
};
image.src = src;
});
}
function checkInArrayByPos(arrayData, x, y) {
let flag = false;
Array.from(arrayData).forEach((item) => {
if (item["x"] == x && item["y"] == y) {
flag = true;
return;
}
});
return flag;
}
function getRandValue(arr) {
if (arr instanceof Array) {
return arr[Math.floor(Math.random() * arr.length)];
} else {
return arr;
}
}
Watermark.prototype.setFile = function(file) {
let that = this;
return new Promise(async (resolve) => {
try {
var fileReader = await loadFile(file);
await that.setImage(fileReader.target.result);
resolve(true);
} catch (error) {
resolve(false);
}
});
};
Watermark.prototype.setImage = function(src) {
this.dataUrl = src;
let that = this;
return new Promise(async (res) => {
var image = await loadImage(src);
that.sizes = {
width: image.width,
height: image.height
};
var canvas = document.createElement("canvas");
canvas.width = that.sizes.width;
canvas.height = that.sizes.height;
var ctx = canvas.getContext("2d");
ctx.drawImage(image, 0, 0);
image = null;
that.canvas = canvas;
res(true);
});
};
Watermark.prototype.hasImage = function() {
return !!this.dataUrl;
};
Watermark.prototype.getSize = function() {
return this.sizes;
};
Watermark.prototype.clearMark = function() {
let that = this;
if (typeof that.canvas === "undefined") {
return;
}
function _clearMark_() {
var ctx = that.canvas.getContext("2d");
ctx.clearRect(0, 0, that.canvas.width, that.canvas.height);
var w = that.canvas.width;
var h = that.canvas.height;
that.canvas.width = w;
that.canvas.height = h;
ctx.beginPath();
var image = new Image();
image.src = that.dataUrl;
ctx.drawImage(image, 0, 0);
image = null;
}
_clearMark_();
};
Watermark.prototype.addText = function(opts) {
var options = {
text: ["Call By waterMark.addText"],
fontSize: "6vw",
fontFamily: "Microsoft Yahei",
color: "#000000",
textAlign: "center",
/* 描边 */
stroke: false,
globalAlpha: 0.7,
/* -360 ~ 360 */
rotateAngle: 50,
/* 必须大于0 */
maxWidth: 100,
/* 必须大于0 */
xMoveDistance: 30,
/* 必须大于0 */
yMoveDistance: 30
};
for (let key in options) {
if (typeof opts[key] !== "undefined") {
options[key] = opts[key];
}
}
options.maxWidth = parseInt(options.maxWidth) > 0 ? options.maxWidth : 1;
options.xMoveDistance = parseInt(options.xMoveDistance) > 0 ? options.xMoveDistance : 1;
options.yMoveDistance = parseInt(options.yMoveDistance) > 0 ? options.yMoveDistance : 1;
var ctx = this.canvas.getContext("2d");
var fontSize = options.fontSize;
fontSize = fontSize.toString();
if (~fontSize.indexOf("vw")) {
fontSize = (this.sizes.width / 100 * parseInt(fontSize)).toFixed(0);
}
fontSize = parseInt(fontSize);
ctx.font = fontSize + "px " + options.fontFamily;
ctx.fillStyle = options.color;
ctx.textAlign = options.textAlign;
ctx.globalAlpha = options.globalAlpha;
let canvasWidth = this.sizes.width, canvasHeight = this.sizes.height;
let rotateAngle = options.rotateAngle * Math.PI / 180;
let xMoveDistance = options.xMoveDistance;
let yMoveDistance = options.yMoveDistance;
let maxWidth = options.maxWidth;
let lineHeight = fontSize;
let pos = [];
for (var i = canvasWidth / 2; i < canvasWidth; i += xMoveDistance) {
for (var j = canvasHeight / 2; j < canvasHeight; j += yMoveDistance) {
if (!checkInArrayByPos(pos, i, j)) {
pos = pos.concat({
x: i,
y: j
});
ctx.setTransform(1, 0, 0, 1, 0, 0);
ctx.translate(i, j);
ctx.rotate(rotateAngle);
ctx.wrapText(
getRandValue(options.text),
0,
0,
maxWidth,
lineHeight,
options.stroke
);
}
}
for (var k = canvasHeight / 2; k > 0; k -= yMoveDistance) {
if (!checkInArrayByPos(pos, i, k)) {
pos = pos.concat({
x: i,
y: k
});
ctx.setTransform(1, 0, 0, 1, 0, 0);
ctx.translate(i, k);
ctx.rotate(rotateAngle);
ctx.wrapText(
getRandValue(options.text),
0,
0,
maxWidth,
lineHeight,
options.stroke
);
}
}
}
for (var i = canvasWidth / 2; i > 0; i -= xMoveDistance) {
for (var j = canvasHeight / 2; j < canvasHeight; j += yMoveDistance) {
if (!checkInArrayByPos(pos, i, j)) {
pos = pos.concat({
x: i,
y: j
});
ctx.setTransform(1, 0, 0, 1, 0, 0);
ctx.translate(i, j);
ctx.rotate(rotateAngle);
ctx.wrapText(
getRandValue(options.text),
0,
0,
maxWidth,
lineHeight,
options.stroke
);
}
}
for (var k = canvasHeight / 2; k > 0; k -= yMoveDistance) {
if (!checkInArrayByPos(pos, i, k)) {
pos = pos.concat({
x: i,
y: k
});
ctx.setTransform(1, 0, 0, 1, 0, 0);
ctx.translate(i, k);
ctx.rotate(rotateAngle);
ctx.wrapText(
getRandValue(options.text),
0,
0,
maxWidth,
lineHeight,
options.stroke
);
}
}
}
};
Watermark.prototype.addPixelText = function(opts) {
var options = {
text: "像素文字水印",
/* 像素文字 */
big: {
fontSize: 150,
fontFamily: "微软雅黑",
textAlign: "center",
rotateAngle: 0,
/* 描边 */
stroke: false
},
/* 绘制像素的文字 */
small: {
fontSize: 10,
fontFamily: "微软雅黑",
color: "#000",
textAlign: "center",
globalAlpha: 0.7
}
};
for (let key in options) {
if (typeof opts[key] !== "undefined") {
options[key] = opts[key];
}
}
var ctx = this.canvas.getContext("2d");
var tmpCanvas = document.createElement("canvas");
var tmpctx = tmpCanvas.getContext("2d");
tmpCanvas.width = this.sizes.width;
tmpCanvas.height = this.sizes.height;
tmpctx.font = options.big.fontSize + "px " + options.big.fontFamily;
tmpctx.textAlign = options.big.textAlign;
tmpctx.textBaseline = "middle";
tmpctx.translate(tmpCanvas.width / 2, tmpCanvas.height / 2);
tmpctx.rotate(options.big.rotateAngle * Math.PI / 180);
tmpctx.translate(-tmpCanvas.width / 2, -tmpCanvas.height / 2);
if (options.big.stroke) {
tmpctx.strokeText(
options.text,
tmpCanvas.width / 2,
tmpCanvas.height / 2,
tmpCanvas.width
);
} else {
tmpctx.fillText(options.text, tmpCanvas.width / 2, tmpCanvas.height / 2);
}
var textArray = options.text.split("");
var textPixleInfo = tmpctx.getImageData(
0,
0,
tmpCanvas.width,
tmpCanvas.height
);
var pixelArray = [];
for (var i = 0; i < tmpCanvas.height; i += options.small.fontSize) {
for (var j = 0; j < tmpCanvas.width; j += options.small.fontSize) {
var index = j + i * tmpCanvas.width;
var a = textPixleInfo.data[index * 4 + 3];
if (a > 128) {
pixelArray.push({
text: getRandValue(textArray),
x: j,
y: i
});
}
}
}
ctx.font = options.small.fontSize + "px " + options.small.fontFamily;
ctx.fillStyle = options.small.color;
ctx.textAlign = options.small.textAlign;
ctx.textBaseline = "middle";
ctx.globalAlpha = options.small.globalAlpha;
pixelArray.forEach((item) => {
ctx.fillText(item.text, item.x, item.y);
});
};
Watermark.prototype.addImage = function(opts) {
if (opts.imageArray == null) {
alert("参数缺少imageArray");
return false;
}
if (opts.imageArray.length === 0) {
alert("参数imageArray不能为空");
return false;
}
let options = {
imageArray: [],
/* 里面为水印Image对象 */
width: 50,
/* 必须大于0 */
height: 50,
/* 必须大于0 */
globalAlpha: 0.5,
rotateAngle: 0,
xMoveDistance: 70,
/* 必须大于0 */
yMoveDistance: 70
/* 必须大于0 */
};
for (let key in options) {
if (typeof opts[key] !== "undefined") {
options[key] = opts[key];
}
}
options.width = parseInt(options.width) > 0 ? options.width : 1;
options.height = parseInt(options.height) > 0 ? options.height : 1;
options.xMoveDistance = parseInt(options.xMoveDistance) > 0 ? options.xMoveDistance : 1;
options.yMoveDistance = parseInt(options.yMoveDistance) > 0 ? options.yMoveDistance : 1;
let ctx = this.canvas.getContext("2d");
let waterImageCanvasArray = [];
let waterImageCanvasDiagonal = parseInt(
Math.sqrt(options.width * options.width + options.height * options.height)
);
let canvasWidth = this.sizes.width, canvasHeight = this.sizes.height;
let rotateAngle = options.rotateAngle * Math.PI / 180;
let xMoveDistance = options.xMoveDistance;
let yMoveDistance = options.yMoveDistance;
let centerDrawLeftPosX = canvasWidth / 2 - waterImageCanvasDiagonal / 2;
let centerDrawLeftPosY = canvasHeight / 2 - waterImageCanvasDiagonal / 2;
let waterDrawPosX = (waterImageCanvasDiagonal - options.width) / 2;
let waterDrawPosY = (waterImageCanvasDiagonal - options.height) / 2;
Array.from(options.imageArray).forEach((item) => {
var waterImageCanvas = document.createElement("canvas");
var waterctx = waterImageCanvas.getContext("2d");
waterImageCanvas.width = waterImageCanvasDiagonal;
waterImageCanvas.height = waterImageCanvasDiagonal;
waterctx.globalAlpha = options.globalAlpha;
waterctx.translate(
waterImageCanvasDiagonal / 2,
waterImageCanvasDiagonal / 2
);
waterctx.rotate(rotateAngle);
waterctx.translate(
-waterImageCanvasDiagonal / 2,
-waterImageCanvasDiagonal / 2
);
waterctx.drawImage(
item,
waterDrawPosX,
waterDrawPosY,
options.width,
options.height
);
waterImageCanvasArray = waterImageCanvasArray.concat(waterImageCanvas);
});
function randomArrayData(array_data) {
return array_data[Math.floor(Math.random() * array_data.length)];
}
ctx.setTransform(1, 0, 0, 1, 0, 0);
let pos = [];
for (let i = centerDrawLeftPosX; i < canvasWidth; i += xMoveDistance) {
for (let j = centerDrawLeftPosY; j < canvasHeight; j += yMoveDistance) {
if (!checkInArrayByPos(pos, i, j)) {
pos = pos.concat({
x: i,
y: j
});
ctx.drawImage(
randomArrayData(waterImageCanvasArray),
i,
j
);
}
}
for (let k = centerDrawLeftPosY; k > -Math.abs(waterImageCanvasDiagonal); k -= yMoveDistance) {
if (!checkInArrayByPos(pos, i, k)) {
pos = pos.concat({
x: i,
y: k
});
ctx.drawImage(randomArrayData(waterImageCanvasArray), i, k);
}
}
}
for (let i = centerDrawLeftPosX; i > -Math.abs(waterImageCanvasDiagonal); i -= xMoveDistance) {
for (let j = centerDrawLeftPosY; j < canvasHeight; j += yMoveDistance) {
if (!checkInArrayByPos(pos, i, j)) {
pos = pos.concat({
x: i,
y: j
});
ctx.drawImage(randomArrayData(waterImageCanvasArray), i, j);
}
}
for (let k = centerDrawLeftPosY; k > -Math.abs(waterImageCanvasDiagonal); k -= yMoveDistance) {
if (!checkInArrayByPos(pos, i, k)) {
pos = pos.concat({
x: i,
y: k
});
ctx.drawImage(randomArrayData(waterImageCanvasArray), i, k);
}
}
}
};
Watermark.prototype.getPreview = function() {
return this.dataUrl;
};
Watermark.prototype.render = function(type) {
type = type === "png" ? "png" : "jpeg";
return this.canvas.toDataURL("image/" + type);
};
Watermark.prototype.renderBlob = function() {
let that = this;
return new Promise((res) => {
that.canvas.toBlob(function(blob) {
res(window.URL.createObjectURL(blob));
});
});
};
Watermark.prototype.noConflict = function() {
if (window.Watermark) {
delete window.Watermark;
}
if (AnotherWatermark) {
window.Watermark = AnotherWatermark;
}
return Watermark;
};
return Watermark;
});
const CommonUtil = {
/**
* 添加屏蔽CSS
* @param args
* @example
* addBlockCSS("")
* addBlockCSS("","")
* addBlockCSS(["",""])
*/
addBlockCSS(...args) {
let selectorList = [];
if (args.length === 0) {
return;
}
if (args.length === 1 && typeof args[0] === "string" && args[0].trim() === "") {
return;
}
args.forEach((selector) => {
if (Array.isArray(selector)) {
selectorList = selectorList.concat(selector);
} else {
selectorList.push(selector);
}
});
return addStyle(`${selectorList.join(",\n")}{display: none !important;}`);
},
/**
* 设置GM_getResourceText的style内容
* @param resourceMapData 资源数据
* @example
* setGMResourceCSS({
* keyName: "ViewerCSS",
* url: "https://example.com/example.css",
* })
*/
setGMResourceCSS(resourceMapData) {
let cssText = typeof _GM_getResourceText === "function" ? _GM_getResourceText(resourceMapData.keyName) : "";
if (typeof cssText === "string" && cssText) {
addStyle(cssText);
} else {
CommonUtil.loadStyleLink(resourceMapData.url);
}
},
/**
* 添加<link>标签
* @param url
* @example
* loadStyleLink("https://example.com/example.css")
*/
async loadStyleLink(url) {
let $link = document.createElement("link");
$link.rel = "stylesheet";
$link.type = "text/css";
$link.href = url;
domUtils.ready(() => {
document.head.appendChild($link);
});
},
/**
* 添加<script>标签
* @param url
* @example
* loadStyleLink("https://example.com/example.js")
*/
async loadScript(url) {
let $script = document.createElement("script");
$script.src = url;
return new Promise((resolve) => {
$script.onload = () => {
resolve(null);
};
(document.head || document.documentElement).appendChild($script);
});
},
/**
* 将url修复,例如只有search的链接修复为完整的链接
*
* 注意:不包括http转https
* @param url 需要修复的链接
* @example
* 修复前:`/xxx/xxx?ss=ssss`
* 修复后:`https://xxx.xxx.xxx/xxx/xxx?ss=ssss`
* @example
* 修复前:`//xxx/xxx?ss=ssss`
* 修复后:`https://xxx.xxx.xxx/xxx/xxx?ss=ssss`
* @example
* 修复前:`https://xxx.xxx.xxx/xxx/xxx?ss=ssss`
* 修复后:`https://xxx.xxx.xxx/xxx/xxx?ss=ssss`
* @example
* 修复前:`xxx/xxx?ss=ssss`
* 修复后:`https://xxx.xxx.xxx/xxx/xxx?ss=ssss`
*/
fixUrl(url) {
url = url.trim();
if (url.match(/^http(s|):\/\//i)) {
return url;
} else {
if (!url.startsWith("/")) {
url += "/";
}
url = window.location.origin + url;
return url;
}
},
/**
* http转https
* @param url 需要修复的链接
* @example
* 修复前:
* 修复后:
* @example
* 修复前:
* 修复后:
*/
fixHttps(url) {
if (url.startsWith("https://")) {
return url;
}
if (!url.startsWith("http://")) {
return url;
}
let urlObj = new URL(url);
urlObj.protocol = "https:";
return urlObj.toString();
}
};
const _SCRIPT_NAME_ = "【移动端】MT论坛优化";
const utils = Utils.noConflict();
const domUtils = DOMUtils.noConflict();
const __pops = pops;
const log = new utils.Log(
_GM_info,
_unsafeWindow.console || _monkeyWindow.console
);
const SCRIPT_NAME = ((_a = _GM_info == null ? void 0 : _GM_info.script) == null ? void 0 : _a.name) || _SCRIPT_NAME_;
const DEBUG = false;
log.config({
debug: DEBUG,
logMaxCount: 1e3,
autoClearConsole: true,
tag: true
});
Qmsg.config(
Object.defineProperties(
{
html: true,
autoClose: true,
showClose: false
},
{
position: {
get() {
return PopsPanel.getValue("qmsg-config-position", "bottom");
}
},
maxNums: {
get() {
return PopsPanel.getValue("qmsg-config-maxnums", 5);
}
},
showReverse: {
get() {
return PopsPanel.getValue("qmsg-config-showreverse", true);
}
},
zIndex: {
get() {
let maxZIndex = Utils.getMaxZIndex();
let popsMaxZIndex = pops.config.InstanceUtils.getPopsMaxZIndex().zIndex;
return Utils.getMaxValue(maxZIndex, popsMaxZIndex) + 100;
}
}
}
)
);
const GM_Menu = new utils.GM_Menu({
GM_getValue: _GM_getValue,
GM_setValue: _GM_setValue,
GM_registerMenuCommand: _GM_registerMenuCommand,
GM_unregisterMenuCommand: _GM_unregisterMenuCommand
});
const httpx = new utils.Httpx(_GM_xmlhttpRequest);
httpx.interceptors.request.use((data) => {
HttpxCookieManager.handle(data);
return data;
});
httpx.interceptors.response.use(void 0, (data) => {
log.error(["拦截器-请求错误", data]);
if (data.type === "onabort") {
Qmsg.warning("请求取消");
} else if (data.type === "onerror") {
Qmsg.error("请求异常");
} else if (data.type === "ontimeout") {
Qmsg.error("请求超时");
} else {
Qmsg.error("其它错误");
}
return data;
});
httpx.config({
logDetails: DEBUG
});
pops.GlobalConfig.setGlobalConfig({
mask: {
enable: true,
clickEvent: {
toClose: false,
toHide: false
}
}
});
({
Object: {
defineProperty: _unsafeWindow.Object.defineProperty
},
Function: {
apply: _unsafeWindow.Function.prototype.apply,
call: _unsafeWindow.Function.prototype.call
},
Element: {
appendChild: _unsafeWindow.Element.prototype.appendChild
},
setTimeout: _unsafeWindow.setTimeout
});
const addStyle = utils.addStyle.bind(utils);
CommonUtil.setGMResourceCSS(GM_RESOURCE_MAPPING.Viewer);
CommonUtil.setGMResourceCSS(GM_RESOURCE_MAPPING.Hljs);
const $ = document.querySelector.bind(document);
const $$ = document.querySelectorAll.bind(document);
const KEY = "GM_Panel";
const ATTRIBUTE_INIT = "data-init";
const ATTRIBUTE_KEY = "data-key";
const ATTRIBUTE_DEFAULT_VALUE = "data-default-value";
const ATTRIBUTE_INIT_MORE_VALUE = "data-init-more-value";
const PROPS_STORAGE_API = "data-storage-api";
const UISwitch = function(text, key, defaultValue, clickCallBack, description, afterAddToUListCallBack) {
let result = {
text,
type: "switch",
description,
attributes: {},
props: {},
getValue() {
return Boolean(
this.props[PROPS_STORAGE_API].get(key, defaultValue)
);
},
callback(event, __value) {
let value = Boolean(__value);
log.success(`${value ? "开启" : "关闭"} ${text}`);
this.props[PROPS_STORAGE_API].set(key, value);
},
afterAddToUListCallBack
};
Reflect.set(result.attributes, ATTRIBUTE_KEY, key);
Reflect.set(result.attributes, ATTRIBUTE_DEFAULT_VALUE, defaultValue);
Reflect.set(result.props, PROPS_STORAGE_API, {
get(key2, defaultValue2) {
return PopsPanel.getValue(key2, defaultValue2);
},
set(key2, value) {
PopsPanel.setValue(key2, value);
}
});
return result;
};
const UITextArea = function(text, key, defaultValue, description, changeCallBack, placeholder = "", disabled) {
let result = {
text,
type: "textarea",
attributes: {},
props: {},
description,
placeholder,
disabled,
getValue() {
return this.props[PROPS_STORAGE_API].get(key, defaultValue);
},
callback(event, value) {
this.props[PROPS_STORAGE_API].set(key, value);
}
};
Reflect.set(result.attributes, ATTRIBUTE_KEY, key);
Reflect.set(result.attributes, ATTRIBUTE_DEFAULT_VALUE, defaultValue);
Reflect.set(result.props, PROPS_STORAGE_API, {
get(key2, defaultValue2) {
return PopsPanel.getValue(key2, defaultValue2);
},
set(key2, value) {
PopsPanel.setValue(key2, value);
}
});
return result;
};
const UISelect = function(text, key, defaultValue, data, callback, description) {
let selectData = [];
if (typeof data === "function") {
selectData = data();
} else {
selectData = data;
}
let result = {
text,
type: "select",
description,
attributes: {},
props: {},
getValue() {
return this.props[PROPS_STORAGE_API].get(key, defaultValue);
},
callback(event, isSelectedValue, isSelectedText) {
let value = isSelectedValue;
log.info(`选择:${isSelectedText}`);
this.props[PROPS_STORAGE_API].set(key, value);
if (typeof callback === "function") {
callback(event, value, isSelectedText);
}
},
data: selectData
};
Reflect.set(result.attributes, ATTRIBUTE_KEY, key);
Reflect.set(result.attributes, ATTRIBUTE_DEFAULT_VALUE, defaultValue);
Reflect.set(result.props, PROPS_STORAGE_API, {
get(key2, defaultValue2) {
return PopsPanel.getValue(key2, defaultValue2);
},
set(key2, value) {
PopsPanel.setValue(key2, value);
}
});
return result;
};
const UIButton = function(text, description, buttonText, buttonIcon, buttonIsRightIcon, buttonIconIsLoading, buttonType, clickCallBack, afterAddToUListCallBack) {
let result = {
text,
type: "button",
description,
buttonIcon,
buttonIsRightIcon,
buttonIconIsLoading,
buttonType,
buttonText,
callback(event) {
if (typeof clickCallBack === "function") {
clickCallBack(event);
}
},
afterAddToUListCallBack
};
return result;
};
const UIOwn = function(getLiElementCallBack, initConfig, props, afterAddToUListCallBack) {
let result = {
type: "own",
attributes: {},
props,
getLiElementCallBack,
afterAddToUListCallBack
};
Reflect.set(result.attributes, ATTRIBUTE_INIT, () => {
return false;
});
return result;
};
const MTUtils = {
/**
* 根据UID获取小|中|大头像
* @param uid
* @param size
*/
getAvatar: (uid, size = "middle") => {
return `/uc_server/avatar.php?uid=${uid}&size=${size}&ts=1`;
},
/**
* 获取当前已登录的用户的uid
*/
getCurrentUID() {
let discuz_uid = _unsafeWindow.discuz_uid;
if (typeof discuz_uid === "string") {
return discuz_uid;
}
let $exit = document.querySelector(
'.sidenv_exit a[href*="uid="]'
);
if ($exit) {
let uidMatch = $exit.href.match(/uid=([0-9]+)/);
if (uidMatch) {
return uidMatch[uidMatch.length - 1];
}
}
},
/**
* 获取当前已登录用户的formhash
*/
getCurrentFormHash() {
let $exit = document.querySelector(
'.sidenv_exit a[href*="formhash="]'
);
if ($exit) {
let formHashMatch = $exit.href.match(/formhash=([0-9a-zA-Z]+)/);
if (formHashMatch) {
return formHashMatch[formHashMatch.length - 1];
}
}
},
/**
* 检测环境模板
*/
envIsMobile() {
return (
// @ts-ignore
(_unsafeWindow.STYLEID || // @ts-ignore
window.STYLEID || // @ts-ignore
typeof STYLEID !== "undefined" && STYLEID) === "3"
);
},
/**
* 获取帖子id
* @param url
*/
getThreadId: (url) => {
let urlMatch = url.match(/thread-([\d]+)-|&tid=([\d]+)/i);
if (urlMatch) {
let forumIdList = urlMatch.filter(Boolean);
let forumId = forumIdList[forumIdList.length - 1];
return forumId;
}
},
/**
* 获取板块?id
*/
getForumId(url) {
let urlMatch = url.match(/&fid=([\d]+)/i);
if (urlMatch) {
return urlMatch[urlMatch.length - 1];
}
},
/**
* 获取发布id
*/
getPostId(url) {
let urlMatch = url.match(/&pid=([\d]+)/i);
if (urlMatch) {
return urlMatch[urlMatch.length - 1];
}
},
/**
* 获取回复id
*/
getRepquote(url) {
let urlMatch = url.match(/&repquote=([\d]+)/i);
if (urlMatch) {
return urlMatch[urlMatch.length - 1];
}
}
};
const MTDyncmicAvatar = {
$upload: {
small: false,
middle: false,
big: false
},
$data: {
/**
* 图片文件最大大小
*/
avatarInfo: {
maxSize: 2097152,
small: {
width: 48,
height: 48
},
middle: {
width: 120,
height: 120
},
big: {
width: 200,
height: 250
}
}
},
$el: {
$smallUpload: null,
$middleUpload: null,
$bigUpload: null,
$smallStatus: null,
$middleStatus: null,
$bigStatus: null
},
$avatar: {
get small() {
return MTDyncmicAvatar.$el.$smallUpload.files[0];
},
get middle() {
return MTDyncmicAvatar.$el.$middleUpload.files[0];
},
get big() {
return MTDyncmicAvatar.$el.$bigUpload.files[0];
}
},
/**
* 显示视图
*/
showView() {
const that = this;
let $confirm = __pops.confirm({
title: {
text: "修改头像",
position: "center"
},
content: {
text: (
/*html*/
`
<div class="avatar-container">
<p class="avatar-tip">1. 小头像(图片宽高限制最大尺寸:48×48)</p>
<p class="avatar-upload-status" data-type="small">🤡请先上传图片</p>
<input type="file" class="avatar-upload" data-type="small" data-maxwidth="48" data-maxheight="48" accept="image/*">
</div>
<div class="avatar-container">
<p class="avatar-tip">2. 中头像(图片宽高限制最大尺寸:120×120)</p>
<p class="avatar-upload-status" data-type="middle">🤡请先上传图片</p>
<input type="file" class="avatar-upload" data-type="middle" data-maxwidth="120" data-maxheight="120" accept="image/*">
</div>
<div class="avatar-container">
<p class="avatar-tip">3. 大头像(图片宽高限制最大尺寸:200×250)</p>
<p class="avatar-upload-status" data-type="big">🤡请先上传图片</p>
<input type="file" class="avatar-upload" data-type="big" data-maxwidth="200" data-maxheight="250" accept="image/*">
</div>
`
),
html: true
},
btn: {
ok: {
text: "上传",
callback: async () => {
if (!that.$upload.small) {
Qmsg.error("请上传小头像");
return;
}
if (!that.$upload.middle) {
Qmsg.error("请上传中头像");
return;
}
if (!that.$upload.big) {
Qmsg.error("请上传大头像");
return;
}
let $loading = Qmsg.loading("正在处理数据中...");
try {
let uploadUrl = await this.getUploadUrl();
if (uploadUrl == null) {
return;
}
let formhash = MTUtils.getCurrentFormHash();
if (formhash == null) {
Qmsg.error("获取formhash失败");
return;
}
let avatarInfo = {
big: {
base64: await utils.parseFileToBase64(this.$avatar.big)
},
middle: {
base64: await utils.parseFileToBase64(this.$avatar.middle)
},
small: {
base64: await utils.parseFileToBase64(this.$avatar.small)
}
};
Object.keys(avatarInfo).forEach((keyName) => {
let value = avatarInfo[keyName];
value.base64 = value.base64.substring(
value.base64.indexOf(",") + 1
);
});
let formData = new FormData();
formData.append("Filedata", this.$avatar.big || "");
formData.append("confirm", "确定");
formData.append("avatar1", avatarInfo.big.base64);
formData.append("avatar2", avatarInfo.middle.base64);
formData.append("avatar3", avatarInfo.small.base64);
formData.append("formhash", formhash);
log.info(`头像的base64字符串`, avatarInfo);
let response = await httpx.post(uploadUrl, {
data: formData,
processData: false,
headers: {
Accept: "text/html,application/xhtml+xml,application/xml;q=0.9,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9",
"User-Agent": utils.getRandomPCUA(),
Host: window.location.hostname,
Origin: window.location.origin,
Referer: `${window.location.origin}/home.php?mod=spacecp&ac=avatar`
}
});
if (!response.status) {
return;
}
if (response.data.responseText.indexOf(
"window.parent.postMessage('success','*')"
) != -1) {
$confirm.close();
Qmsg.success("上传成功");
} else {
log.error("上传失败", response);
Qmsg.error(response.data.responseText, {
timeout: 6e3,
isHTML: false,
html: false
});
}
} catch (error) {
log.error(error);
} finally {
$loading.close();
}
}
}
},
mask: {
enable: true
},
width: "88vw",
height: "500px",
style: (
/*css*/
`
.avatar-container{
display: flex;
width: -webkit-fill-available;
width: -moz-available;
margin: 6px 10px;
flex-direction: column;
}
.avatar-tip{
float: left;
font-weight: bold;
}
.avatar-upload-status {
padding: 0px;
padding-left: 10px;
font-weight: bold;
width: -webkit-fill-available;
text-align: left;
font-size: small;
}
.avatar-upload-status[data-success="false"]{
color: red;
}
.avatar-upload-status[data-success="true"]{
color: green;
}
.avatar-upload {
margin: 20px 0px;
}
`
)
});
this.$el.$smallUpload = $confirm.$shadowRoot.querySelector(
".avatar-upload[data-type='small']"
);
this.$el.$middleUpload = $confirm.$shadowRoot.querySelector(
".avatar-upload[data-type='middle']"
);
this.$el.$bigUpload = $confirm.$shadowRoot.querySelector(
".avatar-upload[data-type='big']"
);
this.$el.$smallStatus = $confirm.$shadowRoot.querySelector(
".avatar-upload-status[data-type='small']"
);
this.$el.$middleStatus = $confirm.$shadowRoot.querySelector(
".avatar-upload-status[data-type='middle']"
);
this.$el.$bigStatus = $confirm.$shadowRoot.querySelector(
".avatar-upload-status[data-type='big']"
);
this.setUploadChangeEvent(
this.$el.$smallUpload,
this.$el.$smallStatus,
this.$data.avatarInfo.small,
() => {
this.$upload.small = true;
}
);
this.setUploadChangeEvent(
this.$el.$middleUpload,
this.$el.$middleStatus,
this.$data.avatarInfo.middle,
() => {
this.$upload.middle = true;
}
);
this.setUploadChangeEvent(
this.$el.$bigUpload,
this.$el.$bigStatus,
this.$data.avatarInfo.big,
() => {
this.$upload.big = true;
}
);
},
/**
* 设置文件改变事件
*/
setUploadChangeEvent($file, $status, sizeInfo, successCallBack) {
domUtils.on($file, "change", (event) => {
var _a2;
if (!((_a2 = $file.files) == null ? void 0 : _a2.length)) {
return;
}
domUtils.text($status, "🤡获取文件信息中...");
$status.removeAttribute("data-success");
let uploadImageFile = $file.files[0];
let fileSize = uploadImageFile.size;
let $image = new Image();
let reader = new FileReader();
reader.readAsDataURL(uploadImageFile);
reader.onload = function(response) {
$image.src = response.target.result;
$image.onload = function() {
if ($image.width > sizeInfo.width || $image.height > sizeInfo.height) {
$file.value = "";
$status.setAttribute("data-success", "false");
domUtils.text(
$status,
`🤡校验失败 ==> 图片尺寸不符合,宽:${$image.width} 高:${$image.height}`
);
return;
}
if (fileSize > MTDyncmicAvatar.$data.avatarInfo.maxSize) {
$file.value = "";
$status.setAttribute("data-success", "false");
domUtils.text(
$status,
`🤡校验失败 ==> 图片大小不符合:${fileSize}byte,限制最大:${MTDyncmicAvatar.$data.avatarInfo.maxSize}byte`
);
return;
}
$status.setAttribute("data-success", "true");
domUtils.text(
$status,
`🤣 通过 宽:${$image.width} 高:${$image.height} 大小(byte):${fileSize}`
);
successCallBack();
};
};
});
},
/**
* 获取上传地址
*/
async getUploadUrl() {
let response = await httpx.get("/home.php?mod=spacecp&ac=avatar", {
headers: {
"User-Agent": utils.getRandomPCUA()
}
});
if (!response.status) {
return;
}
if (utils.isNull(response.data.responseText)) {
Qmsg.error("动态头像:获取上传地址失败");
return;
}
let dataMatch = response.data.responseText.match(
/var[\s]*data[\s]*=[\s]*"(.+?)"/
);
if (dataMatch == null || dataMatch.length != 2) {
Qmsg.error("动态头像:获取变量data失败");
return;
}
let data = dataMatch[dataMatch.length - 1];
let data_split = data.split(",");
let uploadUrl = data_split[data_split.indexOf("src") + 1].replace(
"images/camera.swf?inajax=1",
"index.php?m=user&a=rectavatar&base64=yes"
);
log.info(`上传地址:` + uploadUrl);
return uploadUrl;
}
};
const Component_Common = {
id: "component-common",
title: "通用",
forms: [
{
text: "",
type: "forms",
forms: [
{
text: "Toast配置",
type: "deepMenu",
forms: [
{
text: "",
type: "forms",
forms: [
UISelect(
"Toast位置",
"qmsg-config-position",
"bottom",
[
{
value: "topleft",
text: "左上角"
},
{
value: "top",
text: "顶部"
},
{
value: "topright",
text: "右上角"
},
{
value: "left",
text: "左边"
},
{
value: "center",
text: "中间"
},
{
value: "right",
text: "右边"
},
{
value: "bottomleft",
text: "左下角"
},
{
value: "bottom",
text: "底部"
},
{
value: "bottomright",
text: "右下角"
}
],
(event, isSelectValue, isSelectText) => {
log.info("设置当前Qmsg弹出位置" + isSelectText);
},
"Toast显示在页面九宫格的位置"
),
UISelect(
"最多显示的数量",
"qmsg-config-maxnums",
3,
[
{
value: 1,
text: "1"
},
{
value: 2,
text: "2"
},
{
value: 3,
text: "3"
},
{
value: 4,
text: "4"
},
{
value: 5,
text: "5"
}
],
void 0,
"限制Toast显示的数量"
),
UISwitch(
"逆序弹出",
"qmsg-config-showreverse",
false,
void 0,
"修改Toast弹出的顺序"
)
]
}
]
},
{
text: "Cookie配置",
type: "deepMenu",
forms: [
{
text: "",
type: "forms",
forms: [
UISwitch(
"启用",
"httpx-use-cookie-enable",
false,
void 0,
"启用后,将根据下面的配置进行添加cookie"
),
UISwitch(
"使用document.cookie",
"httpx-use-document-cookie",
false,
void 0,
"自动根据请求的域名来设置对应的cookie"
),
UITextArea(
"bbs.binmt.cc",
"httpx-cookie-bbs.binmt.cc",
"",
void 0,
void 0,
"Cookie格式:xxx=xxxx;xxx=xxxx"
)
]
}
]
}
]
},
{
text: "",
type: "forms",
forms: [
{
text: "功能",
type: "deepMenu",
forms: [
{
text: "",
type: "forms",
forms: [
UISwitch(
"链接文本转超链接",
"mt-link-text-to-hyperlink",
true,
void 0,
"自动把页面中的链接文本转换为超链接"
),
UISwitch(
"显示用户UID",
"mt-show-user-uid",
true,
void 0,
"格式为UID:xxx"
),
UISwitch(
"小窗模式",
"mt-small-window",
true,
void 0,
"开启后点击帖子右侧区域为小窗打开"
)
]
}
]
},
{
text: "额外菜单项",
type: "deepMenu",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"小黑屋",
"mt-black-home",
true,
void 0,
"将会在左侧面板添加【小黑屋】菜单"
),
UISwitch(
"在线用户",
"mt-online-user",
true,
void 0,
"将会在左侧面板添加【在线用户】菜单"
),
UISwitch(
"付费主题白嫖提醒",
"mt-post-paidThemePost",
true,
void 0,
"将会在左侧面板添加【付费主题白嫖提醒】菜单"
),
UISwitch(
"我的屏蔽",
"mt-ownBlock",
true,
void 0,
"将会在左侧面板添加【我的屏蔽】菜单"
),
UISwitch(
"商品上架提醒",
"mt-productListingReminder",
true,
void 0,
"将会在左侧面板添加【商品上架提醒】菜单"
),
UISwitch(
"自定义用户标签",
"mt-customizeUserLabels",
true,
void 0,
"将会在左侧面板添加【自定义用户标签】菜单"
),
UISwitch(
"评论过滤器",
"mt-post-comment-filter",
true,
void 0,
"将会在左侧面板添加【评论过滤器】菜单"
)
]
}
]
},
{
text: "头像",
type: "deepMenu",
forms: [
{
text: "<a href='https://ezgif.com/resize' target='_blank'>Resize Image</a>",
type: "forms",
forms: [
UIOwn(($li) => {
let $left = domUtils.createElement("div", {
className: "pops-panel-item-left-text",
innerHTML: (
/*html*/
`
<p class="pops-panel-item-left-main-text">头像(有缓存)</p>
<p class="pops-panel-item-left-desc-text">小、中、大</p>
`
)
});
let $right = domUtils.createElement("div", {
className: "pops-panel-avatar-img",
innerHTML: (
/*html*/
`
<img
src="/uc_server/avatar.php?uid=${MTUtils.getCurrentUID()}&size=small"
class="avatar-img" data-size="small">
<img
src="/uc_server/avatar.php?uid=${MTUtils.getCurrentUID()}&size=middle"
class="avatar-img" data-size="middle">
<img
src="/uc_server/avatar.php?uid=${MTUtils.getCurrentUID()}&size=big"
class="avatar-img" data-size="big">
`
)
});
let $style = domUtils.createElement("style", {
innerHTML: (
/*css*/
`
.avatar-img {
width: 30px;
height: 30px;
border-radius: 50%;
overflow: hidden;
}
`
)
});
$right.querySelector(
".avatar-img[data-size='small']"
);
$right.querySelector(
".avatar-img[data-size='middle']"
);
$right.querySelector(
".avatar-img[data-size='big']"
);
$li.appendChild($left);
$li.appendChild($right);
$li.appendChild($style);
return $li;
}),
UIOwn(($li) => {
let $left = domUtils.createElement("div", {
className: "pops-panel-item-left-text",
innerHTML: (
/*html*/
`
<p class="pops-panel-item-left-main-text">头像</p>
<p class="pops-panel-item-left-desc-text">小、中、大</p>
`
)
});
let $right = domUtils.createElement("div", {
className: "pops-panel-avatar-img",
innerHTML: (
/*html*/
`
<img
src="/uc_server/avatar.php?uid=${MTUtils.getCurrentUID()}&size=small&ts=${Date.now()}"
class="avatar-img" data-size="small">
<img
src="/uc_server/avatar.php?uid=${MTUtils.getCurrentUID()}&size=middle&ts=${Date.now()}"
class="avatar-img" data-size="middle">
<img
src="/uc_server/avatar.php?uid=${MTUtils.getCurrentUID()}&size=big&ts=${Date.now()}"
class="avatar-img" data-size="big">
`
)
});
$li.appendChild($left);
$li.appendChild($right);
return $li;
}),
UIButton(
"修改头像",
`可以上传gif图片,注意图片最大限制为${Utils.formatByteToSize(
MTDyncmicAvatar.$data.avatarInfo.maxSize
)}`,
"上传",
void 0,
false,
false,
"primary",
() => {
MTDyncmicAvatar.showView();
}
)
]
}
]
}
]
}
]
};
const ElementUtils = {
/**
* 在左侧菜单注册功能
*/
registerLeftMenu(config) {
utils.waitNode(
".comiis_sidenv_box .sidenv_li .comiis_left_Touch",
1e4
).then(($leftTouch) => {
if (!$leftTouch) {
log.error("注册左侧面板菜单失败,原因:该元素不存在");
return;
}
let $setting = domUtils.createElement("li", {
className: "comiis_left_Touch",
innerHTML: (
/*html*/
`
<a href="javascript:;" class="comiis_left_Touch">
<i class="comiis_font"></i>
${config.name}
</a>
`
)
});
let $icon = $setting.querySelector(".comiis_font");
if (typeof config.style === "string") {
$icon.style.cssText = config.style;
}
if (typeof config.icon === "string") {
$icon.innerHTML = config.icon;
}
if (typeof config.iconColor === "string") {
$icon.style.color = config.iconColor;
}
if (typeof config.iconSize === "string") {
$icon.style.fontSize = config.iconSize;
}
domUtils.on($setting, "click", (event) => {
utils.preventEvent(event);
if (typeof config.callback === "function") {
config.callback();
}
});
domUtils.append($leftTouch, $setting);
});
},
/**
* 导读中最新、热门、精华、回复、抢沙发的各个帖子【list】
*/
comiisForumList: () => {
return document.querySelectorAll("li.forumlist_li");
},
/**
* 帖子内评论,包括帖子内容主体,第一个就是主体【list】
*/
comiisPostli: () => {
return document.querySelectorAll(
"div.comiis_postli.comiis_list_readimgs.nfqsqi"
);
},
/**
* 帖子内评论,包括帖子内容主体,第一个就是主体【list】
*/
comiisMmlist: () => {
return document.querySelectorAll(".comiis_mmlist");
}
};
const UIInput = function(text, key, defaultValue, description, changeCallBack, placeholder = "", isNumber, isPassword, afterAddToUListCallBack) {
let result = {
text,
type: "input",
isNumber: Boolean(isNumber),
isPassword: Boolean(isPassword),
props: {},
attributes: {},
description,
afterAddToUListCallBack,
getValue() {
return this.props[PROPS_STORAGE_API].get(key, defaultValue);
},
callback(event, value, valueAsNumber) {
this.props[PROPS_STORAGE_API].set(
key,
isNumber ? valueAsNumber : value
);
},
placeholder
};
Reflect.set(result.attributes, ATTRIBUTE_KEY, key);
Reflect.set(result.attributes, ATTRIBUTE_DEFAULT_VALUE, defaultValue);
Reflect.set(result.props, PROPS_STORAGE_API, {
get(key2, defaultValue2) {
return PopsPanel.getValue(key2, defaultValue2);
},
set(key2, value) {
PopsPanel.setValue(key2, value);
}
});
return result;
};
const optimizationCSS$1 = '#comiis_foot_menu_beautify {\r\n position: fixed;\r\n display: inline-flex;\r\n z-index: 90;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n width: 100%;\r\n height: 48px;\r\n overflow: hidden;\r\n align-content: center;\r\n justify-content: center;\r\n align-items: center;\r\n}\r\n#comiis_foot_menu_beautify_big {\r\n position: fixed;\r\n display: inline-flex;\r\n flex-direction: column;\r\n z-index: 92;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n width: 100%;\r\n min-height: 120px;\r\n overflow: hidden;\r\n align-content: center;\r\n justify-content: center;\r\n align-items: center;\r\n}\r\n#comiis_foot_menu_beautify input.bg_e.f_c::-webkit-input-placeholder {\r\n padding-left: 10px;\r\n color: #999;\r\n}\r\n#comiis_foot_menu_beautify input.bg_e.f_c::-moz-input-placeholder {\r\n padding-left: 10px;\r\n color: #999;\r\n}\r\n#comiis_foot_menu_beautify .reply_area ul li a {\r\n display: block;\r\n width: 22px;\r\n height: 22px;\r\n padding: 4px 8px;\r\n margin: 8px 0;\r\n position: relative;\r\n}\r\n#comiis_foot_menu_beautify .reply_area ul {\r\n display: inline-flex;\r\n align-content: center;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n#comiis_foot_menu_beautify .reply_area,\r\n#comiis_foot_menu_beautify .reply_area ul {\r\n width: 100%;\r\n}\r\n#comiis_foot_menu_beautify .reply_area li a i {\r\n width: 22px;\r\n height: 22px;\r\n line-height: 22px;\r\n font-size: 22px;\r\n}\r\n#comiis_foot_menu_beautify .reply_area li a span {\r\n position: absolute;\r\n display: block;\r\n font-size: 10px;\r\n height: 14px;\r\n line-height: 14px;\r\n padding: 0 6px;\r\n right: -8px;\r\n top: 4px;\r\n overflow: hidden;\r\n border-radius: 20px;\r\n}\r\n#comiis_foot_menu_beautify li[data-attr="回帖"] input {\r\n border: transparent;\r\n border-radius: 15px;\r\n height: 30px;\r\n width: 100%;\r\n}\r\n#comiis_foot_menu_beautify_big .comiis_smiley_box {\r\n padding: 6px 6px 0;\r\n}\r\n#comiis_foot_menu_beautify_big .reply_area {\r\n margin: 10px 0 5px 0;\r\n}\r\n#comiis_foot_menu_beautify_big .reply_area ul {\r\n display: inline-flex;\r\n align-content: center;\r\n justify-content: center;\r\n align-items: flex-end;\r\n}\r\n#comiis_foot_menu_beautify_big li[data-attr="回帖"] {\r\n width: 75vw;\r\n margin-right: 15px;\r\n}\r\n#comiis_foot_menu_beautify_big .reply_user_content {\r\n width: 75vw;\r\n word-wrap: break-word;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n margin: 8px 10px;\r\n}\r\n#comiis_foot_menu_beautify_big li[data-attr="发表"] .fastpostform_new {\r\n text-align: center;\r\n margin-bottom: 28px;\r\n}\r\n#comiis_foot_menu_beautify_big li[data-attr="发表"] .fastpostform_new i {\r\n font-size: 22px;\r\n}\r\n#comiis_foot_menu_beautify_big li[data-attr="发表"] input {\r\n width: 60px;\r\n height: 30px;\r\n border: transparent;\r\n color: #fff;\r\n background: #d1c9fc;\r\n border-radius: 30px;\r\n margin-bottom: 6px;\r\n}\r\n#comiis_foot_menu_beautify_big li[data-attr="发表"] input[data-text="true"] {\r\n background: #7a61fb;\r\n}\r\n#comiis_foot_menu_beautify_big li[data-attr="回帖"] textarea {\r\n padding: 10px 10px 10px 10px;\r\n border: transparent;\r\n border-radius: 6px;\r\n min-height: 70px;\r\n max-height: 180px;\r\n background: #e9e8ec;\r\n overflow-y: auto;\r\n width: -webkit-fill-available;\r\n width: -moz-available;\r\n}\r\n#comiis_foot_menu_beautify .reply_area li[data-attr="回帖"] {\r\n width: 65%;\r\n margin: 0 3%;\r\n text-align: center;\r\n}\r\n#comiis_foot_menu_beautify .reply_area li:not(first-child) {\r\n width: 7%;\r\n text-align: -webkit-center;\r\n text-align: center;\r\n}\r\n#comiis_foot_menu_beautify_big .other_area {\r\n width: 100%;\r\n text-align: center;\r\n}\r\n#comiis_foot_menu_beautify_big .other_area .menu_icon a {\r\n margin: 0 20px;\r\n}\r\n#comiis_foot_menu_beautify_big .other_area i {\r\n font-size: 24px;\r\n}\r\n#comiis_foot_menu_beautify_big .other_area #comiis_insert_ubb_tab i {\r\n font-size: 16px;\r\n}\r\n#comiis_foot_menu_beautify_big .other_area .menu_body {\r\n background: #f4f4f4;\r\n}\r\n#comiis_foot_menu_beautify_big\r\n .other_area\r\n .menu_body\r\n .comiis_smiley_box\r\n .comiis_optimization {\r\n max-height: 140px;\r\n overflow-y: auto;\r\n flex-direction: column;\r\n}\r\n#comiis_foot_menu_beautify_big\r\n .other_area\r\n .menu_body\r\n .comiis_smiley_box\r\n .bqbox_t {\r\n background: #fff;\r\n}\r\n#comiis_foot_menu_beautify_big\r\n .other_area\r\n .menu_body\r\n .comiis_smiley_box\r\n .bqbox_t\r\n ul#comiis_smilies_key\r\n li\r\n a.bg_f.b_l.b_r {\r\n background: #f4f4f4 !important;\r\n}\r\n#comiis_foot_menu_beautify_big\r\n .menu_body\r\n #comiis_pictitle_tab\r\n #comiis_pictitle_key {\r\n display: -webkit-box;\r\n top: 0;\r\n left: 0;\r\n height: 42px;\r\n line-height: 42px;\r\n overflow: hidden;\r\n overflow-x: auto;\r\n}\r\n#comiis_foot_menu_beautify_big\r\n .menu_body\r\n #comiis_pictitle_tab\r\n #comiis_pictitle_key\r\n li {\r\n padding: 0 10px;\r\n}\r\n#comiis_foot_menu_beautify_big\r\n .menu_body\r\n #comiis_insert_ubb_tab\r\n .comiis_input_style,\r\n#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab .comiis_upbox {\r\n height: 140px;\r\n overflow-y: auto;\r\n flex-direction: column;\r\n}\r\n#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab #filedata_hello,\r\n#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab #filedata_kggzs,\r\n#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab #filedata_mt,\r\n#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab #filedata_z4a {\r\n display: none;\r\n}\r\n@media screen and (max-width: 350px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 14.5%;\r\n }\r\n}\r\n@media screen and (min-width: 350px) and (max-width: 400px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 12.5%;\r\n }\r\n}\r\n@media screen and (min-width: 400px) and (max-width: 450px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 11%;\r\n }\r\n}\r\n@media screen and (min-width: 450px) and (max-width: 500px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 10%;\r\n }\r\n}\r\n@media screen and (min-width: 500px) and (max-width: 550px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 9.5%;\r\n }\r\n}\r\n@media screen and (min-width: 550px) and (max-width: 600px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 9%;\r\n }\r\n}\r\n@media screen and (min-width: 600px) and (max-width: 650px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 8.5%;\r\n }\r\n}\r\n@media screen and (min-width: 650px) and (max-width: 700px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 8%;\r\n }\r\n}\r\n@media screen and (min-width: 700px) and (max-width: 750px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 7.5%;\r\n }\r\n}\r\n@media screen and (min-width: 750px) and (max-width: 800px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 7%;\r\n }\r\n}\r\n@media screen and (min-width: 800px) and (max-width: 850px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 6.5%;\r\n }\r\n}\r\n@media screen and (min-width: 850px) and (max-width: 1200px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 6%;\r\n }\r\n}\r\n@media screen and (min-width: 1200px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 4.5%;\r\n }\r\n}\r\n#imglist_settings button {\r\n font-size: 13.333px;\r\n color: #9baacf;\r\n outline: 0;\r\n border: none;\r\n height: 35px;\r\n width: 80px;\r\n border-radius: 10px;\r\n box-shadow: 0.3rem 0.3rem 0.6rem #c8d0e7, -0.2rem -0.2rem 0.5rem #fff;\r\n font-weight: 800;\r\n line-height: 40px;\r\n background: #efefef;\r\n padding: 0;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n}\r\n#imglist_settings button:active {\r\n box-shadow: inset 0.2rem 0.2rem 0.5rem #c8d0e7,\r\n inset -0.2rem -0.2rem 0.5rem #fff !important;\r\n color: #638ffb !important;\r\n}\r\n\r\n#comiis_head .header_y {\r\n display: flex;\r\n align-content: center;\r\n align-items: center;\r\n justify-content: flex-end;\r\n height: 100%;\r\n}\r\n#comiis_head .header_y input {\r\n border: transparent;\r\n background: 0 0;\r\n text-align: center;\r\n margin: 0 5px;\r\n}\r\n#comiis_head .header_y input[value="删除"] {\r\n color: #d00;\r\n}\r\n#comiis_head .header_y input[value="保存"] {\r\n color: #b0ff6a;\r\n}\r\n#comiis_head .header_y input[value="保存草稿"] {\r\n color: #f90;\r\n}\r\n#comiis_head .header_y input[value="发表"] {\r\n color: #b0ff6a;\r\n}\r\n#comiis_head .header_y input[value="回复"] {\r\n color: #b0ff6a;\r\n}\r\n#comiis_post_tab {\r\n color: #000;\r\n}\r\n#comiis_pictitle_tab #imglist input {\r\n display: none;\r\n}\r\n\r\n.comiis_post_imglist .delImg {\r\n position: absolute;\r\n top: -5px;\r\n left: -5px;\r\n}\r\n\r\n.comiis_post_imglist .p_img a {\r\n float: left;\r\n height: 36px;\r\n}\r\n#imglist .p_img a {\r\n float: left;\r\n height: 36px;\r\n}\r\n#imglist .del a {\r\n padding: 0;\r\n}\r\n';
const MTEditorSmilies = () => {
return [
{
"[呵呵]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq001.gif",
"[撇嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq002.gif",
"[色]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq003.gif",
"[发呆]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq004.gif",
"[得意]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq005.gif",
"[流泪]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq006.gif",
"[害羞]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq007.gif",
"[闭嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq008.gif",
"[睡]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq009.gif",
"[大哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq010.gif",
"[尴尬]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq011.gif",
"[发怒]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq012.gif",
"[调皮]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq013.gif",
"[呲牙]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq014.gif",
"[惊讶]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq015.gif",
"[难过]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq016.gif",
"[酷]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq017.gif",
"[冷汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq018.gif",
"[抓狂]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq019.gif",
"[吐]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq020.gif",
"[偷笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq021.gif",
"[可爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq022.gif",
"[白眼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq023.gif",
"[傲慢]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq024.gif",
"[饥饿]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq025.gif",
"[困]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq026.gif",
"[惊恐]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq027.gif",
"[流汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq028.gif",
"[憨笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq029.gif",
"[装逼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq030.gif",
"[奋斗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq031.gif",
"[咒骂]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq032.gif",
"[疑问]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq033.gif",
"[嘘]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq034.gif",
"[晕]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq035.gif",
"[折磨]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq036.gif",
"[衰]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq037.gif",
"[骷髅]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq038.gif",
"[敲打]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq039.gif",
"[再见]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq040.gif",
"[擦汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq041.gif",
"[抠鼻]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq042.gif",
"[鼓掌]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq043.gif",
"[糗大了]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq044.gif",
"[坏笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq045.gif",
"[左哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq046.gif",
"[右哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq047.gif",
"[哈欠]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq048.gif",
"[鄙视]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq049.gif",
"[委屈]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq050.gif",
"[快哭了]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq051.gif",
"[阴脸]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq052.gif",
"[亲亲]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq053.gif",
"[吓]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq054.gif",
"[可怜]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq055.gif",
"[眨眼睛]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq056.gif",
"[笑哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq057.gif",
"[dogeQQ]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq058.gif",
"[泪奔]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq059.gif",
"[无奈]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq060.gif",
"[托腮]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq061.gif",
"[卖萌]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq062.png",
"[斜眼笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq063.gif",
"[喷血]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq064.gif",
"[惊喜]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq065.gif",
"[骚扰]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq066.gif",
"[小纠结]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq067.gif",
"[我最美]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq068.gif",
"[菜刀]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq069.gif",
"[西瓜]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq070.gif",
"[啤酒]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq071.gif",
"[篮球]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq072.gif",
"[乒乓]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq073.gif",
"[咖啡]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq074.gif",
"[饭]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq075.gif",
"[猪]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq076.gif",
"[玫瑰]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq077.gif",
"[凋谢]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq078.gif",
"[示爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq079.gif",
"[爱心]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq080.gif",
"[心碎]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq081.gif",
"[蛋糕]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq082.gif",
"[闪电]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq083.gif",
"[炸弹]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq084.gif",
"[刀]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq085.gif",
"[足球]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq086.gif",
"[瓢虫]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq087.gif",
"[便便]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq088.gif",
"[月亮]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq089.gif",
"[太阳]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq090.gif",
"[礼物]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq091.gif",
"[抱抱]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq092.gif",
"[喝彩]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq93.gif",
"[祈祷]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq94.gif",
"[棒棒糖]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq95.gif",
"[药]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq96.gif",
"[赞]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq097.gif",
"[差劲]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq098.gif",
"[握手]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq099.gif",
"[胜利]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq100.gif",
"[抱拳]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq101.gif",
"[勾引]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq102.gif",
"[拳头]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq103.gif",
"[爱你]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq105.gif",
"[NO]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq106.gif",
"[OK]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq107.gif"
},
{
"[#呵呵]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_1.png",
"[#滑稽]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_10.png",
"[#吐舌]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_3.png",
"[#哈哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_2.png",
"[#啊]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_23.png",
"[#酷]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_22.png",
"[#怒]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_13.png",
"[#开心]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_39.png",
"[#汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_14.png",
"[#泪]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_16.png",
"[#黑线]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_15.png",
"[#鄙视]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_21.png",
"[#不高兴]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_12.png",
"[#真棒]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_17.png",
"[#钱]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_40.png",
"[#疑问]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_26.png",
"[#阴险]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_20.png",
"[#吐]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_34.png",
"[#咦]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_41.png",
"[#委屈]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_29.png",
"[#花心]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_6.png",
"[#呼~]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_42.png",
"[#激动]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_5.png",
"[#冷]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_43.png",
"[#可爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_4.png",
"[#What?]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_25.png",
"[#勉强]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_38.png",
"[#狂汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_24.png",
"[#酸爽]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_27.png",
"[#乖]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_8.png",
"[#雅美蝶]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_28.png",
"[#睡觉]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_31.png",
"[#惊哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_19.png",
"[#哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_44.png",
"[#笑尿]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_32.png",
"[#惊讶]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_30.png",
"[#小乖]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_7.png",
"[#喷]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_18.png",
"[#抠鼻]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_33.png",
"[#捂嘴笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_9.png",
"[#你懂的]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_11.png",
"[#犀利]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_35.png",
"[#小红脸]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_36.png",
"[#懒得理]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_37.png",
"[#爱心]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_45.png",
"[#心碎]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_46.png",
"[#玫瑰]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_47.png",
"[#礼物]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_48.png",
"[#彩虹]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_49.png",
"[#太阳]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_50.png",
"[#月亮]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_51.png",
"[#钱币]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_52.png",
"[#咖啡]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_53.png",
"[#蛋糕]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_54.png",
"[#大拇指]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_55.png",
"[#胜利]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_56.png",
"[#爱你]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_57.png",
"[#OK]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_58.png",
"[#弱]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_59.png",
"[#沙发]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_60.png",
"[#纸巾]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_61.png",
"[#香蕉]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_62.png",
"[#便便]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_63.png",
"[#药丸]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_64.png",
"[#红领巾]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_65.png",
"[#蜡烛]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_66.png",
"[#三道杠]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_67.png",
"[#音乐]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_68.png",
"[#灯泡]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_69.png"
},
{
"[doge]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/1.png",
"[doge思考]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/2.png",
"[doge再见]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/3.png",
"[doge生气]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/4.png",
"[doge气哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/5.png",
"[doge笑哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/7.png",
"[doge调皮]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/6.png",
"[doge啊哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/8.png",
"[doge原谅TA]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/9.png",
"[miao]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/10.png",
"[miao思考]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/11.png",
"[miao拜拜]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/12.png",
"[miao生气]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/13.png",
"[miao气哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/14.png",
"[二哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/15.png",
"[摊手]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/19.png",
"[w并不简单]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/20.png",
"[w滑稽]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/21.png",
"[w色]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/22.png",
"[w爱你]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/23.png",
"[w拜拜]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/24.png",
"[w悲伤]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/25.png",
"[w鄙视]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/26.png",
"[w馋嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/27.png",
"[w冷汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/28.png",
"[w打哈欠]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/29.png",
"[w打脸]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/30.png",
"[w敲打]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/31.png",
"[w生病]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/32.png",
"[w闭嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/33.png",
"[w鼓掌]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/34.png",
"[w哈哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/35.png",
"[w害羞]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/36.png",
"[w呵呵]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/37.png",
"[w黑线]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/38.png",
"[w哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/39.png",
"[w调皮]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/40.png",
"[w可爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/41.png",
"[w可怜]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/42.png",
"[w酷]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/43.png",
"[w困]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/44.png",
"[w懒得理你]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/45.png",
"[w流泪]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/46.png",
"[w怒]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/47.png",
"[w怒骂]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/48.png",
"[w钱]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/49.png",
"[w亲亲]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/50.png",
"[w傻眼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/51.png",
"[w便秘]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/52.png",
"[w失望]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/53.png",
"[w衰]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/54.png",
"[w睡觉]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/55.png",
"[w思考]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/56.png",
"[w开心]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/57.png",
"[w色舔]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/58.png",
"[w偷笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/59.png",
"[w吐]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/60.png",
"[w抠鼻]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/61.png",
"[w委屈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/62.png",
"[w笑哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/63.png",
"[w嘻嘻]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/64.png",
"[w嘘]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/65.png",
"[w阴险]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/66.png",
"[w疑问]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/67.png",
"[w抓狂]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/70.png",
"[w晕]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/69.png",
"[w右哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/68.png",
"[w左哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/71.png",
"[w肥皂]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/77.png",
"[w奥特曼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/78.png",
"[w草泥马]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/79.png",
"[w兔子]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/80.png",
"[w熊猫]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/81.png",
"[w猪头]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/82.png",
"[w→_→]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/83.png",
"[w给力]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/84.png",
"[w囧]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/85.png",
"[w萌]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/86.png",
"[w神马]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/87.png",
"[w威武]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/88.png"
}
];
};
const MTRegExp = {
/** 论坛账号的凭证 */
formhash: /formhash=(.+)&/,
/** 论坛账号的凭证 */
hash: /hash=(.+)&/,
/** 用户uid */
uid: /uid=(\d+)/,
/** 帖子内特殊字体格式 */
fontSpecial: /<font.*?>|<\/font>|<strike>|<strong>|<i>|<u>|align=".*?"|<br>[\s]*<br>[\s]*<br>/g,
/** 帖子链接的ptid参数 */
ptid: /&ptid=([\d]+)/i,
/** 帖子链接的pid参数 */
pid: /&pid=([\d]+)/i,
/** 链接的tid参数 */
tid: /&tid=([\d]+)/i
};
const GlobalImageDelete = [];
class MTEditorImageBed {
constructor(option) {
__publicField(this, "option");
__publicField(this, "$data", {
STORAGE_KEY: "mt-image-bed-upload-history"
});
this.option = option;
GlobalImageDelete.push({
id: this.option.id,
callback: this.option.delImageEvent.bind(this)
});
this.addTab();
domUtils.on(
`.comiis_post_imglist[data-chartbed="${this.option.name}"] .up_btn a`,
"click",
async (event) => {
let result = await this.option.uploadBtnClickEvent(event);
if (result) {
$(
`.comiis_post_imglist[data-chartbed="${this.option.name}"] input[type="file"]`
).click();
}
}
);
domUtils.on(
`.comiis_post_imglist[data-chartbed="${this.option.name}"] input[type="file"]`,
"change",
async (event) => {
let $file = event.target;
let clear_input = () => {
$file.value = "";
};
let upload_callback = async (uploadFiles) => {
let uploadInfo = await this.option.fileChangeEvent(
event,
uploadFiles
);
clear_input();
if (uploadInfo.success) {
uploadInfo.data.forEach((imageInfo) => {
this.addImage(imageInfo);
let $thumbImage = this.createImageBtnElement(
"插入",
imageInfo.url
);
this.setImageBtnDeleteEvent($thumbImage, imageInfo);
domUtils.append(
`.comiis_post_imglist[data-chartbed="${this.option.name}"]`,
$thumbImage
);
});
}
};
if ($file.files && $file.files.length) {
let chooseImage = $file.files;
if (PopsPanel.getValue("mt-image-bed-watermark-enable")) {
let $loading = Qmsg.loading("处理水印中...");
let needUploadImageArray = [];
let needUploadImageFileArray = [];
await Promise.all(
Array.from($file.files).map(async (item, index) => {
if (item.type === "image/gif") {
let image_base64 = await utils.parseFileToBase64(item);
needUploadImageArray.push(image_base64);
needUploadImageFileArray.push(item);
} else {
Qmsg.info(`添加水印 ${index + 1}/${chooseImage.length}`);
var watermark = new window.Watermark();
await watermark.setFile(item);
watermark.addText({
text: [
PopsPanel.getValue("mt-image-bed-watermark-text")
],
color: PopsPanel.getValue(
"mt-image-bed-watermark-text-color"
),
fontSize: PopsPanel.getValue(
"mt-image-bed-watermark-font-size"
),
globalAlpha: PopsPanel.getValue(
"mt-image-bed-watermark-font-opacity"
),
xMoveDistance: PopsPanel.getValue(
"mt-image-bed-watermark-left-right-margin"
),
yMoveDistance: PopsPanel.getValue(
"mt-image-bed-watermark-top-bottom-margin"
),
rotateAngle: PopsPanel.getValue(
"mt-image-bed-watermark-rotate"
)
});
needUploadImageArray.push(watermark.render("png"));
needUploadImageFileArray.push(
utils.parseBase64ToFile(
watermark.render("png"),
"WaterMark_" + item.name
)
);
}
})
);
$loading.close();
chooseImage = needUploadImageFileArray;
if (PopsPanel.getValue(
"mt-image-bed-watermark-autoAddWaterMark"
)) {
await upload_callback(chooseImage);
} else {
__pops.confirm({
title: {
text: "水印预览",
position: "center"
},
content: {
text: (
/*html*/
`
<div class="upload-image-water">${needUploadImageArray.map((item) => {
return (
/*html*/
`<img src="${item}" crossoriginNew="anonymous" loading="lazy">`
);
}).join("\n")}
</div>
`
),
html: true
},
btn: {
ok: {
text: "继续上传",
async callback(eventDetails, event2) {
eventDetails.close();
await upload_callback(chooseImage);
}
},
close: {
callback(details, event2) {
details.close();
clear_input();
}
},
cancel: {
callback(eventDetails, event2) {
eventDetails.close();
clear_input();
}
}
},
drag: true,
width: "88vw",
height: "80vh",
style: (
/*css*/
`
.upload-image-water {
}
.upload-image-water img{
width: 100%;
}
`
)
});
}
} else {
await upload_callback(chooseImage);
}
}
}
);
}
/**
* 添加图床标签
*/
addTab() {
let $picture_key = $("#comiis_pictitle_key");
let $history = $picture_key.querySelector(
"a[data-type='history']"
);
let tabHTML = (
/*html*/
`
<li>
<a href="javascript:;" class="comiis-picture-tab" data-type="image-bed">${this.option.name}</a>
</li>
`
);
if (!$history) {
let $history_parent = domUtils.createElement("li");
$history = domUtils.createElement(
"a",
{
href: "javascript:;",
className: "comiis-picture-tab",
innerHTML: `历史图片`
},
{ "data-type": "history" }
);
domUtils.on($history, "click", () => {
this.initHistoryUploadImageList();
});
domUtils.append($history_parent, $history);
domUtils.append($picture_key, $history_parent);
}
domUtils.before($history.parentElement, tabHTML);
let $box = $("#comiis_pictitle_tab .bqbox_t");
let $historyBox = Array.from(
$$("#comiis_pictitle_tab .comiis_upbox")
).find((item) => Boolean(item.querySelector("#imglist_history")));
if (!$historyBox) {
$historyBox = domUtils.createElement(
"div",
{
className: "comiis_upbox bg_f cl",
innerHTML: (
/*html*/
`
<ul class="comiis_post_imglist cl" id="imglist_history">
</ul>
`
)
},
{
style: "display: none;"
}
);
domUtils.before($box, $historyBox);
$historyBox = Array.from(
$$("#comiis_pictitle_tab .comiis_upbox")
).find((item) => Boolean(item.querySelector("#imglist_history")));
}
domUtils.before(
$historyBox,
/*html*/
`
<div class="comiis_upbox bg_f cl" style="display: none;">
<ul class="comiis_post_imglist cl" data-chartbed="${this.option.name}">
<li class="up_btn">
<a href="javascript:;" class="bg_e b_ok f_d">
<i class="comiis_font"></i>
</a>
<input type="file" name="Filedata" accept="image/*" multiple="" style="display: none;">
</li>
</ul>
</div>
`
);
}
/**
* 创建图片缩略图,用于插入
*/
createImageBtnElement(labelName, url) {
let $li = domUtils.createElement("li", {
innerHTML: (
/*html*/
`
<span class="delImg" data-id="${this.option.id}" data-name="${this.option.name}">
<a href="javascript:;">
<i class="comiis_font f_g"></i>
</a>
</span>
<span class="charu f_f">${labelName}</span>
<span class="p_img">
<a href="javascript:;"
onclick="comiis_addsmilies('[img]${url}[/img]')">
<img style="height:54px;width:54px;"
title="${url}"
src="${url}"
loading="lazy"
class="vm b_ok"></a>
</span>
`
)
});
return $li;
}
/**
* 初始化历史上传图片列表
*/
initHistoryUploadImageList() {
let $imglist_history = $(
"#comiis_pictitle_tab #imglist_history"
);
$imglist_history.innerHTML = "";
let $fragment = document.createDocumentFragment();
this.getAllImage().forEach((item) => {
let $thumbImage = this.createImageBtnElement(
item.labelName,
item.data.url
);
this.setHistoryImageBtnDeleteEvent($thumbImage, item);
$fragment.appendChild($thumbImage);
});
$imglist_history.appendChild($fragment);
}
/**
* 设置图片缩略图的删除事件
*/
setImageBtnDeleteEvent($ele, data) {
let $delImg = $ele.querySelector(".delImg");
domUtils.on($delImg, "click", async (event) => {
let result = await this.option.delImageEvent(event, data);
if (result) {
let deleteStorageStatus = this.deleteImage(this.option.id, data);
if (deleteStorageStatus) {
domUtils.remove($ele);
}
}
});
}
/**
* 设置历史图片图片缩略图的删除事件
*/
setHistoryImageBtnDeleteEvent($ele, data) {
let $delImg = $ele.querySelector(".delImg");
domUtils.on($delImg, "click", async (event) => {
let findValue = GlobalImageDelete.find((item) => item.id === data.id);
if (!findValue) {
return;
}
let result = await findValue.callback(event, data.data);
if (result) {
let deleteStorageStatus = this.deleteImage(data.id, data.data);
if (deleteStorageStatus) {
domUtils.remove($ele);
}
}
});
}
/**
* 存储历史记录图片
*/
addImage(info) {
let allData = _GM_getValue(this.$data.STORAGE_KEY, []);
allData.push({
id: this.option.id,
name: this.option.name,
labelName: this.option.labelName,
data: info
});
_GM_setValue(this.$data.STORAGE_KEY, allData);
}
/**
* 查询所有上传的历史图片
*/
getAllImage() {
let allData = _GM_getValue(this.$data.STORAGE_KEY, []);
return allData;
}
/**
* 删除历史记录图片
*/
deleteImage(id, data) {
let allData = this.getAllImage();
let findIndex = allData.findIndex(
(item) => item.id === id && JSON.stringify(item.data) === JSON.stringify(data)
);
if (findIndex != -1) {
allData.splice(findIndex, 1);
_GM_setValue(this.$data.STORAGE_KEY, allData);
return true;
} else {
return false;
}
}
}
const MTEditorImageBed_Hello = {
$data: {
get account() {
return PopsPanel.getValue("mt-image-bed-hello-account");
},
get password() {
return PopsPanel.getValue("mt-image-bed-hello-password");
},
get token() {
return PopsPanel.getValue("mt-image-bed-hello-token");
}
},
$code: {
401: "未登录或授权失败",
403: "管理员关闭了接口功能或没有该接口权限",
429: "超出请求配额,请求受限",
500: "服务端出现异常"
},
$config: {
base_url: "https://www.helloimg.com/api/v1",
TAG: "Hello图床:"
},
$tabConfig: {
id: "www.helloimg.com",
name: "Hello图床",
labelName: "hello"
},
init() {
const that = this;
new MTEditorImageBed({
id: this.$tabConfig.id,
name: this.$tabConfig.name,
labelName: this.$tabConfig.labelName,
async uploadBtnClickEvent(event) {
return await that.checkLogin();
},
async fileChangeEvent(event, fileList) {
let uploadList = [];
let $loading = Qmsg.loading("上传中...");
let flag = true;
for (let index = 0; index < Array.from(fileList).length; index++) {
const file = Array.from(fileList)[index];
let result = await that.uploadImage(file);
if (result) {
uploadList.push({
url: result.data.links.url,
data: result.data
});
flag = flag && true;
} else {
flag = flag && false;
}
}
$loading.close();
return {
success: flag,
data: uploadList
};
},
storageSaveCallBack(data) {
return data.data;
},
async delImageEvent(event, data) {
let isLogin = await that.checkLogin();
if (isLogin) {
let $loading = Qmsg.loading("正在删除图片...");
let deleteResult = await that.deleteImage(data.data.key) ?? false;
$loading.close();
return deleteResult;
} else {
return false;
}
}
});
},
/**
* 检测是否登录
*/
async checkLogin() {
if (!this.$data.account) {
Qmsg.error(`${this.$config.TAG}请先配置账号`);
return false;
}
if (!this.$data.password) {
Qmsg.error(`${this.$config.TAG}请先配置密码`);
return false;
}
if (!this.$data.token) {
Qmsg.error(`${this.$config.TAG}请先配置token`);
return false;
}
return true;
},
/**
* 上传图片
* @param imageFile
*/
async uploadImage(imageFile) {
let formData = new FormData();
formData.append("file", imageFile);
formData.append("permission", "0");
formData.append("strategy_id", "0");
formData.append("album_id", "0");
let response = await httpx.post(`${this.$config.base_url}/upload`, {
data: formData,
headers: {
Accept: "application/json",
Authorization: `Bearer ${this.$data.token}`,
"User-Agent": utils.getRandomPCUA(),
Referer: `${this.$config.base_url}/`,
Origin: this.$config.base_url
},
allowInterceptConfig: false
});
if (!response.status) {
log.error(response);
Qmsg.error(this.$config.TAG + "网络异常,上传图片失败");
return;
}
if (response.data.status in this.$code) {
log.error(response);
Qmsg.error(this.$config.TAG + this.$code[response.data.status]);
return;
}
let data = utils.toJSON(response.data.responseText);
log.info(data);
if (!data.status) {
Qmsg.error(this.$config.TAG + data.message);
return;
}
Qmsg.success(this.$config.TAG + "上传成功");
let file_reader = new FileReader();
file_reader.readAsDataURL(imageFile);
return await new Promise((resolve) => {
file_reader.onload = function() {
let imageUri = this.result;
let result = {
imageUri,
data: data.data
};
resolve(result);
};
});
},
/**
* 删除图片
* @param imageKey 删除的key
*/
async deleteImage(imageKey) {
let response = await httpx.delete(
this.$config.base_url + "/images/" + imageKey,
{
timeout: 15e3,
headers: {
Accept: "application/json",
Authorization: `Bearer ${this.$data.token}`,
"User-Agent": utils.getRandomPCUA(),
Referer: `${this.$config.base_url}/`,
Origin: this.$config.base_url
},
allowInterceptConfig: false
}
);
if (response.data.status in this.$code) {
Qmsg.error(this.$config.TAG + this.$code[response.data.status]);
return false;
}
let data = utils.toJSON(response.data.responseText);
if (!data.status) {
Qmsg.error(this.$config.TAG + data.message);
return false;
}
Qmsg.success(this.$config.TAG + "删除成功");
return true;
}
};
const MTEditorImageBed_MT = {
$data: {
csrf_token: null
},
$config: {
TAG: "MT图床:",
base_url: "https://img.binmt.cc"
},
$tabConfig: {
id: "img.binmt.cc",
name: "MT图床",
labelName: "mt"
},
init() {
const that = this;
new MTEditorImageBed({
id: this.$tabConfig.id,
name: this.$tabConfig.name,
labelName: this.$tabConfig.labelName,
async uploadBtnClickEvent(event) {
return await that.checkLogin();
},
async fileChangeEvent(event, fileList) {
let uploadList = [];
let $loading = Qmsg.loading("上传中...");
let flag = true;
for (let index = 0; index < Array.from(fileList).length; index++) {
const file = Array.from(fileList)[index];
let result = await that.uploadImage(file);
if (result) {
uploadList.push({
url: result.data.links.url,
data: result.data
});
flag = flag && true;
} else {
flag = flag && false;
}
}
$loading.close();
return {
success: flag,
data: uploadList
};
},
storageSaveCallBack(data) {
return data.data;
},
async delImageEvent(event, data) {
return true;
}
});
},
/**
* 检测是否登录
*/
async checkLogin() {
if (!this.$data.csrf_token) {
let $loading = Qmsg.loading("正在获取CSRF Token中...");
let csrf_token = await this.getCSRFToken();
$loading.close();
if (!csrf_token) {
return false;
}
this.$data.csrf_token = csrf_token;
}
return true;
},
/**
* 获取MT图床的CSRF参数
*/
async getCSRFToken() {
var _a2;
let response = await httpx.get(this.$config.base_url, {
allowInterceptConfig: false,
headers: {
"User-Agent": utils.getRandomPCUA(),
Referer: this.$config.base_url + "/",
Origin: this.$config.base_url
}
});
if (!response.status) {
Qmsg.error(this.$config.TAG + "获取CSRF Token失败,网络异常");
return;
}
let doc = domUtils.parseHTML(response.data.responseText, true, true);
let metaCSRFToken = (_a2 = doc.querySelector('meta[name="csrf-token"]')) == null ? void 0 : _a2.getAttribute("content");
if (!metaCSRFToken) {
return;
}
log.info("获取的CSRF token:", metaCSRFToken);
Qmsg.success(this.$config.TAG + "获取CSRF Token成功");
return metaCSRFToken;
},
/**
* 上传图片
* @param imageFile
*/
async uploadImage(imageFile) {
let formData = new FormData();
formData.append("strategy_id", "2");
formData.append("file", imageFile);
let response = await httpx.post(`${this.$config.base_url}/upload`, {
data: formData,
headers: {
Accept: "application/json, text/javascript, */*; q=0.01",
"User-Agent": utils.getRandomAndroidUA(),
Origin: this.$config.base_url,
pragma: "no-cache",
"Accept-Encoding": "gzip, deflate, br",
"Accept-Language": "zh-CN,zh;q=0.9,en;q=0.8,en-GB;q=0.7,en-US;q=0.6",
Referer: this.$config.base_url + "/",
Pragma: "no-cache",
"x-csrf-token": this.$data.csrf_token,
"X-Requested-With": "XMLHttpRequest"
},
allowInterceptConfig: false
});
if (!response.status) {
log.error(response);
Qmsg.error(this.$config.TAG + "网络异常,上传图片失败");
return;
}
let data = utils.toJSON(response.data.responseText);
log.info(data);
if (!data.status) {
log.error(response);
Qmsg.error(this.$config.TAG + data.message || JSON.stringify(data));
return;
}
Qmsg.success(this.$config.TAG + "上传成功");
let file_reader = new FileReader();
file_reader.readAsDataURL(imageFile);
return await new Promise((resolve) => {
file_reader.onload = function() {
let imageUri = this.result;
let result = {
imageUri,
data: data.data
};
resolve(result);
};
});
}
};
const MTQuickUBB = () => {
return {
rainbow1: {
key: "转普通彩虹",
value: "",
isFunc: true,
num: 1
},
rainbow2: {
key: "转黑白彩虹",
value: "",
isFunc: true,
num: 2
},
rainbow3: {
key: "转黑红彩虹",
value: "",
isFunc: true,
num: 3
},
rainbow4: {
key: "转蓝绿彩虹",
value: "",
isFunc: true,
num: 4
},
size: {
key: "大小",
value: "[size=][/size]",
tagL: "=",
tagR: "]",
L: "[size=]",
R: "[/size]",
cursorL: "[size=",
cursorLength: 6,
quickUBBReplace: "[size=14]replace[/size]"
},
color: {
key: "颜色",
value: "[color=][/color]",
tagL: "=",
tagR: "]",
L: "[color=]",
R: "[/color]",
cursorL: "[color=",
cursorLength: 7,
quickUBBReplace: "[color=#000]replace[/color]"
},
b: {
key: "加粗",
value: "[b][/b]",
tagL: "]",
tagR: "[",
L: "[b]",
R: "[/b]",
cursorR: "[/b]",
cursorLength: 4,
quickUBBReplace: "[b]replace[/b]"
},
u: {
key: "下划线",
value: "[u][/u]",
tagL: "]",
tagR: "[",
L: "[u]",
R: "[/u]",
cursorR: "[/u]",
cursorLength: 4,
quickUBBReplace: "[u]replace[/u]"
},
i: {
key: "倾斜",
value: "[i][/i]",
tagL: "]",
tagR: "[",
L: "[i]",
R: "[/i]",
cursorR: "[/i]",
cursorLength: 4,
quickUBBReplace: "[i]replace[/i]"
},
s: {
key: "中划线",
value: "[s][/s]",
tagL: "]",
tagR: "[",
L: "[s]",
R: "[/s]",
cursorR: "[/s]",
cursorLength: 4,
quickUBBReplace: "[s]replace[/s]"
},
lineFeed: {
key: "换行",
value: "[*]",
L: "",
R: "[*]",
cursorL: "[*]",
cursorLength: 3,
quickUBBReplace: "replace[*]"
},
longHorizontalLine: {
key: "水平线",
value: "[hr]",
L: "",
R: "[hr]",
cursorL: "[hr]",
cursorLength: 4,
quickUBBReplace: "replace[hr]"
},
link: {
key: "链接",
value: "[url=][/url]",
tagL: "=",
tagR: "]",
L: "[url=]",
R: "[/url]",
cursorL: "[url=",
cursorLength: 5,
quickUBBReplace: "[url=replace]replace[/url]"
},
hide: {
key: "隐藏",
value: "[hide]\n[/hide]",
tagL: "]",
tagR: "[",
L: "[hide]",
R: "[/hide]",
cursorR: "[/hide]",
cursorLength: 7,
quickUBBReplace: "[hide]replace\n[/hide]"
},
quote: {
key: "引用",
value: "[quote][/quote]",
tagL: "]",
tagR: "[",
L: "[quote]",
R: "[/quote]",
cursorR: "[/quote]",
cursorLength: 8,
quickUBBReplace: "[quote]replace[/quote]"
},
email: {
key: "邮件",
value: "[email=][/email]",
tagL: "=",
tagR: "]",
L: "[email=]",
R: "[/email]",
cursorL: "[email=",
cursorLength: 7,
quickUBBReplace: "[email=replace]replace[/email]"
}
};
};
const MTUBB_Rainbow = (num, text) => {
if (text == "") {
return "";
}
var wr_text = text;
var wr_code, wr_rgb, r, g, b, i, j, istep;
r = 0;
g = 0;
b = 0;
istep = 0;
wr_code = "";
if (num == 1) {
istep = 40;
r = 255;
i = 1;
j = 0;
do {
if (wr_text.charCodeAt(j) != 32) {
if (g + istep < 256) {
if (i == 1) g += istep;
} else if (i == 1) {
i = 2;
g = 255;
}
if (r - istep > -1) {
if (i == 2) r -= istep;
} else if (i == 2) {
i = 3;
r = 0;
}
if (b + istep < 256) {
if (i == 3) b += istep;
} else if (i == 3) {
i = 4;
b = 255;
}
if (g - istep > -1) {
if (i == 4) g -= istep;
} else if (i == 4) {
i = 5;
g = 0;
}
if (r + istep < 256) {
if (i == 5) r += istep;
} else if (i == 5) {
i = 6;
r = 255;
}
if (b - istep > -1) {
if (i == 6) b -= istep;
} else if (i == 6) {
i = 1;
b = 0;
}
wr_rgb = "";
wr_rgb += // @ts-ignore
parseInt(r).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(r).toString(16)
) : (
// @ts-ignore
parseInt(r).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(g).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(g).toString(16)
) : (
// @ts-ignore
parseInt(g).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(b).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(b).toString(16)
) : (
// @ts-ignore
parseInt(b).toString(16)
);
wr_rgb = wr_rgb.toUpperCase();
wr_code += `[color=#${wr_rgb}]${wr_text.charAt(j)}[/color]`;
} else {
wr_code += wr_text.charAt(j);
}
j++;
} while (j < wr_text.length);
} else if (num == 2) {
istep = 255 / wr_text.length;
for (i = 1; i < wr_text.length + 1; i++) {
if (wr_text.charCodeAt(i - 1) != 32) {
r += istep;
g += istep;
b += istep;
if (r > 255) r = 255;
if (g > 255) g = 255;
if (b > 255) b = 255;
wr_rgb = "";
wr_rgb += // @ts-ignore
parseInt(r).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(r).toString(16)
) : (
// @ts-ignore
parseInt(r).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(g).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(g).toString(16)
) : (
// @ts-ignore
parseInt(g).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(b).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(b).toString(16)
) : (
// @ts-ignore
parseInt(b).toString(16)
);
wr_rgb = wr_rgb.toUpperCase();
wr_code += `[color=#${wr_rgb}]${wr_text.charAt(i - 1)}[/color]`;
} else {
wr_code += wr_text.charAt(i - 1);
}
}
} else if (num == 3) {
istep = 255 / wr_text.length;
for (i = 1; i < wr_text.length + 1; i++) {
if (wr_text.charCodeAt(i - 1) != 32) {
r += istep;
g = 29;
b = 36;
if (r > 255) r = 255;
if (g > 255) g = 255;
if (b > 255) b = 255;
wr_rgb = "";
wr_rgb += // @ts-ignore
parseInt(r).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(r).toString(16)
) : (
// @ts-ignore
parseInt(r).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(g).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(g).toString(16)
) : (
// @ts-ignore
parseInt(g).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(b).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(b).toString(16)
) : (
// @ts-ignore
parseInt(b).toString(16)
);
wr_rgb = wr_rgb.toUpperCase();
wr_code += `[color=#${wr_rgb}]${wr_text.charAt(i - 1)}[/color]`;
} else {
wr_code += wr_text.charAt(i - 1);
}
}
} else if (num == 4) {
istep = 255 / wr_text.length;
for (i = 1; i < wr_text.length + 1; i++) {
if (wr_text.charCodeAt(i - 1) != 32) {
r = 0;
g = 174;
b += istep;
if (r > 255) r = 255;
if (g > 255) g = 255;
if (b > 255) b = 255;
wr_rgb = "";
wr_rgb += // @ts-ignore
parseInt(r).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(r).toString(16)
) : (
// @ts-ignore
parseInt(r).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(g).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(g).toString(16)
) : (
// @ts-ignore
parseInt(g).toString(16)
);
wr_rgb += // @ts-ignore
parseInt(255 - b).toString(16).length == 1 ? (
// @ts-ignore
0 + parseInt(255 - b).toString(16)
) : (
// @ts-ignore
parseInt(255 - b).toString(16)
);
wr_rgb = wr_rgb.toUpperCase();
wr_code += `[color=#${wr_rgb}]${wr_text.charAt(i - 1)}[/color]`;
} else {
wr_code += wr_text.charAt(i - 1);
}
}
}
return wr_code;
};
const ExtendJQueryFn = function() {
_unsafeWindow.$.fn.extend({
insertAtCaret: function(myValue) {
var $t = _unsafeWindow.$(this)[0];
if (document.selection) {
this.focus();
var sel = document.selection.createRange();
sel.text = myValue;
this.focus();
} else if ($t.selectionStart || $t.selectionStart == "0") {
var startPos = $t.selectionStart;
var endPos = $t.selectionEnd;
var scrollTop = $t.scrollTop;
$t.value = $t.value.substring(0, startPos) + myValue + $t.value.substring(endPos, $t.value.length);
this.focus();
$t.selectionStart = startPos + myValue.length;
$t.selectionEnd = startPos + myValue.length;
$t.scrollTop = scrollTop;
} else {
this.value += myValue;
this.focus();
}
},
selectRange: function(start, end) {
if (end === void 0) {
end = start;
}
return this.each(function() {
if ("selectionStart" in this) {
this.selectionStart = start;
this.selectionEnd = end;
} else if (this.setSelectionRange) {
this.setSelectionRange(start, end);
} else if (this.createTextRange) {
var range = this.createTextRange();
range.collapse(true);
range.moveEnd("character", end);
range.moveStart("character", start);
range.select();
}
});
},
getCursorPosition: function() {
var el = _unsafeWindow.$(this)[0];
var pos = 0;
if ("selectionStart" in el) {
pos = el.selectionStart;
} else if ("selection" in document) {
el.focus();
var Sel = document.selection.createRange();
var SelLength = document.selection.createRange().text.length;
Sel.moveStart("character", -el.value.length);
pos = Sel.text.length - SelLength;
}
return pos;
},
moveCursorInCenterByText: function(leftTextFlag, rightTextFlag) {
var el = _unsafeWindow.$(this)[0];
var el_text = el.value;
for (let i = el.selectionStart - 1; i > 0; i--) {
let LText = el_text[i - 1];
let currentText = el_text[i];
if (LText == leftTextFlag && currentText == rightTextFlag) {
this.selectRange(i);
break;
}
}
},
moveCursorToCenterByTextWithLeft: function(leftMatchText, _length_) {
var el = _unsafeWindow.$(this)[0];
var el_text = el.value;
for (let index = el.selectionStart - 1; index > 0; index--) {
let lTexts = el_text.substring(index - _length_, index);
if (lTexts == leftMatchText) {
this.selectRange(index);
break;
}
}
},
moveCursorToCenterByTextWithRight: function(rightMatchText, _length_) {
var el = _unsafeWindow.$(this)[0];
var el_text = el.value;
for (let i = el.selectionStart - 1; i > 0; i--) {
let rTexts = el_text.substring(i, i + _length_);
if (rTexts == rightMatchText) {
this.selectRange(i + _length_);
break;
}
}
}
});
};
let error_code = {
1: {
error_match: "抱歉,您填写的内容包含敏感词而无法提交",
popup_text: "抱歉,您填写的内容包含敏感词而无法提交"
},
2: {
error_match: "抱歉,管理员设置了本版块发表于 30 天以前的主题自动关闭,不再接受新回复",
popup_text: "抱歉,管理员设置了本版块发表于 30 天以前的主题自动关闭,不再接受新回复"
},
3: {
error_match: "抱歉,本主题已关闭,不再接受新内容",
popup_text: "抱歉,本主题已关闭,不再接受新内容"
},
4: {
error_match: "抱歉,管理员设置了本版块发表于 30 天以前的主题自动关闭,不再接受新回复",
popup_text: "抱歉,管理员设置了本版块发表于 30 天以前的主题自动关闭,不再接受新回复"
},
5: {
error_match: "抱歉,您的帖子小于 10 个字符的限制",
popup_text: "抱歉,您的帖子小于 10 个字符的限制"
}
};
let tempReplyBtnNode = null;
const MTEditorOptimizationNormal = {
$data: {
isUBBCodeInsertClick: false,
db: new Utils.indexedDB("mt_reply_record", "input_text"),
forum_action: null,
get tid() {
return MTUtils.getThreadId(window.location.href);
}
},
$el: {
/** 点赞按钮 */
$like: null,
/** 发表按钮 */
$btn_submit: null,
/** 输入框 */
$input: null,
/** 表单元素 */
$form: null,
/** 发表|回复按钮 */
$fastpostsubmit: null
},
init() {
log.info(`编辑器优化-简略版`);
addStyle(optimizationCSS$1);
this.overridePageEditor();
},
/**
* 覆盖页面的编辑器
*/
overridePageEditor() {
let $old_commentIcon = document.querySelector(
"#comiis_foot_memu .comiis_flex li:nth-child(2)"
);
let $old_linkIcon = document.querySelector(
"#comiis_foot_memu .comiis_flex li:nth-child(3)"
);
let $old_collectIcon = document.querySelector(
"#comiis_foot_memu .comiis_flex li:nth-child(4)"
);
this.$el.$form = document.querySelector("#fastpostform");
this.$data.forum_action = this.$el.$form.getAttribute("action");
let forum_serialize = domUtils.serialize(this.$el.$form);
let forum_url = document.querySelector(
"#fastpostform .header_y a"
).href;
domUtils.remove("#needmessage[name='message']");
domUtils.remove("#imglist");
domUtils.remove("#fastpostsubmitline");
domUtils.remove("#fastpostsubmit");
let $footMenu = document.querySelector("#comiis_foot_memu");
domUtils.hide($footMenu, false);
let smiliesList = MTEditorSmilies();
let first_smilies = Object.keys(smiliesList[0]).map((key) => {
let smilies_url = smiliesList[0][key];
return (
/*html*/
`<li><a href="javascript:;" onclick="comiis_addsmilies('${key}');"><img loading="lazy" data-src="${smilies_url}" class="vm"></a></li>`
);
});
let second_smilies = Object.keys(smiliesList[1]).map((key) => {
let smilies_url = smiliesList[1][key];
return (
/*html*/
`<li><a href="javascript:;" onclick="comiis_addsmilies('${key}');"><img loading="lazy" data-src="${smilies_url}" class="vm"></a></li>`
);
});
let third_smilies = Object.keys(smiliesList[2]).map((key) => {
let smilies_url = smiliesList[2][key];
return (
/*html*/
`<li><a href="javascript:;" onclick="comiis_addsmilies('${key}');"><img loading="lazy" data-src="${smilies_url}" class="vm"></a></li>`
);
});
domUtils.after(
$footMenu,
/*html*/
`
<div id="comiis_foot_menu_beautify" class="bg_f b_t">
<div class="reply_area">
<ul>
<li data-attr="回帖"><input type="text" class="bg_e f_c" placeholder="发帖千百度,文明第一步" readonly="readonly"></li>
<li data-attr="评论数量">${$old_commentIcon.innerHTML}</li>
<li data-attr="点赞">${$old_linkIcon.innerHTML}</li>
<li data-attr="收藏">${$old_collectIcon.innerHTML}</li>
</ul>
</div>
</div>
<div id="comiis_foot_menu_beautify_big" data-model="comment" class="bg_f b_t" style="display:none;">
<div class="reply_area">
<div class="reply_user_content" style="display:none;"></div>
<ul>
<li data-attr="回帖"><textarea id="needmessage" placeholder="发帖千百度,文明第一步"></textarea></li>
<li data-attr="发表">
<div class="fastpostform_new"><a href="${forum_url}" data-comment-url="${forum_url}" target="_blank"><i class="comiis_font f_d"></i></a></div>
<div id="fastpostsubmitline"><input data-comment-url="${forum_url}" data-comment-action="${this.$data.forum_action}" data-comment-serialize="${forum_serialize}" data-text="false" type="button" value="发表" name="replysubmit" id="fastpostsubmit" comiis="handle"></div>
</li>
</ul>
</div>
<div class="other_area">
<div class="menu_icon">
<a href="javascript:;" class="comiis_pictitle"><i class="comiis_font"></i></a>
<a href="javascript:;" class="comiis_smile"><i class="comiis_font"></i></a>
<a href="javascript:;" class="commis_insert_bbs"><i class="comiis_font"></i></a>
</div>
<div class="menu_body">
<div id="comiis_pictitle_tab">
<!-- 列表项 -->
<div class="comiis_upbox bg_f cl">
<ul id="imglist" class="comiis_post_imglist cl">
<li class="up_btn">
<a href="javascript:;" class="bg_e b_ok f_d">
<i class="comiis_font"></i>
</a>
<input type="file" name="Filedata" id="filedata" accept="image/*" multiple>
</li>
</ul>
</div>
<!-- 菜单项 -->
<div class="bqbox_t">
<ul id="comiis_pictitle_key">
<li class="bg_f" id="comiis_pictitle_tab_n_1"><a href="javascript:;" class="">论坛</a></li>
</ul>
</div>
</div>
<div id="comiis_post_tab" class="comiis_bqbox">
<div class="comiis_smiley_box swiper-container-horizontal swiper-container-android">
<div class="swiper-wrapper bqbox_c comiis_optimization">
<div class="swiper-slide">
${first_smilies.join("\n")}
</div>
<div class="swiper-slide" style="display: none;">
${second_smilies.join("\n")}
</div>
<div class="swiper-slide" style="display: none;">
${third_smilies.join("\n")}
</div>
</div>
<div class="bqbox_t">
<ul id="comiis_smilies_key">
<li>
<a href="javascript:;" id="comiis_smilies_tab_n_1" class="bg_f b_l b_r">
<img loading="lazy" data-src="https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq063.gif" class="vm">
</a>
</li>
<li>
<a href="javascript:;" id="comiis_smilies_tab_n_2" class="">
<img loading="lazy" data-src="https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_10.png" class="vm">
</a>
</li>
<li>
<a href="javascript:;" id="comiis_smilies_tab_n_3" class="">
<img loading="lazy" data-src="https://cdn-bbs.mt2.cn/static/image/smiley/doge/21.png" class="vm">
</a>
</li>
</ul>
</div>
</div>
</div>
<div id="comiis_insert_ubb_tab" style="display: none;">
<div class="bg_f comiis_input_style">
<div class="comiis_post_urlico b_b">
<ul id="comiis_insert_ubb_tab_list">
</ul>
</div>
</div>
</div>
</div>
</div>
`
);
$(
"#comiis_foot_menu_beautify .comiis_position_key"
);
this.$el.$like = $(
"#comiis_foot_menu_beautify .comiis_recommend_addkey"
);
$(
"#comiis_foot_menu_beautify #comiis_favorite_a"
);
$("#comiis_pictitle_key");
this.$el.$btn_submit = $(
'#comiis_foot_menu_beautify_big li[data-attr="发表"] input'
);
this.$el.$input = $(
"#comiis_foot_menu_beautify_big textarea"
);
this.$el.$fastpostsubmit = $("#fastpostsubmit");
_unsafeWindow.textarea_scrollHeight = () => {
};
if (typeof _unsafeWindow.comiis_addsmilies == "function") {
_unsafeWindow.comiis_addsmilies = (smilies_text) => {
_unsafeWindow.$("#needmessage").comiis_insert(smilies_text);
_unsafeWindow.$("#needmessage")[0].dispatchEvent(new Event("propertychange"));
};
}
_unsafeWindow.$("#imglist .up_btn").append(_unsafeWindow.$("#filedata"));
_unsafeWindow.$(document).on("click", "#imglist .up_btn a", function() {
_unsafeWindow.$(this).next().click();
});
_unsafeWindow.$(document).on("click", "#imglist .p_img a", function() {
let obj = _unsafeWindow.$(this);
if (obj.attr("onclick") == null) {
let img_id = obj.find("img").attr("id").replace("aimg_", "");
_unsafeWindow.comiis_addsmilies(`[attachimg]${img_id}[/attachimg]`);
}
});
domUtils.hide("#comiis_foot_menu_beautify_big .menu_body", false);
this.setInputChangeEvent();
this.setLikeBtnClickEvent();
this.setSubmitBtnClickEvent();
this.setGlobalReplyBtnClickEvent();
this.setGlobalClickCheckEvent();
this.setMenuIconToggleEvent();
this.setMenuImageClickEvent();
this.setMenuImageToggleEvent();
this.setMenuSmileClickEvent();
this.setMenuSmileTabClickEvent();
this.setMenuInsertClickEvent();
this.setMenuQuickUBB();
PopsPanel.execMenu(
"mt-forum-post-editorOptimizationNormal-recordInputText",
() => {
this.initReplyText();
this.setInputChangeSaveEvent();
}
);
PopsPanel.execMenuOnce("mt-image-bed-hello-enable", () => {
MTEditorImageBed_Hello.init();
});
PopsPanel.execMenuOnce("mt-image-bed-mt-enable", () => {
MTEditorImageBed_MT.init();
});
},
/**
* 处理错误的响应
* @param text
*/
handle_error(text) {
let return_status = false;
let messagetext = domUtils.text(
domUtils.parseHTML(text, false, false).querySelector(
"#messagetext"
)
);
if (!messagetext || typeof messagetext === "string" && messagetext.trim() == "") {
return return_status;
}
Object.keys(error_code).forEach((item) => {
let value = error_code[item];
if (messagetext.indexOf(value.error_match) != -1) {
if (messagetext.indexOf(`typeof errorhandle_=='function'`) != -1) {
Qmsg.error(value.popup_text);
}
return_status = true;
return;
}
});
return return_status;
},
/**
* 监听输入框内容改变
*/
setInputChangeEvent() {
const that = this;
domUtils.on(that.$el.$input, ["input", "propertychange"], function(event) {
var _a2, _b;
let inputText = that.$el.$input.value;
if (inputText === "") {
that.$el.$btn_submit.setAttribute("data-text", "false");
(_a2 = $(
"#comiis_foot_menu_beautify li[data-attr='回帖'] input"
)) == null ? void 0 : _a2.setAttribute("placeholder", "发帖千百度,文明第一步");
} else {
that.$el.$btn_submit.setAttribute("data-text", "true");
(_b = $(
"#comiis_foot_menu_beautify li[data-attr='回帖'] input"
)) == null ? void 0 : _b.setAttribute("placeholder", "[草稿待发送]");
}
domUtils.css(that.$el.$input, "height", "70px");
domUtils.css(
that.$el.$input,
"height",
that.$el.$input.scrollHeight - 20 + "px"
);
});
},
/**
* 监听输入框内容改变并保存到indexDB
*/
setInputChangeSaveEvent() {
const that = this;
domUtils.on(this.$el.$input, ["input", "propertychange"], (event) => {
let inputText = that.$el.$input.value;
let $reply = that.$el.$input.closest(".reply_area").querySelector(".reply_user_content");
let replyUrl = $reply.getAttribute("data-reply-url");
let data = {
url: window.location.href,
text: inputText,
repquote: replyUrl ? MTUtils.getRepquote(replyUrl) : void 0,
forumId: that.$data.tid
};
that.$data.db.get("data").then((result) => {
if (!result.success || result.code === 201) {
console.warn(result);
return;
}
let localDataIndex = result.data.findIndex((item) => {
return item.forumId === data.forumId && item.repquote === data.repquote;
});
if (localDataIndex !== -1) {
if (inputText == null || inputText === "") {
result.data.splice(localDataIndex, 1);
} else {
result.data[localDataIndex] = utils.assign(
result.data[localDataIndex],
{
text: data.text
}
);
}
} else {
result.data.push(data);
}
that.$data.db.save("data", result.data).then((result2) => {
});
});
});
},
/**
* 把存储回复框的内容设置到输入框中
* @param isUserReply 是否是来自点击回复的
* @param replyUrl 回复的url
*/
async initReplyText(isUserReply = false, replyUrl = void 0) {
const that = this;
let initResult = await this.$data.db.get(
"data"
);
if (initResult.code === 201) {
await this.$data.db.save("data", []);
}
let queryResult = await this.$data.db.get(
"data"
);
if (!queryResult.success || queryResult.code === 201) {
console.warn(queryResult);
return;
}
let repquote = void 0;
if (replyUrl) {
repquote = MTUtils.getRepquote(replyUrl);
}
let localReplyData = queryResult.data.find((item) => {
if (isUserReply) {
return item.forumId === that.$data.tid && item.repquote == repquote;
} else {
return item.forumId === that.$data.tid && item.repquote == null;
}
});
if (localReplyData) {
domUtils.val(this.$el.$input, localReplyData.text);
utils.dispatchEvent(this.$el.$input, "input");
}
},
/**
* 设置点赞按钮点击事件
*/
setLikeBtnClickEvent() {
domUtils.on(this.$el.$like, "click", async (event) => {
var _a2, _b;
utils.preventEvent(event);
if (_unsafeWindow.comiis_recommend_key == 0) {
_unsafeWindow.comiis_recommend_key = 1;
let response = await httpx.get(this.$el.$like.href + "&inajax=1", {
headers: {
Accept: "application/xml, text/xml, */*; q=0.01"
},
allowInterceptConfig: false
});
if (!response.status) {
window.location.href = this.$el.$like.href;
setTimeout(function() {
_unsafeWindow.comiis_recommend_key = 0;
}, 500);
return;
}
let xmlDoc = utils.parseFromString(
response.data.responseText,
"text/xml"
);
let resultText = (_b = (_a2 = xmlDoc.lastChild) == null ? void 0 : _a2.firstChild) == null ? void 0 : _b.nodeValue;
if (resultText.includes("您已评价过本主题")) {
let tid = this.$el.$like.href.match(MTRegExp.tid)[1];
let response2 = await httpx.get(
`plugin.php?id=comiis_app&comiis=re_recommend&tid=${tid}&inajax=1`,
{
headers: {
Accept: "application/xml, text/xml, */*; q=0.01"
},
allowInterceptConfig: false
}
);
if (!response2.status) {
Qmsg.error("取消点赞失败,网络异常");
return;
}
var recommend_num = Number(domUtils.text("#comiis_recommend_num"));
if (document.querySelectorAll(".comiis_recommend_list_a").length > 0) {
domUtils.remove("#comiis_recommend_list_a" + _unsafeWindow.uid);
}
if (document.querySelectorAll(".comiis_recommend_list_s").length > 0) {
domUtils.remove("#comiis_recommend_list_s" + _unsafeWindow.uid);
}
if (document.querySelectorAll(".comiis_recommend_list_t").length > 0) {
domUtils.remove("#comiis_recommend_list_t" + _unsafeWindow.uid);
}
if (recommend_num > 1) {
domUtils.text(
".comiis_recommend_num",
recommend_num - Number(_unsafeWindow.allowrecommend)
);
domUtils.text(
".comiis_recommend_nums",
"+" + (recommend_num - Number(_unsafeWindow.allowrecommend))
);
} else {
domUtils.remove("#comiis_recommend_num");
domUtils.text(".comiis_recommend_nums", "");
if (document.querySelectorAll(".comiis_recommend_list_a").length > 0) {
domUtils.empty(".comiis_recommend_list_a");
domUtils.removeClass(
".comiis_recommend_list_a",
"comiis_recommend_list_on"
);
}
if (document.querySelectorAll(".comiis_recommend_list_t").length > 0) {
domUtils.removeClass(
".comiis_recommend_list_t",
"comiis_recommend_list_on"
);
}
}
domUtils.html(".comiis_recommend_addkey i", "");
domUtils.removeClass(".comiis_recommend_color", "f_a");
domUtils.addClass(".comiis_recommend_color", "f_b");
if (document.querySelectorAll(".comiis_recommend_list_s").length > 0) {
if (document.querySelectorAll(".comiis_recommend_list_s li").length < 7) {
domUtils.hide(".txshow_more", false);
} else {
domUtils.show(".txshow_more", false);
}
}
Qmsg.success("已取消点赞");
} else if (resultText.includes("您不能评价自己的帖子")) {
Qmsg.error("不能点赞自己的帖子");
} else if (resultText.includes("今日评价机会已用完")) {
Qmsg.warning("您今日的点赞机会已用完");
} else if (resultText.includes(
"'recommendv':'+" + _unsafeWindow.allowrecommend + "'"
)) {
var recommendcList = {
recommendc: 0,
daycount: 0
}, recommendc;
recommendc = resultText.match(/\'recommendc\':\'(.*?)\'/);
if (recommendc != null) {
recommendcList["recommendc"] = parseInt(recommendc[1]);
} else {
recommendcList["recommendc"] = 0;
}
recommendc = resultText.match(/\'daycount\':\'(.*?)\'/);
if (recommendc != null) {
recommendcList["daycount"] = parseInt(recommendc[1]);
} else {
recommendcList["daycount"] = 0;
}
if (document.querySelectorAll(".comiis_recommend_new span").length < 1) {
domUtils.append(
".comiis_recommend_new",
'<span class="bg_del f_f comiis_kmvnum comiis_recommend_num" id="comiis_recommend_num">0</span>'
);
}
var comiis_recommend_num = Number(
domUtils.text("#comiis_recommend_num")
);
if ($$(".comiis_recommend_list_a").length > 0) {
let $list_a = $$(".comiis_recommend_list_a");
domUtils.removeClass($list_a, "comiis_recommend_list_on");
domUtils.addClass($list_a, "comiis_recommend_list_on");
domUtils.prepend(
$list_a,
($$(".comiis_recommend_list_a li").length > 0 ? "" : '<li style="float:right;margin-right:0;"><a href="misc.php?op=recommend&tid= ' + _unsafeWindow.tid + '&mod=faq&mobile=2"><span class="bg_b f_c"><em class="comiis_recommend_num">' + comiis_recommend_num + "</em>赞</span></a></li>") + '<li id="comiis_recommend_list_a' + _unsafeWindow.uid + '"><a href="home.php?mod=space&uid=' + _unsafeWindow.uid + '"><img src="' + MTUtils.getAvatar(_unsafeWindow.uid, "small") + '"></a></li>'
);
}
if ($$(".comiis_recommend_list_t").length > 0) {
let $list_t = $$(".comiis_recommend_list_t");
domUtils.removeClass($list_t, "comiis_recommend_list_on");
domUtils.addClass($list_t, "comiis_recommend_list_on");
domUtils.prepend(
$list_t,
`<span id="comiis_recommend_list_t${_unsafeWindow.uid}">
<a href="home.php?mod=space&uid=${_unsafeWindow.uid}" class="f_c">${_unsafeWindow.username}</a>
${$$(".comiis_recommend_list_t a").length > 0 ? '<span class="f_d"> , </span>' : ""}
</span>`
);
}
if ($$(".comiis_recommend_list_s").length > 0) {
let $list_s = $$(".comiis_recommend_list_s");
domUtils.removeClass($list_s, "comiis_recommend_list_on");
domUtils.addClass($list_s, "comiis_recommend_list_on");
domUtils.prepend(
$list_s,
($$(".comiis_recommend_list_s li").length > 0 ? "" : "") + '<li id="comiis_recommend_list_s' + _unsafeWindow.uid + '"><a href="home.php?mod=space&uid=' + _unsafeWindow.uid + '"><img loading="lazy" src="' + MTUtils.getAvatar(_unsafeWindow.uid, "small") + '"></a></li>'
);
}
domUtils.text(
".comiis_recommend_num",
comiis_recommend_num + Number(_unsafeWindow.allowrecommend)
);
domUtils.text(
".comiis_recommend_nums",
"+" + (comiis_recommend_num + Number(_unsafeWindow.allowrecommend))
);
domUtils.html(".comiis_recommend_addkey i", "");
domUtils.removeClass(".comiis_recommend_color", "f_b");
domUtils.addClass(".comiis_recommend_color", "f_a");
if ($$(".comiis_recommend_list_s").length > 0) {
if ($$(".comiis_recommend_list_s li").length < 7) {
domUtils.hide(".txshow_more", false);
} else {
domUtils.show(".txshow_more", false);
}
}
Qmsg.success(
"点赞成功" + (recommendcList["daycount"] ? `, 您今天还能点赞 ${recommendcList["daycount"] - 1} 次` : "")
);
} else if (resultText.indexOf(
"window.location.href = 'member.php?mod=logging&action=login&mobile=2'"
) >= 0) {
window.location.href = "member.php?mod=logging&action=login&mobile=2";
} else {
Qmsg.error("没有点赞权限或帖子不存在");
}
setTimeout(function() {
_unsafeWindow.comiis_recommend_key = 0;
}, 500);
}
return false;
});
},
/**
* 发表按钮|回复按钮点击事件
*/
setSubmitBtnClickEvent() {
const that = this;
domUtils.on(this.$el.$fastpostsubmit, "click", async (event) => {
var _a2, _b, _c, _d, _e, _f;
utils.preventEvent(event);
var $message = $("#needmessage");
var message = domUtils.val($message);
message = encodeURIComponent(message);
if (message == null || message === "") {
return;
}
if (domUtils.val(that.$el.$fastpostsubmit) == "发表") {
let $loading = Qmsg.loading("发表中,请稍后...");
let data = "message=" + message;
$$("#imglist input[type='hidden']").forEach(
($ele) => {
let key = $ele.getAttribute("name");
data += `&${key}=`;
}
);
data = domUtils.serialize(that.$el.$form) + "&" + data;
let url = that.$data.forum_action + "reply&handlekey=fastpost&loc=1&inajax=1";
let response = await httpx.post(url, {
data,
fetch: true,
allowInterceptConfig: false,
headers: {
"Content-Type": "application/x-www-form-urlencoded"
}
});
$loading.close();
if (!response.status) {
Qmsg.error("发表失败,网络异常");
return;
}
let xmlDoc = utils.parseFromString(
response.data.responseText,
"text/xml"
);
let xmlText = (_b = (_a2 = xmlDoc.lastChild) == null ? void 0 : _a2.firstChild) == null ? void 0 : _b.nodeValue;
_unsafeWindow.evalscript(xmlText);
if (this.handle_error(xmlText)) {
return;
}
window.scrollTo({
top: domUtils.height(document)
});
domUtils.val("#needmessage", "");
(_c = $("#comiis_head")) == null ? void 0 : _c.click();
domUtils.hide(
"#comiis_foot_menu_beautify_big .reply_user_content",
false
);
domUtils.attr(
'#comiis_foot_menu_beautify_big li[data-attr="发表"] input',
"data-text",
"false"
);
domUtils.attr(
"#comiis_foot_menu_beautify li[data-attr='回帖'] input",
"placeholder",
"发帖千百度,文明第一步"
);
this.deleteReplyTextStorage();
} else {
let data = domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_user_content",
"data-reply-serialize"
) + message;
$$("#imglist input[type='hidden']").forEach(
(item) => {
data = `${data}&${item.getAttribute("name")}=`;
}
);
let replyUrl = domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_user_content",
"data-reply-action"
);
let response = await httpx.post(
replyUrl + "&handlekey=fastposts&loc=1&inajax=1",
{
allowInterceptConfig: false,
fetch: true,
data,
headers: {
"Content-Type": "application/x-www-form-urlencoded"
}
}
);
if (!response.status) {
Qmsg.error("回复失败,网络异常");
return;
}
let xmlDoc = utils.parseFromString(
response.data.responseText,
"text/xml"
);
let xmlText = (_e = (_d = xmlDoc.lastChild) == null ? void 0 : _d.firstChild) == null ? void 0 : _e.nodeValue;
log.info(xmlText);
_unsafeWindow.evalscript(xmlText);
if (this.handle_error(xmlText)) {
return;
}
(_f = $(xmlText)) == null ? void 0 : _f.click();
domUtils.val("#needmessage", "");
$("#comiis_head").click();
domUtils.val(
'#comiis_foot_menu_beautify_big li[data-attr="发表"] input',
"发表"
);
domUtils.attr(
'#comiis_foot_menu_beautify_big li[data-attr="发表"] input',
"data-text",
"false"
);
domUtils.attr(
"#comiis_foot_menu_beautify li[data-attr='回帖'] input",
"placeholder",
"发帖千百度,文明第一步"
);
window.scrollTo({
top: domUtils.height(document)
});
this.deleteReplyTextStorage(true, replyUrl);
}
return false;
});
},
/**
* 全局回复按钮点击事件
*/
setGlobalReplyBtnClickEvent() {
domUtils.on(
document,
"click",
'.comiis_postli_times .dialog[href*="reply"]',
async (event) => {
var _a2, _b, _c, _d;
utils.preventEvent(event);
let $reply = event.target;
domUtils.attr("#comiis_foot_menu_beautify_big", "data-model", "reply");
let response = await httpx.get(
domUtils.attr($reply, "datahref") || $reply.href + "&inajax=1",
{
fetch: true,
allowInterceptConfig: false
}
);
if (!response.status) {
Qmsg.error("网络异常,获取回复参数失败");
return;
}
let xmlDoc = utils.parseFromString(
response.data.responseText,
"text/xml"
);
let xmlText = (_b = (_a2 = xmlDoc.lastChild) == null ? void 0 : _a2.firstChild) == null ? void 0 : _b.nodeValue;
if (this.handle_error(xmlText)) {
return;
}
let requestDOM = domUtils.parseHTML(
`<div>${xmlText}</div>`,
true,
false
);
let reply_url = (_c = requestDOM.querySelector(".comiis_tip .tip_tit a")) == null ? void 0 : _c.getAttribute("href");
let reply_user = domUtils.text(
requestDOM.querySelector(".comiis_tip span.f_0")
);
let reply_content = domUtils.val(
requestDOM.querySelector(
"input[name='noticeauthormsg']"
)
);
let reply_action = domUtils.attr(
requestDOM.querySelector("#postforms"),
"action"
);
let reply_serialize = domUtils.serialize(
requestDOM.querySelector("#postforms")
);
domUtils.text(
"#comiis_foot_menu_beautify_big .reply_user_content",
`回复 ${reply_user}: ${reply_content}`
);
domUtils.show(
"#comiis_foot_menu_beautify_big .reply_user_content",
false
);
(_d = $(
"#comiis_foot_menu_beautify li[data-attr='回帖'] input"
)) == null ? void 0 : _d.click();
domUtils.focus("#comiis_foot_menu_beautify li[data-attr='回帖'] input");
domUtils.val("#fastpostsubmitline input", "回复");
domUtils.attr(
"#comiis_foot_menu_beautify_big .fastpostform_new a",
"href",
reply_url
);
domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_user_content",
"data-reply-url",
reply_url
);
domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_user_content",
"data-reply-action",
reply_action
);
domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_user_content",
"data-reply-serialize",
reply_serialize
);
tempReplyBtnNode = $reply;
domUtils.val("#needmessage", domUtils.attr($reply, "data-text") || "");
PopsPanel.execMenu(
"mt-forum-post-editorOptimizationNormal-recordInputText",
() => {
this.initReplyText(true, reply_url);
}
);
},
{
capture: true
}
);
},
/**
* 全局点击检测事件
*/
setGlobalClickCheckEvent() {
const that = this;
let forum_url = $("#fastpostform .header_y a").href;
domUtils.on(document, "click", function(event) {
var _a2;
let $click = event.target;
if ($(".popups-popmenu") || MTEditorOptimizationNormal.$data.isUBBCodeInsertClick) {
log.info(`点击的是弹出层,不做处理`);
MTEditorOptimizationNormal.$data.isUBBCodeInsertClick = false;
return;
} else if (($click == null ? void 0 : $click.classList) && ((_a2 = $click == null ? void 0 : $click.classList) == null ? void 0 : _a2.contains(".dialog_reply")) || ($click == null ? void 0 : $click.closest) && ($click == null ? void 0 : $click.closest(".dialog_reply")) || $click === $('li[data-attr="回帖"] input')) {
log.info(`点击回复按钮或者是编辑器,显示编辑器`);
domUtils.hide("#comiis_foot_menu_beautify", false);
domUtils.show("#comiis_foot_menu_beautify_big", false);
domUtils.focus("#needmessage");
} else if (window.event && !utils.checkUserClickInNode($("#comiis_foot_menu_beautify_big"))) {
log.info(`点击的其它区域,隐藏大编辑器,显示小编辑器`);
domUtils.show("#comiis_foot_menu_beautify", false);
domUtils.hide("#comiis_foot_menu_beautify_big", false);
if (domUtils.attr("#comiis_foot_menu_beautify_big", "data-model") == "reply") {
domUtils.attr(
"#comiis_foot_menu_beautify_big",
"data-model",
"comment"
);
domUtils.val("#fastpostsubmitline input", "发表");
domUtils.attr(
"#comiis_foot_menu_beautify_big .fastpostform_new a",
"href",
forum_url
);
domUtils.text(
"#comiis_foot_menu_beautify_big .reply_area .reply_user_content"
);
domUtils.hide(
"#comiis_foot_menu_beautify_big .reply_area .reply_user_content",
false
);
domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_area .reply_user_content",
"data-reply-url",
""
);
domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_area .reply_user_content",
"data-reply-action",
""
);
domUtils.attr(
"#comiis_foot_menu_beautify_big .reply_area .reply_user_content",
"data-reply-serialize",
""
);
if (tempReplyBtnNode) {
domUtils.attr(
tempReplyBtnNode,
"data-text",
domUtils.val("#needmessage")
);
domUtils.val("#needmessage", "");
domUtils.attr(
'#comiis_foot_menu_beautify_big li[data-attr="发表"] input',
"data-text",
"false"
);
domUtils.attr(
"#comiis_foot_menu_beautify li[data-attr='回帖'] input",
"placeholder",
"发帖千百度,文明第一步"
);
}
}
if (domUtils.val(that.$el.$input) === "") {
PopsPanel.execMenu(
"mt-forum-post-editorOptimizationNormal-recordInputText",
() => {
that.initReplyText();
}
);
}
}
});
},
/**
* 菜单-图标切换事件
*/
setMenuIconToggleEvent() {
domUtils.on(
"#comiis_foot_menu_beautify_big .menu_icon a i",
"click",
function(event) {
let $click = this;
if ($click.classList.contains("f_0")) {
domUtils.hide("#comiis_foot_menu_beautify_big .menu_body", false);
domUtils.removeClass(
"#comiis_foot_menu_beautify_big .menu_icon a i",
"f_0"
);
} else {
domUtils.show("#comiis_foot_menu_beautify_big .menu_body", false);
domUtils.removeClass(
"#comiis_foot_menu_beautify_big .menu_icon a i",
"f_0"
);
domUtils.addClass($click, "f_0");
}
}
);
},
/**
* 菜单-图片点击事件
*/
setMenuImageClickEvent() {
domUtils.on(
"#comiis_foot_menu_beautify_big .menu_icon a.comiis_pictitle",
"click",
function(event) {
domUtils.hide(
"#comiis_foot_menu_beautify_big .menu_body #comiis_post_tab",
false
);
domUtils.hide(
"#comiis_foot_menu_beautify_big .menu_body #comiis_insert_ubb_tab",
false
);
domUtils.show(
"#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab",
false
);
}
);
},
/**
* 菜单-图标-切换图片组的事件
*/
setMenuImageToggleEvent() {
domUtils.on(
"#comiis_foot_menu_beautify_big #comiis_pictitle_tab #comiis_pictitle_key",
"click",
"li",
function(event) {
let $click = event.target;
domUtils.removeClass(
"#comiis_foot_menu_beautify_big #comiis_pictitle_tab #comiis_pictitle_key li",
"bg_f"
);
domUtils.addClass($click, "bg_f");
_unsafeWindow.$(
"#comiis_foot_menu_beautify_big #comiis_pictitle_tab div.comiis_upbox"
).hide().eq(_unsafeWindow.$($click).index()).fadeIn();
}
);
},
/**
* 菜单-表情点击事件
*/
setMenuSmileClickEvent() {
domUtils.on(
"#comiis_foot_menu_beautify_big .menu_icon a.comiis_smile",
"click",
function(event) {
domUtils.hide(
"#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab",
false
);
domUtils.hide(
"#comiis_foot_menu_beautify_big .menu_body #comiis_insert_ubb_tab",
false
);
domUtils.show(
"#comiis_foot_menu_beautify_big .menu_body #comiis_post_tab",
false
);
let smileDOM = $(
"#comiis_foot_menu_beautify_big .menu_body .comiis_bqbox"
);
if (domUtils.attr(smileDOM, "data-isLoaded") != 1) {
domUtils.attr(smileDOM, "data-isLoaded", 1);
smileDOM.querySelectorAll("img").forEach((item) => {
let data_src = item.getAttribute("data-src");
if (data_src) {
item.setAttribute("src", data_src);
}
});
}
}
);
},
/**
* 菜单-表情-切换表情组的点击事件
*/
setMenuSmileTabClickEvent() {
domUtils.on(
"#comiis_foot_menu_beautify_big #comiis_smilies_key li",
"click",
function(event) {
let $click = this;
domUtils.removeClass(
"#comiis_foot_menu_beautify_big #comiis_smilies_key li a"
);
domUtils.addClass($click.querySelector("a"), "bg_f b_l b_r");
_unsafeWindow.$(
"#comiis_post_tab div.swiper-wrapper.bqbox_c.comiis_optimization .swiper-slide"
).hide().eq(_unsafeWindow.$($click).index()).fadeIn();
}
);
},
/**
* 菜单-插入点击事件
*/
setMenuInsertClickEvent() {
domUtils.on(
"#comiis_foot_menu_beautify_big .menu_icon a.commis_insert_bbs",
"click",
(event) => {
domUtils.hide(
"#comiis_foot_menu_beautify_big .menu_body #comiis_post_tab",
false
);
domUtils.hide(
"#comiis_foot_menu_beautify_big .menu_body #comiis_pictitle_tab",
false
);
domUtils.show(
"#comiis_foot_menu_beautify_big .menu_body #comiis_insert_ubb_tab",
false
);
}
);
},
/**
* 获取回复记录的占用空间
*/
async getReplyRecordSize() {
var _a2;
let result = await this.$data.db.get("data");
if (result.success) {
let size = utils.getTextStorageSize(
((_a2 = result == null ? void 0 : result.data) == null ? void 0 : _a2.length) ? JSON.stringify(result.data) : ""
);
return size;
} else {
return utils.formatByteToSize(0);
}
},
/**
* 清空所有的回复记录
*/
async clearAllReplyRecord() {
return await this.$data.db.deleteAll();
},
/**
* 删除存储的回复框的内容到indexedDB
* @param isUserReply 是否是来自点击回复的
* @param replyUrl 回复的url
*/
deleteReplyTextStorage(isUserReply = false, replyUrl = void 0) {
const that = this;
this.$data.db.get("data").then((result) => {
if (!result.success || result.code === 201) {
console.warn(result);
return;
}
let localDataIndex = result.data.findIndex((item) => {
if (isUserReply) {
return item.forumId === that.$data.tid && replyUrl && item.repquote === MTUtils.getRepquote(replyUrl);
} else {
return item.forumId === that.$data.tid && utils.isNull(item.repquote);
}
});
if (localDataIndex !== -1) {
result.data.splice(localDataIndex, 1);
this.$data.db.save("data", result.data).then((result2) => {
});
}
});
},
/**
* 注入UBB代码
*/
setMenuQuickUBB() {
let $tab_list = $("#comiis_insert_ubb_tab_list");
let ubbCodeMap = MTQuickUBB();
Reflect.set(ubbCodeMap, "code", {
key: "代码",
value: "[code][/code]",
tagL: "]",
tagR: "[",
L: "[code]",
R: "[/code]",
cursorL: "[code]",
cursorLength: 7,
quickUBBReplace: "[code]replace[/code]"
});
Reflect.set(ubbCodeMap, "password", {
key: "密码",
value: "[password][/password]",
tagL: "]",
tagR: "[",
L: "[password]",
R: "[/password]",
cursorL: "[password]",
cursorLength: 10,
quickUBBReplace: "[password]replace[/password]"
});
Object.keys(ubbCodeMap).forEach((keyName) => {
let value = ubbCodeMap[keyName];
let $ubbs = domUtils.createElement("li", {
className: "quickUBBs",
innerHTML: (
/*html*/
`
<a href="javascript:;" class="comiis_xifont f_d">
<i class="comiis_font"></i>${value["key"]}
</a>
`
)
});
domUtils.on($ubbs, "click", (event) => {
domUtils.removeClass(
"#comiis_insert_ubb_tab div.comiis_post_urlico ul li.quickUBBs a.comiis_xifont",
"f_0"
);
domUtils.addClass(
"#comiis_insert_ubb_tab div.comiis_post_urlico ul li.quickUBBs a.comiis_xifont",
"f_d"
);
let $font = $ubbs.querySelector(".comiis_xifont");
domUtils.removeClass($font, "f_d");
domUtils.removeClass($font, "f_d");
let $prompt = __pops.prompt({
title: {
text: "UBB代码",
position: "center"
},
content: {
text: "",
placeholder: `请输入需要${value["key"]}的文字`,
focus: true
},
btn: {
ok: {
text: "插入",
type: "primary",
callback: (details) => {
if (details.text.trim() === "") {
Qmsg.error("输入框不能为空或纯空格");
return;
}
if (value["isFunc"]) {
_unsafeWindow.comiis_addsmilies(
MTUBB_Rainbow(value["num"], details.text)
);
} else if (value["quickUBBReplace"]) {
_unsafeWindow.comiis_addsmilies(
value["quickUBBReplace"].replaceAll("replace", details.text)
);
} else {
_unsafeWindow.comiis_addsmilies(details.text);
}
$prompt.close();
}
},
cancel: {
text: "关闭",
callback: () => {
$prompt.close();
}
}
},
width: "300px",
height: "200px"
});
});
$tab_list.append($ubbs);
});
}
};
const optimizationCSS = '.f_c,\r\n.f_c a,\r\n.ntc_body {\r\n color: #000 !important;\r\n}\r\ninput::placeholder,\r\ntextarea::placeholder {\r\n color: #cfcfcf;\r\n}\r\n#needsubject::placeholder {\r\n font-weight: 700;\r\n}\r\n#postform #comiis_mh_sub {\r\n height: 60px;\r\n display: flex;\r\n align-items: center;\r\n}\r\n#postform #comiis_post_tab {\r\n display: inherit;\r\n width: 100%;\r\n}\r\n#postform .comiis_sendbtn {\r\n padding: 0 12px;\r\n display: flex !important;\r\n -webkit-box-align: center;\r\n -moz-box-align: center;\r\n align-items: center;\r\n}\r\n#postform .f_f {\r\n color: #fff !important;\r\n}\r\n#postform #comiis_post_tab .bg_f.b_b.cl:nth-child(2) .comiis_atlist a:hover,\r\n#postform #comiis_post_tab .bg_f.b_b.cl:nth-child(2) .comiis_atlist a:link,\r\n#postform #comiis_post_tab .bg_f.b_b.cl:nth-child(2) .comiis_atlist a:visited {\r\n color: #333 !important;\r\n}\r\n#postform .comiis_post_from .comiis_post_ico.comiis_minipost_icot {\r\n position: fixed;\r\n display: inline-table;\r\n z-index: 90;\r\n left: 0;\r\n right: 0;\r\n bottom: 0;\r\n width: 100%;\r\n overflow: hidden;\r\n padding: 0;\r\n}\r\n#postform .comiis_post_from #comiis_post_tab .comiis_bqbox {\r\n height: 200px;\r\n}\r\n#postform .comiis_post_from #comiis_post_tab .comiis_smiley_box {\r\n height: 150px;\r\n}\r\n#postform\r\n .comiis_post_from\r\n #comiis_post_tab\r\n .comiis_input_style\r\n .comiis_post_urlico {\r\n overflow-y: auto;\r\n height: 110px;\r\n}\r\n#postform\r\n .comiis_post_from\r\n #comiis_post_tab\r\n .comiis_smiley_box\r\n .comiis_optimization {\r\n display: block;\r\n overflow-y: auto;\r\n height: 100%;\r\n}\r\n#postform #comiis_post_tab .comiis_input_style .comiis_xifont {\r\n width: -webkit-fill-available;\r\n width: -moz-available;\r\n}\r\n#postform #comiis_post_tab .comiis_input_style .comiis_xifont i.comiis_font {\r\n font-size: 16px;\r\n line-height: inherit;\r\n padding-top: 0;\r\n}\r\n#postform #comiis_post_tab .comiis_input_style .styli_h10 {\r\n display: none;\r\n}\r\n.gm_plugin_chartbed .comiis_chartbed_hello,\r\n.gm_plugin_chartbed .comiis_chartbed_history,\r\n.gm_plugin_chartbed .comiis_chartbed_kggzs,\r\n.gm_plugin_chartbed .comiis_chartbed_luntan,\r\n.gm_plugin_chartbed .comiis_chartbed_mt,\r\n.gm_plugin_chartbed .comiis_chartbed_z4a {\r\n height: 140px;\r\n overflow-y: auto;\r\n flex-direction: column;\r\n}\r\n#comiis_pictitle_key {\r\n display: -webkit-box;\r\n top: 0;\r\n left: 0;\r\n height: 42px;\r\n line-height: 42px;\r\n overflow: hidden;\r\n overflow-x: auto;\r\n background: #f8f8f8;\r\n}\r\n#comiis_pictitle_key a {\r\n color: #333 !important;\r\n padding: 0 10px;\r\n}\r\n#comiis_mh_sub {\r\n height: auto !important;\r\n}\r\n#comiis_mh_sub .swiper-wrapper.comiis_post_ico {\r\n flex-flow: wrap;\r\n}\r\n#comiis_mh_sub a {\r\n margin: 5px 0;\r\n}\r\n#comiis_post_tab .comiis_over_box {\r\n max-height: 225px;\r\n}\r\n@media screen and (max-width: 350px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 14.5%;\r\n }\r\n}\r\n@media screen and (min-width: 350px) and (max-width: 400px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 12.5%;\r\n }\r\n}\r\n@media screen and (min-width: 400px) and (max-width: 450px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 11%;\r\n }\r\n}\r\n@media screen and (min-width: 450px) and (max-width: 500px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 10%;\r\n }\r\n}\r\n@media screen and (min-width: 500px) and (max-width: 550px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 9.5%;\r\n }\r\n}\r\n@media screen and (min-width: 550px) and (max-width: 600px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 9%;\r\n }\r\n}\r\n@media screen and (min-width: 600px) and (max-width: 650px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 8.5%;\r\n }\r\n}\r\n@media screen and (min-width: 650px) and (max-width: 700px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 8%;\r\n }\r\n}\r\n@media screen and (min-width: 700px) and (max-width: 750px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 7.5%;\r\n }\r\n}\r\n@media screen and (min-width: 750px) and (max-width: 800px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 7%;\r\n }\r\n}\r\n@media screen and (min-width: 800px) and (max-width: 850px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 6.5%;\r\n }\r\n}\r\n@media screen and (min-width: 850px) and (max-width: 1200px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 6%;\r\n }\r\n}\r\n@media screen and (min-width: 1200px) {\r\n .comiis_bqbox .bqbox_c li {\r\n width: 4.5%;\r\n }\r\n}\r\n\r\n#comiis_head .header_y {\r\n display: flex;\r\n align-content: center;\r\n align-items: center;\r\n justify-content: flex-end;\r\n height: 100%;\r\n}\r\n#comiis_head .header_y input {\r\n border: transparent;\r\n background: 0 0;\r\n text-align: center;\r\n margin: 0 5px;\r\n}\r\n#comiis_head .header_y input[value="删除"] {\r\n color: #d00;\r\n}\r\n#comiis_head .header_y input[value="保存"] {\r\n color: #b0ff6a;\r\n}\r\n#comiis_head .header_y input[value="保存草稿"] {\r\n color: #f90;\r\n}\r\n#comiis_head .header_y input[value="发表"] {\r\n color: #b0ff6a;\r\n}\r\n#comiis_head .header_y input[value="回复"] {\r\n color: #b0ff6a;\r\n}\r\n#comiis_post_tab {\r\n color: #000;\r\n}\r\n.gm_plugin_chartbed .delImg a,\r\n.gm_plugin_chartbed .p_img a {\r\n padding: 0;\r\n}\r\n.gm_plugin_chartbed .delImg a i {\r\n line-height: inherit;\r\n}\r\n#filedata,\r\n#filedata_hello,\r\n#filedata_kggzs,\r\n#filedata_mt {\r\n display: none;\r\n}\r\n\r\n#comiis_mh_sub {\r\n height: 40px;\r\n}\r\n#imglist .del a {\r\n padding: 0;\r\n}\r\n.comiis_post_from.mt15 {\r\n margin-top: unset !important;\r\n}\r\n';
const pathname = globalThis.location.pathname;
const search = globalThis.location.search;
new URLSearchParams(search);
const Router = {
/**
* 克米签到页面
*/
isKMiSign() {
return pathname.startsWith("/k_misign-sign.html");
},
/**
* 帖子
*/
isPost() {
return pathname.startsWith("/thread-") || pathname.startsWith("/forum.php") && search.startsWith("?mod=viewthread");
},
/**
* 首页、精华
*/
isPage() {
return Boolean(pathname.match(/^\/page-([0-9]+).html/g));
},
/**
* 导读链接
*/
isGuide() {
return pathname.startsWith("/forum.php") && search.startsWith("?mod=guide");
},
/**
* 板块
*/
isPlate() {
return Boolean(pathname.match(/\/forum-[0-9]{1,2}-[0-9]{1,2}.html/g));
},
/**
* 搜索页面
*/
isSearch() {
return pathname.startsWith("/search.php");
},
/**
* 空间
*/
isSpace() {
return pathname.startsWith("/home.php") && search.startsWith("?mod=space");
},
/**
* 我的个人空间
*/
isMySpace() {
return pathname.startsWith("/home.php") && search.startsWith("?mod=space&do=profile&mycenter");
},
/**
* 个人空间页的@点进去
*/
isSpaceWithAt() {
return pathname.startsWith("/space-uid-");
},
/**
* 社区列表
*/
isForumList() {
return pathname.startsWith("/forum.php") && search.startsWith("?forumlist");
},
/**
* 消息提醒
*/
isMessage() {
return pathname.startsWith("/home.php") && search.startsWith("?mod=space&do=notice");
},
/**
* 消息提醒列表
*/
isMessageList() {
return pathname.startsWith("/home.php") && search.startsWith("?mod=space&do=pm");
},
/**
* 积分商城
*/
isPointsMall() {
return pathname.startsWith("/keke_integralmall-keke_integralmall.html") || pathname.startsWith("/plugin.php") && search.startsWith("?id=keke_integralmal");
},
/**
* 帖子发布/回复页面
*/
isPostPublish() {
return pathname.startsWith("/forum.php") && search.startsWith("?mod=post");
},
/**
* 投票页面
*/
isPostPublish_voting() {
return pathname.startsWith("/forum.php") && search.includes("&special=1") || search.includes("&fid=42");
},
/**
* 帖子编辑页面
*/
isPostPublish_edit() {
return this.isPostPublish() && search.includes("&action=edit");
},
/**
* 发帖页面,该页面是尚未存入草稿
*/
isPostPublish_newthread() {
return this.isPostPublish() && search.includes("&action=newthread");
},
/**
* 回复编辑页面
*/
isPostPublish_reply() {
return this.isPostPublish() && search.includes("&action=reply");
}
};
const MTSmiliesDict = () => {
return {
"[呵呵]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq001.gif",
"[撇嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq002.gif",
"[色]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq003.gif",
"[发呆]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq004.gif",
"[得意]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq005.gif",
"[流泪]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq006.gif",
"[害羞]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq007.gif",
"[闭嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq008.gif",
"[睡]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq009.gif",
"[大哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq010.gif",
"[尴尬]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq011.gif",
"[发怒]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq012.gif",
"[调皮]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq013.gif",
"[呲牙]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq014.gif",
"[惊讶]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq015.gif",
"[难过]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq016.gif",
"[酷]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq017.gif",
"[冷汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq018.gif",
"[抓狂]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq019.gif",
"[吐]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq020.gif",
"[偷笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq021.gif",
"[可爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq022.gif",
"[白眼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq023.gif",
"[傲慢]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq024.gif",
"[饥饿]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq025.gif",
"[困]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq026.gif",
"[惊恐]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq027.gif",
"[流汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq028.gif",
"[憨笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq029.gif",
"[装逼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq030.gif",
"[奋斗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq031.gif",
"[咒骂]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq032.gif",
"[疑问]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq033.gif",
"[嘘]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq034.gif",
"[晕]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq035.gif",
"[折磨]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq036.gif",
"[衰]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq037.gif",
"[骷髅]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq038.gif",
"[敲打]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq039.gif",
"[再见]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq040.gif",
"[擦汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq041.gif",
"[抠鼻]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq042.gif",
"[鼓掌]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq043.gif",
"[糗大了]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq044.gif",
"[坏笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq045.gif",
"[左哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq046.gif",
"[右哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq047.gif",
"[哈欠]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq048.gif",
"[鄙视]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq049.gif",
"[委屈]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq050.gif",
"[快哭了]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq051.gif",
"[阴脸]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq052.gif",
"[亲亲]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq053.gif",
"[吓]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq054.gif",
"[可怜]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq055.gif",
"[眨眼睛]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq056.gif",
"[笑哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq057.gif",
"[dogeQQ]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq058.gif",
"[泪奔]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq059.gif",
"[无奈]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq060.gif",
"[托腮]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq061.gif",
"[卖萌]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq062.png",
"[斜眼笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq063.gif",
"[喷血]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq064.gif",
"[惊喜]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq065.gif",
"[骚扰]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq066.gif",
"[小纠结]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq067.gif",
"[我最美]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq068.gif",
"[菜刀]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq069.gif",
"[西瓜]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq070.gif",
"[啤酒]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq071.gif",
"[篮球]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq072.gif",
"[乒乓]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq073.gif",
"[咖啡]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq074.gif",
"[饭]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq075.gif",
"[猪]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq076.gif",
"[玫瑰]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq077.gif",
"[凋谢]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq078.gif",
"[示爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq079.gif",
"[爱心]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq080.gif",
"[心碎]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq081.gif",
"[蛋糕]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq082.gif",
"[闪电]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq083.gif",
"[炸弹]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq084.gif",
"[刀]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq085.gif",
"[足球]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq086.gif",
"[瓢虫]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq087.gif",
"[便便]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq088.gif",
"[月亮]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq089.gif",
"[太阳]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq090.gif",
"[礼物]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq091.gif",
"[抱抱]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq092.gif",
"[喝彩]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq93.gif",
"[祈祷]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq94.gif",
"[棒棒糖]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq95.gif",
"[药]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq96.gif",
"[赞]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq097.gif",
"[差劲]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq098.gif",
"[握手]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq099.gif",
"[胜利]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq100.gif",
"[抱拳]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq101.gif",
"[勾引]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq102.gif",
"[拳头]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq103.gif",
// "[差劲]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq104.gif",
"[爱你]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq105.gif",
"[NO]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq106.gif",
"[OK]": "https://cdn-bbs.mt2.cn/static/image/smiley/qq/qq107.gif",
"[#呵呵]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_1.png",
"[#滑稽]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_10.png",
"[#吐舌]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_3.png",
"[#哈哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_2.png",
"[#啊]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_23.png",
"[#酷]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_22.png",
"[#怒]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_13.png",
"[#开心]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_39.png",
"[#汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_14.png",
"[#泪]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_16.png",
"[#黑线]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_15.png",
"[#鄙视]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_21.png",
"[#不高兴]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_12.png",
"[#真棒]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_17.png",
"[#钱]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_40.png",
"[#疑问]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_26.png",
"[#阴险]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_20.png",
"[#吐]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_34.png",
"[#咦]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_41.png",
"[#委屈]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_29.png",
"[#花心]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_6.png",
"[#呼~]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_42.png",
"[#激动]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_5.png",
"[#冷]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_43.png",
"[#可爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_4.png",
"[#What?]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_25.png",
"[#勉强]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_38.png",
"[#狂汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_24.png",
"[#酸爽]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_27.png",
"[#乖]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_8.png",
"[#雅美蝶]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_28.png",
"[#睡觉]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_31.png",
"[#惊哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_19.png",
"[#哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_44.png",
"[#笑尿]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_32.png",
"[#惊讶]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_30.png",
"[#小乖]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_7.png",
"[#喷]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_18.png",
"[#抠鼻]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_33.png",
"[#捂嘴笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_9.png",
"[#你懂的]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_11.png",
"[#犀利]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_35.png",
"[#小红脸]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_36.png",
"[#懒得理]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_37.png",
"[#爱心]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_45.png",
"[#心碎]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_46.png",
"[#玫瑰]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_47.png",
"[#礼物]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_48.png",
"[#彩虹]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_49.png",
"[#太阳]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_50.png",
"[#月亮]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_51.png",
"[#钱币]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_52.png",
"[#咖啡]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_53.png",
"[#蛋糕]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_54.png",
"[#大拇指]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_55.png",
"[#胜利]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_56.png",
"[#爱你]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_57.png",
"[#OK]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_58.png",
"[#弱]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_59.png",
"[#沙发]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_60.png",
"[#纸巾]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_61.png",
"[#香蕉]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_62.png",
"[#便便]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_63.png",
"[#药丸]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_64.png",
"[#红领巾]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_65.png",
"[#蜡烛]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_66.png",
"[#三道杠]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_67.png",
"[#音乐]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_68.png",
"[#灯泡]": "https://cdn-bbs.mt2.cn/static/image/smiley/comiis_tb/tb_69.png",
"[doge]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/1.png",
"[doge思考]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/2.png",
"[doge再见]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/3.png",
"[doge生气]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/4.png",
"[doge气哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/5.png",
"[doge笑哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/7.png",
"[doge调皮]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/6.png",
"[doge啊哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/8.png",
"[doge原谅TA]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/9.png",
"[miao]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/10.png",
"[miao思考]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/11.png",
"[miao拜拜]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/12.png",
"[miao生气]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/13.png",
"[miao气哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/14.png",
"[二哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/15.png",
"[摊手]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/19.png",
"[w并不简单]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/20.png",
"[w滑稽]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/21.png",
"[w色]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/22.png",
"[w爱你]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/23.png",
"[w拜拜]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/24.png",
"[w悲伤]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/25.png",
"[w鄙视]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/26.png",
"[w馋嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/27.png",
"[w冷汗]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/28.png",
"[w打哈欠]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/29.png",
"[w打脸]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/30.png",
"[w敲打]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/31.png",
"[w生病]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/32.png",
"[w闭嘴]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/33.png",
"[w鼓掌]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/34.png",
"[w哈哈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/35.png",
"[w害羞]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/36.png",
"[w呵呵]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/37.png",
"[w黑线]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/38.png",
"[w哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/39.png",
"[w调皮]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/40.png",
"[w可爱]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/41.png",
"[w可怜]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/42.png",
"[w酷]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/43.png",
"[w困]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/44.png",
"[w懒得理你]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/45.png",
"[w流泪]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/46.png",
"[w怒]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/47.png",
"[w怒骂]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/48.png",
"[w钱]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/49.png",
"[w亲亲]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/50.png",
"[w傻眼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/51.png",
"[w便秘]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/52.png",
"[w失望]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/53.png",
"[w衰]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/54.png",
"[w睡觉]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/55.png",
"[w思考]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/56.png",
"[w开心]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/57.png",
"[w色舔]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/58.png",
"[w偷笑]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/59.png",
"[w吐]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/60.png",
"[w抠鼻]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/61.png",
"[w委屈]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/62.png",
"[w笑哭]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/63.png",
"[w嘻嘻]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/64.png",
"[w嘘]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/65.png",
"[w阴险]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/66.png",
"[w疑问]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/67.png",
"[w抓狂]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/70.png",
"[w晕]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/69.png",
"[w右哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/68.png",
"[w左哼哼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/71.png",
"[w肥皂]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/77.png",
"[w奥特曼]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/78.png",
"[w草泥马]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/79.png",
"[w兔子]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/80.png",
"[w熊猫]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/81.png",
"[w猪头]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/82.png",
"[w→_→]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/83.png",
"[w给力]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/84.png",
"[w囧]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/85.png",
"[w萌]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/86.png",
"[w神马]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/87.png",
"[w威武]": "https://cdn-bbs.mt2.cn/static/image/smiley/doge/88.png"
};
};
const MTEditorPreview = {
/**
* 内容转换
*/
parseText(text) {
const smiliesDictionaries = MTSmiliesDict();
let attachimgmatch = text.match(/\[attachimg\]([\s\S]+?)\[\/attachimg\]/g);
if (attachimgmatch) {
attachimgmatch.forEach((item) => {
let aimgidMatch = item.match(/\[attachimg\]([\s\S]+?)\[\/attachimg\]/);
let aimg_id = aimgidMatch ? aimgidMatch[aimgidMatch.length - 1] : "";
let imgtitle = domUtils.attr(`#aimg_${aimg_id}`, "title");
let imgsrc = domUtils.attr(`#aimg_${aimg_id}`, "src");
if (!imgsrc) {
imgtitle = "该图片不存在";
}
text = text.replace(
item,
`<span class="comiis_postimg vm"><img loading="lazy" id="aimg_${aimg_id}" src="${imgsrc}" alt="${imgtitle}" title="${imgtitle}"></span>`
);
});
}
let code = text.match(/\[code\]([\s\S]*?)\[\/code\]/g);
if (code) {
code.forEach((item) => {
let match_content = item.match(/\[code\]([\s\S]*?)\[\/code\]/);
let contentAll = match_content ? match_content[match_content.length - 1] : "";
let content = "";
let brSplit = contentAll.split("\n");
if (brSplit.length == 1) {
content = `<li>${contentAll}</li>`;
} else {
Array.from(brSplit).forEach((item2, index) => {
if (index == brSplit.length - 1) {
content = `${content}<li>${item2}</li>`;
} else {
content = `${content}<li>${item2}<br></li>`;
}
});
}
text = text.replace(
item,
`
<div class="comiis_blockcode comiis_bodybg b_ok f_b"><div class="bg_f b_l"><ol>${content}</ol></div></div>`
);
});
}
let url = text.match(/\[url\=[\s\S]*?\]([\s\S]*?)\[\/url\]/g);
if (url) {
url.forEach((item) => {
let urlMatch = item.match(/\[url=([\s\S]*?)\][\s\S]*\[\/url\]/);
let urlNameMatch = item.match(/\[url=[\s\S]*?\]([\s\S]*?)\[\/url\]/);
let _url_ = urlMatch ? urlMatch[urlMatch.length - 1] : "";
let _url_name_ = urlNameMatch ? urlNameMatch[urlNameMatch.length - 1] : "";
text = text.replace(
item,
`<a href="${_url_}" target="_blank">${_url_name_}</a>`
);
});
}
let color = text.match(/\[color\=[\s\S]*?\]([\s\S]*?)\[\/color\]/g);
if (color) {
color.forEach((item) => {
let colorValueMatch = item.match(
/\[color=([\s\S]*?)\][\s\S]*\[\/color\]/
);
let colorTextMatch = item.match(
/\[color=[\s\S]*?\]([\s\S]*?)\[\/color\]/
);
let colorValue = colorValueMatch ? colorValueMatch[colorValueMatch.length - 1] : "";
let colorText = colorTextMatch ? colorTextMatch[colorTextMatch.length - 1] : "";
text = text.replace(
item,
`<font color="${colorValue}">${colorText}</font>`
);
});
}
let size = text.match(/\[size\=[\s\S]*?\]([\s\S]*?)\[\/size\]/g);
if (size) {
size.forEach((item) => {
let sizeValueMatch = item.match(/\[size=([\s\S]*?)\][\s\S]*\[\/size\]/);
let sizeTextMatch = item.match(/\[size=[\s\S]*?\]([\s\S]*?)\[\/size\]/);
let sizeValue = sizeValueMatch ? sizeValueMatch[sizeValueMatch.length - 1] : "";
let sizeText = sizeTextMatch ? sizeTextMatch[sizeTextMatch.length - 1] : "";
text = text.replace(
item,
`<font size="${sizeValue}">${sizeText}</font>`
);
});
}
let img = text.match(/\[img(|\=[\s\S]+?)\]([\s\S]*?)\[\/img\]/g);
if (img) {
img.forEach((item) => {
let widthInfo = null;
let heightInfo = null;
let img_size_match = item.match(/\[img\=([\s\S]+?)\][\s\S]*?\[\/img\]/);
if (img_size_match) {
img_size_match = img_size_match[img_size_match.length - 1].split(",");
widthInfo = img_size_match[0];
heightInfo = img_size_match[1];
}
widthInfo = widthInfo ? widthInfo : "";
heightInfo = heightInfo ? heightInfo : "";
let match_content = item.match(
/\[img\]([\s\S]*?)\[\/img\]|\[img=[\s\S]*?\]([\s\S]*?)\[\/img\]/
);
let content = "";
if (match_content) {
if (match_content[match_content.length - 1] == null) {
content = match_content[match_content.length - 2];
} else {
content = match_content[match_content.length - 1];
}
}
text = text.replace(
item,
`<img loading="lazy" src="${content}" border="0" alt="" width="${widthInfo}" height="${heightInfo}" crossoriginNew="anonymous">`
);
});
}
let hide = text.match(/\[hide\]([\s\S]*?)\[\/hide\]/g);
if (hide) {
hide.forEach((item) => {
let match_content = item.match(/\[hide\]([\s\S]*?)\[\/hide\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(
item,
`<div class="comiis_quote bg_h f_c"><h2 class="f_a">本帖隐藏的内容: </h2>${content}</div>`
);
});
}
let hide2 = text.match(/\[hide=[\s\S]*?\]([\s\S]*?)\[\/hide\]/g);
if (hide2) {
hide2.forEach((item) => {
let match_content = item.match(
/\[hide=([\s\S]*?)\]([\s\S]*?)\[\/hide\]/
);
let other_info = match_content ? match_content[match_content.length - 2] : "";
other_info = other_info.split(",");
let integral_big_can_see = other_info.length == 2 ? other_info[1] : "";
text = text.replace(
item,
`<div class="comiis_quote bg_h f_c">以下内容需要积分高于 ${integral_big_can_see} 才可浏览</div>`
);
});
}
let quote = text.match(/\[quote\]([\s\S]*?)\[\/quote\]/g);
if (quote) {
quote.forEach((item) => {
let match_content = item.match(/\[quote\]([\s\S]*?)\[\/quote\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(
item,
`<div class="comiis_quote bg_h b_dashed f_c"><blockquote><font>回复</font> ${content}</blockquote></div>`
);
});
}
let free = text.match(/\[free\]([\s\S]*?)\[\/free\]/g);
if (free) {
free.forEach((item) => {
let match_content = item.match(/\[free\]([\s\S]*?)\[\/free\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(
item,
`<div class="comiis_quote bg_h f_c"><blockquote>${content}</blockquote></div>`
);
});
}
let strong = text.match(/\[b\]([\s\S]*?)\[\/b\]/g);
if (strong) {
strong.forEach((item) => {
let match_content = item.match(/\[b\]([\s\S]*?)\[\/b\]/i);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(item, `<strong>${content}</strong>`);
});
}
let xhx = text.match(/\[u\]([\s\S]*?)\[\/u\]/g);
if (xhx) {
xhx.forEach((item) => {
let match_content = item.match(/\[u\]([\s\S]*?)\[\/u\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(item, `<u>${content}</u>`);
});
}
let qx = text.match(/\[i\]([\s\S]*?)\[\/i\]/g);
if (qx) {
qx.forEach((item) => {
let match_content = item.match(/\[i\]([\s\S]*?)\[\/i\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(item, `<i>${content}</i>`);
});
}
let strike = text.match(/\[s\]([\s\S]*?)\[\/s\]/g);
if (strike) {
strike.forEach((item) => {
let match_content = item.match(/\[s\]([\s\S]*?)\[\/s\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(item, `<strike>${content}</strike>`);
});
}
let smilies = text.match(/\[([\s\S]+?)\]/g);
if (smilies) {
smilies.forEach((item) => {
let smiliesMatchSrc = smiliesDictionaries[item];
if (smiliesMatchSrc) {
text = text.replace(
item,
`<img loading="lazy" src="${smiliesMatchSrc}" border="0" alt="" smilieid="">`
);
}
});
}
let media = text.match(/\[media=[\s\S]+?\][\s\S]+?\[\/media\]/g);
if (media) {
media.forEach((item) => {
let match_content = item.match(
/\[media=[\s\S]*?\]([\s\S]*?)\[\/media\]/
);
let content = match_content ? match_content[match_content.length - 1] : "";
if (content) {
text = text.replace(
item,
`<ignore_js_op><span><iframe src="${content}" border="0" scrolling="no" framespacing="0" allowfullscreen="true" style="max-width: 100%" width="100%" height="auto" frameborder="no"></iframe></span></ignore_js_op>`
);
}
});
}
let email = text.match(/\[email=[\s\S]+?\][\s\S]+?\[\/email\]/g);
if (email) {
email.forEach((item) => {
let email_match = item.match(/\[email=([\s\S]*?)\][\s\S]*?\[\/email\]/);
let content_match = item.match(
/\[email=[\s\S]*?\]([\s\S]*?)\[\/email\]/
);
let _email_ = email_match.length ? (
// @ts-ignore
email_match[email_match.length - 1]
) : "";
let _content_ = content_match.length ? (
// @ts-ignore
content_match[content_match.length - 1]
) : "";
if (_email_ || _content_) {
text = text.replace(
item,
`<a href="mailto:${_email_}">${_content_}</a>`
);
}
});
}
let align = text.match(/\[align=[\s\S]+?\][\s\S]+?\[\/align\]/g);
if (align) {
align.forEach((item) => {
let align_match = item.match(/\[align=([\s\S]*?)\][\s\S]+?\[\/align\]/);
let content_match = item.match(
/\[align=[\s\S]*?\]([\s\S]+?)\[\/align\]/
);
let _align_ = align_match.length ? (
// @ts-ignore
align_match[align_match.length - 1]
) : "";
let _content_ = content_match.length ? (
// @ts-ignore
content_match[content_match.length - 1]
) : "";
if (_align_ || _content_) {
text = text.replace(
item,
`<div align="${_align_}">${_content_}</div>`
);
}
});
}
let qq = text.match(/\[qq\][\s\S]*?\[\/qq\]/g);
if (qq) {
qq.forEach((item) => {
let match_content = item.match(/\[qq\]([\s\S]*?)\[\/qq\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(
item,
`<a href="http://wpa.qq.com/msgrd?v=3&uin=${content}&site=[Discuz!]&from=discuz&menu=yes" target="_blank"><img loading="lazy" src="static/image/common/qq_big.gif" border="0"></a>`
);
});
}
let td = text.match(/\[td\][\s\S]+?\[\/td\]/g);
if (td) {
td.forEach((item) => {
let match_content = item.match(/\[td\]([\s\S]*?)\[\/td\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(item, `<td>${content}</td>`);
});
}
let tr = text.match(/\[tr\][\s\S]+?\[\/tr\]/g);
if (tr) {
tr.forEach((item) => {
let match_content = item.match(/\[tr\]([\s\S]*?)\[\/tr\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
text = text.replace(item, `<tr>${content}</tr>`);
});
}
let table = text.match(/\[table\][\s\S]+?\[\/table\]/g);
if (table) {
table.forEach((item) => {
let match_content = item.match(/\[table\]([\s\S]*?)\[\/table\]/);
let content = match_content ? match_content[match_content.length - 1] : "";
content = content.replace(/\n/g, "");
text = text.replace(item, `<table>${content}</table>`);
});
}
let list = text.match(/\[list=[\s\S]+?\][\s\S]+?\[\/list\]/g);
if (list) {
list.forEach((item) => {
let list_model_match = item.match(
/\[list=([\s\S]*?)\][\s\S]*?\[\/list\]/
);
let list_content_match = item.match(
/\[list=[\s\S]*?\]([\s\S]*?)\[\/list\]/
);
let list_model = list_model_match ? list_model_match[list_model_match.length - 1] : "";
let list_type = "";
if (list_model === "a") {
list_type = "litype_2";
} else if (list_model === "A") {
list_type = "litype_3";
} else if (list_model.length === 1 && list_model.match(/[0-9]{1}/)) {
list_type = "litype_1";
}
let content = list_content_match ? list_content_match[list_content_match.length - 1] : "";
let li_split = content.split("[*]");
if (li_split.length > 1) {
let newContent = "";
if (li_split[0].replace(/[\s]*/, "") == "") {
li_split = li_split.slice(1);
}
Array.from(li_split).forEach((item2) => {
newContent = `${newContent}<li>${item2}</li>`;
});
content = newContent;
}
content = content.replace(/\n/g, "");
text = text.replace(
item,
`<ul type="${list_model}" class="${list_type}">${content}</ul>`
);
});
}
return text;
},
/**
* 投票的内容转换
*/
parseVoteText() {
let chooseColor = [
"rgb(233, 39, 37)",
"rgb(242, 123, 33)",
"rgb(242, 166, 31)",
"rgb(90, 175, 74)",
"rgb(66, 196, 245)",
"rgb(0, 153, 204)",
"rgb(51, 101, 174)",
"rgb(42, 53, 145)",
"rgb(89, 45, 142)",
"rgb(219, 49, 145)",
"rgb(233, 39, 37)",
"rgb(242, 123, 33)",
"rgb(242, 166, 31)",
"rgb(90, 175, 74)",
"rgb(66, 196, 245)",
"rgb(0, 153, 204)",
"rgb(51, 101, 174)",
"rgb(42, 53, 145)",
"rgb(89, 45, 142)",
"rgb(219, 49, 145)"
];
let chooseContent = $$(
".comiis_polloption_add ul li:first-child div.flex .comiis_input.kmshow[type='text']"
);
let maxchoices = parseInt(domUtils.val("input#maxchoices"));
maxchoices = isNaN(maxchoices) ? 0 : maxchoices;
maxchoices = maxchoices > 0 ? maxchoices : 0;
maxchoices = maxchoices > chooseContent.length ? chooseContent.length : maxchoices;
let polldatas = parseInt(domUtils.val("input#polldatas"));
polldatas = isNaN(polldatas) ? 0 : polldatas;
_unsafeWindow.$("input#visibilitypoll").parent().find(".comiis_checkbox").hasClass("comiis_checkbox_close") ? false : true;
let overt = _unsafeWindow.$("input#overt").parent().find(".comiis_checkbox").hasClass("comiis_checkbox_close") ? false : true;
let html = "";
let choosehtml = "";
chooseContent.forEach((item, index) => {
if (index >= 20) {
return;
}
choosehtml = choosehtml + `
<li class="kmnop">
<input type="${maxchoices > 1 ? "checkbox" : "radio"}">
<label><i class="comiis_font f_d"></i>${item.value}</label>
</li>
<li class="poll_ok cl">
<span class="bg_b">
<em style="width:2%;background-color:${chooseColor[index]}"></em>
</span>
<em style="color:${chooseColor[index]}">0% (0)</em>
</li>`;
});
html = `
<div class="comiis_poll cl comiis_input_style b_t postforum_vote">
<div class="comiis_poll_top">
<i class="comiis_font bg_a f_f"></i>
<h2>${maxchoices > 1 ? '多选投票<em class="f_c"> 最多可选 ' + maxchoices + " 项</em>" : "单选投票"}</h2>
<p class="f_c">共有 0 人参与投票</p>
${polldatas > 0 ? ` <p class="kmbtn">
<span class="bg_e">距结束还有:
${polldatas > 1 ? '<em class="f_a">' + (polldatas - 1) + "</em> 天 " : ""}<em class="f_a">23</em> 小时 <em class="f_a">59</em> 分钟</span>
</p>` : ""}
</div>
<div class="comiis_poll_list comiis_input_style cl">
<ul>
${choosehtml}
</ul>
</div>
<div class="comiis_poll_bottom cl">
<input type="submit" value="提交" class="formdialog comiis_btn kmshow bg_c f_f" disabled>
${overt ? '<div class="comiis_quote bg_h b_dashed f_a"><i class="comiis_font"></i>此为公开投票,其他人可看到您的投票项目</div>' : ""}
</div>
</div>
`;
_unsafeWindow.$(".gm_plugin_previewpostforum_html .postforum_vote").remove();
_unsafeWindow.$(".gm_plugin_previewpostforum_html .comiis_messages.comiis_aimg_show").children().eq(0).before(_unsafeWindow.$(html));
}
};
const MTEditorOptimization = {
$data: {
db: new Utils.indexedDB("mt_full_reply_record", "input_text"),
get type() {
return Router.isPostPublish_voting() ? "post-vote" : "post";
},
get tid() {
return MTUtils.getThreadId(window.location.href);
},
get pid() {
return MTUtils.getPostId(window.location.href);
}
},
$key: {
/** 尚未发布、尚未存入草稿的序列化内容 */
noPublishSerializeText: "mt-editor-no-publish-serialize-text",
/** 尚未发布、尚未存入草稿的序列化投票内容 */
noPublishVotingSerializeText: "mt-editor-no-publish-voting-serialize-text"
},
$el: {
/** 标题框 */
$title: null,
/** 输入框 */
$input: null,
/** 表单元素 */
$form: null
},
init() {
log.info(`编辑器优化`);
addStyle(optimizationCSS);
this.overridePageEditor();
},
/**
* 覆盖页面的编辑器
*/
overridePageEditor() {
const that = this;
this.$el.$title = $("#needsubject");
this.$el.$form = $("#postform");
this.$el.$input = $("#needmessage");
domUtils.hide(domUtils.parent(".comiis_scrollTop_box"), false);
domUtils.css("#postform .comiis_post_from.mt15", {
"margin-top": "0px !important"
});
let comiis_post_tab = _unsafeWindow.$(
"#postform .comiis_post_from #comiis_post_tab"
);
_unsafeWindow.$("#postform .comiis_post_from .comiis_post_ico").append(comiis_post_tab);
comiis_post_tab.remove();
_unsafeWindow.textarea_scrollHeight = () => {
};
let comiis_delete = _unsafeWindow.$.fn.comiis_delete;
_unsafeWindow.$.fn.extend({
comiis_delete: function(...args) {
let result = comiis_delete.call(this, ...args);
utils.dispatchEvent(that.$el.$input, "input");
return result;
}
});
domUtils.hide(".comiis_btnbox", false);
this.initVotePage();
_unsafeWindow.$(
".gm_plugin_chartbed .comiis_over_box.comiis_input_style #imglist"
);
addStyle(
/*css*/
`
#imglist_settings button{
font-size: 13.333px;
color: #9baacf;
outline: none;
border: none;
height: 35px;
width: 80px;
border-radius: 10px;
box-shadow: 0.3rem 0.3rem 0.6rem #c8d0e7, -0.2rem -0.2rem 0.5rem #ffffff;
font-weight: 800;
line-height: 40px;
background: #efefef;
padding: 0;
display: flex;
align-items: center;
justify-content: center;
}
#imglist_settings button:active{box-shadow:inset .2rem .2rem .5rem #c8d0e7,inset -.2rem -.2rem .5rem #fff!important;color:#638ffb!important}
`
);
domUtils.attr("#filedata", "multiple", true);
domUtils.remove(".gm_plugin_chartbed .comiis_over_box.comiis_input_style");
domUtils.on(
document,
"#comiis_pictitle_key li",
"click",
function() {
domUtils.removeClass("#comiis_pictitle_key li", "bg_f");
domUtils.addClass(this, "bg_f");
_unsafeWindow.$(".gm_plugin_chartbed .comiis_upbox").hide().eq(_unsafeWindow.$(this).index()).fadeIn();
}
);
let top_height = parseInt(domUtils.css("#comiis_head", "height")) || 0;
let fatie_toupiao = parseInt(domUtils.css("#comiis_sub", "height")) || 0;
let extra_margin_bottom = $("#pollm_c_1") ? 60 : 0;
let title_height = parseInt(domUtils.css(".comiis_styli.comiis_flex", "height")) || 0;
let nav_bottom_height = parseInt(
domUtils.css(".comiis_post_ico.comiis_minipost_icot", "height")
) || 0;
domUtils.css(
"#needmessage",
"height",
`${window.screen.height - top_height - fatie_toupiao - 48 - title_height - nav_bottom_height - 10}px`
);
domUtils.css("#needmessage", "marginBottom", extra_margin_bottom + "px");
if (Router.isPostPublish_edit() && domUtils.val("#needsubject") === "") {
domUtils.hide(".comiis_styli.comiis_flex", false);
} else {
domUtils.attr(
"#needsubject",
"placeholder",
"请输入完整的帖子标题 (1-80个字)"
);
}
domUtils.attr("#needmessage", "placeholder", "来吧,尽情发挥吧...");
if (typeof _unsafeWindow.comiis_addsmilies == "function") {
_unsafeWindow.comiis_addsmilies = (_str_) => {
_unsafeWindow.$("#needmessage").comiis_insert(_str_);
_unsafeWindow.$("#needmessage")[0].dispatchEvent(new Event("input"));
};
}
if (PopsPanel.getValue(
"mt-forum-post-editorOptimizationNormal-recordInputText"
) || PopsPanel.getValue("mt-forum-post-editorOptimization-recordInputText")) {
this.setInputChangeEvent();
this.initReplyText();
}
this.initDeleteBtn();
this.initSaveDraftBtn();
this.initSaveBtn();
this.initPostBtn();
this.initReplyBtn();
this.observerChangeEditorHeight();
this.listenResize();
this.initSelectPostingSection();
this.initUBB();
this.initImage();
this.initPreview();
this.initCharacterCount();
this.initSettingImmersionMode();
},
/**
* 把存储回复框的内容设置到输入框中
*/
async initReplyText() {
const that = this;
let data = null;
let save_callback = null;
let delete_callback = null;
if (Router.isPostPublish_newthread()) {
log.info(`新发布帖子的页面`);
if (Router.isPostPublish_voting()) {
log.info(`投票页面`);
data = _GM_getValue(
this.$key.noPublishVotingSerializeText
);
delete_callback = () => {
_GM_deleteValue(that.$key.noPublishVotingSerializeText);
};
} else {
log.info(`普通帖子页面`);
data = _GM_getValue(this.$key.noPublishSerializeText);
delete_callback = () => {
_GM_deleteValue(this.$key.noPublishSerializeText);
};
}
} else if (Router.isPostPublish_edit()) {
log.info(`草稿的页面`);
log.info(
`type:${this.$data.type} tid:${this.$data.tid} pid:${this.$data.pid}`
);
let initResult = await this.$data.db.get("data");
if (initResult.code === 201) {
await this.$data.db.save("data", []);
}
let queryResult = await this.$data.db.get("data");
if (queryResult.data) {
let findValue = queryResult.data.find((item) => {
if (item.type !== that.$data.type) {
return;
}
if (item.tid !== that.$data.tid || item.pid !== that.$data.pid) {
return;
}
return true;
});
if (findValue) {
data = findValue.data;
delete_callback = async () => {
let deleteQuery = await this.$data.db.get(
"data"
);
if (deleteQuery.data) {
let deleteFindIndex = deleteQuery.data.findIndex((item) => {
if (item.type !== that.$data.type) {
return;
}
if (item.tid !== that.$data.tid || item.pid !== that.$data.pid) {
return;
}
return true;
});
if (deleteFindIndex != -1) {
deleteQuery.data.splice(deleteFindIndex, 1);
await this.$data.db.save(
"data",
deleteQuery.data
);
}
}
};
}
}
} else if (Router.isPostPublish_reply()) {
log.info(`回复页面`);
if (PopsPanel.getValue(
"mt-forum-post-editorOptimizationNormal-recordInputText"
)) {
let initResult = await MTEditorOptimizationNormal.$data.db.get("data");
if (initResult.code === 201) {
await this.$data.db.save("data", []);
}
let queryResult = await MTEditorOptimizationNormal.$data.db.get("data");
if (queryResult.data) {
let findValue = queryResult.data.find((item) => {
return item.forumId === that.$data.tid && item.repquote === MTUtils.getRepquote(window.location.href);
});
if (findValue) {
data = findValue;
}
}
}
}
if (!data) {
return;
}
if (Router.isPostPublish_voting()) {
save_callback = () => {
let $title = that.$el.$form.querySelector(
"input[name='subject']"
);
let $content = that.$el.$form.querySelector(
"textarea[name='message']"
);
let $maxchoices = that.$el.$form.querySelector(
"input[name='maxchoices']"
);
let $expiration = that.$el.$form.querySelector(
"input[name='expiration']"
);
let $visibilitypoll = that.$el.$form.querySelector(
"input[name='visibilitypoll']"
);
let $overt = that.$el.$form.querySelector(
"input[name='overt']"
);
domUtils.val($title, data.title);
domUtils.val($content, data.content);
domUtils.val($maxchoices, data.maxchoices);
domUtils.val($expiration, data.expiration);
domUtils.val(
$visibilitypoll,
data.visibilitypoll
);
domUtils.val($overt, data.overt);
utils.dispatchEvent($title, "input");
utils.dispatchEvent($content, "input");
utils.dispatchEvent($maxchoices, "input");
utils.dispatchEvent($expiration, "input");
utils.dispatchEvent($visibilitypoll, "input");
utils.dispatchEvent($overt, "input");
return true;
};
} else {
if (Router.isPostPublish_reply()) {
save_callback = () => {
let $content = that.$el.$form.querySelector(
"textarea[name='message']"
);
domUtils.val($content, data.text);
utils.dispatchEvent($content, "input");
return true;
};
} else {
save_callback = () => {
let $title = that.$el.$form.querySelector(
"input[name='subject']"
);
let $content = that.$el.$form.querySelector(
"textarea[name='message']"
);
domUtils.val($title, data.title);
domUtils.val($content, data.content);
utils.dispatchEvent($title, "input");
utils.dispatchEvent($content, "input");
return true;
};
}
}
if (Router.isPostPublish_newthread()) {
log.info(`新发布帖子的页面`);
if (typeof save_callback === "function") {
save_callback();
}
} else if (Router.isPostPublish_edit()) {
log.info(`草稿的页面`);
if (typeof save_callback === "function" && typeof delete_callback === "function") {
__pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: "<p>存在历史写入的数据,是否恢复到编辑器里?</p>",
html: true
},
btn: {
merge: true,
position: "space-between",
ok: {
text: "恢复",
callback: async (details) => {
if (await save_callback()) {
Qmsg.success("恢复成功");
details.close();
}
}
},
other: {
enable: true,
type: "danger",
text: "删除该数据",
callback: async (details) => {
await delete_callback();
details.close();
Qmsg.success("删除成功");
}
}
},
width: "300px",
height: "200px"
});
}
} else if (Router.isPostPublish_reply()) {
log.info(`回复页面`);
if (typeof save_callback === "function") {
save_callback();
}
}
},
/**
* 获取回复记录的占用空间
*/
async getReplyRecordSize() {
var _a2;
let result = await this.$data.db.get("data");
if (result.success) {
let size = utils.getTextStorageSize(
((_a2 = result == null ? void 0 : result.data) == null ? void 0 : _a2.length) ? JSON.stringify(result.data) : ""
);
return size;
} else {
return utils.formatByteToSize(0);
}
},
/**
* 清空所有的回复记录
*/
async clearAllReplyRecord() {
return await this.$data.db.deleteAll();
},
/**
* 删除存储的数据
*/
deleteReplyTextStorage() {
const that = this;
this.$data.db.get("data").then((result) => {
if (!result.success) {
console.warn(result);
return;
}
let type = Router.isPostPublish_voting() ? "post-vote" : "post";
let tid = MTUtils.getThreadId(window.location.href);
let pid = MTUtils.getPostId(window.location.href);
let localDataIndex = result.data.findIndex((item) => {
if (item.type !== type) {
return;
}
if (item.tid !== tid || item.pid !== pid) {
return;
}
return true;
});
if (localDataIndex !== -1) {
result.data.splice(localDataIndex, 1);
that.$data.db.save("data", result.data).then((result2) => {
});
}
});
},
/**
* 监听输入框内容改变
*/
setInputChangeEvent() {
const that = this;
domUtils.on(
[this.$el.$input, this.$el.$title].filter(Boolean),
["input", "propertychange"],
function(event) {
let data = null;
if (Router.isPostPublish_voting()) {
let $title = that.$el.$form.querySelector(
"input[name='subject']"
);
let $content = that.$el.$form.querySelector(
"textarea[name='message']"
);
let $maxchoices = that.$el.$form.querySelector(
"input[name='maxchoices']"
);
let $expiration = that.$el.$form.querySelector(
"input[name='expiration']"
);
let $visibilitypoll = that.$el.$form.querySelector(
"input[name='visibilitypoll']"
);
let $overt = that.$el.$form.querySelector(
"input[name='overt']"
);
data = {
title: $title.value,
maxchoices: $maxchoices.value,
expiration: $expiration.value,
visibilitypoll: $visibilitypoll.checked,
overt: $overt.checked,
content: $content.value
};
} else {
let $title = that.$el.$form.querySelector(
"input[name='subject']"
);
let $content = that.$el.$form.querySelector(
"textarea[name='message']"
);
data = {
title: $title == null ? void 0 : $title.value,
content: $content.value
};
}
if (Router.isPostPublish_newthread()) {
log.info(`内容改变 ==> 新发布帖子的页面`);
if (Router.isPostPublish_voting()) {
_GM_setValue(that.$key.noPublishVotingSerializeText, data);
} else {
_GM_setValue(that.$key.noPublishSerializeText, data);
}
} else if (Router.isPostPublish_edit()) {
log.info(`内容改变 ==> 草稿的页面`);
that.$data.db.get("data").then((result) => {
if (!result.success) {
console.warn(result);
return;
}
let localDataIndex = result.data.findIndex((item) => {
if (item.type !== that.$data.type) {
return;
}
if (item.tid !== that.$data.tid || item.pid !== that.$data.pid) {
return;
}
return true;
});
if (localDataIndex !== -1) {
result.data.splice(localDataIndex, 1);
}
result.data.push({
url: window.location.href,
data,
pid: that.$data.pid,
tid: that.$data.tid,
type: that.$data.type
});
that.$data.db.save("data", result.data).then((result2) => {
});
});
} else if (Router.isPostPublish_reply()) {
log.info(`内容改变 ==> 回复页面`);
PopsPanel.execMenu(
"mt-forum-post-editorOptimizationNormal-recordInputText",
() => {
MTEditorOptimizationNormal.$data.db.get("data").then((result) => {
if (!result.success || result.code === 201) {
console.warn(result);
return;
}
let localDataIndex = result.data.findIndex((item) => {
return item.forumId === that.$data.tid && item.repquote === MTUtils.getRepquote(window.location.href);
});
if (localDataIndex !== -1) {
if (data.content == null || data.content === "") {
result.data.splice(localDataIndex, 1);
} else {
result.data[localDataIndex] = utils.assign(
result.data[localDataIndex],
{
text: data.content
}
);
}
} else {
result.data.push({
forumId: that.$data.tid,
url: window.location.href,
repquote: MTUtils.getRepquote(window.location.href),
text: data.content
});
}
MTEditorOptimizationNormal.$data.db.save("data", result.data).then((result2) => {
});
});
}
);
}
}
);
},
/**
* 初始化删除按钮
*/
initDeleteBtn() {
let btn_del = $(".comiis_btnbox .comiis_btn.bg_del");
if (!btn_del) {
return;
}
let $header = $("#comiis_head .header_y");
let $btn = domUtils.createElement(
"input",
{
className: "new_btn_del"
},
{
type: "button",
value: "删除"
}
);
domUtils.append($header, $btn);
domUtils.on($btn, "click", function() {
__pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: "<p>是否删除帖子?</p>",
html: true
},
btn: {
ok: {
callback: (details) => {
details.close();
_unsafeWindow.comiis_delthread();
}
}
},
width: "300px",
height: "200px"
});
});
},
/**
* 初始化保存按钮
*/
initSaveBtn() {
let $save = domUtils.selector(
".comiis_btnbox button#postsubmit:contains('保存')"
);
if (!$save) {
return;
}
if (domUtils.text($save).includes("草稿")) {
return;
}
let $header = $("#comiis_head .header_y");
let $btn = domUtils.createElement(
"input",
{
className: "new_btn_save"
},
{
type: "button",
value: "保存"
}
);
domUtils.append($header, $btn);
domUtils.on($btn, "click", function() {
$save.click();
});
},
/**
* 初始化发表按钮
*/
initPostBtn() {
let $post = domUtils.selector(
".comiis_btnbox button#postsubmit:contains('发表')"
);
if (!$post) {
return;
}
let $header = $("#comiis_head .header_y");
let $btn = domUtils.createElement(
"input",
{
className: "new_btn_post"
},
{
type: "button",
value: "发表"
}
);
domUtils.append($header, $btn);
domUtils.on($btn, "click", function() {
domUtils.val("#postsave", 0);
$post.click();
});
},
/**
* 初始化回复按钮
*/
initReplyBtn() {
const that = this;
let $reply = domUtils.selector(
".comiis_btnbox button#postsubmit:contains('回复')"
);
if (!$reply) {
return;
}
let $header = $("#comiis_head .header_y");
let $btn = domUtils.createElement(
"input",
{
className: "new_btn_reply"
},
{
type: "button",
value: "回复"
}
);
domUtils.append($header, $btn);
domUtils.on($btn, "click", function() {
$reply.click();
that.deleteReplyTextStorage();
});
},
/**
* 初始化投票页面
*/
initVotePage() {
if (!$$(".comiis_scrollTop_box").length) {
return;
}
_unsafeWindow.$("#htmlon").parent().append(
/*html*/
`
<li class="comiis_styli_m f15 comiis_flex b_b">
<div class="flex">发表帖子</div>
<div class="styli_r">
<input type="checkbox" name="usesig" value="1" class="comiis_checkbox_key">
<label for="" class="wauto">
<code class="bg_f b_ok comiis_checkbox comiis_choose_post comiis_checkbox_close"></code>
</label>
</div>
</li>
<li class="comiis_styli_m f15 comiis_flex b_b">
<div class="flex">发投票</div>
<div class="styli_r">
<input type="checkbox" name="usesig" value="1" class="comiis_checkbox_key">
<label for="" class="wauto">
<code class="bg_f b_ok comiis_checkbox comiis_choose_vote comiis_checkbox_close"></code>
</label>
</div>
</li>
`
);
if (_unsafeWindow.$(".comiis_scrollTop_box .swiper-slide a:contains('发表帖子')").attr("class") != "f_c") {
_unsafeWindow.$(".comiis_checkbox.comiis_choose_post").removeClass("comiis_checkbox_close");
} else {
_unsafeWindow.$(".comiis_checkbox.comiis_choose_vote").removeClass("comiis_checkbox_close");
}
_unsafeWindow.$(".comiis_checkbox.comiis_choose_post").on("click", function() {
let obj = _unsafeWindow.$(this);
obj.addClass("comiis_checkbox_close");
_unsafeWindow.$(".comiis_checkbox.comiis_choose_vote").addClass("comiis_checkbox_close");
obj.removeClass("comiis_checkbox_close");
window.location.href = window.location.href.replace("&special=1", "");
});
_unsafeWindow.$(".comiis_checkbox.comiis_choose_vote").on("click", function() {
let obj = _unsafeWindow.$(this);
obj.addClass("comiis_checkbox_close");
_unsafeWindow.$(".comiis_checkbox.comiis_choose_post").addClass("comiis_checkbox_close");
obj.removeClass("comiis_checkbox_close");
window.location.href = window.location.href + "&special=1";
});
},
/**
* 初始化保存草稿按钮
*/
initSaveDraftBtn() {
let $saveDraft = domUtils.selector(
".comiis_btnbox button#postsubmit em:contains('保存草稿')"
);
if (!$saveDraft) {
return;
}
let $header = $("#comiis_head .header_y");
let $btn = domUtils.createElement(
"input",
{
className: "new_btn_save_temp"
},
{
type: "button",
value: "保存草稿"
}
);
$("#needsubject");
domUtils.append($header, $btn);
domUtils.selector(
".comiis_scrollTop_box .swiper-slide a:contains('发表帖子')"
);
domUtils.on($btn, "click", function() {
$saveDraft.click();
});
},
/**
* 动态修改编辑器的高度
*/
observerChangeEditorHeight() {
var recordHeight = 0;
utils.waitNode("#postform > div > div.comiis_post_ico.comiis_minipost_icot").then((element) => {
utils.mutationObserver(element, {
callback: (mutations) => {
var $tar = $(
"#postform > div > div.comiis_post_ico.comiis_minipost_icot"
);
let height = window.getComputedStyle($tar).getPropertyValue("height");
if (height.toString() === recordHeight.toString()) {
return;
}
recordHeight = parseInt(height);
let needMessageSeeHeight = document.documentElement.clientHeight - $(
"#postform > div > div.comiis_post_ico.comiis_minipost_icot"
).getBoundingClientRect().height - $("#needmessage").getBoundingClientRect().top;
if (needMessageSeeHeight - 5 < 100) {
_unsafeWindow.$("#needmessage").css("height", "100px");
_unsafeWindow.$(
".gm_plugin_previewpostforum_html.double-preview .comiis_over_box"
).css("height", "100px");
} else {
_unsafeWindow.$("#needmessage").css("height", needMessageSeeHeight - 5 + "px");
_unsafeWindow.$(
".gm_plugin_previewpostforum_html.double-preview .comiis_over_box"
).css("height", needMessageSeeHeight - 5 + "px");
}
},
config: {
childList: true,
/* 属性的变动 */
attributes: true,
/* 节点内容或节点文本的变动 */
characterData: true,
/* 是否将观察器应用于该节点的所有后代节点 */
subtree: true
}
});
});
},
/**
* 监听窗口大小变化
*/
listenResize() {
domUtils.on(window, "resize", function() {
let needMessageSeeHeight = document.documentElement.clientHeight - $(
"#postform > div > div.comiis_post_ico.comiis_minipost_icot"
).getBoundingClientRect().height - $("#needmessage").getBoundingClientRect().top;
if (needMessageSeeHeight - 5 < 100) {
domUtils.css("#needmessage", "height", "100px");
domUtils.css(
".gm_plugin_previewpostforum_html.double-preview .comiis_over_box",
"height",
"100px"
);
} else {
log.info("设置输入框、预览高度", needMessageSeeHeight - 5);
domUtils.css("#needmessage", "height", needMessageSeeHeight - 5 + "px");
domUtils.css(
".gm_plugin_previewpostforum_html.double-preview .comiis_over_box",
"height",
needMessageSeeHeight - 5 + "px"
);
}
});
},
/**
* 注入选择板块功能
*/
initSelectPostingSection() {
addStyle(
/*css*/
`
#select-post-section {
height: 28px;
width: 160px;
line-height: 28px;
border: 1px solid #ececec;
background: url(w.png) no-repeat;
background-position: 95% 50%;
-webkit-appearance: none;
appearance: none;
-moz-appearance: none;
}
`
);
let section_dict = {
2: "版本发布",
37: "插件交流",
38: "建议反馈",
41: "逆向交流",
39: "玩机交流",
42: "编程开发",
40: "求助问答",
44: "综合交流",
50: "休闲灌水",
46: "官方公告",
53: "申诉举报",
92: "站务专区"
};
domUtils.before(
".comiis_post_from .comiis_wzpost.comiis_input_style .comiis_styli:contains('标题')",
/*html*/
`
<li class="comiis_styli_section comiis_flex b_b" style="padding: 10px 12px;font-size: 16px;">
<div class="styli_section f_c" style="padding-right: 8px;vertical-align: top;">板块</div>
<div class="flex">
<select id="select-post-section" style="vertical-align:top;border-color:transparent;font-size: 17px;font-weight: 300;text-overflow:ellipsis;white-space:nowrap;">
<option value="2">版本发布</option>
<option value="37">插件交流</option>
<option value="38">建议反馈</option>
<option value="39">玩机交流</option>
<option value="40">求助问答</option>
<option value="41">逆向交流</option>
<option value="42">编程开发</option>
<option value="44">综合交流</option>
<option value="46">官方公告</option>
<option value="50">休闲灌水</option>
<option value="53">申诉举报</option>
<option value="92">站务专区</option>
</select>
</div>
</li>
`
);
let $select = $(`#select-post-section`);
let currentSection = MTUtils.getForumId(window.location.href);
if (Router.isPostPublish_newthread()) {
log.info(`发帖`);
domUtils.on($select, "change", function() {
let fid = domUtils.val($select);
let postSection = `forum.php?mod=post&action=newthread&fid=${fid}&extra=&topicsubmit=yes&mobile=2`;
log.info(`修改发帖板块: ${section_dict[fid]} ${postSection}`);
let classifyClassNameDict = {
求助问答: {
className: "gm_user_select_help",
optionHTML: `<option value="0" selected="selected">请选择</option>
<option value="59">求助问答</option>
<option value="58">已解决</option>`
},
建议反馈: {
className: "gm_user_select_feedback",
optionHTML: `<option value="0" selected="selected">请选择</option>
<option value="62">BUG反馈</option>
<option value="63">意见反馈</option>
<option value="65">论坛问题</option>
<option value="64">已解决</option>`
},
站务专区: {
className: "gm_user_select_depot",
optionHTML: `<option value="0" selected="selected">请选择</option>
<option value="42">版主申请</option>
<option value="43">职位调整</option>`
}
};
let otherSelect = classifyClassNameDict[section_dict[fid]];
if (otherSelect) {
domUtils.remove(
domUtils.parent(".comiis_post_from .styli_tit:contains('分类')")
);
domUtils.before(
".comiis_stylino.comiis_needmessage",
/*html*/
`
<li class="comiis_styli comiis_flex b_b ${otherSelect["className"]}">
<div class="styli_tit f_c">分类</div>
<div class="flex comiis_input_style">
<div class="comiis_login_select">
<span class="inner">
<i class="comiis_font f_d"></i>
<span class="z">
<span class="comiis_question" id="typeid_name">请选择</span>
</span>
</span>
<select id="typeid" name="typeid">
${otherSelect["optionHTML"]}
</select>
</div>
</div>
</li>
`
);
} else {
Object.keys(classifyClassNameDict).forEach((key) => {
domUtils.remove(
".comiis_post_from ." + classifyClassNameDict[key]["className"]
);
});
}
domUtils.attr("#postform", "action", postSection);
});
} else {
domUtils.attr($select, "disabled", true);
}
domUtils.val($select, currentSection);
domUtils.trigger($select, "change");
},
/**
* 字符计数
*/
initCharacterCount() {
log.info(`添加功能:字符计数`);
addStyle(
/*css*/
`
.gm_plugin_word_count{display:flex}
.gm_plugin_word_count::after{content:"/20000"}
`
);
domUtils.append(
"#comiis_mh_sub .swiper-wrapper.comiis_post_ico",
/*html*/
`
<a href="javascript:;" class="swiper-slide gm_plugin_word_count">
<p>0</p>
</a>`
);
domUtils.on(this.$el.$input, ["input", "propertychange"], (event) => {
let userInputText = this.$el.$input.value;
let userInputTextLength = utils.getTextLength(userInputText);
let parsedText = MTEditorPreview.parseText(userInputText);
domUtils.html(
".gm_plugin_previewpostforum_html .comiis_message_table",
parsedText
);
let wordCountDom = $(".gm_plugin_word_count p");
domUtils.text(wordCountDom, userInputTextLength);
if (userInputTextLength > 2e4 || userInputTextLength < 10) {
domUtils.attr(wordCountDom, "style", "color: red;");
} else {
domUtils.attr(wordCountDom, "style", "");
}
});
},
/**
* 自定义的其它ubb
*/
initUBB() {
if (!$(".comiis_post_urlico")) {
log.error("未找到插入元素");
return;
}
addStyle(
/*css*/
`
#comiis_post_tab .comiis_input_style .comiis_post_urlico li a.f_0{
color: #53bcf5 !important;
}
`
);
let ubbCode = MTQuickUBB();
let parentEle = $(".comiis_post_urlico > ul");
let contentEle = $("#comiis_post_qydiv > ul");
let childNums = $$("#comiis_post_qydiv ul li").length;
ExtendJQueryFn();
domUtils.on(
"#comiis_post_tab .comiis_input_style .comiis_post_urlico li",
"click",
function() {
domUtils.removeClass(
"#comiis_post_tab .comiis_input_style .comiis_post_urlico li a",
"f_0"
);
domUtils.addClass(
"#comiis_post_tab .comiis_input_style .comiis_post_urlico li a",
"f_d"
);
domUtils.attr(this.querySelector("a"), "class", "comiis_xifont f_0");
_unsafeWindow.$("#comiis_post_qydiv ul li").hide().eq(_unsafeWindow.$(this).index()).fadeIn();
}
);
_unsafeWindow.$.each(ubbCode, function(key, value) {
let $ubbs = domUtils.createElement("li", {
className: "quickUBBs",
innerHTML: (
/*html*/
`
<a href="javascript:;" class="comiis_xifont f_d"><i class="comiis_font"></i>${value["key"]}</a>
`
)
});
domUtils.on($ubbs, "click", (event) => {
let bottomEle = $(
`#comiis_post_qydiv li[data-key='${value.key}']`
);
if (!bottomEle) {
log.error("未找到该元素");
return;
}
$$(
"#comiis_post_tab div.comiis_post_urlico ul li a.comiis_xifont"
).forEach(($ele) => {
$ele.className = "comiis_xifont f_d";
});
let $childAnchor = $ubbs.querySelector("a");
$childAnchor.className = "comiis_xifont f_0";
let contentIndex = childNums + Object.keys(ubbCode).indexOf(key);
_unsafeWindow.$("#comiis_post_qydiv ul li").hide().eq(contentIndex).fadeIn();
});
domUtils.append(parentEle, $ubbs);
let ubbs_content = document.createElement("li");
ubbs_content.setAttribute("style", "display: none;");
ubbs_content.setAttribute("data-key", value["key"]);
ubbs_content.innerHTML = /*html*/
`
<div class="comiis_styli_m f15" style="padding-top:12px;">
<div class="bg_e comiis_p5" style="border-radius:4px">
<textarea class="comiis_pt kmshow f_c" id="comiis_input_${key}" style="font-size:15px" placeholder="请输入需要${value["key"]}的文字"></textarea>
</div>
</div>
<div class="comiis_styli_m f15 comiis_flex" style="padding-top:0;">
<div class="styli_tit">
<button class="comiis_sendbtn bg_0 f_f" data-keyI="${key}" type="button">插入</button>
</div>
<div class="flex"></div>
</div>`;
domUtils.append(contentEle, ubbs_content);
domUtils.on(`.comiis_sendbtn[data-keyI="${key}"]`, "click", () => {
let text = _unsafeWindow.$(`#comiis_input_${key}`).val();
if (text == "") {
Qmsg.warning("请输入需要插入的内容");
return;
}
let currentUBBObj = ubbCode[key];
if (currentUBBObj["isFunc"]) {
text = MTUBB_Rainbow(currentUBBObj["num"], text);
}
if (currentUBBObj.hasOwnProperty("L")) {
text = currentUBBObj["L"] + text + currentUBBObj["R"];
}
_unsafeWindow.$("#needmessage").insertAtCaret(text);
if (currentUBBObj.hasOwnProperty("cursorL")) {
_unsafeWindow.$("#needmessage").moveCursorToCenterByTextWithLeft(
currentUBBObj["cursorL"],
currentUBBObj["cursorLength"]
);
}
if (currentUBBObj.hasOwnProperty("cursorR")) {
_unsafeWindow.$("#needmessage").moveCursorToCenterByTextWithRight(
currentUBBObj["cursorR"],
currentUBBObj["cursorLength"]
);
}
});
});
},
/**
* 图片功能
*/
initImage() {
log.info(`添加功能:图片`);
addStyle(
/*css*/
`
#comiis_pictitle_tab .comiis_upbox{
height: 140px;
overflow-y: auto;
}
`
);
let imageBtnHTML = (
/*html*/
`
<a href="javascript:;" class="comiis_pictitle"><i class="comiis_font"><em>图片</em></i></a>`
);
domUtils.append(
"#comiis_mh_sub .swiper-wrapper.comiis_post_ico",
imageBtnHTML
);
domUtils.on(
".comiis_pictitle",
"click",
function(event) {
let $click = this;
let $font = $click.querySelector("i.comiis_font");
if (!$font.classList.contains("f_0")) {
domUtils.show(".gm_plugin_chartbed", false);
} else {
domUtils.hide(".gm_plugin_chartbed", false);
}
}
);
domUtils.append(
"#comiis_post_tab",
/*html*/
`
<div id="comiis_pictitle_tab" class="gm_plugin_chartbed" style="display: none">
<!-- <div class="comiis_upbox bg_f cl">
<ul id="mt-imglist" class="comiis_post_imglist cl">
<li class="up_btn">
<a href="javascript:;" class="bg_e b_ok f_d">
<i class="comiis_font"></i>
</a>
</li>
</ul>
</div> -->
<div class="bqbox_t">
<ul id="comiis_pictitle_key">
<li class="bg_f" id="comiis_pictitle_tab_n_1"><a href="javascript:;" class="">论坛</a></li>
</ul>
</div>
</div>
`
);
let originImageList = $("#imglist");
let originImageListParent = domUtils.parent(originImageList);
domUtils.before(".gm_plugin_chartbed .bqbox_t", originImageListParent);
domUtils.on("#imglist .comiis_font", "click", (event) => {
$("#filedata").click();
});
domUtils.on(
"#comiis_pictitle_tab #comiis_pictitle_key",
"click",
"li",
function(event) {
let $click = event.target;
domUtils.removeClass(
"#comiis_pictitle_tab #comiis_pictitle_key li",
"bg_f"
);
domUtils.addClass($click, "bg_f");
_unsafeWindow.$("#comiis_pictitle_tab div.comiis_upbox").hide().eq(_unsafeWindow.$($click).index()).fadeIn();
}
);
PopsPanel.execMenuOnce("mt-image-bed-hello-enable", () => {
MTEditorImageBed_Hello.init();
});
PopsPanel.execMenuOnce("mt-image-bed-mt-enable", () => {
MTEditorImageBed_MT.init();
});
},
/**
* 双列预览
*/
initPreview() {
const that = this;
log.info(`添加功能:双列预览`);
addStyle(
/*css*/
`
.gm_plugin_previewpostforum_html .comiis_message_table{margin-top:10px;font-weight:initial;line-height:24px}
.gm_plugin_previewpostforum_html .comiis_message_table a{height:auto;float:unset;color:#507daf!important}
.gm_plugin_previewpostforum_html .comiis_message_table i{text-align:unset;font-size:unset;line-height:unset;padding-top:unset;display:unset}
.comiis_postli.comiis_list_readimgs.nfqsqi{width:100vw}
.gm_plugin_previewpostforum_html.double-preview{width:50vw}
.gm_plugin_previewpostforum_html.double-preview .comiis_over_box.comiis_input_style{border-left:1px solid}
`
);
let previewBtnHTML = (
/*html*/
`
<a href="javascript:;" class="swiper-slide gm_plugin_previewpostforum">
<i class="comiis_font" style="display: flex;flex-direction: column;padding-top: 1px;">
<svg t="1661243615511" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2399" width="22" height="22" fill="currentColor">
<path d="M470.1 885.3H208.8V138.7h597.3v336c0 20.6 16.7 37.3 37.3 37.3 20.6 0 37.3-16.7 37.3-37.3v-336c0-41.2-33.4-74.7-74.7-74.7H208.8c-41.2 0-74.7 33.4-74.7 74.7v746.7c0 41.2 33.4 74.7 74.7 74.7h261.3c20.6 0 37.3-16.7 37.3-37.3 0.1-20.8-16.6-37.5-37.3-37.5z" p-id="2400"></path>
<path d="M641.3 496.5c-54.3 0-108.5 23.5-146.2 70.5-54.7 68.3-53.4 168.6 2.8 235.6 37.5 44.8 90.5 67.2 143.4 67.2 35.9 0 71.8-10.3 103-30.9l81.8 81.8c7.3 7.3 16.8 10.9 26.4 10.9 9.6 0 19.1-3.6 26.4-10.9 14.6-14.6 14.6-38.2 0-52.8l-81.8-81.8c48-72.5 40.1-171.1-23.7-234.9-36.5-36.4-84.3-54.7-132.1-54.7z m0 298.7c-36.5 0-72.9-17.6-95.3-52.9-22.6-35.6-22.6-82.5 0-118.1 22.4-35.3 58.9-52.9 95.3-52.9 36.5 0 72.9 17.6 95.3 52.9 22.6 35.6 22.6 82.5 0 118.1-22.4 35.2-58.8 52.9-95.3 52.9z" p-id="2401"></path>
</svg>
<em style="bottom: 1px;position: relative;">预览</em>
</i>
</a>`
);
domUtils.append(
"#comiis_mh_sub .swiper-wrapper.comiis_post_ico",
previewBtnHTML
);
domUtils.css(domUtils.parent(this.$el.$input), "display", "flex");
domUtils.after(
this.$el.$input,
/*html*/
`
<div class="bg_f cl gm_plugin_previewpostforum_html double-preview" style="display: none;">
<div class="comiis_over_box comiis_input_style">
<div class="comiis_postli comiis_list_readimgs nfqsqi" style="width: 50vw;">
<div class="comiis_message bg_f view_one cl message" style="margin-bottom: auto;padding: 0px 12px 0px 12px;">
<div class="comiis_messages comiis_aimg_show cl" style="overflow-y: auto;position: relative;">
<div class="comiis_a comiis_message_table cl" style="margin: 0;"></div>
</div>
</div>
</div>
</div>
</div>`
);
domUtils.on(
".gm_plugin_previewpostforum",
"click",
function(event) {
let $click = this;
if ($$("#polldatas").length) {
MTEditorPreview.parseVoteText();
}
let $font = $click.querySelector("i.comiis_font");
if (!$font.classList.contains("f_0")) {
domUtils.show(".gm_plugin_previewpostforum_html", false);
let parsedText = MTEditorPreview.parseText(
domUtils.val(that.$el.$input)
);
domUtils.html(
".gm_plugin_previewpostforum_html .comiis_message_table",
parsedText
);
domUtils.css(
".gm_plugin_previewpostforum_html.double-preview .comiis_over_box.comiis_input_style",
"height",
domUtils.css(that.$el.$input, "height")
);
} else {
domUtils.hide(".gm_plugin_previewpostforum_html", false);
}
}
);
},
/**
* 初始化设置功能-使用沉浸模式
*/
initSettingImmersionMode() {
log.info(`初始化设置功能-使用沉浸模式`);
domUtils.append(
domUtils.parent("#htmlon"),
/*html*/
`
<li class="comiis_styli_m f15 comiis_flex b_b">
<div class="flex">使用沉浸输入</div>
<div class="styli_r">
<input type="checkbox" name="immersiveinput" id="immersiveinput" value="" class="comiis_checkbox_key">
<label for="immersiveinput" class="wauto">
<code class="bg_f b_ok comiis_checkbox comiis_checkbox_close"></code>
</label>
</div>
</li>
`
);
domUtils.on("#immersiveinput", "click", function() {
let $click = this;
let code_obj = domUtils.parent($click).querySelector(".comiis_checkbox");
let elementList = [
/* 板块、标题 */
".comiis_wzpost ul li.comiis_flex",
/* 回复别人的quote */
".comiis_wzpost ul li.comiis_styli.kmquote",
/* 投票,最多可填写 20 个选项 */
domUtils.parent(domUtils.parent("#pollchecked")),
/* 投票,增加一项 */
"#pollm_c_1",
/* 投票,增加一项(编辑状态下) */
".comiis_polloption_add+div.f_0",
/* 投票,内容 */
".comiis_wzpost ul li.comiis_thread_content:contains('内容')",
/* 顶部header */
"div#comiis_head",
/* 后面的 */
"div#comiis_head+*:not([class])"
];
if (domUtils.hasClass(code_obj, "comiis_checkbox_close")) {
elementList.forEach(($ele) => {
$ele && domUtils.hide($ele, false);
});
} else {
elementList.forEach(($ele) => {
$ele && domUtils.show($ele, false);
});
}
window.dispatchEvent(new Event("resize"));
});
}
};
const Component_ForumPost = {
id: "component-forum-post",
title: "帖子",
forms: [
{
text: "",
type: "forms",
forms: [
{
text: "功能",
type: "deepMenu",
forms: [
{
text: "",
type: "forms",
forms: [
UISwitch(
"自动展开内容",
"mt-forum-post-autoExpandContent",
true,
void 0,
"注入CSS展开帖子的内容"
),
UISwitch(
"修复图片宽度",
"mt-forum-post-repairImageWidth",
true,
void 0,
"修复图片宽度超出页面宽度的问题"
),
UISwitch(
"移除帖子字体效果",
"mt-forum-post-removeFontStyle",
false,
void 0,
""
),
UISwitch(
"移除评论区的字体效果",
"mt-forum-post-removeCommentFontStyle",
false,
void 0,
""
),
UISwitch(
"添加【点评】按钮",
"mt-forum-post-addCommentOnBtn",
false,
void 0,
"在评论区的每个评论右下角添加按钮"
),
UISwitch(
"附件点击提醒",
"mt-forum-post-setAttachmentsClickTip",
true,
void 0,
"阻止默认点击附件就会触发附件下载"
),
UISwitch(
"代码块优化",
"mt-forum-post-codeQuoteOptimization",
true,
void 0,
"自动检测代码块语言并设置关键字高亮"
),
UISwitch(
"图片查看优化",
"mt-forum-post-optimizationImagePreview",
true,
void 0,
"使用Viewer查看图片"
)
]
}
]
},
{
text: "自动加载评论",
type: "deepMenu",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"自动加载下一页评论",
"mt-forum-post-loadNextPageComment",
true,
void 0,
""
),
UISwitch(
"同步加载的地址",
"mt-forum-post-syncNextPageUrl",
false,
void 0,
"便于刷新页面会停留在当前查看的评论页面"
)
]
}
]
},
{
text: "编辑器-简略版",
type: "deepMenu",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"启用",
"mt-forum-post-editorOptimizationNormal",
true,
void 0,
"优化样式,插入bbcode代码等"
),
UISwitch(
"自动保存输入记录",
"mt-forum-post-editorOptimizationNormal-recordInputText",
true,
void 0,
"当回复时会自动清空记录"
),
UIButton(
"清空回复记录",
"当前占用空间大小:计算中",
"清理",
void 0,
false,
false,
"default",
async (event) => {
let $click = event.target;
let $li = $click.closest("li");
let $desc = $li.querySelector(
".pops-panel-item-left-desc-text"
);
let result = await MTEditorOptimizationNormal.clearAllReplyRecord();
if (result.success) {
Qmsg.success("清理成功");
domUtils.text(
$desc,
`当前占用空间大小:${await MTEditorOptimizationNormal.getReplyRecordSize()}`
);
} else {
Qmsg.error("清理失败 " + result.msg);
}
},
async (formCOnfig, container) => {
let $desc = container.target.querySelector(
".pops-panel-item-left-desc-text"
);
domUtils.text(
$desc,
`当前占用空间大小:${await MTEditorOptimizationNormal.getReplyRecordSize()}`
);
}
)
]
}
]
},
{
text: "编辑器-完整版",
type: "deepMenu",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"启用",
"mt-forum-post-publish-editorOptimization",
true,
void 0,
"优化样式,插入bbcode代码,双列预览等"
),
UISwitch(
"自动保存输入记录",
"mt-forum-post-editorOptimization-recordInputText",
true,
void 0,
"当回复/发表时会自动清空记录"
),
UIButton(
"清空回复记录",
"当前占用空间大小:计算中",
"清理",
void 0,
false,
false,
"default",
async (event) => {
let $click = event.target;
let $li = $click.closest("li");
let $desc = $li.querySelector(
".pops-panel-item-left-desc-text"
);
let result = await MTEditorOptimization.clearAllReplyRecord();
if (result.success) {
Qmsg.success("清理成功");
domUtils.text(
$desc,
`当前占用空间大小:${await MTEditorOptimization.getReplyRecordSize()}`
);
} else {
Qmsg.error("清理失败 " + result.msg);
}
},
async (formCOnfig, container) => {
let $desc = container.target.querySelector(
".pops-panel-item-left-desc-text"
);
domUtils.text(
$desc,
`当前占用空间大小:${await MTEditorOptimization.getReplyRecordSize()}`
);
}
)
]
}
]
},
{
text: "编辑器-图床配置",
type: "deepMenu",
forms: [
{
type: "forms",
text: `<a href="https://www.helloimg.com/" target="_blank">Hello图床</a>`,
forms: [
UISwitch(
"启用",
"mt-image-bed-hello-enable",
false,
void 0,
"启用Hello图床"
),
UIInput(
"账号",
"mt-image-bed-hello-account",
"",
"",
void 0,
"必填"
),
UIInput(
"密码",
"mt-image-bed-hello-password",
"",
"",
void 0,
"必填",
false,
true
),
UIInput(
"token",
"mt-image-bed-hello-token",
"",
"",
void 0,
"必填",
false,
true
)
]
},
{
type: "forms",
text: `<a href="https://img.binmt.cc/" target="_blank">MT图床</a>`,
forms: [
UISwitch(
"启用",
"mt-image-bed-mt-enable",
true,
void 0,
"启用MT图床"
)
]
},
{
type: "forms",
text: "图片水印",
forms: [
UISwitch(
"启用",
"mt-image-bed-watermark-enable",
false,
void 0,
"开启后会为图床图片添加文字水印"
),
UISwitch(
"自动添加水印",
"mt-image-bed-watermark-autoAddWaterMark",
false,
void 0,
"开启后会自动添加水印,关闭后会有添加水印后的图片预览"
),
UIInput("水印文字", "mt-image-bed-watermark-text", "MT论坛"),
UIInput(
"颜色",
"mt-image-bed-watermark-text-color",
"#000000",
void 0,
void 0,
"",
false,
false,
(formCOnfig, container) => {
var _a2, _b;
let $input = (_a2 = container.target) == null ? void 0 : _a2.querySelector("input");
let $suffix = (_b = container.target) == null ? void 0 : _b.querySelector(
".pops-panel-input__suffix"
);
domUtils.hide($suffix, false);
$input.setAttribute("type", "color");
domUtils.css($input, {
margin: "unset",
padding: "unset",
width: "80px"
});
}
),
UIInput(
"大小",
"mt-image-bed-watermark-font-size",
16,
void 0,
void 0,
void 0,
true
),
UIInput(
"透明度",
"mt-image-bed-watermark-font-opacity",
1,
void 0,
void 0,
void 0,
true
),
UIInput(
"左右间距",
"mt-image-bed-watermark-left-right-margin",
80,
void 0,
void 0,
void 0,
true
),
UIInput(
"上下间距",
"mt-image-bed-watermark-top-bottom-margin",
80,
void 0,
void 0,
void 0,
true
),
UIInput(
"旋转角度",
"mt-image-bed-watermark-rotate",
45,
void 0,
void 0,
void 0,
true
)
]
}
]
}
]
}
]
};
const Component_Search = {
id: "component-search",
title: "搜索",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"显示搜索历史",
"mt-search-showSearchHistory",
true,
void 0,
"自动记住搜索历史并显示"
),
UISwitch(
"修复清空按钮",
"mt-search-repairClearBtn",
true,
void 0,
"修复点击清空按钮不清空输入框的问题"
),
UISwitch(
"搜索框自动获取焦点",
"mt-search-searchInputAutoFocus",
true,
void 0,
""
)
]
}
]
};
const MTAutoSignIn = {
$key: {
signTime: "mt-sign-time"
},
init() {
this.sign();
},
/**
* 判断今日是否已签到
*/
todayIsSign() {
let signTime = this.getSignTime();
if (signTime == null) {
return false;
}
if (utils.formatTime(Date.now(), "yyyyMMdd") !== utils.formatTime(signTime, "yyyyMMdd")) {
return false;
}
return true;
},
/**
* 设置签到时间
*/
setSignTime() {
_GM_setValue(this.$key.signTime, Date.now());
},
/**
* 获取签到时间
*/
getSignTime() {
return _GM_getValue(this.$key.signTime);
},
/**
* 清空签到信息
*/
clearSignTime() {
_GM_deleteValue(this.$key.signTime);
},
/**
* 检测是否登录
*/
async checkLogin() {
if (MTUtils.envIsMobile()) {
let mobile_login_exitBtn = document.querySelector(
".sidenv_exit a[href*='member.php?mod=logging&action=logout']"
);
return mobile_login_exitBtn;
} else {
let pc_login = document.querySelector("#comiis_key");
return pc_login;
}
},
/**
* 获取账号的formhash
*/
getFormHash() {
let $inputFormHash = (top || globalThis).document.querySelector("input[name=formhash]");
let sidenv_exit = (top || globalThis).document.querySelector("div[class=sidenv_exit]>a");
let sidenv_exit_match = null;
let comiis_recommend_addkey = (top || globalThis).document.querySelector("a.comiis_recommend_addkey");
let comiis_recommend_addkey_match = null;
let inputFormHash = $inputFormHash ? $inputFormHash.value : null;
if (sidenv_exit) {
sidenv_exit_match = sidenv_exit.href.match(MTRegExp.formhash);
sidenv_exit_match = sidenv_exit_match ? sidenv_exit_match[sidenv_exit_match.length - 1] : null;
}
if (comiis_recommend_addkey) {
comiis_recommend_addkey_match = comiis_recommend_addkey.href.match(
MTRegExp.hash
);
comiis_recommend_addkey_match = comiis_recommend_addkey_match ? comiis_recommend_addkey_match[comiis_recommend_addkey_match.length - 1] : null;
}
return inputFormHash || sidenv_exit_match || comiis_recommend_addkey_match;
},
/**
* 签到
*/
async sign() {
let formHash = this.getFormHash();
if (formHash == null) {
if (document.querySelector("#comiis_picshowbox")) {
log.info("当前为评论区的看图模式 ");
return;
}
log.error("自动签到:获取账号formhash失败");
_GM_deleteValue("mt_sign");
Qmsg.error({
content: "自动签到:获取账号formhash失败"
});
return;
}
if (this.todayIsSign()) {
log.info("今日已签到");
return;
}
let searchParamsData = {
operation: "qiandao",
format: "button",
formhash: formHash,
inajax: 1,
ajaxtarget: "midaben_sign"
};
let useFetch = Boolean(PopsPanel.getValue("mt-auto-sign-useFetch"));
let response = await httpx.get(
`/k_misign-sign.html?${utils.toSearchParamsStr(searchParamsData)}`,
{
fetch: useFetch,
headers: {
"User-Agent": utils.getRandomPCUA()
},
allowInterceptConfig: false
}
);
if (!response.status) {
log.error("签到:网络异常,请求失败");
Qmsg.error("签到:网络异常,请求失败");
return;
}
this.setSignTime();
log.info("签到信息:", response);
let responseText = response.data.responseText;
let CDATA = utils.parseCDATA(responseText);
let CDATAElement = domUtils.parseHTML(`<div>${CDATA}</div>`, true, false);
let content = domUtils.text(CDATAElement);
if (content.includes("需要先登录")) {
Qmsg.error("签到:请先登录账号", {
timeout: 3e3
});
this.clearSignTime();
return;
} else if (content.includes("请稍后再试") || content.includes("您已经被列入黑名单") || content.includes("绑定手机号后才可以签到") || content.includes("您所在用户组不允许使用")) {
Qmsg.error("签到:" + content, {
timeout: 5e3
});
return;
} else if (content.includes("今日已签")) {
Qmsg.info("签到:" + content);
return;
} else if (responseText.includes("您当前的访问请求当中含有非法字符,已经被系统拒绝")) {
Qmsg.error("签到: 您当前的访问请求当中含有非法字符,已经被系统拒绝", {
timeout: 6e3
});
return;
} else if (useFetch && "location" in utils.toJSON(responseText)) {
Qmsg.success("签到: 签到成功");
return;
}
let signIn_con = CDATAElement.querySelector(".con");
let signIn_line = CDATAElement.querySelector(".line");
if (signIn_con && signIn_line) {
let conMatch = domUtils.text(signIn_con).match(/([0-9]+)金币/);
let lineMatch = domUtils.text(signIn_line).match(/([0-9]+)/);
let con = conMatch[conMatch.length - 1];
let line = lineMatch[lineMatch.length - 1];
log.success(`金币${con},排名${line}`);
Qmsg.info(
/*html*/
`
<div style="display: flex;${!MTUtils.envIsMobile() ? "padding: 20px;" : ""}">
<div style="align-self: center;margin-right: 20px;">签到</div>
<div>排名 ${line}<br>金币 ${con}</div>
</div>`,
{
timeout: 4e3,
isHTML: true
}
);
return;
}
let $alert = pops.alert({
title: {
text: "未知签到内容",
position: "center"
},
content: {
text: "",
html: false
},
width: "88vw",
height: "300px"
});
let $content = $alert.$shadowRoot.querySelector(
".pops-alert-content"
);
$content.innerText = response.data.responseText;
}
};
const Component_Sign = {
id: "component-sigh",
title: "签到",
forms: [
{
text: "功能",
type: "forms",
forms: [
UISwitch(
"显示【今日签到之星】",
"mt-sign-showTodaySignStar",
true,
void 0,
"在签到按钮上面显示今日签到之星"
),
UISwitch(
"显示【今日最先】",
"mt-sign-showTodayRanking",
true,
void 0,
"在签到排名上面新增【今日最先】"
)
]
},
{
text: "自动签到",
type: "forms",
forms: [
UISwitch("启用", "mt-auto-sign", true, void 0, "自动请求签到"),
UISwitch("使用fetch请求", "mt-auto-sign-useFetch", false, void 0, ""),
UIButton(
"签到信息",
`上次签到时间:${MTAutoSignIn.getSignTime() == null ? "尚未签到" : Utils.formatTime(MTAutoSignIn.getSignTime())}`,
"清空信息",
void 0,
void 0,
void 0,
"primary",
(event) => {
let $click = event.composedPath()[0];
let $desc = $click.closest("li").querySelector(".pops-panel-item-left-desc-text");
__pops.confirm({
title: {
text: "提示 ",
position: "center"
},
content: {
text: "<p>是否清空脚本签到记录的时间?</p>",
html: true
},
btn: {
ok: {
enable: true,
callback: (event2) => {
MTAutoSignIn.clearSignTime();
Qmsg.success("删除成功");
domUtils.text(
$desc,
`上次签到时间:${MTAutoSignIn.getSignTime() == null ? "尚未签到" : Utils.formatTime(MTAutoSignIn.getSignTime())}`
);
event2.close();
}
}
},
mask: {
enable: true
},
width: "88vw",
height: "200px"
});
}
)
]
}
]
};
const Component_Space = {
id: "component-space",
title: "空间",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"修复无法进入空间",
"mt-space-repairEnterSpace",
true,
void 0,
"修复链接错误导致不能进入空间的问题"
),
UISwitch(
"显示帖子回复内容",
"mt-space-showCommentContent",
true,
void 0,
"在帖子-回复下面显示具体评论的内容"
)
]
}
]
};
const Component_Guide = {
id: "component-guide",
title: "导读",
forms: [
{
type: "forms",
text: "",
forms: [
UISwitch(
"显示最新帖子",
"mt-guide-showLatestPost",
true,
void 0,
"在最上面显示最新发布的帖子"
)
]
}
]
};
const PanelUISize = {
/**
* 一般设置界面的尺寸
*/
setting: {
get width() {
return window.innerWidth < 550 ? "88vw" : "550px";
},
get height() {
return window.innerHeight < 450 ? "70vh" : "450px";
}
},
/**
* 功能丰富,aside铺满了的设置界面,要稍微大一点
*/
settingBig: {
get width() {
return window.innerWidth < 800 ? "92vw" : "800px";
},
get height() {
return window.innerHeight < 600 ? "80vh" : "600px";
}
},
/**
* 信息界面,一般用于提示信息之类
*/
info: {
get width() {
return window.innerWidth < 350 ? "350px" : "350px";
},
get height() {
return window.innerHeight < 250 ? "250px" : "250px";
}
}
};
const PopsPanel = {
/** 数据 */
$data: {
__data: null,
__oneSuccessExecMenu: null,
__onceExec: null,
__listenData: null,
/**
* 菜单项的默认值
*/
get data() {
if (PopsPanel.$data.__data == null) {
PopsPanel.$data.__data = new utils.Dictionary();
}
return PopsPanel.$data.__data;
},
/**
* 成功只执行了一次的项
*/
get oneSuccessExecMenu() {
if (PopsPanel.$data.__oneSuccessExecMenu == null) {
PopsPanel.$data.__oneSuccessExecMenu = new utils.Dictionary();
}
return PopsPanel.$data.__oneSuccessExecMenu;
},
/**
* 成功只执行了一次的项
*/
get onceExec() {
if (PopsPanel.$data.__onceExec == null) {
PopsPanel.$data.__onceExec = new utils.Dictionary();
}
return PopsPanel.$data.__onceExec;
},
/** 脚本名,一般用在设置的标题上 */
get scriptName() {
return SCRIPT_NAME;
},
/** 菜单项的总值在本地数据配置的键名 */
key: KEY,
/** 菜单项在attributes上配置的菜单键 */
attributeKeyName: ATTRIBUTE_KEY,
/** 菜单项在attributes上配置的菜单默认值 */
attributeDefaultValueName: ATTRIBUTE_DEFAULT_VALUE
},
/** 监听器 */
$listener: {
/**
* 值改变的监听器
*/
get listenData() {
if (PopsPanel.$data.__listenData == null) {
PopsPanel.$data.__listenData = new utils.Dictionary();
}
return PopsPanel.$data.__listenData;
}
},
init() {
this.initPanelDefaultValue();
this.initExtensionsMenu();
},
/** 判断是否是顶层窗口 */
isTopWindow() {
return _unsafeWindow.top === _unsafeWindow.self;
},
/** 初始化进行注册油猴菜单 */
initExtensionsMenu() {
if (!this.isTopWindow()) {
return;
}
GM_Menu.add([
{
key: "show_pops_panel_setting",
text: "⚙ 设置",
autoReload: false,
isStoreValue: false,
showText(text) {
return text;
},
callback: () => {
this.showPanel();
}
}
]);
ElementUtils.registerLeftMenu({
name: "MT论坛脚本设置",
icon: "",
iconColor: "#ff0505",
iconSize: "23px",
callback: () => {
this.showPanel();
}
});
},
/** 初始化菜单项的默认值保存到本地数据中 */
initPanelDefaultValue() {
let that = this;
function initDefaultValue(config) {
if (!config.attributes) {
return;
}
let needInitConfig = {};
let key = config.attributes[ATTRIBUTE_KEY];
if (key != null) {
needInitConfig[key] = config.attributes[ATTRIBUTE_DEFAULT_VALUE];
}
let __attr_init__ = config.attributes[ATTRIBUTE_INIT];
if (typeof __attr_init__ === "function") {
let __attr_result__ = __attr_init__();
if (typeof __attr_result__ === "boolean" && !__attr_result__) {
return;
}
}
let initMoreValue = config.attributes[ATTRIBUTE_INIT_MORE_VALUE];
if (initMoreValue && typeof initMoreValue === "object") {
Object.assign(needInitConfig, initMoreValue);
}
let needInitConfigList = Object.keys(needInitConfig);
if (!needInitConfigList.length) {
log.warn(["请先配置键", config]);
return;
}
needInitConfigList.forEach((__key) => {
let __defaultValue = needInitConfig[__key];
if (that.$data.data.has(__key)) {
log.warn("请检查该key(已存在): " + __key);
}
that.$data.data.set(__key, __defaultValue);
});
}
function loopInitDefaultValue(configList) {
for (let index = 0; index < configList.length; index++) {
let configItem = configList[index];
initDefaultValue(configItem);
let childForms = configItem.forms;
if (childForms && Array.isArray(childForms)) {
loopInitDefaultValue(childForms);
}
}
}
let contentConfigList = this.getPanelContentConfig();
for (let index = 0; index < contentConfigList.length; index++) {
let leftContentConfigItem = contentConfigList[index];
if (!leftContentConfigItem.forms) {
continue;
}
let rightContentConfigList = leftContentConfigItem.forms;
if (rightContentConfigList && Array.isArray(rightContentConfigList)) {
loopInitDefaultValue(rightContentConfigList);
}
}
},
/**
* 设置值
* @param key 键
* @param value 值
*/
setValue(key, value) {
let locaData = _GM_getValue(KEY, {});
let oldValue = locaData[key];
locaData[key] = value;
_GM_setValue(KEY, locaData);
if (this.$listener.listenData.has(key)) {
this.$listener.listenData.get(key).callback(key, oldValue, value);
}
},
/**
* 获取值
* @param key 键
* @param defaultValue 默认值
*/
getValue(key, defaultValue) {
let locaData = _GM_getValue(KEY, {});
let localValue = locaData[key];
if (localValue == null) {
if (this.$data.data.has(key)) {
return this.$data.data.get(key);
}
return defaultValue;
}
return localValue;
},
/**
* 删除值
* @param key 键
*/
deleteValue(key) {
let locaData = _GM_getValue(KEY, {});
let oldValue = locaData[key];
Reflect.deleteProperty(locaData, key);
_GM_setValue(KEY, locaData);
if (this.$listener.listenData.has(key)) {
this.$listener.listenData.get(key).callback(key, oldValue, void 0);
}
},
/**
* 监听调用setValue、deleteValue
* @param key 需要监听的键
* @param callback
*/
addValueChangeListener(key, callback, option) {
let listenerId = Math.random();
this.$listener.listenData.set(key, {
id: listenerId,
key,
callback
});
if (option) {
if (option.immediate) {
callback(key, this.getValue(key), this.getValue(key));
}
}
return listenerId;
},
/**
* 移除监听
* @param listenerId 监听的id
*/
removeValueChangeListener(listenerId) {
let deleteKey = null;
for (const [key, value] of this.$listener.listenData.entries()) {
if (value.id === listenerId) {
deleteKey = key;
break;
}
}
if (typeof deleteKey === "string") {
this.$listener.listenData.delete(deleteKey);
} else {
console.warn("没有找到对应的监听器");
}
},
/**
* 主动触发菜单值改变的回调
* @param key 菜单键
* @param newValue 想要触发的新值,默认使用当前值
* @param oldValue 想要触发的旧值,默认使用当前值
*/
triggerMenuValueChange(key, newValue, oldValue) {
if (this.$listener.listenData.has(key)) {
let listenData = this.$listener.listenData.get(key);
if (typeof listenData.callback === "function") {
let value = this.getValue(key);
let __newValue = value;
let __oldValue = value;
if (typeof newValue !== "undefined" && arguments.length > 1) {
__newValue = newValue;
}
if (typeof oldValue !== "undefined" && arguments.length > 2) {
__oldValue = oldValue;
}
listenData.callback(key, __oldValue, __newValue);
}
}
},
/**
* 判断该键是否存在
* @param key 键
*/
hasKey(key) {
let locaData = _GM_getValue(KEY, {});
return key in locaData;
},
/**
* 自动判断菜单是否启用,然后执行回调
* @param key
* @param callback 回调
* @param isReverse 逆反判断菜单启用
* @param checkEnableCallBack 自定义检测菜单的值,可自行决定是否强制启用菜单,true是启用菜单,false是不启用菜单
*/
execMenu(key, callback, isReverse = false, checkEnableCallBack) {
if (!(typeof key === "string" || typeof key === "object" && Array.isArray(key))) {
throw new TypeError("key 必须是字符串或者字符串数组");
}
let runKeyList = [];
if (typeof key === "object" && Array.isArray(key)) {
runKeyList = [...key];
} else {
runKeyList.push(key);
}
let value = void 0;
for (let index = 0; index < runKeyList.length; index++) {
const runKey = runKeyList[index];
if (!this.$data.data.has(runKey)) {
log.warn(`${key} 键不存在`);
return;
}
let runValue = PopsPanel.getValue(runKey);
if (isReverse) {
runValue = !runValue;
}
if (typeof checkEnableCallBack === "function") {
let checkResult = checkEnableCallBack(runKey, runValue);
if (typeof checkResult === "boolean") {
runValue = checkResult;
}
}
if (!runValue) {
break;
}
value = runValue;
}
if (value) {
callback(value);
}
},
/**
* 自动判断菜单是否启用,然后执行回调,只会执行一次
* @param key
* @param callback 回调
* @param getValueFn 自定义处理获取当前值,值true是启用并执行回调,值false是不执行回调
* @param handleValueChangeFn 自定义处理值改变时的回调,值true是启用并执行回调,值false是不执行回调
* @param checkEnableCallBack 自定义检测菜单的值,可自行决定是否强制启用菜单,true是启用菜单,false是不启用菜单
*/
execMenuOnce(key, callback, getValueFn, handleValueChangeFn, checkEnableCallBack) {
if (typeof key !== "string") {
throw new TypeError("key 必须是字符串");
}
if (!this.$data.data.has(key)) {
log.warn(`${key} 键不存在`);
return;
}
if (this.$data.oneSuccessExecMenu.has(key)) {
return;
}
this.$data.oneSuccessExecMenu.set(key, 1);
let __getValue = () => {
let localValue = PopsPanel.getValue(key);
return typeof getValueFn === "function" ? getValueFn(key, localValue) : localValue;
};
let resultStyleList = [];
let dynamicPushStyleNode = ($style) => {
let __value = __getValue();
let dynamicResultList = [];
if ($style instanceof HTMLStyleElement) {
dynamicResultList = [$style];
} else if (Array.isArray($style)) {
dynamicResultList = [
...$style.filter(
(item) => item != null && item instanceof HTMLStyleElement
)
];
}
if (__value) {
resultStyleList = resultStyleList.concat(dynamicResultList);
} else {
for (let index = 0; index < dynamicResultList.length; index++) {
let $css = dynamicResultList[index];
$css.remove();
dynamicResultList.splice(index, 1);
index--;
}
}
};
let checkMenuEnableCallBack = (currentValue) => {
return typeof checkEnableCallBack === "function" ? checkEnableCallBack(key, currentValue) : currentValue;
};
let changeCallBack = (currentValue) => {
let resultList = [];
if (checkMenuEnableCallBack(currentValue)) {
let result = callback(currentValue, dynamicPushStyleNode);
if (result instanceof HTMLStyleElement) {
resultList = [result];
} else if (Array.isArray(result)) {
resultList = [
...result.filter(
(item) => item != null && item instanceof HTMLStyleElement
)
];
}
}
for (let index = 0; index < resultStyleList.length; index++) {
let $css = resultStyleList[index];
$css.remove();
resultStyleList.splice(index, 1);
index--;
}
resultStyleList = [...resultList];
};
this.addValueChangeListener(
key,
(__key, oldValue, newValue) => {
let __newValue = newValue;
if (typeof handleValueChangeFn === "function") {
__newValue = handleValueChangeFn(__key, newValue, oldValue);
}
changeCallBack(__newValue);
}
);
let value = __getValue();
if (value) {
changeCallBack(value);
}
},
/**
* 父子菜单联动,自动判断菜单是否启用,然后执行回调,只会执行一次
* @param key 菜单键
* @param childKey 子菜单键
* @param callback 回调
* @param replaceValueFn 用于修改mainValue,返回undefined则不做处理
*/
execInheritMenuOnce(key, childKey, callback, replaceValueFn) {
let that = this;
const handleInheritValue = (key2, childKey2) => {
let mainValue = that.getValue(key2);
let childValue = that.getValue(childKey2);
if (typeof replaceValueFn === "function") {
let changedMainValue = replaceValueFn(mainValue, childValue);
if (changedMainValue != null) {
return changedMainValue;
}
}
return mainValue;
};
this.execMenuOnce(
key,
callback,
() => {
return handleInheritValue(key, childKey);
},
() => {
return handleInheritValue(key, childKey);
}
);
this.execMenuOnce(
childKey,
() => {
},
() => false,
() => {
this.triggerMenuValueChange(key);
return false;
}
);
},
/**
* 根据自定义key只执行一次
* @param key 自定义key
*/
onceExec(key, callback) {
if (typeof key !== "string") {
throw new TypeError("key 必须是字符串");
}
if (this.$data.onceExec.has(key)) {
return;
}
callback();
this.$data.onceExec.set(key, 1);
},
/**
* 显示设置面板
*/
showPanel() {
__pops.panel({
title: {
text: `${SCRIPT_NAME}-设置`,
position: "center",
html: false,
style: ""
},
content: this.getPanelContentConfig(),
mask: {
enable: true,
clickEvent: {
toClose: true,
toHide: false
}
},
width: PanelUISize.setting.width,
height: PanelUISize.setting.height,
drag: true,
only: true
});
},
/**
* 判断是否是移动端
*/
isMobile() {
return window.innerWidth < 550;
},
/**
* 获取设置面板的宽度
*/
getWidth() {
if (window.innerWidth < 550) {
return "88vw";
} else {
return "550px";
}
},
/**
* 获取设置面板的高度
*/
getHeight() {
if (window.innerHeight > 450) {
return "450px";
} else {
return "88vh";
}
},
/**
* 获取配置内容
*/
getPanelContentConfig() {
let configList = [
Component_Common,
Component_ForumPost,
Component_Search,
Component_Sign,
Component_Space,
Component_Guide
];
return configList;
}
};
const blackHomeCSS = ".pops-confirm-content {\r\n display: flex;\r\n flex-direction: column;\r\n}\r\n.blackhome-user-filter input {\r\n width: -moz-available;\r\n width: -webkit-fill-available;\r\n height: 30px;\r\n margin: 8px 20px;\r\n border: 0;\r\n border-bottom: 1px solid;\r\n text-overflow: ellipsis;\r\n overflow: hidden;\r\n white-space: nowrap;\r\n}\r\n.blackhome-user-filter input:focus-within {\r\n outline: none;\r\n}\r\n.blackhome-user-list {\r\n flex: 1;\r\n overflow-y: auto;\r\n}\r\n.blackhome-user-list .blackhome-user-item {\r\n margin: 15px 10px;\r\n padding: 10px;\r\n border-radius: 8px;\r\n box-shadow: 0 0 0.6rem #c8d0e7, -0.2rem -0.2rem 0.5rem #fff;\r\n}\r\n.blackhome-user {\r\n display: flex;\r\n}\r\n.blackhome-user img {\r\n width: 45px;\r\n height: 45px;\r\n border-radius: 45px;\r\n}\r\n.blackhome-user-info {\r\n margin-left: 10px;\r\n}\r\n.blackhome-user-info p:nth-child(1) {\r\n margin-bottom: 5px;\r\n}\r\n.blackhome-user-info p:nth-child(2) {\r\n font-size: 14px;\r\n}\r\n.blackhome-user-action {\r\n display: flex;\r\n margin: 10px 0;\r\n}\r\n.blackhome-user-action p:nth-child(1),\r\n.blackhome-user-action p:nth-child(2) {\r\n border: 1px solid red;\r\n color: red;\r\n border-radius: 4px;\r\n padding: 2px 4px;\r\n font-weight: 500;\r\n font-size: 14px;\r\n place-self: center;\r\n}\r\n.blackhome-user-action p:nth-child(2) {\r\n border: 1px solid #ff4b4b;\r\n color: #ff4b4b;\r\n margin-left: 8px;\r\n}\r\n.blackhome-user-uuid {\r\n border: 1px solid #ff7600;\r\n color: #ff7600;\r\n border-radius: 4px;\r\n padding: 2px 4px;\r\n font-weight: 500;\r\n font-size: 14px;\r\n width: fit-content;\r\n width: -moz-fit-content;\r\n margin: 10px 0;\r\n}\r\n.blackhome-operator {\r\n padding: 10px;\r\n background-color: #efefef;\r\n border-radius: 6px;\r\n}\r\n.blackhome-operator-user {\r\n display: flex;\r\n}\r\n.blackhome-operator-user img {\r\n width: 35px;\r\n height: 35px;\r\n border-radius: 35px;\r\n}\r\n.blackhome-operator-user p {\r\n align-self: center;\r\n margin-left: 10px;\r\n}\r\n.blackhome-operator-user-info {\r\n margin: 10px 0;\r\n font-weight: 500;\r\n}\r\n";
const MTBlackHome = {
$data: {
cid: ""
},
init() {
this.registerMenu();
},
/**
* 注册菜单
*/
registerMenu() {
ElementUtils.registerLeftMenu({
name: "小黑屋",
iconColor: "#000000",
icon: "",
callback: () => {
this.showBlackHome();
}
});
},
/**
* 显示小黑屋dialog
*/
async showBlackHome() {
let $loading = Qmsg.loading("正在获取小黑屋名单中...");
let blackListInfo = await this.getBlackListInfo("");
$loading.close();
if (!blackListInfo) {
return;
}
if (blackListInfo.data.length === 0) {
Qmsg.error("获取小黑屋名单为空");
return;
}
this.$data.cid = blackListInfo.next_cid;
let $confirm = __pops.confirm({
title: {
text: "小黑屋名单",
position: "center"
},
content: {
text: (
/*html*/
`
<div class="blackhome-user-filter">
<input placeholder="过滤用户名/操作人员/UID(可正则)">
</div>
<div class="blackhome-user-list"></div>
`
),
html: true
},
btn: {
ok: {
text: "下一页",
callback: async () => {
let $loading2 = Qmsg.loading("正在获取小黑屋名单中...");
log.info("下一页的cid: ", this.$data.cid);
let nextBlackListInfo2 = await this.getBlackListInfo(this.$data.cid);
$loading2.close();
if (!nextBlackListInfo2) {
return;
}
this.$data.cid = nextBlackListInfo2.next_cid;
nextBlackListInfo2.data.forEach((item) => {
let $item = this.createListViewItem(item);
$list.appendChild($item);
});
if (nextBlackListInfo2.data.length === 0) {
Qmsg.error("获取小黑屋名单为空");
} else {
Qmsg.success(`成功获取 ${nextBlackListInfo2.data.length}条数据`);
}
}
},
cancel: {
text: "关闭"
}
},
width: "88vw",
height: "82vh",
style: blackHomeCSS,
mask: {
enable: true
}
});
let $list = $confirm.$shadowRoot.querySelector(
".blackhome-user-list"
);
let $filterInput = $confirm.$shadowRoot.querySelector(
".blackhome-user-filter input"
);
blackListInfo.data.forEach((item) => {
let $item = this.createListViewItem(item);
$list.appendChild($item);
});
Qmsg.success(`成功获取 ${blackListInfo.data.length}条数据`);
let isSeaching = false;
domUtils.on(
$filterInput,
["input", "propertychange"],
utils.debounce(() => {
let inputText = $filterInput.value.trim();
if (isSeaching) {
return;
}
isSeaching = true;
if (inputText == "") {
$confirm.$shadowRoot.querySelectorAll(".blackhome-user-item").forEach((item) => {
item.removeAttribute("style");
});
isSeaching = false;
return;
}
$confirm.$shadowRoot.querySelectorAll(".blackhome-user-item").forEach((item) => {
if (item.getAttribute("data-name").match(new RegExp(inputText, "ig")) || item.getAttribute("data-uid").trim().match(new RegExp(inputText, "ig")) || item.getAttribute("data-operator").match(new RegExp(inputText, "ig"))) {
item.removeAttribute("style");
} else {
item.setAttribute("style", "display:none;");
}
});
isSeaching = false;
})
);
let nextBlackListInfo = await this.getBlackListInfo(this.$data.cid);
if (!nextBlackListInfo) {
return;
}
this.$data.cid = nextBlackListInfo.next_cid;
},
/**
* 获取小黑屋名单信息
*/
async getBlackListInfo(cid = "") {
let searchParamsData = {
mod: "misc",
action: "showdarkroom",
cid,
ajaxdata: "json"
};
let response = await httpx.get(
`/forum.php?${utils.toSearchParamsStr(searchParamsData)}`,
{
headers: {
"User-Agent": utils.getRandomPCUA()
},
responseType: "json"
}
);
if (!response.status) {
return;
}
let data = utils.toJSON(response.data.responseText);
let cidSplit = data["message"].split("|");
let next_cid = cidSplit[cidSplit.length - 1];
let blackListData = utils.parseObjectToArray(data["data"]);
let new_blackListData = [];
let new_blackListData_noTime = [];
blackListData.forEach((item) => {
let date = item["dateline"].match(
/([0-9]{4}-[0-9]{1,2}-[0-9]{1,2}[\s]*[0-9]{1,2}:[0-9]{1,2})/g
);
if (date == null) {
let _time_ = parseInt((Date.now() / 1e3).toString());
let _time_after_count_ = 0;
let sec_data = item["dateline"].match(/([0-9]+|半)[\s\S]*秒前/);
let min_data = item["dateline"].match(/([0-9]+|半)[\s\S]*分钟前/);
let hour_data = item["dateline"].match(/([0-9]+|半)[\s\S]*小时前/);
let yesterday_time_data = item["dateline"].match(
/昨天[\s\S]*(\d{2}):(\d{2})/
);
let before_yesterday_time_data = item["dateline"].match(
/前天[\s\S]*(\d{2}):(\d{2})/
);
let day_data = item["dateline"].match(/([0-9]+|半)[\s\S]*天前/);
if (sec_data) {
sec_data = sec_data[sec_data.length - 1];
sec_data = sec_data.replace(/半/g, 0.5);
sec_data = parseFloat(sec_data);
_time_after_count_ = _time_ - sec_data;
} else if (min_data) {
min_data = min_data[min_data.length - 1];
min_data = min_data.replace(/半/g, 0.5);
min_data = parseFloat(min_data);
_time_after_count_ = _time_ - min_data * 60;
} else if (hour_data) {
hour_data = hour_data[hour_data.length - 1];
hour_data = hour_data.replace(/半/g, 0.5);
hour_data = parseFloat(hour_data);
_time_after_count_ = _time_ - hour_data * 60 * 60;
} else if (yesterday_time_data) {
let yesterday_hour_data = yesterday_time_data[1];
let yesterday_min_data = yesterday_time_data[2];
_time_after_count_ = _time_ - 86400 - parseInt(yesterday_hour_data) * 3600 - parseInt(yesterday_min_data) * 60;
} else if (before_yesterday_time_data) {
let before_yesterday_hour_data = before_yesterday_time_data[1];
let before_yesterday_min_data = before_yesterday_time_data[2];
_time_after_count_ = _time_ - 86400 * 2 - parseInt(before_yesterday_hour_data) * 3600 - parseInt(before_yesterday_min_data) * 60;
} else if (day_data) {
day_data = day_data[day_data.length - 1];
day_data = day_data.replace(/半/g, 0.5);
day_data = parseFloat(day_data);
_time_after_count_ = _time_ - day_data * 60 * 60 * 24;
}
item["time"] = parseInt(_time_after_count_.toString()) * 1e3;
new_blackListData = new_blackListData.concat(item);
return;
} else {
date = date[0];
}
item["time"] = utils.formatToTimeStamp(date);
new_blackListData = new_blackListData.concat(item);
});
utils.sortListByProperty(new_blackListData, "time");
utils.sortListByProperty(new_blackListData_noTime, "time", false);
new_blackListData = new_blackListData.concat(new_blackListData_noTime);
return {
next_cid,
data: new_blackListData
};
},
/**
* 创建黑名单节点
*/
createListViewItem(userInfo) {
let $item = domUtils.createElement(
"div",
{
className: "blackhome-user-item",
innerHTML: (
/*html*/
`
<div class="blackhome-user-avatar">
<div class="blackhome-user">
<img src="${MTUtils.getAvatar(
userInfo["uid"],
"big"
)}" loading="lazy">
<div class="blackhome-user-info">
<p>${userInfo["username"]}</p>
<p>${userInfo["dateline"]}</p>
</div>
</div>
<div class="blackhome-user-action">
<p>${userInfo["action"]}</p>
<p>到期: ${userInfo["groupexpiry"]}</p>
</div>
<div class="blackhome-user-uuid">UID: ${userInfo["uid"]}</div>
<div class="blackhome-operator">
<div class="blackhome-operator-user">
<img loading="lazy" src="${MTUtils.getAvatar(
userInfo["operatorid"],
"big"
)}">
<p>${userInfo["operator"]}</p>
</div>
<div class="blackhome-operator-user-info">
${userInfo["reason"]}
</div>
</div>
</div>
`
)
},
{
"data-name": userInfo.username,
"data-uid": userInfo.uid,
"data-operator": userInfo.operator,
"data-operator-uid": userInfo.operatorid
}
);
domUtils.on(
$item,
"click",
".blackhome-user img",
function() {
window.open(
`home.php?mod=space&uid=${userInfo.uid}&do=profile`,
"_blank"
);
}
);
domUtils.on(
$item,
"click",
".blackhome-operator-user img",
function() {
window.open(
`home.php?mod=space&uid=${userInfo.operatorid}&do=profile`,
"_blank"
);
}
);
return $item;
}
};
const onlineUserCSS = '.pops-alert-content{\r\n display: flex;\r\n flex-direction: column;\r\n}\r\n.pops-alert-content > .online-user-info{\r\n text-align: center;\r\n padding: 0px 6px;\r\n}\r\n.online-user-filter input {\r\n width: -webkit-fill-available;\r\n width: -moz-available;\r\n height: 30px;\r\n margin: 8px 20px;\r\n border: 0;\r\n border-bottom: 1px solid;\r\n}\r\n.online-user-filter input:focus-within {\r\n outline: none;\r\n}\r\n.online-user-list {\r\n flex: 1;\r\n overflow-y: auto;\r\n}\r\n.online-user-list li {\r\n margin: 18px 0;\r\n}\r\n.online-user {\r\n display: flex;\r\n margin: 2px 20px;\r\n align-items: center;\r\n}\r\n.online-user img[data-avatar] {\r\n width: 45px;\r\n height: 45px;\r\n border-radius: 45px;\r\n}\r\n.online-user-list .online-user-info {\r\n margin: 2px 14px;\r\n}\r\n.online-user-list .online-user-info p[data-name] {\r\n margin-bottom: 4px;\r\n}\r\n.online-user-list .online-user-info span[data-sf] {\r\n border-radius: 4px;\r\n padding: 2px 4px;\r\n font-weight: 500;\r\n font-size: 14px;\r\n}\r\n.online-user-list .online-user-info span[data-uid] {\r\n border: 1px solid #ff7600;\r\n color: #ff7600;\r\n border-radius: 4px;\r\n padding: 2px 4px;\r\n font-weight: 500;\r\n font-size: 14px;\r\n width: fit-content;\r\n width: -moz-fit-content;\r\n margin: 10px 0;\r\n}\r\n.online-user-list .online-user-info span[data-sf="会员"] {\r\n color: #88b500;\r\n border: 1px solid #88b500;\r\n}\r\n.online-user-list .online-user-info span[data-sf="版主"] {\r\n color: #2db5e3;\r\n border: 1px solid #2db5e3;\r\n}\r\n.online-user-list .online-user-info span[data-sf="超级版主"] {\r\n color: #e89e38;\r\n border: 1px solid #e89e38;\r\n}\r\n.online-user-list .online-user-info span[data-sf="管理员"] {\r\n color: #ff5416;\r\n border: 1px solid #ff5416;\r\n}\r\n';
const MTOnlineUser = {
$data: {},
init() {
this.registerMenu();
},
/**
* 注册菜单
*/
registerMenu() {
ElementUtils.registerLeftMenu({
name: "在线用户",
iconColor: "#2d92ff",
icon: "",
callback: () => {
this.showOnlineUser();
}
});
},
/**
* 显示在线用户dialog
*/
async showOnlineUser() {
let $loading = Qmsg.loading("正在获取在线用户名单中...");
let onlineUserInfo = await this.getOnlineUserListInfo();
$loading.close();
if (!onlineUserInfo) {
return;
}
let $alert = __pops.alert({
title: {
text: "在线用户",
position: "center"
},
content: {
text: (
/*html*/
`
<div class="online-user-info">${onlineUserInfo.totalOnline} 人在线 - ${onlineUserInfo.onlineUser} 会员${onlineUserInfo.invisibleUser == 0 ? "" : `(${onlineUserInfo.invisibleUser}隐身)`} - ${onlineUserInfo.noRegisterUser} 位游客</div>
<div class="online-user-filter">
<input placeholder="过滤用户名/身份/UID(可正则)"></div>
<div class="online-user-list"></div>
`
),
html: true
},
btn: {
ok: {
text: "关闭",
type: "default"
}
},
width: "88vw",
height: "82vh",
style: onlineUserCSS,
mask: {
enable: true
}
});
let $list = $alert.$shadowRoot.querySelector(".online-user-list");
let $filterInput = $alert.$shadowRoot.querySelector(
".online-user-filter input"
);
onlineUserInfo.data.forEach((item) => {
let $item = this.createListViewItem(item);
$list.appendChild($item);
});
Qmsg.success(`成功获取 ${onlineUserInfo.data.length}条数据`);
let isSeaching = false;
DOMUtils.on(
$filterInput,
["propertychange", "input"],
utils.debounce(() => {
let inputText = $filterInput.value.trim();
if (isSeaching) {
return;
}
isSeaching = true;
if (inputText == "") {
$alert.$shadowRoot.querySelectorAll(".online-user-list .online-item").forEach((item) => {
item.removeAttribute("style");
});
isSeaching = false;
return;
}
$alert.$shadowRoot.querySelectorAll(".online-user-list .online-item").forEach((item) => {
if (item.getAttribute("data-name").match(new RegExp(inputText, "ig")) || item.getAttribute("data-sf").match(new RegExp(inputText, "ig")) || item.getAttribute("data-uid").match(new RegExp(inputText, "ig"))) {
item.removeAttribute("style");
} else {
item.setAttribute("style", "display:none;");
}
});
isSeaching = false;
})
);
},
/**
* 获取在线用户名单信息
*/
async getOnlineUserListInfo() {
let searchParamsData = {
showoldetails: "yes"
};
let response = await httpx.get(
`/forum.php?${utils.toSearchParamsStr(searchParamsData)}`,
{
headers: {
"User-Agent": utils.getRandomPCUA()
}
}
);
if (!response.status) {
return;
}
let pageHTML = utils.parseFromString(
response.data.responseText,
"text/html"
);
let result = {
data: [],
totalOnline: 0,
onlineUser: 0,
noRegisterUser: 0,
invisibleUser: 0
};
let onlineList = pageHTML.querySelectorAll("#onlinelist ul li");
onlineList.forEach((item) => {
let uid = item.querySelector("a").getAttribute("href").match("uid-(.+?).html")[1];
let avatar = MTUtils.getAvatar(uid, "middle");
let name = item.querySelector("a").innerText;
let sf = "";
let space = item.querySelector("a").getAttribute("href");
let memberSrc = item.querySelector("img").src;
if (memberSrc.indexOf("online_member") != -1) {
sf = "会员";
} else if (memberSrc.indexOf("online_moderator") != -1) {
sf = "版主";
} else if (memberSrc.indexOf("online_supermod") != -1) {
sf = "超级版主";
} else if (memberSrc.indexOf("online_admin") != -1) {
sf = "管理员";
} else {
sf = "未知身份";
}
result.data.push({
uid,
avatar,
name,
sf,
space
});
});
let onlineInfo = pageHTML.querySelector("#online div.bm_h span.xs1").textContent;
result.totalOnline = utils.parseInt(
onlineInfo.match(/([0-9]*)\s*人在线/i),
0
);
result.onlineUser = utils.parseInt(
onlineInfo.match(/([0-9]*)\s*会员/i),
0
);
result.noRegisterUser = utils.parseInt(
onlineInfo.match(/([0-9]*)\s*位游客/i),
0
);
result.invisibleUser = utils.parseInt(
onlineInfo.match(/([0-9]*)\s*隐身/i),
0
);
return result;
},
/**
* 创建在线用户节点
*/
createListViewItem(userInfo) {
let $item = DOMUtils.createElement(
"div",
{
className: "online-item",
innerHTML: (
/*html*/
`
<div class="online-user">
<img data-avatar src="${userInfo["avatar"]}" loading="lazy" class="online-user-avatar">
<div class="online-user-info">
<p data-name>${userInfo["name"]}</p>
<span data-sf="${userInfo["sf"]}">${userInfo["sf"]}</span>
<span data-uid>UID: ${userInfo["uid"]}</span>
</div>
</div>
`
)
},
{
"data-name": userInfo.name,
"data-uid": userInfo.uid,
"data-sf": userInfo.sf
}
);
DOMUtils.on($item, "click", ".online-user-avatar", (event) => {
utils.preventEvent(event);
window.open(
`home.php?mod=space&uid=${userInfo.uid}&do=profile`,
"_blank"
);
});
return $item;
}
};
const MTIdentifyLinks = () => {
var clearLink, excludedTags, filter, linkMixInit, linkPack, linkify, observePage, observer, setLink, url_regexp, xpath;
url_regexp = /((https?:\/\/|www\.)[\x21-\x7e]+[\w\/]|(\w[\w._-]+\.(com|cn|org|net|info|tv|cc))(\/[\x21-\x7e]*[\w\/])?|ed2k:\/\/[\x21-\x7e]+\|\/|thunder:\/\/[\x21-\x7e]+=)/gi;
clearLink = function(a) {
var b;
a = null != (b = a.originalTarget) ? b : a.target;
if (null != a && "a" === a.localName && -1 !== a.className.indexOf("texttolink") && (b = a.getAttribute("href"), 0 !== b.indexOf("http") && 0 !== b.indexOf("ed2k://") && 0 !== b.indexOf("thunder://")))
return a.setAttribute("href", "http://" + b);
};
document.addEventListener("mouseover", clearLink);
setLink = function(a) {
if (typeof a != "object") {
return;
}
if (null != a && typeof a.parentNode !== "undefined" && typeof a.parentNode.className !== "undefined" && typeof a.parentNode.className.indexOf === "function" && -1 === a.parentNode.className.indexOf("texttolink") && "#cdata-section" !== a.nodeName) {
var b = a.textContent.replace(
url_regexp,
'<a href="$1" target="_blank" class="texttolink">$1</a>'
);
if (a.textContent.length !== b.length) {
var c = document.createElement("span");
c.innerHTML = b;
console.log(`识别: ${c.querySelector("a")}`);
return a.parentNode.replaceChild(c, a);
}
}
};
excludedTags = "a svg canvas applet input button area pre embed frame frameset head iframe img option map meta noscript object script style textarea code".split(
" "
);
xpath = `//text()[not(ancestor::${excludedTags.join(
") and not(ancestor::"
)})]`;
filter = new RegExp(`^(${excludedTags.join("|")})$`, "i");
linkPack = function(a, b) {
var c, d;
if (b + 1e4 < a.snapshotLength) {
var e = c = b;
for (d = b + 1e4; b <= d ? c <= d : c >= d; e = b <= d ? ++c : --c)
setLink(a.snapshotItem(e));
setTimeout(function() {
return linkPack(a, b + 1e4);
}, 15);
} else
for (e = c = b, d = a.snapshotLength; b <= d ? c <= d : c >= d; e = b <= d ? ++c : --c)
setLink(a.snapshotItem(e));
};
linkify = function(a) {
a = document.evaluate(
xpath,
a,
null,
XPathResult.UNORDERED_NODE_SNAPSHOT_TYPE,
null
);
return linkPack(a, 0);
};
observePage = function(a) {
for (a = document.createTreeWalker(
a,
NodeFilter.SHOW_TEXT,
{
acceptNode: function(a2) {
if (!filter.test(a2.parentNode.localName))
return NodeFilter.FILTER_ACCEPT;
}
},
false
); a.nextNode(); )
setLink(a.currentNode);
};
observer = new window.MutationObserver(function(a) {
var b, c;
var d = 0;
for (b = a.length; d < b; d++) {
var e = a[d];
if ("childList" === e.type) {
var g = e.addedNodes;
var f = 0;
for (c = g.length; f < c; f++) e = g[f], observePage(e);
}
}
});
linkMixInit = function() {
return linkify(document.body), observer.observe(document.body, {
childList: true,
subtree: true
});
};
var clearlinkF = function(a) {
var url = a.getAttribute("href");
if (0 !== url.indexOf("http") && 0 !== url.indexOf("ed2k://") && 0 !== url.indexOf("thunder://"))
return a.setAttribute("href", "http://" + url);
}, clearlinkE = function() {
for (var a = document.getElementsByClassName("texttolink"), b = 0; b < a.length; b++)
clearlinkF(a[b]);
};
setTimeout(clearlinkE, 1500);
setTimeout(linkMixInit, 100);
};
const MTForumPost = {
$flag: {
isSetHljsCSS: false
},
init() {
PopsPanel.execMenuOnce("mt-forum-post-autoExpandContent", () => {
return this.autoExpandContent();
});
PopsPanel.execMenuOnce("mt-forum-post-repairImageWidth", () => {
return this.repairImageWidth();
});
domUtils.ready(() => {
PopsPanel.execMenu("mt-forum-post-removeFontStyle", () => {
this.removeFontStyle();
});
PopsPanel.execMenu("mt-forum-post-removeCommentFontStyle", () => {
this.removeCommentFontStyle();
});
PopsPanel.execMenu("mt-forum-post-addCommentOnBtn", () => {
this.addCommentOnBtn();
});
PopsPanel.execMenuOnce("mt-forum-post-loadNextPageComment", () => {
this.loadNextPageComment();
});
PopsPanel.execMenuOnce("mt-forum-post-codeQuoteOptimization", () => {
this.codeQuoteOptimization();
});
PopsPanel.execMenuOnce("mt-forum-post-editorOptimizationNormal", () => {
MTEditorOptimizationNormal.init();
});
PopsPanel.execMenu("mt-forum-post-optimizationImagePreview", () => {
this.optimizationImagePreview();
});
PopsPanel.execMenuOnce("mt-forum-post-setAttachmentsClickTip", () => {
this.setAttachmentsClickTip();
});
});
},
/**
* 自动展开帖子内容
*/
autoExpandContent() {
log.info(`自动展开帖子内容`);
return addStyle(
/*css*/
`
div.comiis_message.bg_f.view_one.b_b.cl.message>div.comiis_messages.comiis_aimg_show.cl{max-height:inherit!important;overflow-y:inherit!important;position:inherit!important}
.comiis_lookfulltext_bg,.comiis_lookfulltext_key{display:none!important}
`
);
},
/**
* 修复图片宽度
*/
repairImageWidth() {
log.info(`修复图片宽度`);
return addStyle(
/*css*/
`
.comiis_messages img{
max-width: 100% !important;
}`
);
},
/**
* 移除帖子字体效果
*/
removeFontStyle() {
log.info(`移除帖子字体效果`);
let $messageTable = $(
".comiis_a.comiis_message_table"
);
if (!$messageTable) {
return;
}
domUtils.html($messageTable, domUtils.html($messageTable).replace(
MTRegExp.fontSpecial,
""
));
},
/**
* 移除评论区的字体效果
*/
removeCommentFontStyle() {
var _a2;
log.info(`移除评论区的字体效果`);
let $fontList = document.querySelectorAll("font");
let $postForumMainContent = ((_a2 = document.querySelector(".comiis_postlist .comiis_postli")) == null ? void 0 : _a2.innerHTML) || "";
if ($postForumMainContent !== "") {
$fontList.forEach(($font) => {
if (!$postForumMainContent.includes($font.innerHTML)) {
$font.removeAttribute("color");
$font.removeAttribute("style");
$font.removeAttribute("size");
}
});
$$(".comiis_message.message").forEach(($message) => {
if ($postForumMainContent.includes($message.innerHTML)) {
$message.innerHTML = $message.innerHTML.replace(
MTRegExp.fontSpecial,
""
);
let $next = $message.nextElementSibling;
if ($next && $next.localName === "strike") {
$next.outerHTML = $next.outerHTML.replace(/^<strike>(\n|)/g, "").replace(/<\/strike>$/g, "");
}
}
});
}
$$(".comiis_postli.comiis_list_readimgs.nfqsqi").forEach((item) => {
let $parent = item.parentElement;
if ($parent && $parent.localName === "strike") {
$parent.outerHTML = $parent.outerHTML.replace(/^<strike>(\n|)/g, "").replace(/<\/strike>$/g, "");
}
});
},
/**
* 添加【点评】按钮
*/
addCommentOnBtn() {
log.info(`添加【点评】按钮`);
utils.waitNodeList(
".bottom_zhan:not([data-isaddreviews])"
).then(($bottomZhanList) => {
$bottomZhanList.forEach(($bottmZhan) => {
var _a2, _b, _c;
$bottmZhan.setAttribute("data-isaddreviews", "true");
var replyNode = $bottmZhan.querySelector("a");
if (!replyNode) {
return;
}
var replyUrl = replyNode.getAttribute("datahref") || replyNode.getAttribute("data-href") || replyNode.href || "";
var rewardUrl = replyUrl.replace("mod=post&", "mod=misc&").replace("action=reply&", "action=comment&");
var reviewPage = (_a2 = replyUrl == null ? void 0 : replyUrl.match(/&page=([\w]+)/i)) == null ? void 0 : _a2[1];
var reviewsUrl = `${rewardUrl}&extra=page%3D1&page=${reviewPage}`;
var $postli = $bottmZhan == null ? void 0 : $bottmZhan.closest(".comiis_postli[id]");
var reviewsPID = (_b = $postli.getAttribute("id")) == null ? void 0 : _b.replace("pid", "&pid=");
reviewsUrl = reviewsUrl + reviewsPID;
var reviewsUserName = ((_c = $postli.querySelector(".top_user.f_b")) == null ? void 0 : _c.textContent) || "";
var reviewsNode = domUtils.parseHTML(
/*html*/
`
<a href="${reviewsUrl}" class="f_c dialog">
<i class="comiis_font mt_review" style="content: url("https://s1.ax1x.com/2020/04/26/Jcq8VU.png"); height: 15px;"></i>
</a>
`,
true,
false
);
domUtils.on(reviewsNode, "click", function() {
utils.waitNode("div[id=ntcmsg_popmenu]>div>span.f_c").then((element) => {
try {
element.innerText = "点评 " + reviewsUserName;
} catch (err) {
log.error("修改点评失败", err);
}
});
});
domUtils.prepend($bottmZhan, reviewsNode);
});
});
},
/**
* 自动加载下一页评论
*/
loadNextPageComment() {
var _a2;
log.info(`自动加载下一页评论`);
if (document.title.includes("提示信息 - MT论坛")) {
return;
}
function getLoadingCommentTip() {
return document.querySelector("#loading-comment-tip");
}
function getLoadingCommentTipParent() {
return document.querySelector("#loading-comment-tip").parentElement;
}
function autoLoadNextPageComments(post_comments_list) {
let $loadingCommentTip = getLoadingCommentTip();
let $loadingCommentTipParent = getLoadingCommentTipParent();
domUtils.css($loadingCommentTipParent, "display", "");
let $nextPage = Array.from(
post_comments_list.querySelectorAll("a[href]")
).find((item) => {
var _a3;
return ((_a3 = item.textContent) == null ? void 0 : _a3.trim()) === "下一页";
});
let next_page_url = $nextPage.href;
log.info("获取下一页url:", next_page_url);
if (next_page_url.includes("javascript:;")) {
log.info("暂无下一页的评论");
domUtils.remove($loadingCommentTipParent);
return;
}
async function loadNextComments() {
domUtils.text($loadingCommentTip, "正在加载评论中...");
domUtils.css($loadingCommentTipParent, "display", "");
log.info(`请求下一页评论:` + next_page_url);
let url = next_page_url;
let response = await httpx.get(url, {
fetch: true
});
if (!response.status) {
return;
}
let nextPageDoc = domUtils.parseHTML(
response.data.responseText,
true,
true
);
let $kqide = document.querySelector(
".comiis_postlist.kqide"
);
let $nextPage_kqide = nextPageDoc.querySelector(
".comiis_postlist.kqide"
);
let $getNextPage = nextPageDoc.querySelector(".nxt");
if ($getNextPage) {
log.success("成功获取到下一页评论");
next_page_url = $getNextPage.getAttribute("href") || $getNextPage.href;
} else {
log.error("评论全部加载完毕,关闭监听事件");
domUtils.remove(".comiis_page.bg_f");
domUtils.remove($loadingCommentTipParent);
domUtils.off($loadingCommentTip, "click", loadNextComments);
domUtils.off(window, "scroll", lockFn.run);
}
let $pageStrong = $getNextPage == null ? void 0 : $getNextPage.parentElement.querySelector("strong");
if ($pageStrong) {
let $pageSelect = document.querySelector("#select_a");
if ($pageSelect) {
let $pageText = Array.from($pageSelect.childNodes).find(
(item) => item.nodeName === "#text"
);
if ($pageText) {
$pageText.textContent = `第 ${$pageStrong.textContent} 页`;
}
}
}
PopsPanel.execMenu("mt-forum-post-syncNextPageUrl", () => {
if (window === (top == null ? void 0 : top.window)) {
let urlObj = new URL(url);
let setLocationUrl = `${urlObj.pathname}${urlObj.search}`;
window.history.pushState("forward", "", setLocationUrl);
}
});
domUtils.append($kqide, $nextPage_kqide);
MTForumPost.init();
}
var lockFn = new utils.LockFunction(async () => {
if (utils.isNearBottom(50)) {
await loadNextComments();
}
});
domUtils.text($loadingCommentTip, "请上下滑动或点击加载");
domUtils.on(window, "scroll", lockFn.run);
domUtils.on($loadingCommentTip, "click", loadNextComments);
lockFn.run();
}
let tip_html = (
/*html*/
`
<div class="comiis_multi_box bg_f b_t">
<label class="comiis_loadbtn bg_e f_d" id="loading-comment-tip">正在等待页面加载完毕</label>
</div>`
);
let $tip = domUtils.parseHTML(tip_html, true, false);
let $bodybox = document.querySelector(".comiis_bodybox");
domUtils.append($bodybox, $tip);
let commentsEle = document.querySelector(".comiis_pltit span.f_d") || document.querySelector("#comiis_foot_memu .comiis_kmvnum");
if (document.querySelector(".comiis_pltit h2") && ((_a2 = document.querySelector(".comiis_pltit h2")) == null ? void 0 : _a2.textContent.includes("暂无评论"))) {
domUtils.remove(getLoadingCommentTipParent());
log.info("暂无评论");
return;
}
let commentsNum = parseInt(commentsEle.textContent);
if (commentsNum >= 10) {
utils.waitNode(".comiis_page.bg_f").then(($nextPage) => {
autoLoadNextPageComments($nextPage);
});
} else {
domUtils.remove(getLoadingCommentTipParent());
log.info("无多页评论");
}
},
/**
* 代码块优化
**/
codeQuoteOptimization() {
log.info(`代码块优化`);
function hljs_smali(hljs2) {
var smali_instr_low_prio = [
"add",
"and",
"cmp",
"cmpg",
"cmpl",
"const",
"div",
"double",
"float",
"goto",
"if",
"int",
"long",
"move",
"mul",
"neg",
"new",
"nop",
"not",
"or",
"rem",
"return",
"shl",
"shr",
"sput",
"sub",
"throw",
"ushr",
"xor"
];
var smali_instr_high_prio = [
"aget",
"aput",
"array",
"check",
"execute",
"fill",
"filled",
"goto/16",
"goto/32",
"iget",
"instance",
"invoke",
"iput",
"monitor",
"packed",
"sget",
"sparse"
];
var smali_keywords = [
"transient",
"constructor",
"abstract",
"final",
"synthetic",
"public",
"private",
"protected",
"static",
"bridge",
"system"
];
return {
aliases: ["smali"],
contains: [
{
className: "string",
begin: '"',
end: '"',
relevance: 0
},
hljs2.COMMENT("#", "$", {
relevance: 0
}),
{
className: "keyword",
variants: [
{ begin: "\\s*\\.end\\s[a-zA-Z0-9]*" },
{ begin: "^[ ]*\\.[a-zA-Z]*", relevance: 0 },
{ begin: "\\s:[a-zA-Z_0-9]*", relevance: 0 },
{ begin: "\\s(" + smali_keywords.join("|") + ")" }
]
},
{
className: "built_in",
variants: [
{
begin: "\\s(" + smali_instr_low_prio.join("|") + ")\\s"
},
{
begin: "\\s(" + smali_instr_low_prio.join("|") + ")((\\-|/)[a-zA-Z0-9]+)+\\s",
relevance: 10
},
{
begin: "\\s(" + smali_instr_high_prio.join("|") + ")((\\-|/)[a-zA-Z0-9]+)*\\s",
relevance: 10
}
]
},
{
className: "class",
begin: "L[^(;:\n]*;",
relevance: 0
},
{
begin: "[vp][0-9]+"
}
]
};
}
if (!this.$flag.isSetHljsCSS) {
hljs.registerLanguage("smali", hljs_smali);
addStyle(
/*css*/
`
.hljs ol{margin:0 0 0 10px;padding:10px 10px 10px 25px}
.hljs li{padding-left:10px;list-style-type:decimal-leading-zero;font-family:Monaco,Consolas,'Lucida Console','Courier New',serif;font-size:12px;line-height:1.8em}
.hljs li:hover{background:#2c313c}
.hljs li::marker{unicode-bidi:isolate;font-variant-numeric:tabular-nums;text-transform:none;text-indent:0!important;text-align:start!important;text-align-last:start!important}
select.code-select-language{height:40px;line-height:40px;font-size:14px;border:1px solid #5c5c5c;border-radius:5px;text-align:center;outline:0;margin-left:10px}
`
);
addStyle(
/*css*/
`
.reader-copy-button{background:#000;background-size:cover;background-repeat:no-repeat;background-position:0;color:#fff;line-height:40px;display:block;text-align:center;border-radius:5px;cursor:pointer;font-size:15px;width:70px;user-select:none}
.reader-copy-button i{display:inline-block;margin-right:6px;width:16px;height:16px;background-size:cover;vertical-align:sub;user-select:none}
`
);
domUtils.on(
document,
"click",
".reader-copy-button",
async function(event) {
utils.preventEvent(event);
let $click = event.target;
let codeElement = document.querySelector(
$click.getAttribute("data-code-selector")
);
await utils.setClip(codeElement.outerText || codeElement.innerText);
Qmsg.success("已复制到剪贴板");
return false;
}
);
}
let comiis_blockcode = document.querySelectorAll(
".comiis_blockcode.comiis_bodybg"
);
comiis_blockcode.forEach(($comiis_bodybg) => {
if ($comiis_bodybg.getAttribute("data-copy")) {
return;
}
$comiis_bodybg.setAttribute("data-copy", "true");
let tempDivElement = domUtils.createElement(
"div",
{
innerHTML: (
/*html*/
`
<span class="reader-copy-button">
<i>
<svg width="16px" height="16px" viewBox="0 0 16 16" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<title>复制按钮</title>
<defs>
<rect id="path-1" x="0" y="0" width="16" height="16"></rect>
</defs>
<g id="阅读页复制-拦截" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
<g>
<mask id="mask-2" fill="white">
<use xlink:href="#path-1"></use>
</mask>
<g id="矩形"></g>
<path d="M4.11794319,3.55555556 L9.51168644,3.55555556 C10.4768443,3.55555556 11.2592593,4.33797056 11.2592593,5.30312837 L11.2592593,13.067242 C11.2592593,14.0323998 10.4768443,14.8148148 9.51168644,14.8148148 L4.11794319,14.8148148 C3.15278537,14.8148148 2.37037037,14.0323998 2.37037037,13.067242 L2.37037037,5.30312837 C2.37037037,4.33797056 3.15278537,3.55555556 4.11794319,3.55555556 Z" id="矩形" stroke="#DFDFDF" stroke-width="1.45631068" mask="url(#mask-2)"></path>
<path d="M5.03703704,0.888888889 L12.1481481,0.888888889 C13.1299877,0.888888889 13.9259259,1.68482711 13.9259259,2.66666667 L13.9259259,12.7407407" id="形状" stroke="#DFDFDF" stroke-width="1.45631068" mask="url(#mask-2)"></path>
</g>
</g>
</svg>
</i>
复制
</span>`
)
},
{
style: "height: 34px;margin: 14px 0px;display: inline-flex;align-items: flex-end;"
}
);
domUtils.before($comiis_bodybg, tempDivElement);
function setElementHighlight(ele, language = "java") {
if (!ele.oldValue) {
ele.oldValue = ele.textContent;
}
ele.innerHTML = hljs.highlight(ele.oldValue, { language }).value.replace(/\\n$/gi, "");
}
let codeLanguage = hljs.highlightAuto(
$comiis_bodybg.textContent
).language;
let selectElementParentDiv = document.createElement("div");
let selectElement = document.createElement("select");
let selectLanguageList = hljs.listLanguages().sort();
selectLanguageList = selectLanguageList.concat("自动检测");
let selectInnerHTML = "";
selectLanguageList.forEach((languageName) => {
if (languageName.startsWith("自动检测")) {
selectInnerHTML += `<option data-value="${codeLanguage}" selected="selected">${languageName}(${codeLanguage})</option>`;
} else {
selectInnerHTML += `<option data-value="${languageName}">${languageName}</option>`;
}
});
selectElement.className = "code-select-language";
selectElement.innerHTML = selectInnerHTML;
domUtils.on(selectElement, "change", function() {
let changeCodeLanguage = selectElement.selectedOptions[0].getAttribute("data-value");
selectElement.setAttribute("aria-label", changeCodeLanguage);
log.info("切换代码块语言: ", changeCodeLanguage);
$comiis_bodybg.querySelectorAll("li").forEach((liElement) => {
setElementHighlight(liElement, changeCodeLanguage);
});
});
utils.preventEvent(selectElement, "click");
selectElementParentDiv.appendChild(selectElement);
tempDivElement.append(selectElementParentDiv);
utils.dispatchEvent(selectElement, "change");
$comiis_bodybg.className = "hljs";
$comiis_bodybg.firstChild.removeAttribute("class");
tempDivElement.querySelector(".reader-copy-button").setAttribute(
"data-code-selector",
utils.getElementSelector($comiis_bodybg)
);
});
},
/**
* 图片查看优化
*/
optimizationImagePreview() {
log.info(`图片查看优化`);
function viewIMG(imgList = [], index = 0) {
let viewerULNodeHTML = "";
imgList.forEach((item) => {
viewerULNodeHTML += `<li><img data-src="${item}"></li>`;
});
let viewerULNode = domUtils.createElement("ul", {
innerHTML: viewerULNodeHTML
});
let viewer = new Viewer(viewerULNode, {
inline: false,
url: "data-src",
zIndex: utils.getMaxZIndex() + 100,
hidden: () => {
viewer.destroy();
}
});
log.info("查看的图片的下标", index);
viewer.view(index);
viewer.zoomTo(1);
viewer.show();
}
let blackListNoViewIMG = [
{
hostName: "avatar-bbs.mt2.cn",
pathName: "*"
},
{
hostName: "cdn-bbs.mt2.cn",
pathName: "^(/static(/|//)image|/template)"
},
{
hostName: window.location.hostname,
pathName: "^(/static(/|//)image|/template)"
},
{
hostName: window.location.hostname,
pathName: "/uc_server/avatar.php"
}
];
utils.waitNodeList(
"div.comiis_postlist.kqide .comiis_postli:not([data-isHandlingViewIMG])"
).then((nodeList) => {
nodeList.forEach((item) => {
item.setAttribute("data-isHandlingViewIMG", "true");
let clickShowIMGList = [];
item.querySelectorAll("img").forEach(($img) => {
let IMG_URL = $img.src;
let IMG_URL_HOSTNAME = new URL(IMG_URL).hostname;
let IMG_URL_PATHNAME = new URL(IMG_URL).pathname;
let imgParentNode = $img.parentElement;
if (imgParentNode.nodeName.toLowerCase() === "span") {
imgParentNode.removeAttribute("onclick");
}
if (imgParentNode.nodeName.toLowerCase() === "a" && imgParentNode.getAttribute("href") === IMG_URL) {
imgParentNode.setAttribute("href", "javascript:;");
imgParentNode.removeAttribute("target");
}
let isMatching = false;
for (let item2 of blackListNoViewIMG) {
if (IMG_URL_HOSTNAME.indexOf(item2["hostName"]) != -1 && IMG_URL_PATHNAME.match(item2["pathName"])) {
isMatching = true;
break;
}
}
if (isMatching) {
return;
}
clickShowIMGList = [...clickShowIMGList, IMG_URL];
domUtils.on($img, "click", function() {
log.info("点击图片", $img);
let _index_ = clickShowIMGList.findIndex((_img_) => {
return _img_ == IMG_URL;
});
viewIMG(clickShowIMGList, _index_);
});
});
if (clickShowIMGList.length) {
log.info("处理的图片", clickShowIMGList);
}
});
});
},
/**
* 附件点击提醒
*/
setAttachmentsClickTip() {
log.info(`附件点击提醒`);
function handleClick($ele) {
if ($ele.hasAttribute("href")) {
let attachmentURL = $ele.getAttribute("href");
let attachmentNameNode = $ele.querySelector("span.f_ok");
let attachmentDownloadInfo = $ele.querySelector(".attach_size");
if (domUtils.text(attachmentDownloadInfo).indexOf("金币") === -1) {
return;
}
log.info("发现附件", $ele);
log.info("该附件是金币附件,拦截!");
let attachmentName = domUtils.text(attachmentNameNode);
$ele.setAttribute("data-href", $ele.getAttribute("href"));
$ele.removeAttribute("href");
attachmentNameNode.innerText = "【已拦截】" + attachmentName;
$ele.onclick = function() {
log.info("附件url:", attachmentURL);
__pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: (
/*html*/
`<br />确定花费2金币下载附件 <a style="color: #507daf !important;">${attachmentName}</a> ?<br /><br />`
),
html: true
},
btn: {
ok: {
callback: (details) => {
window.open(attachmentURL, "_blank");
details.close();
}
}
},
mask: {
enable: true
},
width: "88vw",
height: "200px"
});
};
}
}
utils.mutationObserver(document.documentElement, {
callback: () => {
document.querySelectorAll(".attnm a").forEach((item) => {
handleClick(item);
});
document.querySelectorAll(".comiis_attach a").forEach((item) => {
handleClick(item);
});
},
config: { childList: true, subtree: true }
});
utils.waitNodeList(".attnm a").then((nodeList) => {
nodeList.forEach((item) => {
handleClick(item);
});
});
utils.waitNodeList(".comiis_attach a").then((nodeList) => {
nodeList.forEach((item) => {
handleClick(item);
});
});
}
};
const MTSearch = {
init() {
addStyle(
/*css*/
`
/* 去除搜索框的蒙版 */
#comiis_search_noe{
display: none !important;
}
/* 显示真正的试搜索框 */
#comiis_search_two{
display: block !important;
}
`
);
DOMUtils.ready(() => {
PopsPanel.execMenuOnce("mt-search-showSearchHistory", () => {
this.showSearchHistory();
});
PopsPanel.execMenuOnce("mt-search-repairClearBtn", () => {
this.repairClearBtn();
});
PopsPanel.execMenuOnce("mt-search-searchInputAutoFocus", () => {
this.searchInputAutoFocus();
});
});
},
/**
* 显示搜索历史
*/
async showSearchHistory() {
log.info(`显示搜索历史`);
let searchHistoryList = _GM_getValue("search_history", []);
let $input = $("#scform_srchtxt");
let $submit = $("#searchform");
let suggestion = __pops.searchSuggestion({
target: $input,
inputTarget: $input,
data: searchHistoryList,
getItemHTML: function(item) {
return item;
},
getData(inputValue) {
return searchHistoryList.filter((item) => {
return item.includes(inputValue);
});
},
deleteIcon: {
enable: true,
callback(event, liElement, data) {
let findIndex = searchHistoryList.findIndex((item) => item === data);
if (findIndex !== -1) {
searchHistoryList.splice(findIndex, 1);
_GM_setValue("search_history", searchHistoryList);
}
liElement.remove();
}
},
itemClickCallBack(event, liElement, data) {
$input.value = data;
$submit.submit();
}
});
suggestion.init();
suggestion.setAllEvent();
function search_event() {
let $submit2 = document.querySelector("#scform_submit");
DOMUtils.on($submit2, "click", function() {
let searchText = $input.value;
if (searchText != "") {
let localHistorySearchText = _GM_getValue(
"search_history",
[]
);
if (localHistorySearchText.includes(searchText)) {
log.info(`已有该搜索历史记录`);
} else {
log.info(`无该记录,追加`);
localHistorySearchText.push(searchText);
}
_GM_setValue("search_history", localHistorySearchText);
}
});
}
function add_clear_history() {
let localHistorySearchText = _GM_getValue("search_history", []);
let clear_history_innerHTML = (
/*html*/
`<div class="comiis_p12 f14 bg_f f_c b_b cl" style="padding-bottom:10px">搜索记录个数: ` + localHistorySearchText.length + /*html*/
`<button class="btn_clear_search_history" style="
border: none;
float: right;
background: red;
color: #fff;
border-radius: 3px;
font-weight: 600;
min-width: 20vw;
width: 20vw;
">清理记录</button></div>`
);
DOMUtils.before(
document.querySelector(".comiis_p12"),
clear_history_innerHTML
);
let $searchHistory = document.querySelector(".btn_clear_search_history");
DOMUtils.on($searchHistory, "click", (event) => {
utils.preventEvent(event);
_GM_deleteValue("search_history");
window.location.reload();
});
}
search_event();
add_clear_history();
},
/**
* 修复清空按钮
*/
repairClearBtn() {
utils.waitNode("a.ssclose").then(($empty) => {
log.info(`修复清空按钮`);
DOMUtils.on(
$empty,
"click",
(event) => {
let $input = document.querySelector("#scform_srchtxt");
if ($input) {
$input.value = "";
} else {
Qmsg.error("获取输入框失败");
}
},
{
capture: true
}
);
});
},
/**
* 搜索框自动获取焦点
*/
searchInputAutoFocus() {
let searchParams = new URLSearchParams(window.location.search);
if (searchParams.has("kw")) {
return;
}
utils.waitNode("#scform_srchtxt").then(($input) => {
log.info(`搜索框自动获取焦点`);
$input.focus();
});
}
};
const MTSign = {
init() {
domUtils.ready(() => {
PopsPanel.execMenuOnce("mt-sign-showTodaySignStar", () => {
this.showTodaySignStar();
});
PopsPanel.execMenuOnce("mt-sign-showTodayRanking", () => {
this.showTodayRanking();
});
});
},
/**
* 显示【今日签到之星】
*/
async showTodaySignStar() {
log.info(`显示【今日签到之星】`);
let todayStarParent = document.querySelector(
".pg_k_misign .comiis_qdinfo"
);
let todayStar = document.createElement("ul");
let response = await httpx.get("/k_misign-sign.html", {
headers: {
"User-Agent": utils.getRandomPCUA()
}
});
if (!response.status) {
return;
}
let doc = domUtils.parseHTML(response.data.responseText, true, true);
let todatastarele = doc.querySelector("#pt span.xg1");
if (!todatastarele) {
return;
}
let todaypeople = domUtils.text(todatastarele).replace(
"今日签到之星:",
""
);
todayStar.innerHTML = /*html*/
`
<li class="f_f" style="display: flex;flex-direction: column;width: 100%;">
<span class="comiis_tm">今日签到之星</span>
${todaypeople}
</li>
`;
let $comiisSpaceBox = document.querySelector(".comiis_space_box");
let comiis_space_box_height = parseInt(
getComputedStyle($comiisSpaceBox, null)["height"].replace("px", "")
);
let comiis_space_box_padding_bottom = parseInt(
getComputedStyle($comiisSpaceBox, null)["paddingBottom"].replace("px", "")
);
let total_height = comiis_space_box_height + comiis_space_box_padding_bottom + 50;
addStyle(
/*css*/
`
.comiis_space_box{
height: ${total_height}px;
background-size: 100% 100%;
}
.pg_k_misign .comiis_qdinfo{
height: 110px !important;
}`
);
todayStarParent.append(todayStar);
},
/**
* 显示【今日最先】
*/
showTodayRanking() {
log.info(`显示【今日最先】`);
let today_ranking_ele = document.querySelector(
".comiis_topnv .comiis_flex .flex"
);
let $li = domUtils.createElement("li", {
className: "flex"
});
let $todayLatest = domUtils.createElement(
"a",
{
id: "k_misignlist_today_latest",
href: "javascript:;",
innerHTML: "今日最先"
},
{
onclick: "ajaxlist('todayLatest');"
}
);
$li.appendChild($todayLatest);
domUtils.after(today_ranking_ele, $li);
let getMaxPage = async (urlextra2) => {
let response = await httpx.get(
`/k_misign-sign.html?operation=${urlextra2}`,
{
responseType: "html",
headers: {
"User-Agent": utils.getRandomPCUA()
}
}
);
if (!response.status) {
return;
}
let doc = domUtils.parseHTML(response.data.responseText, true, true);
let last_page = doc.querySelector(
"#J_list_detail .pg span"
);
if (last_page && typeof last_page.title != "undefined") {
let last_page_match = last_page.title.match(/([0-9]+)/);
if (last_page_match && last_page_match.length == 2) {
return parseInt(last_page_match[last_page_match.length - 1]);
} else {
Qmsg.error("获取页失败");
}
} else {
Qmsg.error("请求最先签到的页失败");
}
};
let getPagePeople = async (page) => {
let response = await httpx.get(
`/k_misign-sign.html?operation=list&op=&page=${page}`,
{
responseType: "html",
headers: {
"User-Agent": utils.getRandomPCUA()
}
}
);
if (!response.status) {
return;
}
let doc = domUtils.parseHTML(response.data.responseText, true, true);
let peoples = doc.querySelectorAll(
"#J_list_detail tbody tr"
);
let ret_array = [];
if (peoples.length == 2 && peoples[0].textContent.indexOf("暂无内容") != -1) {
return ret_array;
}
for (let index = 1; index <= peoples.length - 2; index++) {
let people = peoples[index];
let ret_json = {
user: "",
uid: "",
avatar: "",
days: "",
monthDays: "",
time: "",
reward: ""
};
let user_name = people.children[0].getElementsByTagName("a")[0].textContent;
let space_url = people.children[0].getElementsByTagName("a")[0].href;
let uid = space_url.match(/space-uid-([0-9]*)/)[1];
let sign_all_days = people.children[1].textContent;
let sign_month_days = people.children[2].textContent;
let sign_time = people.children[3].textContent;
let sign_reward = people.children[5].textContent;
ret_json["user"] = user_name;
ret_json["uid"] = uid;
ret_json["avatar"] = MTUtils.getAvatar(uid, "small");
ret_json["days"] = sign_all_days;
ret_json["monthDays"] = sign_month_days;
ret_json["time"] = sign_time;
ret_json["reward"] = sign_reward;
ret_array.push(ret_json);
}
return ret_array;
};
function changeRankList(data, listtype) {
let $ranklist = document.querySelector("#ranklist");
domUtils.html($ranklist, data);
domUtils.attr($ranklist, "listtype", listtype);
}
_unsafeWindow.ajaxlist = async (listtype) => {
listtype = listtype;
if (listtype == "today") {
loadingdelay = false;
urlextra = "list&op=today";
} else if (listtype == "month") {
loadingdelay = false;
urlextra = "list&op=month";
} else if (listtype == "zong") {
loadingdelay = false;
urlextra = "list&op=zong";
} else if (listtype == "calendar") {
loadingdelay = true;
urlextra = "calendar";
} else {
loadingdelay = false;
urlextra = "list";
}
if (listtype == "todayLatest") {
loadingdelay = false;
urlextra = "list&op=&page=0";
let maxPage = await getMaxPage(urlextra);
if (!maxPage) {
return;
}
let latestPeople = await getPagePeople(maxPage);
latestPeople.reverse();
if (latestPeople.length < 10) {
let latestPeople_2 = await getPagePeople(maxPage - 1);
latestPeople_2.reverse();
latestPeople = latestPeople.concat(latestPeople_2);
latestPeople.reverse();
}
let peopleHTML = "";
latestPeople.reverse();
latestPeople.forEach((people) => {
peopleHTML = peopleHTML + /*html*/
`
<tbody id="autolist_${people["uid"]}">
<tr>
<td class="k_misign_lu">
<a href="home.php?mod=space&uid=${people["uid"]}">
<img src="${people["avatar"]}" loading="lazy">
</a>
</td>
<td class="k_misign_ll"><span></span></td>
<td class="k_misign_lc">
<h4 class="f_c">
<a href="home.php?mod=space&uid=${people["uid"]}">${people["user"]}</a>
<span>${people["time"]}</span>
<span class="y">总天数 ${people["days"]}天</span>
</h4>
<p class="f_0">月天数 ${people["monthDays"]} 天,上次奖励 ${people["reward"]}</p>
</td>
</tr>
</tbody>`;
});
let latestHTML = (
/*html*/
`
<li class="styli_h bg_e"></li>
<div class="comiis_topnv bg_f b_t b_b">
<ul class="comiis_flex">
<li class="flex"><a href="javascript:;" id="k_misignlist_today" onclick="ajaxlist('today');">今日排行</a></li>
<li class="flex f_0"><em class="bg_0"></em><a href="javascript:;" id="k_misignlist_today_latest" onclick="ajaxlist('todayLatest');">今日最先</a>
</li>
<li class="flex"><a href="javascript:;" id="k_misignlist_month" onclick="ajaxlist('month');" class="f_c">本月排行</a>
</li>
<li class="flex"><a href="javascript:;" id="k_misignlist_zong" onclick="ajaxlist('zong');" class="f_c">总排行</a></li>
</ul>
</div>
<div class="k_misign_wp">
<div class="k_misign_list bg_f">
<table id="misign_list">
${peopleHTML}
</table>
</div>
</div>`
);
changeRankList(latestHTML, listtype);
} else {
httpx.get(`plugin.php?id=k_misign:sign&operation=${urlextra}`, {
responseType: "html",
fetch: true
}).then((response) => {
let data = response.data.responseText;
data = data.replace(
`今日排行</a></li>`,
`今日排行</a></li>
<li class="flex">
<a href="javascript:;" id="k_misignlist_today_latest" onclick="ajaxlist('todayLatest');" class="f_c">今日最先</a>
</li>`
);
if (listtype == "today") {
data = data.replace(
`<li class="flex"><a href="javascript:;" id="k_misignlist_today" onclick="ajaxlist('today');">今日排行</a></li>`,
/*html*/
`
<li class="flex f_0">
<em class="bg_0"></em>
<a href="javascript:;" id="k_misignlist_today" onclick="ajaxlist('today');">今日排行</a>
</li>
`
);
}
changeRankList(data, listtype);
});
}
};
}
};
const MTSpace = {
init() {
PopsPanel.execMenuOnce("mt-space-repairEnterSpace", () => {
this.repairEnterSpace();
});
domUtils.ready(() => {
PopsPanel.execMenuOnce("mt-space-showCommentContent", () => {
this.showCommentContent();
});
});
},
/**
* 修复无法进入空间
*/
repairEnterSpace() {
log.info(`修复无法进入空间`);
if (Router.isSpace()) {
let hrefParamsMatchArray = window.location.href.match(/home.php\?(.+)/gi);
let href_params = hrefParamsMatchArray[hrefParamsMatchArray.length - 1];
let params_split = href_params.split("&");
if (params_split.length == 2 && href_params.indexOf("uid=") != -1 && href_params.indexOf("mod=space") != -1) {
window.location.href = window.location.href + "&do=profile";
}
} else if (Router.isSpaceWithAt()) {
let hrefParamsMatchArray = window.location.href.match(/space-uid-(.+).html/i);
let href_params = hrefParamsMatchArray[hrefParamsMatchArray.length - 1];
window.location.href = `${window.location.origin}/home.php?mod=space&uid=${href_params}&do=profile`;
}
},
/**
* 显示帖子回复内容
*/
async showCommentContent() {
log.info(`显示帖子回复内容`);
addStyle(
/*css*/
`
div.contrete-reply{padding:5px 10px;border-top:1px solid #f3f3f3}
div.contrete-reply a{margin:0 10px}
`
);
async function getPCReply() {
let response = await httpx.get(window.location.href, {
headers: {
"User-Agent": utils.getRandomPCUA()
}
});
if (!response.status) {
return;
}
let doc = domUtils.parseHTML(response.data.responseText, true, true);
let resultList = [];
doc.querySelectorAll("#delform tr.bw0_all+tr").forEach((item) => {
let replyData = [];
let tagTDNode = item.querySelector("td");
let tagTDValue = domUtils.html(tagTDNode).replace(/^ /, "");
replyData.push(tagTDValue);
let nextHTML = domUtils.next(item);
let $tr = doc.querySelectorAll("#delform tr");
for (let index = 0; index < $tr.length; index++) {
if (!nextHTML || domUtils.attr(nextHTML, "class") === "bw0_all") {
break;
}
let nextTdHTML = nextHTML.querySelector("td");
let nextValue = domUtils.html(nextTdHTML).replace(/^ /, "");
replyData = replyData.concat(nextValue);
nextHTML = domUtils.next(nextHTML);
}
resultList.push(...replyData);
});
return resultList;
}
function getForumList() {
return utils.getNodeListValue(
ElementUtils.comiisForumList(),
ElementUtils.comiisPostli(),
ElementUtils.comiisMmlist()
);
}
function formatPCReply(dataList) {
let resultJSON = {};
dataList.forEach((item) => {
var _a2;
let divItem = domUtils.createElement("div", {
innerHTML: item
});
let url = (_a2 = divItem.querySelector("a")) == null ? void 0 : _a2.getAttribute("href");
let paramPtidMatch = url.match(MTRegExp.ptid);
let paramPidMatch = url.match(MTRegExp.pid);
if (!paramPtidMatch) {
Qmsg.error("获取ptid失败");
return;
}
if (!paramPidMatch) {
Qmsg.error("获取pid失败");
return;
}
let paramPtid = paramPtidMatch[paramPtidMatch.length - 1];
let paramPid = paramPidMatch[paramPidMatch.length - 1];
if (resultJSON[paramPtid]) {
resultJSON[paramPtid]["data"].push(item);
} else {
resultJSON[paramPtid] = {
ptid: paramPtid,
pid: paramPid,
data: [item]
};
}
});
return resultJSON;
}
var pcReplyArray = await getPCReply();
if (pcReplyArray == null) {
return;
}
var pcReplyJSON = formatPCReply(pcReplyArray);
let forumList = getForumList();
forumList.forEach((forumListItem, forumListItemIndex) => {
let praiseNode = forumListItem.querySelector(
".comiis_xznalist_bottom a"
);
let forumTid = praiseNode.getAttribute("tid");
if (!forumTid) {
Qmsg.error("获取帖子tid失败");
log.error(forumListItem);
return;
}
if (!pcReplyJSON[forumTid]) {
return;
}
pcReplyJSON[forumTid]["data"].forEach((forumListReplyHTMLItem) => {
domUtils.append(
forumListItem,
`<div class="contrete-reply">${forumListReplyHTMLItem}</div>`
);
});
});
}
};
const MTPaidThemePost = {
$key: {
tipData: "tipToFreeSubjectForumPost"
},
init() {
this.registerMenu();
let setTipForumPostList = this.getTipData();
if (Router.isPost()) {
let $kmren = document.querySelector("span.kmren");
if ($kmren) {
log.info("当前帖子存在需要购买主题");
let isAddTip = false;
let $tipBtn;
setTipForumPostList.forEach((item, index) => {
if (window.location.href.match(item["url"])) {
isAddTip = true;
return;
}
});
if (isAddTip) {
log.warn("已设置提醒");
$tipBtn = domUtils.createElement("a", {
href: "javascript:;",
className: "styli_tit f_c",
innerHTML: (
/*html*/
`
<i class="comiis_font" style="color: #ffffff;"></i>
`
)
});
domUtils.on($tipBtn, "click", function() {
__pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: "<p>确定移出付费主题白嫖列表?</p>",
html: true
},
btn: {
ok: {
callback: function() {
let findIndex = setTipForumPostList.findIndex(
(item, index) => {
return window.location.href.match(item["url"]);
}
);
if (findIndex !== -1) {
setTipForumPostList.splice(findIndex, 1);
MTPaidThemePost.setTipData(setTipForumPostList);
Qmsg.success("移除成功");
} else {
Qmsg.error("移除失败");
}
}
}
},
mask: {
enable: true
},
width: "88vw",
height: "300px"
});
});
} else {
log.info("未设置提醒");
$tipBtn = domUtils.createElement("a", {
href: "javascript:;",
className: "styli_tit f_c",
innerHTML: (
/*html*/
`
<i class="comiis_font" style="color: #FF9900;"></i>
`
)
});
domUtils.on($tipBtn, "click", () => {
let $_kmren = document.querySelector(".kmren");
let $_kmren_parent = domUtils.parent($_kmren);
let expirationTimeMatch = domUtils.text($_kmren_parent).replace(/\t|\n/g, "").match(
/[0-9]{4}-[0-9]{1,2}-[0-9]{1,2}[\s]{1}[0-9]{1,2}:[0-9]{1,2}/
);
if (!expirationTimeMatch || expirationTimeMatch.length == 0) {
Qmsg.error("获取付费主题到期时间失败");
return;
}
let expirationTime = expirationTimeMatch[0];
let expirationTimeStamp = utils.formatToTimeStamp(expirationTime);
setTipForumPostList.push({
url: window.location.href,
title: document.title.replace(" - MT论坛", ""),
expirationTime,
expirationTimeStamp,
isVisited: false
});
_GM_setValue("tipToFreeSubjectForumPost", setTipForumPostList);
Qmsg.success("添加成功");
setTimeout(function() {
window.location.reload();
}, 1500);
});
}
let $header_y = document.querySelector(
".comiis_head.f_top .header_y"
);
domUtils.append($header_y, $tipBtn);
}
}
function getTipNums() {
let needTipNums = 0;
Array.from(MTPaidThemePost.getTipData()).forEach((item, index) => {
if ((/* @__PURE__ */ new Date()).getTime() > item["expirationTimeStamp"] && item["isVisited"] == false) {
needTipNums += 1;
}
});
return needTipNums;
}
if (Router.isMySpace() || Router.isGuide() || Router.isForumList() || Router.isPlate()) {
let redBtn2 = document.querySelector(
".icon_msgs.bg_del.f_f"
);
let tipNums2 = 0;
if (redBtn2) {
tipNums2 = parseInt(domUtils.text(redBtn2));
domUtils.html(redBtn2, (tipNums2 + getTipNums()).toString());
domUtils.append(
".comiis_head .header_z .kmuser em",
`<span class="icon_msgs bg_del"></span>`
);
} else {
let tipnums = getTipNums();
if (tipnums) {
domUtils.append(
".comiis_head .header_z .kmuser em",
`<span class="icon_msgs bg_del"></span>`
);
}
}
}
let redBtn = document.querySelector(
".sidenv_num.bg_del.f_f"
);
let tipNums = 0;
if (redBtn) {
tipNums = parseInt(domUtils.text(redBtn));
domUtils.html(
".sidenv_num.bg_del.f_f",
(tipNums + getTipNums()).toString()
);
} else {
let tipnums = getTipNums();
if (tipnums) {
domUtils.before(
".sidenv_user em",
`<span class="sidenv_num bg_del f_f">${tipnums}</span>`
);
}
}
if (getTipNums()) {
domUtils.append(
".comiis_left_Touch .paymentsubjectreminder div.flex",
/*html*/
`
<span class="sidenv_num bg_del f_f" style="
position: relative;
border-radius: 18px;
height: 6px;
width: 6px;
left: 3px;
display: inline-flex;
bottom: 8px;
"></span>`
);
}
},
registerMenu() {
ElementUtils.registerLeftMenu({
name: "付费主题白嫖提醒",
icon: "",
iconColor: "#ec0000",
callback: () => {
this.showView();
}
});
},
/**
* 显示白嫖列表
*/
showView() {
log.info(`显示白嫖列表`);
let data = MTPaidThemePost.getTipData();
__pops.alert({
title: {
text: "付费主题白嫖列表",
position: "center"
},
content: {
text: "",
html: true
},
btn: {
ok: {
text: "关闭",
type: "default"
}
},
mask: {
enable: true
},
width: "88vw",
height: "88vh"
});
let notVisitedTipContent = "";
let notVisitedNums = 0;
let isFreeContent = "";
let isPaidContent = "";
let isFreeNotVisitedContentList = [];
let isFreeContentList = [];
let isPaidContentList = [];
data.forEach((item, index) => {
let timeColor = "#f91212";
let leftRedBtn = "";
if ((/* @__PURE__ */ new Date()).getTime() > item["expirationTimeStamp"]) {
timeColor = "#1e90ff";
if (item["isVisited"]) ;
else {
leftRedBtn = /*html*/
`
<span class="icon_msgs bg_del" style="position: fixed;width: 10px;height: 10px;border-radius: 50%;margin: 10px 0px 0px -15px;"></span>
`;
notVisitedNums = notVisitedNums + 1;
}
}
let contentInfo = {
content: (
/*html*/
`
<tbody id="autolist">
<tr>
<td style="width: 100%;">
<div style="display: inline-flex;">
${leftRedBtn}
<div style="width: 240px;">
<a href="javascript:void(0);" t-href="${item["url"]}" t-index="${index}" style="color: #1e90ff;">${item["title"]}</a>
<li style="margin: 5px 15px;color: ${timeColor};">${item["expirationTime"]}</li>
</div>
<div style="align-self: center;margin-left: 10px;" t-index="${index}" class="delsubjecttip">
<i class="comiis_font" style="font-size: 24px;padding: 0px 6px;"></i>
</div>
</div>
</td>
</tr>
<tr style="height:15px;"></tr>
</tbody>`
),
timestamp: item["expirationTimeStamp"]
};
if ((/* @__PURE__ */ new Date()).getTime() > item["expirationTimeStamp"]) {
if (leftRedBtn != "") {
isFreeNotVisitedContentList.push(contentInfo);
} else {
isFreeContentList.push(contentInfo);
}
} else {
isPaidContentList.push(contentInfo);
}
});
log.info("可白嫖但未访问:", isFreeNotVisitedContentList);
log.info("可白嫖:", isFreeContentList);
log.info("未到白嫖时间:", isPaidContentList);
utils.sortListByProperty(
isFreeNotVisitedContentList,
"expirationTimeStamp",
false
);
utils.sortListByProperty(isFreeContentList, "timestamp", false);
utils.sortListByProperty(isPaidContentList, "timestamp", false);
log.info("排序后——可白嫖但未访问:", isFreeNotVisitedContentList);
log.info("排序后——可白嫖:", isFreeContentList);
log.info("排序后——未到白嫖时间:", isPaidContentList);
isFreeContent = utils.mergeArrayToString(isFreeNotVisitedContentList, "content") + utils.mergeArrayToString(isFreeContentList, "content");
isPaidContent = utils.mergeArrayToString(isPaidContentList, "content");
if (notVisitedNums > 0) {
notVisitedTipContent = /*html*/
`
<span class="icon_msgs bg_del f_f" style="
display: inline-block;
position: absolute;
width: 16px;
height: 16px;
line-height: 16px;
border-radius: 50%;
font-size: 14px;
text-align: center;
margin: 3px 0px 0px 10px;
">${notVisitedNums}</span>`;
}
let dialogIsFreeContent = (
/*html*/
`
<details class="subjectcanvisit" open="">
<summary>可白嫖${notVisitedTipContent}</summary>
<table id="paymentSubjectReminderIsFreeList" style="overflow: auto;height: inherit;margin: 15px 0px;">
${isFreeContent}
</table>
</details>
`
);
let dialogIsPaidContent = (
/*html*/
`
<details class="subjectnotvisit">
<summary>需付费</summary>
<table id="paymentSubjectReminderIsPaidList" style="overflow: auto;height: inherit;margin: 15px 0px;">
${isPaidContent}
</table>
</details>
`
);
let $msgcon = document.querySelector(".msgcon");
domUtils.html($msgcon, "");
domUtils.append($msgcon, dialogIsFreeContent);
domUtils.append($msgcon, dialogIsPaidContent);
domUtils.css($msgcon, "height", "400px");
domUtils.on(
document.querySelector(".delsubjecttip i.comiis_font"),
"click",
(event) => {
let $click = event.target;
let $parent = domUtils.parent($click);
var t_index = parseInt($parent.getAttribute("t-index"));
__pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: "<p>确定移出付费主题白嫖列表?</p>",
html: true
},
mask: {
enable: true
},
btn: {
ok: {
callback: (details) => {
data.splice(t_index, 1);
MTPaidThemePost.setTipData(data);
utils.deleteParentNode($click, "tr");
details.close();
}
}
},
width: "80vw",
height: "300px"
});
}
);
let $paymentSubjectReminderIsFreeList = document.querySelector(
"#paymentSubjectReminderIsFreeList"
);
domUtils.on($paymentSubjectReminderIsFreeList, "click", "a", (event) => {
var _a2, _b, _c, _d, _e, _f;
let $click = event.target;
var tIndex = parseInt($click.getAttribute("t-index"));
var tHref = $click.getAttribute("t-href");
data[tIndex]["isVisited"] = true;
MTPaidThemePost.setTipData(data);
window.open(tHref, "_blank");
$click.setAttribute("style", "color: #000000;");
if (((_b = (_a2 = $click == null ? void 0 : $click.parentElement) == null ? void 0 : _a2.parentElement) == null ? void 0 : _b.children[0].className) != "icon_msgs bg_del") {
return;
}
$click.parentElement.parentElement.children[0].remove();
domUtils.append(
$paymentSubjectReminderIsFreeList,
(_f = (_e = (_d = (_c = $click == null ? void 0 : $click.parentElement) == null ? void 0 : _c.parentElement) == null ? void 0 : _d.parentElement) == null ? void 0 : _e.parentElement) == null ? void 0 : _f.parentElement
);
let $del = document.querySelector(
".subjectcanvisit summary span.icon_msgs.bg_del.f_f"
);
let notVisitedNumsStr = domUtils.text($del);
let notVisitedNums2 = parseInt(notVisitedNumsStr) - 1;
if (notVisitedNums2 > 0) {
domUtils.html($del, notVisitedNums2.toString());
} else {
$del.remove();
}
});
let $paymentSubjectReminderIsPaidList = document.querySelector(
"paymentSubjectReminderIsPaidList"
);
domUtils.on($paymentSubjectReminderIsPaidList, "click", "a", (event) => {
let $click = event.target;
$click.getAttribute("t-index");
var t_href = $click.getAttribute("t-href");
window.open(t_href, "_blank");
$click.setAttribute("style", "color: #000000;");
});
},
getTipData() {
return _GM_getValue(this.$key.tipData, []);
},
setTipData(data) {
_GM_setValue(this.$key.tipData, data);
}
};
const smallWindowCSS = ".pops {\r\n --icon-width: 24px;\r\n --right-btn-width: 115px;\r\n}\r\n\r\n.small-window-drag {\r\n width: 100%;\r\n position: relative;\r\n height: 10px;\r\n}\r\n.small-window-drag div {\r\n width: 50px;\r\n margin: 0 auto;\r\n height: 4px;\r\n background: #d9d9d9;\r\n border-radius: 15px;\r\n bottom: 3px;\r\n position: relative;\r\n}\r\n\r\n.pops[type-value] .pops-drawer-title {\r\n display: block;\r\n background: #fff;\r\n width: 100%;\r\n box-sizing: border-box;\r\n padding: 16px 0px;\r\n border-bottom: 1px solid #d6d6d6;\r\n}\r\n\r\n.small-window-title-container {\r\n display: flex;\r\n justify-content: space-between;\r\n padding: 0px 16px;\r\n}\r\n.small-window-website-icon {\r\n width: var(--icon-width);\r\n height: var(--icon-width);\r\n align-self: center;\r\n border-radius: 3px;\r\n}\r\n.small-window-title-text-container {\r\n margin-right: auto;\r\n max-width: calc(100% - var(--icon-width) - var(--right-btn-width));\r\n display: flex;\r\n flex-direction: column;\r\n gap: 4px;\r\n padding: 0px 16px;\r\n}\r\n.small-window-title-text,\r\n.small-window-website-host {\r\n min-width: 150px;\r\n overflow: hidden;\r\n text-overflow: ellipsis;\r\n white-space: nowrap;\r\n}\r\n.xtiper_sheet_tit.xtiper_sheet_left {\r\n display: block;\r\n background: #fff;\r\n width: 100%;\r\n box-sizing: border-box;\r\n}\r\n.small-window-protocol-info {\r\n display: flex;\r\n align-items: center;\r\n}\r\n.small-window-control {\r\n display: flex;\r\n align-items: center;\r\n align-content: center;\r\n width: var(--right-btn-width);\r\n justify-content: center;\r\n gap: 12px;\r\n}\r\n.small-window-control-image-view,\r\n.small-window-control-open-blank,\r\n.small-window-control-close {\r\n width: 2rem;\r\n height: 2rem;\r\n text-align: center;\r\n margin: 0 0;\r\n display: flex;\r\n justify-content: center;\r\n align-items: center;\r\n}\r\n\r\n.refresh-icon {\r\n width: 40px;\r\n display: flex;\r\n align-items: center;\r\n justify-content: center;\r\n padding: 0px 16px;\r\n}\r\n.refresh-icon-in,\r\n.refresh-icon-out {\r\n position: absolute;\r\n border: 5px solid rgba(0, 183, 229, 0.9);\r\n opacity: 0.9;\r\n border-radius: 50px;\r\n box-shadow: 0 0 15px #2187e7;\r\n width: 20px;\r\n height: 20px;\r\n margin: 0 auto;\r\n}\r\n.refresh-icon-out {\r\n background-color: rgba(0, 0, 0, 0);\r\n border-right: 5px solid transparent;\r\n border-left: 5px solid transparent;\r\n -moz-animation: spinPulse 1s infinite ease-in-out;\r\n -webkit-animation: spinPulse 1s infinite ease-in-out;\r\n -o-animation: spinPulse 1s infinite ease-in-out;\r\n -ms-animation: spinPulse 1s infinite ease-in-out;\r\n}\r\n.refresh-icon-in {\r\n background: rgba(0, 0, 0, 0) no-repeat center center;\r\n border-top: 5px solid transparent;\r\n border-bottom: 5px solid transparent;\r\n -moz-animation: spinoffPulse 3s infinite linear;\r\n -webkit-animation: spinoffPulse 3s infinite linear;\r\n -o-animation: spinoffPulse 3s infinite linear;\r\n -ms-animation: spinoffPulse 3s infinite linear;\r\n}\r\n@-moz-keyframes spinPulse {\r\n 0% {\r\n -moz-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -moz-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -moz-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-moz-keyframes spinoffPulse {\r\n 0% {\r\n -moz-transform: rotate(0);\r\n }\r\n 100% {\r\n -moz-transform: rotate(360deg);\r\n }\r\n}\r\n@-webkit-keyframes spinPulse {\r\n 0% {\r\n -webkit-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -webkit-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -webkit-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-webkit-keyframes spinoffPulse {\r\n 0% {\r\n -webkit-transform: rotate(0);\r\n }\r\n 100% {\r\n -webkit-transform: rotate(360deg);\r\n }\r\n}\r\n@-o-keyframes spinPulse {\r\n 0% {\r\n -o-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -o-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -o-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-o-keyframes spinoffPulse {\r\n 0% {\r\n -o-transform: rotate(0);\r\n }\r\n 100% {\r\n -o-transform: rotate(360deg);\r\n }\r\n}\r\n@-ms-keyframes spinPulse {\r\n 0% {\r\n -ms-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -ms-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -ms-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-ms-keyframes spinoffPulse {\r\n 0% {\r\n -ms-transform: rotate(0);\r\n }\r\n 100% {\r\n -ms-transform: rotate(360deg);\r\n }\r\n}\r\n@-moz-keyframes spinPulse {\r\n 0% {\r\n -moz-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -moz-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -moz-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-moz-keyframes spinoffPulse {\r\n 0% {\r\n -moz-transform: rotate(0);\r\n }\r\n 100% {\r\n -moz-transform: rotate(360deg);\r\n }\r\n}\r\n@-webkit-keyframes spinPulse {\r\n 0% {\r\n -webkit-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -webkit-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -webkit-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-webkit-keyframes spinoffPulse {\r\n 0% {\r\n -webkit-transform: rotate(0);\r\n }\r\n 100% {\r\n -webkit-transform: rotate(360deg);\r\n }\r\n}\r\n@-o-keyframes spinPulse {\r\n 0% {\r\n -o-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -o-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -o-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-o-keyframes spinoffPulse {\r\n 0% {\r\n -o-transform: rotate(0);\r\n }\r\n 100% {\r\n -o-transform: rotate(360deg);\r\n }\r\n}\r\n@-ms-keyframes spinPulse {\r\n 0% {\r\n -ms-transform: rotate(160deg);\r\n opacity: 0;\r\n box-shadow: 0 0 1px #505050;\r\n }\r\n 50% {\r\n -ms-transform: rotate(145deg);\r\n opacity: 1;\r\n }\r\n 100% {\r\n -ms-transform: rotate(-320deg);\r\n opacity: 0;\r\n }\r\n}\r\n@-ms-keyframes spinoffPulse {\r\n 0% {\r\n -ms-transform: rotate(0);\r\n }\r\n 100% {\r\n -ms-transform: rotate(360deg);\r\n }\r\n}\r\n";
class GestureBack {
constructor(config) {
/**
* 是否正在后退
*/
__publicField(this, "isBacking", false);
__publicField(this, "config");
this.config = config;
this.enterGestureBackMode.bind(this);
this.quitGestureBackMode.bind(this);
this.popStateEvent.bind(this);
if (typeof this.config.backDelayTime !== "number" || isNaN(this.config.backDelayTime)) {
this.config.backDelayTime = 150;
}
if (this.config.win == null) {
this.config.win = self;
}
}
/**
* popstate事件函数
* @param event
*/
popStateEvent(event) {
utils.preventEvent(event);
if (this.isBacking) {
return;
}
this.quitGestureBackMode(true);
}
/**
* 进入手势模式
*/
enterGestureBackMode() {
log.success("进入手势模式");
let pushUrl = this.config.hash;
if (!pushUrl.startsWith("#")) {
if (!pushUrl.startsWith("/")) {
pushUrl = "/" + pushUrl;
}
pushUrl = "#" + pushUrl;
}
if (this.config.useUrl) {
pushUrl = this.config.win.location.origin + this.config.win.location.pathname + this.config.win.location.search + pushUrl;
}
this.config.win.history.pushState({}, "", pushUrl);
log.success("监听popstate事件");
domUtils.on(this.config.win, "popstate", this.popStateEvent.bind(this), {
capture: true
});
}
/**
* 退出手势模式
* @param isUrlChange 是否是url改变触发的
*/
async quitGestureBackMode(isUrlChange = false) {
this.isBacking = true;
log.success("退出手势模式");
if (typeof this.config.beforeHistoryBackCallBack === "function") {
this.config.beforeHistoryBackCallBack(isUrlChange);
}
let maxDate = Date.now() + 1e3 * 5;
while (true) {
if (Date.now() > maxDate) {
log.error("未知情况,history.back()失败,无法退出手势模式");
break;
}
if (this.config.win.location.hash.endsWith(this.config.hash)) {
log.info("history.back()");
this.config.win.history.back();
await utils.sleep(this.config.backDelayTime || 150);
} else {
break;
}
}
log.success("移除popstate事件");
domUtils.off(this.config.win, "popstate", this.popStateEvent.bind(this), {
capture: true
});
this.isBacking = false;
if (typeof this.config.afterHistoryBackCallBack === "function") {
this.config.afterHistoryBackCallBack(isUrlChange);
}
}
}
const MTSmallWindowIcon = {
/** 锁图标 */
https: (
/*html*/
`
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="12" height="12" style="margin: 0px 6px 0px 2px;">
<path fill="#000000" d="M842.666667 384h-74.666667V277.333333a234.666667 234.666667 0 1 0-469.333333 0v106.666667H224a53.393333 53.393333 0 0 0-53.333333 53.333333v490.666667a53.393333 53.393333 0 0 0 53.333333 53.333333h618.666667a53.393333 53.393333 0 0 0 53.333333-53.333333V437.333333a53.393333 53.393333 0 0 0-53.333333-53.333333zM341.333333 277.333333c0-105.866667 86.133333-192 192-192s192 86.133333 192 192v106.666667H341.333333z"></path>
</svg>`
),
/** 开锁图标 */
http: (
/*html*/
`
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="12" height="12">
<path fill="#2c2c2c" d="M770.423989 451.309956H368.89432V284.246158c0-80.739434 65.689748-146.429182 146.429182-146.429182S661.738235 203.506724 661.738235 284.246158a43.350032 43.350032 0 0 0 86.700063 0c0-128.547294-104.581952-233.129246-233.122021-233.129246-128.547294 0-233.129246 104.581952-233.129245 233.129246v167.063798h-21.978466a43.350032 43.350032 0 0 0-43.350032 43.350031v437.965371a43.350032 43.350032 0 0 0 43.350032 43.350032h510.215423a43.350032 43.350032 0 0 0 43.350032-43.350032V494.659987a43.350032 43.350032 0 0 0-43.350032-43.350031z"></path>
</svg>`
),
/** 新标签页打开 */
openBlank: (
/*html*/
`
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg">
<path d="M192 288A96 96 0 0 1 288 192h128a32 32 0 0 0 0-64h-128A160 160 0 0 0 128 288v448A160 160 0 0 0 288 896h448a160 160 0 0 0 160-160v-128a32 32 0 0 0-64 0v128a96 96 0 0 1-96 96h-448A96 96 0 0 1 192 736v-448z" fill="#000000" fill-opacity=".85"></path>
<path d="M608 128a32 32 0 0 0 0 64h178.752L521.344 457.344a32 32 0 1 0 45.312 45.312L832 237.248V416a32 32 0 0 0 64 0v-256a32 32 0 0 0-32-32h-256z" fill="#000000" fill-opacity=".85" p-id="2334"></path>
</svg>`
),
/** 关闭 */
close: (
/*html*/
`
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg">
<path d="M0 0h1024v1024H0z" fill="#FF0033" fill-opacity="0" p-id="3329"></path><path d="M240.448 168l2.346667 2.154667 289.92 289.941333 279.253333-279.253333a42.666667 42.666667 0 0 1 62.506667 58.026666l-2.133334 2.346667-279.296 279.210667 279.274667 279.253333a42.666667 42.666667 0 0 1-58.005333 62.528l-2.346667-2.176-279.253333-279.253333-289.92 289.962666a42.666667 42.666667 0 0 1-62.506667-58.005333l2.154667-2.346667 289.941333-289.962666-289.92-289.92a42.666667 42.666667 0 0 1 57.984-62.506667z" fill="#111111" p-id="3330"></path>
</svg>`
),
/** 图片预览 */
image: (
/*html*/
`
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg">
<path d="M938.666667 553.92V768c0 64.8-52.533333 117.333333-117.333334 117.333333H202.666667c-64.8 0-117.333333-52.533333-117.333334-117.333333V256c0-64.8 52.533333-117.333333 117.333334-117.333333h618.666666c64.8 0 117.333333 52.533333 117.333334 117.333333v297.92z m-64-74.624V256a53.333333 53.333333 0 0 0-53.333334-53.333333H202.666667a53.333333 53.333333 0 0 0-53.333334 53.333333v344.48A290.090667 290.090667 0 0 1 192 597.333333a286.88 286.88 0 0 1 183.296 65.845334C427.029333 528.384 556.906667 437.333333 704 437.333333c65.706667 0 126.997333 16.778667 170.666667 41.962667z m0 82.24c-5.333333-8.32-21.130667-21.653333-43.648-32.917333C796.768 511.488 753.045333 501.333333 704 501.333333c-121.770667 0-229.130667 76.266667-270.432 188.693334-2.730667 7.445333-7.402667 20.32-13.994667 38.581333-7.68 21.301333-34.453333 28.106667-51.370666 13.056-16.437333-14.634667-28.554667-25.066667-36.138667-31.146667A222.890667 222.890667 0 0 0 192 661.333333c-14.464 0-28.725333 1.365333-42.666667 4.053334V768a53.333333 53.333333 0 0 0 53.333334 53.333333h618.666666a53.333333 53.333333 0 0 0 53.333334-53.333333V561.525333zM320 480a96 96 0 1 1 0-192 96 96 0 0 1 0 192z m0-64a32 32 0 1 0 0-64 32 32 0 0 0 0 64z" fill="#000000"></path>
</svg>`
),
/** 坐标的网站图标 */
mt: (
/*html*/
`
<svg viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" width="24" height="24">
<path d="M979.622067 257.689317c22.828607 10.592474 32.873194 37.804173 22.280721 60.63278l-166.009631 359.778848c-10.592474 22.828607-37.804173 32.873194-60.63278 22.280721l-292.3888-134.780097c-22.828607-10.592474-32.873194-37.804173-22.280721-60.63278l166.009631-359.778848c10.592474-22.828607 37.804173-32.873194 60.632781-22.28072l292.388799 134.780096z" fill="#FFBA02" p-id="1715"></path><path d="M658.743166 46.205101v467.529873c0 25.202782-20.637061 45.657214-45.657214 45.657214H145.556078c-25.202782 0-45.657214-20.637061-45.657214-45.657214v-467.529873c0-25.202782 20.637061-45.657214 45.657214-45.657214h467.529874c25.202782 0 45.657214 20.454432 45.657214 45.657214z" fill="#E2E0E2" p-id="1716"></path><path d="M204.910457 236.50437a177.149991 175.871589 0 1 0 354.299982 0 177.149991 175.871589 0 1 0-354.299982 0Z" fill="#3D82FF" p-id="1717"></path><path d="M245.636692 42.369895a9.861958 9.679329 0 1 0 19.723916 0 9.861958 9.679329 0 1 0-19.723916 0Z" fill="#3D82FF" p-id="1718"></path><path d="M501.864978 43.10041a10.409845 10.409845 0 1 0 20.81969 0 10.409845 10.409845 0 1 0-20.81969 0Z" fill="#3D82FF" p-id="1719"></path><path d="M454.774127 104.071054l48.495267-66.347237 16.807334 12.285443-48.495267 66.347237zM248.102182 48.730858l15.77548-11.220717 50.279551 70.691978-15.775481 11.21889zM204.910457 231.390762h354.299982v193.586588h-354.299982z" fill="#3D82FF" p-id="1720"></path><path d="M280.701432 171.853754a26.115927 25.202782 0 1 0 52.231854 0 26.115927 25.202782 0 1 0-52.231854 0Z" fill="#FFFFFF" p-id="1721"></path><path d="M434.109672 171.671125a25.385411 25.202782 0 1 0 50.770822 0 25.385411 25.202782 0 1 0-50.770822 0Z" fill="#FFFFFF" p-id="1722"></path><path d="M394.844468 1023.817371H50.589073c-25.202782 0-45.657214-20.637061-45.657214-45.657214v-686.684502c0-25.202782 20.637061-45.657214 45.657214-45.657214h344.255395c25.202782 0 45.657214 20.637061 45.657214 45.657214v686.684502c0 25.202782-20.454432 45.657214-45.657214 45.657214z" fill="#303030" p-id="1723"></path><path d="M973.230057 342.976993H50.589073c-25.202782 0-45.657214 20.637061-45.657214 45.657214v589.708579c0 25.202782 20.637061 45.657214 45.657214 45.657214h922.640984c25.202782 0 45.657214-20.637061 45.657215-45.657214V388.634207c0-25.202782-20.637061-45.657214-45.657215-45.657214z" fill="#303030" p-id="1724"></path><path d="M392.287664 488.89745L295.311741 394.843588c-18.080257-17.53237-18.445515-46.570358-1.095773-64.650615l68.303192-70.677368c17.53237-18.080257 46.570358-18.445515 64.650616-1.095773l97.158551 94.053862c18.080257 17.53237 18.445515 46.570358 1.095774 64.650615l-68.303193 70.677367c-17.714999 18.080257-46.752987 18.628143-64.833244 1.095774z" fill="#303030" p-id="1725"></path><path d="M266.273753 628.060638v-13.331906l-54.240771-77.434635v316.495808c0 7.305154-2.556804 13.514535-7.670412 18.628144-5.113608 5.113608-11.322989 7.670412-18.628143 7.670412-7.305154 0-13.514535-2.556804-18.628143-7.853041-5.113608-5.113608-7.670412-11.322989-7.670412-18.445515V465.155698h67.755305l64.467987 94.053861 66.476904-94.053861H424.978229v388.634207c0 7.305154-2.739433 13.514535-8.035669 18.628144-5.296237 5.113608-11.688247 7.670412-18.810773 7.670412-7.122525 0-13.149278-2.556804-18.445514-7.853041-5.113608-5.113608-7.853041-11.322989-7.853041-18.445515V538.572499l-53.144997 74.877831v14.610308c0 7.122525-2.556804 13.149278-7.853041 18.445515-5.113608 5.113608-11.322989 7.853041-18.445515 7.853041-7.305154 0-13.514535-2.556804-18.628143-7.853041-4.930979-5.296237-7.487783-11.322989-7.487783-18.445515z" fill="#FFFFFF" p-id="1726"></path><path d="M600.301932 536.563581V465.703585h264.811842v71.407883c0 7.305154-2.556804 13.514535-7.853041 18.628143-5.113608 5.113608-11.322989 7.670412-18.445514 7.670412-7.305154 0-13.514535-2.556804-18.810772-7.853041-5.296237-5.113608-8.03567-11.322989-8.03567-18.445514v-18.993401h-53.144997v335.48921c0 7.305154-2.556804 13.514535-7.853041 18.628143-5.113608 5.113608-11.322989 7.670412-18.445515 7.670412-7.487783 0-13.879793-2.556804-18.993401-7.670412-5.113608-5.113608-7.853041-11.322989-7.853041-18.628143V518.300696h-53.144997v18.445514c0 7.305154-2.556804 13.514535-7.670412 18.628143-5.113608 5.113608-11.322989 7.670412-18.628143 7.670412-7.305154 0-13.514535-2.556804-18.628144-7.670412-4.74835-5.296237-7.305154-11.505618-7.305154-18.810772z" fill="#FFFFFF"></path>
</svg>`
)
};
const MTSmallWindow = {
$key: {
smallWindow: "smallWindow"
},
$el: {
$refreshIcon: null,
$webSiteIcon: null
},
init() {
let lockFn = new utils.LockFunction(() => {
let forumlist = this.getForumList();
if (forumlist.length) {
this.handleForumPost(forumlist);
}
});
utils.mutationObserver(document.documentElement, {
callback: (mutations, observer) => {
lockFn.run();
},
config: { subtree: true, childList: true }
});
},
/**
* 获取页面所有的帖子
*/
getForumList() {
return utils.getNodeListValue(
ElementUtils.comiisForumList(),
ElementUtils.comiisPostli(),
ElementUtils.comiisMmlist()
);
},
/**
* 显示小窗
* @param title 标题
* @param url 链接
* @param imagesList 图片
*/
showSmallWindow(title, url, imagesList = []) {
let constructURL = new URL(url);
let isHTTPS = constructURL.protocol.includes("https:");
let websiteTitle = (
/*html*/
`
<div class="small-window-drag">
<!-- 这里是拖拽区域 -->
<div></div>
</div>
<div class="small-window-title-container">
<i class="small-window-website-icon" style="display: none;">
${MTSmallWindowIcon.mt}
</i>
<div class="refresh-icon">
<div class="refresh-icon-out"></div>
<div class="refresh-icon-in"></div>
</div>
<div class="small-window-title-text-container">
<p class="small-window-title-text">${title}</p>
<div class="small-window-protocol-info">
<i class="small-window-protocol-icon">
${isHTTPS ? MTSmallWindowIcon.https : MTSmallWindowIcon.http}
</i>
<p class="small-window-website-host">${constructURL.host}</p>
</div>
</div>
<div class="small-window-control">
${imagesList.length ? (
/*html*/
`
<i class="small-window-control-image-view">
${MTSmallWindowIcon.image}
</i>
`
) : ""}
<i class="small-window-control-open-blank">
${MTSmallWindowIcon.openBlank}
</i>
<i class="small-window-control-close">
${MTSmallWindowIcon.close}
</i>
</div>
</div>`
);
let $drawer = __pops.drawer({
title: {
enable: true,
text: websiteTitle,
html: true,
style: "height: auto;line-height: normal;"
},
content: {
text: (
/*html*/
`
<iframe scrolling="auto" allowtransparency="true" frameborder="0" src="${url}" style="width:100%; height:100%;">
</iframe>
`
),
html: true
},
mask: {
enable: true,
clickEvent: {
toClose: true
},
clickCallBack(originalRun, config) {
getureBack.quitGestureBackMode();
}
},
btn: {
ok: {
enable: false
},
cancel: {
enable: false
},
close: {
enable: false
}
},
direction: "bottom",
size: "92%",
borderRadius: 18,
style: smallWindowCSS
});
let $webSiteIcon = $drawer.$shadowRoot.querySelector(
".small-window-website-icon"
);
let $refreshIcon = $drawer.$shadowRoot.querySelector(".refresh-icon");
let $imageIcon = $drawer.$shadowRoot.querySelector(
".small-window-control-image-view"
);
let $openBlankIcon = $drawer.$shadowRoot.querySelector(
".small-window-control-open-blank"
);
let $closeIcon = $drawer.$shadowRoot.querySelector(
".small-window-control-close"
);
let $titleText = $drawer.$shadowRoot.querySelector(
".small-window-title-text"
);
this.$el.$refreshIcon = $refreshIcon;
this.$el.$webSiteIcon = $webSiteIcon;
let $iframe = $drawer.$shadowRoot.querySelector("iframe");
let $drag = $drawer.$shadowRoot.querySelector(".small-window-drag");
let AnyTouch = __pops.config.Utils.AnyTouch();
let dragNode = new AnyTouch($drag);
let smallWidowNode = $drawer.popsElement;
let smallWidowNormalHeight = domUtils.height(smallWidowNode);
dragNode.on("pan", (event) => {
if (event.phase == "move" && event.displacementY > 0) {
smallWidowNode.style["transition"] = "none";
smallWidowNode.style["height"] = Math.abs(smallWidowNormalHeight - event.distanceY) + "px";
}
if (event.isEnd) {
smallWidowNode.style["transition"] = "0.2s ease-in";
if (parseInt(smallWidowNode.style["height"]) > window.innerHeight / 2) {
smallWidowNode.style["height"] = smallWidowNormalHeight + "px";
} else {
$drawer.close();
}
}
});
let getureBack = new GestureBack({
win: self,
hash: this.$key.smallWindow,
useUrl: true,
beforeHistoryBackCallBack: () => {
$drawer.close();
}
});
getureBack.enterGestureBackMode();
domUtils.on($titleText, "click", (event) => {
utils.preventEvent(event);
utils.setClip(`『${title}』 - ${url}`);
Qmsg.success("已复制链接");
});
domUtils.on($imageIcon, "click", (event) => {
utils.preventEvent(event);
log.info(`查看图片`, imagesList);
var viewerULNodeHTML = "";
imagesList.forEach((item) => {
viewerULNodeHTML += `<li><img data-src="${item}"></li>`;
});
var viewerULNode = domUtils.parseHTML(
`<ul>${viewerULNodeHTML}</ul>`,
false,
false
);
let viewer = new Viewer(viewerULNode, {
inline: false,
url: "data-src",
zIndex: (() => {
let maxZIndex = utils.getMaxZIndex();
let popsMaxZIndex = __pops.config.InstanceUtils.getPopsMaxZIndex().zIndex;
return utils.getMaxValue(maxZIndex, popsMaxZIndex) + 100;
})(),
hidden: () => {
viewer.destroy();
}
});
viewer.zoomTo(1);
viewer.show();
});
domUtils.on($closeIcon, "click", (event) => {
utils.preventEvent(event);
getureBack.quitGestureBackMode();
});
domUtils.on($openBlankIcon, "click", (event) => {
utils.preventEvent(event);
window.open(url, "_blank");
});
domUtils.on($webSiteIcon, "click", (event) => {
utils.preventEvent(event);
$iframe.contentWindow.location.reload();
this.checkIframeReadyState($iframe);
});
this.checkIframeReadyState($iframe);
},
/**
* 对帖子进行处理,实现点击某个区域打开小窗
* @param forumlist
*/
async handleForumPost(forumlist) {
forumlist.forEach(($forum) => {
if ($forum.getAttribute("data-injection-small-window")) {
return;
}
let title = domUtils.text(
$forum.querySelector(".mmlist_li_box h2 a")
);
if (title == "" || title == null) {
title = domUtils.text(
$forum.querySelector(".mmlist_li_box a")
);
}
title = title.trim();
let url = $forum.querySelector(".mmlist_li_box a").href;
var imagesList = [];
$forum.setAttribute("data-injection-small-window", "true");
$forum.setAttribute("data-injection-small-window-url", url);
$forum.setAttribute("data-injection-small-window-title", title);
$forum.querySelectorAll(".comiis_pyqlist_img img").forEach(($img) => {
imagesList.push($img.getAttribute("src"));
});
$forum.querySelectorAll(".comiis_pyqlist_imgs img").forEach(($img) => {
imagesList.push($img.getAttribute("src"));
});
$forum.querySelectorAll(".mmlist_li_box a").forEach(($anchor) => {
$anchor.removeAttribute("href");
$anchor.setAttribute("data-href", url);
});
let $mmlist_li_box = $forum.querySelector(".mmlist_li_box");
domUtils.on($mmlist_li_box, "click", function(event) {
var mouseClickPosX = Number(event.clientX);
if (document.body.offsetWidth / 2 > mouseClickPosX) {
window.location.href = url;
} else {
MTSmallWindow.showSmallWindow(title, url, imagesList);
}
});
});
},
/**
* 检测 iframe是否加载完毕
* @param iframe
*/
checkIframeReadyState(iframe) {
this.showRefreshIcon();
let intervalId = setInterval(() => {
if (iframe.contentWindow) {
clearInterval(intervalId);
let iframeDOMUtils = domUtils.createDOMUtils({
document: iframe.contentWindow.document,
// @ts-ignore
window: iframe.contentWindow,
globalThis: iframe.contentWindow,
// @ts-ignore
self: iframe.contentWindow,
top
});
iframeDOMUtils.ready(() => {
log.success("小窗内容已加载完毕");
this.hideRefreshIcon();
});
}
}, 400);
},
hideRefreshIcon() {
this.$el.$refreshIcon.style.display = "none";
this.$el.$webSiteIcon.style.display = "";
},
showRefreshIcon() {
this.$el.$refreshIcon.style.display = "";
this.$el.$webSiteIcon.style.display = "none";
}
};
const MTGuide = {
init() {
DOMUtils.ready(() => {
PopsPanel.execMenuOnce("mt-guide-showLatestPost", () => {
this.showLatestPost();
});
});
},
/**
* 显示最新帖子
*/
showLatestPost() {
log.info(`显示最新帖子`);
async function getLatestPostForum() {
let response = await httpx.get("/forum.php?mod=guide&view=hot", {
fetch: true,
allowInterceptConfig: false
});
if (!response.status) {
Qmsg.error("获取轮播失败");
return;
}
if (response.data.responseText.indexOf(
'<script src="/_guard/auto.js"><\/script>'
) !== -1) {
Qmsg.error("获取轮播失败 未知的/_guard/auto.js文件");
return;
}
var doc = DOMUtils.parseHTML(response.data.responseText, true, true);
var postForumList = doc.querySelectorAll(
'div.comiis_mh_kxtxt div[id*="comiis_mh_kxtxt"] ul'
);
if (postForumList.length === 0) {
Qmsg.error("获取轮播失败");
return;
} else {
var result = [];
postForumList[postForumList.length - 1].querySelectorAll("a").forEach((item) => {
result.push({
href: item.getAttribute("href"),
title: item.getAttribute("title")
});
});
}
return result;
}
getLatestPostForum().then((postInfoList) => {
if (!postInfoList) {
return;
}
addStyle(
/*css*/
`
div.comiis_mh_kxtxt_owm{
margin-top: 10px;
}
div.comiis_mh_kxtxt_owm li{
height: 30px;
width: 100%;
display: flex;
align-items: center;
}
div.comiis_mh_kxtxt_owm span{
background: #FF705E;
color: #fff;
float: left;
height: 18px;
line-height: 18px;
padding: 0 3px;
margin-top: 2px;
margin-right: 10px;
overflow: hidden;
border-radius: 2px;
margin-left: 10px;
}
div.comiis_mh_kxtxt_owm a{
display: block;
font-size: 14px;
font-weight: 400;
height: 22px;
line-height: 22px;
overflow: hidden;
min-width: 100px;
max-width: 80%;
text-overflow: ellipsis;
white-space: nowrap;
margin-right: 10px;
}
`
);
var latestPostForumHTML = "";
utils.sortListByProperty(
postInfoList,
(item) => {
var forumPostNumMatch = item["href"].match(/thread-(.+?)-/i);
let forumPostNum = parseInt(
forumPostNumMatch[forumPostNumMatch.length - 1]
);
return forumPostNum;
},
true
);
log.info("导读内容", postInfoList);
postInfoList.forEach((item) => {
latestPostForumHTML += /*html*/
`
<li>
<span>新帖</span>
<a href="${item.href}" title="${item.title}" target="_blank">${item.title}</a>
</li>`;
});
let $comiis_xznlist = document.querySelector(
".comiis_forumlist.comiis_xznlist"
);
DOMUtils.before(
$comiis_xznlist,
`<div class="comiis_mh_kxtxt bg_f comiis_mh_kxtxt_owm"><ul>${latestPostForumHTML}</ul></div>`
);
});
}
};
class RuleEditView {
constructor(option) {
__publicField(this, "option");
this.option = option;
}
/**
* 显示视图
*/
async showView() {
var _a2;
let $dialog = __pops.confirm({
title: {
text: this.option.title,
position: "center"
},
content: {
text: (
/*html*/
`
<form class="rule-form-container" onsubmit="return false">
<ul class="rule-form-ulist">
</ul>
<input type="submit" style="display: none;" />
</form>
`
),
html: true
},
btn: utils.assign(
{
ok: {
callback: async () => {
await submitSaveOption();
}
}
},
this.option.btn || {},
true
),
mask: {
enable: true
},
style: (
/*css*/
`
${__pops.config.cssText.panelCSS}
.rule-form-container {
}
.rule-form-container li{
display: flex;
align-items: center;
justify-content: space-between;
padding: 5px 20px;
gap: 10px;
}
.pops-panel-item-left-main-text{
max-width: 150px;
}
.pops-panel-item-right-text{
padding-left: 30px;
}
.pops-panel-item-right-text,
.pops-panel-item-right-main-text{
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
}
${((_a2 = this.option) == null ? void 0 : _a2.style) ?? ""}
`
),
width: window.innerWidth > 500 ? "500px" : "88vw",
height: window.innerHeight > 500 ? "500px" : "80vh"
});
let $form = $dialog.$shadowRoot.querySelector(
".rule-form-container"
);
$dialog.$shadowRoot.querySelector(
"input[type=submit]"
);
let $ulist = $dialog.$shadowRoot.querySelector(".rule-form-ulist");
let view = await this.option.getView(await this.option.data());
$ulist.appendChild(view);
const submitSaveOption = async () => {
let result = await this.option.onsubmit($form, await this.option.data());
if (!result.success) {
return;
}
$dialog.close();
await this.option.dialogCloseCallBack(true);
};
}
}
class RuleFilterView {
constructor(option) {
__publicField(this, "option");
this.option = option;
}
showView() {
let $alert = __pops.alert({
title: {
text: this.option.title,
position: "center"
},
content: {
text: (
/*html*/
`
<div class="filter-container"></div>
`
)
},
btn: {
ok: {
text: "关闭",
type: "default"
}
},
mask: {
enable: true
},
width: window.innerWidth > 500 ? "350px" : "80vw",
height: window.innerHeight > 500 ? "300px" : "70vh",
style: (
/*css*/
`
.filter-container{
height: 100%;
display: flex;
flex-direction: column;
gap: 20px;
}
.filter-container button{
text-wrap: wrap;
padding: 8px;
height: auto;
text-align: left;
}
`
)
});
let $filterContainer = $alert.$shadowRoot.querySelector(".filter-container");
let $fragment = document.createDocumentFragment();
this.option.filterOption.forEach((filterOption) => {
let $button = document.createElement("button");
$button.innerText = filterOption.name;
let execFilterAndCloseDialog = async () => {
let allRuleInfo = await this.option.getAllRuleInfo();
allRuleInfo.forEach(async (ruleInfo) => {
let filterResult = await filterOption.filterCallBack(ruleInfo.data);
if (!filterResult) {
domUtils.hide(ruleInfo.$el, false);
} else {
domUtils.show(ruleInfo.$el, false);
}
});
if (typeof this.option.execFilterCallBack === "function") {
await this.option.execFilterCallBack();
}
$alert.close();
};
domUtils.on($button, "click", async (event) => {
utils.preventEvent(event);
if (typeof filterOption.callback === "function") {
let result = await filterOption.callback(
event,
execFilterAndCloseDialog
);
if (!result) {
return;
}
}
await execFilterAndCloseDialog();
});
$fragment.appendChild($button);
});
$filterContainer.appendChild($fragment);
}
}
class RuleView {
constructor(option) {
__publicField(this, "option");
this.option = option;
}
/**
* 显示视图
*/
async showView() {
var _a2, _b, _c, _d, _e, _f, _g, _h, _i;
let $popsConfirm = __pops.confirm({
title: {
text: this.option.title,
position: "center"
},
content: {
text: (
/*html*/
`
<div class="rule-view-container">
</div>
`
),
html: true
},
btn: {
merge: true,
reverse: false,
position: "space-between",
ok: {
enable: ((_c = (_b = (_a2 = this.option) == null ? void 0 : _a2.bottomControls) == null ? void 0 : _b.add) == null ? void 0 : _c.enable) || true,
type: "primary",
text: "添加",
callback: async (event) => {
this.showEditView(
$popsConfirm.$shadowRoot,
false,
await this.option.getAddData()
);
}
},
close: {
enable: true,
callback(event) {
$popsConfirm.close();
}
},
cancel: {
enable: ((_f = (_e = (_d = this.option) == null ? void 0 : _d.bottomControls) == null ? void 0 : _e.filter) == null ? void 0 : _f.enable) || false,
type: "default",
text: "过滤",
callback: (details, event) => {
var _a3, _b2, _c2, _d2, _e2, _f2, _g2;
if (typeof ((_c2 = (_b2 = (_a3 = this.option) == null ? void 0 : _a3.bottomControls) == null ? void 0 : _b2.filter) == null ? void 0 : _c2.callback) === "function") {
this.option.bottomControls.filter.callback();
}
let getAllRuleElement = () => {
return Array.from(
$popsConfirm.$shadowRoot.querySelectorAll(
".rule-view-container .rule-item"
)
);
};
let $button = event.target.closest(".pops-confirm-btn").querySelector(".pops-confirm-btn-cancel span");
if (domUtils.text($button).includes("取消")) {
getAllRuleElement().forEach(($el) => {
domUtils.show($el, false);
});
domUtils.text($button, "过滤");
} else {
let ruleFilterView = new RuleFilterView({
title: ((_e2 = (_d2 = this.option.bottomControls) == null ? void 0 : _d2.filter) == null ? void 0 : _e2.title) ?? "过滤规则",
filterOption: ((_g2 = (_f2 = this.option.bottomControls) == null ? void 0 : _f2.filter) == null ? void 0 : _g2.option) || [],
execFilterCallBack() {
domUtils.text($button, "取消过滤");
},
getAllRuleInfo: () => {
return getAllRuleElement().map(($el) => {
return {
data: this.parseRuleItemElement($el).data,
$el
};
});
}
});
ruleFilterView.showView();
}
}
},
other: {
enable: ((_i = (_h = (_g = this.option) == null ? void 0 : _g.bottomControls) == null ? void 0 : _h.clear) == null ? void 0 : _i.enable) || true,
type: "xiaomi-primary",
text: `清空所有(${(await this.option.data()).length})`,
callback: (event) => {
let $askDialog = __pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: "确定清空所有的数据?",
html: false
},
btn: {
ok: {
enable: true,
callback: async (popsEvent) => {
var _a3, _b2, _c2;
log.success("清空所有");
if (typeof ((_c2 = (_b2 = (_a3 = this.option) == null ? void 0 : _a3.bottomControls) == null ? void 0 : _b2.clear) == null ? void 0 : _c2.callback) === "function") {
this.option.bottomControls.clear.callback();
}
let data = await this.option.data();
if (data.length) {
Qmsg.error("清理失败");
return;
} else {
Qmsg.success("清理成功");
}
await this.updateDeleteAllBtnText($popsConfirm.$shadowRoot);
this.clearContent($popsConfirm.$shadowRoot);
$askDialog.close();
}
},
cancel: {
text: "取消",
enable: true
}
},
mask: { enable: true },
width: "300px",
height: "200px"
});
}
}
},
mask: {
enable: true
},
width: window.innerWidth > 500 ? "500px" : "88vw",
height: window.innerHeight > 500 ? "500px" : "80vh",
style: (
/*css*/
`
${__pops.config.cssText.panelCSS}
.rule-item{
display: flex;
align-items: center;
line-height: normal;
font-size: 16px;
padding: 4px 4px;
gap: 6px;
}
.rule-name{
flex: 1;
white-space: nowrap;
text-overflow: ellipsis;
overflow: hidden;
}
.rule-controls{
display: flex;
align-items: center;
text-overflow: ellipsis;
overflow: hidden;
white-space: nowrap;
gap: 8px;
padding: 0px 4px;
}
.rule-controls-enable{
}
.rule-controls-edit{
}
.rule-controls-delete{
}
.rule-controls-edit,
.rule-controls-delete{
width: 16px;
height: 16px;
cursor: pointer;
}
`
)
});
let allData = await this.option.data();
for (let index = 0; index < allData.length; index++) {
await this.appendRuleItemElement(
$popsConfirm.$shadowRoot,
allData[index]
);
}
}
/**
* 解析弹窗内的各个元素
*/
parseViewElement($shadowRoot) {
let $container = $shadowRoot.querySelector(
".rule-view-container"
);
let $deleteBtn = $shadowRoot.querySelector(
".pops-confirm-btn button.pops-confirm-btn-other"
);
return {
/** 容器 */
$container,
/** 左下角的清空按钮 */
$deleteBtn
};
}
/**
* 解析每一项的元素
*/
parseRuleItemElement($ruleElement) {
let $enable = $ruleElement.querySelector(
".rule-controls-enable"
);
let $enableSwitch = $enable.querySelector(".pops-panel-switch");
let $enableSwitchInput = $enable.querySelector(
".pops-panel-switch__input"
);
let $enableSwitchCore = $enable.querySelector(
".pops-panel-switch__core"
);
let $edit = $ruleElement.querySelector(".rule-controls-edit");
let $delete = $ruleElement.querySelector(
".rule-controls-delete"
);
return {
/** 启用开关 */
$enable,
/** 启用开关的container */
$enableSwitch,
/** 启用开关的input */
$enableSwitchInput,
/** 启用开关的core */
$enableSwitchCore,
/** 编辑按钮 */
$edit,
/** 删除按钮 */
$delete,
/** 存储在元素上的数据 */
data: Reflect.get($ruleElement, "data-rule")
};
}
/**
* 创建一条规则元素
*/
async createRuleItemElement(data, $shadowRoot) {
let name = await this.option.getDataItemName(data);
let $ruleItem = domUtils.createElement("div", {
className: "rule-item",
innerHTML: (
/*html*/
`
<div class="rule-name">${name}</div>
<div class="rule-controls">
<div class="rule-controls-enable">
<div class="pops-panel-switch">
<input class="pops-panel-switch__input" type="checkbox">
<span class="pops-panel-switch__core">
<div class="pops-panel-switch__action">
</div>
</span>
</div>
</div>
<div class="rule-controls-edit">
${__pops.config.iconSVG.edit}
</div>
<div class="rule-controls-delete">
${__pops.config.iconSVG.delete}
</div>
</div>
`
)
});
Reflect.set($ruleItem, "data-rule", data);
let switchCheckedClassName = "pops-panel-switch-is-checked";
const {
$enable,
$enableSwitch,
$enableSwitchCore,
$enableSwitchInput,
$delete,
$edit
} = this.parseRuleItemElement($ruleItem);
if (this.option.itemControls.enable.enable) {
domUtils.on($enableSwitchCore, "click", async (event) => {
let isChecked = false;
if ($enableSwitch.classList.contains(switchCheckedClassName)) {
$enableSwitch.classList.remove(switchCheckedClassName);
isChecked = false;
} else {
$enableSwitch.classList.add(switchCheckedClassName);
isChecked = true;
}
$enableSwitchInput.checked = isChecked;
await this.option.itemControls.enable.callback(data, isChecked);
});
if (await this.option.itemControls.enable.getEnable(data)) {
$enableSwitch.classList.add(switchCheckedClassName);
}
} else {
$enable.remove();
}
if (this.option.itemControls.edit.enable) {
domUtils.on($edit, "click", (event) => {
utils.preventEvent(event);
this.showEditView($shadowRoot, true, data, $ruleItem, (newData) => {
data = null;
data = newData;
});
});
} else {
$edit.remove();
}
if (this.option.itemControls.delete.enable) {
domUtils.on($delete, "click", (event) => {
utils.preventEvent(event);
let $askDialog = __pops.confirm({
title: {
text: "提示",
position: "center"
},
content: {
text: "确定删除该条数据?",
html: false
},
btn: {
ok: {
enable: true,
callback: async (popsEvent) => {
log.success("删除数据");
let flag = await this.option.itemControls.delete.deleteCallBack(
data
);
if (flag) {
Qmsg.success("成功删除该数据");
$ruleItem.remove();
await this.updateDeleteAllBtnText($shadowRoot);
$askDialog.close();
} else {
Qmsg.error("删除该数据失败");
}
}
},
cancel: {
text: "取消",
enable: true
}
},
mask: {
enable: true
},
width: "300px",
height: "200px"
});
});
} else {
$delete.remove();
}
return $ruleItem;
}
/**
* 添加一个规则元素
*/
async appendRuleItemElement($shadowRoot, data) {
const { $container } = this.parseViewElement($shadowRoot);
if (Array.isArray(data)) {
for (let index = 0; index < data.length; index++) {
const item = data[index];
$container.appendChild(
await this.createRuleItemElement(item, $shadowRoot)
);
}
} else {
$container.appendChild(
await this.createRuleItemElement(data, $shadowRoot)
);
}
await this.updateDeleteAllBtnText($shadowRoot);
}
/**
* 更新弹窗内容的元素
*/
async updateRuleContaienrElement($shadowRoot) {
this.clearContent($shadowRoot);
this.parseViewElement($shadowRoot);
let data = await this.option.data();
await this.appendRuleItemElement($shadowRoot, data);
await this.updateDeleteAllBtnText($shadowRoot);
}
/**
* 更新规则元素
*/
async updateRuleItemElement(data, $oldRuleItem, $shadowRoot) {
let $newRuleItem = await this.createRuleItemElement(data, $shadowRoot);
$oldRuleItem.after($newRuleItem);
$oldRuleItem.remove();
}
/**
* 清空内容
*/
clearContent($shadowRoot) {
const { $container } = this.parseViewElement($shadowRoot);
domUtils.html($container, "");
}
/**
* 设置删除按钮的文字
*/
setDeleteBtnText($shadowRoot, text, isHTML = false) {
const { $deleteBtn } = this.parseViewElement($shadowRoot);
if (isHTML) {
domUtils.html($deleteBtn, text);
} else {
domUtils.text($deleteBtn, text);
}
}
/**
* 更新【清空所有】的按钮的文字
*/
async updateDeleteAllBtnText($shadowRoot) {
let data = await this.option.data();
this.setDeleteBtnText($shadowRoot, `清空所有(${data.length})`);
}
/**
* 显示编辑视图
* @param isEdit 是否是编辑状态
*/
showEditView($parentShadowRoot, isEdit, editData, $editRuleItemElement, updateDataCallBack) {
let dialogCloseCallBack = async (isSubmit) => {
if (isSubmit) ;
else {
if (!isEdit) {
await this.option.deleteData(editData);
}
if (typeof updateDataCallBack === "function") {
let newData = await this.option.getData(editData);
updateDataCallBack(newData);
}
}
};
let editView = new RuleEditView({
title: isEdit ? "编辑" : "添加",
data: () => {
return editData;
},
dialogCloseCallBack,
getView: async (data) => {
return await this.option.itemControls.edit.getView(data, isEdit);
},
btn: {
ok: {
enable: true,
text: isEdit ? "修改" : "添加"
},
cancel: {
callback: async (detail, event) => {
detail.close();
await dialogCloseCallBack(false);
}
},
close: {
callback: async (detail, event) => {
detail.close();
await dialogCloseCallBack(false);
}
}
},
onsubmit: async ($form, data) => {
let result = await this.option.itemControls.edit.onsubmit(
$form,
isEdit,
data
);
if (result.success) {
if (isEdit) {
Qmsg.success("修改成功");
await this.updateRuleItemElement(
result.data,
$editRuleItemElement,
$parentShadowRoot
);
} else {
await this.appendRuleItemElement($parentShadowRoot, result.data);
}
} else {
if (isEdit) {
Qmsg.error("修改失败");
}
}
return result;
},
style: this.option.itemControls.edit.style
});
editView.showView();
}
}
const MTOwnBlock = {
$key: {
STORAGE_KEY: "mt-own-block-rule"
},
$data: {
isRegister: false
},
init() {
this.registerMenu();
let lockFn = new utils.LockFunction(() => {
this.runRule();
});
utils.mutationObserver(document, {
config: {
subtree: true,
childList: true
},
callback: () => {
lockFn.run();
}
});
},
/**
* 注册菜单
*/
registerMenu() {
if (this.$data.isRegister) {
return;
}
this.$data.isRegister = true;
ElementUtils.registerLeftMenu({
name: "我的屏蔽",
icon: "",
iconColor: "#000",
callback: () => {
this.showView();
}
});
},
/**
* 获取模板数据
*/
getTemplateData() {
return {
uuid: utils.generateUUID(),
enable: true,
name: "",
data: {
userName: "",
userUID: "",
userLevel: "",
postUrl: "",
postTitle: "",
postContent: "",
postPlateName: ""
}
};
},
/**
* 显示视图
*/
showView() {
let popsPanelContentUtils = __pops.config.panelHandleContentUtils();
function generateStorageApi(data) {
return {
get(key, defaultValue) {
return data[key] ?? defaultValue;
},
set(key, value) {
data[key] = value;
}
};
}
let ruleView = new RuleView({
title: "我的屏蔽",
data: () => {
return this.getData();
},
getAddData: () => {
return this.getTemplateData();
},
getDataItemName: (data) => {
return data["name"];
},
updateData: (data) => {
return this.updateData(data);
},
deleteData: (data) => {
return this.deleteData(data);
},
getData: (data) => {
let allData = this.getData();
let findValue = allData.find((item) => item.uuid === data.uuid);
return findValue ?? data;
},
itemControls: {
enable: {
enable: true,
getEnable(data) {
return data.enable;
},
callback: (data, enable) => {
data.enable = enable;
this.updateData(data);
}
},
edit: {
enable: true,
getView: (data, isEdit) => {
let $fragment = document.createDocumentFragment();
if (!isEdit) {
data = this.getTemplateData();
}
let enable_template = UISwitch("启用", "enable", true);
Reflect.set(
enable_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $enable = popsPanelContentUtils.createSectionContainerItem_switch(
enable_template
);
let name_template = UIInput(
"规则名称",
"name",
"",
"",
void 0,
"必填"
);
Reflect.set(
name_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $name = popsPanelContentUtils.createSectionContainerItem_input(
name_template
);
let data_userName_template = UIInput(
"用户名",
"userName",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_userName_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_userName = popsPanelContentUtils.createSectionContainerItem_input(
data_userName_template
);
let data_userUID_template = UIInput(
"用户UID",
"userUID",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_userUID_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_userUID = popsPanelContentUtils.createSectionContainerItem_input(
data_userUID_template
);
let data_userLevel_template = UIInput(
"用户等级",
"userLevel",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_userLevel_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_userLevel = popsPanelContentUtils.createSectionContainerItem_input(
data_userLevel_template
);
let data_postUrl_template = UIInput(
"帖子url",
"postUrl",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_postUrl_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_postUrl = popsPanelContentUtils.createSectionContainerItem_input(
data_postUrl_template
);
let data_postTitle_template = UIInput(
"帖子标题",
"postTitle",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_postTitle_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_postTitle = popsPanelContentUtils.createSectionContainerItem_input(
data_postTitle_template
);
let data_postContent_template = UIInput(
"帖子内容",
"postContent",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_postContent_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_postContent = popsPanelContentUtils.createSectionContainerItem_input(
data_postContent_template
);
let data_postPlateName_template = UIInput(
"帖子所在的板块名",
"postPlateName",
"",
"",
void 0,
"可正则"
);
Reflect.set(
data_postPlateName_template.props,
PROPS_STORAGE_API,
generateStorageApi(data.data)
);
let $data_postPlateName = popsPanelContentUtils.createSectionContainerItem_input(
data_postPlateName_template
);
$fragment.appendChild($enable);
$fragment.appendChild($name);
$fragment.appendChild($data_userName);
$fragment.appendChild($data_userUID);
$fragment.appendChild($data_userLevel);
$fragment.appendChild($data_postUrl);
$fragment.appendChild($data_postTitle);
$fragment.appendChild($data_postContent);
$fragment.appendChild($data_postPlateName);
return $fragment;
},
onsubmit: ($form, isEdit, editData) => {
let $ulist_li = $form.querySelectorAll(
".rule-form-ulist > li"
);
let data = this.getTemplateData();
if (isEdit) {
data.uuid = editData.uuid;
}
$ulist_li.forEach(($li) => {
let formConfig = Reflect.get($li, "__formConfig__");
let attrs = Reflect.get(formConfig, "attributes");
let storageApi = Reflect.get($li, PROPS_STORAGE_API);
let key = Reflect.get(attrs, ATTRIBUTE_KEY);
let defaultValue = Reflect.get(attrs, ATTRIBUTE_DEFAULT_VALUE);
let value = storageApi.get(key, defaultValue);
if (Reflect.has(data, key)) {
Reflect.set(data, key, value);
} else if (Reflect.has(data.data, key)) {
Reflect.set(data.data, key, value);
} else {
log.error(`${key}不在数据中`);
}
});
if (data.name.trim() === "") {
Qmsg.error("规则名称不能为空");
return {
success: false,
data
};
}
if (isEdit) {
return {
success: this.updateData(data),
data
};
} else {
return {
success: this.addData(data),
data
};
}
}
},
delete: {
enable: true,
deleteCallBack: (data) => {
return this.deleteData(data);
}
}
}
});
ruleView.showView();
},
/**
* 执行规则
*/
runRule() {
let shieldUserList = this.getData();
function checkIsFilter(postForumInfo) {
for (const shieldItem of shieldUserList) {
let shieldOption = shieldItem["data"];
let findValue = Object.keys(shieldOption).find((keyName) => {
let value = shieldOption[keyName];
if (utils.isNotNull(value)) {
let regExpValue = new RegExp(value, "i");
let postForumValue = Reflect.get(postForumInfo, keyName);
if (typeof postForumValue === "string" && utils.isNotNull(postForumValue) && postForumValue.match(regExpValue)) {
log.info(`屏蔽`, [shieldOption, postForumValue]);
return true;
}
}
return false;
});
if (findValue) {
return true;
}
}
return false;
}
if (Router.isGuide() || Router.isPlate() || Router.isPost()) {
this.getData();
document.querySelectorAll(".comiis_forumlist .forumlist_li").forEach((item) => {
var _a2;
let postForumInfo = {
/* 用户名 */
userName: item.querySelector("a.top_user").innerText,
/* 用户UID */
userUID: item.querySelector("a.top_user").href.match(MTRegExp.uid)[1].trim(),
/* 用户等级 */
userLevel: item.querySelector("span.top_lev").innerText.replace("Lv.", ""),
/* 帖子Url */
postUrl: item.querySelector(".mmlist_li_box a").getAttribute("href") || item.querySelector(".mmlist_li_box a").getAttribute("data-href"),
/* 帖子标题 */
postTitle: ((_a2 = item.querySelector(".mmlist_li_box h2 a")) == null ? void 0 : _a2.innerText) || "",
/* 帖子内容(缩略) */
postContent: item.querySelector(
".mmlist_li_box .list_body"
).innerText,
/* 帖子板块 */
postPlateName: (item.querySelector(
".forumlist_li_time a.f_d"
) || item.querySelector(
".comiis_xznalist_bk.cl"
)).innerText.replace(//g, "").replace(/\s*/g, "").replace(/来自/g, "")
};
if (utils.isNull(postForumInfo.postPlateName)) {
postForumInfo.postPlateName = document.querySelector(
"#comiis_wx_title_box"
).innerText;
}
if (checkIsFilter(postForumInfo)) {
item.remove();
}
});
document.querySelectorAll(".comiis_postlist .comiis_postli").forEach((item) => {
let postForumInfo = {
/* 用户名 */
userName: item.querySelector("a.top_user").innerText,
/* 用户UID */
userUID: item.querySelector("a.top_user").href.match(MTRegExp.uid)[1].trim(),
/* 用户等级 */
userLevel: item.querySelector("a.top_lev").innerText.replace("Lv.", ""),
/* 帖子Url */
postUrl: void 0,
/* 帖子标题 */
postTitle: void 0,
/* 帖子内容(缩略) */
postContent: item.querySelector(
".comiis_message_table"
).innerText,
/* 帖子板块 */
postPlateName: void 0
};
if (checkIsFilter(postForumInfo)) {
item.remove();
}
});
}
if (Router.isMessageList()) {
this.getData();
document.querySelectorAll(".comiis_pms_box .comiis_pmlist ul li").forEach((item) => {
let postForumInfo = {
/* 用户名 */
userName: item.querySelector("h2").innerText.replace(
item.querySelector("h2 span").innerText,
""
).replace(/\s*/, ""),
/* 用户UID */
userUID: item.querySelector("a.b_b").href.match(MTRegExp.uid)[1].trim(),
/* 用户等级 */
userLevel: void 0,
/* 帖子Url */
postUrl: item.querySelector("a.b_b").href,
/* 帖子标题 */
postTitle: void 0,
/* 帖子内容(缩略) */
postContent: item.querySelector("p.f_c").innerText.trim(),
/* 帖子板块 */
postPlateName: void 0
};
if (checkIsFilter(postForumInfo)) {
item.remove();
}
});
}
},
/**
* 获取数据
*/
getData() {
return _GM_getValue(this.$key.STORAGE_KEY, []);
},
/**
* 设置数据
* @param data
*/
setData(data) {
_GM_setValue(this.$key.STORAGE_KEY, data);
},
/**
* 添加数据
* @param data
*/
addData(data) {
let localData = this.getData();
let findIndex = localData.findIndex((item) => item.uuid == data.uuid);
if (findIndex === -1) {
localData.push(data);
_GM_setValue(this.$key.STORAGE_KEY, localData);
return true;
} else {
return false;
}
},
/**
* 更新数据
* @param data
*/
updateData(data) {
let localData = this.getData();
let index = localData.findIndex((item) => item.uuid == data.uuid);
let updateFlag = false;
if (index !== -1) {
updateFlag = true;
localData[index] = data;
}
this.setData(localData);
return updateFlag;
},
/**
* 删除数据
* @param data
*/
deleteData(data) {
let localData = this.getData();
let index = localData.findIndex((item) => item.uuid == data.uuid);
let deleteFlag = false;
if (index !== -1) {
deleteFlag = true;
localData.splice(index, 1);
}
this.setData(localData);
return deleteFlag;
},
/**
* 清空数据
*/
clearData() {
_GM_deleteValue(this.$key.STORAGE_KEY);
}
};
const MTCommentFilter = {
$el: {
isFilterElementHTML: []
},
$key: {
STORAGE_KEY: "mt-post-comment-filter-rule"
},
init() {
this.registerMenu();
if (Router.isPost()) {
let allData = this.getData();
if (!allData.enable) {
return;
}
let lockFn = new utils.LockFunction(() => {
this.runFilter(allData);
});
utils.mutationObserver(document, {
config: {
subtree: true,
childList: true
},
callback: () => {
lockFn.run();
}
});
}
},
/**
* 注册菜单
*/
registerMenu() {
ElementUtils.registerLeftMenu({
name: "评论过滤器",
icon: "",
iconColor: "#ff0019",
callback: () => {
this.showView();
}
});
},
/**
* 执行过滤
*/
runFilter(filterData) {
let isBlackListUser = function(postForumInfo) {
for (const userName of filterData["userBlackList"]) {
if (userName == postForumInfo.userName || userName == postForumInfo.userUID) {
log.success("评论过滤器:黑名单用户", postForumInfo);
return true;
}
}
return false;
};
let isWhiteListUser = function(postForumInfo) {
for (const userName of filterData["userWhiteList"]) {
if (userName === postForumInfo.userName || userName === postForumInfo.userUID) {
log.success("评论过滤器:白名单用户", postForumInfo);
return true;
}
}
return false;
};
document.querySelectorAll(".comiis_postlist .comiis_postli").forEach((item) => {
var _a2, _b, _c, _d, _e, _f, _g;
if (item.querySelector("#comiis_allreplies")) {
return;
}
let postForumInfo = {
userName: ((_a2 = item.querySelector("a.top_user")) == null ? void 0 : _a2.innerText) || "",
userUID: ((_e = (_d = (_c = (_b = item.querySelector("a.top_user")) == null ? void 0 : _b.href) == null ? void 0 : _c.match(MTRegExp.uid)) == null ? void 0 : _d[1]) == null ? void 0 : _e.trim()) || "",
content: ((_g = (_f = item.querySelector(".comiis_message_table")) == null ? void 0 : _f.innerText) == null ? void 0 : _g.trim()) || "",
isAuthor: Boolean(item.querySelector("span.top_lev"))
};
if (isWhiteListUser(postForumInfo)) {
return;
}
if (filterData["replyFlag"] && item.querySelector(".comiis_quote")) {
let comiis_quote_Element = item.querySelector(".comiis_quote");
this.$el.isFilterElementHTML.push(comiis_quote_Element.outerHTML);
comiis_quote_Element.remove();
}
if (postForumInfo.isAuthor && !filterData["avatarFlag"]) {
return;
}
if (isBlackListUser(postForumInfo)) {
this.$el.isFilterElementHTML.push(item.outerHTML);
item.remove();
return;
}
if (typeof filterData["minLength"] === "number" && filterData["minLength"] > postForumInfo.content.length) {
return;
}
if (typeof filterData["keywordLength"] === "number" && filterData["keywordLength"] < postForumInfo.content.length) {
return;
}
for (const keywordItem of filterData["keywords"]) {
if (typeof keywordItem !== "string") {
continue;
}
let keywordPattern = new RegExp(keywordItem);
if (postForumInfo.content.match(keywordPattern)) {
console.log("评论过滤器:", postForumInfo);
this.$el.isFilterElementHTML.push(item.outerHTML);
item.remove();
return;
}
}
});
},
/**
* 显示视图
*/
showView() {
const that = this;
function generateStorageApi(data) {
return {
get(key, defaultValue) {
let localData = that.getData();
let value = Reflect.get(localData, key, defaultValue);
if (key === "keywords" || key === "userWhiteList" || key === "userBlackList") {
value = value.join("\n");
}
return value;
},
set(key, value) {
if (key === "keywords" || key === "userWhiteList" || key === "userBlackList") {
value = value.split("\n").filter((item) => item.trim() != "");
}
Reflect.set(data, key, value);
that.setData(data);
}
};
}
let popsPanelContentUtils = __pops.config.panelHandleContentUtils();
let view = new RuleEditView({
title: "评论过滤器",
data: () => {
return this.getData();
},
getView: (data) => {
let $fragment = document.createDocumentFragment();
let enable_template = UISwitch("启用", "enable", true);
Reflect.set(
enable_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $enable = popsPanelContentUtils.createSectionContainerItem_switch(
enable_template
);
let replyFlag_template = UISwitch(
"处理回复引用",
"replyFlag",
false,
void 0,
"移除引用"
);
Reflect.set(
replyFlag_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $replyFlag = popsPanelContentUtils.createSectionContainerItem_switch(
replyFlag_template
);
let avatarFlag_template = UISwitch("处理作者评论", "avatarFlag", false);
Reflect.set(
avatarFlag_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $avatarFlag = popsPanelContentUtils.createSectionContainerItem_switch(
avatarFlag_template
);
let viewthreadFlag_template = UISwitch(
'处理从"搜索页面"或"我的帖子提醒页面"进入的网站',
"viewthreadFlag",
false
);
Reflect.set(
viewthreadFlag_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $viewthreadFlag = popsPanelContentUtils.createSectionContainerItem_switch(
viewthreadFlag_template
);
let minLength_template = UIInput(
"匹配的评论内容长度最小值",
"minLength",
5,
"小于此长度的评论就算关键字匹配成功了也不会被排除",
void 0,
"",
true
);
Reflect.set(
minLength_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $minLength = popsPanelContentUtils.createSectionContainerItem_input(
minLength_template
);
let keywordLength = UIInput(
"匹配的评论内容长度最大值",
"keywordLength",
8,
"大于此长度的评论就算关键字匹配成功了也不会被排除",
void 0,
"",
true
);
Reflect.set(
keywordLength.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $keywordLength = popsPanelContentUtils.createSectionContainerItem_input(keywordLength);
let keywords_template = UITextArea(
"评论关键字",
"keywords",
"",
"多个关键字换行分割"
);
Reflect.set(
keywords_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $keywords = popsPanelContentUtils.createSectionContainerItem_textarea(
keywords_template
);
let userBlackList_template = UITextArea(
"黑名单用户",
"userBlackList",
"",
"多个用户换行分割"
);
Reflect.set(
userBlackList_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $userBlackList = popsPanelContentUtils.createSectionContainerItem_textarea(
userBlackList_template
);
let userWhiteList_template = UITextArea(
"白名单用户",
"userWhiteList",
"",
"多个用户换行分割"
);
Reflect.set(
userWhiteList_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $userWhiteList = popsPanelContentUtils.createSectionContainerItem_textarea(
userWhiteList_template
);
$fragment.append(
$enable,
$replyFlag,
$avatarFlag,
$viewthreadFlag,
$minLength,
$keywordLength,
$keywords,
$userBlackList,
$userWhiteList
);
return $fragment;
},
btn: {
merge: true,
position: "space-between",
ok: {
enable: false
},
cancel: {
enable: true,
text: "关闭"
},
other: {
enable: true,
text: `查看已过滤(${this.$el.isFilterElementHTML.length})`,
type: "primary",
callback: (details, event) => {
console.log(this.$el.isFilterElementHTML);
__pops.alert({
title: {
text: "评论过滤器-已过滤",
position: "center"
},
content: {
text: (
/*html*/
`
${Array.from(
document.querySelectorAll(
'link[rel="stylesheet"]'
)
).map((item) => item.outerHTML).join("\n")}
${this.$el.isFilterElementHTML.join("\n")}
`
),
html: true
},
btn: {
ok: {
type: "default",
text: "关闭"
}
},
mask: {
enable: true
},
width: window.innerWidth > 500 ? "500px" : "88vw",
height: window.innerHeight > 500 ? "500px" : "80vh"
});
}
}
},
dialogCloseCallBack(isSubmit) {
},
onsubmit: ($form, data) => {
return {
success: true,
data
};
},
style: (
/*css*/
`
.pops-panel-item-left-desc-text{
line-height: normal;
margin-top: 6px;
font-size: 0.8em;
color: rgb(108, 108, 108);
}
.pops-panel-item-left-main-text{
max-width: unset;
}
.pops-panel-textarea textarea{
height: 150px;
}
.comiis_postli_top h2,
.comiis_postli_top .top_lev{
height: auto;
}
`
)
});
view.showView();
},
/**
* 获取模板数据
*/
getTemplateData() {
return {
enable: true,
avatarFlag: false,
replyFlag: false,
viewthreadFlag: false,
minLength: 5,
keywordLength: 8,
keywords: [],
userBlackList: [],
userWhiteList: []
};
},
/**
* 获取数据
*/
getData() {
return _GM_getValue(
this.$key.STORAGE_KEY,
this.getTemplateData()
);
},
/**
* 设置数据
*/
setData(data) {
_GM_setValue(this.$key.STORAGE_KEY, data);
}
};
const MTProductListingReminder = {
$key: {
STORAGE_KEY: "mt-productListingReminder-rule"
},
init() {
this.registerMenu();
this.runRule();
},
/**
* 注册菜单
*/
registerMenu() {
ElementUtils.registerLeftMenu({
name: "商品上架提醒",
icon: "",
iconColor: "#2376b7",
callback: () => {
this.showView();
}
});
},
/**
* 执行规则
*/
async runRule() {
async function getCurrentProduct() {
let response = await httpx.get(
"/keke_integralmall-keke_integralmall.html",
{
fetch: true,
allowInterceptConfig: false
}
);
if (!response.status) {
Qmsg.error("【积分商城】获取数据失败");
return;
}
let productInfoList = [];
let doc = domUtils.parseHTML(response.data.responseText, true, true);
doc.querySelectorAll(".task-list-wrapper li.col-xs-12").forEach(($taskList) => {
var _a2, _b;
productInfoList.push({
name: domUtils.text(
$taskList.querySelector(
".mall-info a > *:first-child"
)
) || domUtils.text(
$taskList.querySelector(".mall-info a")
),
price: domUtils.text(
$taskList.querySelector(
".mall-info span.discount-price i"
)
),
endTime: domUtils.text(
$taskList.querySelector(
".mall-info #time_hz span.time"
)
),
remainingQuantity: parseInt(
((_b = (_a2 = $taskList.querySelector(".mall-info .mall-count .count-r")) == null ? void 0 : _a2.innerText) == null ? void 0 : _b.replace(/仅剩|件/gi, "")) || "0"
)
});
});
return productInfoList;
}
if (Router.isPointsMall()) {
return;
}
let allData = this.getData();
if (!allData.length) {
return;
}
let productList = await getCurrentProduct();
if (!productList) {
return;
}
for (const productItem of productList) {
for (const reminderOption of allData) {
if (reminderOption.enable && productItem["name"].match(
new RegExp(reminderOption["productName"], "i")
) && !isNaN(productItem["remainingQuantity"]) && productItem["remainingQuantity"] > 0) {
log.success(`成功匹配对应商品`, reminderOption, productItem);
__pops.confirm({
title: {
text: "积分商城提醒",
position: "center"
},
content: {
text: (
/*html*/
`<br />
您设置的商品已上架在积分商城中,当前售价 ${productItem["price"]}金币,仅剩${productItem["remainingQuantity"]}件,是否前往购买?
<a style="color: red !important;">(如需关闭提醒,请删除该关键字)</a>
<br />`
),
html: true
},
btn: {
merge: true,
position: "space-between",
other: {
enable: true,
type: "danger",
text: "删除提醒",
callback: () => {
let status = this.deleteData(reminderOption);
if (status) {
Qmsg.success("删除成功");
} else {
Qmsg.error("删除失败");
}
}
},
ok: {
text: "前往购买",
callback: () => {
window.location.href = `${window.location.origin}/keke_integralmall-keke_integralmall.html`;
}
}
},
width: "300px",
height: "300px"
});
return;
}
}
}
},
/**
* 获取模板数据
*/
getTemplateData() {
return {
uuid: utils.generateUUID(),
enable: true,
name: "",
productName: ""
};
},
/**
* 显示视图
*/
showView() {
let popsPanelContentUtils = __pops.config.panelHandleContentUtils();
function generateStorageApi(data) {
return {
get(key, defaultValue) {
return data[key] ?? defaultValue;
},
set(key, value) {
data[key] = value;
}
};
}
let ruleView = new RuleView({
title: "商品上架提醒",
data: () => {
return this.getData();
},
getAddData: () => {
return this.getTemplateData();
},
getDataItemName: (data) => {
return data["name"];
},
updateData: (data) => {
return this.updateData(data);
},
deleteData: (data) => {
return this.deleteData(data);
},
getData: (data) => {
let allData = this.getData();
let findValue = allData.find((item) => item.uuid === data.uuid);
return findValue ?? data;
},
itemControls: {
enable: {
enable: true,
getEnable(data) {
return data.enable;
},
callback: (data, enable) => {
data.enable = enable;
this.updateData(data);
}
},
edit: {
enable: true,
getView: (data, isEdit) => {
let $fragment = document.createDocumentFragment();
if (!isEdit) {
data = this.getTemplateData();
}
let enable_template = UISwitch("启用", "enable", true);
Reflect.set(
enable_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $enable = popsPanelContentUtils.createSectionContainerItem_switch(
enable_template
);
let name_template = UIInput(
"规则名称",
"name",
"",
"",
void 0,
"必填"
);
Reflect.set(
name_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $name = popsPanelContentUtils.createSectionContainerItem_input(
name_template
);
let productName_template = UIInput(
"商品名",
"productName",
"",
"",
void 0,
"可正则,需手动转义"
);
Reflect.set(
productName_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $productName = popsPanelContentUtils.createSectionContainerItem_input(
productName_template
);
$fragment.append($enable, $name, $productName);
return $fragment;
},
onsubmit: ($form, isEdit, editData) => {
let $ulist_li = $form.querySelectorAll(
".rule-form-ulist > li"
);
let data = this.getTemplateData();
if (isEdit) {
data.uuid = editData.uuid;
}
$ulist_li.forEach(($li) => {
let formConfig = Reflect.get($li, "__formConfig__");
let attrs = Reflect.get(formConfig, "attributes");
let storageApi = Reflect.get($li, PROPS_STORAGE_API);
let key = Reflect.get(attrs, ATTRIBUTE_KEY);
let defaultValue = Reflect.get(attrs, ATTRIBUTE_DEFAULT_VALUE);
let value = storageApi.get(key, defaultValue);
if (Reflect.has(data, key)) {
Reflect.set(data, key, value);
} else {
log.error(`${key}不在数据中`);
}
});
if (data.name.trim() === "") {
Qmsg.error("规则名称不能为空");
return {
success: false,
data
};
}
if (isEdit) {
return {
success: this.updateData(data),
data
};
} else {
return {
success: this.addData(data),
data
};
}
}
},
delete: {
enable: true,
deleteCallBack: (data) => {
return this.deleteData(data);
}
}
}
});
ruleView.showView();
},
/**
* 获取数据
*/
getData() {
return _GM_getValue(this.$key.STORAGE_KEY, []);
},
/**
* 设置数据
* @param data
*/
setData(data) {
_GM_setValue(this.$key.STORAGE_KEY, data);
},
/**
* 添加数据
* @param data
*/
addData(data) {
let localData = this.getData();
let findIndex = localData.findIndex((item) => item.uuid == data.uuid);
if (findIndex === -1) {
localData.push(data);
_GM_setValue(this.$key.STORAGE_KEY, localData);
return true;
} else {
return false;
}
},
/**
* 更新数据
* @param data
*/
updateData(data) {
let localData = this.getData();
let index = localData.findIndex((item) => item.uuid == data.uuid);
let updateFlag = false;
if (index !== -1) {
updateFlag = true;
localData[index] = data;
}
this.setData(localData);
return updateFlag;
},
/**
* 删除数据
* @param data
*/
deleteData(data) {
let localData = this.getData();
let index = localData.findIndex((item) => item.uuid == data.uuid);
let deleteFlag = false;
if (index !== -1) {
deleteFlag = true;
localData.splice(index, 1);
}
this.setData(localData);
return deleteFlag;
},
/**
* 清空数据
*/
clearData() {
_GM_deleteValue(this.$key.STORAGE_KEY);
}
};
const MTCustomizeUserLabels = {
$key: {
STORAGE_KEY: "mt-customizeUserLabels-rule"
},
init() {
this.registerMenu();
if (Router.isPage() || Router.isGuide() || Router.isPlate() || Router.isPost() || Router.isSearch() || Router.isSpace()) {
let allData = this.getData();
if (!allData.length) {
return;
}
let lockFn = new utils.LockFunction(() => {
this.runRule(allData);
});
utils.mutationObserver(document, {
config: {
subtree: true,
childList: true
},
callback: () => {
lockFn.run();
}
});
}
},
/**
* 注册菜单
*/
registerMenu() {
ElementUtils.registerLeftMenu({
name: "自定义用户标签",
icon: "",
iconColor: "#c70ea6",
callback: () => {
this.showView();
}
});
},
/**
* 显示视图
*/
showView() {
let popsPanelContentUtils = __pops.config.panelHandleContentUtils();
function generateStorageApi(data) {
return {
get(key, defaultValue) {
return data[key] ?? defaultValue;
},
set(key, value) {
data[key] = value;
}
};
}
let ruleView = new RuleView({
title: "自定义用户标签",
data: () => {
return this.getData();
},
getAddData: () => {
return this.getTemplateData();
},
getDataItemName: (data) => {
return data["name"];
},
updateData: (data) => {
return this.updateData(data);
},
deleteData: (data) => {
return this.deleteData(data);
},
getData: (data) => {
let allData = this.getData();
let findValue = allData.find((item) => item.uuid === data.uuid);
return findValue ?? data;
},
itemControls: {
enable: {
enable: true,
getEnable(data) {
return data.enable;
},
callback: (data, enable) => {
data.enable = enable;
this.updateData(data);
}
},
edit: {
enable: true,
getView: (data, isEdit) => {
var _a2;
let $fragment = document.createDocumentFragment();
if (!isEdit) {
data = this.getTemplateData();
}
let enable_template = UISwitch("启用", "enable", true);
Reflect.set(
enable_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $enable = popsPanelContentUtils.createSectionContainerItem_switch(
enable_template
);
let name_template = UIInput(
"规则名称",
"name",
"",
"",
void 0,
"必填"
);
Reflect.set(
name_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $name = popsPanelContentUtils.createSectionContainerItem_input(
name_template
);
let userUID_template = UIInput(
"用户UID",
"userUID",
"",
"",
void 0,
"必填,可正则,注意转义"
);
Reflect.set(
userUID_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $userUID = popsPanelContentUtils.createSectionContainerItem_input(
userUID_template
);
let labelName_template = UIInput(
"标签名",
"labelName",
"",
"",
void 0,
"必填"
);
Reflect.set(
labelName_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $labelName = popsPanelContentUtils.createSectionContainerItem_input(
labelName_template
);
let labelColor_template = UIInput(
"标签颜色",
"labelColor",
"",
""
);
Reflect.set(
labelColor_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $labelColor = popsPanelContentUtils.createSectionContainerItem_input(
labelColor_template
);
let $labelColor_input = $labelColor.querySelector("input");
(_a2 = $labelColor.querySelector(".pops-panel-input__suffix")) == null ? void 0 : _a2.remove();
$labelColor_input.setAttribute("type", "color");
domUtils.css($labelColor_input, {
margin: "unset",
padding: "unset",
width: "80px"
});
let labelStyle_template = UIInput(
"标签CSS",
"labelStyle",
"",
""
);
Reflect.set(
labelStyle_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $labelStyle = popsPanelContentUtils.createSectionContainerItem_input(
labelStyle_template
);
let labelClickEvent_template = UITextArea(
"标签点击事件",
"labelClickEvent",
"",
""
);
Reflect.set(
labelClickEvent_template.props,
PROPS_STORAGE_API,
generateStorageApi(data)
);
let $labelClickEvent = popsPanelContentUtils.createSectionContainerItem_textarea(
labelClickEvent_template
);
$fragment.append(
$enable,
$name,
$userUID,
$labelName,
$labelColor,
$labelStyle,
$labelClickEvent
);
return $fragment;
},
onsubmit: ($form, isEdit, editData) => {
let $ulist_li = $form.querySelectorAll(
".rule-form-ulist > li"
);
let data = this.getTemplateData();
if (isEdit) {
data.uuid = editData.uuid;
}
$ulist_li.forEach(($li) => {
let formConfig = Reflect.get($li, "__formConfig__");
let attrs = Reflect.get(formConfig, "attributes");
let storageApi = Reflect.get($li, PROPS_STORAGE_API);
let key = Reflect.get(attrs, ATTRIBUTE_KEY);
let defaultValue = Reflect.get(attrs, ATTRIBUTE_DEFAULT_VALUE);
let value = storageApi.get(key, defaultValue);
if (Reflect.has(data, key)) {
Reflect.set(data, key, value);
} else {
log.error(`${key}不在数据中`);
}
});
if (data.name.trim() === "") {
Qmsg.error("规则名称不能为空");
return {
success: false,
data
};
}
if (data.userUID.trim() === "") {
Qmsg.error("用户UID不能为空");
return {
success: false,
data
};
}
if (data.labelName.trim() === "") {
Qmsg.error("标签名不能为空");
return {
success: false,
data
};
}
if (isEdit) {
return {
success: this.updateData(data),
data
};
} else {
return {
success: this.addData(data),
data
};
}
},
style: (
/*css*/
`
.pops-panel-textarea textarea{
height: 150px;
}
`
)
},
delete: {
enable: true,
deleteCallBack: (data) => {
return this.deleteData(data);
}
}
}
});
ruleView.showView();
},
/**
* 执行规则
*/
runRule(ruleDataList) {
let forumList = utils.getNodeListValue(
ElementUtils.comiisForumList(),
ElementUtils.comiisPostli(),
ElementUtils.comiisMmlist()
);
if (!forumList.length) {
return;
}
forumList.forEach(($post) => {
if ($post.hasAttribute("data-custom-label")) {
return;
}
$post.setAttribute("data-custom-label", "true");
let mt_uid_array = Array.from($post.querySelectorAll("a")).map((item) => {
let url = item.href;
let uid = url.match(MTRegExp.uid);
if (uid) {
return uid[uid.length - 1];
}
}).filter((item) => item != null);
if (mt_uid_array.length) {
let mt_uid = mt_uid_array[0];
let ownLabelList = ruleDataList.filter(
(item) => item.enable && mt_uid.match(new RegExp(item.userUID))
);
if (!ownLabelList.length) {
return;
}
let $label = document.createElement("a");
let $topLev = $post.querySelector(".top_lev");
ownLabelList.forEach((labelOption) => {
$label.className = $topLev.className;
$label.classList.add("gm-custom-label");
$label.style.cssText = `
background: ${labelOption.labelColor} !important;${labelOption.labelStyle || ""}`;
$label.innerHTML = labelOption.labelName;
domUtils.on($label, "click", async (event) => {
utils.preventEvent(event);
if (utils.isNotNull(labelOption.labelClickEvent)) {
_unsafeWindow.eval(labelOption.labelClickEvent);
}
});
$topLev.parentElement.append($label);
});
}
});
},
/**
* 获取模板数据
*/
getTemplateData() {
return {
uuid: utils.generateUUID(),
enable: true,
name: "",
userUID: "",
labelName: "",
labelColor: "",
labelStyle: "",
labelClickEvent: ""
};
},
/**
* 获取数据
*/
getData() {
return _GM_getValue(this.$key.STORAGE_KEY, []);
},
/**
* 设置数据
* @param data
*/
setData(data) {
_GM_setValue(this.$key.STORAGE_KEY, data);
},
/**
* 添加数据
* @param data
*/
addData(data) {
let localData = this.getData();
let findIndex = localData.findIndex((item) => item.uuid == data.uuid);
if (findIndex === -1) {
localData.push(data);
_GM_setValue(this.$key.STORAGE_KEY, localData);
return true;
} else {
return false;
}
},
/**
* 更新数据
* @param data
*/
updateData(data) {
let localData = this.getData();
let index = localData.findIndex((item) => item.uuid == data.uuid);
let updateFlag = false;
if (index !== -1) {
updateFlag = true;
localData[index] = data;
}
this.setData(localData);
return updateFlag;
},
/**
* 删除数据
* @param data
*/
deleteData(data) {
let localData = this.getData();
let index = localData.findIndex((item) => item.uuid == data.uuid);
let deleteFlag = false;
if (index !== -1) {
deleteFlag = true;
localData.splice(index, 1);
}
this.setData(localData);
return deleteFlag;
},
/**
* 清空数据
*/
clearData() {
_GM_deleteValue(this.$key.STORAGE_KEY);
}
};
const MTForumPostPublish = {
init() {
domUtils.ready(() => {
PopsPanel.execMenuOnce("mt-forum-post-publish-editorOptimization", () => {
MTEditorOptimization.init();
});
});
}
};
const MT = {
$flag: {
showUserUID_initCSS: false
},
init() {
if (Router.isPage() || Router.isGuide() || Router.isPlate() || Router.isPost() || Router.isSearch() || Router.isSpace()) {
PopsPanel.execMenuOnce("mt-show-user-uid", () => {
this.showUserUID();
});
}
if (Router.isSearch() || Router.isGuide() || Router.isSpace() || Router.isPlate()) {
PopsPanel.execMenuOnce("mt-small-window", () => {
MTSmallWindow.init();
});
}
if (Router.isPost()) {
log.info(`Router: 帖子`);
MTForumPost.init();
} else if (Router.isSearch()) {
log.info(`Router: 搜索`);
MTSearch.init();
} else if (Router.isKMiSign()) {
log.info(`Router: 签到`);
MTSign.init();
} else if (Router.isSpace() || Router.isSpaceWithAt()) {
log.info(`Router: 空间`);
MTSpace.init();
} else if (Router.isGuide()) {
log.info(`Router: 导读`);
MTGuide.init();
} else if (Router.isPostPublish()) {
log.info("Router: 发帖页面");
MTForumPostPublish.init();
} else {
log.error(`Router: 未适配的链接 ==> ` + window.location.href);
}
domUtils.ready(() => {
PopsPanel.execMenuOnce("mt-black-home", () => {
MTBlackHome.init();
});
PopsPanel.execMenuOnce("mt-online-user", () => {
MTOnlineUser.init();
});
PopsPanel.execMenuOnce("mt-post-paidThemePost", () => {
MTPaidThemePost.init();
});
PopsPanel.execMenuOnce("mt-ownBlock", () => {
MTOwnBlock.init();
});
PopsPanel.execMenuOnce("mt-post-comment-filter", () => {
MTCommentFilter.init();
});
PopsPanel.execMenuOnce("mt-productListingReminder", () => {
MTProductListingReminder.init();
});
PopsPanel.execMenuOnce("mt-customizeUserLabels", () => {
MTCustomizeUserLabels.init();
});
PopsPanel.execMenuOnce("mt-link-text-to-hyperlink", () => {
MTIdentifyLinks();
});
PopsPanel.execMenu("mt-auto-sign", () => {
MTAutoSignIn.init();
});
});
},
/**
* 显示用户UID
*/
showUserUID() {
log.info(`显示用户UID`);
if (!this.$flag.showUserUID_initCSS) {
this.$flag.showUserUID_initCSS = true;
addStyle(
/*css*/
`
.postli_top_tximg + h2{
height: auto;
}
.comiis_postli_top.bg_f.b_t h2{
height: auto;
}
`
);
}
let lockFn = new utils.LockFunction(() => {
let forumList = utils.getNodeListValue(
ElementUtils.comiisForumList(),
ElementUtils.comiisPostli(),
ElementUtils.comiisMmlist()
);
if (forumList.length) {
forumList.forEach(($post) => {
let mtUIDOM = $post.querySelector(".gm-custom-label-uid");
if (mtUIDOM) {
return;
}
let mt_uid_array = Array.from($post.querySelectorAll("a")).map((item) => {
let url = item.href;
let uid = url.match(MTRegExp.uid);
if (uid) {
return uid[uid.length - 1];
}
}).filter((item) => item != null);
if (mt_uid_array.length) {
let mt_uid = mt_uid_array[0];
let uid_control = document.createElement("a");
let $topLev = $post.querySelector(".top_lev");
uid_control.className = $topLev.className;
uid_control.classList.add("gm-custom-label-uid");
uid_control.style.cssText = `background: #FF7600 !important;`;
uid_control.innerHTML = "UID:" + mt_uid;
domUtils.on(uid_control, "click", async (event) => {
utils.preventEvent(event);
let status = await utils.setClip(mt_uid);
if (status) {
Qmsg.success(`${mt_uid}已复制`);
} else {
Qmsg.error(`${mt_uid}复制失败`);
}
});
$topLev.parentElement.append(uid_control);
}
});
}
});
utils.mutationObserver(document, {
config: {
subtree: true,
childList: true
},
callback() {
lockFn.run();
}
});
}
};
PopsPanel.init();
MT.init();
}
});
require_entrance_001();
})(Qmsg, DOMUtils, Utils, pops, Viewer, hljs);