【移动端】MT论坛优化

MT论坛效果增强,如自动签到、自动展开帖子、滚动加载评论、显示UID、自定义屏蔽、手机版小黑屋、编辑器优化、在线用户查看、便捷式图床、自定义用户标签、积分商城商品上架提醒等

// ==UserScript==
// @name         【移动端】MT论坛优化
// @namespace    https://greasyfork.org/zh-CN/scripts/401359
// @version      2024.12.29
// @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.6/dist/index.umd.js
// @require      https://fastly.jsdelivr.net/npm/@whitesev/domutils@1.4.8/dist/index.umd.js
// @require      https://fastly.jsdelivr.net/npm/@whitesev/pops@1.9.6/dist/index.umd.js
// @require      https://fastly.jsdelivr.net/npm/qmsg@1.2.8/dist/index.umd.js
// @require      https://fastly.jsdelivr.net/npm/viewerjs@1.11.7/dist/viewer.min.js
// @require      https://fastly.jsdelivr.net/npm/@highlightjs/cdn-assets@11.11.0/highlight.min.js
// @resource     HljsCSS    https://fastly.jsdelivr.net/npm/highlight.js@11.11.0/styles/github-dark.min.css
// @resource     ViewerCSS  https://fastly.jsdelivr.net/npm/viewerjs@1.11.7/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-Dn8rrrdJ.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 MTRegExp = {
        /** 论坛账号的凭证 */
        formhash: /formhash=([0-9a-zA-Z]+)/,
        /** 论坛账号的凭证 */
        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 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
         */
        getFormHash() {
          let $inputFormHashList = Array.from(
            (top || globalThis).document.querySelectorAll(
              "input[name=formhash]"
            )
          );
          for (let index = 0; index < $inputFormHashList.length; index++) {
            const $input = $inputFormHashList[index];
            let formHash = $input.value;
            if (formHash) {
              return formHash;
            }
          }
          let $anchorFormHashList = Array.from(
            (top || globalThis).document.querySelectorAll(
              'a[href*="formhash="]'
            )
          );
          for (let index = 0; index < $anchorFormHashList.length; index++) {
            const $anchorFormHash = $anchorFormHashList[index];
            let anchorFormHashMatch = $anchorFormHash.href.match(MTRegExp.formhash);
            if (anchorFormHashMatch) {
              let formHash = anchorFormHashMatch[anchorFormHashMatch.length - 1];
              if (formHash) {
                return formHash;
              }
            }
          }
        },
        /**
         * 检测环境模板
         */
        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.getFormHash();
                    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 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"
                },
                fetch: true,
                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"
                    },
                    fetch: true,
                    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", "&#xe63b;");
                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", "&#xe654;");
                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() {
            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);
        },
        /**
         * 检测是否登录
         */
        checkLogin() {
          if (MTUtils.envIsMobile()) {
            let mobile_login_exitBtn = $(
              ".sidenv_exit a[href*='member.php?mod=logging&action=logout']"
            );
            return mobile_login_exitBtn;
          } else {
            let pc_login = $("#comiis_key");
            return pc_login;
          }
        },
        /**
         * 签到
         */
        async sign() {
          let formHash = MTUtils.getFormHash();
          if (formHash == null) {
            if ($("#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("今日已签") || 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(&quot;https://s1.ax1x.com/2020/04/26/Jcq8VU.png&quot;); 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&amp;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&amp;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(/^&nbsp;/, "");
              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(/^&nbsp;/, "");
                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 = this.enterGestureBackMode.bind(this);
          this.quitGestureBackMode = this.quitGestureBackMode.bind(this);
          this.popStateEvent = 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, {
            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, {
            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({
            hash: this.$key.smallWindow,
            useUrl: true,
            win: _unsafeWindow,
            beforeHistoryBackCallBack: (isUrlChange) => {
              $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 $topUser = item.querySelector("a.top_user");
              let uidMatch = $topUser.href.match(MTRegExp.uid);
              let postForumInfo = {
                /* 用户名 */
                userName: $topUser.innerText,
                /* 用户UID */
                userUID: uidMatch[uidMatch.length - 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 $topUser = item.querySelector("a.top_user");
              let uidMatch = $topUser.href.match(MTRegExp.uid);
              let postForumInfo = {
                /* 用户名 */
                userName: $topUser.innerText,
                /* 用户UID */
                userUID: uidMatch[uidMatch.length - 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();
            $$(".comiis_pms_box .comiis_pmlist ul li").forEach(
              (item) => {
                let uidMatch = item.querySelector("a.b_b").href.match(MTRegExp.uid);
                let postForumInfo = {
                  /* 用户名 */
                  userName: item.querySelector("h2").innerText.replace(
                    item.querySelector("h2 span").innerText,
                    ""
                  ).replace(/\s*/, ""),
                  /* 用户UID */
                  userUID: uidMatch[uidMatch.length - 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;
          };
          $$(".comiis_postlist .comiis_postli").forEach((item) => {
            var _a2, _b, _c;
            if (item.querySelector("#comiis_allreplies")) {
              return;
            }
            let $topUser = item.querySelector("a.top_user");
            let uidMatch = $topUser.href.match(MTRegExp.uid);
            let postForumInfo = {
              userName: ($topUser == null ? void 0 : $topUser.innerText) || "",
              userUID: uidMatch ? ((_a2 = uidMatch[(uidMatch == null ? void 0 : uidMatch.length) - 1]) == null ? void 0 : _a2.trim()) || "" : "",
              content: ((_c = (_b = item.querySelector(".comiis_message_table")) == null ? void 0 : _b.innerText) == null ? void 0 : _c.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);